{"version":3,"file":"utils-aa888deb.js","sources":["../../../node_modules/.pnpm/@braintree+sanitize-url@6.0.0/node_modules/@braintree/sanitize-url/dist/index.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/math.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/linear.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/bump.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/noop.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/basis.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/basisClosed.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/basisOpen.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/bundle.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/cardinal.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/cardinalClosed.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/cardinalOpen.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/catmullRom.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/catmullRomClosed.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/catmullRomOpen.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/linearClosed.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/monotone.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/natural.js","../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/curve/step.js","../../../node_modules/.pnpm/js-yaml@4.1.0/node_modules/js-yaml/dist/js-yaml.mjs","../src/diagram-api/frontmatter.ts","../src/styles.ts","../src/directiveUtils.ts","../src/diagram-api/diagramAPI.ts","../src/errors.ts","../src/diagram-api/detectType.ts","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_freeGlobal.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_root.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_Symbol.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_getRawTag.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_objectToString.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_baseGetTag.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/isObject.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/isFunction.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_coreJsData.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_isMasked.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_toSource.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_baseIsNative.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_getValue.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_getNative.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_nativeCreate.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_hashClear.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_hashDelete.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_hashGet.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_hashHas.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_hashSet.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_Hash.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_listCacheClear.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/eq.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_assocIndexOf.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_listCacheDelete.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_listCacheGet.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_listCacheHas.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_listCacheSet.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_ListCache.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_Map.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_mapCacheClear.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_isKeyable.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_getMapData.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_mapCacheDelete.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_mapCacheGet.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_mapCacheHas.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_mapCacheSet.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/_MapCache.js","../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/memoize.js","../src/utils.ts"],"sourcesContent":["\"use strict\";\nObject.defineProperty(exports, \"__esModule\", { value: true });\nexports.sanitizeUrl = void 0;\nvar invalidProtocolRegex = /^([^\\w]*)(javascript|data|vbscript)/im;\nvar htmlEntitiesRegex = /&#(\\w+)(^\\w|;)?/g;\nvar ctrlCharactersRegex = /[\\u0000-\\u001F\\u007F-\\u009F\\u2000-\\u200D\\uFEFF]/gim;\nvar urlSchemeRegex = /^([^:]+):/gm;\nvar relativeFirstCharacters = [\".\", \"/\"];\nfunction isRelativeUrlWithoutProtocol(url) {\n return relativeFirstCharacters.indexOf(url[0]) > -1;\n}\n// adapted from https://stackoverflow.com/a/29824550/2601552\nfunction decodeHtmlCharacters(str) {\n return str.replace(htmlEntitiesRegex, function (match, dec) {\n return String.fromCharCode(dec);\n });\n}\nfunction sanitizeUrl(url) {\n var sanitizedUrl = decodeHtmlCharacters(url || \"\")\n .replace(ctrlCharactersRegex, \"\")\n .trim();\n if (!sanitizedUrl) {\n return \"about:blank\";\n }\n if (isRelativeUrlWithoutProtocol(sanitizedUrl)) {\n return sanitizedUrl;\n }\n var urlSchemeParseResults = sanitizedUrl.match(urlSchemeRegex);\n if (!urlSchemeParseResults) {\n return sanitizedUrl;\n }\n var urlScheme = urlSchemeParseResults[0];\n if (invalidProtocolRegex.test(urlScheme)) {\n return \"about:blank\";\n }\n return sanitizedUrl;\n}\nexports.sanitizeUrl = sanitizeUrl;\n","export const abs = Math.abs;\nexport const atan2 = Math.atan2;\nexport const cos = Math.cos;\nexport const max = Math.max;\nexport const min = Math.min;\nexport const sin = Math.sin;\nexport const sqrt = Math.sqrt;\n\nexport const epsilon = 1e-12;\nexport const pi = Math.PI;\nexport const halfPi = pi / 2;\nexport const tau = 2 * pi;\n\nexport function acos(x) {\n return x > 1 ? 0 : x < -1 ? pi : Math.acos(x);\n}\n\nexport function asin(x) {\n return x >= 1 ? halfPi : x <= -1 ? -halfPi : Math.asin(x);\n}\n","function Linear(context) {\n this._context = context;\n}\n\nLinear.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // falls through\n default: this._context.lineTo(x, y); break;\n }\n }\n};\n\nexport default function(context) {\n return new Linear(context);\n}\n","import pointRadial from \"../pointRadial.js\";\n\nclass Bump {\n constructor(context, x) {\n this._context = context;\n this._x = x;\n }\n areaStart() {\n this._line = 0;\n }\n areaEnd() {\n this._line = NaN;\n }\n lineStart() {\n this._point = 0;\n }\n lineEnd() {\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n }\n point(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: {\n this._point = 1;\n if (this._line) this._context.lineTo(x, y);\n else this._context.moveTo(x, y);\n break;\n }\n case 1: this._point = 2; // falls through\n default: {\n if (this._x) this._context.bezierCurveTo(this._x0 = (this._x0 + x) / 2, this._y0, this._x0, y, x, y);\n else this._context.bezierCurveTo(this._x0, this._y0 = (this._y0 + y) / 2, x, this._y0, x, y);\n break;\n }\n }\n this._x0 = x, this._y0 = y;\n }\n}\n\nclass BumpRadial {\n constructor(context) {\n this._context = context;\n }\n lineStart() {\n this._point = 0;\n }\n lineEnd() {}\n point(x, y) {\n x = +x, y = +y;\n if (this._point++ === 0) {\n this._x0 = x, this._y0 = y;\n } else {\n const p0 = pointRadial(this._x0, this._y0);\n const p1 = pointRadial(this._x0, this._y0 = (this._y0 + y) / 2);\n const p2 = pointRadial(x, this._y0);\n const p3 = pointRadial(x, y);\n this._context.moveTo(...p0);\n this._context.bezierCurveTo(...p1, ...p2, ...p3);\n }\n }\n}\n\nexport function bumpX(context) {\n return new Bump(context, true);\n}\n\nexport function bumpY(context) {\n return new Bump(context, false);\n}\n\nexport function bumpRadial(context) {\n return new BumpRadial(context);\n}\n","export default function() {}\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n (2 * that._x0 + that._x1) / 3,\n (2 * that._y0 + that._y1) / 3,\n (that._x0 + 2 * that._x1) / 3,\n (that._y0 + 2 * that._y1) / 3,\n (that._x0 + 4 * that._x1 + x) / 6,\n (that._y0 + 4 * that._y1 + y) / 6\n );\n}\n\nexport function Basis(context) {\n this._context = context;\n}\n\nBasis.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 3: point(this, this._x1, this._y1); // falls through\n case 2: this._context.lineTo(this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._context.lineTo((5 * this._x0 + this._x1) / 6, (5 * this._y0 + this._y1) / 6); // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n};\n\nexport default function(context) {\n return new Basis(context);\n}\n","import noop from \"../noop.js\";\nimport {point} from \"./basis.js\";\n\nfunction BasisClosed(context) {\n this._context = context;\n}\n\nBasisClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x2, this._y2);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.moveTo((this._x2 + 2 * this._x3) / 3, (this._y2 + 2 * this._y3) / 3);\n this._context.lineTo((this._x3 + 2 * this._x2) / 3, (this._y3 + 2 * this._y2) / 3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x2, this._y2);\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x2 = x, this._y2 = y; break;\n case 1: this._point = 2; this._x3 = x, this._y3 = y; break;\n case 2: this._point = 3; this._x4 = x, this._y4 = y; this._context.moveTo((this._x0 + 4 * this._x1 + x) / 6, (this._y0 + 4 * this._y1 + y) / 6); break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n};\n\nexport default function(context) {\n return new BasisClosed(context);\n}\n","import {point} from \"./basis.js\";\n\nfunction BasisOpen(context) {\n this._context = context;\n}\n\nBasisOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; var x0 = (this._x0 + 4 * this._x1 + x) / 6, y0 = (this._y0 + 4 * this._y1 + y) / 6; this._line ? this._context.lineTo(x0, y0) : this._context.moveTo(x0, y0); break;\n case 3: this._point = 4; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n }\n};\n\nexport default function(context) {\n return new BasisOpen(context);\n}\n","import {Basis} from \"./basis.js\";\n\nfunction Bundle(context, beta) {\n this._basis = new Basis(context);\n this._beta = beta;\n}\n\nBundle.prototype = {\n lineStart: function() {\n this._x = [];\n this._y = [];\n this._basis.lineStart();\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n j = x.length - 1;\n\n if (j > 0) {\n var x0 = x[0],\n y0 = y[0],\n dx = x[j] - x0,\n dy = y[j] - y0,\n i = -1,\n t;\n\n while (++i <= j) {\n t = i / j;\n this._basis.point(\n this._beta * x[i] + (1 - this._beta) * (x0 + t * dx),\n this._beta * y[i] + (1 - this._beta) * (y0 + t * dy)\n );\n }\n }\n\n this._x = this._y = null;\n this._basis.lineEnd();\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n};\n\nexport default (function custom(beta) {\n\n function bundle(context) {\n return beta === 1 ? new Basis(context) : new Bundle(context, beta);\n }\n\n bundle.beta = function(beta) {\n return custom(+beta);\n };\n\n return bundle;\n})(0.85);\n","export function point(that, x, y) {\n that._context.bezierCurveTo(\n that._x1 + that._k * (that._x2 - that._x0),\n that._y1 + that._k * (that._y2 - that._y0),\n that._x2 + that._k * (that._x1 - x),\n that._y2 + that._k * (that._y1 - y),\n that._x2,\n that._y2\n );\n}\n\nexport function Cardinal(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinal.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: point(this, this._x1, this._y1); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; this._x1 = x, this._y1 = y; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new Cardinal(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import noop from \"../noop.js\";\nimport {point} from \"./cardinal.js\";\n\nexport function CardinalClosed(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalClosed(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import {point} from \"./cardinal.js\";\n\nexport function CardinalOpen(context, tension) {\n this._context = context;\n this._k = (1 - tension) / 6;\n}\n\nCardinalOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // falls through\n default: point(this, x, y); break;\n }\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(tension) {\n\n function cardinal(context) {\n return new CardinalOpen(context, tension);\n }\n\n cardinal.tension = function(tension) {\n return custom(+tension);\n };\n\n return cardinal;\n})(0);\n","import {epsilon} from \"../math.js\";\nimport {Cardinal} from \"./cardinal.js\";\n\nexport function point(that, x, y) {\n var x1 = that._x1,\n y1 = that._y1,\n x2 = that._x2,\n y2 = that._y2;\n\n if (that._l01_a > epsilon) {\n var a = 2 * that._l01_2a + 3 * that._l01_a * that._l12_a + that._l12_2a,\n n = 3 * that._l01_a * (that._l01_a + that._l12_a);\n x1 = (x1 * a - that._x0 * that._l12_2a + that._x2 * that._l01_2a) / n;\n y1 = (y1 * a - that._y0 * that._l12_2a + that._y2 * that._l01_2a) / n;\n }\n\n if (that._l23_a > epsilon) {\n var b = 2 * that._l23_2a + 3 * that._l23_a * that._l12_a + that._l12_2a,\n m = 3 * that._l23_a * (that._l23_a + that._l12_a);\n x2 = (x2 * b + that._x1 * that._l23_2a - x * that._l12_2a) / m;\n y2 = (y2 * b + that._y1 * that._l23_2a - y * that._l12_2a) / m;\n }\n\n that._context.bezierCurveTo(x1, y1, x2, y2, that._x2, that._y2);\n}\n\nfunction CatmullRom(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n}\n\nCatmullRom.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x2, this._y2); break;\n case 3: this.point(this._x2, this._y2); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; // falls through\n default: point(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRom(context, alpha) : new Cardinal(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n})(0.5);\n","import {CardinalClosed} from \"./cardinalClosed.js\";\nimport noop from \"../noop.js\";\nimport {point} from \"./catmullRom.js\";\n\nfunction CatmullRomClosed(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n}\n\nCatmullRomClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._x0 = this._x1 = this._x2 = this._x3 = this._x4 = this._x5 =\n this._y0 = this._y1 = this._y2 = this._y3 = this._y4 = this._y5 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 1: {\n this._context.moveTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 2: {\n this._context.lineTo(this._x3, this._y3);\n this._context.closePath();\n break;\n }\n case 3: {\n this.point(this._x3, this._y3);\n this.point(this._x4, this._y4);\n this.point(this._x5, this._y5);\n break;\n }\n }\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; this._x3 = x, this._y3 = y; break;\n case 1: this._point = 2; this._context.moveTo(this._x4 = x, this._y4 = y); break;\n case 2: this._point = 3; this._x5 = x, this._y5 = y; break;\n default: point(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomClosed(context, alpha) : new CardinalClosed(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n})(0.5);\n","import {CardinalOpen} from \"./cardinalOpen.js\";\nimport {point} from \"./catmullRom.js\";\n\nfunction CatmullRomOpen(context, alpha) {\n this._context = context;\n this._alpha = alpha;\n}\n\nCatmullRomOpen.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 = this._x2 =\n this._y0 = this._y1 = this._y2 = NaN;\n this._l01_a = this._l12_a = this._l23_a =\n this._l01_2a = this._l12_2a = this._l23_2a =\n this._point = 0;\n },\n lineEnd: function() {\n if (this._line || (this._line !== 0 && this._point === 3)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n\n if (this._point) {\n var x23 = this._x2 - x,\n y23 = this._y2 - y;\n this._l23_a = Math.sqrt(this._l23_2a = Math.pow(x23 * x23 + y23 * y23, this._alpha));\n }\n\n switch (this._point) {\n case 0: this._point = 1; break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; this._line ? this._context.lineTo(this._x2, this._y2) : this._context.moveTo(this._x2, this._y2); break;\n case 3: this._point = 4; // falls through\n default: point(this, x, y); break;\n }\n\n this._l01_a = this._l12_a, this._l12_a = this._l23_a;\n this._l01_2a = this._l12_2a, this._l12_2a = this._l23_2a;\n this._x0 = this._x1, this._x1 = this._x2, this._x2 = x;\n this._y0 = this._y1, this._y1 = this._y2, this._y2 = y;\n }\n};\n\nexport default (function custom(alpha) {\n\n function catmullRom(context) {\n return alpha ? new CatmullRomOpen(context, alpha) : new CardinalOpen(context, 0);\n }\n\n catmullRom.alpha = function(alpha) {\n return custom(+alpha);\n };\n\n return catmullRom;\n})(0.5);\n","import noop from \"../noop.js\";\n\nfunction LinearClosed(context) {\n this._context = context;\n}\n\nLinearClosed.prototype = {\n areaStart: noop,\n areaEnd: noop,\n lineStart: function() {\n this._point = 0;\n },\n lineEnd: function() {\n if (this._point) this._context.closePath();\n },\n point: function(x, y) {\n x = +x, y = +y;\n if (this._point) this._context.lineTo(x, y);\n else this._point = 1, this._context.moveTo(x, y);\n }\n};\n\nexport default function(context) {\n return new LinearClosed(context);\n}\n","function sign(x) {\n return x < 0 ? -1 : 1;\n}\n\n// Calculate the slopes of the tangents (Hermite-type interpolation) based on\n// the following paper: Steffen, M. 1990. A Simple Method for Monotonic\n// Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.\n// NOV(II), P. 443, 1990.\nfunction slope3(that, x2, y2) {\n var h0 = that._x1 - that._x0,\n h1 = x2 - that._x1,\n s0 = (that._y1 - that._y0) / (h0 || h1 < 0 && -0),\n s1 = (y2 - that._y1) / (h1 || h0 < 0 && -0),\n p = (s0 * h1 + s1 * h0) / (h0 + h1);\n return (sign(s0) + sign(s1)) * Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0;\n}\n\n// Calculate a one-sided slope.\nfunction slope2(that, t) {\n var h = that._x1 - that._x0;\n return h ? (3 * (that._y1 - that._y0) / h - t) / 2 : t;\n}\n\n// According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations\n// \"you can express cubic Hermite interpolation in terms of cubic Bézier curves\n// with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1\".\nfunction point(that, t0, t1) {\n var x0 = that._x0,\n y0 = that._y0,\n x1 = that._x1,\n y1 = that._y1,\n dx = (x1 - x0) / 3;\n that._context.bezierCurveTo(x0 + dx, y0 + dx * t0, x1 - dx, y1 - dx * t1, x1, y1);\n}\n\nfunction MonotoneX(context) {\n this._context = context;\n}\n\nMonotoneX.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x0 = this._x1 =\n this._y0 = this._y1 =\n this._t0 = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n switch (this._point) {\n case 2: this._context.lineTo(this._x1, this._y1); break;\n case 3: point(this, this._t0, slope2(this, this._t0)); break;\n }\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n this._line = 1 - this._line;\n },\n point: function(x, y) {\n var t1 = NaN;\n\n x = +x, y = +y;\n if (x === this._x1 && y === this._y1) return; // Ignore coincident points.\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; break;\n case 2: this._point = 3; point(this, slope2(this, t1 = slope3(this, x, y)), t1); break;\n default: point(this, this._t0, t1 = slope3(this, x, y)); break;\n }\n\n this._x0 = this._x1, this._x1 = x;\n this._y0 = this._y1, this._y1 = y;\n this._t0 = t1;\n }\n}\n\nfunction MonotoneY(context) {\n this._context = new ReflectContext(context);\n}\n\n(MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function(x, y) {\n MonotoneX.prototype.point.call(this, y, x);\n};\n\nfunction ReflectContext(context) {\n this._context = context;\n}\n\nReflectContext.prototype = {\n moveTo: function(x, y) { this._context.moveTo(y, x); },\n closePath: function() { this._context.closePath(); },\n lineTo: function(x, y) { this._context.lineTo(y, x); },\n bezierCurveTo: function(x1, y1, x2, y2, x, y) { this._context.bezierCurveTo(y1, x1, y2, x2, y, x); }\n};\n\nexport function monotoneX(context) {\n return new MonotoneX(context);\n}\n\nexport function monotoneY(context) {\n return new MonotoneY(context);\n}\n","function Natural(context) {\n this._context = context;\n}\n\nNatural.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = [];\n this._y = [];\n },\n lineEnd: function() {\n var x = this._x,\n y = this._y,\n n = x.length;\n\n if (n) {\n this._line ? this._context.lineTo(x[0], y[0]) : this._context.moveTo(x[0], y[0]);\n if (n === 2) {\n this._context.lineTo(x[1], y[1]);\n } else {\n var px = controlPoints(x),\n py = controlPoints(y);\n for (var i0 = 0, i1 = 1; i1 < n; ++i0, ++i1) {\n this._context.bezierCurveTo(px[0][i0], py[0][i0], px[1][i0], py[1][i0], x[i1], y[i1]);\n }\n }\n }\n\n if (this._line || (this._line !== 0 && n === 1)) this._context.closePath();\n this._line = 1 - this._line;\n this._x = this._y = null;\n },\n point: function(x, y) {\n this._x.push(+x);\n this._y.push(+y);\n }\n};\n\n// See https://www.particleincell.com/2012/bezier-splines/ for derivation.\nfunction controlPoints(x) {\n var i,\n n = x.length - 1,\n m,\n a = new Array(n),\n b = new Array(n),\n r = new Array(n);\n a[0] = 0, b[0] = 2, r[0] = x[0] + 2 * x[1];\n for (i = 1; i < n - 1; ++i) a[i] = 1, b[i] = 4, r[i] = 4 * x[i] + 2 * x[i + 1];\n a[n - 1] = 2, b[n - 1] = 7, r[n - 1] = 8 * x[n - 1] + x[n];\n for (i = 1; i < n; ++i) m = a[i] / b[i - 1], b[i] -= m, r[i] -= m * r[i - 1];\n a[n - 1] = r[n - 1] / b[n - 1];\n for (i = n - 2; i >= 0; --i) a[i] = (r[i] - a[i + 1]) / b[i];\n b[n - 1] = (x[n] + a[n - 1]) / 2;\n for (i = 0; i < n - 1; ++i) b[i] = 2 * x[i + 1] - a[i + 1];\n return [a, b];\n}\n\nexport default function(context) {\n return new Natural(context);\n}\n","function Step(context, t) {\n this._context = context;\n this._t = t;\n}\n\nStep.prototype = {\n areaStart: function() {\n this._line = 0;\n },\n areaEnd: function() {\n this._line = NaN;\n },\n lineStart: function() {\n this._x = this._y = NaN;\n this._point = 0;\n },\n lineEnd: function() {\n if (0 < this._t && this._t < 1 && this._point === 2) this._context.lineTo(this._x, this._y);\n if (this._line || (this._line !== 0 && this._point === 1)) this._context.closePath();\n if (this._line >= 0) this._t = 1 - this._t, this._line = 1 - this._line;\n },\n point: function(x, y) {\n x = +x, y = +y;\n switch (this._point) {\n case 0: this._point = 1; this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y); break;\n case 1: this._point = 2; // falls through\n default: {\n if (this._t <= 0) {\n this._context.lineTo(this._x, y);\n this._context.lineTo(x, y);\n } else {\n var x1 = this._x * (1 - this._t) + x * this._t;\n this._context.lineTo(x1, this._y);\n this._context.lineTo(x1, y);\n }\n break;\n }\n }\n this._x = x, this._y = y;\n }\n};\n\nexport default function(context) {\n return new Step(context, 0.5);\n}\n\nexport function stepBefore(context) {\n return new Step(context, 0);\n}\n\nexport function stepAfter(context) {\n return new Step(context, 1);\n}\n","\n/*! js-yaml 4.1.0 https://github.com/nodeca/js-yaml @license MIT */\nfunction isNothing(subject) {\n return (typeof subject === 'undefined') || (subject === null);\n}\n\n\nfunction isObject(subject) {\n return (typeof subject === 'object') && (subject !== null);\n}\n\n\nfunction toArray(sequence) {\n if (Array.isArray(sequence)) return sequence;\n else if (isNothing(sequence)) return [];\n\n return [ sequence ];\n}\n\n\nfunction extend(target, source) {\n var index, length, key, sourceKeys;\n\n if (source) {\n sourceKeys = Object.keys(source);\n\n for (index = 0, length = sourceKeys.length; index < length; index += 1) {\n key = sourceKeys[index];\n target[key] = source[key];\n }\n }\n\n return target;\n}\n\n\nfunction repeat(string, count) {\n var result = '', cycle;\n\n for (cycle = 0; cycle < count; cycle += 1) {\n result += string;\n }\n\n return result;\n}\n\n\nfunction isNegativeZero(number) {\n return (number === 0) && (Number.NEGATIVE_INFINITY === 1 / number);\n}\n\n\nvar isNothing_1 = isNothing;\nvar isObject_1 = isObject;\nvar toArray_1 = toArray;\nvar repeat_1 = repeat;\nvar isNegativeZero_1 = isNegativeZero;\nvar extend_1 = extend;\n\nvar common = {\n\tisNothing: isNothing_1,\n\tisObject: isObject_1,\n\ttoArray: toArray_1,\n\trepeat: repeat_1,\n\tisNegativeZero: isNegativeZero_1,\n\textend: extend_1\n};\n\n// YAML error class. http://stackoverflow.com/questions/8458984\n\n\nfunction formatError(exception, compact) {\n var where = '', message = exception.reason || '(unknown reason)';\n\n if (!exception.mark) return message;\n\n if (exception.mark.name) {\n where += 'in \"' + exception.mark.name + '\" ';\n }\n\n where += '(' + (exception.mark.line + 1) + ':' + (exception.mark.column + 1) + ')';\n\n if (!compact && exception.mark.snippet) {\n where += '\\n\\n' + exception.mark.snippet;\n }\n\n return message + ' ' + where;\n}\n\n\nfunction YAMLException$1(reason, mark) {\n // Super constructor\n Error.call(this);\n\n this.name = 'YAMLException';\n this.reason = reason;\n this.mark = mark;\n this.message = formatError(this, false);\n\n // Include stack trace in error object\n if (Error.captureStackTrace) {\n // Chrome and NodeJS\n Error.captureStackTrace(this, this.constructor);\n } else {\n // FF, IE 10+ and Safari 6+. Fallback for others\n this.stack = (new Error()).stack || '';\n }\n}\n\n\n// Inherit from Error\nYAMLException$1.prototype = Object.create(Error.prototype);\nYAMLException$1.prototype.constructor = YAMLException$1;\n\n\nYAMLException$1.prototype.toString = function toString(compact) {\n return this.name + ': ' + formatError(this, compact);\n};\n\n\nvar exception = YAMLException$1;\n\n// get snippet for a single line, respecting maxLength\nfunction getLine(buffer, lineStart, lineEnd, position, maxLineLength) {\n var head = '';\n var tail = '';\n var maxHalfLength = Math.floor(maxLineLength / 2) - 1;\n\n if (position - lineStart > maxHalfLength) {\n head = ' ... ';\n lineStart = position - maxHalfLength + head.length;\n }\n\n if (lineEnd - position > maxHalfLength) {\n tail = ' ...';\n lineEnd = position + maxHalfLength - tail.length;\n }\n\n return {\n str: head + buffer.slice(lineStart, lineEnd).replace(/\\t/g, '→') + tail,\n pos: position - lineStart + head.length // relative position\n };\n}\n\n\nfunction padStart(string, max) {\n return common.repeat(' ', max - string.length) + string;\n}\n\n\nfunction makeSnippet(mark, options) {\n options = Object.create(options || null);\n\n if (!mark.buffer) return null;\n\n if (!options.maxLength) options.maxLength = 79;\n if (typeof options.indent !== 'number') options.indent = 1;\n if (typeof options.linesBefore !== 'number') options.linesBefore = 3;\n if (typeof options.linesAfter !== 'number') options.linesAfter = 2;\n\n var re = /\\r?\\n|\\r|\\0/g;\n var lineStarts = [ 0 ];\n var lineEnds = [];\n var match;\n var foundLineNo = -1;\n\n while ((match = re.exec(mark.buffer))) {\n lineEnds.push(match.index);\n lineStarts.push(match.index + match[0].length);\n\n if (mark.position <= match.index && foundLineNo < 0) {\n foundLineNo = lineStarts.length - 2;\n }\n }\n\n if (foundLineNo < 0) foundLineNo = lineStarts.length - 1;\n\n var result = '', i, line;\n var lineNoLength = Math.min(mark.line + options.linesAfter, lineEnds.length).toString().length;\n var maxLineLength = options.maxLength - (options.indent + lineNoLength + 3);\n\n for (i = 1; i <= options.linesBefore; i++) {\n if (foundLineNo - i < 0) break;\n line = getLine(\n mark.buffer,\n lineStarts[foundLineNo - i],\n lineEnds[foundLineNo - i],\n mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo - i]),\n maxLineLength\n );\n result = common.repeat(' ', options.indent) + padStart((mark.line - i + 1).toString(), lineNoLength) +\n ' | ' + line.str + '\\n' + result;\n }\n\n line = getLine(mark.buffer, lineStarts[foundLineNo], lineEnds[foundLineNo], mark.position, maxLineLength);\n result += common.repeat(' ', options.indent) + padStart((mark.line + 1).toString(), lineNoLength) +\n ' | ' + line.str + '\\n';\n result += common.repeat('-', options.indent + lineNoLength + 3 + line.pos) + '^' + '\\n';\n\n for (i = 1; i <= options.linesAfter; i++) {\n if (foundLineNo + i >= lineEnds.length) break;\n line = getLine(\n mark.buffer,\n lineStarts[foundLineNo + i],\n lineEnds[foundLineNo + i],\n mark.position - (lineStarts[foundLineNo] - lineStarts[foundLineNo + i]),\n maxLineLength\n );\n result += common.repeat(' ', options.indent) + padStart((mark.line + i + 1).toString(), lineNoLength) +\n ' | ' + line.str + '\\n';\n }\n\n return result.replace(/\\n$/, '');\n}\n\n\nvar snippet = makeSnippet;\n\nvar TYPE_CONSTRUCTOR_OPTIONS = [\n 'kind',\n 'multi',\n 'resolve',\n 'construct',\n 'instanceOf',\n 'predicate',\n 'represent',\n 'representName',\n 'defaultStyle',\n 'styleAliases'\n];\n\nvar YAML_NODE_KINDS = [\n 'scalar',\n 'sequence',\n 'mapping'\n];\n\nfunction compileStyleAliases(map) {\n var result = {};\n\n if (map !== null) {\n Object.keys(map).forEach(function (style) {\n map[style].forEach(function (alias) {\n result[String(alias)] = style;\n });\n });\n }\n\n return result;\n}\n\nfunction Type$1(tag, options) {\n options = options || {};\n\n Object.keys(options).forEach(function (name) {\n if (TYPE_CONSTRUCTOR_OPTIONS.indexOf(name) === -1) {\n throw new exception('Unknown option \"' + name + '\" is met in definition of \"' + tag + '\" YAML type.');\n }\n });\n\n // TODO: Add tag format check.\n this.options = options; // keep original options in case user wants to extend this type later\n this.tag = tag;\n this.kind = options['kind'] || null;\n this.resolve = options['resolve'] || function () { return true; };\n this.construct = options['construct'] || function (data) { return data; };\n this.instanceOf = options['instanceOf'] || null;\n this.predicate = options['predicate'] || null;\n this.represent = options['represent'] || null;\n this.representName = options['representName'] || null;\n this.defaultStyle = options['defaultStyle'] || null;\n this.multi = options['multi'] || false;\n this.styleAliases = compileStyleAliases(options['styleAliases'] || null);\n\n if (YAML_NODE_KINDS.indexOf(this.kind) === -1) {\n throw new exception('Unknown kind \"' + this.kind + '\" is specified for \"' + tag + '\" YAML type.');\n }\n}\n\nvar type = Type$1;\n\n/*eslint-disable max-len*/\n\n\n\n\n\nfunction compileList(schema, name) {\n var result = [];\n\n schema[name].forEach(function (currentType) {\n var newIndex = result.length;\n\n result.forEach(function (previousType, previousIndex) {\n if (previousType.tag === currentType.tag &&\n previousType.kind === currentType.kind &&\n previousType.multi === currentType.multi) {\n\n newIndex = previousIndex;\n }\n });\n\n result[newIndex] = currentType;\n });\n\n return result;\n}\n\n\nfunction compileMap(/* lists... */) {\n var result = {\n scalar: {},\n sequence: {},\n mapping: {},\n fallback: {},\n multi: {\n scalar: [],\n sequence: [],\n mapping: [],\n fallback: []\n }\n }, index, length;\n\n function collectType(type) {\n if (type.multi) {\n result.multi[type.kind].push(type);\n result.multi['fallback'].push(type);\n } else {\n result[type.kind][type.tag] = result['fallback'][type.tag] = type;\n }\n }\n\n for (index = 0, length = arguments.length; index < length; index += 1) {\n arguments[index].forEach(collectType);\n }\n return result;\n}\n\n\nfunction Schema$1(definition) {\n return this.extend(definition);\n}\n\n\nSchema$1.prototype.extend = function extend(definition) {\n var implicit = [];\n var explicit = [];\n\n if (definition instanceof type) {\n // Schema.extend(type)\n explicit.push(definition);\n\n } else if (Array.isArray(definition)) {\n // Schema.extend([ type1, type2, ... ])\n explicit = explicit.concat(definition);\n\n } else if (definition && (Array.isArray(definition.implicit) || Array.isArray(definition.explicit))) {\n // Schema.extend({ explicit: [ type1, type2, ... ], implicit: [ type1, type2, ... ] })\n if (definition.implicit) implicit = implicit.concat(definition.implicit);\n if (definition.explicit) explicit = explicit.concat(definition.explicit);\n\n } else {\n throw new exception('Schema.extend argument should be a Type, [ Type ], ' +\n 'or a schema definition ({ implicit: [...], explicit: [...] })');\n }\n\n implicit.forEach(function (type$1) {\n if (!(type$1 instanceof type)) {\n throw new exception('Specified list of YAML types (or a single Type object) contains a non-Type object.');\n }\n\n if (type$1.loadKind && type$1.loadKind !== 'scalar') {\n throw new exception('There is a non-scalar type in the implicit list of a schema. Implicit resolving of such types is not supported.');\n }\n\n if (type$1.multi) {\n throw new exception('There is a multi type in the implicit list of a schema. Multi tags can only be listed as explicit.');\n }\n });\n\n explicit.forEach(function (type$1) {\n if (!(type$1 instanceof type)) {\n throw new exception('Specified list of YAML types (or a single Type object) contains a non-Type object.');\n }\n });\n\n var result = Object.create(Schema$1.prototype);\n\n result.implicit = (this.implicit || []).concat(implicit);\n result.explicit = (this.explicit || []).concat(explicit);\n\n result.compiledImplicit = compileList(result, 'implicit');\n result.compiledExplicit = compileList(result, 'explicit');\n result.compiledTypeMap = compileMap(result.compiledImplicit, result.compiledExplicit);\n\n return result;\n};\n\n\nvar schema = Schema$1;\n\nvar str = new type('tag:yaml.org,2002:str', {\n kind: 'scalar',\n construct: function (data) { return data !== null ? data : ''; }\n});\n\nvar seq = new type('tag:yaml.org,2002:seq', {\n kind: 'sequence',\n construct: function (data) { return data !== null ? data : []; }\n});\n\nvar map = new type('tag:yaml.org,2002:map', {\n kind: 'mapping',\n construct: function (data) { return data !== null ? data : {}; }\n});\n\nvar failsafe = new schema({\n explicit: [\n str,\n seq,\n map\n ]\n});\n\nfunction resolveYamlNull(data) {\n if (data === null) return true;\n\n var max = data.length;\n\n return (max === 1 && data === '~') ||\n (max === 4 && (data === 'null' || data === 'Null' || data === 'NULL'));\n}\n\nfunction constructYamlNull() {\n return null;\n}\n\nfunction isNull(object) {\n return object === null;\n}\n\nvar _null = new type('tag:yaml.org,2002:null', {\n kind: 'scalar',\n resolve: resolveYamlNull,\n construct: constructYamlNull,\n predicate: isNull,\n represent: {\n canonical: function () { return '~'; },\n lowercase: function () { return 'null'; },\n uppercase: function () { return 'NULL'; },\n camelcase: function () { return 'Null'; },\n empty: function () { return ''; }\n },\n defaultStyle: 'lowercase'\n});\n\nfunction resolveYamlBoolean(data) {\n if (data === null) return false;\n\n var max = data.length;\n\n return (max === 4 && (data === 'true' || data === 'True' || data === 'TRUE')) ||\n (max === 5 && (data === 'false' || data === 'False' || data === 'FALSE'));\n}\n\nfunction constructYamlBoolean(data) {\n return data === 'true' ||\n data === 'True' ||\n data === 'TRUE';\n}\n\nfunction isBoolean(object) {\n return Object.prototype.toString.call(object) === '[object Boolean]';\n}\n\nvar bool = new type('tag:yaml.org,2002:bool', {\n kind: 'scalar',\n resolve: resolveYamlBoolean,\n construct: constructYamlBoolean,\n predicate: isBoolean,\n represent: {\n lowercase: function (object) { return object ? 'true' : 'false'; },\n uppercase: function (object) { return object ? 'TRUE' : 'FALSE'; },\n camelcase: function (object) { return object ? 'True' : 'False'; }\n },\n defaultStyle: 'lowercase'\n});\n\nfunction isHexCode(c) {\n return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) ||\n ((0x41/* A */ <= c) && (c <= 0x46/* F */)) ||\n ((0x61/* a */ <= c) && (c <= 0x66/* f */));\n}\n\nfunction isOctCode(c) {\n return ((0x30/* 0 */ <= c) && (c <= 0x37/* 7 */));\n}\n\nfunction isDecCode(c) {\n return ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */));\n}\n\nfunction resolveYamlInteger(data) {\n if (data === null) return false;\n\n var max = data.length,\n index = 0,\n hasDigits = false,\n ch;\n\n if (!max) return false;\n\n ch = data[index];\n\n // sign\n if (ch === '-' || ch === '+') {\n ch = data[++index];\n }\n\n if (ch === '0') {\n // 0\n if (index + 1 === max) return true;\n ch = data[++index];\n\n // base 2, base 8, base 16\n\n if (ch === 'b') {\n // base 2\n index++;\n\n for (; index < max; index++) {\n ch = data[index];\n if (ch === '_') continue;\n if (ch !== '0' && ch !== '1') return false;\n hasDigits = true;\n }\n return hasDigits && ch !== '_';\n }\n\n\n if (ch === 'x') {\n // base 16\n index++;\n\n for (; index < max; index++) {\n ch = data[index];\n if (ch === '_') continue;\n if (!isHexCode(data.charCodeAt(index))) return false;\n hasDigits = true;\n }\n return hasDigits && ch !== '_';\n }\n\n\n if (ch === 'o') {\n // base 8\n index++;\n\n for (; index < max; index++) {\n ch = data[index];\n if (ch === '_') continue;\n if (!isOctCode(data.charCodeAt(index))) return false;\n hasDigits = true;\n }\n return hasDigits && ch !== '_';\n }\n }\n\n // base 10 (except 0)\n\n // value should not start with `_`;\n if (ch === '_') return false;\n\n for (; index < max; index++) {\n ch = data[index];\n if (ch === '_') continue;\n if (!isDecCode(data.charCodeAt(index))) {\n return false;\n }\n hasDigits = true;\n }\n\n // Should have digits and should not end with `_`\n if (!hasDigits || ch === '_') return false;\n\n return true;\n}\n\nfunction constructYamlInteger(data) {\n var value = data, sign = 1, ch;\n\n if (value.indexOf('_') !== -1) {\n value = value.replace(/_/g, '');\n }\n\n ch = value[0];\n\n if (ch === '-' || ch === '+') {\n if (ch === '-') sign = -1;\n value = value.slice(1);\n ch = value[0];\n }\n\n if (value === '0') return 0;\n\n if (ch === '0') {\n if (value[1] === 'b') return sign * parseInt(value.slice(2), 2);\n if (value[1] === 'x') return sign * parseInt(value.slice(2), 16);\n if (value[1] === 'o') return sign * parseInt(value.slice(2), 8);\n }\n\n return sign * parseInt(value, 10);\n}\n\nfunction isInteger(object) {\n return (Object.prototype.toString.call(object)) === '[object Number]' &&\n (object % 1 === 0 && !common.isNegativeZero(object));\n}\n\nvar int = new type('tag:yaml.org,2002:int', {\n kind: 'scalar',\n resolve: resolveYamlInteger,\n construct: constructYamlInteger,\n predicate: isInteger,\n represent: {\n binary: function (obj) { return obj >= 0 ? '0b' + obj.toString(2) : '-0b' + obj.toString(2).slice(1); },\n octal: function (obj) { return obj >= 0 ? '0o' + obj.toString(8) : '-0o' + obj.toString(8).slice(1); },\n decimal: function (obj) { return obj.toString(10); },\n /* eslint-disable max-len */\n hexadecimal: function (obj) { return obj >= 0 ? '0x' + obj.toString(16).toUpperCase() : '-0x' + obj.toString(16).toUpperCase().slice(1); }\n },\n defaultStyle: 'decimal',\n styleAliases: {\n binary: [ 2, 'bin' ],\n octal: [ 8, 'oct' ],\n decimal: [ 10, 'dec' ],\n hexadecimal: [ 16, 'hex' ]\n }\n});\n\nvar YAML_FLOAT_PATTERN = new RegExp(\n // 2.5e4, 2.5 and integers\n '^(?:[-+]?(?:[0-9][0-9_]*)(?:\\\\.[0-9_]*)?(?:[eE][-+]?[0-9]+)?' +\n // .2e4, .2\n // special case, seems not from spec\n '|\\\\.[0-9_]+(?:[eE][-+]?[0-9]+)?' +\n // .inf\n '|[-+]?\\\\.(?:inf|Inf|INF)' +\n // .nan\n '|\\\\.(?:nan|NaN|NAN))$');\n\nfunction resolveYamlFloat(data) {\n if (data === null) return false;\n\n if (!YAML_FLOAT_PATTERN.test(data) ||\n // Quick hack to not allow integers end with `_`\n // Probably should update regexp & check speed\n data[data.length - 1] === '_') {\n return false;\n }\n\n return true;\n}\n\nfunction constructYamlFloat(data) {\n var value, sign;\n\n value = data.replace(/_/g, '').toLowerCase();\n sign = value[0] === '-' ? -1 : 1;\n\n if ('+-'.indexOf(value[0]) >= 0) {\n value = value.slice(1);\n }\n\n if (value === '.inf') {\n return (sign === 1) ? Number.POSITIVE_INFINITY : Number.NEGATIVE_INFINITY;\n\n } else if (value === '.nan') {\n return NaN;\n }\n return sign * parseFloat(value, 10);\n}\n\n\nvar SCIENTIFIC_WITHOUT_DOT = /^[-+]?[0-9]+e/;\n\nfunction representYamlFloat(object, style) {\n var res;\n\n if (isNaN(object)) {\n switch (style) {\n case 'lowercase': return '.nan';\n case 'uppercase': return '.NAN';\n case 'camelcase': return '.NaN';\n }\n } else if (Number.POSITIVE_INFINITY === object) {\n switch (style) {\n case 'lowercase': return '.inf';\n case 'uppercase': return '.INF';\n case 'camelcase': return '.Inf';\n }\n } else if (Number.NEGATIVE_INFINITY === object) {\n switch (style) {\n case 'lowercase': return '-.inf';\n case 'uppercase': return '-.INF';\n case 'camelcase': return '-.Inf';\n }\n } else if (common.isNegativeZero(object)) {\n return '-0.0';\n }\n\n res = object.toString(10);\n\n // JS stringifier can build scientific format without dots: 5e-100,\n // while YAML requres dot: 5.e-100. Fix it with simple hack\n\n return SCIENTIFIC_WITHOUT_DOT.test(res) ? res.replace('e', '.e') : res;\n}\n\nfunction isFloat(object) {\n return (Object.prototype.toString.call(object) === '[object Number]') &&\n (object % 1 !== 0 || common.isNegativeZero(object));\n}\n\nvar float = new type('tag:yaml.org,2002:float', {\n kind: 'scalar',\n resolve: resolveYamlFloat,\n construct: constructYamlFloat,\n predicate: isFloat,\n represent: representYamlFloat,\n defaultStyle: 'lowercase'\n});\n\nvar json = failsafe.extend({\n implicit: [\n _null,\n bool,\n int,\n float\n ]\n});\n\nvar core = json;\n\nvar YAML_DATE_REGEXP = new RegExp(\n '^([0-9][0-9][0-9][0-9])' + // [1] year\n '-([0-9][0-9])' + // [2] month\n '-([0-9][0-9])$'); // [3] day\n\nvar YAML_TIMESTAMP_REGEXP = new RegExp(\n '^([0-9][0-9][0-9][0-9])' + // [1] year\n '-([0-9][0-9]?)' + // [2] month\n '-([0-9][0-9]?)' + // [3] day\n '(?:[Tt]|[ \\\\t]+)' + // ...\n '([0-9][0-9]?)' + // [4] hour\n ':([0-9][0-9])' + // [5] minute\n ':([0-9][0-9])' + // [6] second\n '(?:\\\\.([0-9]*))?' + // [7] fraction\n '(?:[ \\\\t]*(Z|([-+])([0-9][0-9]?)' + // [8] tz [9] tz_sign [10] tz_hour\n '(?::([0-9][0-9]))?))?$'); // [11] tz_minute\n\nfunction resolveYamlTimestamp(data) {\n if (data === null) return false;\n if (YAML_DATE_REGEXP.exec(data) !== null) return true;\n if (YAML_TIMESTAMP_REGEXP.exec(data) !== null) return true;\n return false;\n}\n\nfunction constructYamlTimestamp(data) {\n var match, year, month, day, hour, minute, second, fraction = 0,\n delta = null, tz_hour, tz_minute, date;\n\n match = YAML_DATE_REGEXP.exec(data);\n if (match === null) match = YAML_TIMESTAMP_REGEXP.exec(data);\n\n if (match === null) throw new Error('Date resolve error');\n\n // match: [1] year [2] month [3] day\n\n year = +(match[1]);\n month = +(match[2]) - 1; // JS month starts with 0\n day = +(match[3]);\n\n if (!match[4]) { // no hour\n return new Date(Date.UTC(year, month, day));\n }\n\n // match: [4] hour [5] minute [6] second [7] fraction\n\n hour = +(match[4]);\n minute = +(match[5]);\n second = +(match[6]);\n\n if (match[7]) {\n fraction = match[7].slice(0, 3);\n while (fraction.length < 3) { // milli-seconds\n fraction += '0';\n }\n fraction = +fraction;\n }\n\n // match: [8] tz [9] tz_sign [10] tz_hour [11] tz_minute\n\n if (match[9]) {\n tz_hour = +(match[10]);\n tz_minute = +(match[11] || 0);\n delta = (tz_hour * 60 + tz_minute) * 60000; // delta in mili-seconds\n if (match[9] === '-') delta = -delta;\n }\n\n date = new Date(Date.UTC(year, month, day, hour, minute, second, fraction));\n\n if (delta) date.setTime(date.getTime() - delta);\n\n return date;\n}\n\nfunction representYamlTimestamp(object /*, style*/) {\n return object.toISOString();\n}\n\nvar timestamp = new type('tag:yaml.org,2002:timestamp', {\n kind: 'scalar',\n resolve: resolveYamlTimestamp,\n construct: constructYamlTimestamp,\n instanceOf: Date,\n represent: representYamlTimestamp\n});\n\nfunction resolveYamlMerge(data) {\n return data === '<<' || data === null;\n}\n\nvar merge = new type('tag:yaml.org,2002:merge', {\n kind: 'scalar',\n resolve: resolveYamlMerge\n});\n\n/*eslint-disable no-bitwise*/\n\n\n\n\n\n// [ 64, 65, 66 ] -> [ padding, CR, LF ]\nvar BASE64_MAP = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\\n\\r';\n\n\nfunction resolveYamlBinary(data) {\n if (data === null) return false;\n\n var code, idx, bitlen = 0, max = data.length, map = BASE64_MAP;\n\n // Convert one by one.\n for (idx = 0; idx < max; idx++) {\n code = map.indexOf(data.charAt(idx));\n\n // Skip CR/LF\n if (code > 64) continue;\n\n // Fail on illegal characters\n if (code < 0) return false;\n\n bitlen += 6;\n }\n\n // If there are any bits left, source was corrupted\n return (bitlen % 8) === 0;\n}\n\nfunction constructYamlBinary(data) {\n var idx, tailbits,\n input = data.replace(/[\\r\\n=]/g, ''), // remove CR/LF & padding to simplify scan\n max = input.length,\n map = BASE64_MAP,\n bits = 0,\n result = [];\n\n // Collect by 6*4 bits (3 bytes)\n\n for (idx = 0; idx < max; idx++) {\n if ((idx % 4 === 0) && idx) {\n result.push((bits >> 16) & 0xFF);\n result.push((bits >> 8) & 0xFF);\n result.push(bits & 0xFF);\n }\n\n bits = (bits << 6) | map.indexOf(input.charAt(idx));\n }\n\n // Dump tail\n\n tailbits = (max % 4) * 6;\n\n if (tailbits === 0) {\n result.push((bits >> 16) & 0xFF);\n result.push((bits >> 8) & 0xFF);\n result.push(bits & 0xFF);\n } else if (tailbits === 18) {\n result.push((bits >> 10) & 0xFF);\n result.push((bits >> 2) & 0xFF);\n } else if (tailbits === 12) {\n result.push((bits >> 4) & 0xFF);\n }\n\n return new Uint8Array(result);\n}\n\nfunction representYamlBinary(object /*, style*/) {\n var result = '', bits = 0, idx, tail,\n max = object.length,\n map = BASE64_MAP;\n\n // Convert every three bytes to 4 ASCII characters.\n\n for (idx = 0; idx < max; idx++) {\n if ((idx % 3 === 0) && idx) {\n result += map[(bits >> 18) & 0x3F];\n result += map[(bits >> 12) & 0x3F];\n result += map[(bits >> 6) & 0x3F];\n result += map[bits & 0x3F];\n }\n\n bits = (bits << 8) + object[idx];\n }\n\n // Dump tail\n\n tail = max % 3;\n\n if (tail === 0) {\n result += map[(bits >> 18) & 0x3F];\n result += map[(bits >> 12) & 0x3F];\n result += map[(bits >> 6) & 0x3F];\n result += map[bits & 0x3F];\n } else if (tail === 2) {\n result += map[(bits >> 10) & 0x3F];\n result += map[(bits >> 4) & 0x3F];\n result += map[(bits << 2) & 0x3F];\n result += map[64];\n } else if (tail === 1) {\n result += map[(bits >> 2) & 0x3F];\n result += map[(bits << 4) & 0x3F];\n result += map[64];\n result += map[64];\n }\n\n return result;\n}\n\nfunction isBinary(obj) {\n return Object.prototype.toString.call(obj) === '[object Uint8Array]';\n}\n\nvar binary = new type('tag:yaml.org,2002:binary', {\n kind: 'scalar',\n resolve: resolveYamlBinary,\n construct: constructYamlBinary,\n predicate: isBinary,\n represent: representYamlBinary\n});\n\nvar _hasOwnProperty$3 = Object.prototype.hasOwnProperty;\nvar _toString$2 = Object.prototype.toString;\n\nfunction resolveYamlOmap(data) {\n if (data === null) return true;\n\n var objectKeys = [], index, length, pair, pairKey, pairHasKey,\n object = data;\n\n for (index = 0, length = object.length; index < length; index += 1) {\n pair = object[index];\n pairHasKey = false;\n\n if (_toString$2.call(pair) !== '[object Object]') return false;\n\n for (pairKey in pair) {\n if (_hasOwnProperty$3.call(pair, pairKey)) {\n if (!pairHasKey) pairHasKey = true;\n else return false;\n }\n }\n\n if (!pairHasKey) return false;\n\n if (objectKeys.indexOf(pairKey) === -1) objectKeys.push(pairKey);\n else return false;\n }\n\n return true;\n}\n\nfunction constructYamlOmap(data) {\n return data !== null ? data : [];\n}\n\nvar omap = new type('tag:yaml.org,2002:omap', {\n kind: 'sequence',\n resolve: resolveYamlOmap,\n construct: constructYamlOmap\n});\n\nvar _toString$1 = Object.prototype.toString;\n\nfunction resolveYamlPairs(data) {\n if (data === null) return true;\n\n var index, length, pair, keys, result,\n object = data;\n\n result = new Array(object.length);\n\n for (index = 0, length = object.length; index < length; index += 1) {\n pair = object[index];\n\n if (_toString$1.call(pair) !== '[object Object]') return false;\n\n keys = Object.keys(pair);\n\n if (keys.length !== 1) return false;\n\n result[index] = [ keys[0], pair[keys[0]] ];\n }\n\n return true;\n}\n\nfunction constructYamlPairs(data) {\n if (data === null) return [];\n\n var index, length, pair, keys, result,\n object = data;\n\n result = new Array(object.length);\n\n for (index = 0, length = object.length; index < length; index += 1) {\n pair = object[index];\n\n keys = Object.keys(pair);\n\n result[index] = [ keys[0], pair[keys[0]] ];\n }\n\n return result;\n}\n\nvar pairs = new type('tag:yaml.org,2002:pairs', {\n kind: 'sequence',\n resolve: resolveYamlPairs,\n construct: constructYamlPairs\n});\n\nvar _hasOwnProperty$2 = Object.prototype.hasOwnProperty;\n\nfunction resolveYamlSet(data) {\n if (data === null) return true;\n\n var key, object = data;\n\n for (key in object) {\n if (_hasOwnProperty$2.call(object, key)) {\n if (object[key] !== null) return false;\n }\n }\n\n return true;\n}\n\nfunction constructYamlSet(data) {\n return data !== null ? data : {};\n}\n\nvar set = new type('tag:yaml.org,2002:set', {\n kind: 'mapping',\n resolve: resolveYamlSet,\n construct: constructYamlSet\n});\n\nvar _default = core.extend({\n implicit: [\n timestamp,\n merge\n ],\n explicit: [\n binary,\n omap,\n pairs,\n set\n ]\n});\n\n/*eslint-disable max-len,no-use-before-define*/\n\n\n\n\n\n\n\nvar _hasOwnProperty$1 = Object.prototype.hasOwnProperty;\n\n\nvar CONTEXT_FLOW_IN = 1;\nvar CONTEXT_FLOW_OUT = 2;\nvar CONTEXT_BLOCK_IN = 3;\nvar CONTEXT_BLOCK_OUT = 4;\n\n\nvar CHOMPING_CLIP = 1;\nvar CHOMPING_STRIP = 2;\nvar CHOMPING_KEEP = 3;\n\n\nvar PATTERN_NON_PRINTABLE = /[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7F-\\x84\\x86-\\x9F\\uFFFE\\uFFFF]|[\\uD800-\\uDBFF](?![\\uDC00-\\uDFFF])|(?:[^\\uD800-\\uDBFF]|^)[\\uDC00-\\uDFFF]/;\nvar PATTERN_NON_ASCII_LINE_BREAKS = /[\\x85\\u2028\\u2029]/;\nvar PATTERN_FLOW_INDICATORS = /[,\\[\\]\\{\\}]/;\nvar PATTERN_TAG_HANDLE = /^(?:!|!!|![a-z\\-]+!)$/i;\nvar PATTERN_TAG_URI = /^(?:!|[^,\\[\\]\\{\\}])(?:%[0-9a-f]{2}|[0-9a-z\\-#;\\/\\?:@&=\\+\\$,_\\.!~\\*'\\(\\)\\[\\]])*$/i;\n\n\nfunction _class(obj) { return Object.prototype.toString.call(obj); }\n\nfunction is_EOL(c) {\n return (c === 0x0A/* LF */) || (c === 0x0D/* CR */);\n}\n\nfunction is_WHITE_SPACE(c) {\n return (c === 0x09/* Tab */) || (c === 0x20/* Space */);\n}\n\nfunction is_WS_OR_EOL(c) {\n return (c === 0x09/* Tab */) ||\n (c === 0x20/* Space */) ||\n (c === 0x0A/* LF */) ||\n (c === 0x0D/* CR */);\n}\n\nfunction is_FLOW_INDICATOR(c) {\n return c === 0x2C/* , */ ||\n c === 0x5B/* [ */ ||\n c === 0x5D/* ] */ ||\n c === 0x7B/* { */ ||\n c === 0x7D/* } */;\n}\n\nfunction fromHexCode(c) {\n var lc;\n\n if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n return c - 0x30;\n }\n\n /*eslint-disable no-bitwise*/\n lc = c | 0x20;\n\n if ((0x61/* a */ <= lc) && (lc <= 0x66/* f */)) {\n return lc - 0x61 + 10;\n }\n\n return -1;\n}\n\nfunction escapedHexLen(c) {\n if (c === 0x78/* x */) { return 2; }\n if (c === 0x75/* u */) { return 4; }\n if (c === 0x55/* U */) { return 8; }\n return 0;\n}\n\nfunction fromDecimalCode(c) {\n if ((0x30/* 0 */ <= c) && (c <= 0x39/* 9 */)) {\n return c - 0x30;\n }\n\n return -1;\n}\n\nfunction simpleEscapeSequence(c) {\n /* eslint-disable indent */\n return (c === 0x30/* 0 */) ? '\\x00' :\n (c === 0x61/* a */) ? '\\x07' :\n (c === 0x62/* b */) ? '\\x08' :\n (c === 0x74/* t */) ? '\\x09' :\n (c === 0x09/* Tab */) ? '\\x09' :\n (c === 0x6E/* n */) ? '\\x0A' :\n (c === 0x76/* v */) ? '\\x0B' :\n (c === 0x66/* f */) ? '\\x0C' :\n (c === 0x72/* r */) ? '\\x0D' :\n (c === 0x65/* e */) ? '\\x1B' :\n (c === 0x20/* Space */) ? ' ' :\n (c === 0x22/* \" */) ? '\\x22' :\n (c === 0x2F/* / */) ? '/' :\n (c === 0x5C/* \\ */) ? '\\x5C' :\n (c === 0x4E/* N */) ? '\\x85' :\n (c === 0x5F/* _ */) ? '\\xA0' :\n (c === 0x4C/* L */) ? '\\u2028' :\n (c === 0x50/* P */) ? '\\u2029' : '';\n}\n\nfunction charFromCodepoint(c) {\n if (c <= 0xFFFF) {\n return String.fromCharCode(c);\n }\n // Encode UTF-16 surrogate pair\n // https://en.wikipedia.org/wiki/UTF-16#Code_points_U.2B010000_to_U.2B10FFFF\n return String.fromCharCode(\n ((c - 0x010000) >> 10) + 0xD800,\n ((c - 0x010000) & 0x03FF) + 0xDC00\n );\n}\n\nvar simpleEscapeCheck = new Array(256); // integer, for fast access\nvar simpleEscapeMap = new Array(256);\nfor (var i = 0; i < 256; i++) {\n simpleEscapeCheck[i] = simpleEscapeSequence(i) ? 1 : 0;\n simpleEscapeMap[i] = simpleEscapeSequence(i);\n}\n\n\nfunction State$1(input, options) {\n this.input = input;\n\n this.filename = options['filename'] || null;\n this.schema = options['schema'] || _default;\n this.onWarning = options['onWarning'] || null;\n // (Hidden) Remove? makes the loader to expect YAML 1.1 documents\n // if such documents have no explicit %YAML directive\n this.legacy = options['legacy'] || false;\n\n this.json = options['json'] || false;\n this.listener = options['listener'] || null;\n\n this.implicitTypes = this.schema.compiledImplicit;\n this.typeMap = this.schema.compiledTypeMap;\n\n this.length = input.length;\n this.position = 0;\n this.line = 0;\n this.lineStart = 0;\n this.lineIndent = 0;\n\n // position of first leading tab in the current line,\n // used to make sure there are no tabs in the indentation\n this.firstTabInLine = -1;\n\n this.documents = [];\n\n /*\n this.version;\n this.checkLineBreaks;\n this.tagMap;\n this.anchorMap;\n this.tag;\n this.anchor;\n this.kind;\n this.result;*/\n\n}\n\n\nfunction generateError(state, message) {\n var mark = {\n name: state.filename,\n buffer: state.input.slice(0, -1), // omit trailing \\0\n position: state.position,\n line: state.line,\n column: state.position - state.lineStart\n };\n\n mark.snippet = snippet(mark);\n\n return new exception(message, mark);\n}\n\nfunction throwError(state, message) {\n throw generateError(state, message);\n}\n\nfunction throwWarning(state, message) {\n if (state.onWarning) {\n state.onWarning.call(null, generateError(state, message));\n }\n}\n\n\nvar directiveHandlers = {\n\n YAML: function handleYamlDirective(state, name, args) {\n\n var match, major, minor;\n\n if (state.version !== null) {\n throwError(state, 'duplication of %YAML directive');\n }\n\n if (args.length !== 1) {\n throwError(state, 'YAML directive accepts exactly one argument');\n }\n\n match = /^([0-9]+)\\.([0-9]+)$/.exec(args[0]);\n\n if (match === null) {\n throwError(state, 'ill-formed argument of the YAML directive');\n }\n\n major = parseInt(match[1], 10);\n minor = parseInt(match[2], 10);\n\n if (major !== 1) {\n throwError(state, 'unacceptable YAML version of the document');\n }\n\n state.version = args[0];\n state.checkLineBreaks = (minor < 2);\n\n if (minor !== 1 && minor !== 2) {\n throwWarning(state, 'unsupported YAML version of the document');\n }\n },\n\n TAG: function handleTagDirective(state, name, args) {\n\n var handle, prefix;\n\n if (args.length !== 2) {\n throwError(state, 'TAG directive accepts exactly two arguments');\n }\n\n handle = args[0];\n prefix = args[1];\n\n if (!PATTERN_TAG_HANDLE.test(handle)) {\n throwError(state, 'ill-formed tag handle (first argument) of the TAG directive');\n }\n\n if (_hasOwnProperty$1.call(state.tagMap, handle)) {\n throwError(state, 'there is a previously declared suffix for \"' + handle + '\" tag handle');\n }\n\n if (!PATTERN_TAG_URI.test(prefix)) {\n throwError(state, 'ill-formed tag prefix (second argument) of the TAG directive');\n }\n\n try {\n prefix = decodeURIComponent(prefix);\n } catch (err) {\n throwError(state, 'tag prefix is malformed: ' + prefix);\n }\n\n state.tagMap[handle] = prefix;\n }\n};\n\n\nfunction captureSegment(state, start, end, checkJson) {\n var _position, _length, _character, _result;\n\n if (start < end) {\n _result = state.input.slice(start, end);\n\n if (checkJson) {\n for (_position = 0, _length = _result.length; _position < _length; _position += 1) {\n _character = _result.charCodeAt(_position);\n if (!(_character === 0x09 ||\n (0x20 <= _character && _character <= 0x10FFFF))) {\n throwError(state, 'expected valid JSON character');\n }\n }\n } else if (PATTERN_NON_PRINTABLE.test(_result)) {\n throwError(state, 'the stream contains non-printable characters');\n }\n\n state.result += _result;\n }\n}\n\nfunction mergeMappings(state, destination, source, overridableKeys) {\n var sourceKeys, key, index, quantity;\n\n if (!common.isObject(source)) {\n throwError(state, 'cannot merge mappings; the provided source object is unacceptable');\n }\n\n sourceKeys = Object.keys(source);\n\n for (index = 0, quantity = sourceKeys.length; index < quantity; index += 1) {\n key = sourceKeys[index];\n\n if (!_hasOwnProperty$1.call(destination, key)) {\n destination[key] = source[key];\n overridableKeys[key] = true;\n }\n }\n}\n\nfunction storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode,\n startLine, startLineStart, startPos) {\n\n var index, quantity;\n\n // The output is a plain object here, so keys can only be strings.\n // We need to convert keyNode to a string, but doing so can hang the process\n // (deeply nested arrays that explode exponentially using aliases).\n if (Array.isArray(keyNode)) {\n keyNode = Array.prototype.slice.call(keyNode);\n\n for (index = 0, quantity = keyNode.length; index < quantity; index += 1) {\n if (Array.isArray(keyNode[index])) {\n throwError(state, 'nested arrays are not supported inside keys');\n }\n\n if (typeof keyNode === 'object' && _class(keyNode[index]) === '[object Object]') {\n keyNode[index] = '[object Object]';\n }\n }\n }\n\n // Avoid code execution in load() via toString property\n // (still use its own toString for arrays, timestamps,\n // and whatever user schema extensions happen to have @@toStringTag)\n if (typeof keyNode === 'object' && _class(keyNode) === '[object Object]') {\n keyNode = '[object Object]';\n }\n\n\n keyNode = String(keyNode);\n\n if (_result === null) {\n _result = {};\n }\n\n if (keyTag === 'tag:yaml.org,2002:merge') {\n if (Array.isArray(valueNode)) {\n for (index = 0, quantity = valueNode.length; index < quantity; index += 1) {\n mergeMappings(state, _result, valueNode[index], overridableKeys);\n }\n } else {\n mergeMappings(state, _result, valueNode, overridableKeys);\n }\n } else {\n if (!state.json &&\n !_hasOwnProperty$1.call(overridableKeys, keyNode) &&\n _hasOwnProperty$1.call(_result, keyNode)) {\n state.line = startLine || state.line;\n state.lineStart = startLineStart || state.lineStart;\n state.position = startPos || state.position;\n throwError(state, 'duplicated mapping key');\n }\n\n // used for this specific key only because Object.defineProperty is slow\n if (keyNode === '__proto__') {\n Object.defineProperty(_result, keyNode, {\n configurable: true,\n enumerable: true,\n writable: true,\n value: valueNode\n });\n } else {\n _result[keyNode] = valueNode;\n }\n delete overridableKeys[keyNode];\n }\n\n return _result;\n}\n\nfunction readLineBreak(state) {\n var ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch === 0x0A/* LF */) {\n state.position++;\n } else if (ch === 0x0D/* CR */) {\n state.position++;\n if (state.input.charCodeAt(state.position) === 0x0A/* LF */) {\n state.position++;\n }\n } else {\n throwError(state, 'a line break is expected');\n }\n\n state.line += 1;\n state.lineStart = state.position;\n state.firstTabInLine = -1;\n}\n\nfunction skipSeparationSpace(state, allowComments, checkIndent) {\n var lineBreaks = 0,\n ch = state.input.charCodeAt(state.position);\n\n while (ch !== 0) {\n while (is_WHITE_SPACE(ch)) {\n if (ch === 0x09/* Tab */ && state.firstTabInLine === -1) {\n state.firstTabInLine = state.position;\n }\n ch = state.input.charCodeAt(++state.position);\n }\n\n if (allowComments && ch === 0x23/* # */) {\n do {\n ch = state.input.charCodeAt(++state.position);\n } while (ch !== 0x0A/* LF */ && ch !== 0x0D/* CR */ && ch !== 0);\n }\n\n if (is_EOL(ch)) {\n readLineBreak(state);\n\n ch = state.input.charCodeAt(state.position);\n lineBreaks++;\n state.lineIndent = 0;\n\n while (ch === 0x20/* Space */) {\n state.lineIndent++;\n ch = state.input.charCodeAt(++state.position);\n }\n } else {\n break;\n }\n }\n\n if (checkIndent !== -1 && lineBreaks !== 0 && state.lineIndent < checkIndent) {\n throwWarning(state, 'deficient indentation');\n }\n\n return lineBreaks;\n}\n\nfunction testDocumentSeparator(state) {\n var _position = state.position,\n ch;\n\n ch = state.input.charCodeAt(_position);\n\n // Condition state.position === state.lineStart is tested\n // in parent on each call, for efficiency. No needs to test here again.\n if ((ch === 0x2D/* - */ || ch === 0x2E/* . */) &&\n ch === state.input.charCodeAt(_position + 1) &&\n ch === state.input.charCodeAt(_position + 2)) {\n\n _position += 3;\n\n ch = state.input.charCodeAt(_position);\n\n if (ch === 0 || is_WS_OR_EOL(ch)) {\n return true;\n }\n }\n\n return false;\n}\n\nfunction writeFoldedLines(state, count) {\n if (count === 1) {\n state.result += ' ';\n } else if (count > 1) {\n state.result += common.repeat('\\n', count - 1);\n }\n}\n\n\nfunction readPlainScalar(state, nodeIndent, withinFlowCollection) {\n var preceding,\n following,\n captureStart,\n captureEnd,\n hasPendingContent,\n _line,\n _lineStart,\n _lineIndent,\n _kind = state.kind,\n _result = state.result,\n ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (is_WS_OR_EOL(ch) ||\n is_FLOW_INDICATOR(ch) ||\n ch === 0x23/* # */ ||\n ch === 0x26/* & */ ||\n ch === 0x2A/* * */ ||\n ch === 0x21/* ! */ ||\n ch === 0x7C/* | */ ||\n ch === 0x3E/* > */ ||\n ch === 0x27/* ' */ ||\n ch === 0x22/* \" */ ||\n ch === 0x25/* % */ ||\n ch === 0x40/* @ */ ||\n ch === 0x60/* ` */) {\n return false;\n }\n\n if (ch === 0x3F/* ? */ || ch === 0x2D/* - */) {\n following = state.input.charCodeAt(state.position + 1);\n\n if (is_WS_OR_EOL(following) ||\n withinFlowCollection && is_FLOW_INDICATOR(following)) {\n return false;\n }\n }\n\n state.kind = 'scalar';\n state.result = '';\n captureStart = captureEnd = state.position;\n hasPendingContent = false;\n\n while (ch !== 0) {\n if (ch === 0x3A/* : */) {\n following = state.input.charCodeAt(state.position + 1);\n\n if (is_WS_OR_EOL(following) ||\n withinFlowCollection && is_FLOW_INDICATOR(following)) {\n break;\n }\n\n } else if (ch === 0x23/* # */) {\n preceding = state.input.charCodeAt(state.position - 1);\n\n if (is_WS_OR_EOL(preceding)) {\n break;\n }\n\n } else if ((state.position === state.lineStart && testDocumentSeparator(state)) ||\n withinFlowCollection && is_FLOW_INDICATOR(ch)) {\n break;\n\n } else if (is_EOL(ch)) {\n _line = state.line;\n _lineStart = state.lineStart;\n _lineIndent = state.lineIndent;\n skipSeparationSpace(state, false, -1);\n\n if (state.lineIndent >= nodeIndent) {\n hasPendingContent = true;\n ch = state.input.charCodeAt(state.position);\n continue;\n } else {\n state.position = captureEnd;\n state.line = _line;\n state.lineStart = _lineStart;\n state.lineIndent = _lineIndent;\n break;\n }\n }\n\n if (hasPendingContent) {\n captureSegment(state, captureStart, captureEnd, false);\n writeFoldedLines(state, state.line - _line);\n captureStart = captureEnd = state.position;\n hasPendingContent = false;\n }\n\n if (!is_WHITE_SPACE(ch)) {\n captureEnd = state.position + 1;\n }\n\n ch = state.input.charCodeAt(++state.position);\n }\n\n captureSegment(state, captureStart, captureEnd, false);\n\n if (state.result) {\n return true;\n }\n\n state.kind = _kind;\n state.result = _result;\n return false;\n}\n\nfunction readSingleQuotedScalar(state, nodeIndent) {\n var ch,\n captureStart, captureEnd;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch !== 0x27/* ' */) {\n return false;\n }\n\n state.kind = 'scalar';\n state.result = '';\n state.position++;\n captureStart = captureEnd = state.position;\n\n while ((ch = state.input.charCodeAt(state.position)) !== 0) {\n if (ch === 0x27/* ' */) {\n captureSegment(state, captureStart, state.position, true);\n ch = state.input.charCodeAt(++state.position);\n\n if (ch === 0x27/* ' */) {\n captureStart = state.position;\n state.position++;\n captureEnd = state.position;\n } else {\n return true;\n }\n\n } else if (is_EOL(ch)) {\n captureSegment(state, captureStart, captureEnd, true);\n writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n captureStart = captureEnd = state.position;\n\n } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n throwError(state, 'unexpected end of the document within a single quoted scalar');\n\n } else {\n state.position++;\n captureEnd = state.position;\n }\n }\n\n throwError(state, 'unexpected end of the stream within a single quoted scalar');\n}\n\nfunction readDoubleQuotedScalar(state, nodeIndent) {\n var captureStart,\n captureEnd,\n hexLength,\n hexResult,\n tmp,\n ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch !== 0x22/* \" */) {\n return false;\n }\n\n state.kind = 'scalar';\n state.result = '';\n state.position++;\n captureStart = captureEnd = state.position;\n\n while ((ch = state.input.charCodeAt(state.position)) !== 0) {\n if (ch === 0x22/* \" */) {\n captureSegment(state, captureStart, state.position, true);\n state.position++;\n return true;\n\n } else if (ch === 0x5C/* \\ */) {\n captureSegment(state, captureStart, state.position, true);\n ch = state.input.charCodeAt(++state.position);\n\n if (is_EOL(ch)) {\n skipSeparationSpace(state, false, nodeIndent);\n\n // TODO: rework to inline fn with no type cast?\n } else if (ch < 256 && simpleEscapeCheck[ch]) {\n state.result += simpleEscapeMap[ch];\n state.position++;\n\n } else if ((tmp = escapedHexLen(ch)) > 0) {\n hexLength = tmp;\n hexResult = 0;\n\n for (; hexLength > 0; hexLength--) {\n ch = state.input.charCodeAt(++state.position);\n\n if ((tmp = fromHexCode(ch)) >= 0) {\n hexResult = (hexResult << 4) + tmp;\n\n } else {\n throwError(state, 'expected hexadecimal character');\n }\n }\n\n state.result += charFromCodepoint(hexResult);\n\n state.position++;\n\n } else {\n throwError(state, 'unknown escape sequence');\n }\n\n captureStart = captureEnd = state.position;\n\n } else if (is_EOL(ch)) {\n captureSegment(state, captureStart, captureEnd, true);\n writeFoldedLines(state, skipSeparationSpace(state, false, nodeIndent));\n captureStart = captureEnd = state.position;\n\n } else if (state.position === state.lineStart && testDocumentSeparator(state)) {\n throwError(state, 'unexpected end of the document within a double quoted scalar');\n\n } else {\n state.position++;\n captureEnd = state.position;\n }\n }\n\n throwError(state, 'unexpected end of the stream within a double quoted scalar');\n}\n\nfunction readFlowCollection(state, nodeIndent) {\n var readNext = true,\n _line,\n _lineStart,\n _pos,\n _tag = state.tag,\n _result,\n _anchor = state.anchor,\n following,\n terminator,\n isPair,\n isExplicitPair,\n isMapping,\n overridableKeys = Object.create(null),\n keyNode,\n keyTag,\n valueNode,\n ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch === 0x5B/* [ */) {\n terminator = 0x5D;/* ] */\n isMapping = false;\n _result = [];\n } else if (ch === 0x7B/* { */) {\n terminator = 0x7D;/* } */\n isMapping = true;\n _result = {};\n } else {\n return false;\n }\n\n if (state.anchor !== null) {\n state.anchorMap[state.anchor] = _result;\n }\n\n ch = state.input.charCodeAt(++state.position);\n\n while (ch !== 0) {\n skipSeparationSpace(state, true, nodeIndent);\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch === terminator) {\n state.position++;\n state.tag = _tag;\n state.anchor = _anchor;\n state.kind = isMapping ? 'mapping' : 'sequence';\n state.result = _result;\n return true;\n } else if (!readNext) {\n throwError(state, 'missed comma between flow collection entries');\n } else if (ch === 0x2C/* , */) {\n // \"flow collection entries can never be completely empty\", as per YAML 1.2, section 7.4\n throwError(state, \"expected the node content, but found ','\");\n }\n\n keyTag = keyNode = valueNode = null;\n isPair = isExplicitPair = false;\n\n if (ch === 0x3F/* ? */) {\n following = state.input.charCodeAt(state.position + 1);\n\n if (is_WS_OR_EOL(following)) {\n isPair = isExplicitPair = true;\n state.position++;\n skipSeparationSpace(state, true, nodeIndent);\n }\n }\n\n _line = state.line; // Save the current line.\n _lineStart = state.lineStart;\n _pos = state.position;\n composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n keyTag = state.tag;\n keyNode = state.result;\n skipSeparationSpace(state, true, nodeIndent);\n\n ch = state.input.charCodeAt(state.position);\n\n if ((isExplicitPair || state.line === _line) && ch === 0x3A/* : */) {\n isPair = true;\n ch = state.input.charCodeAt(++state.position);\n skipSeparationSpace(state, true, nodeIndent);\n composeNode(state, nodeIndent, CONTEXT_FLOW_IN, false, true);\n valueNode = state.result;\n }\n\n if (isMapping) {\n storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos);\n } else if (isPair) {\n _result.push(storeMappingPair(state, null, overridableKeys, keyTag, keyNode, valueNode, _line, _lineStart, _pos));\n } else {\n _result.push(keyNode);\n }\n\n skipSeparationSpace(state, true, nodeIndent);\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch === 0x2C/* , */) {\n readNext = true;\n ch = state.input.charCodeAt(++state.position);\n } else {\n readNext = false;\n }\n }\n\n throwError(state, 'unexpected end of the stream within a flow collection');\n}\n\nfunction readBlockScalar(state, nodeIndent) {\n var captureStart,\n folding,\n chomping = CHOMPING_CLIP,\n didReadContent = false,\n detectedIndent = false,\n textIndent = nodeIndent,\n emptyLines = 0,\n atMoreIndented = false,\n tmp,\n ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch === 0x7C/* | */) {\n folding = false;\n } else if (ch === 0x3E/* > */) {\n folding = true;\n } else {\n return false;\n }\n\n state.kind = 'scalar';\n state.result = '';\n\n while (ch !== 0) {\n ch = state.input.charCodeAt(++state.position);\n\n if (ch === 0x2B/* + */ || ch === 0x2D/* - */) {\n if (CHOMPING_CLIP === chomping) {\n chomping = (ch === 0x2B/* + */) ? CHOMPING_KEEP : CHOMPING_STRIP;\n } else {\n throwError(state, 'repeat of a chomping mode identifier');\n }\n\n } else if ((tmp = fromDecimalCode(ch)) >= 0) {\n if (tmp === 0) {\n throwError(state, 'bad explicit indentation width of a block scalar; it cannot be less than one');\n } else if (!detectedIndent) {\n textIndent = nodeIndent + tmp - 1;\n detectedIndent = true;\n } else {\n throwError(state, 'repeat of an indentation width identifier');\n }\n\n } else {\n break;\n }\n }\n\n if (is_WHITE_SPACE(ch)) {\n do { ch = state.input.charCodeAt(++state.position); }\n while (is_WHITE_SPACE(ch));\n\n if (ch === 0x23/* # */) {\n do { ch = state.input.charCodeAt(++state.position); }\n while (!is_EOL(ch) && (ch !== 0));\n }\n }\n\n while (ch !== 0) {\n readLineBreak(state);\n state.lineIndent = 0;\n\n ch = state.input.charCodeAt(state.position);\n\n while ((!detectedIndent || state.lineIndent < textIndent) &&\n (ch === 0x20/* Space */)) {\n state.lineIndent++;\n ch = state.input.charCodeAt(++state.position);\n }\n\n if (!detectedIndent && state.lineIndent > textIndent) {\n textIndent = state.lineIndent;\n }\n\n if (is_EOL(ch)) {\n emptyLines++;\n continue;\n }\n\n // End of the scalar.\n if (state.lineIndent < textIndent) {\n\n // Perform the chomping.\n if (chomping === CHOMPING_KEEP) {\n state.result += common.repeat('\\n', didReadContent ? 1 + emptyLines : emptyLines);\n } else if (chomping === CHOMPING_CLIP) {\n if (didReadContent) { // i.e. only if the scalar is not empty.\n state.result += '\\n';\n }\n }\n\n // Break this `while` cycle and go to the funciton's epilogue.\n break;\n }\n\n // Folded style: use fancy rules to handle line breaks.\n if (folding) {\n\n // Lines starting with white space characters (more-indented lines) are not folded.\n if (is_WHITE_SPACE(ch)) {\n atMoreIndented = true;\n // except for the first content line (cf. Example 8.1)\n state.result += common.repeat('\\n', didReadContent ? 1 + emptyLines : emptyLines);\n\n // End of more-indented block.\n } else if (atMoreIndented) {\n atMoreIndented = false;\n state.result += common.repeat('\\n', emptyLines + 1);\n\n // Just one line break - perceive as the same line.\n } else if (emptyLines === 0) {\n if (didReadContent) { // i.e. only if we have already read some scalar content.\n state.result += ' ';\n }\n\n // Several line breaks - perceive as different lines.\n } else {\n state.result += common.repeat('\\n', emptyLines);\n }\n\n // Literal style: just add exact number of line breaks between content lines.\n } else {\n // Keep all line breaks except the header line break.\n state.result += common.repeat('\\n', didReadContent ? 1 + emptyLines : emptyLines);\n }\n\n didReadContent = true;\n detectedIndent = true;\n emptyLines = 0;\n captureStart = state.position;\n\n while (!is_EOL(ch) && (ch !== 0)) {\n ch = state.input.charCodeAt(++state.position);\n }\n\n captureSegment(state, captureStart, state.position, false);\n }\n\n return true;\n}\n\nfunction readBlockSequence(state, nodeIndent) {\n var _line,\n _tag = state.tag,\n _anchor = state.anchor,\n _result = [],\n following,\n detected = false,\n ch;\n\n // there is a leading tab before this token, so it can't be a block sequence/mapping;\n // it can still be flow sequence/mapping or a scalar\n if (state.firstTabInLine !== -1) return false;\n\n if (state.anchor !== null) {\n state.anchorMap[state.anchor] = _result;\n }\n\n ch = state.input.charCodeAt(state.position);\n\n while (ch !== 0) {\n if (state.firstTabInLine !== -1) {\n state.position = state.firstTabInLine;\n throwError(state, 'tab characters must not be used in indentation');\n }\n\n if (ch !== 0x2D/* - */) {\n break;\n }\n\n following = state.input.charCodeAt(state.position + 1);\n\n if (!is_WS_OR_EOL(following)) {\n break;\n }\n\n detected = true;\n state.position++;\n\n if (skipSeparationSpace(state, true, -1)) {\n if (state.lineIndent <= nodeIndent) {\n _result.push(null);\n ch = state.input.charCodeAt(state.position);\n continue;\n }\n }\n\n _line = state.line;\n composeNode(state, nodeIndent, CONTEXT_BLOCK_IN, false, true);\n _result.push(state.result);\n skipSeparationSpace(state, true, -1);\n\n ch = state.input.charCodeAt(state.position);\n\n if ((state.line === _line || state.lineIndent > nodeIndent) && (ch !== 0)) {\n throwError(state, 'bad indentation of a sequence entry');\n } else if (state.lineIndent < nodeIndent) {\n break;\n }\n }\n\n if (detected) {\n state.tag = _tag;\n state.anchor = _anchor;\n state.kind = 'sequence';\n state.result = _result;\n return true;\n }\n return false;\n}\n\nfunction readBlockMapping(state, nodeIndent, flowIndent) {\n var following,\n allowCompact,\n _line,\n _keyLine,\n _keyLineStart,\n _keyPos,\n _tag = state.tag,\n _anchor = state.anchor,\n _result = {},\n overridableKeys = Object.create(null),\n keyTag = null,\n keyNode = null,\n valueNode = null,\n atExplicitKey = false,\n detected = false,\n ch;\n\n // there is a leading tab before this token, so it can't be a block sequence/mapping;\n // it can still be flow sequence/mapping or a scalar\n if (state.firstTabInLine !== -1) return false;\n\n if (state.anchor !== null) {\n state.anchorMap[state.anchor] = _result;\n }\n\n ch = state.input.charCodeAt(state.position);\n\n while (ch !== 0) {\n if (!atExplicitKey && state.firstTabInLine !== -1) {\n state.position = state.firstTabInLine;\n throwError(state, 'tab characters must not be used in indentation');\n }\n\n following = state.input.charCodeAt(state.position + 1);\n _line = state.line; // Save the current line.\n\n //\n // Explicit notation case. There are two separate blocks:\n // first for the key (denoted by \"?\") and second for the value (denoted by \":\")\n //\n if ((ch === 0x3F/* ? */ || ch === 0x3A/* : */) && is_WS_OR_EOL(following)) {\n\n if (ch === 0x3F/* ? */) {\n if (atExplicitKey) {\n storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos);\n keyTag = keyNode = valueNode = null;\n }\n\n detected = true;\n atExplicitKey = true;\n allowCompact = true;\n\n } else if (atExplicitKey) {\n // i.e. 0x3A/* : */ === character after the explicit key.\n atExplicitKey = false;\n allowCompact = true;\n\n } else {\n throwError(state, 'incomplete explicit mapping pair; a key node is missed; or followed by a non-tabulated empty line');\n }\n\n state.position += 1;\n ch = following;\n\n //\n // Implicit notation case. Flow-style node as the key first, then \":\", and the value.\n //\n } else {\n _keyLine = state.line;\n _keyLineStart = state.lineStart;\n _keyPos = state.position;\n\n if (!composeNode(state, flowIndent, CONTEXT_FLOW_OUT, false, true)) {\n // Neither implicit nor explicit notation.\n // Reading is done. Go to the epilogue.\n break;\n }\n\n if (state.line === _line) {\n ch = state.input.charCodeAt(state.position);\n\n while (is_WHITE_SPACE(ch)) {\n ch = state.input.charCodeAt(++state.position);\n }\n\n if (ch === 0x3A/* : */) {\n ch = state.input.charCodeAt(++state.position);\n\n if (!is_WS_OR_EOL(ch)) {\n throwError(state, 'a whitespace character is expected after the key-value separator within a block mapping');\n }\n\n if (atExplicitKey) {\n storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos);\n keyTag = keyNode = valueNode = null;\n }\n\n detected = true;\n atExplicitKey = false;\n allowCompact = false;\n keyTag = state.tag;\n keyNode = state.result;\n\n } else if (detected) {\n throwError(state, 'can not read an implicit mapping pair; a colon is missed');\n\n } else {\n state.tag = _tag;\n state.anchor = _anchor;\n return true; // Keep the result of `composeNode`.\n }\n\n } else if (detected) {\n throwError(state, 'can not read a block mapping entry; a multiline key may not be an implicit key');\n\n } else {\n state.tag = _tag;\n state.anchor = _anchor;\n return true; // Keep the result of `composeNode`.\n }\n }\n\n //\n // Common reading code for both explicit and implicit notations.\n //\n if (state.line === _line || state.lineIndent > nodeIndent) {\n if (atExplicitKey) {\n _keyLine = state.line;\n _keyLineStart = state.lineStart;\n _keyPos = state.position;\n }\n\n if (composeNode(state, nodeIndent, CONTEXT_BLOCK_OUT, true, allowCompact)) {\n if (atExplicitKey) {\n keyNode = state.result;\n } else {\n valueNode = state.result;\n }\n }\n\n if (!atExplicitKey) {\n storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, valueNode, _keyLine, _keyLineStart, _keyPos);\n keyTag = keyNode = valueNode = null;\n }\n\n skipSeparationSpace(state, true, -1);\n ch = state.input.charCodeAt(state.position);\n }\n\n if ((state.line === _line || state.lineIndent > nodeIndent) && (ch !== 0)) {\n throwError(state, 'bad indentation of a mapping entry');\n } else if (state.lineIndent < nodeIndent) {\n break;\n }\n }\n\n //\n // Epilogue.\n //\n\n // Special case: last mapping's node contains only the key in explicit notation.\n if (atExplicitKey) {\n storeMappingPair(state, _result, overridableKeys, keyTag, keyNode, null, _keyLine, _keyLineStart, _keyPos);\n }\n\n // Expose the resulting mapping.\n if (detected) {\n state.tag = _tag;\n state.anchor = _anchor;\n state.kind = 'mapping';\n state.result = _result;\n }\n\n return detected;\n}\n\nfunction readTagProperty(state) {\n var _position,\n isVerbatim = false,\n isNamed = false,\n tagHandle,\n tagName,\n ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch !== 0x21/* ! */) return false;\n\n if (state.tag !== null) {\n throwError(state, 'duplication of a tag property');\n }\n\n ch = state.input.charCodeAt(++state.position);\n\n if (ch === 0x3C/* < */) {\n isVerbatim = true;\n ch = state.input.charCodeAt(++state.position);\n\n } else if (ch === 0x21/* ! */) {\n isNamed = true;\n tagHandle = '!!';\n ch = state.input.charCodeAt(++state.position);\n\n } else {\n tagHandle = '!';\n }\n\n _position = state.position;\n\n if (isVerbatim) {\n do { ch = state.input.charCodeAt(++state.position); }\n while (ch !== 0 && ch !== 0x3E/* > */);\n\n if (state.position < state.length) {\n tagName = state.input.slice(_position, state.position);\n ch = state.input.charCodeAt(++state.position);\n } else {\n throwError(state, 'unexpected end of the stream within a verbatim tag');\n }\n } else {\n while (ch !== 0 && !is_WS_OR_EOL(ch)) {\n\n if (ch === 0x21/* ! */) {\n if (!isNamed) {\n tagHandle = state.input.slice(_position - 1, state.position + 1);\n\n if (!PATTERN_TAG_HANDLE.test(tagHandle)) {\n throwError(state, 'named tag handle cannot contain such characters');\n }\n\n isNamed = true;\n _position = state.position + 1;\n } else {\n throwError(state, 'tag suffix cannot contain exclamation marks');\n }\n }\n\n ch = state.input.charCodeAt(++state.position);\n }\n\n tagName = state.input.slice(_position, state.position);\n\n if (PATTERN_FLOW_INDICATORS.test(tagName)) {\n throwError(state, 'tag suffix cannot contain flow indicator characters');\n }\n }\n\n if (tagName && !PATTERN_TAG_URI.test(tagName)) {\n throwError(state, 'tag name cannot contain such characters: ' + tagName);\n }\n\n try {\n tagName = decodeURIComponent(tagName);\n } catch (err) {\n throwError(state, 'tag name is malformed: ' + tagName);\n }\n\n if (isVerbatim) {\n state.tag = tagName;\n\n } else if (_hasOwnProperty$1.call(state.tagMap, tagHandle)) {\n state.tag = state.tagMap[tagHandle] + tagName;\n\n } else if (tagHandle === '!') {\n state.tag = '!' + tagName;\n\n } else if (tagHandle === '!!') {\n state.tag = 'tag:yaml.org,2002:' + tagName;\n\n } else {\n throwError(state, 'undeclared tag handle \"' + tagHandle + '\"');\n }\n\n return true;\n}\n\nfunction readAnchorProperty(state) {\n var _position,\n ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch !== 0x26/* & */) return false;\n\n if (state.anchor !== null) {\n throwError(state, 'duplication of an anchor property');\n }\n\n ch = state.input.charCodeAt(++state.position);\n _position = state.position;\n\n while (ch !== 0 && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n ch = state.input.charCodeAt(++state.position);\n }\n\n if (state.position === _position) {\n throwError(state, 'name of an anchor node must contain at least one character');\n }\n\n state.anchor = state.input.slice(_position, state.position);\n return true;\n}\n\nfunction readAlias(state) {\n var _position, alias,\n ch;\n\n ch = state.input.charCodeAt(state.position);\n\n if (ch !== 0x2A/* * */) return false;\n\n ch = state.input.charCodeAt(++state.position);\n _position = state.position;\n\n while (ch !== 0 && !is_WS_OR_EOL(ch) && !is_FLOW_INDICATOR(ch)) {\n ch = state.input.charCodeAt(++state.position);\n }\n\n if (state.position === _position) {\n throwError(state, 'name of an alias node must contain at least one character');\n }\n\n alias = state.input.slice(_position, state.position);\n\n if (!_hasOwnProperty$1.call(state.anchorMap, alias)) {\n throwError(state, 'unidentified alias \"' + alias + '\"');\n }\n\n state.result = state.anchorMap[alias];\n skipSeparationSpace(state, true, -1);\n return true;\n}\n\nfunction composeNode(state, parentIndent, nodeContext, allowToSeek, allowCompact) {\n var allowBlockStyles,\n allowBlockScalars,\n allowBlockCollections,\n indentStatus = 1, // 1: this>parent, 0: this=parent, -1: this parentIndent) {\n indentStatus = 1;\n } else if (state.lineIndent === parentIndent) {\n indentStatus = 0;\n } else if (state.lineIndent < parentIndent) {\n indentStatus = -1;\n }\n }\n }\n\n if (indentStatus === 1) {\n while (readTagProperty(state) || readAnchorProperty(state)) {\n if (skipSeparationSpace(state, true, -1)) {\n atNewLine = true;\n allowBlockCollections = allowBlockStyles;\n\n if (state.lineIndent > parentIndent) {\n indentStatus = 1;\n } else if (state.lineIndent === parentIndent) {\n indentStatus = 0;\n } else if (state.lineIndent < parentIndent) {\n indentStatus = -1;\n }\n } else {\n allowBlockCollections = false;\n }\n }\n }\n\n if (allowBlockCollections) {\n allowBlockCollections = atNewLine || allowCompact;\n }\n\n if (indentStatus === 1 || CONTEXT_BLOCK_OUT === nodeContext) {\n if (CONTEXT_FLOW_IN === nodeContext || CONTEXT_FLOW_OUT === nodeContext) {\n flowIndent = parentIndent;\n } else {\n flowIndent = parentIndent + 1;\n }\n\n blockIndent = state.position - state.lineStart;\n\n if (indentStatus === 1) {\n if (allowBlockCollections &&\n (readBlockSequence(state, blockIndent) ||\n readBlockMapping(state, blockIndent, flowIndent)) ||\n readFlowCollection(state, flowIndent)) {\n hasContent = true;\n } else {\n if ((allowBlockScalars && readBlockScalar(state, flowIndent)) ||\n readSingleQuotedScalar(state, flowIndent) ||\n readDoubleQuotedScalar(state, flowIndent)) {\n hasContent = true;\n\n } else if (readAlias(state)) {\n hasContent = true;\n\n if (state.tag !== null || state.anchor !== null) {\n throwError(state, 'alias node should not have any properties');\n }\n\n } else if (readPlainScalar(state, flowIndent, CONTEXT_FLOW_IN === nodeContext)) {\n hasContent = true;\n\n if (state.tag === null) {\n state.tag = '?';\n }\n }\n\n if (state.anchor !== null) {\n state.anchorMap[state.anchor] = state.result;\n }\n }\n } else if (indentStatus === 0) {\n // Special case: block sequences are allowed to have same indentation level as the parent.\n // http://www.yaml.org/spec/1.2/spec.html#id2799784\n hasContent = allowBlockCollections && readBlockSequence(state, blockIndent);\n }\n }\n\n if (state.tag === null) {\n if (state.anchor !== null) {\n state.anchorMap[state.anchor] = state.result;\n }\n\n } else if (state.tag === '?') {\n // Implicit resolving is not allowed for non-scalar types, and '?'\n // non-specific tag is only automatically assigned to plain scalars.\n //\n // We only need to check kind conformity in case user explicitly assigns '?'\n // tag, for example like this: \"! [0]\"\n //\n if (state.result !== null && state.kind !== 'scalar') {\n throwError(state, 'unacceptable node kind for ! tag; it should be \"scalar\", not \"' + state.kind + '\"');\n }\n\n for (typeIndex = 0, typeQuantity = state.implicitTypes.length; typeIndex < typeQuantity; typeIndex += 1) {\n type = state.implicitTypes[typeIndex];\n\n if (type.resolve(state.result)) { // `state.result` updated in resolver if matched\n state.result = type.construct(state.result);\n state.tag = type.tag;\n if (state.anchor !== null) {\n state.anchorMap[state.anchor] = state.result;\n }\n break;\n }\n }\n } else if (state.tag !== '!') {\n if (_hasOwnProperty$1.call(state.typeMap[state.kind || 'fallback'], state.tag)) {\n type = state.typeMap[state.kind || 'fallback'][state.tag];\n } else {\n // looking for multi type\n type = null;\n typeList = state.typeMap.multi[state.kind || 'fallback'];\n\n for (typeIndex = 0, typeQuantity = typeList.length; typeIndex < typeQuantity; typeIndex += 1) {\n if (state.tag.slice(0, typeList[typeIndex].tag.length) === typeList[typeIndex].tag) {\n type = typeList[typeIndex];\n break;\n }\n }\n }\n\n if (!type) {\n throwError(state, 'unknown tag !<' + state.tag + '>');\n }\n\n if (state.result !== null && type.kind !== state.kind) {\n throwError(state, 'unacceptable node kind for !<' + state.tag + '> tag; it should be \"' + type.kind + '\", not \"' + state.kind + '\"');\n }\n\n if (!type.resolve(state.result, state.tag)) { // `state.result` updated in resolver if matched\n throwError(state, 'cannot resolve a node with !<' + state.tag + '> explicit tag');\n } else {\n state.result = type.construct(state.result, state.tag);\n if (state.anchor !== null) {\n state.anchorMap[state.anchor] = state.result;\n }\n }\n }\n\n if (state.listener !== null) {\n state.listener('close', state);\n }\n return state.tag !== null || state.anchor !== null || hasContent;\n}\n\nfunction readDocument(state) {\n var documentStart = state.position,\n _position,\n directiveName,\n directiveArgs,\n hasDirectives = false,\n ch;\n\n state.version = null;\n state.checkLineBreaks = state.legacy;\n state.tagMap = Object.create(null);\n state.anchorMap = Object.create(null);\n\n while ((ch = state.input.charCodeAt(state.position)) !== 0) {\n skipSeparationSpace(state, true, -1);\n\n ch = state.input.charCodeAt(state.position);\n\n if (state.lineIndent > 0 || ch !== 0x25/* % */) {\n break;\n }\n\n hasDirectives = true;\n ch = state.input.charCodeAt(++state.position);\n _position = state.position;\n\n while (ch !== 0 && !is_WS_OR_EOL(ch)) {\n ch = state.input.charCodeAt(++state.position);\n }\n\n directiveName = state.input.slice(_position, state.position);\n directiveArgs = [];\n\n if (directiveName.length < 1) {\n throwError(state, 'directive name must not be less than one character in length');\n }\n\n while (ch !== 0) {\n while (is_WHITE_SPACE(ch)) {\n ch = state.input.charCodeAt(++state.position);\n }\n\n if (ch === 0x23/* # */) {\n do { ch = state.input.charCodeAt(++state.position); }\n while (ch !== 0 && !is_EOL(ch));\n break;\n }\n\n if (is_EOL(ch)) break;\n\n _position = state.position;\n\n while (ch !== 0 && !is_WS_OR_EOL(ch)) {\n ch = state.input.charCodeAt(++state.position);\n }\n\n directiveArgs.push(state.input.slice(_position, state.position));\n }\n\n if (ch !== 0) readLineBreak(state);\n\n if (_hasOwnProperty$1.call(directiveHandlers, directiveName)) {\n directiveHandlers[directiveName](state, directiveName, directiveArgs);\n } else {\n throwWarning(state, 'unknown document directive \"' + directiveName + '\"');\n }\n }\n\n skipSeparationSpace(state, true, -1);\n\n if (state.lineIndent === 0 &&\n state.input.charCodeAt(state.position) === 0x2D/* - */ &&\n state.input.charCodeAt(state.position + 1) === 0x2D/* - */ &&\n state.input.charCodeAt(state.position + 2) === 0x2D/* - */) {\n state.position += 3;\n skipSeparationSpace(state, true, -1);\n\n } else if (hasDirectives) {\n throwError(state, 'directives end mark is expected');\n }\n\n composeNode(state, state.lineIndent - 1, CONTEXT_BLOCK_OUT, false, true);\n skipSeparationSpace(state, true, -1);\n\n if (state.checkLineBreaks &&\n PATTERN_NON_ASCII_LINE_BREAKS.test(state.input.slice(documentStart, state.position))) {\n throwWarning(state, 'non-ASCII line breaks are interpreted as content');\n }\n\n state.documents.push(state.result);\n\n if (state.position === state.lineStart && testDocumentSeparator(state)) {\n\n if (state.input.charCodeAt(state.position) === 0x2E/* . */) {\n state.position += 3;\n skipSeparationSpace(state, true, -1);\n }\n return;\n }\n\n if (state.position < (state.length - 1)) {\n throwError(state, 'end of the stream or a document separator is expected');\n } else {\n return;\n }\n}\n\n\nfunction loadDocuments(input, options) {\n input = String(input);\n options = options || {};\n\n if (input.length !== 0) {\n\n // Add tailing `\\n` if not exists\n if (input.charCodeAt(input.length - 1) !== 0x0A/* LF */ &&\n input.charCodeAt(input.length - 1) !== 0x0D/* CR */) {\n input += '\\n';\n }\n\n // Strip BOM\n if (input.charCodeAt(0) === 0xFEFF) {\n input = input.slice(1);\n }\n }\n\n var state = new State$1(input, options);\n\n var nullpos = input.indexOf('\\0');\n\n if (nullpos !== -1) {\n state.position = nullpos;\n throwError(state, 'null byte is not allowed in input');\n }\n\n // Use 0 as string terminator. That significantly simplifies bounds check.\n state.input += '\\0';\n\n while (state.input.charCodeAt(state.position) === 0x20/* Space */) {\n state.lineIndent += 1;\n state.position += 1;\n }\n\n while (state.position < (state.length - 1)) {\n readDocument(state);\n }\n\n return state.documents;\n}\n\n\nfunction loadAll$1(input, iterator, options) {\n if (iterator !== null && typeof iterator === 'object' && typeof options === 'undefined') {\n options = iterator;\n iterator = null;\n }\n\n var documents = loadDocuments(input, options);\n\n if (typeof iterator !== 'function') {\n return documents;\n }\n\n for (var index = 0, length = documents.length; index < length; index += 1) {\n iterator(documents[index]);\n }\n}\n\n\nfunction load$1(input, options) {\n var documents = loadDocuments(input, options);\n\n if (documents.length === 0) {\n /*eslint-disable no-undefined*/\n return undefined;\n } else if (documents.length === 1) {\n return documents[0];\n }\n throw new exception('expected a single document in the stream, but found more');\n}\n\n\nvar loadAll_1 = loadAll$1;\nvar load_1 = load$1;\n\nvar loader = {\n\tloadAll: loadAll_1,\n\tload: load_1\n};\n\n/*eslint-disable no-use-before-define*/\n\n\n\n\n\nvar _toString = Object.prototype.toString;\nvar _hasOwnProperty = Object.prototype.hasOwnProperty;\n\nvar CHAR_BOM = 0xFEFF;\nvar CHAR_TAB = 0x09; /* Tab */\nvar CHAR_LINE_FEED = 0x0A; /* LF */\nvar CHAR_CARRIAGE_RETURN = 0x0D; /* CR */\nvar CHAR_SPACE = 0x20; /* Space */\nvar CHAR_EXCLAMATION = 0x21; /* ! */\nvar CHAR_DOUBLE_QUOTE = 0x22; /* \" */\nvar CHAR_SHARP = 0x23; /* # */\nvar CHAR_PERCENT = 0x25; /* % */\nvar CHAR_AMPERSAND = 0x26; /* & */\nvar CHAR_SINGLE_QUOTE = 0x27; /* ' */\nvar CHAR_ASTERISK = 0x2A; /* * */\nvar CHAR_COMMA = 0x2C; /* , */\nvar CHAR_MINUS = 0x2D; /* - */\nvar CHAR_COLON = 0x3A; /* : */\nvar CHAR_EQUALS = 0x3D; /* = */\nvar CHAR_GREATER_THAN = 0x3E; /* > */\nvar CHAR_QUESTION = 0x3F; /* ? */\nvar CHAR_COMMERCIAL_AT = 0x40; /* @ */\nvar CHAR_LEFT_SQUARE_BRACKET = 0x5B; /* [ */\nvar CHAR_RIGHT_SQUARE_BRACKET = 0x5D; /* ] */\nvar CHAR_GRAVE_ACCENT = 0x60; /* ` */\nvar CHAR_LEFT_CURLY_BRACKET = 0x7B; /* { */\nvar CHAR_VERTICAL_LINE = 0x7C; /* | */\nvar CHAR_RIGHT_CURLY_BRACKET = 0x7D; /* } */\n\nvar ESCAPE_SEQUENCES = {};\n\nESCAPE_SEQUENCES[0x00] = '\\\\0';\nESCAPE_SEQUENCES[0x07] = '\\\\a';\nESCAPE_SEQUENCES[0x08] = '\\\\b';\nESCAPE_SEQUENCES[0x09] = '\\\\t';\nESCAPE_SEQUENCES[0x0A] = '\\\\n';\nESCAPE_SEQUENCES[0x0B] = '\\\\v';\nESCAPE_SEQUENCES[0x0C] = '\\\\f';\nESCAPE_SEQUENCES[0x0D] = '\\\\r';\nESCAPE_SEQUENCES[0x1B] = '\\\\e';\nESCAPE_SEQUENCES[0x22] = '\\\\\"';\nESCAPE_SEQUENCES[0x5C] = '\\\\\\\\';\nESCAPE_SEQUENCES[0x85] = '\\\\N';\nESCAPE_SEQUENCES[0xA0] = '\\\\_';\nESCAPE_SEQUENCES[0x2028] = '\\\\L';\nESCAPE_SEQUENCES[0x2029] = '\\\\P';\n\nvar DEPRECATED_BOOLEANS_SYNTAX = [\n 'y', 'Y', 'yes', 'Yes', 'YES', 'on', 'On', 'ON',\n 'n', 'N', 'no', 'No', 'NO', 'off', 'Off', 'OFF'\n];\n\nvar DEPRECATED_BASE60_SYNTAX = /^[-+]?[0-9_]+(?::[0-9_]+)+(?:\\.[0-9_]*)?$/;\n\nfunction compileStyleMap(schema, map) {\n var result, keys, index, length, tag, style, type;\n\n if (map === null) return {};\n\n result = {};\n keys = Object.keys(map);\n\n for (index = 0, length = keys.length; index < length; index += 1) {\n tag = keys[index];\n style = String(map[tag]);\n\n if (tag.slice(0, 2) === '!!') {\n tag = 'tag:yaml.org,2002:' + tag.slice(2);\n }\n type = schema.compiledTypeMap['fallback'][tag];\n\n if (type && _hasOwnProperty.call(type.styleAliases, style)) {\n style = type.styleAliases[style];\n }\n\n result[tag] = style;\n }\n\n return result;\n}\n\nfunction encodeHex(character) {\n var string, handle, length;\n\n string = character.toString(16).toUpperCase();\n\n if (character <= 0xFF) {\n handle = 'x';\n length = 2;\n } else if (character <= 0xFFFF) {\n handle = 'u';\n length = 4;\n } else if (character <= 0xFFFFFFFF) {\n handle = 'U';\n length = 8;\n } else {\n throw new exception('code point within a string may not be greater than 0xFFFFFFFF');\n }\n\n return '\\\\' + handle + common.repeat('0', length - string.length) + string;\n}\n\n\nvar QUOTING_TYPE_SINGLE = 1,\n QUOTING_TYPE_DOUBLE = 2;\n\nfunction State(options) {\n this.schema = options['schema'] || _default;\n this.indent = Math.max(1, (options['indent'] || 2));\n this.noArrayIndent = options['noArrayIndent'] || false;\n this.skipInvalid = options['skipInvalid'] || false;\n this.flowLevel = (common.isNothing(options['flowLevel']) ? -1 : options['flowLevel']);\n this.styleMap = compileStyleMap(this.schema, options['styles'] || null);\n this.sortKeys = options['sortKeys'] || false;\n this.lineWidth = options['lineWidth'] || 80;\n this.noRefs = options['noRefs'] || false;\n this.noCompatMode = options['noCompatMode'] || false;\n this.condenseFlow = options['condenseFlow'] || false;\n this.quotingType = options['quotingType'] === '\"' ? QUOTING_TYPE_DOUBLE : QUOTING_TYPE_SINGLE;\n this.forceQuotes = options['forceQuotes'] || false;\n this.replacer = typeof options['replacer'] === 'function' ? options['replacer'] : null;\n\n this.implicitTypes = this.schema.compiledImplicit;\n this.explicitTypes = this.schema.compiledExplicit;\n\n this.tag = null;\n this.result = '';\n\n this.duplicates = [];\n this.usedDuplicates = null;\n}\n\n// Indents every line in a string. Empty lines (\\n only) are not indented.\nfunction indentString(string, spaces) {\n var ind = common.repeat(' ', spaces),\n position = 0,\n next = -1,\n result = '',\n line,\n length = string.length;\n\n while (position < length) {\n next = string.indexOf('\\n', position);\n if (next === -1) {\n line = string.slice(position);\n position = length;\n } else {\n line = string.slice(position, next + 1);\n position = next + 1;\n }\n\n if (line.length && line !== '\\n') result += ind;\n\n result += line;\n }\n\n return result;\n}\n\nfunction generateNextLine(state, level) {\n return '\\n' + common.repeat(' ', state.indent * level);\n}\n\nfunction testImplicitResolving(state, str) {\n var index, length, type;\n\n for (index = 0, length = state.implicitTypes.length; index < length; index += 1) {\n type = state.implicitTypes[index];\n\n if (type.resolve(str)) {\n return true;\n }\n }\n\n return false;\n}\n\n// [33] s-white ::= s-space | s-tab\nfunction isWhitespace(c) {\n return c === CHAR_SPACE || c === CHAR_TAB;\n}\n\n// Returns true if the character can be printed without escaping.\n// From YAML 1.2: \"any allowed characters known to be non-printable\n// should also be escaped. [However,] This isn’t mandatory\"\n// Derived from nb-char - \\t - #x85 - #xA0 - #x2028 - #x2029.\nfunction isPrintable(c) {\n return (0x00020 <= c && c <= 0x00007E)\n || ((0x000A1 <= c && c <= 0x00D7FF) && c !== 0x2028 && c !== 0x2029)\n || ((0x0E000 <= c && c <= 0x00FFFD) && c !== CHAR_BOM)\n || (0x10000 <= c && c <= 0x10FFFF);\n}\n\n// [34] ns-char ::= nb-char - s-white\n// [27] nb-char ::= c-printable - b-char - c-byte-order-mark\n// [26] b-char ::= b-line-feed | b-carriage-return\n// Including s-white (for some reason, examples doesn't match specs in this aspect)\n// ns-char ::= c-printable - b-line-feed - b-carriage-return - c-byte-order-mark\nfunction isNsCharOrWhitespace(c) {\n return isPrintable(c)\n && c !== CHAR_BOM\n // - b-char\n && c !== CHAR_CARRIAGE_RETURN\n && c !== CHAR_LINE_FEED;\n}\n\n// [127] ns-plain-safe(c) ::= c = flow-out ⇒ ns-plain-safe-out\n// c = flow-in ⇒ ns-plain-safe-in\n// c = block-key ⇒ ns-plain-safe-out\n// c = flow-key ⇒ ns-plain-safe-in\n// [128] ns-plain-safe-out ::= ns-char\n// [129] ns-plain-safe-in ::= ns-char - c-flow-indicator\n// [130] ns-plain-char(c) ::= ( ns-plain-safe(c) - “:” - “#” )\n// | ( /* An ns-char preceding */ “#” )\n// | ( “:” /* Followed by an ns-plain-safe(c) */ )\nfunction isPlainSafe(c, prev, inblock) {\n var cIsNsCharOrWhitespace = isNsCharOrWhitespace(c);\n var cIsNsChar = cIsNsCharOrWhitespace && !isWhitespace(c);\n return (\n // ns-plain-safe\n inblock ? // c = flow-in\n cIsNsCharOrWhitespace\n : cIsNsCharOrWhitespace\n // - c-flow-indicator\n && c !== CHAR_COMMA\n && c !== CHAR_LEFT_SQUARE_BRACKET\n && c !== CHAR_RIGHT_SQUARE_BRACKET\n && c !== CHAR_LEFT_CURLY_BRACKET\n && c !== CHAR_RIGHT_CURLY_BRACKET\n )\n // ns-plain-char\n && c !== CHAR_SHARP // false on '#'\n && !(prev === CHAR_COLON && !cIsNsChar) // false on ': '\n || (isNsCharOrWhitespace(prev) && !isWhitespace(prev) && c === CHAR_SHARP) // change to true on '[^ ]#'\n || (prev === CHAR_COLON && cIsNsChar); // change to true on ':[^ ]'\n}\n\n// Simplified test for values allowed as the first character in plain style.\nfunction isPlainSafeFirst(c) {\n // Uses a subset of ns-char - c-indicator\n // where ns-char = nb-char - s-white.\n // No support of ( ( “?” | “:” | “-” ) /* Followed by an ns-plain-safe(c)) */ ) part\n return isPrintable(c) && c !== CHAR_BOM\n && !isWhitespace(c) // - s-white\n // - (c-indicator ::=\n // “-” | “?” | “:” | “,” | “[” | “]” | “{” | “}”\n && c !== CHAR_MINUS\n && c !== CHAR_QUESTION\n && c !== CHAR_COLON\n && c !== CHAR_COMMA\n && c !== CHAR_LEFT_SQUARE_BRACKET\n && c !== CHAR_RIGHT_SQUARE_BRACKET\n && c !== CHAR_LEFT_CURLY_BRACKET\n && c !== CHAR_RIGHT_CURLY_BRACKET\n // | “#” | “&” | “*” | “!” | “|” | “=” | “>” | “'” | “\"”\n && c !== CHAR_SHARP\n && c !== CHAR_AMPERSAND\n && c !== CHAR_ASTERISK\n && c !== CHAR_EXCLAMATION\n && c !== CHAR_VERTICAL_LINE\n && c !== CHAR_EQUALS\n && c !== CHAR_GREATER_THAN\n && c !== CHAR_SINGLE_QUOTE\n && c !== CHAR_DOUBLE_QUOTE\n // | “%” | “@” | “`”)\n && c !== CHAR_PERCENT\n && c !== CHAR_COMMERCIAL_AT\n && c !== CHAR_GRAVE_ACCENT;\n}\n\n// Simplified test for values allowed as the last character in plain style.\nfunction isPlainSafeLast(c) {\n // just not whitespace or colon, it will be checked to be plain character later\n return !isWhitespace(c) && c !== CHAR_COLON;\n}\n\n// Same as 'string'.codePointAt(pos), but works in older browsers.\nfunction codePointAt(string, pos) {\n var first = string.charCodeAt(pos), second;\n if (first >= 0xD800 && first <= 0xDBFF && pos + 1 < string.length) {\n second = string.charCodeAt(pos + 1);\n if (second >= 0xDC00 && second <= 0xDFFF) {\n // https://mathiasbynens.be/notes/javascript-encoding#surrogate-formulae\n return (first - 0xD800) * 0x400 + second - 0xDC00 + 0x10000;\n }\n }\n return first;\n}\n\n// Determines whether block indentation indicator is required.\nfunction needIndentIndicator(string) {\n var leadingSpaceRe = /^\\n* /;\n return leadingSpaceRe.test(string);\n}\n\nvar STYLE_PLAIN = 1,\n STYLE_SINGLE = 2,\n STYLE_LITERAL = 3,\n STYLE_FOLDED = 4,\n STYLE_DOUBLE = 5;\n\n// Determines which scalar styles are possible and returns the preferred style.\n// lineWidth = -1 => no limit.\n// Pre-conditions: str.length > 0.\n// Post-conditions:\n// STYLE_PLAIN or STYLE_SINGLE => no \\n are in the string.\n// STYLE_LITERAL => no lines are suitable for folding (or lineWidth is -1).\n// STYLE_FOLDED => a line > lineWidth and can be folded (and lineWidth != -1).\nfunction chooseScalarStyle(string, singleLineOnly, indentPerLevel, lineWidth,\n testAmbiguousType, quotingType, forceQuotes, inblock) {\n\n var i;\n var char = 0;\n var prevChar = null;\n var hasLineBreak = false;\n var hasFoldableLine = false; // only checked if shouldTrackWidth\n var shouldTrackWidth = lineWidth !== -1;\n var previousLineBreak = -1; // count the first line correctly\n var plain = isPlainSafeFirst(codePointAt(string, 0))\n && isPlainSafeLast(codePointAt(string, string.length - 1));\n\n if (singleLineOnly || forceQuotes) {\n // Case: no block styles.\n // Check for disallowed characters to rule out plain and single.\n for (i = 0; i < string.length; char >= 0x10000 ? i += 2 : i++) {\n char = codePointAt(string, i);\n if (!isPrintable(char)) {\n return STYLE_DOUBLE;\n }\n plain = plain && isPlainSafe(char, prevChar, inblock);\n prevChar = char;\n }\n } else {\n // Case: block styles permitted.\n for (i = 0; i < string.length; char >= 0x10000 ? i += 2 : i++) {\n char = codePointAt(string, i);\n if (char === CHAR_LINE_FEED) {\n hasLineBreak = true;\n // Check if any line can be folded.\n if (shouldTrackWidth) {\n hasFoldableLine = hasFoldableLine ||\n // Foldable line = too long, and not more-indented.\n (i - previousLineBreak - 1 > lineWidth &&\n string[previousLineBreak + 1] !== ' ');\n previousLineBreak = i;\n }\n } else if (!isPrintable(char)) {\n return STYLE_DOUBLE;\n }\n plain = plain && isPlainSafe(char, prevChar, inblock);\n prevChar = char;\n }\n // in case the end is missing a \\n\n hasFoldableLine = hasFoldableLine || (shouldTrackWidth &&\n (i - previousLineBreak - 1 > lineWidth &&\n string[previousLineBreak + 1] !== ' '));\n }\n // Although every style can represent \\n without escaping, prefer block styles\n // for multiline, since they're more readable and they don't add empty lines.\n // Also prefer folding a super-long line.\n if (!hasLineBreak && !hasFoldableLine) {\n // Strings interpretable as another type have to be quoted;\n // e.g. the string 'true' vs. the boolean true.\n if (plain && !forceQuotes && !testAmbiguousType(string)) {\n return STYLE_PLAIN;\n }\n return quotingType === QUOTING_TYPE_DOUBLE ? STYLE_DOUBLE : STYLE_SINGLE;\n }\n // Edge case: block indentation indicator can only have one digit.\n if (indentPerLevel > 9 && needIndentIndicator(string)) {\n return STYLE_DOUBLE;\n }\n // At this point we know block styles are valid.\n // Prefer literal style unless we want to fold.\n if (!forceQuotes) {\n return hasFoldableLine ? STYLE_FOLDED : STYLE_LITERAL;\n }\n return quotingType === QUOTING_TYPE_DOUBLE ? STYLE_DOUBLE : STYLE_SINGLE;\n}\n\n// Note: line breaking/folding is implemented for only the folded style.\n// NB. We drop the last trailing newline (if any) of a returned block scalar\n// since the dumper adds its own newline. This always works:\n// • No ending newline => unaffected; already using strip \"-\" chomping.\n// • Ending newline => removed then restored.\n// Importantly, this keeps the \"+\" chomp indicator from gaining an extra line.\nfunction writeScalar(state, string, level, iskey, inblock) {\n state.dump = (function () {\n if (string.length === 0) {\n return state.quotingType === QUOTING_TYPE_DOUBLE ? '\"\"' : \"''\";\n }\n if (!state.noCompatMode) {\n if (DEPRECATED_BOOLEANS_SYNTAX.indexOf(string) !== -1 || DEPRECATED_BASE60_SYNTAX.test(string)) {\n return state.quotingType === QUOTING_TYPE_DOUBLE ? ('\"' + string + '\"') : (\"'\" + string + \"'\");\n }\n }\n\n var indent = state.indent * Math.max(1, level); // no 0-indent scalars\n // As indentation gets deeper, let the width decrease monotonically\n // to the lower bound min(state.lineWidth, 40).\n // Note that this implies\n // state.lineWidth ≤ 40 + state.indent: width is fixed at the lower bound.\n // state.lineWidth > 40 + state.indent: width decreases until the lower bound.\n // This behaves better than a constant minimum width which disallows narrower options,\n // or an indent threshold which causes the width to suddenly increase.\n var lineWidth = state.lineWidth === -1\n ? -1 : Math.max(Math.min(state.lineWidth, 40), state.lineWidth - indent);\n\n // Without knowing if keys are implicit/explicit, assume implicit for safety.\n var singleLineOnly = iskey\n // No block styles in flow mode.\n || (state.flowLevel > -1 && level >= state.flowLevel);\n function testAmbiguity(string) {\n return testImplicitResolving(state, string);\n }\n\n switch (chooseScalarStyle(string, singleLineOnly, state.indent, lineWidth,\n testAmbiguity, state.quotingType, state.forceQuotes && !iskey, inblock)) {\n\n case STYLE_PLAIN:\n return string;\n case STYLE_SINGLE:\n return \"'\" + string.replace(/'/g, \"''\") + \"'\";\n case STYLE_LITERAL:\n return '|' + blockHeader(string, state.indent)\n + dropEndingNewline(indentString(string, indent));\n case STYLE_FOLDED:\n return '>' + blockHeader(string, state.indent)\n + dropEndingNewline(indentString(foldString(string, lineWidth), indent));\n case STYLE_DOUBLE:\n return '\"' + escapeString(string) + '\"';\n default:\n throw new exception('impossible error: invalid scalar style');\n }\n }());\n}\n\n// Pre-conditions: string is valid for a block scalar, 1 <= indentPerLevel <= 9.\nfunction blockHeader(string, indentPerLevel) {\n var indentIndicator = needIndentIndicator(string) ? String(indentPerLevel) : '';\n\n // note the special case: the string '\\n' counts as a \"trailing\" empty line.\n var clip = string[string.length - 1] === '\\n';\n var keep = clip && (string[string.length - 2] === '\\n' || string === '\\n');\n var chomp = keep ? '+' : (clip ? '' : '-');\n\n return indentIndicator + chomp + '\\n';\n}\n\n// (See the note for writeScalar.)\nfunction dropEndingNewline(string) {\n return string[string.length - 1] === '\\n' ? string.slice(0, -1) : string;\n}\n\n// Note: a long line without a suitable break point will exceed the width limit.\n// Pre-conditions: every char in str isPrintable, str.length > 0, width > 0.\nfunction foldString(string, width) {\n // In folded style, $k$ consecutive newlines output as $k+1$ newlines—\n // unless they're before or after a more-indented line, or at the very\n // beginning or end, in which case $k$ maps to $k$.\n // Therefore, parse each chunk as newline(s) followed by a content line.\n var lineRe = /(\\n+)([^\\n]*)/g;\n\n // first line (possibly an empty line)\n var result = (function () {\n var nextLF = string.indexOf('\\n');\n nextLF = nextLF !== -1 ? nextLF : string.length;\n lineRe.lastIndex = nextLF;\n return foldLine(string.slice(0, nextLF), width);\n }());\n // If we haven't reached the first content line yet, don't add an extra \\n.\n var prevMoreIndented = string[0] === '\\n' || string[0] === ' ';\n var moreIndented;\n\n // rest of the lines\n var match;\n while ((match = lineRe.exec(string))) {\n var prefix = match[1], line = match[2];\n moreIndented = (line[0] === ' ');\n result += prefix\n + (!prevMoreIndented && !moreIndented && line !== ''\n ? '\\n' : '')\n + foldLine(line, width);\n prevMoreIndented = moreIndented;\n }\n\n return result;\n}\n\n// Greedy line breaking.\n// Picks the longest line under the limit each time,\n// otherwise settles for the shortest line over the limit.\n// NB. More-indented lines *cannot* be folded, as that would add an extra \\n.\nfunction foldLine(line, width) {\n if (line === '' || line[0] === ' ') return line;\n\n // Since a more-indented line adds a \\n, breaks can't be followed by a space.\n var breakRe = / [^ ]/g; // note: the match index will always be <= length-2.\n var match;\n // start is an inclusive index. end, curr, and next are exclusive.\n var start = 0, end, curr = 0, next = 0;\n var result = '';\n\n // Invariants: 0 <= start <= length-1.\n // 0 <= curr <= next <= max(0, length-2). curr - start <= width.\n // Inside the loop:\n // A match implies length >= 2, so curr and next are <= length-2.\n while ((match = breakRe.exec(line))) {\n next = match.index;\n // maintain invariant: curr - start <= width\n if (next - start > width) {\n end = (curr > start) ? curr : next; // derive end <= length-2\n result += '\\n' + line.slice(start, end);\n // skip the space that was output as \\n\n start = end + 1; // derive start <= length-1\n }\n curr = next;\n }\n\n // By the invariants, start <= length-1, so there is something left over.\n // It is either the whole string or a part starting from non-whitespace.\n result += '\\n';\n // Insert a break if the remainder is too long and there is a break available.\n if (line.length - start > width && curr > start) {\n result += line.slice(start, curr) + '\\n' + line.slice(curr + 1);\n } else {\n result += line.slice(start);\n }\n\n return result.slice(1); // drop extra \\n joiner\n}\n\n// Escapes a double-quoted string.\nfunction escapeString(string) {\n var result = '';\n var char = 0;\n var escapeSeq;\n\n for (var i = 0; i < string.length; char >= 0x10000 ? i += 2 : i++) {\n char = codePointAt(string, i);\n escapeSeq = ESCAPE_SEQUENCES[char];\n\n if (!escapeSeq && isPrintable(char)) {\n result += string[i];\n if (char >= 0x10000) result += string[i + 1];\n } else {\n result += escapeSeq || encodeHex(char);\n }\n }\n\n return result;\n}\n\nfunction writeFlowSequence(state, level, object) {\n var _result = '',\n _tag = state.tag,\n index,\n length,\n value;\n\n for (index = 0, length = object.length; index < length; index += 1) {\n value = object[index];\n\n if (state.replacer) {\n value = state.replacer.call(object, String(index), value);\n }\n\n // Write only valid elements, put null instead of invalid elements.\n if (writeNode(state, level, value, false, false) ||\n (typeof value === 'undefined' &&\n writeNode(state, level, null, false, false))) {\n\n if (_result !== '') _result += ',' + (!state.condenseFlow ? ' ' : '');\n _result += state.dump;\n }\n }\n\n state.tag = _tag;\n state.dump = '[' + _result + ']';\n}\n\nfunction writeBlockSequence(state, level, object, compact) {\n var _result = '',\n _tag = state.tag,\n index,\n length,\n value;\n\n for (index = 0, length = object.length; index < length; index += 1) {\n value = object[index];\n\n if (state.replacer) {\n value = state.replacer.call(object, String(index), value);\n }\n\n // Write only valid elements, put null instead of invalid elements.\n if (writeNode(state, level + 1, value, true, true, false, true) ||\n (typeof value === 'undefined' &&\n writeNode(state, level + 1, null, true, true, false, true))) {\n\n if (!compact || _result !== '') {\n _result += generateNextLine(state, level);\n }\n\n if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n _result += '-';\n } else {\n _result += '- ';\n }\n\n _result += state.dump;\n }\n }\n\n state.tag = _tag;\n state.dump = _result || '[]'; // Empty sequence if no valid values.\n}\n\nfunction writeFlowMapping(state, level, object) {\n var _result = '',\n _tag = state.tag,\n objectKeyList = Object.keys(object),\n index,\n length,\n objectKey,\n objectValue,\n pairBuffer;\n\n for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n\n pairBuffer = '';\n if (_result !== '') pairBuffer += ', ';\n\n if (state.condenseFlow) pairBuffer += '\"';\n\n objectKey = objectKeyList[index];\n objectValue = object[objectKey];\n\n if (state.replacer) {\n objectValue = state.replacer.call(object, objectKey, objectValue);\n }\n\n if (!writeNode(state, level, objectKey, false, false)) {\n continue; // Skip this pair because of invalid key;\n }\n\n if (state.dump.length > 1024) pairBuffer += '? ';\n\n pairBuffer += state.dump + (state.condenseFlow ? '\"' : '') + ':' + (state.condenseFlow ? '' : ' ');\n\n if (!writeNode(state, level, objectValue, false, false)) {\n continue; // Skip this pair because of invalid value.\n }\n\n pairBuffer += state.dump;\n\n // Both key and value are valid.\n _result += pairBuffer;\n }\n\n state.tag = _tag;\n state.dump = '{' + _result + '}';\n}\n\nfunction writeBlockMapping(state, level, object, compact) {\n var _result = '',\n _tag = state.tag,\n objectKeyList = Object.keys(object),\n index,\n length,\n objectKey,\n objectValue,\n explicitPair,\n pairBuffer;\n\n // Allow sorting keys so that the output file is deterministic\n if (state.sortKeys === true) {\n // Default sorting\n objectKeyList.sort();\n } else if (typeof state.sortKeys === 'function') {\n // Custom sort function\n objectKeyList.sort(state.sortKeys);\n } else if (state.sortKeys) {\n // Something is wrong\n throw new exception('sortKeys must be a boolean or a function');\n }\n\n for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n pairBuffer = '';\n\n if (!compact || _result !== '') {\n pairBuffer += generateNextLine(state, level);\n }\n\n objectKey = objectKeyList[index];\n objectValue = object[objectKey];\n\n if (state.replacer) {\n objectValue = state.replacer.call(object, objectKey, objectValue);\n }\n\n if (!writeNode(state, level + 1, objectKey, true, true, true)) {\n continue; // Skip this pair because of invalid key.\n }\n\n explicitPair = (state.tag !== null && state.tag !== '?') ||\n (state.dump && state.dump.length > 1024);\n\n if (explicitPair) {\n if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n pairBuffer += '?';\n } else {\n pairBuffer += '? ';\n }\n }\n\n pairBuffer += state.dump;\n\n if (explicitPair) {\n pairBuffer += generateNextLine(state, level);\n }\n\n if (!writeNode(state, level + 1, objectValue, true, explicitPair)) {\n continue; // Skip this pair because of invalid value.\n }\n\n if (state.dump && CHAR_LINE_FEED === state.dump.charCodeAt(0)) {\n pairBuffer += ':';\n } else {\n pairBuffer += ': ';\n }\n\n pairBuffer += state.dump;\n\n // Both key and value are valid.\n _result += pairBuffer;\n }\n\n state.tag = _tag;\n state.dump = _result || '{}'; // Empty mapping if no valid pairs.\n}\n\nfunction detectType(state, object, explicit) {\n var _result, typeList, index, length, type, style;\n\n typeList = explicit ? state.explicitTypes : state.implicitTypes;\n\n for (index = 0, length = typeList.length; index < length; index += 1) {\n type = typeList[index];\n\n if ((type.instanceOf || type.predicate) &&\n (!type.instanceOf || ((typeof object === 'object') && (object instanceof type.instanceOf))) &&\n (!type.predicate || type.predicate(object))) {\n\n if (explicit) {\n if (type.multi && type.representName) {\n state.tag = type.representName(object);\n } else {\n state.tag = type.tag;\n }\n } else {\n state.tag = '?';\n }\n\n if (type.represent) {\n style = state.styleMap[type.tag] || type.defaultStyle;\n\n if (_toString.call(type.represent) === '[object Function]') {\n _result = type.represent(object, style);\n } else if (_hasOwnProperty.call(type.represent, style)) {\n _result = type.represent[style](object, style);\n } else {\n throw new exception('!<' + type.tag + '> tag resolver accepts not \"' + style + '\" style');\n }\n\n state.dump = _result;\n }\n\n return true;\n }\n }\n\n return false;\n}\n\n// Serializes `object` and writes it to global `result`.\n// Returns true on success, or false on invalid object.\n//\nfunction writeNode(state, level, object, block, compact, iskey, isblockseq) {\n state.tag = null;\n state.dump = object;\n\n if (!detectType(state, object, false)) {\n detectType(state, object, true);\n }\n\n var type = _toString.call(state.dump);\n var inblock = block;\n var tagStr;\n\n if (block) {\n block = (state.flowLevel < 0 || state.flowLevel > level);\n }\n\n var objectOrArray = type === '[object Object]' || type === '[object Array]',\n duplicateIndex,\n duplicate;\n\n if (objectOrArray) {\n duplicateIndex = state.duplicates.indexOf(object);\n duplicate = duplicateIndex !== -1;\n }\n\n if ((state.tag !== null && state.tag !== '?') || duplicate || (state.indent !== 2 && level > 0)) {\n compact = false;\n }\n\n if (duplicate && state.usedDuplicates[duplicateIndex]) {\n state.dump = '*ref_' + duplicateIndex;\n } else {\n if (objectOrArray && duplicate && !state.usedDuplicates[duplicateIndex]) {\n state.usedDuplicates[duplicateIndex] = true;\n }\n if (type === '[object Object]') {\n if (block && (Object.keys(state.dump).length !== 0)) {\n writeBlockMapping(state, level, state.dump, compact);\n if (duplicate) {\n state.dump = '&ref_' + duplicateIndex + state.dump;\n }\n } else {\n writeFlowMapping(state, level, state.dump);\n if (duplicate) {\n state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n }\n }\n } else if (type === '[object Array]') {\n if (block && (state.dump.length !== 0)) {\n if (state.noArrayIndent && !isblockseq && level > 0) {\n writeBlockSequence(state, level - 1, state.dump, compact);\n } else {\n writeBlockSequence(state, level, state.dump, compact);\n }\n if (duplicate) {\n state.dump = '&ref_' + duplicateIndex + state.dump;\n }\n } else {\n writeFlowSequence(state, level, state.dump);\n if (duplicate) {\n state.dump = '&ref_' + duplicateIndex + ' ' + state.dump;\n }\n }\n } else if (type === '[object String]') {\n if (state.tag !== '?') {\n writeScalar(state, state.dump, level, iskey, inblock);\n }\n } else if (type === '[object Undefined]') {\n return false;\n } else {\n if (state.skipInvalid) return false;\n throw new exception('unacceptable kind of an object to dump ' + type);\n }\n\n if (state.tag !== null && state.tag !== '?') {\n // Need to encode all characters except those allowed by the spec:\n //\n // [35] ns-dec-digit ::= [#x30-#x39] /* 0-9 */\n // [36] ns-hex-digit ::= ns-dec-digit\n // | [#x41-#x46] /* A-F */ | [#x61-#x66] /* a-f */\n // [37] ns-ascii-letter ::= [#x41-#x5A] /* A-Z */ | [#x61-#x7A] /* a-z */\n // [38] ns-word-char ::= ns-dec-digit | ns-ascii-letter | “-”\n // [39] ns-uri-char ::= “%” ns-hex-digit ns-hex-digit | ns-word-char | “#”\n // | “;” | “/” | “?” | “:” | “@” | “&” | “=” | “+” | “$” | “,”\n // | “_” | “.” | “!” | “~” | “*” | “'” | “(” | “)” | “[” | “]”\n //\n // Also need to encode '!' because it has special meaning (end of tag prefix).\n //\n tagStr = encodeURI(\n state.tag[0] === '!' ? state.tag.slice(1) : state.tag\n ).replace(/!/g, '%21');\n\n if (state.tag[0] === '!') {\n tagStr = '!' + tagStr;\n } else if (tagStr.slice(0, 18) === 'tag:yaml.org,2002:') {\n tagStr = '!!' + tagStr.slice(18);\n } else {\n tagStr = '!<' + tagStr + '>';\n }\n\n state.dump = tagStr + ' ' + state.dump;\n }\n }\n\n return true;\n}\n\nfunction getDuplicateReferences(object, state) {\n var objects = [],\n duplicatesIndexes = [],\n index,\n length;\n\n inspectNode(object, objects, duplicatesIndexes);\n\n for (index = 0, length = duplicatesIndexes.length; index < length; index += 1) {\n state.duplicates.push(objects[duplicatesIndexes[index]]);\n }\n state.usedDuplicates = new Array(length);\n}\n\nfunction inspectNode(object, objects, duplicatesIndexes) {\n var objectKeyList,\n index,\n length;\n\n if (object !== null && typeof object === 'object') {\n index = objects.indexOf(object);\n if (index !== -1) {\n if (duplicatesIndexes.indexOf(index) === -1) {\n duplicatesIndexes.push(index);\n }\n } else {\n objects.push(object);\n\n if (Array.isArray(object)) {\n for (index = 0, length = object.length; index < length; index += 1) {\n inspectNode(object[index], objects, duplicatesIndexes);\n }\n } else {\n objectKeyList = Object.keys(object);\n\n for (index = 0, length = objectKeyList.length; index < length; index += 1) {\n inspectNode(object[objectKeyList[index]], objects, duplicatesIndexes);\n }\n }\n }\n }\n}\n\nfunction dump$1(input, options) {\n options = options || {};\n\n var state = new State(options);\n\n if (!state.noRefs) getDuplicateReferences(input, state);\n\n var value = input;\n\n if (state.replacer) {\n value = state.replacer.call({ '': value }, '', value);\n }\n\n if (writeNode(state, 0, value, true, true)) return state.dump + '\\n';\n\n return '';\n}\n\nvar dump_1 = dump$1;\n\nvar dumper = {\n\tdump: dump_1\n};\n\nfunction renamed(from, to) {\n return function () {\n throw new Error('Function yaml.' + from + ' is removed in js-yaml 4. ' +\n 'Use yaml.' + to + ' instead, which is now safe by default.');\n };\n}\n\n\nvar Type = type;\nvar Schema = schema;\nvar FAILSAFE_SCHEMA = failsafe;\nvar JSON_SCHEMA = json;\nvar CORE_SCHEMA = core;\nvar DEFAULT_SCHEMA = _default;\nvar load = loader.load;\nvar loadAll = loader.loadAll;\nvar dump = dumper.dump;\nvar YAMLException = exception;\n\n// Re-export all types in case user wants to create custom schema\nvar types = {\n binary: binary,\n float: float,\n map: map,\n null: _null,\n pairs: pairs,\n set: set,\n timestamp: timestamp,\n bool: bool,\n int: int,\n merge: merge,\n omap: omap,\n seq: seq,\n str: str\n};\n\n// Removed functions from JS-YAML 3.0.x\nvar safeLoad = renamed('safeLoad', 'load');\nvar safeLoadAll = renamed('safeLoadAll', 'loadAll');\nvar safeDump = renamed('safeDump', 'dump');\n\nvar jsYaml = {\n\tType: Type,\n\tSchema: Schema,\n\tFAILSAFE_SCHEMA: FAILSAFE_SCHEMA,\n\tJSON_SCHEMA: JSON_SCHEMA,\n\tCORE_SCHEMA: CORE_SCHEMA,\n\tDEFAULT_SCHEMA: DEFAULT_SCHEMA,\n\tload: load,\n\tloadAll: loadAll,\n\tdump: dump,\n\tYAMLException: YAMLException,\n\ttypes: types,\n\tsafeLoad: safeLoad,\n\tsafeLoadAll: safeLoadAll,\n\tsafeDump: safeDump\n};\n\nexport default jsYaml;\nexport { CORE_SCHEMA, DEFAULT_SCHEMA, FAILSAFE_SCHEMA, JSON_SCHEMA, Schema, Type, YAMLException, dump, load, loadAll, safeDump, safeLoad, safeLoadAll, types };\n","import { DiagramDb } from './types';\n// The \"* as yaml\" part is necessary for tree-shaking\nimport * as yaml from 'js-yaml';\n\n// Match Jekyll-style front matter blocks (https://jekyllrb.com/docs/front-matter/).\n// Based on regex used by Jekyll: https://github.com/jekyll/jekyll/blob/6dd3cc21c40b98054851846425af06c64f9fb466/lib/jekyll/document.rb#L10\n// Note that JS doesn't support the \"\\A\" anchor, which means we can't use\n// multiline mode.\n// Relevant YAML spec: https://yaml.org/spec/1.2.2/#914-explicit-documents\nexport const frontMatterRegex = /^-{3}\\s*[\\n\\r](.*?)[\\n\\r]-{3}\\s*[\\n\\r]+/s;\n\ntype FrontMatterMetadata = {\n title?: string;\n};\n\n/**\n * Extract and parse frontmatter from text, if present, and sets appropriate\n * properties in the provided db.\n * @param text - The text that may have a YAML frontmatter.\n * @param db - Diagram database, could be of any diagram.\n * @returns text with frontmatter stripped out\n */\nexport function extractFrontMatter(text: string, db: DiagramDb): string {\n const matches = text.match(frontMatterRegex);\n if (matches) {\n const parsed: FrontMatterMetadata = yaml.load(matches[1], {\n // To keep things simple, only allow strings, arrays, and plain objects.\n // https://www.yaml.org/spec/1.2/spec.html#id2802346\n schema: yaml.FAILSAFE_SCHEMA,\n }) as FrontMatterMetadata;\n\n if (parsed?.title) {\n db.setDiagramTitle?.(parsed.title);\n }\n\n return text.slice(matches[0].length);\n } else {\n return text;\n }\n}\n","import type { FlowChartStyleOptions } from './diagrams/flowchart/styles';\nimport { log } from './logger';\n\nconst themes: Record = {};\n\nconst getStyles = (\n type: string,\n userStyles: string,\n options: {\n fontFamily: string;\n fontSize: string;\n textColor: string;\n errorBkgColor: string;\n errorTextColor: string;\n lineColor: string;\n } & FlowChartStyleOptions\n) => {\n let diagramStyles = '';\n if (type in themes && themes[type as keyof typeof themes]) {\n diagramStyles = themes[type as keyof typeof themes](options);\n } else {\n log.warn(`No theme found for ${type}`);\n }\n return ` & {\n font-family: ${options.fontFamily};\n font-size: ${options.fontSize};\n fill: ${options.textColor}\n }\n\n /* Classes common for multiple diagrams */\n\n & .error-icon {\n fill: ${options.errorBkgColor};\n }\n & .error-text {\n fill: ${options.errorTextColor};\n stroke: ${options.errorTextColor};\n }\n\n & .edge-thickness-normal {\n stroke-width: 2px;\n }\n & .edge-thickness-thick {\n stroke-width: 3.5px\n }\n & .edge-pattern-solid {\n stroke-dasharray: 0;\n }\n\n & .edge-pattern-dashed{\n stroke-dasharray: 3;\n }\n .edge-pattern-dotted {\n stroke-dasharray: 2;\n }\n\n & .marker {\n fill: ${options.lineColor};\n stroke: ${options.lineColor};\n }\n & .marker.cross {\n stroke: ${options.lineColor};\n }\n\n & svg {\n font-family: ${options.fontFamily};\n font-size: ${options.fontSize};\n }\n\n ${diagramStyles}\n\n ${userStyles}\n`;\n};\n\nexport const addStylesForDiagram = (type: string, diagramTheme: unknown): void => {\n themes[type] = diagramTheme;\n};\n\nexport default getStyles;\n","import * as configApi from './config';\n\nimport { log } from './logger';\nimport { directiveSanitizer } from './utils';\n\nlet currentDirective: { type?: string; args?: any } | undefined = {};\n\nexport const parseDirective = function (\n p: any,\n statement: string,\n context: string,\n type: string\n): void {\n log.debug('parseDirective is being called', statement, context, type);\n try {\n if (statement !== undefined) {\n statement = statement.trim();\n switch (context) {\n case 'open_directive':\n currentDirective = {};\n break;\n case 'type_directive':\n if (!currentDirective) {\n throw new Error('currentDirective is undefined');\n }\n currentDirective.type = statement.toLowerCase();\n break;\n case 'arg_directive':\n if (!currentDirective) {\n throw new Error('currentDirective is undefined');\n }\n currentDirective.args = JSON.parse(statement);\n break;\n case 'close_directive':\n handleDirective(p, currentDirective, type);\n currentDirective = undefined;\n break;\n }\n }\n } catch (error) {\n log.error(\n `Error while rendering sequenceDiagram directive: ${statement} jison context: ${context}`\n );\n // @ts-ignore: TODO Fix ts errors\n log.error(error.message);\n }\n};\n\nconst handleDirective = function (p: any, directive: any, type: string): void {\n log.info(`Directive type=${directive.type} with args:`, directive.args);\n switch (directive.type) {\n case 'init':\n case 'initialize': {\n ['config'].forEach((prop) => {\n if (directive.args[prop] !== undefined) {\n if (type === 'flowchart-v2') {\n type = 'flowchart';\n }\n directive.args[type] = directive.args[prop];\n delete directive.args[prop];\n }\n });\n log.info('sanitize in handleDirective', directive.args);\n directiveSanitizer(directive.args);\n log.info('sanitize in handleDirective (done)', directive.args);\n configApi.addDirective(directive.args);\n break;\n }\n case 'wrap':\n case 'nowrap':\n if (p && p['setWrap']) {\n p.setWrap(directive.type === 'wrap');\n }\n break;\n case 'themeCss':\n log.warn('themeCss encountered');\n break;\n default:\n log.warn(\n `Unhandled directive: source: '%%{${directive.type}: ${JSON.stringify(\n directive.args ? directive.args : {}\n )}}%%`,\n directive\n );\n break;\n }\n};\n","import { addDetector } from './detectType';\nimport { log as _log, setLogLevel as _setLogLevel } from '../logger';\nimport { getConfig as _getConfig } from '../config';\nimport { sanitizeText as _sanitizeText } from '../diagrams/common/common';\nimport { setupGraphViewbox as _setupGraphViewbox } from '../setupGraphViewbox';\nimport { addStylesForDiagram } from '../styles';\nimport { DiagramDefinition, DiagramDetector } from './types';\nimport * as _commonDb from '../commonDb';\nimport { parseDirective as _parseDirective } from '../directiveUtils';\n\n/*\n Packaging and exposing resources for external diagrams so that they can import\n diagramAPI and have access to select parts of mermaid common code required to\n create diagrams working like the internal diagrams.\n*/\nexport const log = _log;\nexport const setLogLevel = _setLogLevel;\nexport const getConfig = _getConfig;\nexport const sanitizeText = (text: string) => _sanitizeText(text, getConfig());\nexport const setupGraphViewbox = _setupGraphViewbox;\nexport const getCommonDb = () => {\n return _commonDb;\n};\nexport const parseDirective = (p: any, statement: string, context: string, type: string) =>\n _parseDirective(p, statement, context, type);\n\nconst diagrams: Record = {};\nexport interface Detectors {\n [key: string]: DiagramDetector;\n}\n\n/**\n * Registers the given diagram with Mermaid.\n *\n * Can be used for third-party custom diagrams.\n *\n * @param id - A unique ID for the given diagram.\n * @param diagram - The diagram definition.\n * @param detector - Function that returns `true` if a given mermaid text is this diagram definition.\n */\nexport const registerDiagram = (\n id: string,\n diagram: DiagramDefinition,\n detector?: DiagramDetector\n) => {\n if (diagrams[id]) {\n throw new Error(`Diagram ${id} already registered.`);\n }\n diagrams[id] = diagram;\n if (detector) {\n addDetector(id, detector);\n }\n addStylesForDiagram(id, diagram.styles);\n\n if (diagram.injectUtils) {\n diagram.injectUtils(\n log,\n setLogLevel,\n getConfig,\n sanitizeText,\n setupGraphViewbox,\n getCommonDb(),\n parseDirective\n );\n }\n};\n\nexport const getDiagram = (name: string): DiagramDefinition => {\n if (name in diagrams) {\n return diagrams[name];\n }\n throw new Error(`Diagram ${name} not found.`);\n};\n\nexport class DiagramNotFoundError extends Error {\n constructor(message: string) {\n super(`Diagram ${message} not found.`);\n }\n}\n","export class UnknownDiagramError extends Error {\n constructor(message: string) {\n super(message);\n this.name = 'UnknownDiagramError';\n }\n}\n","import { MermaidConfig } from '../config.type';\nimport { log } from '../logger';\nimport type {\n DetectorRecord,\n DiagramDetector,\n DiagramLoader,\n ExternalDiagramDefinition,\n} from './types';\nimport { frontMatterRegex } from './frontmatter';\nimport { getDiagram, registerDiagram } from './diagramAPI';\nimport { UnknownDiagramError } from '../errors';\n\nconst directive = /%{2}{\\s*(?:(\\w+)\\s*:|(\\w+))\\s*(?:(\\w+)|((?:(?!}%{2}).|\\r?\\n)*))?\\s*(?:}%{2})?/gi;\nconst anyComment = /\\s*%%.*\\n/gm;\n\nconst detectors: Record = {};\n\n/**\n * Detects the type of the graph text.\n *\n * Takes into consideration the possible existence of an `%%init` directive\n *\n * @param text - The text defining the graph. For example:\n *\n * ```mermaid\n * %%{initialize: {\"startOnLoad\": true, logLevel: \"fatal\" }}%%\n * graph LR\n * a-->b\n * b-->c\n * c-->d\n * d-->e\n * e-->f\n * f-->g\n * g-->h\n * ```\n *\n * @param config - The mermaid config.\n * @returns A graph definition key\n */\nexport const detectType = function (text: string, config?: MermaidConfig): string {\n text = text.replace(frontMatterRegex, '').replace(directive, '').replace(anyComment, '\\n');\n for (const [key, { detector }] of Object.entries(detectors)) {\n const diagram = detector(text, config);\n if (diagram) {\n return key;\n }\n }\n\n throw new UnknownDiagramError(\n `No diagram type detected matching given configuration for text: ${text}`\n );\n};\n\n/**\n * Registers lazy-loaded diagrams to Mermaid.\n *\n * The diagram function is loaded asynchronously, so that diagrams are only loaded\n * if the diagram is detected.\n *\n * @remarks\n * Please note that the order of diagram detectors is important.\n * The first detector to return `true` is the diagram that will be loaded\n * and used, so put more specific detectors at the beginning!\n *\n * @param diagrams - Diagrams to lazy load, and their detectors, in order of importance.\n */\nexport const registerLazyLoadedDiagrams = (...diagrams: ExternalDiagramDefinition[]) => {\n for (const { id, detector, loader } of diagrams) {\n addDetector(id, detector, loader);\n }\n};\n\nexport const loadRegisteredDiagrams = async () => {\n log.debug(`Loading registered diagrams`);\n // Load all lazy loaded diagrams in parallel\n const results = await Promise.allSettled(\n Object.entries(detectors).map(async ([key, { detector, loader }]) => {\n if (loader) {\n try {\n getDiagram(key);\n } catch (error) {\n try {\n // Register diagram if it is not already registered\n const { diagram, id } = await loader();\n registerDiagram(id, diagram, detector);\n } catch (err) {\n // Remove failed diagram from detectors\n log.error(`Failed to load external diagram with key ${key}. Removing from detectors.`);\n delete detectors[key];\n throw err;\n }\n }\n }\n })\n );\n const failed = results.filter((result) => result.status === 'rejected');\n if (failed.length > 0) {\n log.error(`Failed to load ${failed.length} external diagrams`);\n for (const res of failed) {\n log.error(res);\n }\n throw new Error(`Failed to load ${failed.length} external diagrams`);\n }\n};\n\nexport const addDetector = (key: string, detector: DiagramDetector, loader?: DiagramLoader) => {\n if (detectors[key]) {\n log.error(`Detector with key ${key} already exists`);\n } else {\n detectors[key] = { detector, loader };\n }\n log.debug(`Detector with key ${key} added${loader ? ' with loader' : ''}`);\n};\n\nexport const getDiagramLoader = (key: string) => {\n return detectors[key].loader;\n};\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nexport default getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nexport default baseGetTag;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n","import baseGetTag from './_baseGetTag.js';\nimport isObject from './isObject.js';\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nexport default isFunction;\n","import root from './_root.js';\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nexport default coreJsData;\n","import coreJsData from './_coreJsData.js';\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nexport default isMasked;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nexport default toSource;\n","import isFunction from './isFunction.js';\nimport isMasked from './_isMasked.js';\nimport isObject from './isObject.js';\nimport toSource from './_toSource.js';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nexport default baseIsNative;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nexport default getValue;\n","import baseIsNative from './_baseIsNative.js';\nimport getValue from './_getValue.js';\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nexport default getNative;\n","import getNative from './_getNative.js';\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nexport default nativeCreate;\n","import nativeCreate from './_nativeCreate.js';\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nexport default hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default hashDelete;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nexport default hashGet;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nexport default hashHas;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nexport default hashSet;\n","import hashClear from './_hashClear.js';\nimport hashDelete from './_hashDelete.js';\nimport hashGet from './_hashGet.js';\nimport hashHas from './_hashHas.js';\nimport hashSet from './_hashSet.js';\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nexport default Hash;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nexport default listCacheClear;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nexport default eq;\n","import eq from './eq.js';\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nexport default assocIndexOf;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nexport default listCacheDelete;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nexport default listCacheGet;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nexport default listCacheHas;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nexport default listCacheSet;\n","import listCacheClear from './_listCacheClear.js';\nimport listCacheDelete from './_listCacheDelete.js';\nimport listCacheGet from './_listCacheGet.js';\nimport listCacheHas from './_listCacheHas.js';\nimport listCacheSet from './_listCacheSet.js';\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nexport default ListCache;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nexport default Map;\n","import Hash from './_Hash.js';\nimport ListCache from './_ListCache.js';\nimport Map from './_Map.js';\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nexport default mapCacheClear;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nexport default isKeyable;\n","import isKeyable from './_isKeyable.js';\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nexport default getMapData;\n","import getMapData from './_getMapData.js';\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default mapCacheDelete;\n","import getMapData from './_getMapData.js';\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nexport default mapCacheGet;\n","import getMapData from './_getMapData.js';\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nexport default mapCacheHas;\n","import getMapData from './_getMapData.js';\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nexport default mapCacheSet;\n","import mapCacheClear from './_mapCacheClear.js';\nimport mapCacheDelete from './_mapCacheDelete.js';\nimport mapCacheGet from './_mapCacheGet.js';\nimport mapCacheHas from './_mapCacheHas.js';\nimport mapCacheSet from './_mapCacheSet.js';\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nexport default MapCache;\n","import MapCache from './_MapCache.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nexport default memoize;\n","// @ts-nocheck : TODO Fix ts errors\nimport { sanitizeUrl } from '@braintree/sanitize-url';\nimport {\n curveBasis,\n curveBasisClosed,\n curveBasisOpen,\n curveBumpX,\n curveBumpY,\n curveBundle,\n curveCardinalClosed,\n curveCardinalOpen,\n curveCardinal,\n curveCatmullRomClosed,\n curveCatmullRomOpen,\n curveCatmullRom,\n CurveFactory,\n curveLinear,\n curveLinearClosed,\n curveMonotoneX,\n curveMonotoneY,\n curveNatural,\n curveStep,\n curveStepAfter,\n curveStepBefore,\n select,\n} from 'd3';\nimport common from './diagrams/common/common';\nimport { configKeys } from './defaultConfig';\nimport { log } from './logger';\nimport { detectType } from './diagram-api/detectType';\nimport assignWithDepth from './assignWithDepth';\nimport { MermaidConfig } from './config.type';\nimport memoize from 'lodash-es/memoize.js';\n\n// Effectively an enum of the supported curve types, accessible by name\nconst d3CurveTypes = {\n curveBasis: curveBasis,\n curveBasisClosed: curveBasisClosed,\n curveBasisOpen: curveBasisOpen,\n curveBumpX: curveBumpX,\n curveBumpY: curveBumpY,\n curveBundle: curveBundle,\n curveCardinalClosed: curveCardinalClosed,\n curveCardinalOpen: curveCardinalOpen,\n curveCardinal: curveCardinal,\n curveCatmullRomClosed: curveCatmullRomClosed,\n curveCatmullRomOpen: curveCatmullRomOpen,\n curveCatmullRom: curveCatmullRom,\n curveLinear: curveLinear,\n curveLinearClosed: curveLinearClosed,\n curveMonotoneX: curveMonotoneX,\n curveMonotoneY: curveMonotoneY,\n curveNatural: curveNatural,\n curveStep: curveStep,\n curveStepAfter: curveStepAfter,\n curveStepBefore: curveStepBefore,\n};\nconst directive = /%{2}{\\s*(?:(\\w+)\\s*:|(\\w+))\\s*(?:(\\w+)|((?:(?!}%{2}).|\\r?\\n)*))?\\s*(?:}%{2})?/gi;\nconst directiveWithoutOpen =\n /\\s*(?:(\\w+)(?=:):|(\\w+))\\s*(?:(\\w+)|((?:(?!}%{2}).|\\r?\\n)*))?\\s*(?:}%{2})?/gi;\n\n/**\n * Detects the init config object from the text\n *\n * @param text - The text defining the graph. For example:\n *\n * ```mermaid\n * %%{init: {\"theme\": \"debug\", \"logLevel\": 1 }}%%\n * graph LR\n * a-->b\n * b-->c\n * c-->d\n * d-->e\n * e-->f\n * f-->g\n * g-->h\n * ```\n *\n * Or\n *\n * ```mermaid\n * %%{initialize: {\"theme\": \"dark\", logLevel: \"debug\" }}%%\n * graph LR\n * a-->b\n * b-->c\n * c-->d\n * d-->e\n * e-->f\n * f-->g\n * g-->h\n * ```\n *\n * @param config - Optional mermaid configuration object.\n * @returns The json object representing the init passed to mermaid.initialize()\n */\nexport const detectInit = function (text: string, config?: MermaidConfig): MermaidConfig {\n const inits = detectDirective(text, /(?:init\\b)|(?:initialize\\b)/);\n let results = {};\n\n if (Array.isArray(inits)) {\n const args = inits.map((init) => init.args);\n directiveSanitizer(args);\n\n results = assignWithDepth(results, [...args]);\n } else {\n results = inits.args;\n }\n if (results) {\n let type = detectType(text, config);\n ['config'].forEach((prop) => {\n if (results[prop] !== undefined) {\n if (type === 'flowchart-v2') {\n type = 'flowchart';\n }\n results[type] = results[prop];\n delete results[prop];\n }\n });\n }\n\n // Todo: refactor this, these results are never used\n return results;\n};\n\n/**\n * Detects the directive from the text.\n *\n * Text can be single line or multiline. If type is null or omitted,\n * the first directive encountered in text will be returned\n *\n * ```mermaid\n * graph LR\n * %%{someDirective}%%\n * a-->b\n * b-->c\n * c-->d\n * d-->e\n * e-->f\n * f-->g\n * g-->h\n * ```\n *\n * @param text - The text defining the graph\n * @param type - The directive to return (default: `null`)\n * @returns An object or Array representing the directive(s) matched by the input type.\n * If a single directive was found, that directive object will be returned.\n */\nexport const detectDirective = function (\n text: string,\n type: string | RegExp = null\n): { type?: string; args?: any } | { type?: string; args?: any }[] {\n try {\n const commentWithoutDirectives = new RegExp(\n `[%]{2}(?![{]${directiveWithoutOpen.source})(?=[}][%]{2}).*\\n`,\n 'ig'\n );\n text = text.trim().replace(commentWithoutDirectives, '').replace(/'/gm, '\"');\n log.debug(\n `Detecting diagram directive${type !== null ? ' type:' + type : ''} based on the text:${text}`\n );\n let match;\n const result = [];\n while ((match = directive.exec(text)) !== null) {\n // This is necessary to avoid infinite loops with zero-width matches\n if (match.index === directive.lastIndex) {\n directive.lastIndex++;\n }\n if (\n (match && !type) ||\n (type && match[1] && match[1].match(type)) ||\n (type && match[2] && match[2].match(type))\n ) {\n const type = match[1] ? match[1] : match[2];\n const args = match[3] ? match[3].trim() : match[4] ? JSON.parse(match[4].trim()) : null;\n result.push({ type, args });\n }\n }\n if (result.length === 0) {\n result.push({ type: text, args: null });\n }\n\n return result.length === 1 ? result[0] : result;\n } catch (error) {\n log.error(\n `ERROR: ${error.message} - Unable to parse directive\n ${type !== null ? ' type:' + type : ''} based on the text:${text}`\n );\n return { type: null, args: null };\n }\n};\n\n/**\n * Detects whether a substring in present in a given array\n *\n * @param str - The substring to detect\n * @param arr - The array to search\n * @returns The array index containing the substring or -1 if not present\n */\nexport const isSubstringInArray = function (str: string, arr: string[]): number {\n for (const [i, element] of arr.entries()) {\n if (element.match(str)) {\n return i;\n }\n }\n return -1;\n};\n\n/**\n * Returns a d3 curve given a curve name\n *\n * @param interpolate - The interpolation name\n * @param defaultCurve - The default curve to return\n * @returns The curve factory to use\n */\nexport function interpolateToCurve(\n interpolate: string | undefined,\n defaultCurve: CurveFactory\n): CurveFactory {\n if (!interpolate) {\n return defaultCurve;\n }\n const curveName = `curve${interpolate.charAt(0).toUpperCase() + interpolate.slice(1)}`;\n return d3CurveTypes[curveName] || defaultCurve;\n}\n\n/**\n * Formats a URL string\n *\n * @param linkStr - String of the URL\n * @param config - Configuration passed to MermaidJS\n * @returns The formatted URL or `undefined`.\n */\nexport function formatUrl(linkStr: string, config: MermaidConfig): string | undefined {\n const url = linkStr.trim();\n\n if (url) {\n if (config.securityLevel !== 'loose') {\n return sanitizeUrl(url);\n }\n\n return url;\n }\n}\n\n/**\n * Runs a function\n *\n * @param functionName - A dot separated path to the function relative to the `window`\n * @param params - Parameters to pass to the function\n */\nexport const runFunc = (functionName: string, ...params) => {\n const arrPaths = functionName.split('.');\n\n const len = arrPaths.length - 1;\n const fnName = arrPaths[len];\n\n let obj = window;\n for (let i = 0; i < len; i++) {\n obj = obj[arrPaths[i]];\n if (!obj) {\n return;\n }\n }\n\n obj[fnName](...params);\n};\n\n/** A (x, y) point */\ninterface Point {\n /** The x value */\n x: number;\n /** The y value */\n y: number;\n}\n\n/**\n * Finds the distance between two points using the Distance Formula\n *\n * @param p1 - The first point\n * @param p2 - The second point\n * @returns The distance between the two points.\n */\nfunction distance(p1: Point, p2: Point): number {\n return p1 && p2 ? Math.sqrt(Math.pow(p2.x - p1.x, 2) + Math.pow(p2.y - p1.y, 2)) : 0;\n}\n\n/**\n * TODO: Give this a description\n *\n * @param points - List of points\n */\nfunction traverseEdge(points: Point[]): Point {\n let prevPoint;\n let totalDistance = 0;\n\n points.forEach((point) => {\n totalDistance += distance(point, prevPoint);\n prevPoint = point;\n });\n\n // Traverse half of total distance along points\n let remainingDistance = totalDistance / 2;\n let center = undefined;\n prevPoint = undefined;\n points.forEach((point) => {\n if (prevPoint && !center) {\n const vectorDistance = distance(point, prevPoint);\n if (vectorDistance < remainingDistance) {\n remainingDistance -= vectorDistance;\n } else {\n // The point is remainingDistance from prevPoint in the vector between prevPoint and point\n // Calculate the coordinates\n const distanceRatio = remainingDistance / vectorDistance;\n if (distanceRatio <= 0) {\n center = prevPoint;\n }\n if (distanceRatio >= 1) {\n center = { x: point.x, y: point.y };\n }\n if (distanceRatio > 0 && distanceRatio < 1) {\n center = {\n x: (1 - distanceRatio) * prevPoint.x + distanceRatio * point.x,\n y: (1 - distanceRatio) * prevPoint.y + distanceRatio * point.y,\n };\n }\n }\n }\n prevPoint = point;\n });\n return center;\n}\n\n/**\n * {@inheritdoc traverseEdge}\n */\nfunction calcLabelPosition(points: Point[]): Point {\n if (points.length === 1) {\n return points[0];\n }\n return traverseEdge(points);\n}\n\nconst calcCardinalityPosition = (isRelationTypePresent, points, initialPosition) => {\n let prevPoint;\n log.info(`our points ${JSON.stringify(points)}`);\n if (points[0] !== initialPosition) {\n points = points.reverse();\n }\n // Traverse only 25 total distance along points to find cardinality point\n const distanceToCardinalityPoint = 25;\n\n let remainingDistance = distanceToCardinalityPoint;\n let center;\n prevPoint = undefined;\n points.forEach((point) => {\n if (prevPoint && !center) {\n const vectorDistance = distance(point, prevPoint);\n if (vectorDistance < remainingDistance) {\n remainingDistance -= vectorDistance;\n } else {\n // The point is remainingDistance from prevPoint in the vector between prevPoint and point\n // Calculate the coordinates\n const distanceRatio = remainingDistance / vectorDistance;\n if (distanceRatio <= 0) {\n center = prevPoint;\n }\n if (distanceRatio >= 1) {\n center = { x: point.x, y: point.y };\n }\n if (distanceRatio > 0 && distanceRatio < 1) {\n center = {\n x: (1 - distanceRatio) * prevPoint.x + distanceRatio * point.x,\n y: (1 - distanceRatio) * prevPoint.y + distanceRatio * point.y,\n };\n }\n }\n }\n prevPoint = point;\n });\n // if relation is present (Arrows will be added), change cardinality point off-set distance (d)\n const d = isRelationTypePresent ? 10 : 5;\n //Calculate Angle for x and y axis\n const angle = Math.atan2(points[0].y - center.y, points[0].x - center.x);\n const cardinalityPosition = { x: 0, y: 0 };\n //Calculation cardinality position using angle, center point on the line/curve but pendicular and with offset-distance\n cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center.x) / 2;\n cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center.y) / 2;\n return cardinalityPosition;\n};\n\n/**\n * Calculates the terminal label position.\n *\n * @param terminalMarkerSize - Terminal marker size.\n * @param position - Position of label relative to points.\n * @param _points - Array of points.\n * @returns - The `cardinalityPosition`.\n */\nfunction calcTerminalLabelPosition(\n terminalMarkerSize: number,\n position: 'start_left' | 'start_right' | 'end_left' | 'end_right',\n _points: Point[]\n): Point {\n // Todo looking to faster cloning method\n let points = JSON.parse(JSON.stringify(_points));\n let prevPoint;\n log.info('our points', points);\n if (position !== 'start_left' && position !== 'start_right') {\n points = points.reverse();\n }\n\n points.forEach((point) => {\n prevPoint = point;\n });\n\n // Traverse only 25 total distance along points to find cardinality point\n const distanceToCardinalityPoint = 25 + terminalMarkerSize;\n\n let remainingDistance = distanceToCardinalityPoint;\n let center;\n prevPoint = undefined;\n points.forEach((point) => {\n if (prevPoint && !center) {\n const vectorDistance = distance(point, prevPoint);\n if (vectorDistance < remainingDistance) {\n remainingDistance -= vectorDistance;\n } else {\n // The point is remainingDistance from prevPoint in the vector between prevPoint and point\n // Calculate the coordinates\n const distanceRatio = remainingDistance / vectorDistance;\n if (distanceRatio <= 0) {\n center = prevPoint;\n }\n if (distanceRatio >= 1) {\n center = { x: point.x, y: point.y };\n }\n if (distanceRatio > 0 && distanceRatio < 1) {\n center = {\n x: (1 - distanceRatio) * prevPoint.x + distanceRatio * point.x,\n y: (1 - distanceRatio) * prevPoint.y + distanceRatio * point.y,\n };\n }\n }\n }\n prevPoint = point;\n });\n // if relation is present (Arrows will be added), change cardinality point off-set distance (d)\n const d = 10 + terminalMarkerSize * 0.5;\n //Calculate Angle for x and y axis\n const angle = Math.atan2(points[0].y - center.y, points[0].x - center.x);\n\n const cardinalityPosition = { x: 0, y: 0 };\n\n //Calculation cardinality position using angle, center point on the line/curve but pendicular and with offset-distance\n\n cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center.x) / 2;\n cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center.y) / 2;\n if (position === 'start_left') {\n cardinalityPosition.x = Math.sin(angle + Math.PI) * d + (points[0].x + center.x) / 2;\n cardinalityPosition.y = -Math.cos(angle + Math.PI) * d + (points[0].y + center.y) / 2;\n }\n if (position === 'end_right') {\n cardinalityPosition.x = Math.sin(angle - Math.PI) * d + (points[0].x + center.x) / 2 - 5;\n cardinalityPosition.y = -Math.cos(angle - Math.PI) * d + (points[0].y + center.y) / 2 - 5;\n }\n if (position === 'end_left') {\n cardinalityPosition.x = Math.sin(angle) * d + (points[0].x + center.x) / 2 - 5;\n cardinalityPosition.y = -Math.cos(angle) * d + (points[0].y + center.y) / 2 - 5;\n }\n return cardinalityPosition;\n}\n\n/**\n * Gets styles from an array of declarations\n *\n * @param arr - Declarations\n * @returns The styles grouped as strings\n */\nexport function getStylesFromArray(arr: string[]): { style: string; labelStyle: string } {\n let style = '';\n let labelStyle = '';\n\n for (const element of arr) {\n if (element !== undefined) {\n // add text properties to label style definition\n if (element.startsWith('color:') || element.startsWith('text-align:')) {\n labelStyle = labelStyle + element + ';';\n } else {\n style = style + element + ';';\n }\n }\n }\n\n return { style: style, labelStyle: labelStyle };\n}\n\nlet cnt = 0;\nexport const generateId = () => {\n cnt++;\n return 'id-' + Math.random().toString(36).substr(2, 12) + '-' + cnt;\n};\n\n/**\n * Generates a random hexadecimal id of the given length.\n *\n * @param length - Length of ID.\n * @returns The generated ID.\n */\nfunction makeid(length: number): string {\n let result = '';\n const characters = '0123456789abcdef';\n const charactersLength = characters.length;\n for (let i = 0; i < length; i++) {\n result += characters.charAt(Math.floor(Math.random() * charactersLength));\n }\n return result;\n}\n\nexport const random = (options) => {\n return makeid(options.length);\n};\n\nexport const getTextObj = function () {\n return {\n x: 0,\n y: 0,\n fill: undefined,\n anchor: 'start',\n style: '#666',\n width: 100,\n height: 100,\n textMargin: 0,\n rx: 0,\n ry: 0,\n valign: undefined,\n };\n};\n\n/**\n * Adds text to an element\n *\n * @param elem - SVG Element to add text to\n * @param textData - Text options.\n * @returns Text element with given styling and content\n */\nexport const drawSimpleText = function (\n elem: SVGElement,\n textData: {\n text: string;\n x: number;\n y: number;\n anchor: 'start' | 'middle' | 'end';\n fontFamily: string;\n fontSize: string | number;\n fontWeight: string | number;\n fill: string;\n class: string | undefined;\n textMargin: number;\n }\n): SVGTextElement {\n // Remove and ignore br:s\n const nText = textData.text.replace(common.lineBreakRegex, ' ');\n\n const [, _fontSizePx] = parseFontSize(textData.fontSize);\n\n const textElem = elem.append('text');\n textElem.attr('x', textData.x);\n textElem.attr('y', textData.y);\n textElem.style('text-anchor', textData.anchor);\n textElem.style('font-family', textData.fontFamily);\n textElem.style('font-size', _fontSizePx);\n textElem.style('font-weight', textData.fontWeight);\n textElem.attr('fill', textData.fill);\n if (textData.class !== undefined) {\n textElem.attr('class', textData.class);\n }\n\n const span = textElem.append('tspan');\n span.attr('x', textData.x + textData.textMargin * 2);\n span.attr('fill', textData.fill);\n span.text(nText);\n\n return textElem;\n};\n\ninterface WrapLabelConfig {\n fontSize: number;\n fontFamily: string;\n fontWeight: number;\n joinWith: string;\n}\n\nexport const wrapLabel: (label: string, maxWidth: string, config: WrapLabelConfig) => string =\n memoize(\n (label: string, maxWidth: string, config: WrapLabelConfig): string => {\n if (!label) {\n return label;\n }\n config = Object.assign(\n { fontSize: 12, fontWeight: 400, fontFamily: 'Arial', joinWith: '
' },\n config\n );\n if (common.lineBreakRegex.test(label)) {\n return label;\n }\n const words = label.split(' ');\n const completedLines = [];\n let nextLine = '';\n words.forEach((word, index) => {\n const wordLength = calculateTextWidth(`${word} `, config);\n const nextLineLength = calculateTextWidth(nextLine, config);\n if (wordLength > maxWidth) {\n const { hyphenatedStrings, remainingWord } = breakString(word, maxWidth, '-', config);\n completedLines.push(nextLine, ...hyphenatedStrings);\n nextLine = remainingWord;\n } else if (nextLineLength + wordLength >= maxWidth) {\n completedLines.push(nextLine);\n nextLine = word;\n } else {\n nextLine = [nextLine, word].filter(Boolean).join(' ');\n }\n const currentWord = index + 1;\n const isLastWord = currentWord === words.length;\n if (isLastWord) {\n completedLines.push(nextLine);\n }\n });\n return completedLines.filter((line) => line !== '').join(config.joinWith);\n },\n (label, maxWidth, config) =>\n `${label}${maxWidth}${config.fontSize}${config.fontWeight}${config.fontFamily}${config.joinWith}`\n );\n\ninterface BreakStringOutput {\n hyphenatedStrings: string[];\n remainingWord: string;\n}\n\nconst breakString: (\n word: string,\n maxWidth: number,\n hyphenCharacter: string,\n config: WrapLabelConfig\n) => BreakStringOutput = memoize(\n (\n word: string,\n maxWidth: number,\n hyphenCharacter = '-',\n config: WrapLabelConfig\n ): BreakStringOutput => {\n config = Object.assign(\n { fontSize: 12, fontWeight: 400, fontFamily: 'Arial', margin: 0 },\n config\n );\n const characters = [...word];\n const lines: string[] = [];\n let currentLine = '';\n characters.forEach((character, index) => {\n const nextLine = `${currentLine}${character}`;\n const lineWidth = calculateTextWidth(nextLine, config);\n if (lineWidth >= maxWidth) {\n const currentCharacter = index + 1;\n const isLastLine = characters.length === currentCharacter;\n const hyphenatedNextLine = `${nextLine}${hyphenCharacter}`;\n lines.push(isLastLine ? nextLine : hyphenatedNextLine);\n currentLine = '';\n } else {\n currentLine = nextLine;\n }\n });\n return { hyphenatedStrings: lines, remainingWord: currentLine };\n },\n (word, maxWidth, hyphenCharacter = '-', config) =>\n `${word}${maxWidth}${hyphenCharacter}${config.fontSize}${config.fontWeight}${config.fontFamily}`\n);\n\n/**\n * This calculates the text's height, taking into account the wrap breaks and both the statically\n * configured height, width, and the length of the text (in pixels).\n *\n * If the wrapped text text has greater height, we extend the height, so it's value won't overflow.\n *\n * @param text - The text to measure\n * @param config - The config for fontSize, fontFamily, and fontWeight all impacting the\n * resulting size\n * @returns The height for the given text\n */\nexport function calculateTextHeight(\n text: Parameters[0],\n config: Parameters[1]\n): ReturnType['height'] {\n config = Object.assign(\n { fontSize: 12, fontWeight: 400, fontFamily: 'Arial', margin: 15 },\n config\n );\n return calculateTextDimensions(text, config).height;\n}\n\n/**\n * This calculates the width of the given text, font size and family.\n *\n * @param text - The text to calculate the width of\n * @param config - The config for fontSize, fontFamily, and fontWeight all impacting the\n * resulting size\n * @returns The width for the given text\n */\nexport function calculateTextWidth(\n text: Parameters[0],\n config: Parameters[1]\n): ReturnType['width'] {\n config = Object.assign({ fontSize: 12, fontWeight: 400, fontFamily: 'Arial' }, config);\n return calculateTextDimensions(text, config).width;\n}\n\ninterface TextDimensionConfig {\n fontSize?: number;\n fontWeight?: number;\n fontFamily?: string;\n}\ninterface TextDimensions {\n width: number;\n height: number;\n lineHeight?: number;\n}\n/**\n * This calculates the dimensions of the given text, font size, font family, font weight, and\n * margins.\n *\n * @param text - The text to calculate the width of\n * @param config - The config for fontSize, fontFamily, fontWeight, and margin all impacting\n * the resulting size\n * @returns The dimensions for the given text\n */\nexport const calculateTextDimensions: (\n text: string,\n config: TextDimensionConfig\n) => TextDimensions = memoize(\n (text: string, config: TextDimensionConfig): TextDimensions => {\n config = Object.assign({ fontSize: 12, fontWeight: 400, fontFamily: 'Arial' }, config);\n const { fontSize, fontFamily, fontWeight } = config;\n if (!text) {\n return { width: 0, height: 0 };\n }\n\n const [, _fontSizePx] = parseFontSize(fontSize);\n\n // We can't really know if the user supplied font family will render on the user agent;\n // thus, we'll take the max width between the user supplied font family, and a default\n // of sans-serif.\n const fontFamilies = ['sans-serif', fontFamily];\n const lines = text.split(common.lineBreakRegex);\n const dims = [];\n\n const body = select('body');\n // We don't want to leak DOM elements - if a removal operation isn't available\n // for any reason, do not continue.\n if (!body.remove) {\n return { width: 0, height: 0, lineHeight: 0 };\n }\n\n const g = body.append('svg');\n\n for (const fontFamily of fontFamilies) {\n let cheight = 0;\n const dim = { width: 0, height: 0, lineHeight: 0 };\n for (const line of lines) {\n const textObj = getTextObj();\n textObj.text = line;\n const textElem = drawSimpleText(g, textObj)\n .style('font-size', _fontSizePx)\n .style('font-weight', fontWeight)\n .style('font-family', fontFamily);\n\n const bBox = (textElem._groups || textElem)[0][0].getBBox();\n dim.width = Math.round(Math.max(dim.width, bBox.width));\n cheight = Math.round(bBox.height);\n dim.height += cheight;\n dim.lineHeight = Math.round(Math.max(dim.lineHeight, cheight));\n }\n dims.push(dim);\n }\n\n g.remove();\n\n const index =\n isNaN(dims[1].height) ||\n isNaN(dims[1].width) ||\n isNaN(dims[1].lineHeight) ||\n (dims[0].height > dims[1].height &&\n dims[0].width > dims[1].width &&\n dims[0].lineHeight > dims[1].lineHeight)\n ? 0\n : 1;\n return dims[index];\n },\n (text, config) => `${text}${config.fontSize}${config.fontWeight}${config.fontFamily}`\n);\n\nexport const initIdGenerator = class iterator {\n constructor(deterministic, seed) {\n this.deterministic = deterministic;\n // TODO: Seed is only used for length?\n this.seed = seed;\n\n this.count = seed ? seed.length : 0;\n }\n\n next() {\n if (!this.deterministic) {\n return Date.now();\n }\n\n return this.count++;\n }\n};\n\nlet decoder;\n\n/**\n * Decodes HTML, source: {@link https://github.com/shrpne/entity-decode/blob/v2.0.1/browser.js}\n *\n * @param html - HTML as a string\n * @returns Unescaped HTML\n */\nexport const entityDecode = function (html: string): string {\n decoder = decoder || document.createElement('div');\n // Escape HTML before decoding for HTML Entities\n html = escape(html).replace(/%26/g, '&').replace(/%23/g, '#').replace(/%3B/g, ';');\n // decoding\n decoder.innerHTML = html;\n return unescape(decoder.textContent);\n};\n\n/**\n * Sanitizes directive objects\n *\n * @param args - Directive's JSON\n */\nexport const directiveSanitizer = (args: any) => {\n log.debug('directiveSanitizer called with', args);\n if (typeof args === 'object') {\n // check for array\n if (args.length) {\n args.forEach((arg) => directiveSanitizer(arg));\n } else {\n // This is an object\n Object.keys(args).forEach((key) => {\n log.debug('Checking key', key);\n if (key.startsWith('__')) {\n log.debug('sanitize deleting __ option', key);\n delete args[key];\n }\n\n if (key.includes('proto')) {\n log.debug('sanitize deleting proto option', key);\n delete args[key];\n }\n\n if (key.includes('constr')) {\n log.debug('sanitize deleting constr option', key);\n delete args[key];\n }\n\n if (key.includes('themeCSS')) {\n log.debug('sanitizing themeCss option');\n args[key] = sanitizeCss(args[key]);\n }\n if (key.includes('fontFamily')) {\n log.debug('sanitizing fontFamily option');\n args[key] = sanitizeCss(args[key]);\n }\n if (key.includes('altFontFamily')) {\n log.debug('sanitizing altFontFamily option');\n args[key] = sanitizeCss(args[key]);\n }\n if (!configKeys.includes(key)) {\n log.debug('sanitize deleting option', key);\n delete args[key];\n } else {\n if (typeof args[key] === 'object') {\n log.debug('sanitize deleting object', key);\n directiveSanitizer(args[key]);\n }\n }\n });\n }\n }\n if (args.themeVariables) {\n const kArr = Object.keys(args.themeVariables);\n for (const k of kArr) {\n const val = args.themeVariables[k];\n if (val && val.match && !val.match(/^[\\d \"#%(),.;A-Za-z]+$/)) {\n args.themeVariables[k] = '';\n }\n }\n }\n log.debug('After sanitization', args);\n};\nexport const sanitizeCss = (str) => {\n let startCnt = 0;\n let endCnt = 0;\n\n for (const element of str) {\n if (startCnt < endCnt) {\n return '{ /* ERROR: Unbalanced CSS */ }';\n }\n if (element === '{') {\n startCnt++;\n } else if (element === '}') {\n endCnt++;\n }\n }\n if (startCnt !== endCnt) {\n return '{ /* ERROR: Unbalanced CSS */ }';\n }\n // Todo add more checks here\n return str;\n};\n\nexport interface DetailedError {\n str: string;\n hash: any;\n error?: any;\n message?: string;\n}\n\n/** @param error - The error to check */\nexport function isDetailedError(error: unknown): error is DetailedError {\n return 'str' in error;\n}\n\n/** @param error - The error to convert to an error message */\nexport function getErrorMessage(error: unknown): string {\n if (error instanceof Error) {\n return error.message;\n }\n return String(error);\n}\n\n/**\n * Appends element with the given title and css class.\n *\n * @param parent - d3 svg object to append title to\n * @param cssClass - CSS class for the element containing the title\n * @param titleTopMargin - Margin in pixels between title and rest of the graph\n * @param title - The title. If empty, returns immediately.\n */\nexport const insertTitle = (\n parent,\n cssClass: string,\n titleTopMargin: number,\n title?: string\n): void => {\n if (!title) {\n return;\n }\n const bounds = parent.node().getBBox();\n parent\n .append('text')\n .text(title)\n .attr('x', bounds.x + bounds.width / 2)\n .attr('y', -titleTopMargin)\n .attr('class', cssClass);\n};\n\n/**\n * Parses a raw fontSize configuration value into a number and string value.\n *\n * @param fontSize - a string or number font size configuration value\n *\n * @returns parsed number and string style font size values, or nulls if a number value can't\n * be parsed from an input string.\n */\nexport const parseFontSize = (fontSize: string | number | undefined): [number?, string?] => {\n // if the font size is a number, assume a px string representation\n if (typeof fontSize === 'number') {\n return [fontSize, fontSize + 'px'];\n }\n\n const fontSizeNumber = parseInt(fontSize, 10);\n if (Number.isNaN(fontSizeNumber)) {\n // if a number value can't be parsed, return null for both values\n return [undefined, undefined];\n } else if (fontSize === String(fontSizeNumber)) {\n // if a string input doesn't contain any units, assume px units\n return [fontSizeNumber, fontSize + 'px'];\n } else {\n return [fontSizeNumber, fontSize];\n }\n};\n\nexport default {\n assignWithDepth,\n wrapLabel,\n calculateTextHeight,\n calculateTextWidth,\n calculateTextDimensions,\n detectInit,\n detectDirective,\n isSubstringInArray,\n interpolateToCurve,\n calcLabelPosition,\n calcCardinalityPosition,\n calcTerminalLabelPosition,\n formatUrl,\n getStylesFromArray,\n generateId,\n random,\n runFunc,\n entityDecode,\n initIdGenerator: initIdGenerator,\n directiveSanitizer,\n sanitizeCss,\n insertTitle,\n parseFontSize,\n};\n"],"names":["dist","sanitizeUrl_1","invalidProtocolRegex","htmlEntitiesRegex","ctrlCharactersRegex","urlSchemeRegex","relativeFirstCharacters","isRelativeUrlWithoutProtocol","url","decodeHtmlCharacters","str","match","dec","sanitizeUrl","sanitizedUrl","urlSchemeParseResults","urlScheme","abs","atan2","cos","max","min","sin","sqrt","epsilon","pi","halfPi","tau","acos","x","asin","Linear","context","y","curveLinear","Bump","bumpX","bumpY","noop","point","that","Basis","curveBasis","BasisClosed","curveBasisClosed","BasisOpen","x0","y0","curveBasisOpen","Bundle","beta","j","dx","dy","i","t","curveBundle","custom","bundle","Cardinal","tension","curveCardinal","cardinal","CardinalClosed","curveCardinalClosed","CardinalOpen","curveCardinalOpen","x1","y1","x2","y2","a","n","b","m","CatmullRom","alpha","x23","y23","curveCatmullRom","catmullRom","CatmullRomClosed","curveCatmullRomClosed","CatmullRomOpen","curveCatmullRomOpen","LinearClosed","curveLinearClosed","sign","slope3","h0","h1","s0","s1","p","slope2","h","t0","t1","MonotoneX","MonotoneY","ReflectContext","monotoneX","monotoneY","Natural","px","controlPoints","py","i0","i1","r","curveNatural","Step","curveStep","stepBefore","stepAfter","isNothing","subject","isObject","toArray","sequence","extend","target","source","index","length","key","sourceKeys","repeat","string","count","result","cycle","isNegativeZero","number","isNothing_1","isObject_1","toArray_1","repeat_1","isNegativeZero_1","extend_1","common","formatError","exception","compact","where","message","YAMLException$1","reason","mark","getLine","buffer","lineStart","lineEnd","position","maxLineLength","head","tail","maxHalfLength","padStart","makeSnippet","options","re","lineStarts","lineEnds","foundLineNo","line","lineNoLength","snippet","TYPE_CONSTRUCTOR_OPTIONS","YAML_NODE_KINDS","compileStyleAliases","map","style","alias","Type$1","tag","name","data","type","compileList","schema","currentType","newIndex","previousType","previousIndex","compileMap","collectType","Schema$1","definition","implicit","explicit","type$1","seq","failsafe","resolveYamlNull","constructYamlNull","isNull","object","_null","resolveYamlBoolean","constructYamlBoolean","isBoolean","bool","isHexCode","c","isOctCode","isDecCode","resolveYamlInteger","hasDigits","ch","constructYamlInteger","value","isInteger","int","obj","YAML_FLOAT_PATTERN","resolveYamlFloat","constructYamlFloat","SCIENTIFIC_WITHOUT_DOT","representYamlFloat","res","isFloat","float","json","core","YAML_DATE_REGEXP","YAML_TIMESTAMP_REGEXP","resolveYamlTimestamp","constructYamlTimestamp","year","month","day","hour","minute","second","fraction","delta","tz_hour","tz_minute","date","representYamlTimestamp","timestamp","resolveYamlMerge","merge","BASE64_MAP","resolveYamlBinary","code","idx","bitlen","constructYamlBinary","tailbits","input","bits","representYamlBinary","isBinary","binary","_hasOwnProperty$3","_toString$2","resolveYamlOmap","objectKeys","pair","pairKey","pairHasKey","constructYamlOmap","omap","_toString$1","resolveYamlPairs","keys","constructYamlPairs","pairs","_hasOwnProperty$2","resolveYamlSet","constructYamlSet","set","_default","_hasOwnProperty$1","CONTEXT_FLOW_IN","CONTEXT_FLOW_OUT","CONTEXT_BLOCK_IN","CONTEXT_BLOCK_OUT","CHOMPING_CLIP","CHOMPING_STRIP","CHOMPING_KEEP","PATTERN_NON_PRINTABLE","PATTERN_NON_ASCII_LINE_BREAKS","PATTERN_FLOW_INDICATORS","PATTERN_TAG_HANDLE","PATTERN_TAG_URI","_class","is_EOL","is_WHITE_SPACE","is_WS_OR_EOL","is_FLOW_INDICATOR","fromHexCode","lc","escapedHexLen","fromDecimalCode","simpleEscapeSequence","charFromCodepoint","simpleEscapeCheck","simpleEscapeMap","State$1","generateError","state","throwError","throwWarning","directiveHandlers","args","major","minor","handle","prefix","captureSegment","start","end","checkJson","_position","_length","_character","_result","mergeMappings","destination","overridableKeys","quantity","storeMappingPair","keyTag","keyNode","valueNode","startLine","startLineStart","startPos","readLineBreak","skipSeparationSpace","allowComments","checkIndent","lineBreaks","testDocumentSeparator","writeFoldedLines","readPlainScalar","nodeIndent","withinFlowCollection","preceding","following","captureStart","captureEnd","hasPendingContent","_line","_lineStart","_lineIndent","_kind","readSingleQuotedScalar","readDoubleQuotedScalar","hexLength","hexResult","tmp","readFlowCollection","readNext","_pos","_tag","_anchor","terminator","isPair","isExplicitPair","isMapping","composeNode","readBlockScalar","folding","chomping","didReadContent","detectedIndent","textIndent","emptyLines","atMoreIndented","readBlockSequence","detected","readBlockMapping","flowIndent","allowCompact","_keyLine","_keyLineStart","_keyPos","atExplicitKey","readTagProperty","isVerbatim","isNamed","tagHandle","tagName","readAnchorProperty","readAlias","parentIndent","nodeContext","allowToSeek","allowBlockStyles","allowBlockScalars","allowBlockCollections","indentStatus","atNewLine","hasContent","typeIndex","typeQuantity","typeList","blockIndent","readDocument","documentStart","directiveName","directiveArgs","hasDirectives","loadDocuments","nullpos","loadAll$1","iterator","documents","load$1","loadAll_1","load_1","loader","FAILSAFE_SCHEMA","load","frontMatterRegex","extractFrontMatter","text","db","matches","parsed","yaml.load","yaml.FAILSAFE_SCHEMA","_a","themes","getStyles","userStyles","diagramStyles","log","addStylesForDiagram","diagramTheme","getStyles$1","currentDirective","parseDirective","statement","handleDirective","error","directive","prop","directiveSanitizer","configApi.addDirective","_log","setLogLevel","_setLogLevel","getConfig","_getConfig","sanitizeText","_sanitizeText","setupGraphViewbox","_setupGraphViewbox","getCommonDb","_commonDb","_parseDirective","diagrams","registerDiagram","id","diagram","detector","addDetector","getDiagram","UnknownDiagramError","anyComment","detectors","detectType","config","registerLazyLoadedDiagrams","loadRegisteredDiagrams","failed","err","getDiagramLoader","freeGlobal","freeGlobal$1","freeSelf","root","root$1","Symbol","Symbol$2","objectProto","hasOwnProperty","nativeObjectToString","symToStringTag","getRawTag","isOwn","unmasked","objectToString","nullTag","undefinedTag","baseGetTag","asyncTag","funcTag","genTag","proxyTag","isFunction","coreJsData","coreJsData$1","maskSrcKey","uid","isMasked","func","funcProto","funcToString","toSource","reRegExpChar","reIsHostCtor","reIsNative","baseIsNative","pattern","getValue","getNative","nativeCreate","nativeCreate$1","hashClear","hashDelete","HASH_UNDEFINED","hashGet","hashHas","hashSet","Hash","entries","entry","listCacheClear","eq","other","assocIndexOf","array","arrayProto","splice","listCacheDelete","lastIndex","listCacheGet","listCacheHas","listCacheSet","ListCache","Map","Map$1","mapCacheClear","isKeyable","getMapData","mapCacheDelete","mapCacheGet","mapCacheHas","mapCacheSet","size","MapCache","FUNC_ERROR_TEXT","memoize","resolver","memoized","cache","d3CurveTypes","curveBumpX","curveBumpY","curveMonotoneX","curveMonotoneY","curveStepAfter","curveStepBefore","directiveWithoutOpen","detectInit","inits","detectDirective","results","init","assignWithDepth","commentWithoutDirectives","isSubstringInArray","arr","element","interpolateToCurve","interpolate","defaultCurve","curveName","formatUrl","linkStr","runFunc","functionName","params","arrPaths","len","fnName","distance","p1","p2","traverseEdge","points","prevPoint","totalDistance","remainingDistance","center","vectorDistance","distanceRatio","calcLabelPosition","calcCardinalityPosition","isRelationTypePresent","initialPosition","d","angle","cardinalityPosition","calcTerminalLabelPosition","terminalMarkerSize","_points","getStylesFromArray","labelStyle","cnt","generateId","makeid","characters","charactersLength","random","getTextObj","drawSimpleText","elem","textData","nText","_fontSizePx","parseFontSize","textElem","span","wrapLabel","label","maxWidth","words","completedLines","nextLine","word","wordLength","calculateTextWidth","nextLineLength","hyphenatedStrings","remainingWord","breakString","hyphenCharacter","lines","currentLine","character","currentCharacter","isLastLine","hyphenatedNextLine","calculateTextHeight","calculateTextDimensions","fontSize","fontFamily","fontWeight","fontFamilies","dims","body","select","g","cheight","dim","textObj","bBox","initIdGenerator","deterministic","seed","decoder","entityDecode","html","arg","sanitizeCss","configKeys","kArr","k","val","startCnt","endCnt","isDetailedError","getErrorMessage","insertTitle","parent","cssClass","titleTopMargin","title","bounds","fontSizeNumber","utils"],"mappings":"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"}