sysinfo: Use less ambiguous IEC prefixes in storage measurements
Closes #922
This commit is contained in:
parent
7e55e4ee73
commit
231590f71e
|
@ -32,36 +32,31 @@ float percentage(unsigned long long *free, unsigned long long *total)
|
||||||
|
|
||||||
char *pretty_freespace(const char *desc, unsigned long long *free_k, unsigned long long *total_k)
|
char *pretty_freespace(const char *desc, unsigned long long *free_k, unsigned long long *total_k)
|
||||||
{
|
{
|
||||||
char *result, *bytesize;
|
char *result, **quantity;
|
||||||
double free_space, total_space;
|
double free_space, total_space;
|
||||||
free_space = *free_k;
|
free_space = *free_k;
|
||||||
total_space = *total_k;
|
total_space = *total_k;
|
||||||
result = malloc(bsize * sizeof(char));
|
result = malloc(bsize * sizeof(char));
|
||||||
const char *quantities = "KB\0MB\0GB\0TB\0PB\0EB\0ZB\0YB\0";
|
char *quantities[] = { "KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB", 0 };
|
||||||
int i=0;
|
|
||||||
if (total_space == 0)
|
if (total_space == 0)
|
||||||
{
|
{
|
||||||
snprintf(result, bsize, "%s: none", desc);
|
snprintf(result, bsize, "%s: none", desc);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
bytesize = malloc(3 * sizeof(char));
|
quantity = quantities;
|
||||||
while (total_space > 1023 && i <= 14)
|
while (total_space > 1023 && *(quantity + 1))
|
||||||
{
|
{
|
||||||
i=i+3;
|
quantity++;
|
||||||
*bytesize=*(quantities+i);
|
|
||||||
*(bytesize+1)=*(quantities+i+1);
|
|
||||||
*(bytesize+2)=*(quantities+i+2);
|
|
||||||
free_space = free_space / 1024;
|
free_space = free_space / 1024;
|
||||||
total_space = total_space / 1024;
|
total_space = total_space / 1024;
|
||||||
}
|
}
|
||||||
if (sysinfo_get_percent () != 0)
|
if (sysinfo_get_percent () != 0)
|
||||||
snprintf(result, bsize, "%s: %.1f%s, %.1f%% free",
|
snprintf(result, bsize, "%s: %.1f%s, %.1f%% free",
|
||||||
desc, total_space, bytesize,
|
desc, total_space, *quantity,
|
||||||
percentage(free_k, total_k));
|
percentage(free_k, total_k));
|
||||||
else
|
else
|
||||||
snprintf(result, bsize, "%s: %.1f%s/%.1f%s free",
|
snprintf(result, bsize, "%s: %.1f%s/%.1f%s free",
|
||||||
desc, free_space, bytesize, total_space, bytesize);
|
desc, free_space, *quantity, total_space, *quantity);
|
||||||
free (bytesize);
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue