2 * collectd - src/types_list.c
3 * Copyright (C) 2007 Florian octo Forster
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
12 * The above copyright notice and this permission notice shall be included in
13 * all copies or substantial portions of the Software.
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
21 * DEALINGS IN THE SOFTWARE.
24 * Florian octo Forster <octo at collectd.org>
31 #include "configfile.h"
33 #include "types_list.h"
35 static int parse_ds(data_source_t *dsrc, char *buf, size_t buf_len) {
42 ERROR("parse_ds: (buf_len = %zu) < 11", buf_len);
46 if (buf[buf_len - 1] == ',') {
55 while (fields_num < 8) {
56 if ((fields[fields_num] = strtok_r(dummy, ":", &saveptr)) == NULL)
62 if (fields_num != 4) {
63 ERROR("parse_ds: (fields_num = %i) != 4", fields_num);
67 sstrncpy(dsrc->name, fields[0], sizeof(dsrc->name));
69 if (strcasecmp(fields[1], "GAUGE") == 0)
70 dsrc->type = DS_TYPE_GAUGE;
71 else if (strcasecmp(fields[1], "COUNTER") == 0)
72 dsrc->type = DS_TYPE_COUNTER;
73 else if (strcasecmp(fields[1], "DERIVE") == 0)
74 dsrc->type = DS_TYPE_DERIVE;
75 else if (strcasecmp(fields[1], "ABSOLUTE") == 0)
76 dsrc->type = DS_TYPE_ABSOLUTE;
78 ERROR("(fields[1] = %s) != (GAUGE || COUNTER || DERIVE || ABSOLUTE)",
83 if (strcasecmp(fields[2], "U") == 0)
86 dsrc->min = atof(fields[2]);
88 if (strcasecmp(fields[3], "U") == 0)
91 dsrc->max = atof(fields[3]);
96 static void parse_line(char *buf) {
101 fields_num = strsplit(buf, fields, 64);
105 /* Ignore lines which begin with a hash sign. */
106 if (fields[0][0] == '#')
109 ds = calloc(1, sizeof(*ds));
113 sstrncpy(ds->type, fields[0], sizeof(ds->type));
115 ds->ds_num = fields_num - 1;
116 ds->ds = (data_source_t *)calloc(ds->ds_num, sizeof(data_source_t));
117 if (ds->ds == NULL) {
122 for (size_t i = 0; i < ds->ds_num; i++)
123 if (parse_ds(ds->ds + i, fields[i + 1], strlen(fields[i + 1])) != 0) {
124 ERROR("types_list: parse_line: Cannot parse data source #%zu "
132 plugin_register_data_set(ds);
136 } /* void parse_line */
138 static void parse_file(FILE *fh) {
142 while (fgets(buf, sizeof(buf), fh) != NULL) {
143 buf_len = strlen(buf);
145 if (buf_len >= 4095) {
146 NOTICE("Skipping line with more than 4095 characters.");
148 if (fgets(buf, sizeof(buf), fh) == NULL)
150 buf_len = strlen(buf);
151 } while (buf_len >= 4095);
153 } /* if (buf_len >= 4095) */
155 if ((buf_len == 0) || (buf[0] == '#'))
158 while ((buf_len > 0) &&
159 ((buf[buf_len - 1] == '\n') || (buf[buf_len - 1] == '\r')))
160 buf[--buf_len] = '\0';
166 } /* while (fgets) */
167 } /* void parse_file */
169 int read_types_list(const char *file) {
175 fh = fopen(file, "r");
178 fprintf(stderr, "Failed to open types database `%s': %s.\n", file,
179 sstrerror(errno, errbuf, sizeof(errbuf)));
180 ERROR("Failed to open types database `%s': %s", file,
181 sstrerror(errno, errbuf, sizeof(errbuf)));
190 DEBUG("Done parsing `%s'", file);
193 } /* int read_types_list */