diff options
Diffstat (limited to 'lib/perfdata.c')
| -rw-r--r-- | lib/perfdata.c | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/lib/perfdata.c b/lib/perfdata.c index 4f9c9558..1742342e 100644 --- a/lib/perfdata.c +++ b/lib/perfdata.c | |||
| @@ -514,3 +514,90 @@ 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 | case PD_TYPE_DOUBLE: | ||
| 573 | default: | ||
| 574 | // already there | ||
| 575 | } | ||
| 576 | |||
| 577 | switch (right.type) { | ||
| 578 | case PD_TYPE_INT: | ||
| 579 | right.pd_double = (double)right.pd_int; | ||
| 580 | right.type = PD_TYPE_DOUBLE; | ||
| 581 | break; | ||
| 582 | case PD_TYPE_UINT: | ||
| 583 | right.pd_double = (double)right.pd_uint; | ||
| 584 | right.type = PD_TYPE_DOUBLE; | ||
| 585 | break; | ||
| 586 | case PD_TYPE_DOUBLE: | ||
| 587 | default: | ||
| 588 | // already there | ||
| 589 | } | ||
| 590 | |||
| 591 | left.pd_double *= right.pd_double; | ||
| 592 | return left; | ||
| 593 | } | ||
| 594 | |||
| 595 | mp_range mp_range_multiply(mp_range range, mp_perfdata_value factor) { | ||
| 596 | if (!range.end_infinity) { | ||
| 597 | range.end = mp_pd_value_multiply(range.end, factor); | ||
| 598 | } | ||
| 599 | if (!range.start_infinity) { | ||
| 600 | range.start = mp_pd_value_multiply(range.start, factor); | ||
| 601 | } | ||
| 602 | return range; | ||
| 603 | } | ||
