X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fdaemon%2Fplugin.h;h=9a9bf497607d0a7240e287421d95dc6fe8149735;hb=8acc85b19e44c9bc106484b95cd352d867abdf1c;hp=73982279a665767650e41ef616731fe4960a1125;hpb=f16ca847fd053e954519bae596e456ab84c91719;p=collectd.git diff --git a/src/daemon/plugin.h b/src/daemon/plugin.h index 73982279..9a9bf497 100644 --- a/src/daemon/plugin.h +++ b/src/daemon/plugin.h @@ -29,18 +29,17 @@ #define PLUGIN_H #include "collectd.h" + #include "configfile.h" #include "meta_data.h" #include "utils_time.h" -#if HAVE_PTHREAD_H -# include -#endif +#include #define PLUGIN_FLAGS_GLOBAL 0x0001 #ifndef DATA_MAX_NAME_LEN -# define DATA_MAX_NAME_LEN 64 +# define DATA_MAX_NAME_LEN 128 #endif #define DS_TYPE_COUNTER 0 @@ -82,6 +81,16 @@ /* * Public data types */ +struct identifier_s +{ + char *host; + char *plugin; + char *plugin_instance; + char *type; + char *type_instance; +}; +typedef struct identifier_s identifier_t; + typedef unsigned long long counter_t; typedef double gauge_t; typedef int64_t derive_t; @@ -111,9 +120,7 @@ struct value_list_s }; typedef struct value_list_s value_list_t; -#define VALUE_LIST_INIT { NULL, 0, 0, plugin_get_interval (), \ - "localhost", "", "", "", "", NULL } -#define VALUE_LIST_STATIC { NULL, 0, 0, 0, "localhost", "", "", "", "", NULL } +#define VALUE_LIST_INIT { .values = NULL, .meta = NULL } struct data_source_s { @@ -202,7 +209,6 @@ typedef void (*plugin_log_cb) (int severity, const char *message, typedef int (*plugin_shutdown_cb) (void); typedef int (*plugin_notification_cb) (const notification_t *, user_data_t *); - /* * NAME * plugin_set_dir @@ -298,20 +304,20 @@ int plugin_register_read (const char *name, int plugin_register_complex_read (const char *group, const char *name, plugin_read_cb callback, cdtime_t interval, - user_data_t *user_data); + user_data_t const *user_data); int plugin_register_write (const char *name, - plugin_write_cb callback, user_data_t *user_data); + plugin_write_cb callback, user_data_t const *user_data); int plugin_register_flush (const char *name, - plugin_flush_cb callback, user_data_t *user_data); + plugin_flush_cb callback, user_data_t const *user_data); int plugin_register_missing (const char *name, - plugin_missing_cb callback, user_data_t *user_data); + plugin_missing_cb callback, user_data_t const *user_data); int plugin_register_shutdown (const char *name, plugin_shutdown_cb callback); int plugin_register_data_set (const data_set_t *ds); int plugin_register_log (const char *name, - plugin_log_cb callback, user_data_t *user_data); + plugin_log_cb callback, user_data_t const *user_data); int plugin_register_notification (const char *name, - plugin_notification_cb callback, user_data_t *user_data); + plugin_notification_cb callback, user_data_t const *user_data); int plugin_unregister_config (const char *name); int plugin_unregister_complex_config (const char *name); @@ -459,7 +465,7 @@ cdtime_t plugin_get_interval (void); */ int plugin_thread_create (pthread_t *thread, const pthread_attr_t *attr, - void *(*start_routine) (void *), void *arg); + void *(*start_routine) (void *), void *arg, char const *name); /* * Plugins need to implement this