diff options
| author | Lorenz Kästle <12514511+RincewindsHat@users.noreply.github.com> | 2025-03-31 23:58:02 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-03-31 23:58:02 +0200 |
| commit | 4924bc877f714ec00ac8b02378d11f1508bbe8b4 (patch) | |
| tree | 276d2c7b746e593133cf1fc6ca548e10f71e1b5f /lib/perfdata.c | |
| parent | 922d16ab2e44594d0ae4e4ac0c2b095cb1a1003f (diff) | |
| parent | d0647ec7e1500c0e6164ac9820a7d623582bdde2 (diff) | |
| download | monitoring-plugins-4924bc877f714ec00ac8b02378d11f1508bbe8b4.tar.gz | |
Merge pull request #2113 from RincewindsHat/refactor/check_disk
Refactor/check disk
Diffstat (limited to 'lib/perfdata.c')
| -rw-r--r-- | lib/perfdata.c | 83 |
1 files changed, 82 insertions, 1 deletions
diff --git a/lib/perfdata.c b/lib/perfdata.c index 661756c5..f425ffcf 100644 --- a/lib/perfdata.c +++ b/lib/perfdata.c | |||
| @@ -33,7 +33,7 @@ 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 | asprintf(&result, "'%s'=", pd.label); |
| 37 | 37 | ||
| 38 | asprintf(&result, "%s%s", result, pd_value_to_string(pd.value)); | 38 | asprintf(&result, "%s%s", result, pd_value_to_string(pd.value)); |
| 39 | 39 | ||
| @@ -514,3 +514,84 @@ perfdata_value_parser_wrapper parse_pd_value(const char *input) { | |||
| 514 | } | 514 | } |
| 515 | return result; | 515 | return result; |
| 516 | } | 516 | } |
| 517 | |||
| 518 | mp_perfdata mp_set_pd_max_value(mp_perfdata perfdata, mp_perfdata_value value) { | ||
| 519 | perfdata.max = value; | ||
| 520 | perfdata.max_present = true; | ||
| 521 | return perfdata; | ||
| 522 | } | ||
| 523 | |||
| 524 | mp_perfdata mp_set_pd_min_value(mp_perfdata perfdata, mp_perfdata_value value) { | ||
| 525 | perfdata.min = value; | ||
| 526 | perfdata.min_present = true; | ||
| 527 | return perfdata; | ||
| 528 | } | ||
| 529 | |||
| 530 | double mp_get_pd_value(mp_perfdata_value value) { | ||
| 531 | assert(value.type != PD_TYPE_NONE); | ||
| 532 | switch (value.type) { | ||
| 533 | case PD_TYPE_DOUBLE: | ||
| 534 | return value.pd_double; | ||
| 535 | case PD_TYPE_INT: | ||
| 536 | return (double)value.pd_int; | ||
| 537 | case PD_TYPE_UINT: | ||
| 538 | return (double)value.pd_uint; | ||
| 539 | default: | ||
| 540 | return 0; // just to make the compiler happy | ||
| 541 | } | ||
| 542 | } | ||
| 543 | |||
| 544 | mp_perfdata_value mp_pd_value_multiply(mp_perfdata_value left, mp_perfdata_value right) { | ||
| 545 | if (left.type == right.type) { | ||
| 546 | switch (left.type) { | ||
| 547 | case PD_TYPE_DOUBLE: | ||
| 548 | left.pd_double *= right.pd_double; | ||
| 549 | return left; | ||
| 550 | case PD_TYPE_INT: | ||
| 551 | left.pd_int *= right.pd_int; | ||
| 552 | return left; | ||
| 553 | case PD_TYPE_UINT: | ||
| 554 | left.pd_uint *= right.pd_uint; | ||
| 555 | return left; | ||
| 556 | default: | ||
| 557 | // what to here? | ||
| 558 | return left; | ||
| 559 | } | ||
| 560 | } | ||
| 561 | |||
| 562 | // Different types, oh boy, just do the lazy thing for now and switch to double | ||
| 563 | switch (left.type) { | ||
| 564 | case PD_TYPE_INT: | ||
| 565 | left.pd_double = (double)left.pd_int; | ||
| 566 | left.type = PD_TYPE_DOUBLE; | ||
| 567 | break; | ||
| 568 | case PD_TYPE_UINT: | ||
| 569 | left.pd_double = (double)left.pd_uint; | ||
| 570 | left.type = PD_TYPE_DOUBLE; | ||
| 571 | break; | ||
| 572 | } | ||
| 573 | |||
| 574 | switch (right.type) { | ||
| 575 | case PD_TYPE_INT: | ||
| 576 | right.pd_double = (double)right.pd_int; | ||
| 577 | right.type = PD_TYPE_DOUBLE; | ||
| 578 | break; | ||
| 579 | case PD_TYPE_UINT: | ||
| 580 | right.pd_double = (double)right.pd_uint; | ||
| 581 | right.type = PD_TYPE_DOUBLE; | ||
| 582 | break; | ||
| 583 | } | ||
| 584 | |||
| 585 | left.pd_double *= right.pd_double; | ||
| 586 | return left; | ||
| 587 | } | ||
| 588 | |||
| 589 | mp_range mp_range_multiply(mp_range range, mp_perfdata_value factor) { | ||
| 590 | if (!range.end_infinity) { | ||
| 591 | range.end = mp_pd_value_multiply(range.end, factor); | ||
| 592 | } | ||
| 593 | if (!range.start_infinity) { | ||
| 594 | range.start = mp_pd_value_multiply(range.start, factor); | ||
| 595 | } | ||
| 596 | return range; | ||
| 597 | } | ||
