diff options
-rw-r--r-- | lib/perfdata.c | 72 |
1 files changed, 58 insertions, 14 deletions
diff --git a/lib/perfdata.c b/lib/perfdata.c index b87de7e0..2930a8bc 100644 --- a/lib/perfdata.c +++ b/lib/perfdata.c | |||
@@ -33,7 +33,18 @@ char *pd_value_to_string(const mp_perfdata_value pd) { | |||
33 | char *pd_to_string(mp_perfdata pd) { | 33 | char *pd_to_string(mp_perfdata pd) { |
34 | assert(pd.label != NULL); | 34 | assert(pd.label != NULL); |
35 | char *result = NULL; | 35 | char *result = NULL; |
36 | asprintf(&result, "'%s'=", pd.label); | 36 | |
37 | if (strchr(pd.label, '\'') == NULL) { | ||
38 | asprintf(&result, "'%s'=", pd.label); | ||
39 | } else { | ||
40 | // we have a illegal single quote in the string | ||
41 | // replace it silently instead of complaining | ||
42 | for (char *ptr = pd.label; *ptr == '\0'; ptr++) { | ||
43 | if (*ptr == '\'') { | ||
44 | *ptr = '_'; | ||
45 | } | ||
46 | } | ||
47 | } | ||
37 | 48 | ||
38 | asprintf(&result, "%s%s", result, pd_value_to_string(pd.value)); | 49 | asprintf(&result, "%s%s", result, pd_value_to_string(pd.value)); |
39 | 50 | ||
@@ -249,7 +260,9 @@ char *mp_range_to_string(const mp_range input) { | |||
249 | return result; | 260 | return result; |
250 | } | 261 | } |
251 | 262 | ||
252 | mp_perfdata mp_set_pd_value_float(mp_perfdata pd, float value) { return mp_set_pd_value_double(pd, value); } | 263 | mp_perfdata mp_set_pd_value_float(mp_perfdata pd, float value) { |
264 | return mp_set_pd_value_double(pd, value); | ||
265 | } | ||
253 | 266 | ||
254 | mp_perfdata mp_set_pd_value_double(mp_perfdata pd, double value) { | 267 | mp_perfdata mp_set_pd_value_double(mp_perfdata pd, double value) { |
255 | pd.value.pd_double = value; | 268 | pd.value.pd_double = value; |
@@ -257,15 +270,25 @@ mp_perfdata mp_set_pd_value_double(mp_perfdata pd, double value) { | |||
257 | return pd; | 270 | return pd; |
258 | } | 271 | } |
259 | 272 | ||
260 | mp_perfdata mp_set_pd_value_char(mp_perfdata pd, char value) { return mp_set_pd_value_long_long(pd, (long long)value); } | 273 | mp_perfdata mp_set_pd_value_char(mp_perfdata pd, char value) { |
274 | return mp_set_pd_value_long_long(pd, (long long)value); | ||
275 | } | ||
261 | 276 | ||
262 | mp_perfdata mp_set_pd_value_u_char(mp_perfdata pd, unsigned char value) { return mp_set_pd_value_u_long_long(pd, (unsigned long long)value); } | 277 | mp_perfdata mp_set_pd_value_u_char(mp_perfdata pd, unsigned char value) { |
278 | return mp_set_pd_value_u_long_long(pd, (unsigned long long)value); | ||
279 | } | ||
263 | 280 | ||
264 | mp_perfdata mp_set_pd_value_int(mp_perfdata pd, int value) { return mp_set_pd_value_long_long(pd, (long long)value); } | 281 | mp_perfdata mp_set_pd_value_int(mp_perfdata pd, int value) { |
282 | return mp_set_pd_value_long_long(pd, (long long)value); | ||
283 | } | ||
265 | 284 | ||
266 | mp_perfdata mp_set_pd_value_u_int(mp_perfdata pd, unsigned int value) { return mp_set_pd_value_u_long_long(pd, (unsigned long long)value); } | 285 | mp_perfdata mp_set_pd_value_u_int(mp_perfdata pd, unsigned int value) { |
286 | return mp_set_pd_value_u_long_long(pd, (unsigned long long)value); | ||
287 | } | ||
267 | 288 | ||
268 | mp_perfdata mp_set_pd_value_long(mp_perfdata pd, long value) { return mp_set_pd_value_long_long(pd, (long long)value); } | 289 | mp_perfdata mp_set_pd_value_long(mp_perfdata pd, long value) { |
290 | return mp_set_pd_value_long_long(pd, (long long)value); | ||
291 | } | ||
269 | 292 | ||
270 | mp_perfdata mp_set_pd_value_u_long(mp_perfdata pd, unsigned long value) { | 293 | mp_perfdata mp_set_pd_value_u_long(mp_perfdata pd, unsigned long value) { |
271 | return mp_set_pd_value_u_long_long(pd, (unsigned long long)value); | 294 | return mp_set_pd_value_u_long_long(pd, (unsigned long long)value); |
@@ -290,19 +313,33 @@ mp_perfdata_value mp_create_pd_value_double(double value) { | |||
290 | return res; | 313 | return res; |
291 | } | 314 | } |
292 | 315 | ||
293 | mp_perfdata_value mp_create_pd_value_float(float value) { return mp_create_pd_value_double((double)value); } | 316 | mp_perfdata_value mp_create_pd_value_float(float value) { |
317 | return mp_create_pd_value_double((double)value); | ||
318 | } | ||
294 | 319 | ||
295 | mp_perfdata_value mp_create_pd_value_char(char value) { return mp_create_pd_value_long_long((long long)value); } | 320 | mp_perfdata_value mp_create_pd_value_char(char value) { |
321 | return mp_create_pd_value_long_long((long long)value); | ||
322 | } | ||
296 | 323 | ||
297 | mp_perfdata_value mp_create_pd_value_u_char(unsigned char value) { return mp_create_pd_value_u_long_long((unsigned long long)value); } | 324 | mp_perfdata_value mp_create_pd_value_u_char(unsigned char value) { |
325 | return mp_create_pd_value_u_long_long((unsigned long long)value); | ||
326 | } | ||
298 | 327 | ||
299 | mp_perfdata_value mp_create_pd_value_int(int value) { return mp_create_pd_value_long_long((long long)value); } | 328 | mp_perfdata_value mp_create_pd_value_int(int value) { |
329 | return mp_create_pd_value_long_long((long long)value); | ||
330 | } | ||
300 | 331 | ||
301 | mp_perfdata_value mp_create_pd_value_u_int(unsigned int value) { return mp_create_pd_value_u_long_long((unsigned long long)value); } | 332 | mp_perfdata_value mp_create_pd_value_u_int(unsigned int value) { |
333 | return mp_create_pd_value_u_long_long((unsigned long long)value); | ||
334 | } | ||
302 | 335 | ||
303 | mp_perfdata_value mp_create_pd_value_long(long value) { return mp_create_pd_value_long_long((long long)value); } | 336 | mp_perfdata_value mp_create_pd_value_long(long value) { |
337 | return mp_create_pd_value_long_long((long long)value); | ||
338 | } | ||
304 | 339 | ||
305 | mp_perfdata_value mp_create_pd_value_u_long(unsigned long value) { return mp_create_pd_value_u_long_long((unsigned long long)value); } | 340 | mp_perfdata_value mp_create_pd_value_u_long(unsigned long value) { |
341 | return mp_create_pd_value_u_long_long((unsigned long long)value); | ||
342 | } | ||
306 | 343 | ||
307 | mp_perfdata_value mp_create_pd_value_long_long(long long value) { | 344 | mp_perfdata_value mp_create_pd_value_long_long(long long value) { |
308 | mp_perfdata_value res = {0}; | 345 | mp_perfdata_value res = {0}; |
@@ -368,6 +405,13 @@ mp_range_parsed mp_parse_range_string(const char *input) { | |||
368 | } | 405 | } |
369 | 406 | ||
370 | char *working_copy = strdup(input); | 407 | char *working_copy = strdup(input); |
408 | if (working_copy == NULL) { | ||
409 | // strdup error, probably | ||
410 | mp_range_parsed result = { | ||
411 | .error = MP_RANGE_PARSING_FAILURE, | ||
412 | }; | ||
413 | return result; | ||
414 | } | ||
371 | input = working_copy; | 415 | input = working_copy; |
372 | 416 | ||
373 | char *separator = index(working_copy, ':'); | 417 | char *separator = index(working_copy, ':'); |