diff options
Diffstat (limited to 'lib/perfdata.c')
| -rw-r--r-- | lib/perfdata.c | 72 |
1 files changed, 62 insertions, 10 deletions
diff --git a/lib/perfdata.c b/lib/perfdata.c index f425ffcf..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,11 +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_int(mp_perfdata pd, int 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_int(mp_perfdata pd, unsigned int 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 | } | ||
| 280 | |||
| 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 | } | ||
| 263 | 284 | ||
| 264 | mp_perfdata mp_set_pd_value_long(mp_perfdata pd, long value) { return mp_set_pd_value_long_long(pd, (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 | } | ||
| 288 | |||
| 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 | } | ||
| 265 | 292 | ||
| 266 | 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) { |
| 267 | 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); |
| @@ -286,15 +313,33 @@ mp_perfdata_value mp_create_pd_value_double(double value) { | |||
| 286 | return res; | 313 | return res; |
| 287 | } | 314 | } |
| 288 | 315 | ||
| 289 | 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 | } | ||
| 319 | |||
| 320 | mp_perfdata_value mp_create_pd_value_char(char value) { | ||
| 321 | return mp_create_pd_value_long_long((long long)value); | ||
| 322 | } | ||
| 290 | 323 | ||
| 291 | mp_perfdata_value mp_create_pd_value_int(int value) { return mp_create_pd_value_long_long((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 | } | ||
| 292 | 327 | ||
| 293 | mp_perfdata_value mp_create_pd_value_u_int(unsigned int value) { return mp_create_pd_value_u_long_long((unsigned 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 | } | ||
| 331 | |||
| 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 | } | ||
| 294 | 335 | ||
| 295 | 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 | } | ||
| 296 | 339 | ||
| 297 | 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 | } | ||
| 298 | 343 | ||
| 299 | 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) { |
| 300 | mp_perfdata_value res = {0}; | 345 | mp_perfdata_value res = {0}; |
| @@ -360,6 +405,13 @@ mp_range_parsed mp_parse_range_string(const char *input) { | |||
| 360 | } | 405 | } |
| 361 | 406 | ||
| 362 | 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 | } | ||
| 363 | input = working_copy; | 415 | input = working_copy; |
| 364 | 416 | ||
| 365 | char *separator = index(working_copy, ':'); | 417 | char *separator = index(working_copy, ':'); |
