flatted
3.2.73.4.2
index.js~
index.jsModified+78−58
Index: package/index.js
===================================================================
--- package/index.js
+++ package/index.js
@@ -1,86 +1,101 @@
self.Flatted = (function (exports) {
'use strict';
- function _typeof(obj) {
+ function _typeof(o) {
"@babel/helpers - typeof";
- return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {
- return typeof obj;
- } : function (obj) {
- return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
- }, _typeof(obj);
+ return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) {
+ return typeof o;
+ } : function (o) {
+ return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o;
+ }, _typeof(o);
}
- /*! (c) 2020 Andrea Giammarchi */
+ /// <reference types="../types/index.d.ts" />
+
+ // (c) 2020-present Andrea Giammarchi
+
var $parse = JSON.parse,
- $stringify = JSON.stringify;
+ $stringify = JSON.stringify;
var keys = Object.keys;
var Primitive = String; // it could be Number
-
var primitive = 'string'; // it could be 'number'
var ignore = {};
var object = 'object';
-
var noop = function noop(_, value) {
return value;
};
-
var primitives = function primitives(value) {
return value instanceof Primitive ? Primitive(value) : value;
};
-
var Primitives = function Primitives(_, value) {
return _typeof(value) === primitive ? new Primitive(value) : value;
};
-
- var revive = function revive(input, parsed, output, $) {
- var lazy = [];
-
- for (var ke = keys(output), length = ke.length, y = 0; y < length; y++) {
- var k = ke[y];
- var value = output[k];
-
- if (value instanceof Primitive) {
- var tmp = input[value];
-
- if (_typeof(tmp) === object && !parsed.has(tmp)) {
- parsed.add(tmp);
- output[k] = ignore;
- lazy.push({
- k: k,
- a: [input, parsed, tmp, $]
- });
- } else output[k] = $.call(output, k, tmp);
- } else if (output[k] !== ignore) output[k] = $.call(output, k, value);
- }
-
- for (var _length = lazy.length, i = 0; i < _length; i++) {
- var _lazy$i = lazy[i],
- _k = _lazy$i.k,
- a = _lazy$i.a;
- output[_k] = $.call(output, _k, revive.apply(null, a));
- }
-
- return output;
+ var resolver = function resolver(input, lazy, parsed, $) {
+ return function (output) {
+ for (var ke = keys(output), length = ke.length, y = 0; y < length; y++) {
+ var k = ke[y];
+ var value = output[k];
+ if (value instanceof Primitive) {
+ var tmp = input[+value];
+ if (_typeof(tmp) === object && !parsed.has(tmp)) {
+ parsed.add(tmp);
+ output[k] = ignore;
+ lazy.push({
+ o: output,
+ k: k,
+ r: tmp
+ });
+ } else output[k] = $.call(output, k, tmp);
+ } else if (output[k] !== ignore) output[k] = $.call(output, k, value);
+ }
+ return output;
+ };
};
-
var set = function set(known, input, value) {
var index = Primitive(input.push(value) - 1);
known.set(value, index);
return index;
};
+ /**
+ * Converts a specialized flatted string into a JS value.
+ * @param {string} text
+ * @param {(this: any, key: string, value: any) => any} [reviver]
+ * @returns {any}
+ */
var parse = function parse(text, reviver) {
var input = $parse(text, Primitives).map(primitives);
- var value = input[0];
var $ = reviver || noop;
- var tmp = _typeof(value) === object && value ? revive(input, new Set(), value, $) : value;
+ var value = input[0];
+ if (_typeof(value) === object && value) {
+ var lazy = [];
+ var revive = resolver(input, lazy, new Set(), $);
+ value = revive(value);
+ var i = 0;
+ while (i < lazy.length) {
+ // it could be a lazy.shift() but that's costly
+ var _lazy$i = lazy[i++],
+ o = _lazy$i.o,
+ k = _lazy$i.k,
+ r = _lazy$i.r;
+ o[k] = $.call(o, k, revive(r));
+ }
+ }
return $.call({
- '': tmp
- }, '', tmp);
+ '': value
+ }, '', value);
};
+
+ /**
+ * Converts a JS value into a specialized flatted string.
+ * @param {any} value
+ * @param {((this: any, key: string, value: any) => any) | (string | number)[] | null | undefined} [replacer]
+ * @param {string | number | undefined} [space]
+ * @returns {string}
+ */
var stringify = function stringify(value, replacer, space) {
var $ = replacer && _typeof(replacer) === object ? function (k, v) {
return k === '' || -1 < replacer.indexOf(k) ? v : void 0;
} : replacer || noop;
@@ -90,40 +105,45 @@
var i = +set(known, input, $.call({
'': value
}, '', value));
var firstRun = !i;
-
while (i < input.length) {
firstRun = true;
output[i] = $stringify(input[i++], replace, space);
}
-
return '[' + output.join(',') + ']';
-
function replace(key, value) {
if (firstRun) {
firstRun = !firstRun;
return value;
}
-
var after = $.call(this, key, value);
-
switch (_typeof(after)) {
case object:
if (after === null) return after;
-
case primitive:
return known.get(after) || set(known, input, after);
}
-
return after;
}
};
- var toJSON = function toJSON(any) {
- return $parse(stringify(any));
+
+ /**
+ * Converts a generic value into a JSON serializable object without losing recursion.
+ * @param {any} value
+ * @returns {any}
+ */
+ var toJSON = function toJSON(value) {
+ return $parse(stringify(value));
};
- var fromJSON = function fromJSON(any) {
- return parse($stringify(any));
+
+ /**
+ * Converts a previously serialized object with recursion into a recursive one.
+ * @param {any} value
+ * @returns {any}
+ */
+ var fromJSON = function fromJSON(value) {
+ return parse($stringify(value));
};
exports.fromJSON = fromJSON;
exports.parse = parse;