|
|
import { d as defaultTagPrefix, _ as _createForOfIteratorHelper, a as _typeof, b as _createClass, c as _classCallCheck, e as _defineProperty, Y as YAMLSyntaxError, T as Type, f as YAMLWarning, g as YAMLSemanticError, h as _slicedToArray, i as YAMLError, j as _inherits, k as _createSuper } from './PlainValue-b8036b75.js'; import { parse as parse$1 } from './parse-cst.js'; import { b as binaryOptions, a as boolOptions, i as intOptions, n as nullOptions, s as strOptions, N as Node, P as Pair, S as Scalar, c as stringifyString, A as Alias, Y as YAMLSeq, d as YAMLMap, M as Merge, C as Collection, r as resolveNode, e as isEmptyPath, t as toJSON, f as addComment } from './resolveSeq-492ab440.js'; import { S as Schema } from './Schema-e94716c8.js'; import { w as warn } from './warnings-df54cb69.js';
var defaultOptions = { anchorPrefix: 'a', customTags: null, indent: 2, indentSeq: true, keepCstNodes: false, keepNodeTypes: true, keepBlobsInJSON: true, mapAsMap: false, maxAliasCount: 100, prettyErrors: false, // TODO Set true in v2
simpleKeys: false, version: '1.2' }; var scalarOptions = { get binary() { return binaryOptions; },
set binary(opt) { Object.assign(binaryOptions, opt); },
get bool() { return boolOptions; },
set bool(opt) { Object.assign(boolOptions, opt); },
get int() { return intOptions; },
set int(opt) { Object.assign(intOptions, opt); },
get null() { return nullOptions; },
set null(opt) { Object.assign(nullOptions, opt); },
get str() { return strOptions; },
set str(opt) { Object.assign(strOptions, opt); }
}; var documentOptions = { '1.0': { schema: 'yaml-1.1', merge: true, tagPrefixes: [{ handle: '!', prefix: defaultTagPrefix }, { handle: '!!', prefix: 'tag:private.yaml.org,2002:' }] }, 1.1: { schema: 'yaml-1.1', merge: true, tagPrefixes: [{ handle: '!', prefix: '!' }, { handle: '!!', prefix: defaultTagPrefix }] }, 1.2: { schema: 'core', merge: false, tagPrefixes: [{ handle: '!', prefix: '!' }, { handle: '!!', prefix: defaultTagPrefix }] } };
function stringifyTag(doc, tag) { if ((doc.version || doc.options.version) === '1.0') { var priv = tag.match(/^tag:private\.yaml\.org,2002:([^:/]+)$/); if (priv) return '!' + priv[1]; var vocab = tag.match(/^tag:([a-zA-Z0-9-]+)\.yaml\.org,2002:(.*)/); return vocab ? "!".concat(vocab[1], "/").concat(vocab[2]) : "!".concat(tag.replace(/^tag:/, '')); }
var p = doc.tagPrefixes.find(function (p) { return tag.indexOf(p.prefix) === 0; });
if (!p) { var dtp = doc.getDefaults().tagPrefixes; p = dtp && dtp.find(function (p) { return tag.indexOf(p.prefix) === 0; }); }
if (!p) return tag[0] === '!' ? tag : "!<".concat(tag, ">"); var suffix = tag.substr(p.prefix.length).replace(/[!,[\]{}]/g, function (ch) { return { '!': '%21', ',': '%2C', '[': '%5B', ']': '%5D', '{': '%7B', '}': '%7D' }[ch]; }); return p.handle + suffix; }
function getTagObject(tags, item) { if (item instanceof Alias) return Alias;
if (item.tag) { var match = tags.filter(function (t) { return t.tag === item.tag; }); if (match.length > 0) return match.find(function (t) { return t.format === item.format; }) || match[0]; }
var tagObj, obj;
if (item instanceof Scalar) { obj = item.value; // TODO: deprecate/remove class check
var _match = tags.filter(function (t) { return t.identify && t.identify(obj) || t.class && obj instanceof t.class; });
tagObj = _match.find(function (t) { return t.format === item.format; }) || _match.find(function (t) { return !t.format; }); } else { obj = item; tagObj = tags.find(function (t) { return t.nodeClass && obj instanceof t.nodeClass; }); }
if (!tagObj) { var name = obj && obj.constructor ? obj.constructor.name : _typeof(obj); throw new Error("Tag not resolved for ".concat(name, " value")); }
return tagObj; } // needs to be called before value stringifier to allow for circular anchor refs
function stringifyProps(node, tagObj, _ref) { var anchors = _ref.anchors, doc = _ref.doc; var props = []; var anchor = doc.anchors.getName(node);
if (anchor) { anchors[anchor] = node; props.push("&".concat(anchor)); }
if (node.tag) { props.push(stringifyTag(doc, node.tag)); } else if (!tagObj.default) { props.push(stringifyTag(doc, tagObj.tag)); }
return props.join(' '); }
function stringify$1(item, ctx, onComment, onChompKeep) { var _ctx$doc = ctx.doc, anchors = _ctx$doc.anchors, schema = _ctx$doc.schema; var tagObj;
if (!(item instanceof Node)) { var createCtx = { aliasNodes: [], onTagObj: function onTagObj(o) { return tagObj = o; }, prevObjects: new Map() }; item = schema.createNode(item, true, null, createCtx);
var _iterator = _createForOfIteratorHelper(createCtx.aliasNodes), _step;
try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var alias = _step.value; alias.source = alias.source.node; var name = anchors.getName(alias.source);
if (!name) { name = anchors.newName(); anchors.map[name] = alias.source; } } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } }
if (item instanceof Pair) return item.toString(ctx, onComment, onChompKeep); if (!tagObj) tagObj = getTagObject(schema.tags, item); var props = stringifyProps(item, tagObj, ctx); if (props.length > 0) ctx.indentAtStart = (ctx.indentAtStart || 0) + props.length + 1; var str = typeof tagObj.stringify === 'function' ? tagObj.stringify(item, ctx, onComment, onChompKeep) : item instanceof Scalar ? stringifyString(item, ctx, onComment, onChompKeep) : item.toString(ctx, onComment, onChompKeep); if (!props) return str; return item instanceof Scalar || str[0] === '{' || str[0] === '[' ? "".concat(props, " ").concat(str) : "".concat(props, "\n").concat(ctx.indent).concat(str); }
var Anchors = /*#__PURE__*/function () { function Anchors(prefix) { _classCallCheck(this, Anchors);
_defineProperty(this, "map", Object.create(null));
this.prefix = prefix; }
_createClass(Anchors, [{ key: "createAlias", value: function createAlias(node, name) { this.setAnchor(node, name); return new Alias(node); } }, { key: "createMergePair", value: function createMergePair() { var _this = this;
var merge = new Merge();
for (var _len = arguments.length, sources = new Array(_len), _key = 0; _key < _len; _key++) { sources[_key] = arguments[_key]; }
merge.value.items = sources.map(function (s) { if (s instanceof Alias) { if (s.source instanceof YAMLMap) return s; } else if (s instanceof YAMLMap) { return _this.createAlias(s); }
throw new Error('Merge sources must be Map nodes or their Aliases'); }); return merge; } }, { key: "getName", value: function getName(node) { var map = this.map; return Object.keys(map).find(function (a) { return map[a] === node; }); } }, { key: "getNames", value: function getNames() { return Object.keys(this.map); } }, { key: "getNode", value: function getNode(name) { return this.map[name]; } }, { key: "newName", value: function newName(prefix) { if (!prefix) prefix = this.prefix; var names = Object.keys(this.map);
for (var i = 1; true; ++i) { var name = "".concat(prefix).concat(i); if (!names.includes(name)) return name; } } // During parsing, map & aliases contain CST nodes
}, { key: "resolveNodes", value: function resolveNodes() { var map = this.map, _cstAliases = this._cstAliases; Object.keys(map).forEach(function (a) { map[a] = map[a].resolved; });
_cstAliases.forEach(function (a) { a.source = a.source.resolved; });
delete this._cstAliases; } }, { key: "setAnchor", value: function setAnchor(node, name) { if (node != null && !Anchors.validAnchorNode(node)) { throw new Error('Anchors may only be set for Scalar, Seq and Map nodes'); }
if (name && /[\x00-\x19\s,[\]{}]/.test(name)) { throw new Error('Anchor names must not contain whitespace or control characters'); }
var map = this.map; var prev = node && Object.keys(map).find(function (a) { return map[a] === node; });
if (prev) { if (!name) { return prev; } else if (prev !== name) { delete map[prev]; map[name] = node; } } else { if (!name) { if (!node) return null; name = this.newName(); }
map[name] = node; }
return name; } }], [{ key: "validAnchorNode", value: function validAnchorNode(node) { return node instanceof Scalar || node instanceof YAMLSeq || node instanceof YAMLMap; } }]);
return Anchors; }();
var visit = function visit(node, tags) { if (node && _typeof(node) === 'object') { var tag = node.tag;
if (node instanceof Collection) { if (tag) tags[tag] = true; node.items.forEach(function (n) { return visit(n, tags); }); } else if (node instanceof Pair) { visit(node.key, tags); visit(node.value, tags); } else if (node instanceof Scalar) { if (tag) tags[tag] = true; } }
return tags; };
var listTagNames = function listTagNames(node) { return Object.keys(visit(node, {})); };
function parseContents(doc, contents) { var comments = { before: [], after: [] }; var body = undefined; var spaceBefore = false;
var _iterator = _createForOfIteratorHelper(contents), _step;
try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var node = _step.value;
if (node.valueRange) { if (body !== undefined) { var msg = 'Document contains trailing content not separated by a ... or --- line'; doc.errors.push(new YAMLSyntaxError(node, msg)); break; }
var res = resolveNode(doc, node);
if (spaceBefore) { res.spaceBefore = true; spaceBefore = false; }
body = res; } else if (node.comment !== null) { var cc = body === undefined ? comments.before : comments.after; cc.push(node.comment); } else if (node.type === Type.BLANK_LINE) { spaceBefore = true;
if (body === undefined && comments.before.length > 0 && !doc.commentBefore) { // space-separated comments at start are parsed as document comments
doc.commentBefore = comments.before.join('\n'); comments.before = []; } } } } catch (err) { _iterator.e(err); } finally { _iterator.f(); }
doc.contents = body || null;
if (!body) { doc.comment = comments.before.concat(comments.after).join('\n') || null; } else { var cb = comments.before.join('\n');
if (cb) { var cbNode = body instanceof Collection && body.items[0] ? body.items[0] : body; cbNode.commentBefore = cbNode.commentBefore ? "".concat(cb, "\n").concat(cbNode.commentBefore) : cb; }
doc.comment = comments.after.join('\n') || null; } }
function resolveTagDirective(_ref, directive) { var tagPrefixes = _ref.tagPrefixes;
var _directive$parameters = _slicedToArray(directive.parameters, 2), handle = _directive$parameters[0], prefix = _directive$parameters[1];
if (!handle || !prefix) { var msg = 'Insufficient parameters given for %TAG directive'; throw new YAMLSemanticError(directive, msg); }
if (tagPrefixes.some(function (p) { return p.handle === handle; })) { var _msg = 'The %TAG directive must only be given at most once per handle in the same document.'; throw new YAMLSemanticError(directive, _msg); }
return { handle: handle, prefix: prefix }; }
function resolveYamlDirective(doc, directive) { var _directive$parameters2 = _slicedToArray(directive.parameters, 1), version = _directive$parameters2[0];
if (directive.name === 'YAML:1.0') version = '1.0';
if (!version) { var msg = 'Insufficient parameters given for %YAML directive'; throw new YAMLSemanticError(directive, msg); }
if (!documentOptions[version]) { var v0 = doc.version || doc.options.version;
var _msg2 = "Document will be parsed as YAML ".concat(v0, " rather than YAML ").concat(version);
doc.warnings.push(new YAMLWarning(directive, _msg2)); }
return version; }
function parseDirectives(doc, directives, prevDoc) { var directiveComments = []; var hasDirectives = false;
var _iterator = _createForOfIteratorHelper(directives), _step;
try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var directive = _step.value; var comment = directive.comment, name = directive.name;
switch (name) { case 'TAG': try { doc.tagPrefixes.push(resolveTagDirective(doc, directive)); } catch (error) { doc.errors.push(error); }
hasDirectives = true; break;
case 'YAML': case 'YAML:1.0': if (doc.version) { var msg = 'The %YAML directive must only be given at most once per document.'; doc.errors.push(new YAMLSemanticError(directive, msg)); }
try { doc.version = resolveYamlDirective(doc, directive); } catch (error) { doc.errors.push(error); }
hasDirectives = true; break;
default: if (name) { var _msg3 = "YAML only supports %TAG and %YAML directives, and not %".concat(name);
doc.warnings.push(new YAMLWarning(directive, _msg3)); }
}
if (comment) directiveComments.push(comment); } } catch (err) { _iterator.e(err); } finally { _iterator.f(); }
if (prevDoc && !hasDirectives && '1.1' === (doc.version || prevDoc.version || doc.options.version)) { var copyTagPrefix = function copyTagPrefix(_ref2) { var handle = _ref2.handle, prefix = _ref2.prefix; return { handle: handle, prefix: prefix }; };
doc.tagPrefixes = prevDoc.tagPrefixes.map(copyTagPrefix); doc.version = prevDoc.version; }
doc.commentBefore = directiveComments.join('\n') || null; }
function assertCollection(contents) { if (contents instanceof Collection) return true; throw new Error('Expected a YAML collection as document contents'); }
var Document$1 = /*#__PURE__*/function () { function Document(options) { _classCallCheck(this, Document);
this.anchors = new Anchors(options.anchorPrefix); this.commentBefore = null; this.comment = null; this.contents = null; this.directivesEndMarker = null; this.errors = []; this.options = options; this.schema = null; this.tagPrefixes = []; this.version = null; this.warnings = []; }
_createClass(Document, [{ key: "add", value: function add(value) { assertCollection(this.contents); return this.contents.add(value); } }, { key: "addIn", value: function addIn(path, value) { assertCollection(this.contents); this.contents.addIn(path, value); } }, { key: "delete", value: function _delete(key) { assertCollection(this.contents); return this.contents.delete(key); } }, { key: "deleteIn", value: function deleteIn(path) { if (isEmptyPath(path)) { if (this.contents == null) return false; this.contents = null; return true; }
assertCollection(this.contents); return this.contents.deleteIn(path); } }, { key: "getDefaults", value: function getDefaults() { return Document.defaults[this.version] || Document.defaults[this.options.version] || {}; } }, { key: "get", value: function get(key, keepScalar) { return this.contents instanceof Collection ? this.contents.get(key, keepScalar) : undefined; } }, { key: "getIn", value: function getIn(path, keepScalar) { if (isEmptyPath(path)) return !keepScalar && this.contents instanceof Scalar ? this.contents.value : this.contents; return this.contents instanceof Collection ? this.contents.getIn(path, keepScalar) : undefined; } }, { key: "has", value: function has(key) { return this.contents instanceof Collection ? this.contents.has(key) : false; } }, { key: "hasIn", value: function hasIn(path) { if (isEmptyPath(path)) return this.contents !== undefined; return this.contents instanceof Collection ? this.contents.hasIn(path) : false; } }, { key: "set", value: function set(key, value) { assertCollection(this.contents); this.contents.set(key, value); } }, { key: "setIn", value: function setIn(path, value) { if (isEmptyPath(path)) this.contents = value;else { assertCollection(this.contents); this.contents.setIn(path, value); } } }, { key: "setSchema", value: function setSchema(id, customTags) { if (!id && !customTags && this.schema) return; if (typeof id === 'number') id = id.toFixed(1);
if (id === '1.0' || id === '1.1' || id === '1.2') { if (this.version) this.version = id;else this.options.version = id; delete this.options.schema; } else if (id && typeof id === 'string') { this.options.schema = id; }
if (Array.isArray(customTags)) this.options.customTags = customTags; var opt = Object.assign({}, this.getDefaults(), this.options); this.schema = new Schema(opt); } }, { key: "parse", value: function parse(node, prevDoc) { if (this.options.keepCstNodes) this.cstNode = node; if (this.options.keepNodeTypes) this.type = 'DOCUMENT'; var _node$directives = node.directives, directives = _node$directives === void 0 ? [] : _node$directives, _node$contents = node.contents, contents = _node$contents === void 0 ? [] : _node$contents, directivesEndMarker = node.directivesEndMarker, error = node.error, valueRange = node.valueRange;
if (error) { if (!error.source) error.source = this; this.errors.push(error); }
parseDirectives(this, directives, prevDoc); if (directivesEndMarker) this.directivesEndMarker = true; this.range = valueRange ? [valueRange.start, valueRange.end] : null; this.setSchema(); this.anchors._cstAliases = []; parseContents(this, contents); this.anchors.resolveNodes();
if (this.options.prettyErrors) { var _iterator = _createForOfIteratorHelper(this.errors), _step;
try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var _error = _step.value; if (_error instanceof YAMLError) _error.makePretty(); } } catch (err) { _iterator.e(err); } finally { _iterator.f(); }
var _iterator2 = _createForOfIteratorHelper(this.warnings), _step2;
try { for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) { var warn = _step2.value; if (warn instanceof YAMLError) warn.makePretty(); } } catch (err) { _iterator2.e(err); } finally { _iterator2.f(); } }
return this; } }, { key: "listNonDefaultTags", value: function listNonDefaultTags() { return listTagNames(this.contents).filter(function (t) { return t.indexOf(Schema.defaultPrefix) !== 0; }); } }, { key: "setTagPrefix", value: function setTagPrefix(handle, prefix) { if (handle[0] !== '!' || handle[handle.length - 1] !== '!') throw new Error('Handle must start and end with !');
if (prefix) { var prev = this.tagPrefixes.find(function (p) { return p.handle === handle; }); if (prev) prev.prefix = prefix;else this.tagPrefixes.push({ handle: handle, prefix: prefix }); } else { this.tagPrefixes = this.tagPrefixes.filter(function (p) { return p.handle !== handle; }); } } }, { key: "toJSON", value: function toJSON$1(arg, onAnchor) { var _this = this;
var _this$options = this.options, keepBlobsInJSON = _this$options.keepBlobsInJSON, mapAsMap = _this$options.mapAsMap, maxAliasCount = _this$options.maxAliasCount; var keep = keepBlobsInJSON && (typeof arg !== 'string' || !(this.contents instanceof Scalar)); var ctx = { doc: this, indentStep: ' ', keep: keep, mapAsMap: keep && !!mapAsMap, maxAliasCount: maxAliasCount, stringify: stringify$1 // Requiring directly in Pair would create circular dependencies
}; var anchorNames = Object.keys(this.anchors.map); if (anchorNames.length > 0) ctx.anchors = new Map(anchorNames.map(function (name) { return [_this.anchors.map[name], { alias: [], aliasCount: 0, count: 1 }]; }));
var res = toJSON(this.contents, arg, ctx);
if (typeof onAnchor === 'function' && ctx.anchors) { var _iterator3 = _createForOfIteratorHelper(ctx.anchors.values()), _step3;
try { for (_iterator3.s(); !(_step3 = _iterator3.n()).done;) { var _step3$value = _step3.value, count = _step3$value.count, _res = _step3$value.res; onAnchor(_res, count); } } catch (err) { _iterator3.e(err); } finally { _iterator3.f(); } }
return res; } }, { key: "toString", value: function toString() { if (this.errors.length > 0) throw new Error('Document with errors cannot be stringified'); var indentSize = this.options.indent;
if (!Number.isInteger(indentSize) || indentSize <= 0) { var s = JSON.stringify(indentSize); throw new Error("\"indent\" option must be a positive integer, not ".concat(s)); }
this.setSchema(); var lines = []; var hasDirectives = false;
if (this.version) { var vd = '%YAML 1.2';
if (this.schema.name === 'yaml-1.1') { if (this.version === '1.0') vd = '%YAML:1.0';else if (this.version === '1.1') vd = '%YAML 1.1'; }
lines.push(vd); hasDirectives = true; }
var tagNames = this.listNonDefaultTags(); this.tagPrefixes.forEach(function (_ref) { var handle = _ref.handle, prefix = _ref.prefix;
if (tagNames.some(function (t) { return t.indexOf(prefix) === 0; })) { lines.push("%TAG ".concat(handle, " ").concat(prefix)); hasDirectives = true; } }); if (hasDirectives || this.directivesEndMarker) lines.push('---');
if (this.commentBefore) { if (hasDirectives || !this.directivesEndMarker) lines.unshift(''); lines.unshift(this.commentBefore.replace(/^/gm, '#')); }
var ctx = { anchors: Object.create(null), doc: this, indent: '', indentStep: ' '.repeat(indentSize), stringify: stringify$1 // Requiring directly in nodes would create circular dependencies
}; var chompKeep = false; var contentComment = null;
if (this.contents) { if (this.contents instanceof Node) { if (this.contents.spaceBefore && (hasDirectives || this.directivesEndMarker)) lines.push(''); if (this.contents.commentBefore) lines.push(this.contents.commentBefore.replace(/^/gm, '#')); // top-level block scalars need to be indented if followed by a comment
ctx.forceBlockIndent = !!this.comment; contentComment = this.contents.comment; }
var onChompKeep = contentComment ? null : function () { return chompKeep = true; }; var body = stringify$1(this.contents, ctx, function () { return contentComment = null; }, onChompKeep); lines.push(addComment(body, '', contentComment)); } else if (this.contents !== undefined) { lines.push(stringify$1(this.contents, ctx)); }
if (this.comment) { if ((!chompKeep || contentComment) && lines[lines.length - 1] !== '') lines.push(''); lines.push(this.comment.replace(/^/gm, '#')); }
return lines.join('\n') + '\n'; } }]);
return Document; }();
_defineProperty(Document$1, "defaults", documentOptions);
function createNode(value) { var wrapScalars = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; var tag = arguments.length > 2 ? arguments[2] : undefined;
if (tag === undefined && typeof wrapScalars === 'string') { tag = wrapScalars; wrapScalars = true; }
var options = Object.assign({}, Document$1.defaults[defaultOptions.version], defaultOptions); var schema = new Schema(options); return schema.createNode(value, wrapScalars, tag); }
var Document = /*#__PURE__*/function (_YAMLDocument) { _inherits(Document, _YAMLDocument);
var _super = _createSuper(Document);
function Document(options) { _classCallCheck(this, Document);
return _super.call(this, Object.assign({}, defaultOptions, options)); }
return Document; }(Document$1);
function parseAllDocuments(src, options) { var stream = []; var prev;
var _iterator = _createForOfIteratorHelper(parse$1(src)), _step;
try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var cstDoc = _step.value; var doc = new Document(options); doc.parse(cstDoc, prev); stream.push(doc); prev = doc; } } catch (err) { _iterator.e(err); } finally { _iterator.f(); }
return stream; }
function parseDocument(src, options) { var cst = parse$1(src); var doc = new Document(options).parse(cst[0]);
if (cst.length > 1) { var errMsg = 'Source contains multiple documents; please use YAML.parseAllDocuments()'; doc.errors.unshift(new YAMLSemanticError(cst[1], errMsg)); }
return doc; }
function parse(src, options) { var doc = parseDocument(src, options); doc.warnings.forEach(function (warning) { return warn(warning); }); if (doc.errors.length > 0) throw doc.errors[0]; return doc.toJSON(); }
function stringify(value, options) { var doc = new Document(options); doc.contents = value; return String(doc); }
var YAML = { createNode: createNode, defaultOptions: defaultOptions, Document: Document, parse: parse, parseAllDocuments: parseAllDocuments, parseCST: parse$1, parseDocument: parseDocument, scalarOptions: scalarOptions, stringify: stringify };
export { YAML };
|