"use strict"; exports.Anchors = void 0; var _Alias = require("./schema/Alias"); var _Map = require("./schema/Map"); var _Merge = require("./schema/Merge"); var _Scalar = require("./schema/Scalar"); var _Seq = require("./schema/Seq"); function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } class Anchors { static validAnchorNode(node) { return node instanceof _Scalar.Scalar || node instanceof _Seq.YAMLSeq || node instanceof _Map.YAMLMap; } constructor(prefix) { _defineProperty(this, "map", {}); this.prefix = prefix; } createAlias(node, name) { this.setAnchor(node, name); return new _Alias.Alias(node); } createMergePair(...sources) { const merge = new _Merge.Merge(); merge.value.items = sources.map(s => { if (s instanceof _Alias.Alias) { if (s.source instanceof _Map.YAMLMap) return s; } else if (s instanceof _Map.YAMLMap) { return this.createAlias(s); } throw new Error('Merge sources must be Map nodes or their Aliases'); }); return merge; } getName(node) { const { map } = this; return Object.keys(map).find(a => map[a] === node); } getNode(name) { return this.map[name]; } newName(prefix) { if (!prefix) prefix = this.prefix; const names = Object.keys(this.map); for (let i = 1; true; ++i) { const name = `${prefix}${i}`; if (!names.includes(name)) return name; } } // During parsing, map & aliases contain CST nodes resolveNodes() { const { map, _cstAliases } = this; Object.keys(map).forEach(a => { map[a] = map[a].resolved; }); _cstAliases.forEach(a => { a.source = a.source.resolved; }); delete this._cstAliases; } 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'); } const { map } = this; const prev = node && Object.keys(map).find(a => 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; } } exports.Anchors = Anchors;