phantom-pr 0.2.2 → 0.2.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/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 +5 -1
|
@@ -0,0 +1,217 @@
|
|
|
1
|
+
import { Directives } from '../doc/directives.js';
|
|
2
|
+
import { Document } from '../doc/Document.js';
|
|
3
|
+
import { YAMLWarning, YAMLParseError } from '../errors.js';
|
|
4
|
+
import { isCollection, isPair } from '../nodes/identity.js';
|
|
5
|
+
import { composeDoc } from './compose-doc.js';
|
|
6
|
+
import { resolveEnd } from './resolve-end.js';
|
|
7
|
+
|
|
8
|
+
function getErrorPos(src) {
|
|
9
|
+
if (typeof src === 'number')
|
|
10
|
+
return [src, src + 1];
|
|
11
|
+
if (Array.isArray(src))
|
|
12
|
+
return src.length === 2 ? src : [src[0], src[1]];
|
|
13
|
+
const { offset, source } = src;
|
|
14
|
+
return [offset, offset + (typeof source === 'string' ? source.length : 1)];
|
|
15
|
+
}
|
|
16
|
+
function parsePrelude(prelude) {
|
|
17
|
+
let comment = '';
|
|
18
|
+
let atComment = false;
|
|
19
|
+
let afterEmptyLine = false;
|
|
20
|
+
for (let i = 0; i < prelude.length; ++i) {
|
|
21
|
+
const source = prelude[i];
|
|
22
|
+
switch (source[0]) {
|
|
23
|
+
case '#':
|
|
24
|
+
comment +=
|
|
25
|
+
(comment === '' ? '' : afterEmptyLine ? '\n\n' : '\n') +
|
|
26
|
+
(source.substring(1) || ' ');
|
|
27
|
+
atComment = true;
|
|
28
|
+
afterEmptyLine = false;
|
|
29
|
+
break;
|
|
30
|
+
case '%':
|
|
31
|
+
if (prelude[i + 1]?.[0] !== '#')
|
|
32
|
+
i += 1;
|
|
33
|
+
atComment = false;
|
|
34
|
+
break;
|
|
35
|
+
default:
|
|
36
|
+
// This may be wrong after doc-end, but in that case it doesn't matter
|
|
37
|
+
if (!atComment)
|
|
38
|
+
afterEmptyLine = true;
|
|
39
|
+
atComment = false;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return { comment, afterEmptyLine };
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Compose a stream of CST nodes into a stream of YAML Documents.
|
|
46
|
+
*
|
|
47
|
+
* ```ts
|
|
48
|
+
* import { Composer, Parser } from 'yaml'
|
|
49
|
+
*
|
|
50
|
+
* const src: string = ...
|
|
51
|
+
* const tokens = new Parser().parse(src)
|
|
52
|
+
* const docs = new Composer().compose(tokens)
|
|
53
|
+
* ```
|
|
54
|
+
*/
|
|
55
|
+
class Composer {
|
|
56
|
+
constructor(options = {}) {
|
|
57
|
+
this.doc = null;
|
|
58
|
+
this.atDirectives = false;
|
|
59
|
+
this.prelude = [];
|
|
60
|
+
this.errors = [];
|
|
61
|
+
this.warnings = [];
|
|
62
|
+
this.onError = (source, code, message, warning) => {
|
|
63
|
+
const pos = getErrorPos(source);
|
|
64
|
+
if (warning)
|
|
65
|
+
this.warnings.push(new YAMLWarning(pos, code, message));
|
|
66
|
+
else
|
|
67
|
+
this.errors.push(new YAMLParseError(pos, code, message));
|
|
68
|
+
};
|
|
69
|
+
// eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
|
|
70
|
+
this.directives = new Directives({ version: options.version || '1.2' });
|
|
71
|
+
this.options = options;
|
|
72
|
+
}
|
|
73
|
+
decorate(doc, afterDoc) {
|
|
74
|
+
const { comment, afterEmptyLine } = parsePrelude(this.prelude);
|
|
75
|
+
//console.log({ dc: doc.comment, prelude, comment })
|
|
76
|
+
if (comment) {
|
|
77
|
+
const dc = doc.contents;
|
|
78
|
+
if (afterDoc) {
|
|
79
|
+
doc.comment = doc.comment ? `${doc.comment}\n${comment}` : comment;
|
|
80
|
+
}
|
|
81
|
+
else if (afterEmptyLine || doc.directives.docStart || !dc) {
|
|
82
|
+
doc.commentBefore = comment;
|
|
83
|
+
}
|
|
84
|
+
else if (isCollection(dc) && !dc.flow && dc.items.length > 0) {
|
|
85
|
+
let it = dc.items[0];
|
|
86
|
+
if (isPair(it))
|
|
87
|
+
it = it.key;
|
|
88
|
+
const cb = it.commentBefore;
|
|
89
|
+
it.commentBefore = cb ? `${comment}\n${cb}` : comment;
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
const cb = dc.commentBefore;
|
|
93
|
+
dc.commentBefore = cb ? `${comment}\n${cb}` : comment;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
if (afterDoc) {
|
|
97
|
+
Array.prototype.push.apply(doc.errors, this.errors);
|
|
98
|
+
Array.prototype.push.apply(doc.warnings, this.warnings);
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
doc.errors = this.errors;
|
|
102
|
+
doc.warnings = this.warnings;
|
|
103
|
+
}
|
|
104
|
+
this.prelude = [];
|
|
105
|
+
this.errors = [];
|
|
106
|
+
this.warnings = [];
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Current stream status information.
|
|
110
|
+
*
|
|
111
|
+
* Mostly useful at the end of input for an empty stream.
|
|
112
|
+
*/
|
|
113
|
+
streamInfo() {
|
|
114
|
+
return {
|
|
115
|
+
comment: parsePrelude(this.prelude).comment,
|
|
116
|
+
directives: this.directives,
|
|
117
|
+
errors: this.errors,
|
|
118
|
+
warnings: this.warnings
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Compose tokens into documents.
|
|
123
|
+
*
|
|
124
|
+
* @param forceDoc - If the stream contains no document, still emit a final document including any comments and directives that would be applied to a subsequent document.
|
|
125
|
+
* @param endOffset - Should be set if `forceDoc` is also set, to set the document range end and to indicate errors correctly.
|
|
126
|
+
*/
|
|
127
|
+
*compose(tokens, forceDoc = false, endOffset = -1) {
|
|
128
|
+
for (const token of tokens)
|
|
129
|
+
yield* this.next(token);
|
|
130
|
+
yield* this.end(forceDoc, endOffset);
|
|
131
|
+
}
|
|
132
|
+
/** Advance the composer by one CST token. */
|
|
133
|
+
*next(token) {
|
|
134
|
+
switch (token.type) {
|
|
135
|
+
case 'directive':
|
|
136
|
+
this.directives.add(token.source, (offset, message, warning) => {
|
|
137
|
+
const pos = getErrorPos(token);
|
|
138
|
+
pos[0] += offset;
|
|
139
|
+
this.onError(pos, 'BAD_DIRECTIVE', message, warning);
|
|
140
|
+
});
|
|
141
|
+
this.prelude.push(token.source);
|
|
142
|
+
this.atDirectives = true;
|
|
143
|
+
break;
|
|
144
|
+
case 'document': {
|
|
145
|
+
const doc = composeDoc(this.options, this.directives, token, this.onError);
|
|
146
|
+
if (this.atDirectives && !doc.directives.docStart)
|
|
147
|
+
this.onError(token, 'MISSING_CHAR', 'Missing directives-end/doc-start indicator line');
|
|
148
|
+
this.decorate(doc, false);
|
|
149
|
+
if (this.doc)
|
|
150
|
+
yield this.doc;
|
|
151
|
+
this.doc = doc;
|
|
152
|
+
this.atDirectives = false;
|
|
153
|
+
break;
|
|
154
|
+
}
|
|
155
|
+
case 'byte-order-mark':
|
|
156
|
+
case 'space':
|
|
157
|
+
break;
|
|
158
|
+
case 'comment':
|
|
159
|
+
case 'newline':
|
|
160
|
+
this.prelude.push(token.source);
|
|
161
|
+
break;
|
|
162
|
+
case 'error': {
|
|
163
|
+
const msg = token.source
|
|
164
|
+
? `${token.message}: ${JSON.stringify(token.source)}`
|
|
165
|
+
: token.message;
|
|
166
|
+
const error = new YAMLParseError(getErrorPos(token), 'UNEXPECTED_TOKEN', msg);
|
|
167
|
+
if (this.atDirectives || !this.doc)
|
|
168
|
+
this.errors.push(error);
|
|
169
|
+
else
|
|
170
|
+
this.doc.errors.push(error);
|
|
171
|
+
break;
|
|
172
|
+
}
|
|
173
|
+
case 'doc-end': {
|
|
174
|
+
if (!this.doc) {
|
|
175
|
+
const msg = 'Unexpected doc-end without preceding document';
|
|
176
|
+
this.errors.push(new YAMLParseError(getErrorPos(token), 'UNEXPECTED_TOKEN', msg));
|
|
177
|
+
break;
|
|
178
|
+
}
|
|
179
|
+
this.doc.directives.docEnd = true;
|
|
180
|
+
const end = resolveEnd(token.end, token.offset + token.source.length, this.doc.options.strict, this.onError);
|
|
181
|
+
this.decorate(this.doc, true);
|
|
182
|
+
if (end.comment) {
|
|
183
|
+
const dc = this.doc.comment;
|
|
184
|
+
this.doc.comment = dc ? `${dc}\n${end.comment}` : end.comment;
|
|
185
|
+
}
|
|
186
|
+
this.doc.range[2] = end.offset;
|
|
187
|
+
break;
|
|
188
|
+
}
|
|
189
|
+
default:
|
|
190
|
+
this.errors.push(new YAMLParseError(getErrorPos(token), 'UNEXPECTED_TOKEN', `Unsupported token ${token.type}`));
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* Call at end of input to yield any remaining document.
|
|
195
|
+
*
|
|
196
|
+
* @param forceDoc - If the stream contains no document, still emit a final document including any comments and directives that would be applied to a subsequent document.
|
|
197
|
+
* @param endOffset - Should be set if `forceDoc` is also set, to set the document range end and to indicate errors correctly.
|
|
198
|
+
*/
|
|
199
|
+
*end(forceDoc = false, endOffset = -1) {
|
|
200
|
+
if (this.doc) {
|
|
201
|
+
this.decorate(this.doc, true);
|
|
202
|
+
yield this.doc;
|
|
203
|
+
this.doc = null;
|
|
204
|
+
}
|
|
205
|
+
else if (forceDoc) {
|
|
206
|
+
const opts = Object.assign({ _directives: this.directives }, this.options);
|
|
207
|
+
const doc = new Document(undefined, opts);
|
|
208
|
+
if (this.atDirectives)
|
|
209
|
+
this.onError(endOffset, 'MISSING_CHAR', 'Missing directives-end indicator line');
|
|
210
|
+
doc.range = [0, endOffset, endOffset];
|
|
211
|
+
this.decorate(doc, false);
|
|
212
|
+
yield doc;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
export { Composer };
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { Pair } from '../nodes/Pair.js';
|
|
2
|
+
import { YAMLMap } from '../nodes/YAMLMap.js';
|
|
3
|
+
import { resolveProps } from './resolve-props.js';
|
|
4
|
+
import { containsNewline } from './util-contains-newline.js';
|
|
5
|
+
import { flowIndentCheck } from './util-flow-indent-check.js';
|
|
6
|
+
import { mapIncludes } from './util-map-includes.js';
|
|
7
|
+
|
|
8
|
+
const startColMsg = 'All mapping items must start at the same column';
|
|
9
|
+
function resolveBlockMap({ composeNode, composeEmptyNode }, ctx, bm, onError, tag) {
|
|
10
|
+
const NodeClass = tag?.nodeClass ?? YAMLMap;
|
|
11
|
+
const map = new NodeClass(ctx.schema);
|
|
12
|
+
if (ctx.atRoot)
|
|
13
|
+
ctx.atRoot = false;
|
|
14
|
+
let offset = bm.offset;
|
|
15
|
+
let commentEnd = null;
|
|
16
|
+
for (const collItem of bm.items) {
|
|
17
|
+
const { start, key, sep, value } = collItem;
|
|
18
|
+
// key properties
|
|
19
|
+
const keyProps = resolveProps(start, {
|
|
20
|
+
indicator: 'explicit-key-ind',
|
|
21
|
+
next: key ?? sep?.[0],
|
|
22
|
+
offset,
|
|
23
|
+
onError,
|
|
24
|
+
parentIndent: bm.indent,
|
|
25
|
+
startOnNewline: true
|
|
26
|
+
});
|
|
27
|
+
const implicitKey = !keyProps.found;
|
|
28
|
+
if (implicitKey) {
|
|
29
|
+
if (key) {
|
|
30
|
+
if (key.type === 'block-seq')
|
|
31
|
+
onError(offset, 'BLOCK_AS_IMPLICIT_KEY', 'A block sequence may not be used as an implicit map key');
|
|
32
|
+
else if ('indent' in key && key.indent !== bm.indent)
|
|
33
|
+
onError(offset, 'BAD_INDENT', startColMsg);
|
|
34
|
+
}
|
|
35
|
+
if (!keyProps.anchor && !keyProps.tag && !sep) {
|
|
36
|
+
commentEnd = keyProps.end;
|
|
37
|
+
if (keyProps.comment) {
|
|
38
|
+
if (map.comment)
|
|
39
|
+
map.comment += '\n' + keyProps.comment;
|
|
40
|
+
else
|
|
41
|
+
map.comment = keyProps.comment;
|
|
42
|
+
}
|
|
43
|
+
continue;
|
|
44
|
+
}
|
|
45
|
+
if (keyProps.newlineAfterProp || containsNewline(key)) {
|
|
46
|
+
onError(key ?? start[start.length - 1], 'MULTILINE_IMPLICIT_KEY', 'Implicit keys need to be on a single line');
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
else if (keyProps.found?.indent !== bm.indent) {
|
|
50
|
+
onError(offset, 'BAD_INDENT', startColMsg);
|
|
51
|
+
}
|
|
52
|
+
// key value
|
|
53
|
+
ctx.atKey = true;
|
|
54
|
+
const keyStart = keyProps.end;
|
|
55
|
+
const keyNode = key
|
|
56
|
+
? composeNode(ctx, key, keyProps, onError)
|
|
57
|
+
: composeEmptyNode(ctx, keyStart, start, null, keyProps, onError);
|
|
58
|
+
if (ctx.schema.compat)
|
|
59
|
+
flowIndentCheck(bm.indent, key, onError);
|
|
60
|
+
ctx.atKey = false;
|
|
61
|
+
if (mapIncludes(ctx, map.items, keyNode))
|
|
62
|
+
onError(keyStart, 'DUPLICATE_KEY', 'Map keys must be unique');
|
|
63
|
+
// value properties
|
|
64
|
+
const valueProps = resolveProps(sep ?? [], {
|
|
65
|
+
indicator: 'map-value-ind',
|
|
66
|
+
next: value,
|
|
67
|
+
offset: keyNode.range[2],
|
|
68
|
+
onError,
|
|
69
|
+
parentIndent: bm.indent,
|
|
70
|
+
startOnNewline: !key || key.type === 'block-scalar'
|
|
71
|
+
});
|
|
72
|
+
offset = valueProps.end;
|
|
73
|
+
if (valueProps.found) {
|
|
74
|
+
if (implicitKey) {
|
|
75
|
+
if (value?.type === 'block-map' && !valueProps.hasNewline)
|
|
76
|
+
onError(offset, 'BLOCK_AS_IMPLICIT_KEY', 'Nested mappings are not allowed in compact mappings');
|
|
77
|
+
if (ctx.options.strict &&
|
|
78
|
+
keyProps.start < valueProps.found.offset - 1024)
|
|
79
|
+
onError(keyNode.range, 'KEY_OVER_1024_CHARS', 'The : indicator must be at most 1024 chars after the start of an implicit block mapping key');
|
|
80
|
+
}
|
|
81
|
+
// value value
|
|
82
|
+
const valueNode = value
|
|
83
|
+
? composeNode(ctx, value, valueProps, onError)
|
|
84
|
+
: composeEmptyNode(ctx, offset, sep, null, valueProps, onError);
|
|
85
|
+
if (ctx.schema.compat)
|
|
86
|
+
flowIndentCheck(bm.indent, value, onError);
|
|
87
|
+
offset = valueNode.range[2];
|
|
88
|
+
const pair = new Pair(keyNode, valueNode);
|
|
89
|
+
if (ctx.options.keepSourceTokens)
|
|
90
|
+
pair.srcToken = collItem;
|
|
91
|
+
map.items.push(pair);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
// key with no value
|
|
95
|
+
if (implicitKey)
|
|
96
|
+
onError(keyNode.range, 'MISSING_CHAR', 'Implicit map keys need to be followed by map values');
|
|
97
|
+
if (valueProps.comment) {
|
|
98
|
+
if (keyNode.comment)
|
|
99
|
+
keyNode.comment += '\n' + valueProps.comment;
|
|
100
|
+
else
|
|
101
|
+
keyNode.comment = valueProps.comment;
|
|
102
|
+
}
|
|
103
|
+
const pair = new Pair(keyNode);
|
|
104
|
+
if (ctx.options.keepSourceTokens)
|
|
105
|
+
pair.srcToken = collItem;
|
|
106
|
+
map.items.push(pair);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
if (commentEnd && commentEnd < offset)
|
|
110
|
+
onError(commentEnd, 'IMPOSSIBLE', 'Map comment with trailing content');
|
|
111
|
+
map.range = [bm.offset, offset, commentEnd ?? offset];
|
|
112
|
+
return map;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
export { resolveBlockMap };
|
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
import { Scalar } from '../nodes/Scalar.js';
|
|
2
|
+
|
|
3
|
+
function resolveBlockScalar(ctx, scalar, onError) {
|
|
4
|
+
const start = scalar.offset;
|
|
5
|
+
const header = parseBlockScalarHeader(scalar, ctx.options.strict, onError);
|
|
6
|
+
if (!header)
|
|
7
|
+
return { value: '', type: null, comment: '', range: [start, start, start] };
|
|
8
|
+
const type = header.mode === '>' ? Scalar.BLOCK_FOLDED : Scalar.BLOCK_LITERAL;
|
|
9
|
+
const lines = scalar.source ? splitLines(scalar.source) : [];
|
|
10
|
+
// determine the end of content & start of chomping
|
|
11
|
+
let chompStart = lines.length;
|
|
12
|
+
for (let i = lines.length - 1; i >= 0; --i) {
|
|
13
|
+
const content = lines[i][1];
|
|
14
|
+
if (content === '' || content === '\r')
|
|
15
|
+
chompStart = i;
|
|
16
|
+
else
|
|
17
|
+
break;
|
|
18
|
+
}
|
|
19
|
+
// shortcut for empty contents
|
|
20
|
+
if (chompStart === 0) {
|
|
21
|
+
const value = header.chomp === '+' && lines.length > 0
|
|
22
|
+
? '\n'.repeat(Math.max(1, lines.length - 1))
|
|
23
|
+
: '';
|
|
24
|
+
let end = start + header.length;
|
|
25
|
+
if (scalar.source)
|
|
26
|
+
end += scalar.source.length;
|
|
27
|
+
return { value, type, comment: header.comment, range: [start, end, end] };
|
|
28
|
+
}
|
|
29
|
+
// find the indentation level to trim from start
|
|
30
|
+
let trimIndent = scalar.indent + header.indent;
|
|
31
|
+
let offset = scalar.offset + header.length;
|
|
32
|
+
let contentStart = 0;
|
|
33
|
+
for (let i = 0; i < chompStart; ++i) {
|
|
34
|
+
const [indent, content] = lines[i];
|
|
35
|
+
if (content === '' || content === '\r') {
|
|
36
|
+
if (header.indent === 0 && indent.length > trimIndent)
|
|
37
|
+
trimIndent = indent.length;
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
if (indent.length < trimIndent) {
|
|
41
|
+
const message = 'Block scalars with more-indented leading empty lines must use an explicit indentation indicator';
|
|
42
|
+
onError(offset + indent.length, 'MISSING_CHAR', message);
|
|
43
|
+
}
|
|
44
|
+
if (header.indent === 0)
|
|
45
|
+
trimIndent = indent.length;
|
|
46
|
+
contentStart = i;
|
|
47
|
+
if (trimIndent === 0 && !ctx.atRoot) {
|
|
48
|
+
const message = 'Block scalar values in collections must be indented';
|
|
49
|
+
onError(offset, 'BAD_INDENT', message);
|
|
50
|
+
}
|
|
51
|
+
break;
|
|
52
|
+
}
|
|
53
|
+
offset += indent.length + content.length + 1;
|
|
54
|
+
}
|
|
55
|
+
// include trailing more-indented empty lines in content
|
|
56
|
+
for (let i = lines.length - 1; i >= chompStart; --i) {
|
|
57
|
+
if (lines[i][0].length > trimIndent)
|
|
58
|
+
chompStart = i + 1;
|
|
59
|
+
}
|
|
60
|
+
let value = '';
|
|
61
|
+
let sep = '';
|
|
62
|
+
let prevMoreIndented = false;
|
|
63
|
+
// leading whitespace is kept intact
|
|
64
|
+
for (let i = 0; i < contentStart; ++i)
|
|
65
|
+
value += lines[i][0].slice(trimIndent) + '\n';
|
|
66
|
+
for (let i = contentStart; i < chompStart; ++i) {
|
|
67
|
+
let [indent, content] = lines[i];
|
|
68
|
+
offset += indent.length + content.length + 1;
|
|
69
|
+
const crlf = content[content.length - 1] === '\r';
|
|
70
|
+
if (crlf)
|
|
71
|
+
content = content.slice(0, -1);
|
|
72
|
+
/* istanbul ignore if already caught in lexer */
|
|
73
|
+
if (content && indent.length < trimIndent) {
|
|
74
|
+
const src = header.indent
|
|
75
|
+
? 'explicit indentation indicator'
|
|
76
|
+
: 'first line';
|
|
77
|
+
const message = `Block scalar lines must not be less indented than their ${src}`;
|
|
78
|
+
onError(offset - content.length - (crlf ? 2 : 1), 'BAD_INDENT', message);
|
|
79
|
+
indent = '';
|
|
80
|
+
}
|
|
81
|
+
if (type === Scalar.BLOCK_LITERAL) {
|
|
82
|
+
value += sep + indent.slice(trimIndent) + content;
|
|
83
|
+
sep = '\n';
|
|
84
|
+
}
|
|
85
|
+
else if (indent.length > trimIndent || content[0] === '\t') {
|
|
86
|
+
// more-indented content within a folded block
|
|
87
|
+
if (sep === ' ')
|
|
88
|
+
sep = '\n';
|
|
89
|
+
else if (!prevMoreIndented && sep === '\n')
|
|
90
|
+
sep = '\n\n';
|
|
91
|
+
value += sep + indent.slice(trimIndent) + content;
|
|
92
|
+
sep = '\n';
|
|
93
|
+
prevMoreIndented = true;
|
|
94
|
+
}
|
|
95
|
+
else if (content === '') {
|
|
96
|
+
// empty line
|
|
97
|
+
if (sep === '\n')
|
|
98
|
+
value += '\n';
|
|
99
|
+
else
|
|
100
|
+
sep = '\n';
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
value += sep + content;
|
|
104
|
+
sep = ' ';
|
|
105
|
+
prevMoreIndented = false;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
switch (header.chomp) {
|
|
109
|
+
case '-':
|
|
110
|
+
break;
|
|
111
|
+
case '+':
|
|
112
|
+
for (let i = chompStart; i < lines.length; ++i)
|
|
113
|
+
value += '\n' + lines[i][0].slice(trimIndent);
|
|
114
|
+
if (value[value.length - 1] !== '\n')
|
|
115
|
+
value += '\n';
|
|
116
|
+
break;
|
|
117
|
+
default:
|
|
118
|
+
value += '\n';
|
|
119
|
+
}
|
|
120
|
+
const end = start + header.length + scalar.source.length;
|
|
121
|
+
return { value, type, comment: header.comment, range: [start, end, end] };
|
|
122
|
+
}
|
|
123
|
+
function parseBlockScalarHeader({ offset, props }, strict, onError) {
|
|
124
|
+
/* istanbul ignore if should not happen */
|
|
125
|
+
if (props[0].type !== 'block-scalar-header') {
|
|
126
|
+
onError(props[0], 'IMPOSSIBLE', 'Block scalar header not found');
|
|
127
|
+
return null;
|
|
128
|
+
}
|
|
129
|
+
const { source } = props[0];
|
|
130
|
+
const mode = source[0];
|
|
131
|
+
let indent = 0;
|
|
132
|
+
let chomp = '';
|
|
133
|
+
let error = -1;
|
|
134
|
+
for (let i = 1; i < source.length; ++i) {
|
|
135
|
+
const ch = source[i];
|
|
136
|
+
if (!chomp && (ch === '-' || ch === '+'))
|
|
137
|
+
chomp = ch;
|
|
138
|
+
else {
|
|
139
|
+
const n = Number(ch);
|
|
140
|
+
if (!indent && n)
|
|
141
|
+
indent = n;
|
|
142
|
+
else if (error === -1)
|
|
143
|
+
error = offset + i;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
if (error !== -1)
|
|
147
|
+
onError(error, 'UNEXPECTED_TOKEN', `Block scalar header includes extra characters: ${source}`);
|
|
148
|
+
let hasSpace = false;
|
|
149
|
+
let comment = '';
|
|
150
|
+
let length = source.length;
|
|
151
|
+
for (let i = 1; i < props.length; ++i) {
|
|
152
|
+
const token = props[i];
|
|
153
|
+
switch (token.type) {
|
|
154
|
+
case 'space':
|
|
155
|
+
hasSpace = true;
|
|
156
|
+
// fallthrough
|
|
157
|
+
case 'newline':
|
|
158
|
+
length += token.source.length;
|
|
159
|
+
break;
|
|
160
|
+
case 'comment':
|
|
161
|
+
if (strict && !hasSpace) {
|
|
162
|
+
const message = 'Comments must be separated from other tokens by white space characters';
|
|
163
|
+
onError(token, 'MISSING_CHAR', message);
|
|
164
|
+
}
|
|
165
|
+
length += token.source.length;
|
|
166
|
+
comment = token.source.substring(1);
|
|
167
|
+
break;
|
|
168
|
+
case 'error':
|
|
169
|
+
onError(token, 'UNEXPECTED_TOKEN', token.message);
|
|
170
|
+
length += token.source.length;
|
|
171
|
+
break;
|
|
172
|
+
/* istanbul ignore next should not happen */
|
|
173
|
+
default: {
|
|
174
|
+
const message = `Unexpected token in block scalar header: ${token.type}`;
|
|
175
|
+
onError(token, 'UNEXPECTED_TOKEN', message);
|
|
176
|
+
const ts = token.source;
|
|
177
|
+
if (ts && typeof ts === 'string')
|
|
178
|
+
length += ts.length;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
return { mode, indent, chomp, comment, length };
|
|
183
|
+
}
|
|
184
|
+
/** @returns Array of lines split up as `[indent, content]` */
|
|
185
|
+
function splitLines(source) {
|
|
186
|
+
const split = source.split(/\n( *)/);
|
|
187
|
+
const first = split[0];
|
|
188
|
+
const m = first.match(/^( *)/);
|
|
189
|
+
const line0 = m?.[1]
|
|
190
|
+
? [m[1], first.slice(m[1].length)]
|
|
191
|
+
: ['', first];
|
|
192
|
+
const lines = [line0];
|
|
193
|
+
for (let i = 1; i < split.length; i += 2)
|
|
194
|
+
lines.push([split[i], split[i + 1]]);
|
|
195
|
+
return lines;
|
|
196
|
+
}
|
|
197
|
+
|
|
198
|
+
export { resolveBlockScalar };
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { YAMLSeq } from '../nodes/YAMLSeq.js';
|
|
2
|
+
import { resolveProps } from './resolve-props.js';
|
|
3
|
+
import { flowIndentCheck } from './util-flow-indent-check.js';
|
|
4
|
+
|
|
5
|
+
function resolveBlockSeq({ composeNode, composeEmptyNode }, ctx, bs, onError, tag) {
|
|
6
|
+
const NodeClass = tag?.nodeClass ?? YAMLSeq;
|
|
7
|
+
const seq = new NodeClass(ctx.schema);
|
|
8
|
+
if (ctx.atRoot)
|
|
9
|
+
ctx.atRoot = false;
|
|
10
|
+
if (ctx.atKey)
|
|
11
|
+
ctx.atKey = false;
|
|
12
|
+
let offset = bs.offset;
|
|
13
|
+
let commentEnd = null;
|
|
14
|
+
for (const { start, value } of bs.items) {
|
|
15
|
+
const props = resolveProps(start, {
|
|
16
|
+
indicator: 'seq-item-ind',
|
|
17
|
+
next: value,
|
|
18
|
+
offset,
|
|
19
|
+
onError,
|
|
20
|
+
parentIndent: bs.indent,
|
|
21
|
+
startOnNewline: true
|
|
22
|
+
});
|
|
23
|
+
if (!props.found) {
|
|
24
|
+
if (props.anchor || props.tag || value) {
|
|
25
|
+
if (value?.type === 'block-seq')
|
|
26
|
+
onError(props.end, 'BAD_INDENT', 'All sequence items must start at the same column');
|
|
27
|
+
else
|
|
28
|
+
onError(offset, 'MISSING_CHAR', 'Sequence item without - indicator');
|
|
29
|
+
}
|
|
30
|
+
else {
|
|
31
|
+
commentEnd = props.end;
|
|
32
|
+
if (props.comment)
|
|
33
|
+
seq.comment = props.comment;
|
|
34
|
+
continue;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
const node = value
|
|
38
|
+
? composeNode(ctx, value, props, onError)
|
|
39
|
+
: composeEmptyNode(ctx, props.end, start, null, props, onError);
|
|
40
|
+
if (ctx.schema.compat)
|
|
41
|
+
flowIndentCheck(bs.indent, value, onError);
|
|
42
|
+
offset = node.range[2];
|
|
43
|
+
seq.items.push(node);
|
|
44
|
+
}
|
|
45
|
+
seq.range = [bs.offset, offset, commentEnd ?? offset];
|
|
46
|
+
return seq;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
export { resolveBlockSeq };
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
function resolveEnd(end, offset, reqSpace, onError) {
|
|
2
|
+
let comment = '';
|
|
3
|
+
if (end) {
|
|
4
|
+
let hasSpace = false;
|
|
5
|
+
let sep = '';
|
|
6
|
+
for (const token of end) {
|
|
7
|
+
const { source, type } = token;
|
|
8
|
+
switch (type) {
|
|
9
|
+
case 'space':
|
|
10
|
+
hasSpace = true;
|
|
11
|
+
break;
|
|
12
|
+
case 'comment': {
|
|
13
|
+
if (reqSpace && !hasSpace)
|
|
14
|
+
onError(token, 'MISSING_CHAR', 'Comments must be separated from other tokens by white space characters');
|
|
15
|
+
const cb = source.substring(1) || ' ';
|
|
16
|
+
if (!comment)
|
|
17
|
+
comment = cb;
|
|
18
|
+
else
|
|
19
|
+
comment += sep + cb;
|
|
20
|
+
sep = '';
|
|
21
|
+
break;
|
|
22
|
+
}
|
|
23
|
+
case 'newline':
|
|
24
|
+
if (comment)
|
|
25
|
+
sep += source;
|
|
26
|
+
hasSpace = true;
|
|
27
|
+
break;
|
|
28
|
+
default:
|
|
29
|
+
onError(token, 'UNEXPECTED_TOKEN', `Unexpected ${type} at node end`);
|
|
30
|
+
}
|
|
31
|
+
offset += source.length;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return { comment, offset };
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export { resolveEnd };
|