phantom-pr 0.2.2 → 0.2.5
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/bin/phantom-pr.cjs +20 -0
- package/dist/cli.js +7 -0
- package/dist/cli.js.map +1 -1
- package/node_modules/ignore/LICENSE-MIT +21 -0
- package/node_modules/ignore/README.md +452 -0
- package/node_modules/ignore/index.d.ts +81 -0
- package/node_modules/ignore/index.js +784 -0
- package/node_modules/ignore/legacy.js +681 -0
- package/node_modules/ignore/package.json +87 -0
- package/node_modules/yaml/LICENSE +13 -0
- package/node_modules/yaml/README.md +172 -0
- package/node_modules/yaml/bin.mjs +11 -0
- package/node_modules/yaml/browser/dist/compose/compose-collection.js +88 -0
- package/node_modules/yaml/browser/dist/compose/compose-doc.js +43 -0
- package/node_modules/yaml/browser/dist/compose/compose-node.js +102 -0
- package/node_modules/yaml/browser/dist/compose/compose-scalar.js +86 -0
- package/node_modules/yaml/browser/dist/compose/composer.js +217 -0
- package/node_modules/yaml/browser/dist/compose/resolve-block-map.js +115 -0
- package/node_modules/yaml/browser/dist/compose/resolve-block-scalar.js +198 -0
- package/node_modules/yaml/browser/dist/compose/resolve-block-seq.js +49 -0
- package/node_modules/yaml/browser/dist/compose/resolve-end.js +37 -0
- package/node_modules/yaml/browser/dist/compose/resolve-flow-collection.js +207 -0
- package/node_modules/yaml/browser/dist/compose/resolve-flow-scalar.js +223 -0
- package/node_modules/yaml/browser/dist/compose/resolve-props.js +146 -0
- package/node_modules/yaml/browser/dist/compose/util-contains-newline.js +34 -0
- package/node_modules/yaml/browser/dist/compose/util-empty-scalar-position.js +26 -0
- package/node_modules/yaml/browser/dist/compose/util-flow-indent-check.js +15 -0
- package/node_modules/yaml/browser/dist/compose/util-map-includes.js +13 -0
- package/node_modules/yaml/browser/dist/doc/Document.js +335 -0
- package/node_modules/yaml/browser/dist/doc/anchors.js +71 -0
- package/node_modules/yaml/browser/dist/doc/applyReviver.js +55 -0
- package/node_modules/yaml/browser/dist/doc/createNode.js +88 -0
- package/node_modules/yaml/browser/dist/doc/directives.js +176 -0
- package/node_modules/yaml/browser/dist/errors.js +57 -0
- package/node_modules/yaml/browser/dist/index.js +17 -0
- package/node_modules/yaml/browser/dist/log.js +11 -0
- package/node_modules/yaml/browser/dist/nodes/Alias.js +114 -0
- package/node_modules/yaml/browser/dist/nodes/Collection.js +147 -0
- package/node_modules/yaml/browser/dist/nodes/Node.js +38 -0
- package/node_modules/yaml/browser/dist/nodes/Pair.js +36 -0
- package/node_modules/yaml/browser/dist/nodes/Scalar.js +24 -0
- package/node_modules/yaml/browser/dist/nodes/YAMLMap.js +144 -0
- package/node_modules/yaml/browser/dist/nodes/YAMLSeq.js +113 -0
- package/node_modules/yaml/browser/dist/nodes/addPairToJSMap.js +63 -0
- package/node_modules/yaml/browser/dist/nodes/identity.js +36 -0
- package/node_modules/yaml/browser/dist/nodes/toJS.js +37 -0
- package/node_modules/yaml/browser/dist/parse/cst-scalar.js +214 -0
- package/node_modules/yaml/browser/dist/parse/cst-stringify.js +61 -0
- package/node_modules/yaml/browser/dist/parse/cst-visit.js +97 -0
- package/node_modules/yaml/browser/dist/parse/cst.js +98 -0
- package/node_modules/yaml/browser/dist/parse/lexer.js +717 -0
- package/node_modules/yaml/browser/dist/parse/line-counter.js +39 -0
- package/node_modules/yaml/browser/dist/parse/parser.js +967 -0
- package/node_modules/yaml/browser/dist/public-api.js +102 -0
- package/node_modules/yaml/browser/dist/schema/Schema.js +37 -0
- package/node_modules/yaml/browser/dist/schema/common/map.js +17 -0
- package/node_modules/yaml/browser/dist/schema/common/null.js +15 -0
- package/node_modules/yaml/browser/dist/schema/common/seq.js +17 -0
- package/node_modules/yaml/browser/dist/schema/common/string.js +14 -0
- package/node_modules/yaml/browser/dist/schema/core/bool.js +19 -0
- package/node_modules/yaml/browser/dist/schema/core/float.js +43 -0
- package/node_modules/yaml/browser/dist/schema/core/int.js +38 -0
- package/node_modules/yaml/browser/dist/schema/core/schema.js +23 -0
- package/node_modules/yaml/browser/dist/schema/json/schema.js +62 -0
- package/node_modules/yaml/browser/dist/schema/tags.js +96 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/binary.js +58 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/bool.js +26 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/float.js +46 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/int.js +71 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/merge.js +64 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/omap.js +74 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/pairs.js +78 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/schema.js +39 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/set.js +93 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/timestamp.js +101 -0
- package/node_modules/yaml/browser/dist/stringify/foldFlowLines.js +146 -0
- package/node_modules/yaml/browser/dist/stringify/stringify.js +128 -0
- package/node_modules/yaml/browser/dist/stringify/stringifyCollection.js +143 -0
- package/node_modules/yaml/browser/dist/stringify/stringifyComment.js +20 -0
- package/node_modules/yaml/browser/dist/stringify/stringifyDocument.js +85 -0
- package/node_modules/yaml/browser/dist/stringify/stringifyNumber.js +24 -0
- package/node_modules/yaml/browser/dist/stringify/stringifyPair.js +150 -0
- package/node_modules/yaml/browser/dist/stringify/stringifyString.js +336 -0
- package/node_modules/yaml/browser/dist/util.js +11 -0
- package/node_modules/yaml/browser/dist/visit.js +233 -0
- package/node_modules/yaml/browser/index.js +5 -0
- package/node_modules/yaml/browser/package.json +3 -0
- package/node_modules/yaml/dist/cli.d.ts +8 -0
- package/node_modules/yaml/dist/cli.mjs +201 -0
- package/node_modules/yaml/dist/compose/compose-collection.d.ts +11 -0
- package/node_modules/yaml/dist/compose/compose-collection.js +90 -0
- package/node_modules/yaml/dist/compose/compose-doc.d.ts +7 -0
- package/node_modules/yaml/dist/compose/compose-doc.js +45 -0
- package/node_modules/yaml/dist/compose/compose-node.d.ts +29 -0
- package/node_modules/yaml/dist/compose/compose-node.js +105 -0
- package/node_modules/yaml/dist/compose/compose-scalar.d.ts +5 -0
- package/node_modules/yaml/dist/compose/compose-scalar.js +88 -0
- package/node_modules/yaml/dist/compose/composer.d.ts +63 -0
- package/node_modules/yaml/dist/compose/composer.js +222 -0
- package/node_modules/yaml/dist/compose/resolve-block-map.d.ts +6 -0
- package/node_modules/yaml/dist/compose/resolve-block-map.js +117 -0
- package/node_modules/yaml/dist/compose/resolve-block-scalar.d.ts +11 -0
- package/node_modules/yaml/dist/compose/resolve-block-scalar.js +200 -0
- package/node_modules/yaml/dist/compose/resolve-block-seq.d.ts +6 -0
- package/node_modules/yaml/dist/compose/resolve-block-seq.js +51 -0
- package/node_modules/yaml/dist/compose/resolve-end.d.ts +6 -0
- package/node_modules/yaml/dist/compose/resolve-end.js +39 -0
- package/node_modules/yaml/dist/compose/resolve-flow-collection.d.ts +7 -0
- package/node_modules/yaml/dist/compose/resolve-flow-collection.js +209 -0
- package/node_modules/yaml/dist/compose/resolve-flow-scalar.d.ts +10 -0
- package/node_modules/yaml/dist/compose/resolve-flow-scalar.js +225 -0
- package/node_modules/yaml/dist/compose/resolve-props.d.ts +23 -0
- package/node_modules/yaml/dist/compose/resolve-props.js +148 -0
- package/node_modules/yaml/dist/compose/util-contains-newline.d.ts +2 -0
- package/node_modules/yaml/dist/compose/util-contains-newline.js +36 -0
- package/node_modules/yaml/dist/compose/util-empty-scalar-position.d.ts +2 -0
- package/node_modules/yaml/dist/compose/util-empty-scalar-position.js +28 -0
- package/node_modules/yaml/dist/compose/util-flow-indent-check.d.ts +3 -0
- package/node_modules/yaml/dist/compose/util-flow-indent-check.js +17 -0
- package/node_modules/yaml/dist/compose/util-map-includes.d.ts +4 -0
- package/node_modules/yaml/dist/compose/util-map-includes.js +15 -0
- package/node_modules/yaml/dist/doc/Document.d.ts +141 -0
- package/node_modules/yaml/dist/doc/Document.js +337 -0
- package/node_modules/yaml/dist/doc/anchors.d.ts +24 -0
- package/node_modules/yaml/dist/doc/anchors.js +76 -0
- package/node_modules/yaml/dist/doc/applyReviver.d.ts +9 -0
- package/node_modules/yaml/dist/doc/applyReviver.js +57 -0
- package/node_modules/yaml/dist/doc/createNode.d.ts +17 -0
- package/node_modules/yaml/dist/doc/createNode.js +90 -0
- package/node_modules/yaml/dist/doc/directives.d.ts +49 -0
- package/node_modules/yaml/dist/doc/directives.js +178 -0
- package/node_modules/yaml/dist/errors.d.ts +21 -0
- package/node_modules/yaml/dist/errors.js +62 -0
- package/node_modules/yaml/dist/index.d.ts +25 -0
- package/node_modules/yaml/dist/index.js +50 -0
- package/node_modules/yaml/dist/log.d.ts +3 -0
- package/node_modules/yaml/dist/log.js +19 -0
- package/node_modules/yaml/dist/nodes/Alias.d.ts +29 -0
- package/node_modules/yaml/dist/nodes/Alias.js +116 -0
- package/node_modules/yaml/dist/nodes/Collection.d.ts +73 -0
- package/node_modules/yaml/dist/nodes/Collection.js +151 -0
- package/node_modules/yaml/dist/nodes/Node.d.ts +53 -0
- package/node_modules/yaml/dist/nodes/Node.js +40 -0
- package/node_modules/yaml/dist/nodes/Pair.d.ts +22 -0
- package/node_modules/yaml/dist/nodes/Pair.js +39 -0
- package/node_modules/yaml/dist/nodes/Scalar.d.ts +43 -0
- package/node_modules/yaml/dist/nodes/Scalar.js +27 -0
- package/node_modules/yaml/dist/nodes/YAMLMap.d.ts +53 -0
- package/node_modules/yaml/dist/nodes/YAMLMap.js +147 -0
- package/node_modules/yaml/dist/nodes/YAMLSeq.d.ts +60 -0
- package/node_modules/yaml/dist/nodes/YAMLSeq.js +115 -0
- package/node_modules/yaml/dist/nodes/addPairToJSMap.d.ts +4 -0
- package/node_modules/yaml/dist/nodes/addPairToJSMap.js +65 -0
- package/node_modules/yaml/dist/nodes/identity.d.ts +23 -0
- package/node_modules/yaml/dist/nodes/identity.js +53 -0
- package/node_modules/yaml/dist/nodes/toJS.d.ts +29 -0
- package/node_modules/yaml/dist/nodes/toJS.js +39 -0
- package/node_modules/yaml/dist/options.d.ts +344 -0
- package/node_modules/yaml/dist/parse/cst-scalar.d.ts +64 -0
- package/node_modules/yaml/dist/parse/cst-scalar.js +218 -0
- package/node_modules/yaml/dist/parse/cst-stringify.d.ts +8 -0
- package/node_modules/yaml/dist/parse/cst-stringify.js +63 -0
- package/node_modules/yaml/dist/parse/cst-visit.d.ts +39 -0
- package/node_modules/yaml/dist/parse/cst-visit.js +99 -0
- package/node_modules/yaml/dist/parse/cst.d.ts +109 -0
- package/node_modules/yaml/dist/parse/cst.js +112 -0
- package/node_modules/yaml/dist/parse/lexer.d.ts +87 -0
- package/node_modules/yaml/dist/parse/lexer.js +719 -0
- package/node_modules/yaml/dist/parse/line-counter.d.ts +22 -0
- package/node_modules/yaml/dist/parse/line-counter.js +41 -0
- package/node_modules/yaml/dist/parse/parser.d.ts +84 -0
- package/node_modules/yaml/dist/parse/parser.js +972 -0
- package/node_modules/yaml/dist/public-api.d.ts +44 -0
- package/node_modules/yaml/dist/public-api.js +107 -0
- package/node_modules/yaml/dist/schema/Schema.d.ts +17 -0
- package/node_modules/yaml/dist/schema/Schema.js +39 -0
- package/node_modules/yaml/dist/schema/common/map.d.ts +2 -0
- package/node_modules/yaml/dist/schema/common/map.js +19 -0
- package/node_modules/yaml/dist/schema/common/null.d.ts +4 -0
- package/node_modules/yaml/dist/schema/common/null.js +17 -0
- package/node_modules/yaml/dist/schema/common/seq.d.ts +2 -0
- package/node_modules/yaml/dist/schema/common/seq.js +19 -0
- package/node_modules/yaml/dist/schema/common/string.d.ts +2 -0
- package/node_modules/yaml/dist/schema/common/string.js +16 -0
- package/node_modules/yaml/dist/schema/core/bool.d.ts +4 -0
- package/node_modules/yaml/dist/schema/core/bool.js +21 -0
- package/node_modules/yaml/dist/schema/core/float.d.ts +4 -0
- package/node_modules/yaml/dist/schema/core/float.js +47 -0
- package/node_modules/yaml/dist/schema/core/int.d.ts +4 -0
- package/node_modules/yaml/dist/schema/core/int.js +42 -0
- package/node_modules/yaml/dist/schema/core/schema.d.ts +1 -0
- package/node_modules/yaml/dist/schema/core/schema.js +25 -0
- package/node_modules/yaml/dist/schema/json/schema.d.ts +2 -0
- package/node_modules/yaml/dist/schema/json/schema.js +64 -0
- package/node_modules/yaml/dist/schema/json-schema.d.ts +69 -0
- package/node_modules/yaml/dist/schema/tags.d.ts +48 -0
- package/node_modules/yaml/dist/schema/tags.js +99 -0
- package/node_modules/yaml/dist/schema/types.d.ts +92 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/binary.d.ts +2 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/binary.js +70 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/bool.d.ts +7 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/bool.js +29 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/float.d.ts +4 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/float.js +50 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/int.d.ts +5 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/int.js +76 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/merge.d.ts +9 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/merge.js +68 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/omap.d.ts +22 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/omap.js +77 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/pairs.d.ts +10 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/pairs.js +82 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/schema.d.ts +1 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/schema.js +41 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/set.d.ts +28 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/set.js +96 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/timestamp.d.ts +6 -0
- package/node_modules/yaml/dist/schema/yaml-1.1/timestamp.js +105 -0
- package/node_modules/yaml/dist/stringify/foldFlowLines.d.ts +34 -0
- package/node_modules/yaml/dist/stringify/foldFlowLines.js +151 -0
- package/node_modules/yaml/dist/stringify/stringify.d.ts +21 -0
- package/node_modules/yaml/dist/stringify/stringify.js +131 -0
- package/node_modules/yaml/dist/stringify/stringifyCollection.d.ts +17 -0
- package/node_modules/yaml/dist/stringify/stringifyCollection.js +145 -0
- package/node_modules/yaml/dist/stringify/stringifyComment.d.ts +10 -0
- package/node_modules/yaml/dist/stringify/stringifyComment.js +24 -0
- package/node_modules/yaml/dist/stringify/stringifyDocument.d.ts +4 -0
- package/node_modules/yaml/dist/stringify/stringifyDocument.js +87 -0
- package/node_modules/yaml/dist/stringify/stringifyNumber.d.ts +2 -0
- package/node_modules/yaml/dist/stringify/stringifyNumber.js +26 -0
- package/node_modules/yaml/dist/stringify/stringifyPair.d.ts +3 -0
- package/node_modules/yaml/dist/stringify/stringifyPair.js +152 -0
- package/node_modules/yaml/dist/stringify/stringifyString.d.ts +9 -0
- package/node_modules/yaml/dist/stringify/stringifyString.js +338 -0
- package/node_modules/yaml/dist/test-events.d.ts +4 -0
- package/node_modules/yaml/dist/test-events.js +134 -0
- package/node_modules/yaml/dist/util.d.ts +16 -0
- package/node_modules/yaml/dist/util.js +28 -0
- package/node_modules/yaml/dist/visit.d.ts +102 -0
- package/node_modules/yaml/dist/visit.js +236 -0
- package/node_modules/yaml/package.json +97 -0
- package/node_modules/yaml/util.js +2 -0
- package/package.json +7 -3
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var utilContainsNewline = require('./util-contains-newline.js');
|
|
4
|
+
|
|
5
|
+
function flowIndentCheck(indent, fc, onError) {
|
|
6
|
+
if (fc?.type === 'flow-collection') {
|
|
7
|
+
const end = fc.end[0];
|
|
8
|
+
if (end.indent === indent &&
|
|
9
|
+
(end.source === ']' || end.source === '}') &&
|
|
10
|
+
utilContainsNewline.containsNewline(fc)) {
|
|
11
|
+
const msg = 'Flow end indicator should be more indented than parent';
|
|
12
|
+
onError(end, 'BAD_INDENT', msg, true);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
exports.flowIndentCheck = flowIndentCheck;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var identity = require('../nodes/identity.js');
|
|
4
|
+
|
|
5
|
+
function mapIncludes(ctx, items, search) {
|
|
6
|
+
const { uniqueKeys } = ctx.options;
|
|
7
|
+
if (uniqueKeys === false)
|
|
8
|
+
return false;
|
|
9
|
+
const isEqual = typeof uniqueKeys === 'function'
|
|
10
|
+
? uniqueKeys
|
|
11
|
+
: (a, b) => a === b || (identity.isScalar(a) && identity.isScalar(b) && a.value === b.value);
|
|
12
|
+
return items.some(pair => isEqual(pair.key, search));
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
exports.mapIncludes = mapIncludes;
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import type { YAMLError, YAMLWarning } from '../errors';
|
|
2
|
+
import { Alias } from '../nodes/Alias';
|
|
3
|
+
import { NODE_TYPE } from '../nodes/identity';
|
|
4
|
+
import type { Node, NodeType, ParsedNode, Range } from '../nodes/Node';
|
|
5
|
+
import { Pair } from '../nodes/Pair';
|
|
6
|
+
import type { Scalar } from '../nodes/Scalar';
|
|
7
|
+
import type { YAMLMap } from '../nodes/YAMLMap';
|
|
8
|
+
import type { YAMLSeq } from '../nodes/YAMLSeq';
|
|
9
|
+
import type { CreateNodeOptions, DocumentOptions, ParseOptions, SchemaOptions, ToJSOptions, ToStringOptions } from '../options';
|
|
10
|
+
import { Schema } from '../schema/Schema';
|
|
11
|
+
import { Directives } from './directives';
|
|
12
|
+
export type Replacer = any[] | ((key: any, value: any) => unknown);
|
|
13
|
+
export declare namespace Document {
|
|
14
|
+
/** @ts-ignore The typing of directives fails in TS <= 4.2 */
|
|
15
|
+
interface Parsed<Contents extends ParsedNode = ParsedNode, Strict extends boolean = true> extends Document<Contents, Strict> {
|
|
16
|
+
directives: Directives;
|
|
17
|
+
range: Range;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export declare class Document<Contents extends Node = Node, Strict extends boolean = true> {
|
|
21
|
+
readonly [NODE_TYPE]: symbol;
|
|
22
|
+
/** A comment before this Document */
|
|
23
|
+
commentBefore: string | null;
|
|
24
|
+
/** A comment immediately after this Document */
|
|
25
|
+
comment: string | null;
|
|
26
|
+
/** The document contents. */
|
|
27
|
+
contents: Strict extends true ? Contents | null : Contents;
|
|
28
|
+
directives: Strict extends true ? Directives | undefined : Directives;
|
|
29
|
+
/** Errors encountered during parsing. */
|
|
30
|
+
errors: YAMLError[];
|
|
31
|
+
options: Required<Omit<ParseOptions & DocumentOptions, '_directives' | 'lineCounter' | 'version'>>;
|
|
32
|
+
/**
|
|
33
|
+
* The `[start, value-end, node-end]` character offsets for the part of the
|
|
34
|
+
* source parsed into this document (undefined if not parsed). The `value-end`
|
|
35
|
+
* and `node-end` positions are themselves not included in their respective
|
|
36
|
+
* ranges.
|
|
37
|
+
*/
|
|
38
|
+
range?: Range;
|
|
39
|
+
/** The schema used with the document. Use `setSchema()` to change. */
|
|
40
|
+
schema: Schema;
|
|
41
|
+
/** Warnings encountered during parsing. */
|
|
42
|
+
warnings: YAMLWarning[];
|
|
43
|
+
/**
|
|
44
|
+
* @param value - The initial value for the document, which will be wrapped
|
|
45
|
+
* in a Node container.
|
|
46
|
+
*/
|
|
47
|
+
constructor(value?: any, options?: DocumentOptions & SchemaOptions & ParseOptions & CreateNodeOptions);
|
|
48
|
+
constructor(value: any, replacer: null | Replacer, options?: DocumentOptions & SchemaOptions & ParseOptions & CreateNodeOptions);
|
|
49
|
+
/**
|
|
50
|
+
* Create a deep copy of this Document and its contents.
|
|
51
|
+
*
|
|
52
|
+
* Custom Node values that inherit from `Object` still refer to their original instances.
|
|
53
|
+
*/
|
|
54
|
+
clone(): Document<Contents, Strict>;
|
|
55
|
+
/** Adds a value to the document. */
|
|
56
|
+
add(value: any): void;
|
|
57
|
+
/** Adds a value to the document. */
|
|
58
|
+
addIn(path: Iterable<unknown>, value: unknown): void;
|
|
59
|
+
/**
|
|
60
|
+
* Create a new `Alias` node, ensuring that the target `node` has the required anchor.
|
|
61
|
+
*
|
|
62
|
+
* If `node` already has an anchor, `name` is ignored.
|
|
63
|
+
* Otherwise, the `node.anchor` value will be set to `name`,
|
|
64
|
+
* or if an anchor with that name is already present in the document,
|
|
65
|
+
* `name` will be used as a prefix for a new unique anchor.
|
|
66
|
+
* If `name` is undefined, the generated anchor will use 'a' as a prefix.
|
|
67
|
+
*/
|
|
68
|
+
createAlias(node: Strict extends true ? Scalar | YAMLMap | YAMLSeq : Node, name?: string): Alias;
|
|
69
|
+
/**
|
|
70
|
+
* Convert any value into a `Node` using the current schema, recursively
|
|
71
|
+
* turning objects into collections.
|
|
72
|
+
*/
|
|
73
|
+
createNode<T = unknown>(value: T, options?: CreateNodeOptions): NodeType<T>;
|
|
74
|
+
createNode<T = unknown>(value: T, replacer: Replacer | CreateNodeOptions | null, options?: CreateNodeOptions): NodeType<T>;
|
|
75
|
+
/**
|
|
76
|
+
* Convert a key and a value into a `Pair` using the current schema,
|
|
77
|
+
* recursively wrapping all values as `Scalar` or `Collection` nodes.
|
|
78
|
+
*/
|
|
79
|
+
createPair<K extends Node = Node, V extends Node = Node>(key: unknown, value: unknown, options?: CreateNodeOptions): Pair<K, V>;
|
|
80
|
+
/**
|
|
81
|
+
* Removes a value from the document.
|
|
82
|
+
* @returns `true` if the item was found and removed.
|
|
83
|
+
*/
|
|
84
|
+
delete(key: unknown): boolean;
|
|
85
|
+
/**
|
|
86
|
+
* Removes a value from the document.
|
|
87
|
+
* @returns `true` if the item was found and removed.
|
|
88
|
+
*/
|
|
89
|
+
deleteIn(path: Iterable<unknown> | null): boolean;
|
|
90
|
+
/**
|
|
91
|
+
* Returns item at `key`, or `undefined` if not found. By default unwraps
|
|
92
|
+
* scalar values from their surrounding node; to disable set `keepScalar` to
|
|
93
|
+
* `true` (collections are always returned intact).
|
|
94
|
+
*/
|
|
95
|
+
get(key: unknown, keepScalar?: boolean): Strict extends true ? unknown : any;
|
|
96
|
+
/**
|
|
97
|
+
* Returns item at `path`, or `undefined` if not found. By default unwraps
|
|
98
|
+
* scalar values from their surrounding node; to disable set `keepScalar` to
|
|
99
|
+
* `true` (collections are always returned intact).
|
|
100
|
+
*/
|
|
101
|
+
getIn(path: Iterable<unknown> | null, keepScalar?: boolean): Strict extends true ? unknown : any;
|
|
102
|
+
/**
|
|
103
|
+
* Checks if the document includes a value with the key `key`.
|
|
104
|
+
*/
|
|
105
|
+
has(key: unknown): boolean;
|
|
106
|
+
/**
|
|
107
|
+
* Checks if the document includes a value at `path`.
|
|
108
|
+
*/
|
|
109
|
+
hasIn(path: Iterable<unknown> | null): boolean;
|
|
110
|
+
/**
|
|
111
|
+
* Sets a value in this document. For `!!set`, `value` needs to be a
|
|
112
|
+
* boolean to add/remove the item from the set.
|
|
113
|
+
*/
|
|
114
|
+
set(key: any, value: unknown): void;
|
|
115
|
+
/**
|
|
116
|
+
* Sets a value in this document. For `!!set`, `value` needs to be a
|
|
117
|
+
* boolean to add/remove the item from the set.
|
|
118
|
+
*/
|
|
119
|
+
setIn(path: Iterable<unknown> | null, value: unknown): void;
|
|
120
|
+
/**
|
|
121
|
+
* Change the YAML version and schema used by the document.
|
|
122
|
+
* A `null` version disables support for directives, explicit tags, anchors, and aliases.
|
|
123
|
+
* It also requires the `schema` option to be given as a `Schema` instance value.
|
|
124
|
+
*
|
|
125
|
+
* Overrides all previously set schema options.
|
|
126
|
+
*/
|
|
127
|
+
setSchema(version: '1.1' | '1.2' | 'next' | null, options?: SchemaOptions): void;
|
|
128
|
+
/** A plain JavaScript representation of the document `contents`. */
|
|
129
|
+
toJS(opt?: ToJSOptions & {
|
|
130
|
+
[ignored: string]: unknown;
|
|
131
|
+
}): any;
|
|
132
|
+
/**
|
|
133
|
+
* A JSON representation of the document `contents`.
|
|
134
|
+
*
|
|
135
|
+
* @param jsonArg Used by `JSON.stringify` to indicate the array index or
|
|
136
|
+
* property name.
|
|
137
|
+
*/
|
|
138
|
+
toJSON(jsonArg?: string | null, onAnchor?: ToJSOptions['onAnchor']): any;
|
|
139
|
+
/** A YAML representation of the document. */
|
|
140
|
+
toString(options?: ToStringOptions): string;
|
|
141
|
+
}
|
|
@@ -0,0 +1,337 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var Alias = require('../nodes/Alias.js');
|
|
4
|
+
var Collection = require('../nodes/Collection.js');
|
|
5
|
+
var identity = require('../nodes/identity.js');
|
|
6
|
+
var Pair = require('../nodes/Pair.js');
|
|
7
|
+
var toJS = require('../nodes/toJS.js');
|
|
8
|
+
var Schema = require('../schema/Schema.js');
|
|
9
|
+
var stringifyDocument = require('../stringify/stringifyDocument.js');
|
|
10
|
+
var anchors = require('./anchors.js');
|
|
11
|
+
var applyReviver = require('./applyReviver.js');
|
|
12
|
+
var createNode = require('./createNode.js');
|
|
13
|
+
var directives = require('./directives.js');
|
|
14
|
+
|
|
15
|
+
class Document {
|
|
16
|
+
constructor(value, replacer, options) {
|
|
17
|
+
/** A comment before this Document */
|
|
18
|
+
this.commentBefore = null;
|
|
19
|
+
/** A comment immediately after this Document */
|
|
20
|
+
this.comment = null;
|
|
21
|
+
/** Errors encountered during parsing. */
|
|
22
|
+
this.errors = [];
|
|
23
|
+
/** Warnings encountered during parsing. */
|
|
24
|
+
this.warnings = [];
|
|
25
|
+
Object.defineProperty(this, identity.NODE_TYPE, { value: identity.DOC });
|
|
26
|
+
let _replacer = null;
|
|
27
|
+
if (typeof replacer === 'function' || Array.isArray(replacer)) {
|
|
28
|
+
_replacer = replacer;
|
|
29
|
+
}
|
|
30
|
+
else if (options === undefined && replacer) {
|
|
31
|
+
options = replacer;
|
|
32
|
+
replacer = undefined;
|
|
33
|
+
}
|
|
34
|
+
const opt = Object.assign({
|
|
35
|
+
intAsBigInt: false,
|
|
36
|
+
keepSourceTokens: false,
|
|
37
|
+
logLevel: 'warn',
|
|
38
|
+
prettyErrors: true,
|
|
39
|
+
strict: true,
|
|
40
|
+
stringKeys: false,
|
|
41
|
+
uniqueKeys: true,
|
|
42
|
+
version: '1.2'
|
|
43
|
+
}, options);
|
|
44
|
+
this.options = opt;
|
|
45
|
+
let { version } = opt;
|
|
46
|
+
if (options?._directives) {
|
|
47
|
+
this.directives = options._directives.atDocument();
|
|
48
|
+
if (this.directives.yaml.explicit)
|
|
49
|
+
version = this.directives.yaml.version;
|
|
50
|
+
}
|
|
51
|
+
else
|
|
52
|
+
this.directives = new directives.Directives({ version });
|
|
53
|
+
this.setSchema(version, options);
|
|
54
|
+
// @ts-expect-error We can't really know that this matches Contents.
|
|
55
|
+
this.contents =
|
|
56
|
+
value === undefined ? null : this.createNode(value, _replacer, options);
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Create a deep copy of this Document and its contents.
|
|
60
|
+
*
|
|
61
|
+
* Custom Node values that inherit from `Object` still refer to their original instances.
|
|
62
|
+
*/
|
|
63
|
+
clone() {
|
|
64
|
+
const copy = Object.create(Document.prototype, {
|
|
65
|
+
[identity.NODE_TYPE]: { value: identity.DOC }
|
|
66
|
+
});
|
|
67
|
+
copy.commentBefore = this.commentBefore;
|
|
68
|
+
copy.comment = this.comment;
|
|
69
|
+
copy.errors = this.errors.slice();
|
|
70
|
+
copy.warnings = this.warnings.slice();
|
|
71
|
+
copy.options = Object.assign({}, this.options);
|
|
72
|
+
if (this.directives)
|
|
73
|
+
copy.directives = this.directives.clone();
|
|
74
|
+
copy.schema = this.schema.clone();
|
|
75
|
+
// @ts-expect-error We can't really know that this matches Contents.
|
|
76
|
+
copy.contents = identity.isNode(this.contents)
|
|
77
|
+
? this.contents.clone(copy.schema)
|
|
78
|
+
: this.contents;
|
|
79
|
+
if (this.range)
|
|
80
|
+
copy.range = this.range.slice();
|
|
81
|
+
return copy;
|
|
82
|
+
}
|
|
83
|
+
/** Adds a value to the document. */
|
|
84
|
+
add(value) {
|
|
85
|
+
if (assertCollection(this.contents))
|
|
86
|
+
this.contents.add(value);
|
|
87
|
+
}
|
|
88
|
+
/** Adds a value to the document. */
|
|
89
|
+
addIn(path, value) {
|
|
90
|
+
if (assertCollection(this.contents))
|
|
91
|
+
this.contents.addIn(path, value);
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Create a new `Alias` node, ensuring that the target `node` has the required anchor.
|
|
95
|
+
*
|
|
96
|
+
* If `node` already has an anchor, `name` is ignored.
|
|
97
|
+
* Otherwise, the `node.anchor` value will be set to `name`,
|
|
98
|
+
* or if an anchor with that name is already present in the document,
|
|
99
|
+
* `name` will be used as a prefix for a new unique anchor.
|
|
100
|
+
* If `name` is undefined, the generated anchor will use 'a' as a prefix.
|
|
101
|
+
*/
|
|
102
|
+
createAlias(node, name) {
|
|
103
|
+
if (!node.anchor) {
|
|
104
|
+
const prev = anchors.anchorNames(this);
|
|
105
|
+
node.anchor =
|
|
106
|
+
// eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
|
|
107
|
+
!name || prev.has(name) ? anchors.findNewAnchor(name || 'a', prev) : name;
|
|
108
|
+
}
|
|
109
|
+
return new Alias.Alias(node.anchor);
|
|
110
|
+
}
|
|
111
|
+
createNode(value, replacer, options) {
|
|
112
|
+
let _replacer = undefined;
|
|
113
|
+
if (typeof replacer === 'function') {
|
|
114
|
+
value = replacer.call({ '': value }, '', value);
|
|
115
|
+
_replacer = replacer;
|
|
116
|
+
}
|
|
117
|
+
else if (Array.isArray(replacer)) {
|
|
118
|
+
const keyToStr = (v) => typeof v === 'number' || v instanceof String || v instanceof Number;
|
|
119
|
+
const asStr = replacer.filter(keyToStr).map(String);
|
|
120
|
+
if (asStr.length > 0)
|
|
121
|
+
replacer = replacer.concat(asStr);
|
|
122
|
+
_replacer = replacer;
|
|
123
|
+
}
|
|
124
|
+
else if (options === undefined && replacer) {
|
|
125
|
+
options = replacer;
|
|
126
|
+
replacer = undefined;
|
|
127
|
+
}
|
|
128
|
+
const { aliasDuplicateObjects, anchorPrefix, flow, keepUndefined, onTagObj, tag } = options ?? {};
|
|
129
|
+
const { onAnchor, setAnchors, sourceObjects } = anchors.createNodeAnchors(this,
|
|
130
|
+
// eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
|
|
131
|
+
anchorPrefix || 'a');
|
|
132
|
+
const ctx = {
|
|
133
|
+
aliasDuplicateObjects: aliasDuplicateObjects ?? true,
|
|
134
|
+
keepUndefined: keepUndefined ?? false,
|
|
135
|
+
onAnchor,
|
|
136
|
+
onTagObj,
|
|
137
|
+
replacer: _replacer,
|
|
138
|
+
schema: this.schema,
|
|
139
|
+
sourceObjects
|
|
140
|
+
};
|
|
141
|
+
const node = createNode.createNode(value, tag, ctx);
|
|
142
|
+
if (flow && identity.isCollection(node))
|
|
143
|
+
node.flow = true;
|
|
144
|
+
setAnchors();
|
|
145
|
+
return node;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Convert a key and a value into a `Pair` using the current schema,
|
|
149
|
+
* recursively wrapping all values as `Scalar` or `Collection` nodes.
|
|
150
|
+
*/
|
|
151
|
+
createPair(key, value, options = {}) {
|
|
152
|
+
const k = this.createNode(key, null, options);
|
|
153
|
+
const v = this.createNode(value, null, options);
|
|
154
|
+
return new Pair.Pair(k, v);
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Removes a value from the document.
|
|
158
|
+
* @returns `true` if the item was found and removed.
|
|
159
|
+
*/
|
|
160
|
+
delete(key) {
|
|
161
|
+
return assertCollection(this.contents) ? this.contents.delete(key) : false;
|
|
162
|
+
}
|
|
163
|
+
/**
|
|
164
|
+
* Removes a value from the document.
|
|
165
|
+
* @returns `true` if the item was found and removed.
|
|
166
|
+
*/
|
|
167
|
+
deleteIn(path) {
|
|
168
|
+
if (Collection.isEmptyPath(path)) {
|
|
169
|
+
if (this.contents == null)
|
|
170
|
+
return false;
|
|
171
|
+
// @ts-expect-error Presumed impossible if Strict extends false
|
|
172
|
+
this.contents = null;
|
|
173
|
+
return true;
|
|
174
|
+
}
|
|
175
|
+
return assertCollection(this.contents)
|
|
176
|
+
? this.contents.deleteIn(path)
|
|
177
|
+
: false;
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Returns item at `key`, or `undefined` if not found. By default unwraps
|
|
181
|
+
* scalar values from their surrounding node; to disable set `keepScalar` to
|
|
182
|
+
* `true` (collections are always returned intact).
|
|
183
|
+
*/
|
|
184
|
+
get(key, keepScalar) {
|
|
185
|
+
return identity.isCollection(this.contents)
|
|
186
|
+
? this.contents.get(key, keepScalar)
|
|
187
|
+
: undefined;
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Returns item at `path`, or `undefined` if not found. By default unwraps
|
|
191
|
+
* scalar values from their surrounding node; to disable set `keepScalar` to
|
|
192
|
+
* `true` (collections are always returned intact).
|
|
193
|
+
*/
|
|
194
|
+
getIn(path, keepScalar) {
|
|
195
|
+
if (Collection.isEmptyPath(path))
|
|
196
|
+
return !keepScalar && identity.isScalar(this.contents)
|
|
197
|
+
? this.contents.value
|
|
198
|
+
: this.contents;
|
|
199
|
+
return identity.isCollection(this.contents)
|
|
200
|
+
? this.contents.getIn(path, keepScalar)
|
|
201
|
+
: undefined;
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Checks if the document includes a value with the key `key`.
|
|
205
|
+
*/
|
|
206
|
+
has(key) {
|
|
207
|
+
return identity.isCollection(this.contents) ? this.contents.has(key) : false;
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* Checks if the document includes a value at `path`.
|
|
211
|
+
*/
|
|
212
|
+
hasIn(path) {
|
|
213
|
+
if (Collection.isEmptyPath(path))
|
|
214
|
+
return this.contents !== undefined;
|
|
215
|
+
return identity.isCollection(this.contents) ? this.contents.hasIn(path) : false;
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Sets a value in this document. For `!!set`, `value` needs to be a
|
|
219
|
+
* boolean to add/remove the item from the set.
|
|
220
|
+
*/
|
|
221
|
+
set(key, value) {
|
|
222
|
+
if (this.contents == null) {
|
|
223
|
+
// @ts-expect-error We can't really know that this matches Contents.
|
|
224
|
+
this.contents = Collection.collectionFromPath(this.schema, [key], value);
|
|
225
|
+
}
|
|
226
|
+
else if (assertCollection(this.contents)) {
|
|
227
|
+
this.contents.set(key, value);
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Sets a value in this document. For `!!set`, `value` needs to be a
|
|
232
|
+
* boolean to add/remove the item from the set.
|
|
233
|
+
*/
|
|
234
|
+
setIn(path, value) {
|
|
235
|
+
if (Collection.isEmptyPath(path)) {
|
|
236
|
+
// @ts-expect-error We can't really know that this matches Contents.
|
|
237
|
+
this.contents = value;
|
|
238
|
+
}
|
|
239
|
+
else if (this.contents == null) {
|
|
240
|
+
// @ts-expect-error We can't really know that this matches Contents.
|
|
241
|
+
this.contents = Collection.collectionFromPath(this.schema, Array.from(path), value);
|
|
242
|
+
}
|
|
243
|
+
else if (assertCollection(this.contents)) {
|
|
244
|
+
this.contents.setIn(path, value);
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* Change the YAML version and schema used by the document.
|
|
249
|
+
* A `null` version disables support for directives, explicit tags, anchors, and aliases.
|
|
250
|
+
* It also requires the `schema` option to be given as a `Schema` instance value.
|
|
251
|
+
*
|
|
252
|
+
* Overrides all previously set schema options.
|
|
253
|
+
*/
|
|
254
|
+
setSchema(version, options = {}) {
|
|
255
|
+
if (typeof version === 'number')
|
|
256
|
+
version = String(version);
|
|
257
|
+
let opt;
|
|
258
|
+
switch (version) {
|
|
259
|
+
case '1.1':
|
|
260
|
+
if (this.directives)
|
|
261
|
+
this.directives.yaml.version = '1.1';
|
|
262
|
+
else
|
|
263
|
+
this.directives = new directives.Directives({ version: '1.1' });
|
|
264
|
+
opt = { resolveKnownTags: false, schema: 'yaml-1.1' };
|
|
265
|
+
break;
|
|
266
|
+
case '1.2':
|
|
267
|
+
case 'next':
|
|
268
|
+
if (this.directives)
|
|
269
|
+
this.directives.yaml.version = version;
|
|
270
|
+
else
|
|
271
|
+
this.directives = new directives.Directives({ version });
|
|
272
|
+
opt = { resolveKnownTags: true, schema: 'core' };
|
|
273
|
+
break;
|
|
274
|
+
case null:
|
|
275
|
+
if (this.directives)
|
|
276
|
+
delete this.directives;
|
|
277
|
+
opt = null;
|
|
278
|
+
break;
|
|
279
|
+
default: {
|
|
280
|
+
const sv = JSON.stringify(version);
|
|
281
|
+
throw new Error(`Expected '1.1', '1.2' or null as first argument, but found: ${sv}`);
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
// Not using `instanceof Schema` to allow for duck typing
|
|
285
|
+
if (options.schema instanceof Object)
|
|
286
|
+
this.schema = options.schema;
|
|
287
|
+
else if (opt)
|
|
288
|
+
this.schema = new Schema.Schema(Object.assign(opt, options));
|
|
289
|
+
else
|
|
290
|
+
throw new Error(`With a null YAML version, the { schema: Schema } option is required`);
|
|
291
|
+
}
|
|
292
|
+
// json & jsonArg are only used from toJSON()
|
|
293
|
+
toJS({ json, jsonArg, mapAsMap, maxAliasCount, onAnchor, reviver } = {}) {
|
|
294
|
+
const ctx = {
|
|
295
|
+
anchors: new Map(),
|
|
296
|
+
doc: this,
|
|
297
|
+
keep: !json,
|
|
298
|
+
mapAsMap: mapAsMap === true,
|
|
299
|
+
mapKeyWarned: false,
|
|
300
|
+
maxAliasCount: typeof maxAliasCount === 'number' ? maxAliasCount : 100
|
|
301
|
+
};
|
|
302
|
+
const res = toJS.toJS(this.contents, jsonArg ?? '', ctx);
|
|
303
|
+
if (typeof onAnchor === 'function')
|
|
304
|
+
for (const { count, res } of ctx.anchors.values())
|
|
305
|
+
onAnchor(res, count);
|
|
306
|
+
return typeof reviver === 'function'
|
|
307
|
+
? applyReviver.applyReviver(reviver, { '': res }, '', res)
|
|
308
|
+
: res;
|
|
309
|
+
}
|
|
310
|
+
/**
|
|
311
|
+
* A JSON representation of the document `contents`.
|
|
312
|
+
*
|
|
313
|
+
* @param jsonArg Used by `JSON.stringify` to indicate the array index or
|
|
314
|
+
* property name.
|
|
315
|
+
*/
|
|
316
|
+
toJSON(jsonArg, onAnchor) {
|
|
317
|
+
return this.toJS({ json: true, jsonArg, mapAsMap: false, onAnchor });
|
|
318
|
+
}
|
|
319
|
+
/** A YAML representation of the document. */
|
|
320
|
+
toString(options = {}) {
|
|
321
|
+
if (this.errors.length > 0)
|
|
322
|
+
throw new Error('Document with errors cannot be stringified');
|
|
323
|
+
if ('indent' in options &&
|
|
324
|
+
(!Number.isInteger(options.indent) || Number(options.indent) <= 0)) {
|
|
325
|
+
const s = JSON.stringify(options.indent);
|
|
326
|
+
throw new Error(`"indent" option must be a positive integer, not ${s}`);
|
|
327
|
+
}
|
|
328
|
+
return stringifyDocument.stringifyDocument(this, options);
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
function assertCollection(contents) {
|
|
332
|
+
if (identity.isCollection(contents))
|
|
333
|
+
return true;
|
|
334
|
+
throw new Error('Expected a YAML collection as document contents');
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
exports.Document = Document;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { Node } from '../nodes/Node';
|
|
2
|
+
import type { Document } from './Document';
|
|
3
|
+
/**
|
|
4
|
+
* Verify that the input string is a valid anchor.
|
|
5
|
+
*
|
|
6
|
+
* Will throw on errors.
|
|
7
|
+
*/
|
|
8
|
+
export declare function anchorIsValid(anchor: string): true;
|
|
9
|
+
export declare function anchorNames(root: Document<Node, boolean> | Node): Set<string>;
|
|
10
|
+
/** Find a new anchor name with the given `prefix` and a one-indexed suffix. */
|
|
11
|
+
export declare function findNewAnchor(prefix: string, exclude: Set<string>): string;
|
|
12
|
+
export declare function createNodeAnchors(doc: Document<Node, boolean>, prefix: string): {
|
|
13
|
+
onAnchor: (source: unknown) => string;
|
|
14
|
+
/**
|
|
15
|
+
* With circular references, the source node is only resolved after all
|
|
16
|
+
* of its child nodes are. This is why anchors are set only after all of
|
|
17
|
+
* the nodes have been created.
|
|
18
|
+
*/
|
|
19
|
+
setAnchors: () => void;
|
|
20
|
+
sourceObjects: Map<unknown, {
|
|
21
|
+
anchor: string | null;
|
|
22
|
+
node: Node | null;
|
|
23
|
+
}>;
|
|
24
|
+
};
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var identity = require('../nodes/identity.js');
|
|
4
|
+
var visit = require('../visit.js');
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Verify that the input string is a valid anchor.
|
|
8
|
+
*
|
|
9
|
+
* Will throw on errors.
|
|
10
|
+
*/
|
|
11
|
+
function anchorIsValid(anchor) {
|
|
12
|
+
if (/[\x00-\x19\s,[\]{}]/.test(anchor)) {
|
|
13
|
+
const sa = JSON.stringify(anchor);
|
|
14
|
+
const msg = `Anchor must not contain whitespace or control characters: ${sa}`;
|
|
15
|
+
throw new Error(msg);
|
|
16
|
+
}
|
|
17
|
+
return true;
|
|
18
|
+
}
|
|
19
|
+
function anchorNames(root) {
|
|
20
|
+
const anchors = new Set();
|
|
21
|
+
visit.visit(root, {
|
|
22
|
+
Value(_key, node) {
|
|
23
|
+
if (node.anchor)
|
|
24
|
+
anchors.add(node.anchor);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
return anchors;
|
|
28
|
+
}
|
|
29
|
+
/** Find a new anchor name with the given `prefix` and a one-indexed suffix. */
|
|
30
|
+
function findNewAnchor(prefix, exclude) {
|
|
31
|
+
for (let i = 1; true; ++i) {
|
|
32
|
+
const name = `${prefix}${i}`;
|
|
33
|
+
if (!exclude.has(name))
|
|
34
|
+
return name;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
function createNodeAnchors(doc, prefix) {
|
|
38
|
+
const aliasObjects = [];
|
|
39
|
+
const sourceObjects = new Map();
|
|
40
|
+
let prevAnchors = null;
|
|
41
|
+
return {
|
|
42
|
+
onAnchor: (source) => {
|
|
43
|
+
aliasObjects.push(source);
|
|
44
|
+
prevAnchors ?? (prevAnchors = anchorNames(doc));
|
|
45
|
+
const anchor = findNewAnchor(prefix, prevAnchors);
|
|
46
|
+
prevAnchors.add(anchor);
|
|
47
|
+
return anchor;
|
|
48
|
+
},
|
|
49
|
+
/**
|
|
50
|
+
* With circular references, the source node is only resolved after all
|
|
51
|
+
* of its child nodes are. This is why anchors are set only after all of
|
|
52
|
+
* the nodes have been created.
|
|
53
|
+
*/
|
|
54
|
+
setAnchors: () => {
|
|
55
|
+
for (const source of aliasObjects) {
|
|
56
|
+
const ref = sourceObjects.get(source);
|
|
57
|
+
if (typeof ref === 'object' &&
|
|
58
|
+
ref.anchor &&
|
|
59
|
+
(identity.isScalar(ref.node) || identity.isCollection(ref.node))) {
|
|
60
|
+
ref.node.anchor = ref.anchor;
|
|
61
|
+
}
|
|
62
|
+
else {
|
|
63
|
+
const error = new Error('Failed to resolve repeated object (this should not happen)');
|
|
64
|
+
error.source = source;
|
|
65
|
+
throw error;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
},
|
|
69
|
+
sourceObjects
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
exports.anchorIsValid = anchorIsValid;
|
|
74
|
+
exports.anchorNames = anchorNames;
|
|
75
|
+
exports.createNodeAnchors = createNodeAnchors;
|
|
76
|
+
exports.findNewAnchor = findNewAnchor;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export type Reviver = (key: unknown, value: unknown) => unknown;
|
|
2
|
+
/**
|
|
3
|
+
* Applies the JSON.parse reviver algorithm as defined in the ECMA-262 spec,
|
|
4
|
+
* in section 24.5.1.1 "Runtime Semantics: InternalizeJSONProperty" of the
|
|
5
|
+
* 2021 edition: https://tc39.es/ecma262/#sec-json.parse
|
|
6
|
+
*
|
|
7
|
+
* Includes extensions for handling Map and Set objects.
|
|
8
|
+
*/
|
|
9
|
+
export declare function applyReviver(reviver: Reviver, obj: unknown, key: unknown, val: any): unknown;
|