sysinfo: Use less ambiguous IEC prefixes in storage measurements

Closes #922
This commit is contained in:
Max Zerzouri 2014-03-20 16:19:47 +13:00 committed by TingPing
parent 7e55e4ee73
commit 231590f71e
1 changed files with 7 additions and 12 deletions

View File

@ -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;
} }