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,336 +0,0 @@
1
- import { Scalar } from '../nodes/Scalar.js';
2
- import { foldFlowLines, FOLD_FLOW, FOLD_QUOTED, FOLD_BLOCK } from './foldFlowLines.js';
3
-
4
- const getFoldOptions = (ctx, isBlock) => ({
5
- indentAtStart: isBlock ? ctx.indent.length : ctx.indentAtStart,
6
- lineWidth: ctx.options.lineWidth,
7
- minContentWidth: ctx.options.minContentWidth
8
- });
9
- // Also checks for lines starting with %, as parsing the output as YAML 1.1 will
10
- // presume that's starting a new document.
11
- const containsDocumentMarker = (str) => /^(%|---|\.\.\.)/m.test(str);
12
- function lineLengthOverLimit(str, lineWidth, indentLength) {
13
- if (!lineWidth || lineWidth < 0)
14
- return false;
15
- const limit = lineWidth - indentLength;
16
- const strLen = str.length;
17
- if (strLen <= limit)
18
- return false;
19
- for (let i = 0, start = 0; i < strLen; ++i) {
20
- if (str[i] === '\n') {
21
- if (i - start > limit)
22
- return true;
23
- start = i + 1;
24
- if (strLen - start <= limit)
25
- return false;
26
- }
27
- }
28
- return true;
29
- }
30
- function doubleQuotedString(value, ctx) {
31
- const json = JSON.stringify(value);
32
- if (ctx.options.doubleQuotedAsJSON)
33
- return json;
34
- const { implicitKey } = ctx;
35
- const minMultiLineLength = ctx.options.doubleQuotedMinMultiLineLength;
36
- const indent = ctx.indent || (containsDocumentMarker(value) ? ' ' : '');
37
- let str = '';
38
- let start = 0;
39
- for (let i = 0, ch = json[i]; ch; ch = json[++i]) {
40
- if (ch === ' ' && json[i + 1] === '\\' && json[i + 2] === 'n') {
41
- // space before newline needs to be escaped to not be folded
42
- str += json.slice(start, i) + '\\ ';
43
- i += 1;
44
- start = i;
45
- ch = '\\';
46
- }
47
- if (ch === '\\')
48
- switch (json[i + 1]) {
49
- case 'u':
50
- {
51
- str += json.slice(start, i);
52
- const code = json.substr(i + 2, 4);
53
- switch (code) {
54
- case '0000':
55
- str += '\\0';
56
- break;
57
- case '0007':
58
- str += '\\a';
59
- break;
60
- case '000b':
61
- str += '\\v';
62
- break;
63
- case '001b':
64
- str += '\\e';
65
- break;
66
- case '0085':
67
- str += '\\N';
68
- break;
69
- case '00a0':
70
- str += '\\_';
71
- break;
72
- case '2028':
73
- str += '\\L';
74
- break;
75
- case '2029':
76
- str += '\\P';
77
- break;
78
- default:
79
- if (code.substr(0, 2) === '00')
80
- str += '\\x' + code.substr(2);
81
- else
82
- str += json.substr(i, 6);
83
- }
84
- i += 5;
85
- start = i + 1;
86
- }
87
- break;
88
- case 'n':
89
- if (implicitKey ||
90
- json[i + 2] === '"' ||
91
- json.length < minMultiLineLength) {
92
- i += 1;
93
- }
94
- else {
95
- // folding will eat first newline
96
- str += json.slice(start, i) + '\n\n';
97
- while (json[i + 2] === '\\' &&
98
- json[i + 3] === 'n' &&
99
- json[i + 4] !== '"') {
100
- str += '\n';
101
- i += 2;
102
- }
103
- str += indent;
104
- // space after newline needs to be escaped to not be folded
105
- if (json[i + 2] === ' ')
106
- str += '\\';
107
- i += 1;
108
- start = i + 1;
109
- }
110
- break;
111
- default:
112
- i += 1;
113
- }
114
- }
115
- str = start ? str + json.slice(start) : json;
116
- return implicitKey
117
- ? str
118
- : foldFlowLines(str, indent, FOLD_QUOTED, getFoldOptions(ctx, false));
119
- }
120
- function singleQuotedString(value, ctx) {
121
- if (ctx.options.singleQuote === false ||
122
- (ctx.implicitKey && value.includes('\n')) ||
123
- /[ \t]\n|\n[ \t]/.test(value) // single quoted string can't have leading or trailing whitespace around newline
124
- )
125
- return doubleQuotedString(value, ctx);
126
- const indent = ctx.indent || (containsDocumentMarker(value) ? ' ' : '');
127
- const res = "'" + value.replace(/'/g, "''").replace(/\n+/g, `$&\n${indent}`) + "'";
128
- return ctx.implicitKey
129
- ? res
130
- : foldFlowLines(res, indent, FOLD_FLOW, getFoldOptions(ctx, false));
131
- }
132
- function quotedString(value, ctx) {
133
- const { singleQuote } = ctx.options;
134
- let qs;
135
- if (singleQuote === false)
136
- qs = doubleQuotedString;
137
- else {
138
- const hasDouble = value.includes('"');
139
- const hasSingle = value.includes("'");
140
- if (hasDouble && !hasSingle)
141
- qs = singleQuotedString;
142
- else if (hasSingle && !hasDouble)
143
- qs = doubleQuotedString;
144
- else
145
- qs = singleQuote ? singleQuotedString : doubleQuotedString;
146
- }
147
- return qs(value, ctx);
148
- }
149
- // The negative lookbehind avoids a polynomial search,
150
- // but isn't supported yet on Safari: https://caniuse.com/js-regexp-lookbehind
151
- let blockEndNewlines;
152
- try {
153
- blockEndNewlines = new RegExp('(^|(?<!\n))\n+(?!\n|$)', 'g');
154
- }
155
- catch {
156
- blockEndNewlines = /\n+(?!\n|$)/g;
157
- }
158
- function blockString({ comment, type, value }, ctx, onComment, onChompKeep) {
159
- const { blockQuote, commentString, lineWidth } = ctx.options;
160
- // 1. Block can't end in whitespace unless the last line is non-empty.
161
- // 2. Strings consisting of only whitespace are best rendered explicitly.
162
- if (!blockQuote || /\n[\t ]+$/.test(value)) {
163
- return quotedString(value, ctx);
164
- }
165
- const indent = ctx.indent ||
166
- (ctx.forceBlockIndent || containsDocumentMarker(value) ? ' ' : '');
167
- const literal = blockQuote === 'literal'
168
- ? true
169
- : blockQuote === 'folded' || type === Scalar.BLOCK_FOLDED
170
- ? false
171
- : type === Scalar.BLOCK_LITERAL
172
- ? true
173
- : !lineLengthOverLimit(value, lineWidth, indent.length);
174
- if (!value)
175
- return literal ? '|\n' : '>\n';
176
- // determine chomping from whitespace at value end
177
- let chomp;
178
- let endStart;
179
- for (endStart = value.length; endStart > 0; --endStart) {
180
- const ch = value[endStart - 1];
181
- if (ch !== '\n' && ch !== '\t' && ch !== ' ')
182
- break;
183
- }
184
- let end = value.substring(endStart);
185
- const endNlPos = end.indexOf('\n');
186
- if (endNlPos === -1) {
187
- chomp = '-'; // strip
188
- }
189
- else if (value === end || endNlPos !== end.length - 1) {
190
- chomp = '+'; // keep
191
- if (onChompKeep)
192
- onChompKeep();
193
- }
194
- else {
195
- chomp = ''; // clip
196
- }
197
- if (end) {
198
- value = value.slice(0, -end.length);
199
- if (end[end.length - 1] === '\n')
200
- end = end.slice(0, -1);
201
- end = end.replace(blockEndNewlines, `$&${indent}`);
202
- }
203
- // determine indent indicator from whitespace at value start
204
- let startWithSpace = false;
205
- let startEnd;
206
- let startNlPos = -1;
207
- for (startEnd = 0; startEnd < value.length; ++startEnd) {
208
- const ch = value[startEnd];
209
- if (ch === ' ')
210
- startWithSpace = true;
211
- else if (ch === '\n')
212
- startNlPos = startEnd;
213
- else
214
- break;
215
- }
216
- let start = value.substring(0, startNlPos < startEnd ? startNlPos + 1 : startEnd);
217
- if (start) {
218
- value = value.substring(start.length);
219
- start = start.replace(/\n+/g, `$&${indent}`);
220
- }
221
- const indentSize = indent ? '2' : '1'; // root is at -1
222
- // Leading | or > is added later
223
- let header = (startWithSpace ? indentSize : '') + chomp;
224
- if (comment) {
225
- header += ' ' + commentString(comment.replace(/ ?[\r\n]+/g, ' '));
226
- if (onComment)
227
- onComment();
228
- }
229
- if (!literal) {
230
- const foldedValue = value
231
- .replace(/\n+/g, '\n$&')
232
- .replace(/(?:^|\n)([\t ].*)(?:([\n\t ]*)\n(?![\n\t ]))?/g, '$1$2') // more-indented lines aren't folded
233
- // ^ more-ind. ^ empty ^ capture next empty lines only at end of indent
234
- .replace(/\n+/g, `$&${indent}`);
235
- let literalFallback = false;
236
- const foldOptions = getFoldOptions(ctx, true);
237
- if (blockQuote !== 'folded' && type !== Scalar.BLOCK_FOLDED) {
238
- foldOptions.onOverflow = () => {
239
- literalFallback = true;
240
- };
241
- }
242
- const body = foldFlowLines(`${start}${foldedValue}${end}`, indent, FOLD_BLOCK, foldOptions);
243
- if (!literalFallback)
244
- return `>${header}\n${indent}${body}`;
245
- }
246
- value = value.replace(/\n+/g, `$&${indent}`);
247
- return `|${header}\n${indent}${start}${value}${end}`;
248
- }
249
- function plainString(item, ctx, onComment, onChompKeep) {
250
- const { type, value } = item;
251
- const { actualString, implicitKey, indent, indentStep, inFlow } = ctx;
252
- if ((implicitKey && value.includes('\n')) ||
253
- (inFlow && /[[\]{},]/.test(value))) {
254
- return quotedString(value, ctx);
255
- }
256
- if (/^[\n\t ,[\]{}#&*!|>'"%@`]|^[?-]$|^[?-][ \t]|[\n:][ \t]|[ \t]\n|[\n\t ]#|[\n\t :]$/.test(value)) {
257
- // not allowed:
258
- // - '-' or '?'
259
- // - start with an indicator character (except [?:-]) or /[?-] /
260
- // - '\n ', ': ' or ' \n' anywhere
261
- // - '#' not preceded by a non-space char
262
- // - end with ' ' or ':'
263
- return implicitKey || inFlow || !value.includes('\n')
264
- ? quotedString(value, ctx)
265
- : blockString(item, ctx, onComment, onChompKeep);
266
- }
267
- if (!implicitKey &&
268
- !inFlow &&
269
- type !== Scalar.PLAIN &&
270
- value.includes('\n')) {
271
- // Where allowed & type not set explicitly, prefer block style for multiline strings
272
- return blockString(item, ctx, onComment, onChompKeep);
273
- }
274
- if (containsDocumentMarker(value)) {
275
- if (indent === '') {
276
- ctx.forceBlockIndent = true;
277
- return blockString(item, ctx, onComment, onChompKeep);
278
- }
279
- else if (implicitKey && indent === indentStep) {
280
- return quotedString(value, ctx);
281
- }
282
- }
283
- const str = value.replace(/\n+/g, `$&\n${indent}`);
284
- // Verify that output will be parsed as a string, as e.g. plain numbers and
285
- // booleans get parsed with those types in v1.2 (e.g. '42', 'true' & '0.9e-3'),
286
- // and others in v1.1.
287
- if (actualString) {
288
- const test = (tag) => tag.default && tag.tag !== 'tag:yaml.org,2002:str' && tag.test?.test(str);
289
- const { compat, tags } = ctx.doc.schema;
290
- if (tags.some(test) || compat?.some(test))
291
- return quotedString(value, ctx);
292
- }
293
- return implicitKey
294
- ? str
295
- : foldFlowLines(str, indent, FOLD_FLOW, getFoldOptions(ctx, false));
296
- }
297
- function stringifyString(item, ctx, onComment, onChompKeep) {
298
- const { implicitKey, inFlow } = ctx;
299
- const ss = typeof item.value === 'string'
300
- ? item
301
- : Object.assign({}, item, { value: String(item.value) });
302
- let { type } = item;
303
- if (type !== Scalar.QUOTE_DOUBLE) {
304
- // force double quotes on control characters & unpaired surrogates
305
- if (/[\x00-\x08\x0b-\x1f\x7f-\x9f\u{D800}-\u{DFFF}]/u.test(ss.value))
306
- type = Scalar.QUOTE_DOUBLE;
307
- }
308
- const _stringify = (_type) => {
309
- switch (_type) {
310
- case Scalar.BLOCK_FOLDED:
311
- case Scalar.BLOCK_LITERAL:
312
- return implicitKey || inFlow
313
- ? quotedString(ss.value, ctx) // blocks are not valid inside flow containers
314
- : blockString(ss, ctx, onComment, onChompKeep);
315
- case Scalar.QUOTE_DOUBLE:
316
- return doubleQuotedString(ss.value, ctx);
317
- case Scalar.QUOTE_SINGLE:
318
- return singleQuotedString(ss.value, ctx);
319
- case Scalar.PLAIN:
320
- return plainString(ss, ctx, onComment, onChompKeep);
321
- default:
322
- return null;
323
- }
324
- };
325
- let res = _stringify(type);
326
- if (res === null) {
327
- const { defaultKeyType, defaultStringType } = ctx.options;
328
- const t = (implicitKey && defaultKeyType) || defaultStringType;
329
- res = _stringify(t);
330
- if (res === null)
331
- throw new Error(`Unsupported default string type ${t}`);
332
- }
333
- return res;
334
- }
335
-
336
- export { stringifyString };
@@ -1,11 +0,0 @@
1
- export { createNode } from './doc/createNode.js';
2
- export { debug, warn } from './log.js';
3
- export { createPair } from './nodes/Pair.js';
4
- export { toJS } from './nodes/toJS.js';
5
- export { findPair } from './nodes/YAMLMap.js';
6
- export { map as mapTag } from './schema/common/map.js';
7
- export { seq as seqTag } from './schema/common/seq.js';
8
- export { string as stringTag } from './schema/common/string.js';
9
- export { foldFlowLines } from './stringify/foldFlowLines.js';
10
- export { stringifyNumber } from './stringify/stringifyNumber.js';
11
- export { stringifyString } from './stringify/stringifyString.js';
@@ -1,233 +0,0 @@
1
- import { isDocument, isNode, isPair, isCollection, isMap, isSeq, isScalar, isAlias } from './nodes/identity.js';
2
-
3
- const BREAK = Symbol('break visit');
4
- const SKIP = Symbol('skip children');
5
- const REMOVE = Symbol('remove node');
6
- /**
7
- * Apply a visitor to an AST node or document.
8
- *
9
- * Walks through the tree (depth-first) starting from `node`, calling a
10
- * `visitor` function with three arguments:
11
- * - `key`: For sequence values and map `Pair`, the node's index in the
12
- * collection. Within a `Pair`, `'key'` or `'value'`, correspondingly.
13
- * `null` for the root node.
14
- * - `node`: The current node.
15
- * - `path`: The ancestry of the current node.
16
- *
17
- * The return value of the visitor may be used to control the traversal:
18
- * - `undefined` (default): Do nothing and continue
19
- * - `visit.SKIP`: Do not visit the children of this node, continue with next
20
- * sibling
21
- * - `visit.BREAK`: Terminate traversal completely
22
- * - `visit.REMOVE`: Remove the current node, then continue with the next one
23
- * - `Node`: Replace the current node, then continue by visiting it
24
- * - `number`: While iterating the items of a sequence or map, set the index
25
- * of the next step. This is useful especially if the index of the current
26
- * node has changed.
27
- *
28
- * If `visitor` is a single function, it will be called with all values
29
- * encountered in the tree, including e.g. `null` values. Alternatively,
30
- * separate visitor functions may be defined for each `Map`, `Pair`, `Seq`,
31
- * `Alias` and `Scalar` node. To define the same visitor function for more than
32
- * one node type, use the `Collection` (map and seq), `Value` (map, seq & scalar)
33
- * and `Node` (alias, map, seq & scalar) targets. Of all these, only the most
34
- * specific defined one will be used for each node.
35
- */
36
- function visit(node, visitor) {
37
- const visitor_ = initVisitor(visitor);
38
- if (isDocument(node)) {
39
- const cd = visit_(null, node.contents, visitor_, Object.freeze([node]));
40
- if (cd === REMOVE)
41
- node.contents = null;
42
- }
43
- else
44
- visit_(null, node, visitor_, Object.freeze([]));
45
- }
46
- // Without the `as symbol` casts, TS declares these in the `visit`
47
- // namespace using `var`, but then complains about that because
48
- // `unique symbol` must be `const`.
49
- /** Terminate visit traversal completely */
50
- visit.BREAK = BREAK;
51
- /** Do not visit the children of the current node */
52
- visit.SKIP = SKIP;
53
- /** Remove the current node */
54
- visit.REMOVE = REMOVE;
55
- function visit_(key, node, visitor, path) {
56
- const ctrl = callVisitor(key, node, visitor, path);
57
- if (isNode(ctrl) || isPair(ctrl)) {
58
- replaceNode(key, path, ctrl);
59
- return visit_(key, ctrl, visitor, path);
60
- }
61
- if (typeof ctrl !== 'symbol') {
62
- if (isCollection(node)) {
63
- path = Object.freeze(path.concat(node));
64
- for (let i = 0; i < node.items.length; ++i) {
65
- const ci = visit_(i, node.items[i], visitor, path);
66
- if (typeof ci === 'number')
67
- i = ci - 1;
68
- else if (ci === BREAK)
69
- return BREAK;
70
- else if (ci === REMOVE) {
71
- node.items.splice(i, 1);
72
- i -= 1;
73
- }
74
- }
75
- }
76
- else if (isPair(node)) {
77
- path = Object.freeze(path.concat(node));
78
- const ck = visit_('key', node.key, visitor, path);
79
- if (ck === BREAK)
80
- return BREAK;
81
- else if (ck === REMOVE)
82
- node.key = null;
83
- const cv = visit_('value', node.value, visitor, path);
84
- if (cv === BREAK)
85
- return BREAK;
86
- else if (cv === REMOVE)
87
- node.value = null;
88
- }
89
- }
90
- return ctrl;
91
- }
92
- /**
93
- * Apply an async visitor to an AST node or document.
94
- *
95
- * Walks through the tree (depth-first) starting from `node`, calling a
96
- * `visitor` function with three arguments:
97
- * - `key`: For sequence values and map `Pair`, the node's index in the
98
- * collection. Within a `Pair`, `'key'` or `'value'`, correspondingly.
99
- * `null` for the root node.
100
- * - `node`: The current node.
101
- * - `path`: The ancestry of the current node.
102
- *
103
- * The return value of the visitor may be used to control the traversal:
104
- * - `Promise`: Must resolve to one of the following values
105
- * - `undefined` (default): Do nothing and continue
106
- * - `visit.SKIP`: Do not visit the children of this node, continue with next
107
- * sibling
108
- * - `visit.BREAK`: Terminate traversal completely
109
- * - `visit.REMOVE`: Remove the current node, then continue with the next one
110
- * - `Node`: Replace the current node, then continue by visiting it
111
- * - `number`: While iterating the items of a sequence or map, set the index
112
- * of the next step. This is useful especially if the index of the current
113
- * node has changed.
114
- *
115
- * If `visitor` is a single function, it will be called with all values
116
- * encountered in the tree, including e.g. `null` values. Alternatively,
117
- * separate visitor functions may be defined for each `Map`, `Pair`, `Seq`,
118
- * `Alias` and `Scalar` node. To define the same visitor function for more than
119
- * one node type, use the `Collection` (map and seq), `Value` (map, seq & scalar)
120
- * and `Node` (alias, map, seq & scalar) targets. Of all these, only the most
121
- * specific defined one will be used for each node.
122
- */
123
- async function visitAsync(node, visitor) {
124
- const visitor_ = initVisitor(visitor);
125
- if (isDocument(node)) {
126
- const cd = await visitAsync_(null, node.contents, visitor_, Object.freeze([node]));
127
- if (cd === REMOVE)
128
- node.contents = null;
129
- }
130
- else
131
- await visitAsync_(null, node, visitor_, Object.freeze([]));
132
- }
133
- // Without the `as symbol` casts, TS declares these in the `visit`
134
- // namespace using `var`, but then complains about that because
135
- // `unique symbol` must be `const`.
136
- /** Terminate visit traversal completely */
137
- visitAsync.BREAK = BREAK;
138
- /** Do not visit the children of the current node */
139
- visitAsync.SKIP = SKIP;
140
- /** Remove the current node */
141
- visitAsync.REMOVE = REMOVE;
142
- async function visitAsync_(key, node, visitor, path) {
143
- const ctrl = await callVisitor(key, node, visitor, path);
144
- if (isNode(ctrl) || isPair(ctrl)) {
145
- replaceNode(key, path, ctrl);
146
- return visitAsync_(key, ctrl, visitor, path);
147
- }
148
- if (typeof ctrl !== 'symbol') {
149
- if (isCollection(node)) {
150
- path = Object.freeze(path.concat(node));
151
- for (let i = 0; i < node.items.length; ++i) {
152
- const ci = await visitAsync_(i, node.items[i], visitor, path);
153
- if (typeof ci === 'number')
154
- i = ci - 1;
155
- else if (ci === BREAK)
156
- return BREAK;
157
- else if (ci === REMOVE) {
158
- node.items.splice(i, 1);
159
- i -= 1;
160
- }
161
- }
162
- }
163
- else if (isPair(node)) {
164
- path = Object.freeze(path.concat(node));
165
- const ck = await visitAsync_('key', node.key, visitor, path);
166
- if (ck === BREAK)
167
- return BREAK;
168
- else if (ck === REMOVE)
169
- node.key = null;
170
- const cv = await visitAsync_('value', node.value, visitor, path);
171
- if (cv === BREAK)
172
- return BREAK;
173
- else if (cv === REMOVE)
174
- node.value = null;
175
- }
176
- }
177
- return ctrl;
178
- }
179
- function initVisitor(visitor) {
180
- if (typeof visitor === 'object' &&
181
- (visitor.Collection || visitor.Node || visitor.Value)) {
182
- return Object.assign({
183
- Alias: visitor.Node,
184
- Map: visitor.Node,
185
- Scalar: visitor.Node,
186
- Seq: visitor.Node
187
- }, visitor.Value && {
188
- Map: visitor.Value,
189
- Scalar: visitor.Value,
190
- Seq: visitor.Value
191
- }, visitor.Collection && {
192
- Map: visitor.Collection,
193
- Seq: visitor.Collection
194
- }, visitor);
195
- }
196
- return visitor;
197
- }
198
- function callVisitor(key, node, visitor, path) {
199
- if (typeof visitor === 'function')
200
- return visitor(key, node, path);
201
- if (isMap(node))
202
- return visitor.Map?.(key, node, path);
203
- if (isSeq(node))
204
- return visitor.Seq?.(key, node, path);
205
- if (isPair(node))
206
- return visitor.Pair?.(key, node, path);
207
- if (isScalar(node))
208
- return visitor.Scalar?.(key, node, path);
209
- if (isAlias(node))
210
- return visitor.Alias?.(key, node, path);
211
- return undefined;
212
- }
213
- function replaceNode(key, path, node) {
214
- const parent = path[path.length - 1];
215
- if (isCollection(parent)) {
216
- parent.items[key] = node;
217
- }
218
- else if (isPair(parent)) {
219
- if (key === 'key')
220
- parent.key = node;
221
- else
222
- parent.value = node;
223
- }
224
- else if (isDocument(parent)) {
225
- parent.contents = node;
226
- }
227
- else {
228
- const pt = isAlias(parent) ? 'alias' : 'scalar';
229
- throw new Error(`Cannot replace node with ${pt} parent`);
230
- }
231
- }
232
-
233
- export { visit, visitAsync };
@@ -1,5 +0,0 @@
1
- // `export * as default from ...` fails on Webpack v4
2
- // https://github.com/eemeli/yaml/issues/228
3
- import * as YAML from './dist/index.js'
4
- export default YAML
5
- export * from './dist/index.js'
@@ -1,3 +0,0 @@
1
- {
2
- "type": "module"
3
- }
@@ -1,8 +0,0 @@
1
- export declare const help = "yaml: A command-line YAML processor and inspector\n\nReads stdin and writes output to stdout and errors & warnings to stderr.\n\nUsage:\n yaml Process a YAML stream, outputting it as YAML\n yaml cst Parse the CST of a YAML stream\n yaml lex Parse the lexical tokens of a YAML stream\n yaml valid Validate a YAML stream, returning 0 on success\n\nOptions:\n --help, -h Show this message.\n --json, -j Output JSON.\n --indent 2 Output pretty-printed data, indented by the given number of spaces.\n --merge, -m Enable support for \"<<\" merge keys.\n\nAdditional options for bare \"yaml\" command:\n --doc, -d Output pretty-printed JS Document objects.\n --single, -1 Require the input to consist of a single YAML document.\n --strict, -s Stop on errors.\n --visit, -v Apply a visitor to each document (requires a path to import)\n --yaml 1.1 Set the YAML version. (default: 1.2)";
2
- export declare class UserError extends Error {
3
- static ARGS: number;
4
- static SINGLE: number;
5
- code: number;
6
- constructor(code: number, message: string);
7
- }
8
- export declare function cli(stdin: NodeJS.ReadableStream, done: (error?: Error) => void, argv?: string[]): Promise<void>;