step-node-agent 3.26.4 → 3.26.5-CustomizedJv2
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/node_modules/{has-property-descriptors → call-bind-apply-helpers}/.github/FUNDING.yml +1 -1
- package/node_modules/call-bind-apply-helpers/CHANGELOG.md +23 -0
- package/node_modules/{call-bind → call-bind-apply-helpers}/LICENSE +1 -1
- package/node_modules/call-bind-apply-helpers/README.md +62 -0
- package/node_modules/call-bind-apply-helpers/actualApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/actualApply.js +10 -0
- package/node_modules/call-bind-apply-helpers/applyBind.d.ts +19 -0
- package/node_modules/call-bind-apply-helpers/applyBind.js +10 -0
- package/node_modules/call-bind-apply-helpers/functionApply.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/functionCall.d.ts +1 -0
- package/node_modules/call-bind-apply-helpers/functionCall.js +4 -0
- package/node_modules/call-bind-apply-helpers/index.d.ts +46 -0
- package/node_modules/call-bind-apply-helpers/index.js +15 -0
- package/node_modules/call-bind-apply-helpers/package.json +85 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.d.ts +3 -0
- package/node_modules/call-bind-apply-helpers/reflectApply.js +4 -0
- package/node_modules/call-bind-apply-helpers/test/index.js +63 -0
- package/node_modules/call-bind-apply-helpers/tsconfig.json +9 -0
- package/node_modules/call-bound/.eslintrc +13 -0
- package/node_modules/{call-bind → call-bound}/.github/FUNDING.yml +1 -1
- package/node_modules/call-bound/CHANGELOG.md +34 -0
- package/node_modules/{has-property-descriptors → call-bound}/LICENSE +1 -1
- package/node_modules/call-bound/README.md +53 -0
- package/node_modules/call-bound/index.d.ts +13 -0
- package/node_modules/call-bound/index.js +18 -0
- package/node_modules/{call-bind → call-bound}/package.json +27 -23
- package/node_modules/{call-bind/test/callBound.js → call-bound/test/index.js} +1 -1
- package/node_modules/{define-data-property → dunder-proto}/.github/FUNDING.yml +1 -1
- package/node_modules/dunder-proto/CHANGELOG.md +24 -0
- package/node_modules/dunder-proto/LICENSE +21 -0
- package/node_modules/dunder-proto/README.md +54 -0
- package/node_modules/dunder-proto/get.d.ts +5 -0
- package/node_modules/dunder-proto/get.js +30 -0
- package/node_modules/{has-proto → dunder-proto}/package.json +34 -36
- package/node_modules/dunder-proto/set.d.ts +5 -0
- package/node_modules/dunder-proto/set.js +35 -0
- package/node_modules/dunder-proto/test/get.js +34 -0
- package/node_modules/dunder-proto/test/index.js +4 -0
- package/node_modules/dunder-proto/test/set.js +50 -0
- package/node_modules/dunder-proto/tsconfig.json +9 -0
- package/node_modules/es-define-property/CHANGELOG.md +14 -0
- package/node_modules/es-define-property/index.js +1 -3
- package/node_modules/es-define-property/package.json +12 -12
- package/node_modules/es-define-property/test/index.js +1 -0
- package/node_modules/es-define-property/tsconfig.json +2 -42
- package/node_modules/es-object-atoms/.eslintrc +16 -0
- package/node_modules/{set-function-length → es-object-atoms}/.github/FUNDING.yml +1 -1
- package/node_modules/es-object-atoms/CHANGELOG.md +37 -0
- package/node_modules/{define-data-property → es-object-atoms}/LICENSE +1 -1
- package/node_modules/es-object-atoms/README.md +63 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +3 -0
- package/node_modules/es-object-atoms/RequireObjectCoercible.js +11 -0
- package/node_modules/es-object-atoms/ToObject.d.ts +7 -0
- package/node_modules/es-object-atoms/ToObject.js +10 -0
- package/node_modules/es-object-atoms/index.d.ts +3 -0
- package/node_modules/es-object-atoms/index.js +4 -0
- package/node_modules/es-object-atoms/isObject.d.ts +3 -0
- package/node_modules/es-object-atoms/isObject.js +6 -0
- package/node_modules/es-object-atoms/package.json +80 -0
- package/node_modules/es-object-atoms/test/index.js +38 -0
- package/node_modules/es-object-atoms/tsconfig.json +6 -0
- package/node_modules/express/History.md +10 -1
- package/node_modules/express/package.json +6 -2
- package/node_modules/get-intrinsic/CHANGELOG.md +35 -0
- package/node_modules/get-intrinsic/index.js +39 -21
- package/node_modules/get-intrinsic/package.json +23 -19
- package/node_modules/get-intrinsic/test/GetIntrinsic.js +2 -2
- package/node_modules/get-proto/.eslintrc +10 -0
- package/node_modules/{has-proto → get-proto}/.github/FUNDING.yml +1 -1
- package/node_modules/get-proto/.nycrc +9 -0
- package/node_modules/get-proto/CHANGELOG.md +21 -0
- package/node_modules/{has-proto → get-proto}/LICENSE +1 -1
- package/node_modules/get-proto/Object.getPrototypeOf.d.ts +5 -0
- package/node_modules/get-proto/Object.getPrototypeOf.js +6 -0
- package/node_modules/get-proto/README.md +50 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +3 -0
- package/node_modules/get-proto/Reflect.getPrototypeOf.js +4 -0
- package/node_modules/get-proto/index.d.ts +5 -0
- package/node_modules/get-proto/index.js +27 -0
- package/node_modules/{has-property-descriptors → get-proto}/package.json +35 -31
- package/node_modules/get-proto/test/index.js +68 -0
- package/node_modules/get-proto/tsconfig.json +9 -0
- package/node_modules/gopd/CHANGELOG.md +20 -0
- package/node_modules/gopd/gOPD.d.ts +1 -0
- package/node_modules/gopd/gOPD.js +4 -0
- package/node_modules/gopd/index.d.ts +5 -0
- package/node_modules/gopd/index.js +2 -3
- package/node_modules/gopd/package.json +16 -10
- package/node_modules/gopd/test/index.js +2 -1
- package/node_modules/gopd/tsconfig.json +9 -0
- package/node_modules/has-symbols/CHANGELOG.md +16 -0
- package/node_modules/has-symbols/index.d.ts +3 -0
- package/node_modules/has-symbols/index.js +1 -0
- package/node_modules/has-symbols/package.json +19 -9
- package/node_modules/has-symbols/shams.d.ts +3 -0
- package/node_modules/has-symbols/shams.js +5 -2
- package/node_modules/has-symbols/test/shams/core-js.js +1 -0
- package/node_modules/has-symbols/test/shams/get-own-property-symbols.js +1 -0
- package/node_modules/has-symbols/test/tests.js +4 -2
- package/node_modules/has-symbols/tsconfig.json +10 -0
- package/node_modules/is-core-module/CHANGELOG.md +13 -0
- package/node_modules/is-core-module/core.json +1 -0
- package/node_modules/is-core-module/package.json +3 -3
- package/node_modules/is-core-module/test/index.js +3 -0
- package/node_modules/math-intrinsics/.eslintrc +16 -0
- package/node_modules/math-intrinsics/.github/FUNDING.yml +12 -0
- package/node_modules/math-intrinsics/CHANGELOG.md +24 -0
- package/node_modules/math-intrinsics/LICENSE +21 -0
- package/node_modules/math-intrinsics/README.md +50 -0
- package/node_modules/math-intrinsics/abs.d.ts +1 -0
- package/node_modules/math-intrinsics/abs.js +4 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxArrayLength.js +4 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxSafeInteger.js +5 -0
- package/node_modules/math-intrinsics/constants/maxValue.d.ts +3 -0
- package/node_modules/math-intrinsics/constants/maxValue.js +5 -0
- package/node_modules/math-intrinsics/floor.d.ts +1 -0
- package/node_modules/math-intrinsics/floor.js +4 -0
- package/node_modules/math-intrinsics/isFinite.d.ts +3 -0
- package/node_modules/math-intrinsics/isFinite.js +12 -0
- package/node_modules/math-intrinsics/isInteger.d.ts +3 -0
- package/node_modules/math-intrinsics/isInteger.js +16 -0
- package/node_modules/math-intrinsics/isNaN.d.ts +1 -0
- package/node_modules/math-intrinsics/isNaN.js +6 -0
- package/node_modules/math-intrinsics/isNegativeZero.d.ts +3 -0
- package/node_modules/math-intrinsics/isNegativeZero.js +6 -0
- package/node_modules/math-intrinsics/max.d.ts +1 -0
- package/node_modules/math-intrinsics/max.js +4 -0
- package/node_modules/math-intrinsics/min.d.ts +1 -0
- package/node_modules/math-intrinsics/min.js +4 -0
- package/node_modules/math-intrinsics/mod.d.ts +3 -0
- package/node_modules/math-intrinsics/mod.js +9 -0
- package/node_modules/math-intrinsics/package.json +86 -0
- package/node_modules/math-intrinsics/pow.d.ts +1 -0
- package/node_modules/math-intrinsics/pow.js +4 -0
- package/node_modules/math-intrinsics/round.d.ts +1 -0
- package/node_modules/math-intrinsics/round.js +4 -0
- package/node_modules/math-intrinsics/sign.d.ts +3 -0
- package/node_modules/math-intrinsics/sign.js +11 -0
- package/node_modules/math-intrinsics/test/index.js +192 -0
- package/node_modules/math-intrinsics/tsconfig.json +3 -0
- package/node_modules/object-inspect/CHANGELOG.md +8 -0
- package/node_modules/object-inspect/index.js +10 -7
- package/node_modules/object-inspect/package.json +5 -4
- package/node_modules/object-inspect/test/values.js +50 -0
- package/node_modules/path-to-regexp/index.js +13 -3
- package/node_modules/path-to-regexp/package.json +1 -1
- package/node_modules/psl/README.md +7 -14
- package/node_modules/psl/SECURITY.md +13 -0
- package/node_modules/psl/data/rules.js +536 -529
- package/node_modules/psl/dist/psl.cjs +1 -1
- package/node_modules/psl/dist/psl.mjs +726 -715
- package/node_modules/psl/dist/psl.umd.cjs +1 -1
- package/node_modules/psl/index.js +52 -74
- package/node_modules/psl/package.json +10 -7
- package/node_modules/resolve/lib/core.json +4 -0
- package/node_modules/resolve/package.json +12 -9
- package/node_modules/side-channel/.eslintrc +1 -0
- package/node_modules/side-channel/CHANGELOG.md +15 -0
- package/node_modules/side-channel/README.md +60 -1
- package/node_modules/side-channel/index.d.ts +9 -22
- package/node_modules/side-channel/index.js +20 -106
- package/node_modules/side-channel/package.json +20 -19
- package/node_modules/side-channel/test/index.js +76 -55
- package/node_modules/side-channel/tsconfig.json +2 -43
- package/node_modules/side-channel-list/.editorconfig +9 -0
- package/node_modules/side-channel-list/.eslintrc +11 -0
- package/node_modules/side-channel-list/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-list/CHANGELOG.md +15 -0
- package/node_modules/side-channel-list/LICENSE +21 -0
- package/node_modules/side-channel-list/README.md +62 -0
- package/node_modules/side-channel-list/index.d.ts +13 -0
- package/node_modules/side-channel-list/index.js +113 -0
- package/node_modules/side-channel-list/list.d.ts +14 -0
- package/node_modules/side-channel-list/package.json +77 -0
- package/node_modules/side-channel-list/test/index.js +104 -0
- package/node_modules/side-channel-list/tsconfig.json +9 -0
- package/node_modules/side-channel-map/.editorconfig +9 -0
- package/node_modules/side-channel-map/.eslintrc +11 -0
- package/node_modules/side-channel-map/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-map/.nycrc +13 -0
- package/node_modules/side-channel-map/CHANGELOG.md +22 -0
- package/node_modules/side-channel-map/LICENSE +21 -0
- package/node_modules/side-channel-map/README.md +62 -0
- package/node_modules/side-channel-map/index.d.ts +15 -0
- package/node_modules/side-channel-map/index.js +68 -0
- package/node_modules/side-channel-map/package.json +80 -0
- package/node_modules/side-channel-map/test/index.js +114 -0
- package/node_modules/side-channel-map/tsconfig.json +9 -0
- package/node_modules/side-channel-weakmap/.editorconfig +9 -0
- package/node_modules/side-channel-weakmap/.eslintrc +12 -0
- package/node_modules/side-channel-weakmap/.github/FUNDING.yml +12 -0
- package/node_modules/side-channel-weakmap/.nycrc +13 -0
- package/node_modules/side-channel-weakmap/CHANGELOG.md +28 -0
- package/node_modules/side-channel-weakmap/LICENSE +21 -0
- package/node_modules/side-channel-weakmap/README.md +62 -0
- package/node_modules/side-channel-weakmap/index.d.ts +15 -0
- package/node_modules/side-channel-weakmap/index.js +84 -0
- package/node_modules/side-channel-weakmap/package.json +87 -0
- package/node_modules/side-channel-weakmap/test/index.js +114 -0
- package/node_modules/side-channel-weakmap/tsconfig.json +9 -0
- package/node_modules/yaml/README.md +27 -8
- package/node_modules/yaml/browser/dist/compose/resolve-props.js +1 -1
- package/node_modules/yaml/browser/dist/log.js +1 -4
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/binary.js +2 -11
- package/node_modules/yaml/browser/dist/util.js +1 -1
- package/node_modules/yaml/dist/compose/compose-collection.d.ts +4 -4
- package/node_modules/yaml/dist/compose/compose-doc.d.ts +6 -6
- package/node_modules/yaml/dist/compose/compose-node.d.ts +7 -7
- package/node_modules/yaml/dist/compose/compose-scalar.d.ts +4 -4
- package/node_modules/yaml/dist/compose/composer.d.ts +7 -6
- package/node_modules/yaml/dist/compose/composer.js +2 -1
- package/node_modules/yaml/dist/compose/resolve-block-map.d.ts +5 -5
- package/node_modules/yaml/dist/compose/resolve-block-scalar.d.ts +5 -5
- package/node_modules/yaml/dist/compose/resolve-block-seq.d.ts +5 -5
- package/node_modules/yaml/dist/compose/resolve-end.d.ts +2 -2
- package/node_modules/yaml/dist/compose/resolve-flow-collection.d.ts +7 -7
- package/node_modules/yaml/dist/compose/resolve-flow-scalar.d.ts +4 -4
- package/node_modules/yaml/dist/compose/resolve-props.d.ts +2 -2
- package/node_modules/yaml/dist/compose/resolve-props.js +1 -1
- package/node_modules/yaml/dist/compose/util-contains-newline.d.ts +1 -1
- package/node_modules/yaml/dist/compose/util-empty-scalar-position.d.ts +1 -1
- package/node_modules/yaml/dist/compose/util-flow-indent-check.d.ts +2 -2
- package/node_modules/yaml/dist/compose/util-map-includes.d.ts +3 -3
- package/node_modules/yaml/dist/doc/Document.d.ts +11 -11
- package/node_modules/yaml/dist/doc/anchors.d.ts +2 -2
- package/node_modules/yaml/dist/doc/createNode.d.ts +4 -4
- package/node_modules/yaml/dist/doc/directives.d.ts +1 -1
- package/node_modules/yaml/dist/index.d.ts +21 -18
- package/node_modules/yaml/dist/log.js +4 -2
- package/node_modules/yaml/dist/nodes/Alias.d.ts +9 -8
- package/node_modules/yaml/dist/nodes/Collection.d.ts +4 -4
- package/node_modules/yaml/dist/nodes/Node.d.ts +10 -10
- package/node_modules/yaml/dist/nodes/Pair.d.ts +9 -8
- package/node_modules/yaml/dist/nodes/Scalar.d.ts +4 -3
- package/node_modules/yaml/dist/nodes/YAMLMap.d.ts +10 -10
- package/node_modules/yaml/dist/nodes/YAMLSeq.d.ts +10 -10
- package/node_modules/yaml/dist/nodes/addPairToJSMap.d.ts +3 -3
- package/node_modules/yaml/dist/nodes/identity.d.ts +7 -7
- package/node_modules/yaml/dist/nodes/toJS.d.ts +2 -2
- package/node_modules/yaml/dist/options.d.ts +10 -10
- package/node_modules/yaml/dist/parse/cst-scalar.d.ts +4 -4
- package/node_modules/yaml/dist/parse/cst-stringify.d.ts +1 -1
- package/node_modules/yaml/dist/parse/cst-visit.d.ts +2 -2
- package/node_modules/yaml/dist/parse/cst.d.ts +4 -3
- package/node_modules/yaml/dist/parse/lexer.d.ts +1 -1
- package/node_modules/yaml/dist/parse/parser.d.ts +4 -4
- package/node_modules/yaml/dist/parse/parser.js +2 -1
- package/node_modules/yaml/dist/public-api.d.ts +6 -5
- package/node_modules/yaml/dist/schema/Schema.d.ts +4 -4
- package/node_modules/yaml/dist/schema/common/map.d.ts +1 -1
- package/node_modules/yaml/dist/schema/common/null.d.ts +1 -1
- package/node_modules/yaml/dist/schema/common/seq.d.ts +1 -1
- package/node_modules/yaml/dist/schema/common/string.d.ts +1 -1
- package/node_modules/yaml/dist/schema/core/bool.d.ts +1 -1
- package/node_modules/yaml/dist/schema/core/float.d.ts +1 -1
- package/node_modules/yaml/dist/schema/core/int.d.ts +1 -1
- package/node_modules/yaml/dist/schema/core/schema.d.ts +1 -1
- package/node_modules/yaml/dist/schema/json/schema.d.ts +1 -1
- package/node_modules/yaml/dist/schema/tags.d.ts +2 -2
- package/node_modules/yaml/dist/schema/types.d.ts +8 -8
- package/node_modules/yaml/dist/schema/yaml-1.1/binary.d.ts +1 -1
- package/node_modules/yaml/dist/schema/yaml-1.1/binary.js +6 -5
- package/node_modules/yaml/dist/schema/yaml-1.1/bool.d.ts +1 -1
- package/node_modules/yaml/dist/schema/yaml-1.1/float.d.ts +1 -1
- package/node_modules/yaml/dist/schema/yaml-1.1/int.d.ts +1 -1
- package/node_modules/yaml/dist/schema/yaml-1.1/merge.d.ts +3 -3
- package/node_modules/yaml/dist/schema/yaml-1.1/omap.d.ts +11 -17
- package/node_modules/yaml/dist/schema/yaml-1.1/pairs.d.ts +7 -7
- package/node_modules/yaml/dist/schema/yaml-1.1/schema.d.ts +1 -1
- package/node_modules/yaml/dist/schema/yaml-1.1/set.d.ts +9 -9
- package/node_modules/yaml/dist/schema/yaml-1.1/timestamp.d.ts +1 -1
- package/node_modules/yaml/dist/stringify/stringify.d.ts +3 -3
- package/node_modules/yaml/dist/stringify/stringifyCollection.d.ts +2 -2
- package/node_modules/yaml/dist/stringify/stringifyDocument.d.ts +3 -3
- package/node_modules/yaml/dist/stringify/stringifyNumber.d.ts +1 -1
- package/node_modules/yaml/dist/stringify/stringifyPair.d.ts +2 -2
- package/node_modules/yaml/dist/stringify/stringifyString.d.ts +2 -2
- package/node_modules/yaml/dist/util.d.ts +16 -12
- package/node_modules/yaml/dist/util.js +2 -2
- package/node_modules/yaml/dist/visit.d.ts +7 -7
- package/node_modules/yaml/package.json +4 -4
- package/package.json +1 -1
- package/node_modules/call-bind/.eslintignore +0 -1
- package/node_modules/call-bind/CHANGELOG.md +0 -93
- package/node_modules/call-bind/README.md +0 -64
- package/node_modules/call-bind/callBound.js +0 -15
- package/node_modules/call-bind/index.js +0 -35
- package/node_modules/call-bind/test/index.js +0 -80
- package/node_modules/define-data-property/.eslintrc +0 -24
- package/node_modules/define-data-property/CHANGELOG.md +0 -70
- package/node_modules/define-data-property/README.md +0 -67
- package/node_modules/define-data-property/index.d.ts +0 -12
- package/node_modules/define-data-property/index.js +0 -56
- package/node_modules/define-data-property/package.json +0 -106
- package/node_modules/define-data-property/test/index.js +0 -392
- package/node_modules/define-data-property/tsconfig.json +0 -59
- package/node_modules/has-property-descriptors/.eslintrc +0 -13
- package/node_modules/has-property-descriptors/CHANGELOG.md +0 -35
- package/node_modules/has-property-descriptors/README.md +0 -43
- package/node_modules/has-property-descriptors/index.js +0 -22
- package/node_modules/has-property-descriptors/test/index.js +0 -57
- package/node_modules/has-proto/CHANGELOG.md +0 -38
- package/node_modules/has-proto/README.md +0 -38
- package/node_modules/has-proto/index.d.ts +0 -3
- package/node_modules/has-proto/index.js +0 -15
- package/node_modules/has-proto/test/index.js +0 -19
- package/node_modules/has-proto/tsconfig.json +0 -49
- package/node_modules/set-function-length/.eslintrc +0 -27
- package/node_modules/set-function-length/CHANGELOG.md +0 -70
- package/node_modules/set-function-length/LICENSE +0 -21
- package/node_modules/set-function-length/README.md +0 -56
- package/node_modules/set-function-length/env.d.ts +0 -9
- package/node_modules/set-function-length/env.js +0 -25
- package/node_modules/set-function-length/index.d.ts +0 -7
- package/node_modules/set-function-length/index.js +0 -42
- package/node_modules/set-function-length/package.json +0 -102
- /package/node_modules/{call-bind → call-bind-apply-helpers}/.eslintrc +0 -0
- /package/node_modules/{call-bind → call-bind-apply-helpers}/.nycrc +0 -0
- /package/node_modules/{has-property-descriptors → call-bound}/.nycrc +0 -0
- /package/node_modules/{set-function-length → call-bound}/tsconfig.json +0 -0
- /package/node_modules/{has-proto → dunder-proto}/.eslintrc +0 -0
- /package/node_modules/{define-data-property → dunder-proto}/.nycrc +0 -0
- /package/node_modules/{set-function-length → side-channel-list}/.nycrc +0 -0
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
# side-channel-weakmap <sup>[![Version Badge][npm-version-svg]][package-url]</sup>
|
|
2
|
+
|
|
3
|
+
[![github actions][actions-image]][actions-url]
|
|
4
|
+
[![coverage][codecov-image]][codecov-url]
|
|
5
|
+
[![License][license-image]][license-url]
|
|
6
|
+
[![Downloads][downloads-image]][downloads-url]
|
|
7
|
+
|
|
8
|
+
[![npm badge][npm-badge-png]][package-url]
|
|
9
|
+
|
|
10
|
+
Store information about any JS value in a side channel. Uses WeakMap if available.
|
|
11
|
+
|
|
12
|
+
Warning: this implementation will leak memory until you `delete` the `key`.
|
|
13
|
+
Use [`side-channel`](https://npmjs.com/side-channel) for the best available strategy.
|
|
14
|
+
|
|
15
|
+
## Getting started
|
|
16
|
+
|
|
17
|
+
```sh
|
|
18
|
+
npm install --save side-channel-weakmap
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
## Usage/Examples
|
|
22
|
+
|
|
23
|
+
```js
|
|
24
|
+
const assert = require('assert');
|
|
25
|
+
const getSideChannelList = require('side-channel-weakmap');
|
|
26
|
+
|
|
27
|
+
const channel = getSideChannelList();
|
|
28
|
+
|
|
29
|
+
const key = {};
|
|
30
|
+
assert.equal(channel.has(key), false);
|
|
31
|
+
assert.throws(() => channel.assert(key), TypeError);
|
|
32
|
+
|
|
33
|
+
channel.set(key, 42);
|
|
34
|
+
|
|
35
|
+
channel.assert(key); // does not throw
|
|
36
|
+
assert.equal(channel.has(key), true);
|
|
37
|
+
assert.equal(channel.get(key), 42);
|
|
38
|
+
|
|
39
|
+
channel.delete(key);
|
|
40
|
+
assert.equal(channel.has(key), false);
|
|
41
|
+
assert.throws(() => channel.assert(key), TypeError);
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
## Tests
|
|
45
|
+
|
|
46
|
+
Clone the repo, `npm install`, and run `npm test`
|
|
47
|
+
|
|
48
|
+
[package-url]: https://npmjs.org/package/side-channel-weakmap
|
|
49
|
+
[npm-version-svg]: https://versionbadg.es/ljharb/side-channel-weakmap.svg
|
|
50
|
+
[deps-svg]: https://david-dm.org/ljharb/side-channel-weakmap.svg
|
|
51
|
+
[deps-url]: https://david-dm.org/ljharb/side-channel-weakmap
|
|
52
|
+
[dev-deps-svg]: https://david-dm.org/ljharb/side-channel-weakmap/dev-status.svg
|
|
53
|
+
[dev-deps-url]: https://david-dm.org/ljharb/side-channel-weakmap#info=devDependencies
|
|
54
|
+
[npm-badge-png]: https://nodei.co/npm/side-channel-weakmap.png?downloads=true&stars=true
|
|
55
|
+
[license-image]: https://img.shields.io/npm/l/side-channel-weakmap.svg
|
|
56
|
+
[license-url]: LICENSE
|
|
57
|
+
[downloads-image]: https://img.shields.io/npm/dm/side-channel-weakmap.svg
|
|
58
|
+
[downloads-url]: https://npm-stat.com/charts.html?package=side-channel-weakmap
|
|
59
|
+
[codecov-image]: https://codecov.io/gh/ljharb/side-channel-weakmap/branch/main/graphs/badge.svg
|
|
60
|
+
[codecov-url]: https://app.codecov.io/gh/ljharb/side-channel-weakmap/
|
|
61
|
+
[actions-image]: https://img.shields.io/endpoint?url=https://github-actions-badge-u3jn4tfpocch.runkit.sh/ljharb/side-channel-weakmap
|
|
62
|
+
[actions-url]: https://github.com/ljharb/side-channel-weakmap/actions
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
declare namespace getSideChannelWeakMap {
|
|
2
|
+
type Channel<K, V> = {
|
|
3
|
+
assert: (key: K) => void;
|
|
4
|
+
has: (key: K) => boolean;
|
|
5
|
+
get: (key: K) => V | undefined;
|
|
6
|
+
set: (key: K, value: V) => void;
|
|
7
|
+
delete: (key: K) => boolean;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
declare function getSideChannelWeakMap<K, V>(): getSideChannelWeakMap.Channel<K, V>;
|
|
12
|
+
|
|
13
|
+
declare const x: false | typeof getSideChannelWeakMap;
|
|
14
|
+
|
|
15
|
+
export = x;
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var GetIntrinsic = require('get-intrinsic');
|
|
4
|
+
var callBound = require('call-bound');
|
|
5
|
+
var inspect = require('object-inspect');
|
|
6
|
+
var getSideChannelMap = require('side-channel-map');
|
|
7
|
+
|
|
8
|
+
var $TypeError = require('es-errors/type');
|
|
9
|
+
var $WeakMap = GetIntrinsic('%WeakMap%', true);
|
|
10
|
+
|
|
11
|
+
/** @type {<K extends object, V>(thisArg: WeakMap<K, V>, key: K) => V} */
|
|
12
|
+
var $weakMapGet = callBound('WeakMap.prototype.get', true);
|
|
13
|
+
/** @type {<K extends object, V>(thisArg: WeakMap<K, V>, key: K, value: V) => void} */
|
|
14
|
+
var $weakMapSet = callBound('WeakMap.prototype.set', true);
|
|
15
|
+
/** @type {<K extends object, V>(thisArg: WeakMap<K, V>, key: K) => boolean} */
|
|
16
|
+
var $weakMapHas = callBound('WeakMap.prototype.has', true);
|
|
17
|
+
/** @type {<K extends object, V>(thisArg: WeakMap<K, V>, key: K) => boolean} */
|
|
18
|
+
var $weakMapDelete = callBound('WeakMap.prototype.delete', true);
|
|
19
|
+
|
|
20
|
+
/** @type {import('.')} */
|
|
21
|
+
module.exports = $WeakMap
|
|
22
|
+
? /** @type {Exclude<import('.'), false>} */ function getSideChannelWeakMap() {
|
|
23
|
+
/** @typedef {ReturnType<typeof getSideChannelWeakMap>} Channel */
|
|
24
|
+
/** @typedef {Parameters<Channel['get']>[0]} K */
|
|
25
|
+
/** @typedef {Parameters<Channel['set']>[1]} V */
|
|
26
|
+
|
|
27
|
+
/** @type {WeakMap<K & object, V> | undefined} */ var $wm;
|
|
28
|
+
/** @type {Channel | undefined} */ var $m;
|
|
29
|
+
|
|
30
|
+
/** @type {Channel} */
|
|
31
|
+
var channel = {
|
|
32
|
+
assert: function (key) {
|
|
33
|
+
if (!channel.has(key)) {
|
|
34
|
+
throw new $TypeError('Side channel does not contain ' + inspect(key));
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
'delete': function (key) {
|
|
38
|
+
if ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {
|
|
39
|
+
if ($wm) {
|
|
40
|
+
return $weakMapDelete($wm, key);
|
|
41
|
+
}
|
|
42
|
+
} else if (getSideChannelMap) {
|
|
43
|
+
if ($m) {
|
|
44
|
+
return $m['delete'](key);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
return false;
|
|
48
|
+
},
|
|
49
|
+
get: function (key) {
|
|
50
|
+
if ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {
|
|
51
|
+
if ($wm) {
|
|
52
|
+
return $weakMapGet($wm, key);
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
return $m && $m.get(key);
|
|
56
|
+
},
|
|
57
|
+
has: function (key) {
|
|
58
|
+
if ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {
|
|
59
|
+
if ($wm) {
|
|
60
|
+
return $weakMapHas($wm, key);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
return !!$m && $m.has(key);
|
|
64
|
+
},
|
|
65
|
+
set: function (key, value) {
|
|
66
|
+
if ($WeakMap && key && (typeof key === 'object' || typeof key === 'function')) {
|
|
67
|
+
if (!$wm) {
|
|
68
|
+
$wm = new $WeakMap();
|
|
69
|
+
}
|
|
70
|
+
$weakMapSet($wm, key, value);
|
|
71
|
+
} else if (getSideChannelMap) {
|
|
72
|
+
if (!$m) {
|
|
73
|
+
$m = getSideChannelMap();
|
|
74
|
+
}
|
|
75
|
+
// eslint-disable-next-line no-extra-parens
|
|
76
|
+
/** @type {NonNullable<typeof $m>} */ ($m).set(key, value);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
// @ts-expect-error TODO: figure out why this is erroring
|
|
82
|
+
return channel;
|
|
83
|
+
}
|
|
84
|
+
: getSideChannelMap;
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "side-channel-weakmap",
|
|
3
|
+
"version": "1.0.2",
|
|
4
|
+
"description": "Store information about any JS value in a side channel. Uses WeakMap if available.",
|
|
5
|
+
"main": "index.js",
|
|
6
|
+
"exports": {
|
|
7
|
+
".": "./index.js",
|
|
8
|
+
"./package.json": "./package.json"
|
|
9
|
+
},
|
|
10
|
+
"types": "./index.d.ts",
|
|
11
|
+
"scripts": {
|
|
12
|
+
"prepack": "npmignore --auto --commentLines=autogenerated",
|
|
13
|
+
"prepublishOnly": "safe-publish-latest",
|
|
14
|
+
"prepublish": "not-in-publish || npm run prepublishOnly",
|
|
15
|
+
"prelint": "eclint check $(git ls-files | xargs find 2> /dev/null | grep -vE 'node_modules|\\.git')",
|
|
16
|
+
"lint": "eslint --ext=js,mjs .",
|
|
17
|
+
"postlint": "tsc -p . && attw -P",
|
|
18
|
+
"pretest": "npm run lint",
|
|
19
|
+
"tests-only": "nyc tape 'test/**/*.js'",
|
|
20
|
+
"test": "npm run tests-only",
|
|
21
|
+
"posttest": "npx npm@'>=10.2' audit --production",
|
|
22
|
+
"version": "auto-changelog && git add CHANGELOG.md",
|
|
23
|
+
"postversion": "auto-changelog && git add CHANGELOG.md && git commit --no-edit --amend && git tag -f \"v$(node -e \"console.log(require('./package.json').version)\")\""
|
|
24
|
+
},
|
|
25
|
+
"repository": {
|
|
26
|
+
"type": "git",
|
|
27
|
+
"url": "git+https://github.com/ljharb/side-channel-weakmap.git"
|
|
28
|
+
},
|
|
29
|
+
"keywords": [
|
|
30
|
+
"weakmap",
|
|
31
|
+
"map",
|
|
32
|
+
"side",
|
|
33
|
+
"channel",
|
|
34
|
+
"metadata"
|
|
35
|
+
],
|
|
36
|
+
"author": "Jordan Harband <ljharb@gmail.com>",
|
|
37
|
+
"funding": {
|
|
38
|
+
"url": "https://github.com/sponsors/ljharb"
|
|
39
|
+
},
|
|
40
|
+
"license": "MIT",
|
|
41
|
+
"bugs": {
|
|
42
|
+
"url": "https://github.com/ljharb/side-channel-weakmap/issues"
|
|
43
|
+
},
|
|
44
|
+
"homepage": "https://github.com/ljharb/side-channel-weakmap#readme",
|
|
45
|
+
"dependencies": {
|
|
46
|
+
"call-bound": "^1.0.2",
|
|
47
|
+
"es-errors": "^1.3.0",
|
|
48
|
+
"get-intrinsic": "^1.2.5",
|
|
49
|
+
"object-inspect": "^1.13.3",
|
|
50
|
+
"side-channel-map": "^1.0.1"
|
|
51
|
+
},
|
|
52
|
+
"devDependencies": {
|
|
53
|
+
"@arethetypeswrong/cli": "^0.17.1",
|
|
54
|
+
"@ljharb/eslint-config": "^21.1.1",
|
|
55
|
+
"@ljharb/tsconfig": "^0.2.2",
|
|
56
|
+
"@types/call-bind": "^1.0.5",
|
|
57
|
+
"@types/get-intrinsic": "^1.2.3",
|
|
58
|
+
"@types/object-inspect": "^1.13.0",
|
|
59
|
+
"@types/tape": "^5.6.5",
|
|
60
|
+
"auto-changelog": "^2.5.0",
|
|
61
|
+
"eclint": "^2.8.1",
|
|
62
|
+
"encoding": "^0.1.13",
|
|
63
|
+
"eslint": "=8.8.0",
|
|
64
|
+
"in-publish": "^2.0.1",
|
|
65
|
+
"npmignore": "^0.3.1",
|
|
66
|
+
"nyc": "^10.3.2",
|
|
67
|
+
"safe-publish-latest": "^2.0.0",
|
|
68
|
+
"tape": "^5.9.0",
|
|
69
|
+
"typescript": "next"
|
|
70
|
+
},
|
|
71
|
+
"auto-changelog": {
|
|
72
|
+
"output": "CHANGELOG.md",
|
|
73
|
+
"template": "keepachangelog",
|
|
74
|
+
"unreleased": false,
|
|
75
|
+
"commitLimit": false,
|
|
76
|
+
"backfillLimit": false,
|
|
77
|
+
"hideCredit": true
|
|
78
|
+
},
|
|
79
|
+
"publishConfig": {
|
|
80
|
+
"ignore": [
|
|
81
|
+
".github/workflows"
|
|
82
|
+
]
|
|
83
|
+
},
|
|
84
|
+
"engines": {
|
|
85
|
+
"node": ">= 0.4"
|
|
86
|
+
}
|
|
87
|
+
}
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var test = require('tape');
|
|
4
|
+
|
|
5
|
+
var getSideChannelWeakMap = require('../');
|
|
6
|
+
|
|
7
|
+
test('getSideChannelMap', { skip: typeof WeakMap !== 'function' && typeof Map !== 'function' }, function (t) {
|
|
8
|
+
var getSideChannel = getSideChannelWeakMap || function () {
|
|
9
|
+
throw new EvalError('should never happen');
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
t.test('export', function (st) {
|
|
13
|
+
st.equal(typeof getSideChannel, 'function', 'is a function');
|
|
14
|
+
|
|
15
|
+
st.equal(getSideChannel.length, 0, 'takes no arguments');
|
|
16
|
+
|
|
17
|
+
var channel = getSideChannel();
|
|
18
|
+
st.ok(channel, 'is truthy');
|
|
19
|
+
st.equal(typeof channel, 'object', 'is an object');
|
|
20
|
+
st.end();
|
|
21
|
+
});
|
|
22
|
+
|
|
23
|
+
t.test('assert', function (st) {
|
|
24
|
+
var channel = getSideChannel();
|
|
25
|
+
st['throws'](
|
|
26
|
+
function () { channel.assert({}); },
|
|
27
|
+
TypeError,
|
|
28
|
+
'nonexistent value throws'
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
var o = {};
|
|
32
|
+
channel.set(o, 'data');
|
|
33
|
+
st.doesNotThrow(function () { channel.assert(o); }, 'existent value noops');
|
|
34
|
+
|
|
35
|
+
st.end();
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
t.test('has', function (st) {
|
|
39
|
+
var channel = getSideChannel();
|
|
40
|
+
/** @type {unknown[]} */ var o = [];
|
|
41
|
+
|
|
42
|
+
st.equal(channel.has(o), false, 'nonexistent value yields false');
|
|
43
|
+
|
|
44
|
+
channel.set(o, 'foo');
|
|
45
|
+
st.equal(channel.has(o), true, 'existent value yields true');
|
|
46
|
+
|
|
47
|
+
st.equal(channel.has('abc'), false, 'non object value non existent yields false');
|
|
48
|
+
|
|
49
|
+
channel.set('abc', 'foo');
|
|
50
|
+
st.equal(channel.has('abc'), true, 'non object value that exists yields true');
|
|
51
|
+
|
|
52
|
+
st.end();
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
t.test('get', function (st) {
|
|
56
|
+
var channel = getSideChannel();
|
|
57
|
+
var o = {};
|
|
58
|
+
st.equal(channel.get(o), undefined, 'nonexistent value yields undefined');
|
|
59
|
+
|
|
60
|
+
var data = {};
|
|
61
|
+
channel.set(o, data);
|
|
62
|
+
st.equal(channel.get(o), data, '"get" yields data set by "set"');
|
|
63
|
+
|
|
64
|
+
st.end();
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
t.test('set', function (st) {
|
|
68
|
+
var channel = getSideChannel();
|
|
69
|
+
var o = function () {};
|
|
70
|
+
st.equal(channel.get(o), undefined, 'value not set');
|
|
71
|
+
|
|
72
|
+
channel.set(o, 42);
|
|
73
|
+
st.equal(channel.get(o), 42, 'value was set');
|
|
74
|
+
|
|
75
|
+
channel.set(o, Infinity);
|
|
76
|
+
st.equal(channel.get(o), Infinity, 'value was set again');
|
|
77
|
+
|
|
78
|
+
var o2 = {};
|
|
79
|
+
channel.set(o2, 17);
|
|
80
|
+
st.equal(channel.get(o), Infinity, 'o is not modified');
|
|
81
|
+
st.equal(channel.get(o2), 17, 'o2 is set');
|
|
82
|
+
|
|
83
|
+
channel.set(o, 14);
|
|
84
|
+
st.equal(channel.get(o), 14, 'o is modified');
|
|
85
|
+
st.equal(channel.get(o2), 17, 'o2 is not modified');
|
|
86
|
+
|
|
87
|
+
st.end();
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
t.test('delete', function (st) {
|
|
91
|
+
var channel = getSideChannel();
|
|
92
|
+
var o = {};
|
|
93
|
+
st.equal(channel['delete']({}), false, 'nonexistent value yields false');
|
|
94
|
+
|
|
95
|
+
channel.set(o, 42);
|
|
96
|
+
st.equal(channel.has(o), true, 'value is set');
|
|
97
|
+
|
|
98
|
+
st.equal(channel['delete']({}), false, 'nonexistent value still yields false');
|
|
99
|
+
|
|
100
|
+
st.equal(channel['delete'](o), true, 'deleted value yields true');
|
|
101
|
+
|
|
102
|
+
st.equal(channel.has(o), false, 'value is no longer set');
|
|
103
|
+
|
|
104
|
+
st.end();
|
|
105
|
+
});
|
|
106
|
+
|
|
107
|
+
t.end();
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
test('getSideChannelMap, no WeakMaps and/or Maps', { skip: typeof WeakMap === 'function' || typeof Map === 'function' }, function (t) {
|
|
111
|
+
t.equal(getSideChannelWeakMap, false, 'is false');
|
|
112
|
+
|
|
113
|
+
t.end();
|
|
114
|
+
});
|
|
@@ -55,24 +55,29 @@ The first has the simplest API and "just works", the second gets you all the bel
|
|
|
55
55
|
|
|
56
56
|
A [command-line tool](https://eemeli.org/yaml/#command-line-tool) is also included.
|
|
57
57
|
|
|
58
|
+
### Parse & Stringify
|
|
59
|
+
|
|
58
60
|
```js
|
|
59
61
|
import { parse, stringify } from 'yaml'
|
|
60
|
-
// or
|
|
61
|
-
import YAML from 'yaml'
|
|
62
|
-
// or
|
|
63
|
-
const YAML = require('yaml')
|
|
64
62
|
```
|
|
65
63
|
|
|
66
|
-
### Parse & Stringify
|
|
67
|
-
|
|
68
64
|
- [`parse(str, reviver?, options?): value`](https://eemeli.org/yaml/#yaml-parse)
|
|
69
65
|
- [`stringify(value, replacer?, options?): string`](https://eemeli.org/yaml/#yaml-stringify)
|
|
70
66
|
|
|
71
67
|
### Documents
|
|
72
68
|
|
|
69
|
+
<!-- prettier-ignore -->
|
|
70
|
+
```js
|
|
71
|
+
import {
|
|
72
|
+
Document,
|
|
73
|
+
isDocument,
|
|
74
|
+
parseAllDocuments,
|
|
75
|
+
parseDocument
|
|
76
|
+
} from 'yaml'
|
|
77
|
+
```
|
|
78
|
+
|
|
73
79
|
- [`Document`](https://eemeli.org/yaml/#documents)
|
|
74
80
|
- [`constructor(value, replacer?, options?)`](https://eemeli.org/yaml/#creating-documents)
|
|
75
|
-
- [`#anchors`](https://eemeli.org/yaml/#working-with-anchors)
|
|
76
81
|
- [`#contents`](https://eemeli.org/yaml/#content-nodes)
|
|
77
82
|
- [`#directives`](https://eemeli.org/yaml/#stream-directives)
|
|
78
83
|
- [`#errors`](https://eemeli.org/yaml/#errors)
|
|
@@ -83,6 +88,15 @@ const YAML = require('yaml')
|
|
|
83
88
|
|
|
84
89
|
### Content Nodes
|
|
85
90
|
|
|
91
|
+
<!-- prettier-ignore -->
|
|
92
|
+
```js
|
|
93
|
+
import {
|
|
94
|
+
isAlias, isCollection, isMap, isNode,
|
|
95
|
+
isPair, isScalar, isSeq, Scalar,
|
|
96
|
+
visit, visitAsync, YAMLMap, YAMLSeq
|
|
97
|
+
} from 'yaml'
|
|
98
|
+
```
|
|
99
|
+
|
|
86
100
|
- [`isAlias(foo): boolean`](https://eemeli.org/yaml/#identifying-node-types)
|
|
87
101
|
- [`isCollection(foo): boolean`](https://eemeli.org/yaml/#identifying-node-types)
|
|
88
102
|
- [`isMap(foo): boolean`](https://eemeli.org/yaml/#identifying-node-types)
|
|
@@ -93,13 +107,18 @@ const YAML = require('yaml')
|
|
|
93
107
|
- [`new Scalar(value)`](https://eemeli.org/yaml/#scalar-values)
|
|
94
108
|
- [`new YAMLMap()`](https://eemeli.org/yaml/#collections)
|
|
95
109
|
- [`new YAMLSeq()`](https://eemeli.org/yaml/#collections)
|
|
96
|
-
- [`doc.createAlias(node, name?): Alias`](https://eemeli.org/yaml/#
|
|
110
|
+
- [`doc.createAlias(node, name?): Alias`](https://eemeli.org/yaml/#creating-nodes)
|
|
97
111
|
- [`doc.createNode(value, options?): Node`](https://eemeli.org/yaml/#creating-nodes)
|
|
98
112
|
- [`doc.createPair(key, value): Pair`](https://eemeli.org/yaml/#creating-nodes)
|
|
99
113
|
- [`visit(node, visitor)`](https://eemeli.org/yaml/#finding-and-modifying-nodes)
|
|
114
|
+
- [`visitAsync(node, visitor)`](https://eemeli.org/yaml/#finding-and-modifying-nodes)
|
|
100
115
|
|
|
101
116
|
### Parsing YAML
|
|
102
117
|
|
|
118
|
+
```js
|
|
119
|
+
import { Composer, Lexer, Parser } from 'yaml'
|
|
120
|
+
```
|
|
121
|
+
|
|
103
122
|
- [`new Lexer().lex(src)`](https://eemeli.org/yaml/#lexer)
|
|
104
123
|
- [`new Parser(onNewLine?).parse(src)`](https://eemeli.org/yaml/#parser)
|
|
105
124
|
- [`new Composer(options?).compose(tokens)`](https://eemeli.org/yaml/#composer)
|
|
@@ -4,10 +4,7 @@ function debug(logLevel, ...messages) {
|
|
|
4
4
|
}
|
|
5
5
|
function warn(logLevel, warning) {
|
|
6
6
|
if (logLevel === 'debug' || logLevel === 'warn') {
|
|
7
|
-
|
|
8
|
-
process.emitWarning(warning);
|
|
9
|
-
else
|
|
10
|
-
console.warn(warning);
|
|
7
|
+
console.warn(warning);
|
|
11
8
|
}
|
|
12
9
|
}
|
|
13
10
|
|
|
@@ -14,10 +14,7 @@ const binary = {
|
|
|
14
14
|
* document.querySelector('#photo').src = URL.createObjectURL(blob)
|
|
15
15
|
*/
|
|
16
16
|
resolve(src, onError) {
|
|
17
|
-
if (typeof
|
|
18
|
-
return Buffer.from(src, 'base64');
|
|
19
|
-
}
|
|
20
|
-
else if (typeof atob === 'function') {
|
|
17
|
+
if (typeof atob === 'function') {
|
|
21
18
|
// On IE 11, atob() can't handle newlines
|
|
22
19
|
const str = atob(src.replace(/[\n\r]/g, ''));
|
|
23
20
|
const buffer = new Uint8Array(str.length);
|
|
@@ -33,13 +30,7 @@ const binary = {
|
|
|
33
30
|
stringify({ comment, type, value }, ctx, onComment, onChompKeep) {
|
|
34
31
|
const buf = value; // checked earlier by binary.identify()
|
|
35
32
|
let str;
|
|
36
|
-
if (typeof
|
|
37
|
-
str =
|
|
38
|
-
buf instanceof Buffer
|
|
39
|
-
? buf.toString('base64')
|
|
40
|
-
: Buffer.from(buf.buffer).toString('base64');
|
|
41
|
-
}
|
|
42
|
-
else if (typeof btoa === 'function') {
|
|
33
|
+
if (typeof btoa === 'function') {
|
|
43
34
|
let s = '';
|
|
44
35
|
for (let i = 0; i < buf.length; ++i)
|
|
45
36
|
s += String.fromCharCode(buf[i]);
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
export { createNode } from './doc/createNode.js';
|
|
2
2
|
export { debug, warn } from './log.js';
|
|
3
3
|
export { createPair } from './nodes/Pair.js';
|
|
4
|
-
export { findPair } from './nodes/YAMLMap.js';
|
|
5
4
|
export { toJS } from './nodes/toJS.js';
|
|
5
|
+
export { findPair } from './nodes/YAMLMap.js';
|
|
6
6
|
export { map as mapTag } from './schema/common/map.js';
|
|
7
7
|
export { seq as seqTag } from './schema/common/seq.js';
|
|
8
8
|
export { string as stringTag } from './schema/common/string.js';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { ParsedNode } from '../nodes/Node
|
|
2
|
-
import type { BlockMap, BlockSequence, FlowCollection, SourceToken } from '../parse/cst
|
|
3
|
-
import type { ComposeContext, ComposeNode } from './compose-node
|
|
4
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import type { ParsedNode } from '../nodes/Node';
|
|
2
|
+
import type { BlockMap, BlockSequence, FlowCollection, SourceToken } from '../parse/cst';
|
|
3
|
+
import type { ComposeContext, ComposeNode } from './compose-node';
|
|
4
|
+
import type { ComposeErrorHandler } from './composer';
|
|
5
5
|
interface Props {
|
|
6
6
|
anchor: SourceToken | null;
|
|
7
7
|
tag: SourceToken | null;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { Directives } from '../doc/directives
|
|
2
|
-
import { Document } from '../doc/Document
|
|
3
|
-
import type { ParsedNode } from '../nodes/Node
|
|
4
|
-
import type { DocumentOptions, ParseOptions, SchemaOptions } from '../options
|
|
5
|
-
import type * as CST from '../parse/cst
|
|
6
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import type { Directives } from '../doc/directives';
|
|
2
|
+
import { Document } from '../doc/Document';
|
|
3
|
+
import type { ParsedNode } from '../nodes/Node';
|
|
4
|
+
import type { DocumentOptions, ParseOptions, SchemaOptions } from '../options';
|
|
5
|
+
import type * as CST from '../parse/cst';
|
|
6
|
+
import type { ComposeErrorHandler } from './composer';
|
|
7
7
|
export declare function composeDoc<Contents extends ParsedNode = ParsedNode, Strict extends boolean = true>(options: ParseOptions & DocumentOptions & SchemaOptions, directives: Directives, { offset, start, value, end }: CST.Document, onError: ComposeErrorHandler): Document.Parsed<Contents, Strict>;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import type { Directives } from '../doc/directives
|
|
2
|
-
import type { ParsedNode } from '../nodes/Node
|
|
3
|
-
import type { ParseOptions } from '../options
|
|
4
|
-
import type { SourceToken, Token } from '../parse/cst
|
|
5
|
-
import type { Schema } from '../schema/Schema
|
|
6
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import type { Directives } from '../doc/directives';
|
|
2
|
+
import type { ParsedNode } from '../nodes/Node';
|
|
3
|
+
import type { ParseOptions } from '../options';
|
|
4
|
+
import type { SourceToken, Token } from '../parse/cst';
|
|
5
|
+
import type { Schema } from '../schema/Schema';
|
|
6
|
+
import type { ComposeErrorHandler } from './composer';
|
|
7
7
|
export interface ComposeContext {
|
|
8
8
|
atKey: boolean;
|
|
9
9
|
atRoot: boolean;
|
|
@@ -25,5 +25,5 @@ declare const CN: {
|
|
|
25
25
|
};
|
|
26
26
|
export type ComposeNode = typeof CN;
|
|
27
27
|
export declare function composeNode(ctx: ComposeContext, token: Token, props: Props, onError: ComposeErrorHandler): ParsedNode;
|
|
28
|
-
export declare function composeEmptyNode(ctx: ComposeContext, offset: number, before: Token[] | undefined, pos: number | null, { spaceBefore, comment, anchor, tag, end }: Props, onError: ComposeErrorHandler): import(
|
|
28
|
+
export declare function composeEmptyNode(ctx: ComposeContext, offset: number, before: Token[] | undefined, pos: number | null, { spaceBefore, comment, anchor, tag, end }: Props, onError: ComposeErrorHandler): import('../index').Scalar.Parsed;
|
|
29
29
|
export {};
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { Scalar } from '../nodes/Scalar
|
|
2
|
-
import type { BlockScalar, FlowScalar, SourceToken } from '../parse/cst
|
|
3
|
-
import type { ComposeContext } from './compose-node
|
|
4
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import { Scalar } from '../nodes/Scalar';
|
|
2
|
+
import type { BlockScalar, FlowScalar, SourceToken } from '../parse/cst';
|
|
3
|
+
import type { ComposeContext } from './compose-node';
|
|
4
|
+
import type { ComposeErrorHandler } from './composer';
|
|
5
5
|
export declare function composeScalar(ctx: ComposeContext, token: FlowScalar | BlockScalar, tagToken: SourceToken | null, onError: ComposeErrorHandler): Scalar.Parsed;
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { Directives } from '../doc/directives
|
|
2
|
-
import { Document } from '../doc/Document
|
|
3
|
-
import { ErrorCode
|
|
4
|
-
import
|
|
5
|
-
import type {
|
|
6
|
-
import type {
|
|
1
|
+
import { Directives } from '../doc/directives';
|
|
2
|
+
import { Document } from '../doc/Document';
|
|
3
|
+
import type { ErrorCode } from '../errors';
|
|
4
|
+
import { YAMLParseError, YAMLWarning } from '../errors';
|
|
5
|
+
import type { ParsedNode, Range } from '../nodes/Node';
|
|
6
|
+
import type { DocumentOptions, ParseOptions, SchemaOptions } from '../options';
|
|
7
|
+
import type { Token } from '../parse/cst';
|
|
7
8
|
type ErrorSource = number | [number, number] | Range | {
|
|
8
9
|
offset: number;
|
|
9
10
|
source?: string;
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
+
var node_process = require('node:process');
|
|
3
4
|
var directives = require('../doc/directives.js');
|
|
4
5
|
var Document = require('../doc/Document.js');
|
|
5
6
|
var errors = require('../errors.js');
|
|
@@ -133,7 +134,7 @@ class Composer {
|
|
|
133
134
|
}
|
|
134
135
|
/** Advance the composer by one CST token. */
|
|
135
136
|
*next(token) {
|
|
136
|
-
if (
|
|
137
|
+
if (node_process.env.LOG_STREAM)
|
|
137
138
|
console.dir(token, { depth: null });
|
|
138
139
|
switch (token.type) {
|
|
139
140
|
case 'directive':
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { YAMLMap } from '../nodes/YAMLMap
|
|
2
|
-
import type { BlockMap } from '../parse/cst
|
|
3
|
-
import { CollectionTag } from '../schema/types
|
|
4
|
-
import type { ComposeContext, ComposeNode } from './compose-node
|
|
5
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import { YAMLMap } from '../nodes/YAMLMap';
|
|
2
|
+
import type { BlockMap } from '../parse/cst';
|
|
3
|
+
import type { CollectionTag } from '../schema/types';
|
|
4
|
+
import type { ComposeContext, ComposeNode } from './compose-node';
|
|
5
|
+
import type { ComposeErrorHandler } from './composer';
|
|
6
6
|
export declare function resolveBlockMap({ composeNode, composeEmptyNode }: ComposeNode, ctx: ComposeContext, bm: BlockMap, onError: ComposeErrorHandler, tag?: CollectionTag): YAMLMap.Parsed;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { Range } from '../nodes/Node
|
|
2
|
-
import { Scalar } from '../nodes/Scalar
|
|
3
|
-
import type { BlockScalar } from '../parse/cst
|
|
4
|
-
import type { ComposeContext } from './compose-node
|
|
5
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import type { Range } from '../nodes/Node';
|
|
2
|
+
import { Scalar } from '../nodes/Scalar';
|
|
3
|
+
import type { BlockScalar } from '../parse/cst';
|
|
4
|
+
import type { ComposeContext } from './compose-node';
|
|
5
|
+
import type { ComposeErrorHandler } from './composer';
|
|
6
6
|
export declare function resolveBlockScalar(ctx: ComposeContext, scalar: BlockScalar, onError: ComposeErrorHandler): {
|
|
7
7
|
value: string;
|
|
8
8
|
type: Scalar.BLOCK_FOLDED | Scalar.BLOCK_LITERAL | null;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { YAMLSeq } from '../nodes/YAMLSeq
|
|
2
|
-
import type { BlockSequence } from '../parse/cst
|
|
3
|
-
import { CollectionTag } from '../schema/types
|
|
4
|
-
import type { ComposeContext, ComposeNode } from './compose-node
|
|
5
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import { YAMLSeq } from '../nodes/YAMLSeq';
|
|
2
|
+
import type { BlockSequence } from '../parse/cst';
|
|
3
|
+
import type { CollectionTag } from '../schema/types';
|
|
4
|
+
import type { ComposeContext, ComposeNode } from './compose-node';
|
|
5
|
+
import type { ComposeErrorHandler } from './composer';
|
|
6
6
|
export declare function resolveBlockSeq({ composeNode, composeEmptyNode }: ComposeNode, ctx: ComposeContext, bs: BlockSequence, onError: ComposeErrorHandler, tag?: CollectionTag): YAMLSeq.Parsed;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import type { SourceToken } from '../parse/cst
|
|
2
|
-
import type { ComposeErrorHandler } from './composer
|
|
1
|
+
import type { SourceToken } from '../parse/cst';
|
|
2
|
+
import type { ComposeErrorHandler } from './composer';
|
|
3
3
|
export declare function resolveEnd(end: SourceToken[] | undefined, offset: number, reqSpace: boolean, onError: ComposeErrorHandler): {
|
|
4
4
|
comment: string;
|
|
5
5
|
offset: number;
|