phantom-pr 0.2.5 → 0.2.6

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.
Files changed (242) hide show
  1. package/dist/core/index/indexer.js +3 -1
  2. package/dist/core/index/indexer.js.map +1 -1
  3. package/package.json +3 -7
  4. package/node_modules/ignore/LICENSE-MIT +0 -21
  5. package/node_modules/ignore/README.md +0 -452
  6. package/node_modules/ignore/index.d.ts +0 -81
  7. package/node_modules/ignore/index.js +0 -784
  8. package/node_modules/ignore/legacy.js +0 -681
  9. package/node_modules/ignore/package.json +0 -87
  10. package/node_modules/yaml/LICENSE +0 -13
  11. package/node_modules/yaml/README.md +0 -172
  12. package/node_modules/yaml/bin.mjs +0 -11
  13. package/node_modules/yaml/browser/dist/compose/compose-collection.js +0 -88
  14. package/node_modules/yaml/browser/dist/compose/compose-doc.js +0 -43
  15. package/node_modules/yaml/browser/dist/compose/compose-node.js +0 -102
  16. package/node_modules/yaml/browser/dist/compose/compose-scalar.js +0 -86
  17. package/node_modules/yaml/browser/dist/compose/composer.js +0 -217
  18. package/node_modules/yaml/browser/dist/compose/resolve-block-map.js +0 -115
  19. package/node_modules/yaml/browser/dist/compose/resolve-block-scalar.js +0 -198
  20. package/node_modules/yaml/browser/dist/compose/resolve-block-seq.js +0 -49
  21. package/node_modules/yaml/browser/dist/compose/resolve-end.js +0 -37
  22. package/node_modules/yaml/browser/dist/compose/resolve-flow-collection.js +0 -207
  23. package/node_modules/yaml/browser/dist/compose/resolve-flow-scalar.js +0 -223
  24. package/node_modules/yaml/browser/dist/compose/resolve-props.js +0 -146
  25. package/node_modules/yaml/browser/dist/compose/util-contains-newline.js +0 -34
  26. package/node_modules/yaml/browser/dist/compose/util-empty-scalar-position.js +0 -26
  27. package/node_modules/yaml/browser/dist/compose/util-flow-indent-check.js +0 -15
  28. package/node_modules/yaml/browser/dist/compose/util-map-includes.js +0 -13
  29. package/node_modules/yaml/browser/dist/doc/Document.js +0 -335
  30. package/node_modules/yaml/browser/dist/doc/anchors.js +0 -71
  31. package/node_modules/yaml/browser/dist/doc/applyReviver.js +0 -55
  32. package/node_modules/yaml/browser/dist/doc/createNode.js +0 -88
  33. package/node_modules/yaml/browser/dist/doc/directives.js +0 -176
  34. package/node_modules/yaml/browser/dist/errors.js +0 -57
  35. package/node_modules/yaml/browser/dist/index.js +0 -17
  36. package/node_modules/yaml/browser/dist/log.js +0 -11
  37. package/node_modules/yaml/browser/dist/nodes/Alias.js +0 -114
  38. package/node_modules/yaml/browser/dist/nodes/Collection.js +0 -147
  39. package/node_modules/yaml/browser/dist/nodes/Node.js +0 -38
  40. package/node_modules/yaml/browser/dist/nodes/Pair.js +0 -36
  41. package/node_modules/yaml/browser/dist/nodes/Scalar.js +0 -24
  42. package/node_modules/yaml/browser/dist/nodes/YAMLMap.js +0 -144
  43. package/node_modules/yaml/browser/dist/nodes/YAMLSeq.js +0 -113
  44. package/node_modules/yaml/browser/dist/nodes/addPairToJSMap.js +0 -63
  45. package/node_modules/yaml/browser/dist/nodes/identity.js +0 -36
  46. package/node_modules/yaml/browser/dist/nodes/toJS.js +0 -37
  47. package/node_modules/yaml/browser/dist/parse/cst-scalar.js +0 -214
  48. package/node_modules/yaml/browser/dist/parse/cst-stringify.js +0 -61
  49. package/node_modules/yaml/browser/dist/parse/cst-visit.js +0 -97
  50. package/node_modules/yaml/browser/dist/parse/cst.js +0 -98
  51. package/node_modules/yaml/browser/dist/parse/lexer.js +0 -717
  52. package/node_modules/yaml/browser/dist/parse/line-counter.js +0 -39
  53. package/node_modules/yaml/browser/dist/parse/parser.js +0 -967
  54. package/node_modules/yaml/browser/dist/public-api.js +0 -102
  55. package/node_modules/yaml/browser/dist/schema/Schema.js +0 -37
  56. package/node_modules/yaml/browser/dist/schema/common/map.js +0 -17
  57. package/node_modules/yaml/browser/dist/schema/common/null.js +0 -15
  58. package/node_modules/yaml/browser/dist/schema/common/seq.js +0 -17
  59. package/node_modules/yaml/browser/dist/schema/common/string.js +0 -14
  60. package/node_modules/yaml/browser/dist/schema/core/bool.js +0 -19
  61. package/node_modules/yaml/browser/dist/schema/core/float.js +0 -43
  62. package/node_modules/yaml/browser/dist/schema/core/int.js +0 -38
  63. package/node_modules/yaml/browser/dist/schema/core/schema.js +0 -23
  64. package/node_modules/yaml/browser/dist/schema/json/schema.js +0 -62
  65. package/node_modules/yaml/browser/dist/schema/tags.js +0 -96
  66. package/node_modules/yaml/browser/dist/schema/yaml-1.1/binary.js +0 -58
  67. package/node_modules/yaml/browser/dist/schema/yaml-1.1/bool.js +0 -26
  68. package/node_modules/yaml/browser/dist/schema/yaml-1.1/float.js +0 -46
  69. package/node_modules/yaml/browser/dist/schema/yaml-1.1/int.js +0 -71
  70. package/node_modules/yaml/browser/dist/schema/yaml-1.1/merge.js +0 -64
  71. package/node_modules/yaml/browser/dist/schema/yaml-1.1/omap.js +0 -74
  72. package/node_modules/yaml/browser/dist/schema/yaml-1.1/pairs.js +0 -78
  73. package/node_modules/yaml/browser/dist/schema/yaml-1.1/schema.js +0 -39
  74. package/node_modules/yaml/browser/dist/schema/yaml-1.1/set.js +0 -93
  75. package/node_modules/yaml/browser/dist/schema/yaml-1.1/timestamp.js +0 -101
  76. package/node_modules/yaml/browser/dist/stringify/foldFlowLines.js +0 -146
  77. package/node_modules/yaml/browser/dist/stringify/stringify.js +0 -128
  78. package/node_modules/yaml/browser/dist/stringify/stringifyCollection.js +0 -143
  79. package/node_modules/yaml/browser/dist/stringify/stringifyComment.js +0 -20
  80. package/node_modules/yaml/browser/dist/stringify/stringifyDocument.js +0 -85
  81. package/node_modules/yaml/browser/dist/stringify/stringifyNumber.js +0 -24
  82. package/node_modules/yaml/browser/dist/stringify/stringifyPair.js +0 -150
  83. package/node_modules/yaml/browser/dist/stringify/stringifyString.js +0 -336
  84. package/node_modules/yaml/browser/dist/util.js +0 -11
  85. package/node_modules/yaml/browser/dist/visit.js +0 -233
  86. package/node_modules/yaml/browser/index.js +0 -5
  87. package/node_modules/yaml/browser/package.json +0 -3
  88. package/node_modules/yaml/dist/cli.d.ts +0 -8
  89. package/node_modules/yaml/dist/cli.mjs +0 -201
  90. package/node_modules/yaml/dist/compose/compose-collection.d.ts +0 -11
  91. package/node_modules/yaml/dist/compose/compose-collection.js +0 -90
  92. package/node_modules/yaml/dist/compose/compose-doc.d.ts +0 -7
  93. package/node_modules/yaml/dist/compose/compose-doc.js +0 -45
  94. package/node_modules/yaml/dist/compose/compose-node.d.ts +0 -29
  95. package/node_modules/yaml/dist/compose/compose-node.js +0 -105
  96. package/node_modules/yaml/dist/compose/compose-scalar.d.ts +0 -5
  97. package/node_modules/yaml/dist/compose/compose-scalar.js +0 -88
  98. package/node_modules/yaml/dist/compose/composer.d.ts +0 -63
  99. package/node_modules/yaml/dist/compose/composer.js +0 -222
  100. package/node_modules/yaml/dist/compose/resolve-block-map.d.ts +0 -6
  101. package/node_modules/yaml/dist/compose/resolve-block-map.js +0 -117
  102. package/node_modules/yaml/dist/compose/resolve-block-scalar.d.ts +0 -11
  103. package/node_modules/yaml/dist/compose/resolve-block-scalar.js +0 -200
  104. package/node_modules/yaml/dist/compose/resolve-block-seq.d.ts +0 -6
  105. package/node_modules/yaml/dist/compose/resolve-block-seq.js +0 -51
  106. package/node_modules/yaml/dist/compose/resolve-end.d.ts +0 -6
  107. package/node_modules/yaml/dist/compose/resolve-end.js +0 -39
  108. package/node_modules/yaml/dist/compose/resolve-flow-collection.d.ts +0 -7
  109. package/node_modules/yaml/dist/compose/resolve-flow-collection.js +0 -209
  110. package/node_modules/yaml/dist/compose/resolve-flow-scalar.d.ts +0 -10
  111. package/node_modules/yaml/dist/compose/resolve-flow-scalar.js +0 -225
  112. package/node_modules/yaml/dist/compose/resolve-props.d.ts +0 -23
  113. package/node_modules/yaml/dist/compose/resolve-props.js +0 -148
  114. package/node_modules/yaml/dist/compose/util-contains-newline.d.ts +0 -2
  115. package/node_modules/yaml/dist/compose/util-contains-newline.js +0 -36
  116. package/node_modules/yaml/dist/compose/util-empty-scalar-position.d.ts +0 -2
  117. package/node_modules/yaml/dist/compose/util-empty-scalar-position.js +0 -28
  118. package/node_modules/yaml/dist/compose/util-flow-indent-check.d.ts +0 -3
  119. package/node_modules/yaml/dist/compose/util-flow-indent-check.js +0 -17
  120. package/node_modules/yaml/dist/compose/util-map-includes.d.ts +0 -4
  121. package/node_modules/yaml/dist/compose/util-map-includes.js +0 -15
  122. package/node_modules/yaml/dist/doc/Document.d.ts +0 -141
  123. package/node_modules/yaml/dist/doc/Document.js +0 -337
  124. package/node_modules/yaml/dist/doc/anchors.d.ts +0 -24
  125. package/node_modules/yaml/dist/doc/anchors.js +0 -76
  126. package/node_modules/yaml/dist/doc/applyReviver.d.ts +0 -9
  127. package/node_modules/yaml/dist/doc/applyReviver.js +0 -57
  128. package/node_modules/yaml/dist/doc/createNode.d.ts +0 -17
  129. package/node_modules/yaml/dist/doc/createNode.js +0 -90
  130. package/node_modules/yaml/dist/doc/directives.d.ts +0 -49
  131. package/node_modules/yaml/dist/doc/directives.js +0 -178
  132. package/node_modules/yaml/dist/errors.d.ts +0 -21
  133. package/node_modules/yaml/dist/errors.js +0 -62
  134. package/node_modules/yaml/dist/index.d.ts +0 -25
  135. package/node_modules/yaml/dist/index.js +0 -50
  136. package/node_modules/yaml/dist/log.d.ts +0 -3
  137. package/node_modules/yaml/dist/log.js +0 -19
  138. package/node_modules/yaml/dist/nodes/Alias.d.ts +0 -29
  139. package/node_modules/yaml/dist/nodes/Alias.js +0 -116
  140. package/node_modules/yaml/dist/nodes/Collection.d.ts +0 -73
  141. package/node_modules/yaml/dist/nodes/Collection.js +0 -151
  142. package/node_modules/yaml/dist/nodes/Node.d.ts +0 -53
  143. package/node_modules/yaml/dist/nodes/Node.js +0 -40
  144. package/node_modules/yaml/dist/nodes/Pair.d.ts +0 -22
  145. package/node_modules/yaml/dist/nodes/Pair.js +0 -39
  146. package/node_modules/yaml/dist/nodes/Scalar.d.ts +0 -43
  147. package/node_modules/yaml/dist/nodes/Scalar.js +0 -27
  148. package/node_modules/yaml/dist/nodes/YAMLMap.d.ts +0 -53
  149. package/node_modules/yaml/dist/nodes/YAMLMap.js +0 -147
  150. package/node_modules/yaml/dist/nodes/YAMLSeq.d.ts +0 -60
  151. package/node_modules/yaml/dist/nodes/YAMLSeq.js +0 -115
  152. package/node_modules/yaml/dist/nodes/addPairToJSMap.d.ts +0 -4
  153. package/node_modules/yaml/dist/nodes/addPairToJSMap.js +0 -65
  154. package/node_modules/yaml/dist/nodes/identity.d.ts +0 -23
  155. package/node_modules/yaml/dist/nodes/identity.js +0 -53
  156. package/node_modules/yaml/dist/nodes/toJS.d.ts +0 -29
  157. package/node_modules/yaml/dist/nodes/toJS.js +0 -39
  158. package/node_modules/yaml/dist/options.d.ts +0 -344
  159. package/node_modules/yaml/dist/parse/cst-scalar.d.ts +0 -64
  160. package/node_modules/yaml/dist/parse/cst-scalar.js +0 -218
  161. package/node_modules/yaml/dist/parse/cst-stringify.d.ts +0 -8
  162. package/node_modules/yaml/dist/parse/cst-stringify.js +0 -63
  163. package/node_modules/yaml/dist/parse/cst-visit.d.ts +0 -39
  164. package/node_modules/yaml/dist/parse/cst-visit.js +0 -99
  165. package/node_modules/yaml/dist/parse/cst.d.ts +0 -109
  166. package/node_modules/yaml/dist/parse/cst.js +0 -112
  167. package/node_modules/yaml/dist/parse/lexer.d.ts +0 -87
  168. package/node_modules/yaml/dist/parse/lexer.js +0 -719
  169. package/node_modules/yaml/dist/parse/line-counter.d.ts +0 -22
  170. package/node_modules/yaml/dist/parse/line-counter.js +0 -41
  171. package/node_modules/yaml/dist/parse/parser.d.ts +0 -84
  172. package/node_modules/yaml/dist/parse/parser.js +0 -972
  173. package/node_modules/yaml/dist/public-api.d.ts +0 -44
  174. package/node_modules/yaml/dist/public-api.js +0 -107
  175. package/node_modules/yaml/dist/schema/Schema.d.ts +0 -17
  176. package/node_modules/yaml/dist/schema/Schema.js +0 -39
  177. package/node_modules/yaml/dist/schema/common/map.d.ts +0 -2
  178. package/node_modules/yaml/dist/schema/common/map.js +0 -19
  179. package/node_modules/yaml/dist/schema/common/null.d.ts +0 -4
  180. package/node_modules/yaml/dist/schema/common/null.js +0 -17
  181. package/node_modules/yaml/dist/schema/common/seq.d.ts +0 -2
  182. package/node_modules/yaml/dist/schema/common/seq.js +0 -19
  183. package/node_modules/yaml/dist/schema/common/string.d.ts +0 -2
  184. package/node_modules/yaml/dist/schema/common/string.js +0 -16
  185. package/node_modules/yaml/dist/schema/core/bool.d.ts +0 -4
  186. package/node_modules/yaml/dist/schema/core/bool.js +0 -21
  187. package/node_modules/yaml/dist/schema/core/float.d.ts +0 -4
  188. package/node_modules/yaml/dist/schema/core/float.js +0 -47
  189. package/node_modules/yaml/dist/schema/core/int.d.ts +0 -4
  190. package/node_modules/yaml/dist/schema/core/int.js +0 -42
  191. package/node_modules/yaml/dist/schema/core/schema.d.ts +0 -1
  192. package/node_modules/yaml/dist/schema/core/schema.js +0 -25
  193. package/node_modules/yaml/dist/schema/json/schema.d.ts +0 -2
  194. package/node_modules/yaml/dist/schema/json/schema.js +0 -64
  195. package/node_modules/yaml/dist/schema/json-schema.d.ts +0 -69
  196. package/node_modules/yaml/dist/schema/tags.d.ts +0 -48
  197. package/node_modules/yaml/dist/schema/tags.js +0 -99
  198. package/node_modules/yaml/dist/schema/types.d.ts +0 -92
  199. package/node_modules/yaml/dist/schema/yaml-1.1/binary.d.ts +0 -2
  200. package/node_modules/yaml/dist/schema/yaml-1.1/binary.js +0 -70
  201. package/node_modules/yaml/dist/schema/yaml-1.1/bool.d.ts +0 -7
  202. package/node_modules/yaml/dist/schema/yaml-1.1/bool.js +0 -29
  203. package/node_modules/yaml/dist/schema/yaml-1.1/float.d.ts +0 -4
  204. package/node_modules/yaml/dist/schema/yaml-1.1/float.js +0 -50
  205. package/node_modules/yaml/dist/schema/yaml-1.1/int.d.ts +0 -5
  206. package/node_modules/yaml/dist/schema/yaml-1.1/int.js +0 -76
  207. package/node_modules/yaml/dist/schema/yaml-1.1/merge.d.ts +0 -9
  208. package/node_modules/yaml/dist/schema/yaml-1.1/merge.js +0 -68
  209. package/node_modules/yaml/dist/schema/yaml-1.1/omap.d.ts +0 -22
  210. package/node_modules/yaml/dist/schema/yaml-1.1/omap.js +0 -77
  211. package/node_modules/yaml/dist/schema/yaml-1.1/pairs.d.ts +0 -10
  212. package/node_modules/yaml/dist/schema/yaml-1.1/pairs.js +0 -82
  213. package/node_modules/yaml/dist/schema/yaml-1.1/schema.d.ts +0 -1
  214. package/node_modules/yaml/dist/schema/yaml-1.1/schema.js +0 -41
  215. package/node_modules/yaml/dist/schema/yaml-1.1/set.d.ts +0 -28
  216. package/node_modules/yaml/dist/schema/yaml-1.1/set.js +0 -96
  217. package/node_modules/yaml/dist/schema/yaml-1.1/timestamp.d.ts +0 -6
  218. package/node_modules/yaml/dist/schema/yaml-1.1/timestamp.js +0 -105
  219. package/node_modules/yaml/dist/stringify/foldFlowLines.d.ts +0 -34
  220. package/node_modules/yaml/dist/stringify/foldFlowLines.js +0 -151
  221. package/node_modules/yaml/dist/stringify/stringify.d.ts +0 -21
  222. package/node_modules/yaml/dist/stringify/stringify.js +0 -131
  223. package/node_modules/yaml/dist/stringify/stringifyCollection.d.ts +0 -17
  224. package/node_modules/yaml/dist/stringify/stringifyCollection.js +0 -145
  225. package/node_modules/yaml/dist/stringify/stringifyComment.d.ts +0 -10
  226. package/node_modules/yaml/dist/stringify/stringifyComment.js +0 -24
  227. package/node_modules/yaml/dist/stringify/stringifyDocument.d.ts +0 -4
  228. package/node_modules/yaml/dist/stringify/stringifyDocument.js +0 -87
  229. package/node_modules/yaml/dist/stringify/stringifyNumber.d.ts +0 -2
  230. package/node_modules/yaml/dist/stringify/stringifyNumber.js +0 -26
  231. package/node_modules/yaml/dist/stringify/stringifyPair.d.ts +0 -3
  232. package/node_modules/yaml/dist/stringify/stringifyPair.js +0 -152
  233. package/node_modules/yaml/dist/stringify/stringifyString.d.ts +0 -9
  234. package/node_modules/yaml/dist/stringify/stringifyString.js +0 -338
  235. package/node_modules/yaml/dist/test-events.d.ts +0 -4
  236. package/node_modules/yaml/dist/test-events.js +0 -134
  237. package/node_modules/yaml/dist/util.d.ts +0 -16
  238. package/node_modules/yaml/dist/util.js +0 -28
  239. package/node_modules/yaml/dist/visit.d.ts +0 -102
  240. package/node_modules/yaml/dist/visit.js +0 -236
  241. package/node_modules/yaml/package.json +0 -97
  242. package/node_modules/yaml/util.js +0 -2
@@ -1,28 +0,0 @@
1
- 'use strict';
2
-
3
- function emptyScalarPosition(offset, before, pos) {
4
- if (before) {
5
- pos ?? (pos = before.length);
6
- for (let i = pos - 1; i >= 0; --i) {
7
- let st = before[i];
8
- switch (st.type) {
9
- case 'space':
10
- case 'comment':
11
- case 'newline':
12
- offset -= st.source.length;
13
- continue;
14
- }
15
- // Technically, an empty scalar is immediately after the last non-empty
16
- // node, but it's more useful to place it after any whitespace.
17
- st = before[++i];
18
- while (st?.type === 'space') {
19
- offset += st.source.length;
20
- st = before[++i];
21
- }
22
- break;
23
- }
24
- }
25
- return offset;
26
- }
27
-
28
- exports.emptyScalarPosition = emptyScalarPosition;
@@ -1,3 +0,0 @@
1
- import type { Token } from '../parse/cst';
2
- import type { ComposeErrorHandler } from './composer';
3
- export declare function flowIndentCheck(indent: number, fc: Token | null | undefined, onError: ComposeErrorHandler): void;
@@ -1,17 +0,0 @@
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;
@@ -1,4 +0,0 @@
1
- import type { ParsedNode } from '../nodes/Node';
2
- import type { Pair } from '../nodes/Pair';
3
- import type { ComposeContext } from './compose-node';
4
- export declare function mapIncludes(ctx: ComposeContext, items: Pair<ParsedNode>[], search: ParsedNode): boolean;
@@ -1,15 +0,0 @@
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;
@@ -1,141 +0,0 @@
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
- }
@@ -1,337 +0,0 @@
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;
@@ -1,24 +0,0 @@
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
- };
@@ -1,76 +0,0 @@
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;
@@ -1,9 +0,0 @@
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;