mirror of
git://sourceware.org/git/lvm2.git
synced 2024-09-09 14:27:01 +03:00
libdm: implement dm_percent_to_round_float
Add function to adjust printing of percent values in better way. Rounding here is going along following rules: 0% & 100% are always clearly reported with .0 decimal points. Values slightly above 0% we make sure a nearest bigger non zero value with given precission is printed (i.e. 0.01 for %.2f will be shown) For values closely approaching 100% we again detect and adjust value that is less then 100 when printed. (i.e. 99.99 for %.2f will be shown). For other values we are leaving them with standard rounding mechanism since we care mainly about corner values 0 & 100 which need to be printed precisely.
This commit is contained in:
parent
0016b79c8b
commit
2ef8da61eb
|
@ -1,5 +1,6 @@
|
|||
Version 1.02.141 -
|
||||
===============================
|
||||
Add dm_percent_to_round_float for adjusted percentage rounding.
|
||||
Reset array with dead rimage devices once raid gets in sync.
|
||||
Drop unneeded --config option from raid dmeventd plugin.
|
||||
dm_get_status_raid() handle better some incosistent md statuses.
|
||||
|
|
1
libdm/.exported_symbols.DM_1_02_141
Normal file
1
libdm/.exported_symbols.DM_1_02_141
Normal file
|
@ -0,0 +1 @@
|
|||
dm_percent_to_round_float
|
|
@ -2836,6 +2836,16 @@ typedef enum {
|
|||
typedef int32_t dm_percent_t;
|
||||
|
||||
float dm_percent_to_float(dm_percent_t percent);
|
||||
/*
|
||||
* Return adjusted/rounded float for better percent value printing.
|
||||
* Function ensures for given precision of digits:
|
||||
* 100.0% returns only when the value is DM_PERCENT_100
|
||||
* for close smaller values rounds to nearest smaller value
|
||||
* 0.0% returns only for value DM_PERCENT_0
|
||||
* for close bigger values rounds to nearest bigger value
|
||||
* In all other cases returns same value as dm_percent_to_float()
|
||||
*/
|
||||
float dm_percent_to_round_float(dm_percent_t percent, unsigned digits);
|
||||
dm_percent_t dm_make_percent(uint64_t numerator, uint64_t denominator);
|
||||
|
||||
/********************
|
||||
|
|
|
@ -2425,6 +2425,29 @@ float dm_percent_to_float(dm_percent_t percent)
|
|||
return (float) percent / DM_PERCENT_1 + 0.f;
|
||||
}
|
||||
|
||||
float dm_percent_to_round_float(dm_percent_t percent, unsigned digits)
|
||||
{
|
||||
static const float power10[] = {
|
||||
1.f, .1f, .01f, .001f, .0001f, .00001f, .000001f,
|
||||
.0000001f, .00000001f, .000000001f,
|
||||
.0000000001f
|
||||
};
|
||||
float r;
|
||||
float f = dm_percent_to_float(percent);
|
||||
|
||||
if (digits >= DM_ARRAY_SIZE(power10))
|
||||
digits = DM_ARRAY_SIZE(power10) - 1; /* no better precision */
|
||||
|
||||
r = DM_PERCENT_1 * power10[digits];
|
||||
|
||||
if ((percent < r) && (percent > DM_PERCENT_0))
|
||||
f = power10[digits];
|
||||
else if ((percent > (DM_PERCENT_100 - r)) && (percent < DM_PERCENT_100))
|
||||
f = (float) (DM_PERCENT_100 - r) / DM_PERCENT_1;
|
||||
|
||||
return f;
|
||||
}
|
||||
|
||||
dm_percent_t dm_make_percent(uint64_t numerator, uint64_t denominator)
|
||||
{
|
||||
dm_percent_t percent;
|
||||
|
|
Loading…
Reference in New Issue
Block a user