diff --git a/exec/load/file_size.js b/exec/load/file_size.js index 2d2a91825792ed5ee8ef8c5a2efb21fa0e781c1a..d0c0da3d8eb8df765a2edf4efff0d566725c259d 100644 --- a/exec/load/file_size.js +++ b/exec/load/file_size.js @@ -4,8 +4,10 @@ // Function for returning a string representation of a file size -function file_size_str(size, bytes) +function file_size_str(size, bytes, float) { + if(float !== undefined) + return file_size_float(size, /* unit: */bytes, /* precision */float); if(bytes) { if(size < 1000) /* Bytes */ return format("%ldB",size); @@ -56,3 +58,24 @@ function file_size_str(size, bytes) return "Too damn big to download."; } + +// ported from xpdev/genwrap.c byte_estimate_to_str() +function file_size_float(bytes, unit, precision) +{ + const one_tebibyte = 1024.0*1024.0*1024.0*1024.0; + const one_gibibyte = 1024.0*1024.0*1024.0; + const one_mebibyte = 1024.0*1024.0; + const one_kibibyte = 1024.0; + + if(bytes >= one_tebibyte) + return format("%1.*fT", precision, bytes/one_tebibyte); + if(bytes >= one_gibibyte || unit == one_gibibyte) + return format("%1.*fG", precision, bytes/one_gibibyte); + if(bytes >= one_mebibyte || unit == one_mebibyte) + return format("%1.*fM", precision, bytes/one_mebibyte); + else if(bytes >= one_kibibyte || unit == one_kibibyte) + return format("%1.*fK", precision, bytes/one_kibibyte); + else + return format("%luB", bytes); + +}