Socket
Socket
Sign inDemoInstall

yaml

Package Overview
Dependencies
0
Maintainers
1
Versions
85
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

Comparing version 2.0.0-1 to 2.0.0-2

browser/dist/_virtual/_rollupPluginBabelHelpers.js

2055

browser/dist/index.js

@@ -1,2005 +0,20 @@

import { d as defaultTagPrefix, _ as _typeof, a as _createClass, b as _classCallCheck, c as _defineProperty, e as _slicedToArray, Y as YAMLSemanticError, T as Type, f as defaultTags, g as YAMLWarning, h as _createForOfIteratorHelper, i as YAMLSyntaxError, C as Char, j as YAMLReferenceError, k as YAMLError } from './errors-2634d01a.js';
import { P as PlainValue, D as Document$1, p as parse$1 } from './parse-d1ba890f.js';
export { p as parseCST } from './parse-d1ba890f.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, C as Collection, r as resolveScalar, e as createNode, f as isEmptyPath, g as collectionFromPath, t as toJS, h as addComment } from './stringifyNumber-d8af95b1.js';
import { M as Merge, a as MERGE_KEY, S as Schema } from './Schema-ea978338.js';
import { LogLevel } from './constants.js';
import { parse as parse$1 } from './cst/parse.js';
export { parse as parseCST } from './cst/parse.js';
import { Document } from './doc/Document.js';
export { Document } from './doc/Document.js';
import { YAMLSemanticError } from './errors.js';
import { warn } from './log.js';
export { defaultOptions, scalarOptions } from './options.js';
export { visit } from './ast/visit.js';
var defaultOptions = {
anchorPrefix: 'a',
customTags: null,
indent: 2,
indentSeq: true,
keepCstNodes: false,
keepNodeTypes: true,
keepUndefined: false,
mapAsMap: false,
maxAliasCount: 100,
prettyErrors: true,
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,
resolveKnownTags: true,
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;
var _match = tags.filter(function (t) {
return t.identify && t.identify(obj);
});
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(item, ctx, onComment, onChompKeep) {
var schema = ctx.doc.schema;
var tagObj;
if (!(item instanceof Node)) {
item = ctx.doc.createNode(item, {
onTagObj: function onTagObj(o) {
return tagObj = o;
},
wrapScalars: true
});
}
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 () {
_createClass(Anchors, null, [{
key: "validAnchorNode",
value: function validAnchorNode(node) {
return node instanceof Scalar || node instanceof YAMLSeq || node instanceof YAMLMap;
}
}]);
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;
}
}]);
return Anchors;
}();
/**
* Applies the JSON.parse reviver algorithm as defined in the ECMA-262 spec,
* in section 24.5.1.1 "Runtime Semantics: InternalizeJSONProperty" of the
* 2021 edition: https://tc39.es/ecma262/#sec-json.parse
*
* Includes extensions for handling Map and Set objects.
*/
function applyReviver(reviver, obj, key, val) {
if (val && _typeof(val) === 'object') {
if (Array.isArray(val)) {
for (var i = 0, len = val.length; i < len; ++i) {
var v0 = val[i];
var v1 = applyReviver(reviver, val, String(i), v0);
if (v1 === undefined) delete val[i];else if (v1 !== v0) val[i] = v1;
}
} else if (val instanceof Map) {
for (var _i = 0, _Array$from = Array.from(val.keys()); _i < _Array$from.length; _i++) {
var k = _Array$from[_i];
var _v = val.get(k);
var _v2 = applyReviver(reviver, val, k, _v);
if (_v2 === undefined) val.delete(k);else if (_v2 !== _v) val.set(k, _v2);
}
} else if (val instanceof Set) {
for (var _i2 = 0, _Array$from2 = Array.from(val); _i2 < _Array$from2.length; _i2++) {
var _v3 = _Array$from2[_i2];
var _v4 = applyReviver(reviver, val, _v3, _v3);
if (_v4 === undefined) val.delete(_v3);else if (_v4 !== _v3) {
val.delete(_v3);
val.add(_v4);
}
}
} else {
for (var _i3 = 0, _Object$entries = Object.entries(val); _i3 < _Object$entries.length; _i3++) {
var _Object$entries$_i = _slicedToArray(_Object$entries[_i3], 2),
_k = _Object$entries$_i[0],
_v5 = _Object$entries$_i[1];
var _v6 = applyReviver(reviver, val, _k, _v5);
if (_v6 === undefined) delete val[_k];else if (_v6 !== _v5) val[_k] = _v6;
}
}
}
return reviver.call(obj, key, val);
}
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 resolveTagHandle(doc, node) {
var _node$tag = node.tag,
handle = _node$tag.handle,
suffix = _node$tag.suffix;
var prefix = doc.tagPrefixes.find(function (p) {
return p.handle === handle;
});
if (!prefix) {
var dtp = doc.getDefaults().tagPrefixes;
if (dtp) prefix = dtp.find(function (p) {
return p.handle === handle;
});
if (!prefix) throw new YAMLSemanticError(node, "The ".concat(handle, " tag handle is non-default and was not declared."));
}
if (!suffix) throw new YAMLSemanticError(node, "The ".concat(handle, " tag has no suffix."));
if (handle === '!' && (doc.version || doc.options.version) === '1.0') {
if (suffix[0] === '^') {
doc.warnings.push(new YAMLWarning(node, 'YAML 1.0 ^ tag expansion is not supported'));
return suffix;
}
if (/[:/]/.test(suffix)) {
// word/foo -> tag:word.yaml.org,2002:foo
var vocab = suffix.match(/^([a-z0-9-]+)\/(.*)/i);
return vocab ? "tag:".concat(vocab[1], ".yaml.org,2002:").concat(vocab[2]) : "tag:".concat(suffix);
}
}
return prefix.prefix + decodeURIComponent(suffix);
}
function resolveTagName(doc, node) {
var tag = node.tag,
type = node.type;
var nonSpecific = false;
if (tag) {
var handle = tag.handle,
suffix = tag.suffix,
verbatim = tag.verbatim;
if (verbatim) {
if (verbatim !== '!' && verbatim !== '!!') return verbatim;
var msg = "Verbatim tags aren't resolved, so ".concat(verbatim, " is invalid.");
doc.errors.push(new YAMLSemanticError(node, msg));
} else if (handle === '!' && !suffix) {
nonSpecific = true;
} else {
try {
return resolveTagHandle(doc, node);
} catch (error) {
doc.errors.push(error);
}
}
}
switch (type) {
case Type.BLOCK_FOLDED:
case Type.BLOCK_LITERAL:
case Type.QUOTE_DOUBLE:
case Type.QUOTE_SINGLE:
return defaultTags.STR;
case Type.FLOW_MAP:
case Type.MAP:
return defaultTags.MAP;
case Type.FLOW_SEQ:
case Type.SEQ:
return defaultTags.SEQ;
case Type.PLAIN:
return nonSpecific ? defaultTags.STR : null;
default:
return null;
}
}
function checkFlowCollectionEnd(errors, cst) {
var char, name;
switch (cst.type) {
case Type.FLOW_MAP:
char = '}';
name = 'flow map';
break;
case Type.FLOW_SEQ:
char = ']';
name = 'flow sequence';
break;
default:
errors.push(new YAMLSemanticError(cst, 'Not a flow collection!?'));
return;
}
var lastItem;
for (var i = cst.items.length - 1; i >= 0; --i) {
var item = cst.items[i];
if (!item || item.type !== Type.COMMENT) {
lastItem = item;
break;
}
}
if (lastItem && lastItem.char !== char) {
var msg = "Expected ".concat(name, " to end with ").concat(char);
var err;
if (typeof lastItem.offset === 'number') {
err = new YAMLSemanticError(cst, msg);
err.offset = lastItem.offset + 1;
} else {
err = new YAMLSemanticError(lastItem, msg);
if (lastItem.range && lastItem.range.end) err.offset = lastItem.range.end - lastItem.range.start;
}
errors.push(err);
}
}
function checkFlowCommentSpace(errors, comment) {
var prev = comment.context.src[comment.range.start - 1];
if (prev !== '\n' && prev !== '\t' && prev !== ' ') {
var msg = 'Comments must be separated from other tokens by white space characters';
errors.push(new YAMLSemanticError(comment, msg));
}
}
function getLongKeyError(source, key) {
var sk = String(key);
var k = sk.substr(0, 8) + '...' + sk.substr(-8);
return new YAMLSemanticError(source, "The \"".concat(k, "\" key is too long"));
}
function resolveComments(collection, comments) {
var _iterator = _createForOfIteratorHelper(comments),
_step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
var _step$value = _step.value,
afterKey = _step$value.afterKey,
before = _step$value.before,
comment = _step$value.comment;
var item = collection.items[before];
if (!item) {
if (comment !== undefined) {
if (collection.comment) collection.comment += '\n' + comment;else collection.comment = comment;
}
} else {
if (afterKey && item.value) item = item.value;
if (comment === undefined) {
if (afterKey || !item.commentBefore) item.spaceBefore = true;
} else {
if (item.commentBefore) item.commentBefore += '\n' + comment;else item.commentBefore = comment;
}
}
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
}
function resolveMap(doc, cst) {
var _ref = cst.type === Type.FLOW_MAP ? resolveFlowMapItems(doc, cst) : resolveBlockMapItems(doc, cst),
comments = _ref.comments,
items = _ref.items;
var map = new YAMLMap(doc.schema);
map.items = items;
resolveComments(map, comments);
var hasCollectionKey = false;
for (var i = 0; i < items.length; ++i) {
var iKey = items[i].key;
if (iKey instanceof Collection) hasCollectionKey = true;
if (doc.schema.merge && iKey && iKey.value === MERGE_KEY) {
items[i] = new Merge(items[i]);
var sources = items[i].value.items;
var error = null;
sources.some(function (node) {
if (node instanceof Alias) {
// During parsing, alias sources are CST nodes; to account for
// circular references their resolved values can't be used here.
var type = node.source.type;
if (type === Type.MAP || type === Type.FLOW_MAP) return false;
return error = 'Merge nodes aliases can only point to maps';
}
return error = 'Merge nodes can only have Alias nodes as values';
});
if (error) doc.errors.push(new YAMLSemanticError(cst, error));
} else {
for (var j = i + 1; j < items.length; ++j) {
var jKey = items[j].key;
if (iKey === jKey || iKey && jKey && Object.prototype.hasOwnProperty.call(iKey, 'value') && iKey.value === jKey.value) {
var msg = "Map keys must be unique; \"".concat(iKey, "\" is repeated");
doc.errors.push(new YAMLSemanticError(cst, msg));
break;
}
}
}
}
if (hasCollectionKey && !doc.options.mapAsMap) {
var warn = 'Keys with collection values will be stringified as YAML due to JS Object restrictions. Use mapAsMap: true to avoid this.';
doc.warnings.push(new YAMLWarning(cst, warn));
}
cst.resolved = map;
return map;
}
var valueHasPairComment = function valueHasPairComment(_ref2) {
var _ref2$context = _ref2.context,
lineStart = _ref2$context.lineStart,
node = _ref2$context.node,
src = _ref2$context.src,
props = _ref2.props;
if (props.length === 0) return false;
var start = props[0].start;
if (node && start > node.valueRange.start) return false;
if (src[start] !== Char.COMMENT) return false;
for (var i = lineStart; i < start; ++i) {
if (src[i] === '\n') return false;
}
return true;
};
function resolvePairComment(item, pair) {
if (!valueHasPairComment(item)) return;
var comment = item.getPropValue(0, Char.COMMENT, true);
var found = false;
var cb = pair.value.commentBefore;
if (cb && cb.startsWith(comment)) {
pair.value.commentBefore = cb.substr(comment.length + 1);
found = true;
} else {
var cc = pair.value.comment;
if (!item.node && cc && cc.startsWith(comment)) {
pair.value.comment = cc.substr(comment.length + 1);
found = true;
}
}
if (found) pair.comment = comment;
}
function resolveBlockMapItems(doc, cst) {
var comments = [];
var items = [];
var key = undefined;
var keyStart = null;
for (var i = 0; i < cst.items.length; ++i) {
var item = cst.items[i];
switch (item.type) {
case Type.BLANK_LINE:
comments.push({
afterKey: !!key,
before: items.length
});
break;
case Type.COMMENT:
comments.push({
afterKey: !!key,
before: items.length,
comment: item.comment
});
break;
case Type.MAP_KEY:
if (key !== undefined) items.push(new Pair(key));
if (item.error) doc.errors.push(item.error);
key = resolveNode(doc, item.node);
keyStart = null;
break;
case Type.MAP_VALUE:
{
if (key === undefined) key = null;
if (item.error) doc.errors.push(item.error);
if (!item.context.atLineStart && item.node && item.node.type === Type.MAP && !item.node.context.atLineStart) {
var msg = 'Nested mappings are not allowed in compact mappings';
doc.errors.push(new YAMLSemanticError(item.node, msg));
}
var valueNode = item.node;
if (!valueNode && item.props.length > 0) {
// Comments on an empty mapping value need to be preserved, so we
// need to construct a minimal empty node here to use instead of the
// missing `item.node`. -- eemeli/yaml#19
valueNode = new PlainValue(Type.PLAIN, []);
valueNode.context = {
parent: item,
src: item.context.src
};
var pos = item.range.start + 1;
valueNode.range = {
start: pos,
end: pos
};
valueNode.valueRange = {
start: pos,
end: pos
};
if (typeof item.range.origStart === 'number') {
var origPos = item.range.origStart + 1;
valueNode.range.origStart = valueNode.range.origEnd = origPos;
valueNode.valueRange.origStart = valueNode.valueRange.origEnd = origPos;
}
}
var pair = new Pair(key, resolveNode(doc, valueNode));
resolvePairComment(item, pair);
items.push(pair);
if (key && typeof keyStart === 'number') {
if (item.range.start > keyStart + 1024) doc.errors.push(getLongKeyError(cst, key));
}
key = undefined;
keyStart = null;
}
break;
default:
if (key !== undefined) items.push(new Pair(key));
key = resolveNode(doc, item);
keyStart = item.range.start;
if (item.error) doc.errors.push(item.error);
next: for (var j = i + 1;; ++j) {
var nextItem = cst.items[j];
switch (nextItem && nextItem.type) {
case Type.BLANK_LINE:
case Type.COMMENT:
continue next;
case Type.MAP_VALUE:
break next;
default:
{
var _msg = 'Implicit map keys need to be followed by map values';
doc.errors.push(new YAMLSemanticError(item, _msg));
break next;
}
}
}
if (item.valueRangeContainsNewline) {
var _msg2 = 'Implicit map keys need to be on a single line';
doc.errors.push(new YAMLSemanticError(item, _msg2));
}
}
}
if (key !== undefined) items.push(new Pair(key));
return {
comments: comments,
items: items
};
}
function resolveFlowMapItems(doc, cst) {
var comments = [];
var items = [];
var key = undefined;
var explicitKey = false;
var next = '{';
for (var i = 0; i < cst.items.length; ++i) {
var item = cst.items[i];
if (typeof item.char === 'string') {
var char = item.char,
offset = item.offset;
if (char === '?' && key === undefined && !explicitKey) {
explicitKey = true;
next = ':';
continue;
}
if (char === ':') {
if (key === undefined) key = null;
if (next === ':') {
next = ',';
continue;
}
} else {
if (explicitKey) {
if (key === undefined && char !== ',') key = null;
explicitKey = false;
}
if (key !== undefined) {
items.push(new Pair(key));
key = undefined;
if (char === ',') {
next = ':';
continue;
}
}
}
if (char === '}') {
if (i === cst.items.length - 1) continue;
} else if (char === next) {
next = ':';
continue;
}
var msg = "Flow map contains an unexpected ".concat(char);
var err = new YAMLSyntaxError(cst, msg);
err.offset = offset;
doc.errors.push(err);
} else if (item.type === Type.BLANK_LINE) {
comments.push({
afterKey: !!key,
before: items.length
});
} else if (item.type === Type.COMMENT) {
checkFlowCommentSpace(doc.errors, item);
comments.push({
afterKey: !!key,
before: items.length,
comment: item.comment
});
} else if (key === undefined) {
if (next === ',') doc.errors.push(new YAMLSemanticError(item, 'Separator , missing in flow map'));
key = resolveNode(doc, item);
} else {
if (next !== ',') doc.errors.push(new YAMLSemanticError(item, 'Indicator : missing in flow map entry'));
items.push(new Pair(key, resolveNode(doc, item)));
key = undefined;
explicitKey = false;
}
}
checkFlowCollectionEnd(doc.errors, cst);
if (key !== undefined) items.push(new Pair(key));
return {
comments: comments,
items: items
};
}
function resolveSeq(doc, cst) {
var _ref = cst.type === Type.FLOW_SEQ ? resolveFlowSeqItems(doc, cst) : resolveBlockSeqItems(doc, cst),
comments = _ref.comments,
items = _ref.items;
var seq = new YAMLSeq(doc.schema);
seq.items = items;
resolveComments(seq, comments);
if (!doc.options.mapAsMap && items.some(function (it) {
return it instanceof Pair && it.key instanceof Collection;
})) {
var warn = 'Keys with collection values will be stringified as YAML due to JS Object restrictions. Use mapAsMap: true to avoid this.';
doc.warnings.push(new YAMLWarning(cst, warn));
}
cst.resolved = seq;
return seq;
}
function resolveBlockSeqItems(doc, cst) {
var comments = [];
var items = [];
for (var i = 0; i < cst.items.length; ++i) {
var item = cst.items[i];
switch (item.type) {
case Type.BLANK_LINE:
comments.push({
before: items.length
});
break;
case Type.COMMENT:
comments.push({
comment: item.comment,
before: items.length
});
break;
case Type.SEQ_ITEM:
if (item.error) doc.errors.push(item.error);
items.push(resolveNode(doc, item.node));
if (item.hasProps) {
var msg = 'Sequence items cannot have tags or anchors before the - indicator';
doc.errors.push(new YAMLSemanticError(item, msg));
}
break;
default:
if (item.error) doc.errors.push(item.error);
doc.errors.push(new YAMLSyntaxError(item, "Unexpected ".concat(item.type, " node in sequence")));
}
}
return {
comments: comments,
items: items
};
}
function resolveFlowSeqItems(doc, cst) {
var comments = [];
var items = [];
var explicitKey = false;
var key = undefined;
var keyStart = null;
var next = '[';
var prevItem = null;
for (var i = 0; i < cst.items.length; ++i) {
var item = cst.items[i];
if (typeof item.char === 'string') {
var char = item.char,
offset = item.offset;
if (char !== ':' && (explicitKey || key !== undefined)) {
if (explicitKey && key === undefined) key = next ? items.pop() : null;
items.push(new Pair(key));
explicitKey = false;
key = undefined;
keyStart = null;
}
if (char === next) {
next = null;
} else if (!next && char === '?') {
explicitKey = true;
} else if (next !== '[' && char === ':' && key === undefined) {
if (next === ',') {
key = items.pop();
if (key instanceof Pair) {
var msg = 'Chaining flow sequence pairs is invalid';
var err = new YAMLSemanticError(cst, msg);
err.offset = offset;
doc.errors.push(err);
}
if (!explicitKey && typeof keyStart === 'number') {
var keyEnd = item.range ? item.range.start : item.offset;
if (keyEnd > keyStart + 1024) doc.errors.push(getLongKeyError(cst, key));
var src = prevItem.context.src;
for (var _i = keyStart; _i < keyEnd; ++_i) {
if (src[_i] === '\n') {
var _msg = 'Implicit keys of flow sequence pairs need to be on a single line';
doc.errors.push(new YAMLSemanticError(prevItem, _msg));
break;
}
}
}
} else {
key = null;
}
keyStart = null;
explicitKey = false;
next = null;
} else if (next === '[' || char !== ']' || i < cst.items.length - 1) {
var _msg2 = "Flow sequence contains an unexpected ".concat(char);
var _err = new YAMLSyntaxError(cst, _msg2);
_err.offset = offset;
doc.errors.push(_err);
}
} else if (item.type === Type.BLANK_LINE) {
comments.push({
before: items.length
});
} else if (item.type === Type.COMMENT) {
checkFlowCommentSpace(doc.errors, item);
comments.push({
comment: item.comment,
before: items.length
});
} else {
if (next) {
var _msg3 = "Expected a ".concat(next, " in flow sequence");
doc.errors.push(new YAMLSemanticError(item, _msg3));
}
var value = resolveNode(doc, item);
if (key === undefined) {
items.push(value);
prevItem = item;
} else {
items.push(new Pair(key, value));
key = undefined;
}
keyStart = item.range.start;
next = ',';
}
}
checkFlowCollectionEnd(doc.errors, cst);
if (key !== undefined) items.push(new Pair(key));
return {
comments: comments,
items: items
};
}
function resolveByTagName(_ref, tagName, value, onError) {
var knownTags = _ref.knownTags,
tags = _ref.tags;
var matchWithTest = [];
var _iterator = _createForOfIteratorHelper(tags),
_step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
var tag = _step.value;
if (tag.tag === tagName) {
if (tag.test) {
if (typeof value === 'string') matchWithTest.push(tag);else onError("The tag ".concat(tagName, " cannot be applied to a collection"));
} else {
var _res = tag.resolve(value, onError);
return _res instanceof Collection ? _res : new Scalar(_res);
}
}
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
if (matchWithTest.length > 0) return resolveScalar(value, matchWithTest);
var kt = knownTags[tagName];
if (kt) {
tags.push(Object.assign({}, kt, {
default: false,
test: undefined
}));
var res = kt.resolve(value, onError);
return res instanceof Collection ? res : new Scalar(res);
}
return null;
}
function resolveTag(doc, node, tagName) {
var MAP = defaultTags.MAP,
SEQ = defaultTags.SEQ,
STR = defaultTags.STR;
var value, fallback;
var onError = function onError(message) {
return doc.errors.push(new YAMLSemanticError(node, message));
};
try {
switch (node.type) {
case Type.FLOW_MAP:
case Type.MAP:
value = resolveMap(doc, node);
fallback = MAP;
if (tagName === SEQ || tagName === STR) onError("The tag ".concat(tagName, " cannot be applied to a mapping"));
break;
case Type.FLOW_SEQ:
case Type.SEQ:
value = resolveSeq(doc, node);
fallback = SEQ;
if (tagName === MAP || tagName === STR) onError("The tag ".concat(tagName, " cannot be applied to a sequence"));
break;
default:
value = node.strValue || '';
if (typeof value !== 'string') {
value.errors.forEach(function (error) {
return doc.errors.push(error);
});
value = value.str;
}
if (tagName === MAP || tagName === SEQ) onError("The tag ".concat(tagName, " cannot be applied to a scalar"));
fallback = STR;
}
var res = resolveByTagName(doc.schema, tagName, value, onError);
if (res) {
if (tagName && node.tag) res.tag = tagName;
return res;
}
} catch (error) {
/* istanbul ignore if */
if (!error.source) error.source = node;
doc.errors.push(error);
return null;
}
try {
if (!fallback) throw new Error("The tag ".concat(tagName, " is unavailable"));
var msg = "The tag ".concat(tagName, " is unavailable, falling back to ").concat(fallback);
doc.warnings.push(new YAMLWarning(node, msg));
var _res2 = resolveByTagName(doc.schema, fallback, value, onError);
_res2.tag = tagName;
return _res2;
} catch (error) {
var refError = new YAMLReferenceError(node, error.message);
refError.stack = error.stack;
doc.errors.push(refError);
return null;
}
}
var isCollectionItem = function isCollectionItem(node) {
if (!node) return false;
var type = node.type;
return type === Type.MAP_KEY || type === Type.MAP_VALUE || type === Type.SEQ_ITEM;
};
function resolveNodeProps(errors, node) {
var comments = {
before: [],
after: []
};
var hasAnchor = false;
var hasTag = false;
var props = isCollectionItem(node.context.parent) ? node.context.parent.props.concat(node.props) : node.props;
var _iterator = _createForOfIteratorHelper(props),
_step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
var _step$value = _step.value,
start = _step$value.start,
end = _step$value.end;
switch (node.context.src[start]) {
case Char.COMMENT:
{
if (!node.commentHasRequiredWhitespace(start)) {
var msg = 'Comments must be separated from other tokens by white space characters';
errors.push(new YAMLSemanticError(node, msg));
}
var header = node.header,
valueRange = node.valueRange;
var cc = valueRange && (start > valueRange.start || header && start > header.start) ? comments.after : comments.before;
cc.push(node.context.src.slice(start + 1, end));
break;
}
// Actual anchor & tag resolution is handled by schema, here we just complain
case Char.ANCHOR:
if (hasAnchor) {
var _msg = 'A node can have at most one anchor';
errors.push(new YAMLSemanticError(node, _msg));
}
hasAnchor = true;
break;
case Char.TAG:
if (hasTag) {
var _msg2 = 'A node can have at most one tag';
errors.push(new YAMLSemanticError(node, _msg2));
}
hasTag = true;
break;
}
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
}
return {
comments: comments,
hasAnchor: hasAnchor,
hasTag: hasTag
};
}
function resolveNodeValue(doc, node) {
var anchors = doc.anchors,
errors = doc.errors,
schema = doc.schema;
if (node.type === Type.ALIAS) {
var name = node.rawValue;
var src = anchors.getNode(name);
if (!src) {
var msg = "Aliased anchor not found: ".concat(name);
errors.push(new YAMLReferenceError(node, msg));
return null;
} // Lazy resolution for circular references
var res = new Alias(src);
anchors._cstAliases.push(res);
return res;
}
var tagName = resolveTagName(doc, node);
if (tagName) return resolveTag(doc, node, tagName);
if (node.type !== Type.PLAIN) {
var _msg3 = "Failed to resolve ".concat(node.type, " node here");
errors.push(new YAMLSyntaxError(node, _msg3));
return null;
}
try {
var str = node.strValue || '';
if (typeof str !== 'string') {
str.errors.forEach(function (error) {
return doc.errors.push(error);
});
str = str.str;
}
return resolveScalar(str, schema.tags);
} catch (error) {
if (!error.source) error.source = node;
errors.push(error);
return null;
}
} // sets node.resolved on success
function resolveNode(doc, node) {
if (!node) return null;
if (node.error) doc.errors.push(node.error);
var _resolveNodeProps = resolveNodeProps(doc.errors, node),
comments = _resolveNodeProps.comments,
hasAnchor = _resolveNodeProps.hasAnchor,
hasTag = _resolveNodeProps.hasTag;
if (hasAnchor) {
var anchors = doc.anchors;
var name = node.anchor;
var prev = anchors.getNode(name); // At this point, aliases for any preceding node with the same anchor
// name have already been resolved, so it may safely be renamed.
if (prev) anchors.map[anchors.newName(name)] = prev; // During parsing, we need to store the CST node in anchors.map as
// anchors need to be available during resolution to allow for
// circular references.
anchors.map[name] = node;
}
if (node.type === Type.ALIAS && (hasAnchor || hasTag)) {
var msg = 'An alias node must not specify any properties';
doc.errors.push(new YAMLSemanticError(node, msg));
}
var res = resolveNodeValue(doc, node);
if (res) {
res.range = [node.range.start, node.range.end];
if (doc.options.keepCstNodes) res.cstNode = node;
if (doc.options.keepNodeTypes) res.type = node.type;
var cb = comments.before.join('\n');
if (cb) {
res.commentBefore = res.commentBefore ? "".concat(res.commentBefore, "\n").concat(cb) : cb;
}
var ca = comments.after.join('\n');
if (ca) res.comment = res.comment ? "".concat(res.comment, "\n").concat(ca) : ca;
}
return node.resolved = res;
}
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 = /*#__PURE__*/function () {
function Document(value, replacer, options) {
_classCallCheck(this, Document);
if (options === undefined && replacer && _typeof(replacer) === 'object' && !Array.isArray(replacer)) {
options = replacer;
replacer = undefined;
}
this.options = Object.assign({}, defaultOptions, options);
this.anchors = new Anchors(this.options.anchorPrefix);
this.commentBefore = null;
this.comment = null;
this.directivesEndMarker = null;
this.errors = [];
this.schema = null;
this.tagPrefixes = [];
this.version = null;
this.warnings = [];
if (value === undefined) {
// note that this.schema is left as null here
this.contents = null;
} else if (value instanceof Document$1) {
this.parse(value);
} else {
this.contents = this.createNode(value, {
replacer: replacer
});
}
}
_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: "createNode",
value: function createNode$1(value) {
var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
keepUndefined = _ref.keepUndefined,
onTagObj = _ref.onTagObj,
replacer = _ref.replacer,
tag = _ref.tag,
wrapScalars = _ref.wrapScalars;
this.setSchema();
if (typeof replacer === 'function') value = replacer.call({
'': value
}, '', value);else if (Array.isArray(replacer)) {
var keyToStr = function keyToStr(v) {
return typeof v === 'number' || v instanceof String || v instanceof Number;
};
var asStr = replacer.filter(keyToStr).map(String);
if (asStr.length > 0) replacer = replacer.concat(asStr);
}
if (typeof keepUndefined !== 'boolean') keepUndefined = !!this.options.keepUndefined;
var aliasNodes = [];
var ctx = {
keepUndefined: keepUndefined,
onAlias: function onAlias(source) {
var alias = new Alias(source);
aliasNodes.push(alias);
return alias;
},
onTagObj: onTagObj,
prevObjects: new Map(),
replacer: replacer,
schema: this.schema,
wrapScalars: wrapScalars !== false
};
var node = createNode(value, tag, ctx);
for (var _i = 0, _aliasNodes = aliasNodes; _i < _aliasNodes.length; _i++) {
var alias = _aliasNodes[_i];
// With circular references, the source node is only resolved after all of
// its child nodes are. This is why anchors are set only after all of the
// nodes have been created.
alias.source = alias.source.node;
var name = this.anchors.getName(alias.source);
if (!name) {
name = this.anchors.newName();
this.anchors.map[name] = alias.source;
}
}
return node;
}
}, {
key: "createPair",
value: function createPair(key, value) {
var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
var k = this.createNode(key, options);
var v = this.createNode(value, options);
return new Pair(k, v);
}
}, {
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) {
if (this.contents == null) {
this.setSchema();
this.contents = collectionFromPath(this.schema, [key], value);
} else {
assertCollection(this.contents);
this.contents.set(key, value);
}
}
}, {
key: "setIn",
value: function setIn(path, value) {
if (isEmptyPath(path)) this.contents = value;else if (this.contents == null) {
this.setSchema();
this.contents = collectionFromPath(this.schema, path, 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(defaultTagPrefix) !== 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: "toJS",
value: function toJS$1() {
var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
json = _ref2.json,
jsonArg = _ref2.jsonArg,
mapAsMap = _ref2.mapAsMap,
onAnchor = _ref2.onAnchor,
reviver = _ref2.reviver;
var anchorNodes = Object.values(this.anchors.map).map(function (node) {
return [node, {
alias: [],
aliasCount: 0,
count: 1
}];
});
var anchors = anchorNodes.length > 0 ? new Map(anchorNodes) : null;
var ctx = {
anchors: anchors,
doc: this,
indentStep: ' ',
keep: !json,
mapAsMap: typeof mapAsMap === 'boolean' ? mapAsMap : !!this.options.mapAsMap,
maxAliasCount: this.options.maxAliasCount,
stringify: stringify // Requiring directly in Pair would create circular dependencies
};
var res = toJS(this.contents, jsonArg || '', ctx);
if (typeof onAnchor === 'function' && anchors) {
var _iterator3 = _createForOfIteratorHelper(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 typeof reviver === 'function' ? applyReviver(reviver, {
'': res
}, '', res) : res;
}
}, {
key: "toJSON",
value: function toJSON(jsonArg, onAnchor) {
return this.toJS({
json: true,
jsonArg: jsonArg,
mapAsMap: false,
onAnchor: onAnchor
});
}
}, {
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 (_ref3) {
var handle = _ref3.handle,
prefix = _ref3.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 // 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(this.contents, ctx, function () {
return contentComment = null;
}, onChompKeep);
lines.push(addComment(body, '', contentComment));
} else {
lines.push(stringify(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, "defaults", documentOptions);
/* global console, process, YAML_SILENCE_WARNINGS */
function warn(warning, type) {
if (typeof YAML_SILENCE_WARNINGS !== 'undefined' && YAML_SILENCE_WARNINGS) return;
if (typeof process !== 'undefined') {
if (process.env.YAML_SILENCE_WARNINGS) return; // This will throw in Jest if `warning` is an Error instance due to
// https://github.com/facebook/jest/issues/2549
if (process.emitWarning) {
process.emitWarning(warning, type);
return;
}
} // eslint-disable-next-line no-console
console.warn(type ? "".concat(type, ": ").concat(warning) : warning);
}
function parseAllDocuments(src, options) {
var stream = [];
var prev;
const stream = [];
let prev;
var _iterator = _createForOfIteratorHelper(parse$1(src)),
_step;
try {
for (_iterator.s(); !(_step = _iterator.n()).done;) {
var cstDoc = _step.value;
var doc = new Document(undefined, null, options);
doc.parse(cstDoc, prev);
stream.push(doc);
prev = doc;
}
} catch (err) {
_iterator.e(err);
} finally {
_iterator.f();
for (const cstDoc of parse$1(src)) {
const doc = new Document(undefined, null, options);
doc.parse(cstDoc, prev);
stream.push(doc);
prev = doc;
}

@@ -2010,7 +25,7 @@

function parseDocument(src, options) {
var cst = parse$1(src);
var doc = new Document(cst[0], null, options);
const cst = parse$1(src);
const doc = new Document(cst[0], null, options);
if (cst.length > 1) {
var errMsg = 'Source contains multiple documents; please use YAML.parseAllDocuments()';
if (cst.length > 1 && LogLevel.indexOf(doc.options.logLevel) >= LogLevel.ERROR) {
const errMsg = 'Source contains multiple documents; please use YAML.parseAllDocuments()';
doc.errors.unshift(new YAMLSemanticError(cst[1], errMsg));

@@ -2022,3 +37,3 @@ }

function parse(src, reviver, options) {
if (options === undefined && reviver && _typeof(reviver) === 'object') {
if (options === undefined && reviver && typeof reviver === 'object') {
options = reviver;

@@ -2028,20 +43,22 @@ reviver = undefined;

var doc = parseDocument(src, options);
doc.warnings.forEach(function (warning) {
return warn(warning);
});
if (doc.errors.length > 0) throw doc.errors[0];
const doc = parseDocument(src, options);
doc.warnings.forEach(warning => warn(doc.options.logLevel, warning));
if (doc.errors.length > 0) {
if (LogLevel.indexOf(doc.options.logLevel) >= LogLevel.ERROR) throw doc.errors[0];else doc.errors = [];
}
return doc.toJS({
reviver: reviver
reviver
});
}
function stringify$1(value, replacer, options) {
function stringify(value, replacer, options) {
if (typeof options === 'string') options = options.length;
if (typeof options === 'number') {
var indent = Math.round(options);
const indent = Math.round(options);
options = indent < 1 ? undefined : indent > 8 ? {
indent: 8
} : {
indent: indent
indent
};

@@ -2051,5 +68,5 @@ }

if (value === undefined) {
var _ref = options || replacer || {},
keepUndefined = _ref.keepUndefined;
const {
keepUndefined
} = options || replacer || {};
if (!keepUndefined) return undefined;

@@ -2061,2 +78,2 @@ }

export { Document, defaultOptions, parse, parseAllDocuments, parseDocument, scalarOptions, stringify$1 as stringify };
export { parse, parseAllDocuments, parseDocument, stringify };

@@ -1,3 +0,10 @@

import './errors-2634d01a.js';
export { A as Alias, C as Collection, N as Node, P as Pair, S as Scalar, d as YAMLMap, Y as YAMLSeq, b as binaryOptions, a as boolOptions, i as intOptions, n as nullOptions, s as strOptions } from './stringifyNumber-d8af95b1.js';
export { M as Merge, S as Schema } from './Schema-ea978338.js';
export { binaryOptions, boolOptions, intOptions, nullOptions, strOptions } from './tags/options.js';
export { Schema } from './doc/Schema.js';
export { Alias } from './ast/Alias.js';
export { Collection } from './ast/Collection.js';
export { Merge } from './ast/Merge.js';
export { Node } from './ast/Node.js';
export { Pair } from './ast/Pair.js';
export { Scalar } from './ast/Scalar.js';
export { YAMLMap } from './ast/YAMLMap.js';
export { YAMLSeq } from './ast/YAMLSeq.js';

@@ -1,2 +0,6 @@

export { T as Type, k as YAMLError, j as YAMLReferenceError, Y as YAMLSemanticError, i as YAMLSyntaxError, g as YAMLWarning } from './errors-2634d01a.js';
export { l as findPair, k as stringifyNumber, c as stringifyString, t as toJS } from './stringifyNumber-d8af95b1.js';
export { stringifyNumber } from './stringify/stringifyNumber.js';
export { stringifyString } from './stringify/stringifyString.js';
export { Type } from './constants.js';
export { YAMLError, YAMLReferenceError, YAMLSemanticError, YAMLSyntaxError, YAMLWarning } from './errors.js';
export { findPair } from './ast/YAMLMap.js';
export { toJS } from './ast/toJS.js';

@@ -1,1 +0,2 @@

module.exports = require('./dist')
export * as default from './dist/index.js'
export * from './dist/index.js'
'use strict';
var _rollupPluginBabelHelpers = require('./_rollupPluginBabelHelpers-eed30217.js');
var parseCst = require('./parse-3997f544.js');
require('./stringifyNumber-dea1120c.js');
require('./Schema-807430ba.js');
var Document = require('./Document-f89a2614.js');
var constants = require('./constants.js');
var parse$1 = require('./cst/parse.js');
var Document = require('./doc/Document.js');
var errors = require('./errors.js');
var log = require('./log.js');
var options = require('./options.js');
var visit = require('./ast/visit.js');
/* global console, process, YAML_SILENCE_WARNINGS */
function warn(warning, type) {
if (typeof YAML_SILENCE_WARNINGS !== 'undefined' && YAML_SILENCE_WARNINGS) return;
if (typeof process !== 'undefined') {
if (process.env.YAML_SILENCE_WARNINGS) return; // This will throw in Jest if `warning` is an Error instance due to
// https://github.com/facebook/jest/issues/2549
if (process.emitWarning) {
process.emitWarning(warning, type);
return;
}
} // eslint-disable-next-line no-console
console.warn(type ? `${type}: ${warning}` : warning);
}
function parseAllDocuments(src, options) {

@@ -31,3 +15,3 @@ const stream = [];

for (const cstDoc of parseCst.parse(src)) {
for (const cstDoc of parse$1.parse(src)) {
const doc = new Document.Document(undefined, null, options);

@@ -42,8 +26,8 @@ doc.parse(cstDoc, prev);

function parseDocument(src, options) {
const cst = parseCst.parse(src);
const cst = parse$1.parse(src);
const doc = new Document.Document(cst[0], null, options);
if (cst.length > 1) {
if (cst.length > 1 && constants.LogLevel.indexOf(doc.options.logLevel) >= constants.LogLevel.ERROR) {
const errMsg = 'Source contains multiple documents; please use YAML.parseAllDocuments()';
doc.errors.unshift(new _rollupPluginBabelHelpers.YAMLSemanticError(cst[1], errMsg));
doc.errors.unshift(new errors.YAMLSemanticError(cst[1], errMsg));
}

@@ -60,4 +44,8 @@

const doc = parseDocument(src, options);
doc.warnings.forEach(warning => warn(warning));
if (doc.errors.length > 0) throw doc.errors[0];
doc.warnings.forEach(warning => log.warn(doc.options.logLevel, warning));
if (doc.errors.length > 0) {
if (constants.LogLevel.indexOf(doc.options.logLevel) >= constants.LogLevel.ERROR) throw doc.errors[0];else doc.errors = [];
}
return doc.toJS({

@@ -89,6 +77,7 @@ reviver

exports.parseCST = parseCst.parse;
exports.parseCST = parse$1.parse;
exports.Document = Document.Document;
exports.defaultOptions = Document.defaultOptions;
exports.scalarOptions = Document.scalarOptions;
exports.defaultOptions = options.defaultOptions;
exports.scalarOptions = options.scalarOptions;
exports.visit = visit.visit;
exports.parse = parse;

@@ -95,0 +84,0 @@ exports.parseAllDocuments = parseAllDocuments;

'use strict';
require('./_rollupPluginBabelHelpers-eed30217.js');
var parseCst = require('./parse-3997f544.js');
require('./stringifyNumber-dea1120c.js');
require('./Schema-807430ba.js');
var Document = require('./Document-f89a2614.js');
var parse = require('./cst/parse.js');
var Document = require('./doc/Document.js');

@@ -15,3 +12,3 @@ function testEvents(src, options) {

}, options);
const docs = parseCst.parse(src).map(cstDoc => new Document.Document(null, opt).parse(cstDoc));
const docs = parse.parse(src).map(cstDoc => new Document.Document(null, opt).parse(cstDoc));
const errDoc = docs.find(doc => doc.errors.length > 0);

@@ -18,0 +15,0 @@ const error = errDoc ? errDoc.errors[0].message : null;

'use strict';
require('./_rollupPluginBabelHelpers-eed30217.js');
var stringifyNumber = require('./stringifyNumber-dea1120c.js');
var Schema = require('./Schema-807430ba.js');
var options = require('./tags/options.js');
var Schema = require('./doc/Schema.js');
var Alias = require('./ast/Alias.js');
var Collection = require('./ast/Collection.js');
var Merge = require('./ast/Merge.js');
var Node = require('./ast/Node.js');
var Pair = require('./ast/Pair.js');
var Scalar = require('./ast/Scalar.js');
var YAMLMap = require('./ast/YAMLMap.js');
var YAMLSeq = require('./ast/YAMLSeq.js');
exports.Alias = stringifyNumber.Alias;
exports.Collection = stringifyNumber.Collection;
exports.Node = stringifyNumber.Node;
exports.Pair = stringifyNumber.Pair;
exports.Scalar = stringifyNumber.Scalar;
exports.YAMLMap = stringifyNumber.YAMLMap;
exports.YAMLSeq = stringifyNumber.YAMLSeq;
exports.binaryOptions = stringifyNumber.binaryOptions;
exports.boolOptions = stringifyNumber.boolOptions;
exports.intOptions = stringifyNumber.intOptions;
exports.nullOptions = stringifyNumber.nullOptions;
exports.strOptions = stringifyNumber.strOptions;
exports.Merge = Schema.Merge;
exports.binaryOptions = options.binaryOptions;
exports.boolOptions = options.boolOptions;
exports.intOptions = options.intOptions;
exports.nullOptions = options.nullOptions;
exports.strOptions = options.strOptions;
exports.Schema = Schema.Schema;
exports.Alias = Alias.Alias;
exports.Collection = Collection.Collection;
exports.Merge = Merge.Merge;
exports.Node = Node.Node;
exports.Pair = Pair.Pair;
exports.Scalar = Scalar.Scalar;
exports.YAMLMap = YAMLMap.YAMLMap;
exports.YAMLSeq = YAMLSeq.YAMLSeq;
'use strict';
var _rollupPluginBabelHelpers = require('./_rollupPluginBabelHelpers-eed30217.js');
var stringifyNumber = require('./stringifyNumber-dea1120c.js');
var stringifyNumber = require('./stringify/stringifyNumber.js');
var stringifyString = require('./stringify/stringifyString.js');
var constants = require('./constants.js');
var errors = require('./errors.js');
var YAMLMap = require('./ast/YAMLMap.js');
var toJS = require('./ast/toJS.js');
exports.Type = _rollupPluginBabelHelpers.Type;
exports.YAMLError = _rollupPluginBabelHelpers.YAMLError;
exports.YAMLReferenceError = _rollupPluginBabelHelpers.YAMLReferenceError;
exports.YAMLSemanticError = _rollupPluginBabelHelpers.YAMLSemanticError;
exports.YAMLSyntaxError = _rollupPluginBabelHelpers.YAMLSyntaxError;
exports.YAMLWarning = _rollupPluginBabelHelpers.YAMLWarning;
exports.findPair = stringifyNumber.findPair;
exports.stringifyNumber = stringifyNumber.stringifyNumber;
exports.stringifyString = stringifyNumber.stringifyString;
exports.toJS = stringifyNumber.toJS;
exports.stringifyString = stringifyString.stringifyString;
exports.Type = constants.Type;
exports.YAMLError = errors.YAMLError;
exports.YAMLReferenceError = errors.YAMLReferenceError;
exports.YAMLSemanticError = errors.YAMLSemanticError;
exports.YAMLSyntaxError = errors.YAMLSyntaxError;
exports.YAMLWarning = errors.YAMLWarning;
exports.findPair = YAMLMap.findPair;
exports.toJS = toJS.toJS;

@@ -1,2 +0,2 @@

import { CST } from './parse-cst'
import { CST } from './cst'
import {

@@ -17,5 +17,69 @@ AST,

export { AST, CST }
export { default as parseCST } from './parse-cst'
export function parseCST(str: string): ParsedCST
export interface ParsedCST extends Array<CST.Document> {
setOrigRanges(): boolean
}
/**
* Apply a visitor to an AST node or document.
*
* Walks through the tree (depth-first) starting from `node`, calling a
* `visitor` function with three arguments:
* - `key`: For sequence values and map `Pair`, the node's index in the
* collection. Within a `Pair`, `'key'` or `'value'`, correspondingly.
* `null` for the root node.
* - `node`: The current node.
* - `path`: The ancestry of the current node.
*
* The return value of the visitor may be used to control the traversal:
* - `undefined` (default): Do nothing and continue
* - `visit.SKIP`: Do not visit the children of this node, continue with next
* sibling
* - `visit.BREAK`: Terminate traversal completely
* - `visit.REMOVE`: Remove the current node, then continue with the next one
* - `Node`: Replace the current node, then continue by visiting it
* - `number`: While iterating the items of a sequence or map, set the index
* of the next step. This is useful especially if the index of the current
* node has changed.
*
* If `visitor` is a single function, it will be called with all values
* encountered in the tree, including e.g. `null` values. Alternatively,
* separate visitor functions may be defined for each `Map`, `Pair`, `Seq`,
* `Alias` and `Scalar` node.
*/
export declare const visit: visit
export type visitor<T> = (
key: number | 'key' | 'value' | null,
node: T,
path: Node[]
) => void | symbol | number | Node
export interface visit {
(
node: Node | Document,
visitor:
| visitor<any>
| {
Alias?: visitor<Alias>
Map?: visitor<YAMLMap>
Pair?: visitor<Pair>
Scalar?: visitor<Scalar>
Seq?: visitor<YAMLSeq>
}
): void
/** Terminate visit traversal completely */
BREAK: symbol
/** Remove the current node */
REMOVE: symbol
/** Do not visit the children of the current node */
SKIP: symbol
}
/**
* `yaml` defines document-specific options in three places: as an argument of

@@ -333,3 +397,3 @@ * parse, create and stringify calls, in the values of `YAML.defaultOptions`,

interface Parsed extends Document {
contents: Node | null
contents: Scalar | YAMLMap | YAMLSeq | null
/** The schema used with the document. */

@@ -336,0 +400,0 @@ schema: Schema

{
"name": "yaml",
"version": "2.0.0-1",
"version": "2.0.0-2",
"license": "ISC",

@@ -27,24 +27,27 @@ "author": "Eemeli Aro <eemeli@gmail.com>",

"./index.js": "./browser/index.js",
"./parse-cst.js": "./browser/parse-cst.js",
"./types.js": "./browser/types.js",
"./types.mjs": "./browser/types.js",
"./util.js": "./browser/util.js",
"./util.mjs": "./browser/util.js"
"./types.js": "./browser/dist/types.js",
"./types.mjs": "./browser/dist/types.js",
"./util.js": "./browser/dist/util.js",
"./util.mjs": "./browser/dist/util.js"
},
"exports": {
".": "./index.js",
".": {
"node": "./index.js",
"default": "./browser/index.js"
},
"./package.json": "./package.json",
"./parse-cst": "./parse-cst.js",
"./types": [
{
"import": "./types.mjs"
"./types": {
"node": {
"import": "./types.mjs",
"require": "./types.js"
},
"./types.js"
],
"./util": [
{
"import": "./util.mjs"
"default": "./browser/dist/types.js"
},
"./util": {
"node": {
"import": "./util.mjs",
"require": "./util.js"
},
"./util.js"
]
"default": "./browser/dist/util.js"
}
},

@@ -69,3 +72,3 @@ "scripts": {

},
"browserslist": "> 0.5%, not dead",
"browserslist": "> 0.5%, not dead, not ie 11",
"prettier": {

@@ -78,22 +81,23 @@ "arrowParens": "avoid",

"devDependencies": {
"@babel/core": "^7.11.6",
"@babel/plugin-proposal-class-properties": "^7.10.4",
"@babel/preset-env": "^7.11.5",
"@rollup/plugin-babel": "^5.2.1",
"@babel/core": "^7.12.10",
"@babel/plugin-proposal-class-properties": "^7.12.1",
"@babel/plugin-proposal-nullish-coalescing-operator": "^7.12.1",
"@babel/preset-env": "^7.12.11",
"@rollup/plugin-babel": "^5.2.3",
"babel-eslint": "^10.1.0",
"babel-jest": "^26.5.0",
"babel-jest": "^26.6.3",
"babel-plugin-trace": "^1.1.0",
"common-tags": "^1.8.0",
"cross-env": "^7.0.2",
"eslint": "^7.10.0",
"eslint-config-prettier": "^6.12.0",
"fast-check": "^2.4.0",
"jest": "^26.5.0",
"prettier": "^2.1.2",
"rollup": "^2.28.2",
"typescript": "^4.0.3"
"cross-env": "^7.0.3",
"eslint": "^7.19.0",
"eslint-config-prettier": "^7.2.0",
"fast-check": "^2.12.0",
"jest": "^26.6.3",
"prettier": "^2.2.1",
"rollup": "^2.38.2",
"typescript": "^4.1.3"
},
"engines": {
"node": ">= 6"
"node": ">= 10"
}
}

@@ -5,3 +5,4 @@ # YAML <a href="https://www.npmjs.com/package/yaml"><img align="right" src="https://badge.fury.io/js/yaml.svg" title="npm package" /></a>

The library is released under the ISC open source license, and the code is [available on GitHub](https://github.com/eemeli/yaml/). It has no external dependencies and runs on Node.js 6 and later, and in browsers from IE 11 upwards.
The library is released under the ISC open source license, and the code is [available on GitHub](https://github.com/eemeli/yaml/).
It has no external dependencies and runs on Node.js as well as modern browsers.

@@ -47,2 +48,3 @@ For the purposes of versioning, any changes that break any of the endpoints or APIs documented here will be considered semver-major breaking changes. Undocumented library internals may change between minor versions, and previous APIs may be deprecated (but not removed).

- [`YAML.parseDocument(str, options?): YAML.Document`](https://eemeli.org/yaml/#parsing-documents)
- [`YAML.visit(node, visitor)`](https://eemeli.org/yaml/#modifying-nodes)

@@ -59,7 +61,2 @@ ```js

```js
import parseCST from 'yaml/parse-cst'
```
- [`parseCST(str): CSTDocument[]`](https://eemeli.org/yaml/#parsecst)
- [`YAML.parseCST(str): CSTDocument[]`](https://eemeli.org/yaml/#parsecst)

@@ -66,0 +63,0 @@

import { Document, scalarOptions } from './index'
import { CST } from './parse-cst'
import { CST } from './cst'
import { Type } from './util'

@@ -4,0 +4,0 @@

@@ -1,2 +0,2 @@

import { CST } from './parse-cst'
import { CST } from './cst'
import { Pair, Scalar, Schema } from './types'

@@ -3,0 +3,0 @@

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc