step-node-agent 3.25.4 → 3.26.0
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/AgentConf.yaml +13 -0
- package/api/controllers/controller.js +4 -0
- package/api/routes/routes.js +1 -0
- package/node_modules/aws4/aws4.js +1 -1
- package/node_modules/aws4/package.json +2 -2
- package/node_modules/body-parser/HISTORY.md +7 -0
- package/node_modules/body-parser/README.md +11 -0
- package/node_modules/body-parser/lib/types/urlencoded.js +30 -7
- package/node_modules/body-parser/package.json +2 -2
- package/node_modules/encodeurl/README.md +19 -38
- package/node_modules/encodeurl/index.js +1 -1
- package/node_modules/encodeurl/package.json +7 -7
- package/node_modules/express/History.md +27 -0
- package/node_modules/express/Readme.md +100 -6
- package/node_modules/express/lib/response.js +11 -10
- package/node_modules/express/package.json +11 -11
- package/node_modules/finalhandler/HISTORY.md +15 -0
- package/node_modules/finalhandler/README.md +2 -2
- package/node_modules/finalhandler/index.js +7 -2
- package/node_modules/finalhandler/package.json +8 -7
- package/node_modules/get-fqdn/LICENSE +21 -0
- package/node_modules/get-fqdn/README.md +83 -0
- package/node_modules/get-fqdn/index.js +17 -0
- package/node_modules/get-fqdn/package.json +73 -0
- package/node_modules/is-core-module/CHANGELOG.md +10 -0
- package/node_modules/is-core-module/core.json +2 -2
- package/node_modules/is-core-module/package.json +4 -4
- package/node_modules/is-core-module/test/index.js +17 -1
- package/node_modules/merge-descriptors/README.md +4 -3
- package/node_modules/merge-descriptors/index.js +3 -3
- package/node_modules/merge-descriptors/package.json +14 -7
- package/node_modules/path-to-regexp/index.js +57 -40
- package/node_modules/path-to-regexp/package.json +2 -2
- package/node_modules/qs/.editorconfig +3 -0
- package/node_modules/qs/.eslintrc +2 -2
- package/node_modules/qs/CHANGELOG.md +59 -5
- package/node_modules/qs/README.md +133 -49
- package/node_modules/qs/dist/qs.js +56 -2020
- package/node_modules/qs/lib/parse.js +46 -13
- package/node_modules/qs/lib/stringify.js +53 -28
- package/node_modules/qs/lib/utils.js +47 -34
- package/node_modules/qs/package.json +26 -12
- package/node_modules/qs/test/empty-keys-cases.js +267 -0
- package/node_modules/qs/test/parse.js +347 -32
- package/node_modules/qs/test/stringify.js +436 -47
- package/node_modules/send/HISTORY.md +5 -0
- package/node_modules/send/index.js +1 -2
- package/node_modules/send/node_modules/encodeurl/LICENSE +22 -0
- package/node_modules/send/node_modules/encodeurl/README.md +128 -0
- package/node_modules/send/node_modules/encodeurl/index.js +60 -0
- package/node_modules/send/node_modules/encodeurl/package.json +40 -0
- package/node_modules/send/package.json +1 -1
- package/node_modules/serve-static/HISTORY.md +16 -0
- package/node_modules/serve-static/index.js +1 -2
- package/node_modules/serve-static/package.json +3 -3
- package/node_modules/yaml/LICENSE +13 -0
- package/node_modules/yaml/README.md +155 -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 +42 -0
- package/node_modules/yaml/browser/dist/compose/compose-node.js +92 -0
- package/node_modules/yaml/browser/dist/compose/compose-scalar.js +80 -0
- package/node_modules/yaml/browser/dist/compose/composer.js +217 -0
- package/node_modules/yaml/browser/dist/compose/resolve-block-map.js +113 -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 +47 -0
- package/node_modules/yaml/browser/dist/compose/resolve-end.js +37 -0
- package/node_modules/yaml/browser/dist/compose/resolve-flow-collection.js +203 -0
- package/node_modules/yaml/browser/dist/compose/resolve-flow-scalar.js +223 -0
- package/node_modules/yaml/browser/dist/compose/resolve-props.js +148 -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 +27 -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 +17 -0
- package/node_modules/yaml/browser/dist/doc/Document.js +334 -0
- package/node_modules/yaml/browser/dist/doc/anchors.js +72 -0
- package/node_modules/yaml/browser/dist/doc/applyReviver.js +55 -0
- package/node_modules/yaml/browser/dist/doc/createNode.js +89 -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 +14 -0
- package/node_modules/yaml/browser/dist/nodes/Alias.js +101 -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 +104 -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 +954 -0
- package/node_modules/yaml/browser/dist/public-api.js +99 -0
- package/node_modules/yaml/browser/dist/schema/Schema.js +38 -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 +83 -0
- package/node_modules/yaml/browser/dist/schema/yaml-1.1/binary.js +66 -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/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 +37 -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 +124 -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 +328 -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 +199 -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 +44 -0
- package/node_modules/yaml/dist/compose/compose-node.d.ts +28 -0
- package/node_modules/yaml/dist/compose/compose-node.js +95 -0
- package/node_modules/yaml/dist/compose/compose-scalar.d.ts +5 -0
- package/node_modules/yaml/dist/compose/compose-scalar.js +82 -0
- package/node_modules/yaml/dist/compose/composer.d.ts +62 -0
- package/node_modules/yaml/dist/compose/composer.js +221 -0
- package/node_modules/yaml/dist/compose/resolve-block-map.d.ts +6 -0
- package/node_modules/yaml/dist/compose/resolve-block-map.js +115 -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 +49 -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 +205 -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 +150 -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 +29 -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 +19 -0
- package/node_modules/yaml/dist/doc/Document.d.ts +141 -0
- package/node_modules/yaml/dist/doc/Document.js +336 -0
- package/node_modules/yaml/dist/doc/anchors.d.ts +24 -0
- package/node_modules/yaml/dist/doc/anchors.js +77 -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 +91 -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 +22 -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 +17 -0
- package/node_modules/yaml/dist/nodes/Alias.d.ts +28 -0
- package/node_modules/yaml/dist/nodes/Alias.js +103 -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 +47 -0
- package/node_modules/yaml/dist/nodes/Node.js +40 -0
- package/node_modules/yaml/dist/nodes/Pair.d.ts +21 -0
- package/node_modules/yaml/dist/nodes/Pair.js +39 -0
- package/node_modules/yaml/dist/nodes/Scalar.d.ts +42 -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 +106 -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 +27 -0
- package/node_modules/yaml/dist/nodes/toJS.js +39 -0
- package/node_modules/yaml/dist/options.d.ts +338 -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 +108 -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 +958 -0
- package/node_modules/yaml/dist/public-api.d.ts +43 -0
- package/node_modules/yaml/dist/public-api.js +104 -0
- package/node_modules/yaml/dist/schema/Schema.d.ts +18 -0
- package/node_modules/yaml/dist/schema/Schema.js +40 -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 +40 -0
- package/node_modules/yaml/dist/schema/tags.js +86 -0
- package/node_modules/yaml/dist/schema/types.d.ts +90 -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 +68 -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/omap.d.ts +28 -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 +39 -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 +127 -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 +330 -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 +12 -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 +96 -0
- package/node_modules/yaml/util.js +2 -0
- package/package.json +7 -3
- package/server.js +50 -23
- package/node_modules/path-to-regexp/History.md +0 -36
- /package/node_modules/{encodeurl → send/node_modules/encodeurl}/HISTORY.md +0 -0
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var identity = require('../nodes/identity.js');
|
|
4
|
+
var stringify = require('./stringify.js');
|
|
5
|
+
var stringifyComment = require('./stringifyComment.js');
|
|
6
|
+
|
|
7
|
+
function stringifyCollection(collection, ctx, options) {
|
|
8
|
+
const flow = ctx.inFlow ?? collection.flow;
|
|
9
|
+
const stringify = flow ? stringifyFlowCollection : stringifyBlockCollection;
|
|
10
|
+
return stringify(collection, ctx, options);
|
|
11
|
+
}
|
|
12
|
+
function stringifyBlockCollection({ comment, items }, ctx, { blockItemPrefix, flowChars, itemIndent, onChompKeep, onComment }) {
|
|
13
|
+
const { indent, options: { commentString } } = ctx;
|
|
14
|
+
const itemCtx = Object.assign({}, ctx, { indent: itemIndent, type: null });
|
|
15
|
+
let chompKeep = false; // flag for the preceding node's status
|
|
16
|
+
const lines = [];
|
|
17
|
+
for (let i = 0; i < items.length; ++i) {
|
|
18
|
+
const item = items[i];
|
|
19
|
+
let comment = null;
|
|
20
|
+
if (identity.isNode(item)) {
|
|
21
|
+
if (!chompKeep && item.spaceBefore)
|
|
22
|
+
lines.push('');
|
|
23
|
+
addCommentBefore(ctx, lines, item.commentBefore, chompKeep);
|
|
24
|
+
if (item.comment)
|
|
25
|
+
comment = item.comment;
|
|
26
|
+
}
|
|
27
|
+
else if (identity.isPair(item)) {
|
|
28
|
+
const ik = identity.isNode(item.key) ? item.key : null;
|
|
29
|
+
if (ik) {
|
|
30
|
+
if (!chompKeep && ik.spaceBefore)
|
|
31
|
+
lines.push('');
|
|
32
|
+
addCommentBefore(ctx, lines, ik.commentBefore, chompKeep);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
chompKeep = false;
|
|
36
|
+
let str = stringify.stringify(item, itemCtx, () => (comment = null), () => (chompKeep = true));
|
|
37
|
+
if (comment)
|
|
38
|
+
str += stringifyComment.lineComment(str, itemIndent, commentString(comment));
|
|
39
|
+
if (chompKeep && comment)
|
|
40
|
+
chompKeep = false;
|
|
41
|
+
lines.push(blockItemPrefix + str);
|
|
42
|
+
}
|
|
43
|
+
let str;
|
|
44
|
+
if (lines.length === 0) {
|
|
45
|
+
str = flowChars.start + flowChars.end;
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
str = lines[0];
|
|
49
|
+
for (let i = 1; i < lines.length; ++i) {
|
|
50
|
+
const line = lines[i];
|
|
51
|
+
str += line ? `\n${indent}${line}` : '\n';
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if (comment) {
|
|
55
|
+
str += '\n' + stringifyComment.indentComment(commentString(comment), indent);
|
|
56
|
+
if (onComment)
|
|
57
|
+
onComment();
|
|
58
|
+
}
|
|
59
|
+
else if (chompKeep && onChompKeep)
|
|
60
|
+
onChompKeep();
|
|
61
|
+
return str;
|
|
62
|
+
}
|
|
63
|
+
function stringifyFlowCollection({ items }, ctx, { flowChars, itemIndent }) {
|
|
64
|
+
const { indent, indentStep, flowCollectionPadding: fcPadding, options: { commentString } } = ctx;
|
|
65
|
+
itemIndent += indentStep;
|
|
66
|
+
const itemCtx = Object.assign({}, ctx, {
|
|
67
|
+
indent: itemIndent,
|
|
68
|
+
inFlow: true,
|
|
69
|
+
type: null
|
|
70
|
+
});
|
|
71
|
+
let reqNewline = false;
|
|
72
|
+
let linesAtValue = 0;
|
|
73
|
+
const lines = [];
|
|
74
|
+
for (let i = 0; i < items.length; ++i) {
|
|
75
|
+
const item = items[i];
|
|
76
|
+
let comment = null;
|
|
77
|
+
if (identity.isNode(item)) {
|
|
78
|
+
if (item.spaceBefore)
|
|
79
|
+
lines.push('');
|
|
80
|
+
addCommentBefore(ctx, lines, item.commentBefore, false);
|
|
81
|
+
if (item.comment)
|
|
82
|
+
comment = item.comment;
|
|
83
|
+
}
|
|
84
|
+
else if (identity.isPair(item)) {
|
|
85
|
+
const ik = identity.isNode(item.key) ? item.key : null;
|
|
86
|
+
if (ik) {
|
|
87
|
+
if (ik.spaceBefore)
|
|
88
|
+
lines.push('');
|
|
89
|
+
addCommentBefore(ctx, lines, ik.commentBefore, false);
|
|
90
|
+
if (ik.comment)
|
|
91
|
+
reqNewline = true;
|
|
92
|
+
}
|
|
93
|
+
const iv = identity.isNode(item.value) ? item.value : null;
|
|
94
|
+
if (iv) {
|
|
95
|
+
if (iv.comment)
|
|
96
|
+
comment = iv.comment;
|
|
97
|
+
if (iv.commentBefore)
|
|
98
|
+
reqNewline = true;
|
|
99
|
+
}
|
|
100
|
+
else if (item.value == null && ik?.comment) {
|
|
101
|
+
comment = ik.comment;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
if (comment)
|
|
105
|
+
reqNewline = true;
|
|
106
|
+
let str = stringify.stringify(item, itemCtx, () => (comment = null));
|
|
107
|
+
if (i < items.length - 1)
|
|
108
|
+
str += ',';
|
|
109
|
+
if (comment)
|
|
110
|
+
str += stringifyComment.lineComment(str, itemIndent, commentString(comment));
|
|
111
|
+
if (!reqNewline && (lines.length > linesAtValue || str.includes('\n')))
|
|
112
|
+
reqNewline = true;
|
|
113
|
+
lines.push(str);
|
|
114
|
+
linesAtValue = lines.length;
|
|
115
|
+
}
|
|
116
|
+
const { start, end } = flowChars;
|
|
117
|
+
if (lines.length === 0) {
|
|
118
|
+
return start + end;
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
if (!reqNewline) {
|
|
122
|
+
const len = lines.reduce((sum, line) => sum + line.length + 2, 2);
|
|
123
|
+
reqNewline = ctx.options.lineWidth > 0 && len > ctx.options.lineWidth;
|
|
124
|
+
}
|
|
125
|
+
if (reqNewline) {
|
|
126
|
+
let str = start;
|
|
127
|
+
for (const line of lines)
|
|
128
|
+
str += line ? `\n${indentStep}${indent}${line}` : '\n';
|
|
129
|
+
return `${str}\n${indent}${end}`;
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
return `${start}${fcPadding}${lines.join(' ')}${fcPadding}${end}`;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
function addCommentBefore({ indent, options: { commentString } }, lines, comment, chompKeep) {
|
|
137
|
+
if (comment && chompKeep)
|
|
138
|
+
comment = comment.replace(/^\n+/, '');
|
|
139
|
+
if (comment) {
|
|
140
|
+
const ic = stringifyComment.indentComment(commentString(comment), indent);
|
|
141
|
+
lines.push(ic.trimStart()); // Avoid double indent on first line
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
exports.stringifyCollection = stringifyCollection;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Stringifies a comment.
|
|
3
|
+
*
|
|
4
|
+
* Empty comment lines are left empty,
|
|
5
|
+
* lines consisting of a single space are replaced by `#`,
|
|
6
|
+
* and all other lines are prefixed with a `#`.
|
|
7
|
+
*/
|
|
8
|
+
export declare const stringifyComment: (str: string) => string;
|
|
9
|
+
export declare function indentComment(comment: string, indent: string): string;
|
|
10
|
+
export declare const lineComment: (str: string, indent: string, comment: string) => string;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Stringifies a comment.
|
|
5
|
+
*
|
|
6
|
+
* Empty comment lines are left empty,
|
|
7
|
+
* lines consisting of a single space are replaced by `#`,
|
|
8
|
+
* and all other lines are prefixed with a `#`.
|
|
9
|
+
*/
|
|
10
|
+
const stringifyComment = (str) => str.replace(/^(?!$)(?: $)?/gm, '#');
|
|
11
|
+
function indentComment(comment, indent) {
|
|
12
|
+
if (/^\n+$/.test(comment))
|
|
13
|
+
return comment.substring(1);
|
|
14
|
+
return indent ? comment.replace(/^(?! *$)/gm, indent) : comment;
|
|
15
|
+
}
|
|
16
|
+
const lineComment = (str, indent, comment) => str.endsWith('\n')
|
|
17
|
+
? indentComment(comment, indent)
|
|
18
|
+
: comment.includes('\n')
|
|
19
|
+
? '\n' + indentComment(comment, indent)
|
|
20
|
+
: (str.endsWith(' ') ? '' : ' ') + comment;
|
|
21
|
+
|
|
22
|
+
exports.indentComment = indentComment;
|
|
23
|
+
exports.lineComment = lineComment;
|
|
24
|
+
exports.stringifyComment = stringifyComment;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Document } from '../doc/Document.js';
|
|
2
|
+
import type { Node } from '../nodes/Node.js';
|
|
3
|
+
import type { ToStringOptions } from '../options.js';
|
|
4
|
+
export declare function stringifyDocument(doc: Readonly<Document<Node, boolean>>, options: ToStringOptions): string;
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var identity = require('../nodes/identity.js');
|
|
4
|
+
var stringify = require('./stringify.js');
|
|
5
|
+
var stringifyComment = require('./stringifyComment.js');
|
|
6
|
+
|
|
7
|
+
function stringifyDocument(doc, options) {
|
|
8
|
+
const lines = [];
|
|
9
|
+
let hasDirectives = options.directives === true;
|
|
10
|
+
if (options.directives !== false && doc.directives) {
|
|
11
|
+
const dir = doc.directives.toString(doc);
|
|
12
|
+
if (dir) {
|
|
13
|
+
lines.push(dir);
|
|
14
|
+
hasDirectives = true;
|
|
15
|
+
}
|
|
16
|
+
else if (doc.directives.docStart)
|
|
17
|
+
hasDirectives = true;
|
|
18
|
+
}
|
|
19
|
+
if (hasDirectives)
|
|
20
|
+
lines.push('---');
|
|
21
|
+
const ctx = stringify.createStringifyContext(doc, options);
|
|
22
|
+
const { commentString } = ctx.options;
|
|
23
|
+
if (doc.commentBefore) {
|
|
24
|
+
if (lines.length !== 1)
|
|
25
|
+
lines.unshift('');
|
|
26
|
+
const cs = commentString(doc.commentBefore);
|
|
27
|
+
lines.unshift(stringifyComment.indentComment(cs, ''));
|
|
28
|
+
}
|
|
29
|
+
let chompKeep = false;
|
|
30
|
+
let contentComment = null;
|
|
31
|
+
if (doc.contents) {
|
|
32
|
+
if (identity.isNode(doc.contents)) {
|
|
33
|
+
if (doc.contents.spaceBefore && hasDirectives)
|
|
34
|
+
lines.push('');
|
|
35
|
+
if (doc.contents.commentBefore) {
|
|
36
|
+
const cs = commentString(doc.contents.commentBefore);
|
|
37
|
+
lines.push(stringifyComment.indentComment(cs, ''));
|
|
38
|
+
}
|
|
39
|
+
// top-level block scalars need to be indented if followed by a comment
|
|
40
|
+
ctx.forceBlockIndent = !!doc.comment;
|
|
41
|
+
contentComment = doc.contents.comment;
|
|
42
|
+
}
|
|
43
|
+
const onChompKeep = contentComment ? undefined : () => (chompKeep = true);
|
|
44
|
+
let body = stringify.stringify(doc.contents, ctx, () => (contentComment = null), onChompKeep);
|
|
45
|
+
if (contentComment)
|
|
46
|
+
body += stringifyComment.lineComment(body, '', commentString(contentComment));
|
|
47
|
+
if ((body[0] === '|' || body[0] === '>') &&
|
|
48
|
+
lines[lines.length - 1] === '---') {
|
|
49
|
+
// Top-level block scalars with a preceding doc marker ought to use the
|
|
50
|
+
// same line for their header.
|
|
51
|
+
lines[lines.length - 1] = `--- ${body}`;
|
|
52
|
+
}
|
|
53
|
+
else
|
|
54
|
+
lines.push(body);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
lines.push(stringify.stringify(doc.contents, ctx));
|
|
58
|
+
}
|
|
59
|
+
if (doc.directives?.docEnd) {
|
|
60
|
+
if (doc.comment) {
|
|
61
|
+
const cs = commentString(doc.comment);
|
|
62
|
+
if (cs.includes('\n')) {
|
|
63
|
+
lines.push('...');
|
|
64
|
+
lines.push(stringifyComment.indentComment(cs, ''));
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
lines.push(`... ${cs}`);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
lines.push('...');
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
let dc = doc.comment;
|
|
76
|
+
if (dc && chompKeep)
|
|
77
|
+
dc = dc.replace(/^\n+/, '');
|
|
78
|
+
if (dc) {
|
|
79
|
+
if ((!chompKeep || contentComment) && lines[lines.length - 1] !== '')
|
|
80
|
+
lines.push('');
|
|
81
|
+
lines.push(stringifyComment.indentComment(commentString(dc), ''));
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return lines.join('\n') + '\n';
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
exports.stringifyDocument = stringifyDocument;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
function stringifyNumber({ format, minFractionDigits, tag, value }) {
|
|
4
|
+
if (typeof value === 'bigint')
|
|
5
|
+
return String(value);
|
|
6
|
+
const num = typeof value === 'number' ? value : Number(value);
|
|
7
|
+
if (!isFinite(num))
|
|
8
|
+
return isNaN(num) ? '.nan' : num < 0 ? '-.inf' : '.inf';
|
|
9
|
+
let n = JSON.stringify(value);
|
|
10
|
+
if (!format &&
|
|
11
|
+
minFractionDigits &&
|
|
12
|
+
(!tag || tag === 'tag:yaml.org,2002:float') &&
|
|
13
|
+
/^\d/.test(n)) {
|
|
14
|
+
let i = n.indexOf('.');
|
|
15
|
+
if (i < 0) {
|
|
16
|
+
i = n.length;
|
|
17
|
+
n += '.';
|
|
18
|
+
}
|
|
19
|
+
let d = minFractionDigits - (n.length - i - 1);
|
|
20
|
+
while (d-- > 0)
|
|
21
|
+
n += '0';
|
|
22
|
+
}
|
|
23
|
+
return n;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
exports.stringifyNumber = stringifyNumber;
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var identity = require('../nodes/identity.js');
|
|
4
|
+
var Scalar = require('../nodes/Scalar.js');
|
|
5
|
+
var stringify = require('./stringify.js');
|
|
6
|
+
var stringifyComment = require('./stringifyComment.js');
|
|
7
|
+
|
|
8
|
+
function stringifyPair({ key, value }, ctx, onComment, onChompKeep) {
|
|
9
|
+
const { allNullValues, doc, indent, indentStep, options: { commentString, indentSeq, simpleKeys } } = ctx;
|
|
10
|
+
let keyComment = (identity.isNode(key) && key.comment) || null;
|
|
11
|
+
if (simpleKeys) {
|
|
12
|
+
if (keyComment) {
|
|
13
|
+
throw new Error('With simple keys, key nodes cannot have comments');
|
|
14
|
+
}
|
|
15
|
+
if (identity.isCollection(key) || (!identity.isNode(key) && typeof key === 'object')) {
|
|
16
|
+
const msg = 'With simple keys, collection cannot be used as a key value';
|
|
17
|
+
throw new Error(msg);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
let explicitKey = !simpleKeys &&
|
|
21
|
+
(!key ||
|
|
22
|
+
(keyComment && value == null && !ctx.inFlow) ||
|
|
23
|
+
identity.isCollection(key) ||
|
|
24
|
+
(identity.isScalar(key)
|
|
25
|
+
? key.type === Scalar.Scalar.BLOCK_FOLDED || key.type === Scalar.Scalar.BLOCK_LITERAL
|
|
26
|
+
: typeof key === 'object'));
|
|
27
|
+
ctx = Object.assign({}, ctx, {
|
|
28
|
+
allNullValues: false,
|
|
29
|
+
implicitKey: !explicitKey && (simpleKeys || !allNullValues),
|
|
30
|
+
indent: indent + indentStep
|
|
31
|
+
});
|
|
32
|
+
let keyCommentDone = false;
|
|
33
|
+
let chompKeep = false;
|
|
34
|
+
let str = stringify.stringify(key, ctx, () => (keyCommentDone = true), () => (chompKeep = true));
|
|
35
|
+
if (!explicitKey && !ctx.inFlow && str.length > 1024) {
|
|
36
|
+
if (simpleKeys)
|
|
37
|
+
throw new Error('With simple keys, single line scalar must not span more than 1024 characters');
|
|
38
|
+
explicitKey = true;
|
|
39
|
+
}
|
|
40
|
+
if (ctx.inFlow) {
|
|
41
|
+
if (allNullValues || value == null) {
|
|
42
|
+
if (keyCommentDone && onComment)
|
|
43
|
+
onComment();
|
|
44
|
+
return str === '' ? '?' : explicitKey ? `? ${str}` : str;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
else if ((allNullValues && !simpleKeys) || (value == null && explicitKey)) {
|
|
48
|
+
str = `? ${str}`;
|
|
49
|
+
if (keyComment && !keyCommentDone) {
|
|
50
|
+
str += stringifyComment.lineComment(str, ctx.indent, commentString(keyComment));
|
|
51
|
+
}
|
|
52
|
+
else if (chompKeep && onChompKeep)
|
|
53
|
+
onChompKeep();
|
|
54
|
+
return str;
|
|
55
|
+
}
|
|
56
|
+
if (keyCommentDone)
|
|
57
|
+
keyComment = null;
|
|
58
|
+
if (explicitKey) {
|
|
59
|
+
if (keyComment)
|
|
60
|
+
str += stringifyComment.lineComment(str, ctx.indent, commentString(keyComment));
|
|
61
|
+
str = `? ${str}\n${indent}:`;
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
str = `${str}:`;
|
|
65
|
+
if (keyComment)
|
|
66
|
+
str += stringifyComment.lineComment(str, ctx.indent, commentString(keyComment));
|
|
67
|
+
}
|
|
68
|
+
let vsb, vcb, valueComment;
|
|
69
|
+
if (identity.isNode(value)) {
|
|
70
|
+
vsb = !!value.spaceBefore;
|
|
71
|
+
vcb = value.commentBefore;
|
|
72
|
+
valueComment = value.comment;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
vsb = false;
|
|
76
|
+
vcb = null;
|
|
77
|
+
valueComment = null;
|
|
78
|
+
if (value && typeof value === 'object')
|
|
79
|
+
value = doc.createNode(value);
|
|
80
|
+
}
|
|
81
|
+
ctx.implicitKey = false;
|
|
82
|
+
if (!explicitKey && !keyComment && identity.isScalar(value))
|
|
83
|
+
ctx.indentAtStart = str.length + 1;
|
|
84
|
+
chompKeep = false;
|
|
85
|
+
if (!indentSeq &&
|
|
86
|
+
indentStep.length >= 2 &&
|
|
87
|
+
!ctx.inFlow &&
|
|
88
|
+
!explicitKey &&
|
|
89
|
+
identity.isSeq(value) &&
|
|
90
|
+
!value.flow &&
|
|
91
|
+
!value.tag &&
|
|
92
|
+
!value.anchor) {
|
|
93
|
+
// If indentSeq === false, consider '- ' as part of indentation where possible
|
|
94
|
+
ctx.indent = ctx.indent.substring(2);
|
|
95
|
+
}
|
|
96
|
+
let valueCommentDone = false;
|
|
97
|
+
const valueStr = stringify.stringify(value, ctx, () => (valueCommentDone = true), () => (chompKeep = true));
|
|
98
|
+
let ws = ' ';
|
|
99
|
+
if (keyComment || vsb || vcb) {
|
|
100
|
+
ws = vsb ? '\n' : '';
|
|
101
|
+
if (vcb) {
|
|
102
|
+
const cs = commentString(vcb);
|
|
103
|
+
ws += `\n${stringifyComment.indentComment(cs, ctx.indent)}`;
|
|
104
|
+
}
|
|
105
|
+
if (valueStr === '' && !ctx.inFlow) {
|
|
106
|
+
if (ws === '\n')
|
|
107
|
+
ws = '\n\n';
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
ws += `\n${ctx.indent}`;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
else if (!explicitKey && identity.isCollection(value)) {
|
|
114
|
+
const vs0 = valueStr[0];
|
|
115
|
+
const nl0 = valueStr.indexOf('\n');
|
|
116
|
+
const hasNewline = nl0 !== -1;
|
|
117
|
+
const flow = ctx.inFlow ?? value.flow ?? value.items.length === 0;
|
|
118
|
+
if (hasNewline || !flow) {
|
|
119
|
+
let hasPropsLine = false;
|
|
120
|
+
if (hasNewline && (vs0 === '&' || vs0 === '!')) {
|
|
121
|
+
let sp0 = valueStr.indexOf(' ');
|
|
122
|
+
if (vs0 === '&' &&
|
|
123
|
+
sp0 !== -1 &&
|
|
124
|
+
sp0 < nl0 &&
|
|
125
|
+
valueStr[sp0 + 1] === '!') {
|
|
126
|
+
sp0 = valueStr.indexOf(' ', sp0 + 1);
|
|
127
|
+
}
|
|
128
|
+
if (sp0 === -1 || nl0 < sp0)
|
|
129
|
+
hasPropsLine = true;
|
|
130
|
+
}
|
|
131
|
+
if (!hasPropsLine)
|
|
132
|
+
ws = `\n${ctx.indent}`;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
else if (valueStr === '' || valueStr[0] === '\n') {
|
|
136
|
+
ws = '';
|
|
137
|
+
}
|
|
138
|
+
str += ws + valueStr;
|
|
139
|
+
if (ctx.inFlow) {
|
|
140
|
+
if (valueCommentDone && onComment)
|
|
141
|
+
onComment();
|
|
142
|
+
}
|
|
143
|
+
else if (valueComment && !valueCommentDone) {
|
|
144
|
+
str += stringifyComment.lineComment(str, ctx.indent, commentString(valueComment));
|
|
145
|
+
}
|
|
146
|
+
else if (chompKeep && onChompKeep) {
|
|
147
|
+
onChompKeep();
|
|
148
|
+
}
|
|
149
|
+
return str;
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
exports.stringifyPair = stringifyPair;
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Scalar } from '../nodes/Scalar.js';
|
|
2
|
+
import type { StringifyContext } from './stringify.js';
|
|
3
|
+
interface StringifyScalar {
|
|
4
|
+
value: string;
|
|
5
|
+
comment?: string | null;
|
|
6
|
+
type?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function stringifyString(item: Scalar | StringifyScalar, ctx: StringifyContext, onComment?: () => void, onChompKeep?: () => void): string;
|
|
9
|
+
export {};
|