X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fdaemon%2Fplugin_mock.c;h=1624f0ea9f2a92f0ee79e2344d84950b574252ed;hb=54619dc85fd308b21ed09a0271e5c7383c7921b9;hp=e01e2569429e3f10e91683f3bbd4df102af690b8;hpb=92860d61218a3da1e9b74a2fad37e9df88df8ce8;p=collectd.git diff --git a/src/daemon/plugin_mock.c b/src/daemon/plugin_mock.c index e01e2569..1624f0ea 100644 --- a/src/daemon/plugin_mock.c +++ b/src/daemon/plugin_mock.c @@ -26,67 +26,180 @@ #include "plugin.h" +#if HAVE_KSTAT_H +#include +#endif + #if HAVE_LIBKSTAT kstat_ctl_t *kc = NULL; #endif /* HAVE_LIBKSTAT */ -char hostname_g[] = "example.com"; +char *hostname_g = "example.com"; + +void plugin_set_dir(const char *dir) { /* nop */ +} + +int plugin_load(const char *name, bool global) { return ENOTSUP; } + +int plugin_register_config(const char *name, + int (*callback)(const char *key, const char *val), + const char **keys, int keys_num) { + return ENOTSUP; +} + +int plugin_register_complex_config(const char *type, + int (*callback)(oconfig_item_t *)) { + return ENOTSUP; +} + +int plugin_register_init(const char *name, plugin_init_cb callback) { + return ENOTSUP; +} + +int plugin_register_read(__attribute__((unused)) const char *name, + __attribute__((unused)) int (*callback)(void)) { + return ENOTSUP; +} + +int plugin_register_write(__attribute__((unused)) const char *name, + __attribute__((unused)) plugin_write_cb callback, + __attribute__((unused)) user_data_t const *ud) { + return ENOTSUP; +} + +int plugin_register_missing(const char *name, plugin_missing_cb callback, + user_data_t const *ud) { + return ENOTSUP; +} + +int plugin_register_complex_read(const char *group, const char *name, + int (*callback)(user_data_t *), + cdtime_t interval, + user_data_t const *user_data) { + return ENOTSUP; +} + +int plugin_register_shutdown(const char *name, int (*callback)(void)) { + return ENOTSUP; +} + +int plugin_register_data_set(const data_set_t *ds) { return ENOTSUP; } -int plugin_register_complex_config (const char *type, int (*callback) (oconfig_item_t *)) -{ +int plugin_dispatch_values(value_list_t const *vl) { return ENOTSUP; } + +int plugin_dispatch_notification(__attribute__((unused)) + const notification_t *notif) { return ENOTSUP; } -int plugin_register_init (const char *name, plugin_init_cb callback) -{ +int plugin_notification_meta_add_string(__attribute__((unused)) + notification_t *n, + __attribute__((unused)) + const char *name, + __attribute__((unused)) + const char *value) { return ENOTSUP; } -int plugin_register_read (const char *name, int (*callback) (void)) -{ +int plugin_notification_meta_add_signed_int(__attribute__((unused)) + notification_t *n, + __attribute__((unused)) + const char *name, + __attribute__((unused)) + int64_t value) { return ENOTSUP; } -int plugin_register_shutdown (const char *name, int (*callback) (void)) -{ +int plugin_notification_meta_add_unsigned_int(__attribute__((unused)) + notification_t *n, + __attribute__((unused)) + const char *name, + __attribute__((unused)) + uint64_t value) { return ENOTSUP; } -int plugin_dispatch_values (value_list_t const *vl) -{ +int plugin_notification_meta_add_double(__attribute__((unused)) + notification_t *n, + __attribute__((unused)) + const char *name, + __attribute__((unused)) double value) { return ENOTSUP; } -int plugin_flush (const char *plugin, cdtime_t timeout, const char *identifier) -{ +int plugin_notification_meta_add_boolean(__attribute__((unused)) + notification_t *n, + __attribute__((unused)) + const char *name, + __attribute__((unused)) _Bool value) { return ENOTSUP; } -static data_source_t magic_ds[] = {{ "value", DS_TYPE_DERIVE, 0.0, NAN }}; -static data_set_t magic = { "MAGIC", 1, magic_ds }; -const data_set_t *plugin_get_ds (const char *name) -{ - if (strcmp (name, "MAGIC")) +int plugin_notification_meta_copy(__attribute__((unused)) notification_t *dst, + __attribute__((unused)) + const notification_t *src) { + return ENOTSUP; +} + +int plugin_notification_meta_free(__attribute__((unused)) + notification_meta_t *n) { + return ENOTSUP; +} + +int plugin_flush(const char *plugin, cdtime_t timeout, const char *identifier) { + return ENOTSUP; +} + +static data_source_t magic_ds[] = {{"value", DS_TYPE_DERIVE, 0.0, NAN}}; +static data_set_t magic = {"MAGIC", 1, magic_ds}; +const data_set_t *plugin_get_ds(const char *name) { + if (strcmp(name, "MAGIC")) return NULL; return &magic; } -void plugin_log (int level, char const *format, ...) -{ +void plugin_log(int level, char const *format, ...) { + char buffer[1024]; + va_list ap; + + va_start(ap, format); + vsnprintf(buffer, sizeof(buffer), format, ap); + va_end(ap); + + printf("plugin_log (%i, \"%s\");\n", level, buffer); +} + +void daemon_log(int level, char const *format, ...) { char buffer[1024]; va_list ap; - va_start (ap, format); - vsnprintf (buffer, sizeof (buffer), format, ap); - va_end (ap); + va_start(ap, format); + vsnprintf(buffer, sizeof(buffer), format, ap); + va_end(ap); + + printf("daemon_log (%i, \"%s\");\n", level, buffer); +} - printf ("plugin_log (%i, \"%s\");\n", level, buffer); +void plugin_init_ctx(void) { /* nop */ } -cdtime_t plugin_get_interval (void) -{ - return TIME_T_TO_CDTIME_T (10); +plugin_ctx_t mock_context = { + .interval = TIME_T_TO_CDTIME_T_STATIC(10), +}; + +plugin_ctx_t plugin_get_ctx(void) { return mock_context; } + +plugin_ctx_t plugin_set_ctx(plugin_ctx_t ctx) { + plugin_ctx_t prev = mock_context; + mock_context = ctx; + return prev; } -/* vim: set sw=2 sts=2 et : */ +cdtime_t plugin_get_interval(void) { return mock_context.interval; } + +/* TODO(octo): this function is actually from filter_chain.h, but in order not + * to tumble down that rabbit hole, we're declaring it here. A better solution + * would be to hard-code the top-level config keys in daemon/collectd.c to avoid + * having these references in daemon/configfile.c. */ +int fc_configure(const oconfig_item_t *ci) { return ENOTSUP; }