You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							1003 lines
						
					
					
						
							27 KiB
						
					
					
				
			
		
		
	
	
							1003 lines
						
					
					
						
							27 KiB
						
					
					
				| 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 };
 |