@stryke/url 0.4.12 → 0.4.14
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/CHANGELOG.md +24 -0
- package/README.md +1 -1
- package/dist/json/src/storm-json.cjs +11 -22
- package/dist/json/src/storm-json.mjs +11 -22
- package/dist/json/src/storm-json.mjs.map +1 -1
- package/dist/json/src/utils/stringify.cjs +1 -35
- package/dist/json/src/utils/stringify.mjs +1 -35
- package/dist/json/src/utils/stringify.mjs.map +1 -1
- package/dist/type-checks/src/is-plain-object.cjs +2 -2
- package/dist/type-checks/src/is-plain-object.mjs +2 -2
- package/dist/type-checks/src/is-plain-object.mjs.map +1 -1
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,30 @@
|
|
|
2
2
|
|
|
3
3
|
# Changelog for Stryke - URL
|
|
4
4
|
|
|
5
|
+
## [0.4.14](https://github.com/storm-software/stryke/releases/tag/url%400.4.14) (03/23/2026)
|
|
6
|
+
|
|
7
|
+
### Bug Fixes
|
|
8
|
+
|
|
9
|
+
- **monorepo:** Update all repository projects to resolve linting failures ([e9fb597b](https://github.com/storm-software/stryke/commit/e9fb597b))
|
|
10
|
+
|
|
11
|
+
### Updated Dependencies
|
|
12
|
+
|
|
13
|
+
- Updated **type-checks** to **v0.6.0**
|
|
14
|
+
- Updated **json** to **v0.14.11**
|
|
15
|
+
- Updated **path** to **v0.27.3**
|
|
16
|
+
|
|
17
|
+
## [0.4.13](https://github.com/storm-software/stryke/releases/tag/url%400.4.13) (03/16/2026)
|
|
18
|
+
|
|
19
|
+
### Miscellaneous
|
|
20
|
+
|
|
21
|
+
- **monorepo:** Added `README.md` workspace files ([515dc333](https://github.com/storm-software/stryke/commit/515dc333))
|
|
22
|
+
|
|
23
|
+
### Updated Dependencies
|
|
24
|
+
|
|
25
|
+
- Updated **type-checks** to **v0.5.41**
|
|
26
|
+
- Updated **json** to **v0.14.10**
|
|
27
|
+
- Updated **path** to **v0.27.2**
|
|
28
|
+
|
|
5
29
|
## [0.4.12](https://github.com/storm-software/stryke/releases/tag/url%400.4.12) (03/16/2026)
|
|
6
30
|
|
|
7
31
|
### Updated Dependencies
|
package/README.md
CHANGED
|
@@ -28,7 +28,7 @@ This package is part of Storm Software's **🌩️ Stryke** monorepo. Stryke pac
|
|
|
28
28
|
|
|
29
29
|
<h3 align="center">💻 Visit <a href="https://stormsoftware.com" target="_blank">stormsoftware.com</a> to stay up to date with this developer</h3><br />
|
|
30
30
|
|
|
31
|
-
[](https://github.com/storm-software/stryke) [](http://commitizen.github.io/cz-cli/)  
|
|
32
32
|
|
|
33
33
|
> [!IMPORTANT] Important
|
|
34
34
|
> This repository, and the apps, libraries, and tools contained within, is still in it's initial development phase. As a result, bugs and issues are expected with it's usage. When the main development phase completes, a proper release will be performed, the packages will be available through NPM (and other distributions), and this message will be removed. However, in the meantime, please feel free to report any issues you may come across.
|
|
@@ -40,8 +40,17 @@ var StormJSON = class StormJSON extends superjson.default {
|
|
|
40
40
|
* @param value - The string value to parse
|
|
41
41
|
* @returns The parsed data
|
|
42
42
|
*/
|
|
43
|
-
static parse(value) {
|
|
44
|
-
|
|
43
|
+
static parse(value, options = {}) {
|
|
44
|
+
try {
|
|
45
|
+
if (options.expectComments === false) return require_parse.parse(value);
|
|
46
|
+
} catch {}
|
|
47
|
+
const errors = [];
|
|
48
|
+
const result = (0, jsonc_parser.parse)(value, errors, {
|
|
49
|
+
allowTrailingComma: true,
|
|
50
|
+
...options
|
|
51
|
+
});
|
|
52
|
+
if (errors.length > 0 && errors[0]) throw new Error(require_parse_error.formatParseError(value, errors[0]));
|
|
53
|
+
return result;
|
|
45
54
|
}
|
|
46
55
|
/**
|
|
47
56
|
* Serializes the given data to a JSON string.
|
|
@@ -58,26 +67,6 @@ var StormJSON = class StormJSON extends superjson.default {
|
|
|
58
67
|
return require_stringify.stringify(result, options?.spaces ?? 2);
|
|
59
68
|
}
|
|
60
69
|
/**
|
|
61
|
-
* Parses the given JSON string and returns the object the JSON content represents.
|
|
62
|
-
* By default javascript-style comments and trailing commas are allowed.
|
|
63
|
-
*
|
|
64
|
-
* @param strData - JSON content as string
|
|
65
|
-
* @param options - JSON parse options
|
|
66
|
-
* @returns Object the JSON content represents
|
|
67
|
-
*/
|
|
68
|
-
static parseJson(strData, options) {
|
|
69
|
-
try {
|
|
70
|
-
if (options?.expectComments === false) return StormJSON.instance.parse(strData);
|
|
71
|
-
} catch {}
|
|
72
|
-
const errors = [];
|
|
73
|
-
const result = (0, jsonc_parser.parse)(strData, errors, {
|
|
74
|
-
allowTrailingComma: true,
|
|
75
|
-
...options
|
|
76
|
-
});
|
|
77
|
-
if (errors.length > 0 && errors[0]) throw new Error(require_parse_error.formatParseError(strData, errors[0]));
|
|
78
|
-
return result;
|
|
79
|
-
}
|
|
80
|
-
/**
|
|
81
70
|
* Register a custom schema with superjson
|
|
82
71
|
*
|
|
83
72
|
* @param name - The name of the schema
|
|
@@ -38,8 +38,17 @@ var StormJSON = class StormJSON extends SuperJSON {
|
|
|
38
38
|
* @param value - The string value to parse
|
|
39
39
|
* @returns The parsed data
|
|
40
40
|
*/
|
|
41
|
-
static parse(value) {
|
|
42
|
-
|
|
41
|
+
static parse(value, options = {}) {
|
|
42
|
+
try {
|
|
43
|
+
if (options.expectComments === false) return parse$1(value);
|
|
44
|
+
} catch {}
|
|
45
|
+
const errors = [];
|
|
46
|
+
const result = parse(value, errors, {
|
|
47
|
+
allowTrailingComma: true,
|
|
48
|
+
...options
|
|
49
|
+
});
|
|
50
|
+
if (errors.length > 0 && errors[0]) throw new Error(formatParseError(value, errors[0]));
|
|
51
|
+
return result;
|
|
43
52
|
}
|
|
44
53
|
/**
|
|
45
54
|
* Serializes the given data to a JSON string.
|
|
@@ -56,26 +65,6 @@ var StormJSON = class StormJSON extends SuperJSON {
|
|
|
56
65
|
return stringify(result, options?.spaces ?? 2);
|
|
57
66
|
}
|
|
58
67
|
/**
|
|
59
|
-
* Parses the given JSON string and returns the object the JSON content represents.
|
|
60
|
-
* By default javascript-style comments and trailing commas are allowed.
|
|
61
|
-
*
|
|
62
|
-
* @param strData - JSON content as string
|
|
63
|
-
* @param options - JSON parse options
|
|
64
|
-
* @returns Object the JSON content represents
|
|
65
|
-
*/
|
|
66
|
-
static parseJson(strData, options) {
|
|
67
|
-
try {
|
|
68
|
-
if (options?.expectComments === false) return StormJSON.instance.parse(strData);
|
|
69
|
-
} catch {}
|
|
70
|
-
const errors = [];
|
|
71
|
-
const result = parse(strData, errors, {
|
|
72
|
-
allowTrailingComma: true,
|
|
73
|
-
...options
|
|
74
|
-
});
|
|
75
|
-
if (errors.length > 0 && errors[0]) throw new Error(formatParseError(strData, errors[0]));
|
|
76
|
-
return result;
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
68
|
* Register a custom schema with superjson
|
|
80
69
|
*
|
|
81
70
|
* @param name - The name of the schema
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"storm-json.mjs","names":["#instance","parseValue","
|
|
1
|
+
{"version":3,"file":"storm-json.mjs","names":["#instance","parseValue","errors: ParseError[]","stringifyValue"],"sources":["../../../../json/src/storm-json.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Stryke\n\n This code was released as part of the Stryke project. Stryke\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/stryke.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/stryke\n Documentation: https://docs.stormsoftware.com/projects/stryke\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport type { ParseError } from \"jsonc-parser\";\nimport type {\n Class,\n JsonParseOptions,\n JsonParserResult,\n JsonSerializeOptions,\n JsonValue\n} from \"./types\";\n// import { Decimal } from \"decimal.js\";\nimport { isObject } from \"@stryke/type-checks/is-object\";\nimport { isString } from \"@stryke/type-checks/is-string\";\nimport { parse } from \"jsonc-parser\";\nimport { Buffer } from \"node:buffer\";\nimport SuperJSON from \"superjson\";\nimport { parse as parseValue } from \"./utils/parse\";\nimport { formatParseError } from \"./utils/parse-error\";\nimport { stringify as stringifyValue } from \"./utils/stringify\";\n\n/**\n * A static JSON parser class used by Storm Software to serialize and deserialize JSON data\n *\n * @remarks\n * This class uses the [SuperJSON](https://github.com/blitz-js/superjson) library under the hood.\n */\nexport class StormJSON extends SuperJSON {\n static #instance: StormJSON;\n\n public static get instance(): StormJSON {\n if (!StormJSON.#instance) {\n StormJSON.#instance = new StormJSON();\n }\n\n return StormJSON.#instance;\n }\n\n /**\n * Deserialize the given value with superjson using the given metadata\n */\n public static override deserialize<TData = unknown>(\n payload: JsonParserResult\n ): TData {\n return StormJSON.instance.deserialize(payload);\n }\n\n /**\n * Serialize the given value with superjson\n */\n public static override serialize(object: JsonValue): JsonParserResult {\n return StormJSON.instance.serialize(object);\n }\n\n /**\n * Parse the given string value with superjson using the given metadata\n *\n * @param value - The string value to parse\n * @returns The parsed data\n */\n public static override parse<TData = unknown>(\n value: string,\n options: JsonParseOptions = {}\n ): TData {\n try {\n if (options.expectComments === false) {\n return parseValue<TData>(value);\n }\n } catch {\n // Do nothing\n }\n\n const errors: ParseError[] = [];\n const opts = {\n allowTrailingComma: true,\n ...options\n };\n const result = parse(value, errors, opts) as TData;\n\n if (errors.length > 0 && errors[0]) {\n throw new Error(formatParseError(value, errors[0]));\n }\n\n return result;\n }\n\n /**\n * Serializes the given data to a JSON string.\n * By default the JSON string is formatted with a 2 space indentation to be easy readable.\n *\n * @param value - Object which should be serialized to JSON\n * @param options - JSON serialize options\n * @returns the formatted JSON representation of the object\n */\n public static override stringify<T>(\n value: T,\n options?: JsonSerializeOptions\n ): string {\n const customTransformer =\n StormJSON.instance.customTransformerRegistry.findApplicable(value);\n\n let result = value;\n if (customTransformer && customTransformer.isApplicable(value)) {\n result = customTransformer.serialize(result) as T;\n }\n\n return stringifyValue(result, options?.spaces ?? 2);\n }\n\n /**\n * Register a custom schema with superjson\n *\n * @param name - The name of the schema\n * @param serialize - The function to serialize the schema\n * @param deserialize - The function to deserialize the schema\n * @param isApplicable - The function to check if the schema is applicable\n */\n public static register<\n TData = any,\n TJsonObject extends JsonValue = JsonValue\n >(\n name: string,\n serialize: (data: TData) => TJsonObject,\n deserialize: (json: TJsonObject) => TData,\n isApplicable: (data: any) => data is TData\n ) {\n StormJSON.instance.registerCustom<TData, TJsonObject>(\n {\n isApplicable,\n serialize,\n deserialize\n },\n name\n );\n }\n\n /**\n * Register a class with superjson\n *\n * @param classConstructor - The class constructor to register\n */\n public static override registerClass(\n classConstructor: Class,\n options?: { identifier?: string; allowProps?: string[] } | string\n ) {\n StormJSON.instance.registerClass(classConstructor, {\n identifier: isString(options)\n ? options\n : options?.identifier || classConstructor.name,\n allowProps:\n options &&\n isObject(options) &&\n options?.allowProps &&\n Array.isArray(options.allowProps)\n ? options.allowProps\n : [\"__typename\"]\n });\n }\n\n private constructor() {\n super({ dedupe: true });\n }\n}\n\nStormJSON.instance.registerCustom<Buffer, string>(\n {\n isApplicable: (v): v is Buffer =>\n typeof Buffer.isBuffer === \"function\" && Buffer.isBuffer(v),\n serialize: v => v.toString(\"base64\"),\n deserialize: v => Buffer.from(v, \"base64\")\n },\n \"Bytes\"\n);\n"],"mappings":";;;;;;;;;;;;;;;;AA0CA,IAAa,YAAb,MAAa,kBAAkB,UAAU;CACvC,QAAOA;CAEP,WAAkB,WAAsB;AACtC,MAAI,CAAC,WAAUA,SACb,YAAUA,WAAY,IAAI,WAAW;AAGvC,SAAO,WAAUA;;;;;CAMnB,OAAuB,YACrB,SACO;AACP,SAAO,UAAU,SAAS,YAAY,QAAQ;;;;;CAMhD,OAAuB,UAAU,QAAqC;AACpE,SAAO,UAAU,SAAS,UAAU,OAAO;;;;;;;;CAS7C,OAAuB,MACrB,OACA,UAA4B,EAAE,EACvB;AACP,MAAI;AACF,OAAI,QAAQ,mBAAmB,MAC7B,QAAOC,QAAkB,MAAM;UAE3B;EAIR,MAAMC,SAAuB,EAAE;EAK/B,MAAM,SAAS,MAAM,OAAO,QAJf;GACX,oBAAoB;GACpB,GAAG;GACJ,CACwC;AAEzC,MAAI,OAAO,SAAS,KAAK,OAAO,GAC9B,OAAM,IAAI,MAAM,iBAAiB,OAAO,OAAO,GAAG,CAAC;AAGrD,SAAO;;;;;;;;;;CAWT,OAAuB,UACrB,OACA,SACQ;EACR,MAAM,oBACJ,UAAU,SAAS,0BAA0B,eAAe,MAAM;EAEpE,IAAI,SAAS;AACb,MAAI,qBAAqB,kBAAkB,aAAa,MAAM,CAC5D,UAAS,kBAAkB,UAAU,OAAO;AAG9C,SAAOC,UAAe,QAAQ,SAAS,UAAU,EAAE;;;;;;;;;;CAWrD,OAAc,SAIZ,MACA,WACA,aACA,cACA;AACA,YAAU,SAAS,eACjB;GACE;GACA;GACA;GACD,EACD,KACD;;;;;;;CAQH,OAAuB,cACrB,kBACA,SACA;AACA,YAAU,SAAS,cAAc,kBAAkB;GACjD,YAAY,SAAS,QAAQ,GACzB,UACA,SAAS,cAAc,iBAAiB;GAC5C,YACE,WACA,SAAS,QAAQ,IACjB,SAAS,cACT,MAAM,QAAQ,QAAQ,WAAW,GAC7B,QAAQ,aACR,CAAC,aAAa;GACrB,CAAC;;CAGJ,AAAQ,cAAc;AACpB,QAAM,EAAE,QAAQ,MAAM,CAAC;;;AAI3B,UAAU,SAAS,eACjB;CACE,eAAe,MACb,OAAO,OAAO,aAAa,cAAc,OAAO,SAAS,EAAE;CAC7D,YAAW,MAAK,EAAE,SAAS,SAAS;CACpC,cAAa,MAAK,OAAO,KAAK,GAAG,SAAS;CAC3C,EACD,QACD"}
|
|
@@ -2,40 +2,6 @@ const require_is_number = require('../../../type-checks/src/is-number.cjs');
|
|
|
2
2
|
const require_is_undefined = require('../../../type-checks/src/is-undefined.cjs');
|
|
3
3
|
|
|
4
4
|
//#region ../json/src/utils/stringify.ts
|
|
5
|
-
const invalidKeyChars = [
|
|
6
|
-
"@",
|
|
7
|
-
"/",
|
|
8
|
-
"#",
|
|
9
|
-
"$",
|
|
10
|
-
" ",
|
|
11
|
-
":",
|
|
12
|
-
";",
|
|
13
|
-
",",
|
|
14
|
-
".",
|
|
15
|
-
"!",
|
|
16
|
-
"?",
|
|
17
|
-
"&",
|
|
18
|
-
"=",
|
|
19
|
-
"+",
|
|
20
|
-
"-",
|
|
21
|
-
"*",
|
|
22
|
-
"%",
|
|
23
|
-
"^",
|
|
24
|
-
"~",
|
|
25
|
-
"|",
|
|
26
|
-
"\\",
|
|
27
|
-
"\"",
|
|
28
|
-
"'",
|
|
29
|
-
"`",
|
|
30
|
-
"{",
|
|
31
|
-
"}",
|
|
32
|
-
"[",
|
|
33
|
-
"]",
|
|
34
|
-
"(",
|
|
35
|
-
")",
|
|
36
|
-
"<",
|
|
37
|
-
">"
|
|
38
|
-
];
|
|
39
5
|
/**
|
|
40
6
|
* Stringify a value to a JSON-like string.
|
|
41
7
|
*
|
|
@@ -58,7 +24,7 @@ const stringify = (value, spacing = 2) => {
|
|
|
58
24
|
switch (typeof value) {
|
|
59
25
|
case "number": return `${value}`;
|
|
60
26
|
case "string": return JSON.stringify(value);
|
|
61
|
-
case "object": return `{${space}${Object.keys(value).filter((key) => !require_is_undefined.isUndefined(value[key])).map((key) =>
|
|
27
|
+
case "object": return `{${space}${Object.keys(value).filter((key) => !require_is_undefined.isUndefined(value[key])).map((key) => `"${key}": ${space}${stringify(value[key], space)}`).join(`,${space}`)}${space}}`;
|
|
62
28
|
default: return "null";
|
|
63
29
|
}
|
|
64
30
|
};
|
|
@@ -2,40 +2,6 @@ import { isNumber } from "../../../type-checks/src/is-number.mjs";
|
|
|
2
2
|
import { isUndefined } from "../../../type-checks/src/is-undefined.mjs";
|
|
3
3
|
|
|
4
4
|
//#region ../json/src/utils/stringify.ts
|
|
5
|
-
const invalidKeyChars = [
|
|
6
|
-
"@",
|
|
7
|
-
"/",
|
|
8
|
-
"#",
|
|
9
|
-
"$",
|
|
10
|
-
" ",
|
|
11
|
-
":",
|
|
12
|
-
";",
|
|
13
|
-
",",
|
|
14
|
-
".",
|
|
15
|
-
"!",
|
|
16
|
-
"?",
|
|
17
|
-
"&",
|
|
18
|
-
"=",
|
|
19
|
-
"+",
|
|
20
|
-
"-",
|
|
21
|
-
"*",
|
|
22
|
-
"%",
|
|
23
|
-
"^",
|
|
24
|
-
"~",
|
|
25
|
-
"|",
|
|
26
|
-
"\\",
|
|
27
|
-
"\"",
|
|
28
|
-
"'",
|
|
29
|
-
"`",
|
|
30
|
-
"{",
|
|
31
|
-
"}",
|
|
32
|
-
"[",
|
|
33
|
-
"]",
|
|
34
|
-
"(",
|
|
35
|
-
")",
|
|
36
|
-
"<",
|
|
37
|
-
">"
|
|
38
|
-
];
|
|
39
5
|
/**
|
|
40
6
|
* Stringify a value to a JSON-like string.
|
|
41
7
|
*
|
|
@@ -58,7 +24,7 @@ const stringify = (value, spacing = 2) => {
|
|
|
58
24
|
switch (typeof value) {
|
|
59
25
|
case "number": return `${value}`;
|
|
60
26
|
case "string": return JSON.stringify(value);
|
|
61
|
-
case "object": return `{${space}${Object.keys(value).filter((key) => !isUndefined(value[key])).map((key) =>
|
|
27
|
+
case "object": return `{${space}${Object.keys(value).filter((key) => !isUndefined(value[key])).map((key) => `"${key}": ${space}${stringify(value[key], space)}`).join(`,${space}`)}${space}}`;
|
|
62
28
|
default: return "null";
|
|
63
29
|
}
|
|
64
30
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"stringify.mjs","names":[],"sources":["../../../../../json/src/utils/stringify.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Stryke\n\n This code was released as part of the Stryke project. Stryke\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/stryke.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/stryke\n Documentation: https://docs.stormsoftware.com/projects/stryke\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport { isNumber } from \"@stryke/type-checks/is-number\";\nimport { isUndefined } from \"@stryke/type-checks/is-undefined\";\n\nexport const invalidKeyChars = [\n \"@\",\n \"/\",\n \"#\",\n \"$\",\n \" \",\n \":\",\n \";\",\n \",\",\n \".\",\n \"!\",\n \"?\",\n \"&\",\n \"=\",\n \"+\",\n \"-\",\n \"*\",\n \"%\",\n \"^\",\n \"~\",\n \"|\",\n \"\\\\\",\n '\"',\n \"'\",\n \"`\",\n \"{\",\n \"}\",\n \"[\",\n \"]\",\n \"(\",\n \")\",\n \"<\",\n \">\"\n] as const;\n\n/**\n * Stringify a value to a JSON-like string.\n *\n * @param value - The value to stringify\n * @param spacing - The spacing to use for the stringification\n * @returns The stringified value\n */\nexport const stringify = (\n value: unknown,\n spacing: string | number = 2\n): string => {\n const space = isNumber(spacing) ? \" \".repeat(spacing) : spacing;\n\n switch (value) {\n case null: {\n return \"null\";\n }\n case undefined: {\n return '\"undefined\"';\n }\n case true: {\n return \"true\";\n }\n case false: {\n return \"false\";\n }\n case Number.POSITIVE_INFINITY: {\n return \"infinity\";\n }\n case Number.NEGATIVE_INFINITY: {\n return \"-infinity\";\n }\n }\n\n if (Array.isArray(value)) {\n return `[${space}${value.map(v => stringify(v, space)).join(`,${space}`)}${space}]`;\n }\n if (value instanceof Uint8Array) {\n return value.toString();\n }\n\n // eslint-disable-next-line ts/switch-exhaustiveness-check\n switch (typeof value) {\n case \"number\": {\n return `${value}`;\n }\n case \"string\": {\n return JSON.stringify(value);\n }\n case \"object\": {\n const keys = Object.keys(value as object).filter(\n key => !isUndefined((value as any)[key])\n );\n\n return `{${space}${keys\n .map(\n key
|
|
1
|
+
{"version":3,"file":"stringify.mjs","names":[],"sources":["../../../../../json/src/utils/stringify.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Stryke\n\n This code was released as part of the Stryke project. Stryke\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/stryke.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/stryke\n Documentation: https://docs.stormsoftware.com/projects/stryke\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport { isNumber } from \"@stryke/type-checks/is-number\";\nimport { isUndefined } from \"@stryke/type-checks/is-undefined\";\n\nexport const invalidKeyChars = [\n \"@\",\n \"/\",\n \"#\",\n \"$\",\n \" \",\n \":\",\n \";\",\n \",\",\n \".\",\n \"!\",\n \"?\",\n \"&\",\n \"=\",\n \"+\",\n \"-\",\n \"*\",\n \"%\",\n \"^\",\n \"~\",\n \"|\",\n \"\\\\\",\n '\"',\n \"'\",\n \"`\",\n \"{\",\n \"}\",\n \"[\",\n \"]\",\n \"(\",\n \")\",\n \"<\",\n \">\"\n] as const;\n\n/**\n * Stringify a value to a JSON-like string.\n *\n * @param value - The value to stringify\n * @param spacing - The spacing to use for the stringification\n * @returns The stringified value\n */\nexport const stringify = (\n value: unknown,\n spacing: string | number = 2\n): string => {\n const space = isNumber(spacing) ? \" \".repeat(spacing) : spacing;\n\n switch (value) {\n case null: {\n return \"null\";\n }\n case undefined: {\n return '\"undefined\"';\n }\n case true: {\n return \"true\";\n }\n case false: {\n return \"false\";\n }\n case Number.POSITIVE_INFINITY: {\n return \"infinity\";\n }\n case Number.NEGATIVE_INFINITY: {\n return \"-infinity\";\n }\n }\n\n if (Array.isArray(value)) {\n return `[${space}${value.map(v => stringify(v, space)).join(`,${space}`)}${space}]`;\n }\n if (value instanceof Uint8Array) {\n return value.toString();\n }\n\n // eslint-disable-next-line ts/switch-exhaustiveness-check\n switch (typeof value) {\n case \"number\": {\n return `${value}`;\n }\n case \"string\": {\n return JSON.stringify(value);\n }\n case \"object\": {\n const keys = Object.keys(value as object).filter(\n key => !isUndefined((value as any)[key])\n );\n\n return `{${space}${keys\n .map(\n key => `\"${key}\": ${space}${stringify((value as any)[key], space)}`\n )\n .join(`,${space}`)}${space}}`;\n }\n default:\n return \"null\";\n }\n};\n"],"mappings":";;;;;;;;;;;AA+DA,MAAa,aACX,OACA,UAA2B,MAChB;CACX,MAAM,QAAQ,SAAS,QAAQ,GAAG,IAAI,OAAO,QAAQ,GAAG;AAExD,SAAQ,OAAR;EACE,KAAK,KACH,QAAO;EAET,KAAK,OACH,QAAO;EAET,KAAK,KACH,QAAO;EAET,KAAK,MACH,QAAO;EAET,KAAK,OAAO,kBACV,QAAO;EAET,KAAK,OAAO,kBACV,QAAO;;AAIX,KAAI,MAAM,QAAQ,MAAM,CACtB,QAAO,IAAI,QAAQ,MAAM,KAAI,MAAK,UAAU,GAAG,MAAM,CAAC,CAAC,KAAK,IAAI,QAAQ,GAAG,MAAM;AAEnF,KAAI,iBAAiB,WACnB,QAAO,MAAM,UAAU;AAIzB,SAAQ,OAAO,OAAf;EACE,KAAK,SACH,QAAO,GAAG;EAEZ,KAAK,SACH,QAAO,KAAK,UAAU,MAAM;EAE9B,KAAK,SAKH,QAAO,IAAI,QAJE,OAAO,KAAK,MAAgB,CAAC,QACxC,QAAO,CAAC,YAAa,MAAc,KAAK,CACzC,CAGE,KACC,QAAO,IAAI,IAAI,KAAK,QAAQ,UAAW,MAAc,MAAM,MAAM,GAClE,CACA,KAAK,IAAI,QAAQ,GAAG,MAAM;EAE/B,QACE,QAAO"}
|
|
@@ -23,8 +23,8 @@ const require_get_object_tag = require('./get-object-tag.cjs');
|
|
|
23
23
|
* @param value - The value to check.
|
|
24
24
|
* @returns Returns `true` if `value` is object-like, else `false`.
|
|
25
25
|
*/
|
|
26
|
-
const isObjectLike = (
|
|
27
|
-
return typeof
|
|
26
|
+
const isObjectLike = (value) => {
|
|
27
|
+
return typeof value === "object" && value !== null;
|
|
28
28
|
};
|
|
29
29
|
/**
|
|
30
30
|
* Checks if `obj` is a plain object, that is, an object created by the `Object` constructor or one with a `[[Prototype]]` of `null`.
|
|
@@ -23,8 +23,8 @@ import { getObjectTag } from "./get-object-tag.mjs";
|
|
|
23
23
|
* @param value - The value to check.
|
|
24
24
|
* @returns Returns `true` if `value` is object-like, else `false`.
|
|
25
25
|
*/
|
|
26
|
-
const isObjectLike = (
|
|
27
|
-
return typeof
|
|
26
|
+
const isObjectLike = (value) => {
|
|
27
|
+
return typeof value === "object" && value !== null;
|
|
28
28
|
};
|
|
29
29
|
/**
|
|
30
30
|
* Checks if `obj` is a plain object, that is, an object created by the `Object` constructor or one with a `[[Prototype]]` of `null`.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"is-plain-object.mjs","names":[],"sources":["../../../../type-checks/src/is-plain-object.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Stryke\n\n This code was released as part of the Stryke project. Stryke\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/stryke.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/stryke\n Documentation: https://docs.stormsoftware.com/projects/stryke\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport type { PlainObject } from \"@stryke/types/base\";\nimport { getObjectTag } from \"./get-object-tag\";\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @example\n * ```typescript\n * isObjectLike({})\n * // => true\n *\n * isObjectLike([1, 2, 3])\n * // => true\n *\n * isObjectLike(Function)\n * // => false\n *\n * isObjectLike(null)\n * // => false\n * ```\n *\n * @param value - The value to check.\n * @returns Returns `true` if `value` is object-like, else `false`.\n */\nexport const isObjectLike = (
|
|
1
|
+
{"version":3,"file":"is-plain-object.mjs","names":[],"sources":["../../../../type-checks/src/is-plain-object.ts"],"sourcesContent":["/* -------------------------------------------------------------------\n\n ⚡ Storm Software - Stryke\n\n This code was released as part of the Stryke project. Stryke\n is maintained by Storm Software under the Apache-2.0 license, and is\n free for commercial and private use. For more information, please visit\n our licensing page at https://stormsoftware.com/licenses/projects/stryke.\n\n Website: https://stormsoftware.com\n Repository: https://github.com/storm-software/stryke\n Documentation: https://docs.stormsoftware.com/projects/stryke\n Contact: https://stormsoftware.com/contact\n\n SPDX-License-Identifier: Apache-2.0\n\n ------------------------------------------------------------------- */\n\nimport type { PlainObject } from \"@stryke/types/base\";\nimport { getObjectTag } from \"./get-object-tag\";\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @example\n * ```typescript\n * isObjectLike({})\n * // => true\n *\n * isObjectLike([1, 2, 3])\n * // => true\n *\n * isObjectLike(Function)\n * // => false\n *\n * isObjectLike(null)\n * // => false\n * ```\n *\n * @param value - The value to check.\n * @returns Returns `true` if `value` is object-like, else `false`.\n */\nexport const isObjectLike = (value: unknown) => {\n return typeof value === \"object\" && value !== null;\n};\n\n/**\n * Checks if `obj` is a plain object, that is, an object created by the `Object` constructor or one with a `[[Prototype]]` of `null`.\n *\n * @example\n * ```typescript\n * function Foo() {\n * this.a = 1\n * }\n *\n * isPlainObject(new Foo)\n * // => false\n *\n * isPlainObject([1, 2, 3])\n * // => false\n *\n * isPlainObject({ 'x': 0, 'y': 0 })\n * // => true\n *\n * isPlainObject(Object.create(null))\n * // => true\n * ```\n *\n * @param obj - The value to check.\n * @returns Returns `true` if `obj` is a plain object, else `false`.\n */\nexport const isPlainObject = (obj: unknown): obj is PlainObject => {\n if (!isObjectLike(obj) || getObjectTag(obj) !== \"[object Object]\") {\n return false;\n }\n if (Object.getPrototypeOf(obj) === null) {\n return true;\n }\n let proto = obj;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(obj) === proto;\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AA2CA,MAAa,gBAAgB,UAAmB;AAC9C,QAAO,OAAO,UAAU,YAAY,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4BhD,MAAa,iBAAiB,QAAqC;AACjE,KAAI,CAAC,aAAa,IAAI,IAAI,aAAa,IAAI,KAAK,kBAC9C,QAAO;AAET,KAAI,OAAO,eAAe,IAAI,KAAK,KACjC,QAAO;CAET,IAAI,QAAQ;AACZ,QAAO,OAAO,eAAe,MAAM,KAAK,KACtC,SAAQ,OAAO,eAAe,MAAM;AAEtC,QAAO,OAAO,eAAe,IAAI,KAAK"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@stryke/url",
|
|
3
|
-
"version": "0.4.
|
|
3
|
+
"version": "0.4.14",
|
|
4
4
|
"private": false,
|
|
5
5
|
"description": "A package containing the `StormURL` class, which is used to parse and manipulate URLs.",
|
|
6
6
|
"repository": {
|
|
@@ -32,5 +32,5 @@
|
|
|
32
32
|
"dependencies": { "ufo": "^1.6.3" },
|
|
33
33
|
"devDependencies": { "@types/node": "^24.12.0", "tsdown": "^0.17.2" },
|
|
34
34
|
"publishConfig": { "access": "public" },
|
|
35
|
-
"gitHead": "
|
|
35
|
+
"gitHead": "ad0acb8f9d34c16300a0901dd4db448756480415"
|
|
36
36
|
}
|