X-Git-Url: https://git.octo.it/?a=blobdiff_plain;ds=sidebyside;f=src%2Fcollectd-nagios.c;h=e31d95ca31f3e52ebd2923e0482b3e7f7973f294;hb=96e0f2341bace029acefe0a88bab96ae326c0ff5;hp=d3923f1fcab46b00c29ca6f46208839d21415b2f;hpb=03326eeaf8819d87786b132b80a0e772a9c5e2b0;p=collectd.git diff --git a/src/collectd-nagios.c b/src/collectd-nagios.c index d3923f1f..e31d95ca 100644 --- a/src/collectd-nagios.c +++ b/src/collectd-nagios.c @@ -66,7 +66,7 @@ # endif #endif /* NAN_ZERO_ZERO */ -#include "libcollectdclient/client.h" +#include "libcollectdclient/collectd/client.h" #define RET_OKAY 0 #define RET_WARNING 1 @@ -274,6 +274,8 @@ static int do_listval (lcc_connection_t *connection) lcc_identifier_t *ret_ident = NULL; size_t ret_ident_num = 0; + char *hostname = NULL; + int status; size_t i; @@ -285,9 +287,31 @@ static int do_listval (lcc_connection_t *connection) return (RET_UNKNOWN); } + status = lcc_sort_identifiers (connection, ret_ident, ret_ident_num); + if (status != 0) { + printf ("UNKNOWN: %s\n", lcc_strerror (connection)); + if (ret_ident != NULL) + free (ret_ident); + return (RET_UNKNOWN); + } + for (i = 0; i < ret_ident_num; ++i) { char id[1024]; + if ((hostname_g != NULL) && (strcasecmp (hostname_g, ret_ident[i].host))) + continue; + + if ((hostname == NULL) || strcasecmp (hostname, ret_ident[i].host)) + { + if (hostname != NULL) + free (hostname); + hostname = strdup (ret_ident[i].host); + printf ("Host: %s\n", hostname); + } + + /* empty hostname; not to be printed again */ + ret_ident[i].host[0] = '\0'; + status = lcc_identifier_to_string (connection, id, sizeof (id), ret_ident + i); if (status != 0) { @@ -297,7 +321,8 @@ static int do_listval (lcc_connection_t *connection) continue; } - printf ("%s\n", id); + /* skip over the (empty) hostname and following '/' */ + printf ("\t%s\n", id + 1); } if (ret_ident != NULL)