X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fcommon.h;h=f463b77e0c3b6f95707a4092d8f5310979ce3b5e;hb=068ae14b916aa298995433da83302032c5e57c76;hp=e99aea697e45f854b30a50d0b089b8cf20ddf406;hpb=759c544568c019721fe868e7c319bd1471fd501c;p=collectd.git diff --git a/src/common.h b/src/common.h index e99aea69..f463b77e 100644 --- a/src/common.h +++ b/src/common.h @@ -31,14 +31,17 @@ #endif #define sfree(ptr) \ - if((ptr) != NULL) { \ - free(ptr); \ - } \ - (ptr) = NULL + do { \ + if((ptr) != NULL) { \ + free(ptr); \ + } \ + (ptr) = NULL; \ + } while (0) #define STATIC_ARRAY_SIZE(a) (sizeof (a) / sizeof (*(a))) char *sstrncpy (char *dest, const char *src, size_t n); +int ssnprintf (char *dest, size_t n, const char *format, ...); char *sstrdup(const char *s); void *smalloc(size_t size); char *sstrerror (int errnum, char *buf, size_t buflen); @@ -199,4 +202,11 @@ int notification_init (notification_t *n, int severity, const char *message, notification_init (n, NOTIF_FAILURE, NULL, \ (vl)->host, (vl)->plugin, (vl)->plugin_instance, \ (ds)->type, (vl)->type_instance) + +typedef int (*dirwalk_callback_f)(const char *dirname, const char *filename, + void *user_data); +int walk_directory (const char *dir, dirwalk_callback_f callback, + void *user_data); +int read_file_contents (const char *filename, char *buf, int bufsize); + #endif /* COMMON_H */