@stryke/json 0.4.2 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/pointer/find-reference.cjs +2 -2
- package/dist/pointer/find-reference.mjs +1 -1
- package/dist/pointer/parse.cjs +10 -10
- package/dist/pointer/parse.d.ts +1 -1
- package/dist/pointer/parse.mjs +1 -1
- package/dist/storm-json.cjs +2 -2
- package/dist/storm-json.mjs +1 -1
- package/dist/utils/stringify.cjs +1 -1
- package/dist/utils/stringify.mjs +1 -1
- package/package.json +3 -3
|
@@ -4,8 +4,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.isObjectReference = exports.isArrayReference = exports.isArrayEnd = exports.find = void 0;
|
|
7
|
-
var _isSetObject = require("@stryke/
|
|
8
|
-
var _isString = require("@stryke/
|
|
7
|
+
var _isSetObject = require("@stryke/type-checks/is-set-object");
|
|
8
|
+
var _isString = require("@stryke/type-checks/is-string");
|
|
9
9
|
const {
|
|
10
10
|
isArray: i
|
|
11
11
|
} = Array;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{isSetObject as s}from"@stryke/
|
|
1
|
+
import{isSetObject as s}from"@stryke/type-checks/is-set-object";import{isString as a}from"@stryke/type-checks/is-string";const{isArray:i}=Array;export const find=(e,t)=>{const f=t.length;if(!f)return{val:e};let r,n;for(let o=0;o<f;o++)if(r=e,n=t[o],i(r)){const y=r.length;if(n==="-")n=y;else if(a(n)){const c=Math.trunc(n);if(String(c)!==n)throw new Error("INVALID_INDEX");if(n=c,n<0)throw new Error("INVALID_INDEX")}n&&(e=r[n])}else if(s(r))e=n in r?r[n]:void 0;else throw new Error("NOT_FOUND");return{val:e,obj:r,key:n}},isArrayReference=e=>i(e.obj)&&typeof e.key=="number",isArrayEnd=e=>e.obj.length===e.key,isObjectReference=e=>typeof e.obj=="object"&&typeof e.key=="string";
|
package/dist/pointer/parse.cjs
CHANGED
|
@@ -10,7 +10,7 @@ exports.isValidIndex = isValidIndex;
|
|
|
10
10
|
exports.parent = parent;
|
|
11
11
|
exports.parseJsonPointer = parseJsonPointer;
|
|
12
12
|
exports.unescapePointerSegment = unescapePointerSegment;
|
|
13
|
-
var _isNumber = require("@stryke/
|
|
13
|
+
var _isNumber = require("@stryke/type-checks/is-number");
|
|
14
14
|
const i = /~1/g,
|
|
15
15
|
s = /~0/g,
|
|
16
16
|
u = /~/g,
|
|
@@ -22,10 +22,10 @@ function unescapePointerSegment(n) {
|
|
|
22
22
|
return n.includes("~") ? n.replace(i, "/").replace(s, "~") : n;
|
|
23
23
|
}
|
|
24
24
|
function parseJsonPointer(n) {
|
|
25
|
-
return n ? n.slice(1).split("/").map(
|
|
25
|
+
return n ? n.slice(1).split("/").map(r => unescapePointerSegment(r)) : [];
|
|
26
26
|
}
|
|
27
27
|
function formatJsonPointer(n) {
|
|
28
|
-
return isRoot(n) ? "" : `/${n.map(
|
|
28
|
+
return isRoot(n) ? "" : `/${n.map(r => escapePointerSegment(String(r))).join("/")}`;
|
|
29
29
|
}
|
|
30
30
|
const isRoot = n => n.length === 0;
|
|
31
31
|
exports.isRoot = isRoot;
|
|
@@ -35,16 +35,16 @@ function parent(n) {
|
|
|
35
35
|
}
|
|
36
36
|
function isValidIndex(n) {
|
|
37
37
|
if ((0, _isNumber.isNumber)(n)) return !0;
|
|
38
|
-
const
|
|
39
|
-
return String(
|
|
38
|
+
const r = Number.parseInt(n, 10);
|
|
39
|
+
return String(r) === n && r >= 0;
|
|
40
40
|
}
|
|
41
41
|
const isInteger = n => {
|
|
42
|
-
const
|
|
43
|
-
let
|
|
42
|
+
const r = n.length;
|
|
43
|
+
let t = 0,
|
|
44
44
|
e;
|
|
45
|
-
for (;
|
|
46
|
-
if (e = n.codePointAt(
|
|
47
|
-
|
|
45
|
+
for (; t < r;) {
|
|
46
|
+
if (e = n.codePointAt(t), e >= 48 && e <= 57) {
|
|
47
|
+
t++;
|
|
48
48
|
continue;
|
|
49
49
|
}
|
|
50
50
|
return !1;
|
package/dist/pointer/parse.d.ts
CHANGED
package/dist/pointer/parse.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{isNumber as o}from"@stryke/
|
|
1
|
+
import{isNumber as o}from"@stryke/type-checks/is-number";const i=/~1/g,s=/~0/g,u=/~/g,c=/\//g;export function escapePointerSegment(n){return!n.includes("/")&&!n.includes("~")?n:n.replace(u,"~0").replace(c,"~1")}export function unescapePointerSegment(n){return n.includes("~")?n.replace(i,"/").replace(s,"~"):n}export function parseJsonPointer(n){return n?n.slice(1).split("/").map(r=>unescapePointerSegment(r)):[]}export function formatJsonPointer(n){return isRoot(n)?"":`/${n.map(r=>escapePointerSegment(String(r))).join("/")}`}export const isRoot=n=>n.length===0;export function parent(n){if(n.length===0)throw new Error("NO_PARENT");return n.slice(0,-1)}export function isValidIndex(n){if(o(n))return!0;const r=Number.parseInt(n,10);return String(r)===n&&r>=0}export const isInteger=n=>{const r=n.length;let t=0,e;for(;t<r;){if(e=n.codePointAt(t),e>=48&&e<=57){t++;continue}return!1}return!0};
|
package/dist/storm-json.cjs
CHANGED
|
@@ -4,8 +4,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.StormJSON = void 0;
|
|
7
|
-
var _isObject = require("@stryke/
|
|
8
|
-
var _isString = require("@stryke/
|
|
7
|
+
var _isObject = require("@stryke/type-checks/is-object");
|
|
8
|
+
var _isString = require("@stryke/type-checks/is-string");
|
|
9
9
|
var _buffer = require("buffer/");
|
|
10
10
|
var _jsoncParser = require("jsonc-parser");
|
|
11
11
|
var _superjson = _interopRequireDefault(require("superjson"));
|
package/dist/storm-json.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{isObject as o}from"@stryke/
|
|
1
|
+
import{isObject as o}from"@stryke/type-checks/is-object";import{isString as l}from"@stryke/type-checks/is-string";import{Buffer as a}from"buffer/";import{parse as c}from"jsonc-parser";import u from"superjson";import{formatParseError as p}from"./utils/parse-error";import{stringify as f}from"./utils/stringify";export class StormJSON extends u{static#e;static get instance(){return StormJSON.#e||(StormJSON.#e=new StormJSON),StormJSON.#e}static deserialize(e){return StormJSON.instance.deserialize(e)}static serialize(e){return StormJSON.instance.serialize(e)}static parse(e){return StormJSON.instance.parse(e)}static stringify(e,r){const s=StormJSON.instance.customTransformerRegistry.findApplicable(e);let t=e;return s&&(t=s.serialize(t)),f(t?.json?t?.json:t,r?.spaces)}static stringifyBase(e){return StormJSON.instance.stringify(e)}static parseJson(e,r){try{if(r?.expectComments===!1)return StormJSON.instance.parse(e)}catch{}const s=[],t={allowTrailingComma:!0,...r},n=c(e,s,t);if(s.length>0&&s[0])throw new Error(p(e,s[0]));return n}static register(e,r,s,t){StormJSON.instance.registerCustom({isApplicable:t,serialize:r,deserialize:s},e)}static registerClass(e,r){StormJSON.instance.registerClass(e,{identifier:l(r)?r:r?.identifier||e.name,allowProps:r&&o(r)&&r?.allowProps&&Array.isArray(r.allowProps)?r.allowProps:["__typename"]})}constructor(){super({dedupe:!0})}}StormJSON.instance.registerCustom({isApplicable:i=>a.isBuffer(i),serialize:i=>i.toString("base64"),deserialize:i=>a.from(i,"base64")},"Bytes");
|
package/dist/utils/stringify.cjs
CHANGED
|
@@ -4,7 +4,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.stringify = void 0;
|
|
7
|
-
var _isNumber = require("@stryke/
|
|
7
|
+
var _isNumber = require("@stryke/type-checks/is-number");
|
|
8
8
|
const stringify = (r, t = 2) => {
|
|
9
9
|
const n = (0, _isNumber.isNumber)(t) ? " ".repeat(t) : t;
|
|
10
10
|
switch (r) {
|
package/dist/utils/stringify.mjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
import{isNumber as i}from"@stryke/
|
|
1
|
+
import{isNumber as i}from"@stryke/type-checks/is-number";export const stringify=(r,t=2)=>{const n=i(t)?" ".repeat(t):t;switch(r){case null:return"null";case void 0:return"undefined";case!0:return"true";case!1:return"false"}if(Array.isArray(r))return`[${n}${r.map(e=>stringify(e,n)).join(`,${n}`)}${n}]`;if(r instanceof Uint8Array)return r.toString();switch(typeof r){case"number":return`${r}`;case"string":return JSON.stringify(r);case"object":{const e=Object.keys(r);return`{${n}${e.map(s=>`${s}: ${n}${stringify(r[s],n)}`).join(`,${n}`)}${n}}`}default:return"null"}};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stryke/json",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.5.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "A package containing JSON parsing/stringify utilities used by Storm Software.",
|
|
6
6
|
"repository": {
|
|
@@ -14,7 +14,8 @@
|
|
|
14
14
|
"jsonc-parser": "3.3.1",
|
|
15
15
|
"lines-and-columns": "2.0.4",
|
|
16
16
|
"superjson": "2.2.2",
|
|
17
|
-
"@stryke/
|
|
17
|
+
"@stryke/type-checks": ">=0.1.0",
|
|
18
|
+
"@stryke/types": ">=0.6.0"
|
|
18
19
|
},
|
|
19
20
|
"publishConfig": { "access": "public" },
|
|
20
21
|
"devDependencies": {},
|
|
@@ -30,7 +31,6 @@
|
|
|
30
31
|
"stryke",
|
|
31
32
|
"typescript",
|
|
32
33
|
"utilities",
|
|
33
|
-
"storm-stack",
|
|
34
34
|
"storm-software",
|
|
35
35
|
"storm",
|
|
36
36
|
"storm-ops",
|