| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002 | 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 refsfunction 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 };
 |