summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--core/js/js.js90
-rw-r--r--core/js/tests/specs/coreSpec.js4
2 files changed, 46 insertions, 48 deletions
diff --git a/core/js/js.js b/core/js/js.js
index 2b14ded87d7..f2cdf7c93ef 100644
--- a/core/js/js.js
+++ b/core/js/js.js
@@ -1626,51 +1626,6 @@ function humanFileSize(size, skipSmallSizes) {
}
/**
- * Returns a file size in bytes from a humanly readable string
- * @param {string} string file size in human readable format
- * @return {number}
- *
- * Makes 2kB to 2048.
- *
- * Inspired by computerFileSize in helper.php
- */
-function computerFileSize(string) {
- var s = string.toLowerCase();
-
- if (!isNaN(parseFloat(s)) && isFinite(s)) {
- return parseFloat(s);
- }
-
- var bytes_array = {
- 'b' : 1,
- 'k' : 1024,
- 'kb': 1024,
- 'mb': 1024 * 1024,
- 'm' : 1024 * 1024,
- 'gb': 1024 * 1024 * 1024,
- 'g' : 1024 * 1024 * 1024,
- 'tb': 1024 * 1024 * 1024 * 1024,
- 't' : 1024 * 1024 * 1024 * 1024,
- 'pb': 1024 * 1024 * 1024 * 1024 * 1024,
- 'p' : 1024 * 1024 * 1024 * 1024 * 1024
- };
-
- var bytes = parseFloat(s);
-
- var matches = s.match(/([kmgtp]?b?)$/i);
- if (matches[1]) {
- bytes = bytes * bytes_array[matches[1]];
- }
- else {
- return false;
- }
-
- bytes = Math.round(bytes);
- console.log(bytes);
- return bytes;
-}
-
-/**
* Format an UNIX timestamp to a human understandable format
* @param {number} timestamp UNIX timestamp
* @return {string} Human readable format
@@ -1712,7 +1667,50 @@ function relative_modified_date(timestamp) {
OC.Util = {
// TODO: remove original functions from global namespace
humanFileSize: humanFileSize,
- computerFileSize: computerFileSize,
+
+ /**
+ * Returns a file size in bytes from a humanly readable string
+ * @param {string} string file size in human readable format
+ * @return {number} or null if string could not be parsed
+ *
+ * Makes 2kB to 2048.
+ *
+ * Inspired by computerFileSize in helper.php
+ */
+ computerFileSize: function (string) {
+ var s = string.toLowerCase();
+
+ if (!isNaN(parseFloat(s)) && isFinite(s)) {
+ return parseFloat(s);
+ }
+
+ var bytes_array = {
+ 'b' : 1,
+ 'k' : 1024,
+ 'kb': 1024,
+ 'mb': 1024 * 1024,
+ 'm' : 1024 * 1024,
+ 'gb': 1024 * 1024 * 1024,
+ 'g' : 1024 * 1024 * 1024,
+ 'tb': 1024 * 1024 * 1024 * 1024,
+ 't' : 1024 * 1024 * 1024 * 1024,
+ 'pb': 1024 * 1024 * 1024 * 1024 * 1024,
+ 'p' : 1024 * 1024 * 1024 * 1024 * 1024
+ };
+
+ var bytes = parseFloat(s);
+
+ var matches = s.match(/([kmgtp]?b?)$/i);
+ if (matches[1]) {
+ bytes = bytes * bytes_array[matches[1]];
+ }
+ else {
+ return null;
+ }
+
+ bytes = Math.round(bytes);
+ return bytes;
+ },
/**
* @param timestamp
diff --git a/core/js/tests/specs/coreSpec.js b/core/js/tests/specs/coreSpec.js
index 8ece9344b5b..2960d1d7d23 100644
--- a/core/js/tests/specs/coreSpec.js
+++ b/core/js/tests/specs/coreSpec.js
@@ -598,8 +598,8 @@ describe('Core base tests', function() {
['125b', 125],
['125 KB', 128000],
['125kb', 128000],
- ['122.1 MB', 128031130, ],
- ['122.1mb', 128031130, ],
+ ['122.1 MB', 128031130],
+ ['122.1mb', 128031130],
['119.2 GB', 127990025421],
['119.2gb', 127990025421],
['116.4 TB', 127983153473126],