UNPKG

transformation-matrix

Version:

2d transformation matrix functions written in ES6 syntax. Tree shaking ready!

1,404 lines (1,273 loc) 35 kB
// @generated by Peggy 5.0.6. // // https://peggyjs.org/ class peg$SyntaxError extends SyntaxError { constructor(message, expected, found, location) { super(message); this.expected = expected; this.found = found; this.location = location; this.name = "SyntaxError"; } format(sources) { let str = "Error: " + this.message; if (this.location) { let src = null; const st = sources.find(s => s.source === this.location.source); if (st) { src = st.text.split(/\r\n|\n|\r/g); } const s = this.location.start; const offset_s = (this.location.source && (typeof this.location.source.offset === "function")) ? this.location.source.offset(s) : s; const loc = this.location.source + ":" + offset_s.line + ":" + offset_s.column; if (src) { const e = this.location.end; const filler = "".padEnd(offset_s.line.toString().length, " "); const line = src[s.line - 1]; const last = s.line === e.line ? e.column : line.length + 1; const hatLen = (last - s.column) || 1; str += "\n --> " + loc + "\n" + filler + " |\n" + offset_s.line + " | " + line + "\n" + filler + " | " + "".padEnd(s.column - 1, " ") + "".padEnd(hatLen, "^"); } else { str += "\n at " + loc; } } return str; } static buildMessage(expected, found) { function hex(ch) { return ch.codePointAt(0).toString(16).toUpperCase(); } const nonPrintable = Object.prototype.hasOwnProperty.call(RegExp.prototype, "unicode") ? new RegExp("[\\p{C}\\p{Mn}\\p{Mc}]", "gu") : null; function unicodeEscape(s) { if (nonPrintable) { return s.replace(nonPrintable, ch => "\\u{" + hex(ch) + "}"); } return s; } function literalEscape(s) { return unicodeEscape(s .replace(/\\/g, "\\\\") .replace(/"/g, "\\\"") .replace(/\0/g, "\\0") .replace(/\t/g, "\\t") .replace(/\n/g, "\\n") .replace(/\r/g, "\\r") .replace(/[\x00-\x0F]/g, ch => "\\x0" + hex(ch)) .replace(/[\x10-\x1F\x7F-\x9F]/g, ch => "\\x" + hex(ch))); } function classEscape(s) { return unicodeEscape(s .replace(/\\/g, "\\\\") .replace(/\]/g, "\\]") .replace(/\^/g, "\\^") .replace(/-/g, "\\-") .replace(/\0/g, "\\0") .replace(/\t/g, "\\t") .replace(/\n/g, "\\n") .replace(/\r/g, "\\r") .replace(/[\x00-\x0F]/g, ch => "\\x0" + hex(ch)) .replace(/[\x10-\x1F\x7F-\x9F]/g, ch => "\\x" + hex(ch))); } const DESCRIBE_EXPECTATION_FNS = { literal(expectation) { return "\"" + literalEscape(expectation.text) + "\""; }, class(expectation) { const escapedParts = expectation.parts.map( part => (Array.isArray(part) ? classEscape(part[0]) + "-" + classEscape(part[1]) : classEscape(part)) ); return "[" + (expectation.inverted ? "^" : "") + escapedParts.join("") + "]" + (expectation.unicode ? "u" : ""); }, any() { return "any character"; }, end() { return "end of input"; }, other(expectation) { return expectation.description; }, }; function describeExpectation(expectation) { return DESCRIBE_EXPECTATION_FNS[expectation.type](expectation); } function describeExpected(expected) { const descriptions = expected.map(describeExpectation); descriptions.sort(); if (descriptions.length > 0) { let j = 1; for (let i = 1; i < descriptions.length; i++) { if (descriptions[i - 1] !== descriptions[i]) { descriptions[j] = descriptions[i]; j++; } } descriptions.length = j; } switch (descriptions.length) { case 1: return descriptions[0]; case 2: return descriptions[0] + " or " + descriptions[1]; default: return descriptions.slice(0, -1).join(", ") + ", or " + descriptions[descriptions.length - 1]; } } function describeFound(found) { return found ? "\"" + literalEscape(found) + "\"" : "end of input"; } return "Expected " + describeExpected(expected) + " but " + describeFound(found) + " found."; } } function peg$parse(input, options) { options = options !== undefined ? options : {}; const peg$FAILED = {}; const peg$source = options.grammarSource; const peg$startRuleFunctions = { transformList: peg$parsetransformList, }; let peg$startRuleFunction = peg$parsetransformList; const peg$c0 = "matrix"; const peg$c1 = "("; const peg$c2 = ")"; const peg$c3 = "translate"; const peg$c4 = "scale"; const peg$c5 = "rotate"; const peg$c6 = "skewX"; const peg$c7 = "skewY"; const peg$c8 = ","; const peg$c9 = "."; const peg$r0 = /^[eE]/; const peg$r1 = /^[+\-]/; const peg$r2 = /^[0-9]/; const peg$r3 = /^[ \t\r\n]/; const peg$e0 = peg$literalExpectation("matrix", false); const peg$e1 = peg$literalExpectation("(", false); const peg$e2 = peg$literalExpectation(")", false); const peg$e3 = peg$literalExpectation("translate", false); const peg$e4 = peg$literalExpectation("scale", false); const peg$e5 = peg$literalExpectation("rotate", false); const peg$e6 = peg$literalExpectation("skewX", false); const peg$e7 = peg$literalExpectation("skewY", false); const peg$e8 = peg$literalExpectation(",", false); const peg$e9 = peg$otherExpectation("fractionalConstant"); const peg$e10 = peg$literalExpectation(".", false); const peg$e11 = peg$classExpectation(["e", "E"], false, false, false); const peg$e12 = peg$classExpectation(["+", "-"], false, false, false); const peg$e13 = peg$classExpectation([["0", "9"]], false, false, false); const peg$e14 = peg$classExpectation([" ", "\t", "\r", "\n"], false, false, false); function peg$f0(ts) { return ts; } function peg$f1(t, ts) { return t.concat(ts) } function peg$f2(a, b, c, d, e, f) { return [{type: 'matrix', a: a, b: b, c: c, d: d, e: e, f: f}]; } function peg$f3(tx, ty) { var t = {type: 'translate', tx: tx}; if (ty) t.ty = ty; return [t]; } function peg$f4(sx, sy) { var s = {type:'scale', sx: sx}; if (sy) s.sy = sy; return [s]; } function peg$f5(angle, c) { var r = {type:'rotate', angle: angle}; if (c) { r.cx = c[0]; r.cy = c[1]; } return [r]; } function peg$f6(angle) { return [{type: 'skewX', angle: angle}]; } function peg$f7(angle) { return [{type: 'skewY', angle: angle}]; } function peg$f8(f) { return parseFloat(f.join("")); } function peg$f9(i) { return parseInt(i.join("")); } function peg$f10(n) { return n; } function peg$f11(n1, n2) { return [n1, n2]; } function peg$f12(ds) { return ds.join(""); } function peg$f13(f, e) { return [f, e || null].join("") } function peg$f14(d, e) { return [d, e].join("") } function peg$f15(d1, d2) { return [d1 ? d1.join("") : null, ".", d2.join("")].join(""); } function peg$f16(d) { return d.join(""); } function peg$f17(s, d) { return ['e', s, d.join("")].join("") } let peg$currPos = options.peg$currPos | 0; let peg$savedPos = peg$currPos; const peg$posDetailsCache = [{ line: 1, column: 1 }]; let peg$maxFailPos = peg$currPos; let peg$maxFailExpected = options.peg$maxFailExpected || []; let peg$silentFails = options.peg$silentFails | 0; let peg$result; if (options.startRule) { if (!(options.startRule in peg$startRuleFunctions)) { throw new Error("Can't start parsing from rule \"" + options.startRule + "\"."); } peg$startRuleFunction = peg$startRuleFunctions[options.startRule]; } function text() { return input.substring(peg$savedPos, peg$currPos); } function offset() { return peg$savedPos; } function range() { return { source: peg$source, start: peg$savedPos, end: peg$currPos, }; } function location() { return peg$computeLocation(peg$savedPos, peg$currPos); } function expected(description, location) { location = location !== undefined ? location : peg$computeLocation(peg$savedPos, peg$currPos); throw peg$buildStructuredError( [peg$otherExpectation(description)], input.substring(peg$savedPos, peg$currPos), location ); } function error(message, location) { location = location !== undefined ? location : peg$computeLocation(peg$savedPos, peg$currPos); throw peg$buildSimpleError(message, location); } function peg$getUnicode(pos = peg$currPos) { const cp = input.codePointAt(pos); if (cp === undefined) { return ""; } return String.fromCodePoint(cp); } function peg$literalExpectation(text, ignoreCase) { return { type: "literal", text, ignoreCase }; } function peg$classExpectation(parts, inverted, ignoreCase, unicode) { return { type: "class", parts, inverted, ignoreCase, unicode }; } function peg$anyExpectation() { return { type: "any" }; } function peg$endExpectation() { return { type: "end" }; } function peg$otherExpectation(description) { return { type: "other", description }; } function peg$computePosDetails(pos) { let details = peg$posDetailsCache[pos]; let p; if (details) { return details; } else { if (pos >= peg$posDetailsCache.length) { p = peg$posDetailsCache.length - 1; } else { p = pos; while (!peg$posDetailsCache[--p]) {} } details = peg$posDetailsCache[p]; details = { line: details.line, column: details.column, }; while (p < pos) { if (input.charCodeAt(p) === 10) { details.line++; details.column = 1; } else { details.column++; } p++; } peg$posDetailsCache[pos] = details; return details; } } function peg$computeLocation(startPos, endPos, offset) { const startPosDetails = peg$computePosDetails(startPos); const endPosDetails = peg$computePosDetails(endPos); const res = { source: peg$source, start: { offset: startPos, line: startPosDetails.line, column: startPosDetails.column, }, end: { offset: endPos, line: endPosDetails.line, column: endPosDetails.column, }, }; if (offset && peg$source && (typeof peg$source.offset === "function")) { res.start = peg$source.offset(res.start); res.end = peg$source.offset(res.end); } return res; } function peg$fail(expected) { if (peg$currPos < peg$maxFailPos) { return; } if (peg$currPos > peg$maxFailPos) { peg$maxFailPos = peg$currPos; peg$maxFailExpected = []; } peg$maxFailExpected.push(expected); } function peg$buildSimpleError(message, location) { return new peg$SyntaxError(message, null, null, location); } function peg$buildStructuredError(expected, found, location) { return new peg$SyntaxError( peg$SyntaxError.buildMessage(expected, found), expected, found, location ); } function peg$parsetransformList() { let s0, s1, s2, s3, s4; s0 = peg$currPos; s1 = []; s2 = peg$parsewsp(); while (s2 !== peg$FAILED) { s1.push(s2); s2 = peg$parsewsp(); } s2 = peg$parsetransforms(); if (s2 === peg$FAILED) { s2 = null; } s3 = []; s4 = peg$parsewsp(); while (s4 !== peg$FAILED) { s3.push(s4); s4 = peg$parsewsp(); } peg$savedPos = s0; s0 = peg$f0(s2); return s0; } function peg$parsetransforms() { let s0, s1, s2, s3; s0 = peg$currPos; s1 = peg$parsetransform(); if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsecommaWsp(); if (s3 !== peg$FAILED) { while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsecommaWsp(); } } else { s2 = peg$FAILED; } if (s2 !== peg$FAILED) { s3 = peg$parsetransforms(); if (s3 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f1(s1, s3); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } if (s0 === peg$FAILED) { s0 = peg$parsetransform(); } return s0; } function peg$parsetransform() { let s0; s0 = peg$parsematrix(); if (s0 === peg$FAILED) { s0 = peg$parsetranslate(); if (s0 === peg$FAILED) { s0 = peg$parsescale(); if (s0 === peg$FAILED) { s0 = peg$parserotate(); if (s0 === peg$FAILED) { s0 = peg$parseskewX(); if (s0 === peg$FAILED) { s0 = peg$parseskewY(); } } } } } return s0; } function peg$parsematrix() { let s0, s1, s2, s3, s4, s5, s6, s7, s8, s9, s10, s11, s12, s13, s14, s15, s16, s17; s0 = peg$currPos; if (input.substr(peg$currPos, 6) === peg$c0) { s1 = peg$c0; peg$currPos += 6; } else { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e0); } } if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsewsp(); while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 40) { s3 = peg$c1; peg$currPos++; } else { s3 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e1); } } if (s3 !== peg$FAILED) { s4 = []; s5 = peg$parsewsp(); while (s5 !== peg$FAILED) { s4.push(s5); s5 = peg$parsewsp(); } s5 = peg$parsenumber(); if (s5 !== peg$FAILED) { s6 = peg$parsecommaWsp(); if (s6 !== peg$FAILED) { s7 = peg$parsenumber(); if (s7 !== peg$FAILED) { s8 = peg$parsecommaWsp(); if (s8 !== peg$FAILED) { s9 = peg$parsenumber(); if (s9 !== peg$FAILED) { s10 = peg$parsecommaWsp(); if (s10 !== peg$FAILED) { s11 = peg$parsenumber(); if (s11 !== peg$FAILED) { s12 = peg$parsecommaWsp(); if (s12 !== peg$FAILED) { s13 = peg$parsenumber(); if (s13 !== peg$FAILED) { s14 = peg$parsecommaWsp(); if (s14 !== peg$FAILED) { s15 = peg$parsenumber(); if (s15 !== peg$FAILED) { s16 = []; s17 = peg$parsewsp(); while (s17 !== peg$FAILED) { s16.push(s17); s17 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 41) { s17 = peg$c2; peg$currPos++; } else { s17 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e2); } } if (s17 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f2(s5, s7, s9, s11, s13, s15); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parsetranslate() { let s0, s1, s2, s3, s4, s5, s6, s7, s8; s0 = peg$currPos; if (input.substr(peg$currPos, 9) === peg$c3) { s1 = peg$c3; peg$currPos += 9; } else { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e3); } } if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsewsp(); while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 40) { s3 = peg$c1; peg$currPos++; } else { s3 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e1); } } if (s3 !== peg$FAILED) { s4 = []; s5 = peg$parsewsp(); while (s5 !== peg$FAILED) { s4.push(s5); s5 = peg$parsewsp(); } s5 = peg$parsenumber(); if (s5 !== peg$FAILED) { s6 = peg$parsecommaWspNumber(); if (s6 === peg$FAILED) { s6 = null; } s7 = []; s8 = peg$parsewsp(); while (s8 !== peg$FAILED) { s7.push(s8); s8 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 41) { s8 = peg$c2; peg$currPos++; } else { s8 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e2); } } if (s8 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f3(s5, s6); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parsescale() { let s0, s1, s2, s3, s4, s5, s6, s7, s8; s0 = peg$currPos; if (input.substr(peg$currPos, 5) === peg$c4) { s1 = peg$c4; peg$currPos += 5; } else { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e4); } } if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsewsp(); while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 40) { s3 = peg$c1; peg$currPos++; } else { s3 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e1); } } if (s3 !== peg$FAILED) { s4 = []; s5 = peg$parsewsp(); while (s5 !== peg$FAILED) { s4.push(s5); s5 = peg$parsewsp(); } s5 = peg$parsenumber(); if (s5 !== peg$FAILED) { s6 = peg$parsecommaWspNumber(); if (s6 === peg$FAILED) { s6 = null; } s7 = []; s8 = peg$parsewsp(); while (s8 !== peg$FAILED) { s7.push(s8); s8 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 41) { s8 = peg$c2; peg$currPos++; } else { s8 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e2); } } if (s8 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f4(s5, s6); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parserotate() { let s0, s1, s2, s3, s4, s5, s6, s7, s8; s0 = peg$currPos; if (input.substr(peg$currPos, 6) === peg$c5) { s1 = peg$c5; peg$currPos += 6; } else { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e5); } } if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsewsp(); while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 40) { s3 = peg$c1; peg$currPos++; } else { s3 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e1); } } if (s3 !== peg$FAILED) { s4 = []; s5 = peg$parsewsp(); while (s5 !== peg$FAILED) { s4.push(s5); s5 = peg$parsewsp(); } s5 = peg$parsenumber(); if (s5 !== peg$FAILED) { s6 = peg$parsecommaWspTwoNumbers(); if (s6 === peg$FAILED) { s6 = null; } s7 = []; s8 = peg$parsewsp(); while (s8 !== peg$FAILED) { s7.push(s8); s8 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 41) { s8 = peg$c2; peg$currPos++; } else { s8 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e2); } } if (s8 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f5(s5, s6); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parseskewX() { let s0, s1, s2, s3, s4, s5, s6, s7; s0 = peg$currPos; if (input.substr(peg$currPos, 5) === peg$c6) { s1 = peg$c6; peg$currPos += 5; } else { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e6); } } if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsewsp(); while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 40) { s3 = peg$c1; peg$currPos++; } else { s3 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e1); } } if (s3 !== peg$FAILED) { s4 = []; s5 = peg$parsewsp(); while (s5 !== peg$FAILED) { s4.push(s5); s5 = peg$parsewsp(); } s5 = peg$parsenumber(); if (s5 !== peg$FAILED) { s6 = []; s7 = peg$parsewsp(); while (s7 !== peg$FAILED) { s6.push(s7); s7 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 41) { s7 = peg$c2; peg$currPos++; } else { s7 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e2); } } if (s7 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f6(s5); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parseskewY() { let s0, s1, s2, s3, s4, s5, s6, s7; s0 = peg$currPos; if (input.substr(peg$currPos, 5) === peg$c7) { s1 = peg$c7; peg$currPos += 5; } else { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e7); } } if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsewsp(); while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 40) { s3 = peg$c1; peg$currPos++; } else { s3 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e1); } } if (s3 !== peg$FAILED) { s4 = []; s5 = peg$parsewsp(); while (s5 !== peg$FAILED) { s4.push(s5); s5 = peg$parsewsp(); } s5 = peg$parsenumber(); if (s5 !== peg$FAILED) { s6 = []; s7 = peg$parsewsp(); while (s7 !== peg$FAILED) { s6.push(s7); s7 = peg$parsewsp(); } if (input.charCodeAt(peg$currPos) === 41) { s7 = peg$c2; peg$currPos++; } else { s7 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e2); } } if (s7 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f7(s5); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parsenumber() { let s0, s1, s2, s3; s0 = peg$currPos; s1 = peg$currPos; s2 = peg$parsesign(); if (s2 === peg$FAILED) { s2 = null; } s3 = peg$parsefloatingPointConstant(); if (s3 !== peg$FAILED) { s2 = [s2, s3]; s1 = s2; } else { peg$currPos = s1; s1 = peg$FAILED; } if (s1 !== peg$FAILED) { peg$savedPos = s0; s1 = peg$f8(s1); } s0 = s1; if (s0 === peg$FAILED) { s0 = peg$currPos; s1 = peg$currPos; s2 = peg$parsesign(); if (s2 === peg$FAILED) { s2 = null; } s3 = peg$parseintegerConstant(); if (s3 !== peg$FAILED) { s2 = [s2, s3]; s1 = s2; } else { peg$currPos = s1; s1 = peg$FAILED; } if (s1 !== peg$FAILED) { peg$savedPos = s0; s1 = peg$f9(s1); } s0 = s1; } return s0; } function peg$parsecommaWspNumber() { let s0, s1, s2; s0 = peg$currPos; s1 = peg$parsecommaWsp(); if (s1 !== peg$FAILED) { s2 = peg$parsenumber(); if (s2 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f10(s2); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parsecommaWspTwoNumbers() { let s0, s1, s2, s3, s4; s0 = peg$currPos; s1 = peg$parsecommaWsp(); if (s1 !== peg$FAILED) { s2 = peg$parsenumber(); if (s2 !== peg$FAILED) { s3 = peg$parsecommaWsp(); if (s3 !== peg$FAILED) { s4 = peg$parsenumber(); if (s4 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f11(s2, s4); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parsecommaWsp() { let s0, s1, s2, s3, s4; s0 = peg$currPos; s1 = []; s2 = peg$parsewsp(); if (s2 !== peg$FAILED) { while (s2 !== peg$FAILED) { s1.push(s2); s2 = peg$parsewsp(); } } else { s1 = peg$FAILED; } if (s1 !== peg$FAILED) { s2 = peg$parsecomma(); if (s2 === peg$FAILED) { s2 = null; } s3 = []; s4 = peg$parsewsp(); while (s4 !== peg$FAILED) { s3.push(s4); s4 = peg$parsewsp(); } s1 = [s1, s2, s3]; s0 = s1; } else { peg$currPos = s0; s0 = peg$FAILED; } if (s0 === peg$FAILED) { s0 = peg$currPos; s1 = peg$parsecomma(); if (s1 !== peg$FAILED) { s2 = []; s3 = peg$parsewsp(); while (s3 !== peg$FAILED) { s2.push(s3); s3 = peg$parsewsp(); } s1 = [s1, s2]; s0 = s1; } else { peg$currPos = s0; s0 = peg$FAILED; } } return s0; } function peg$parsecomma() { let s0; if (input.charCodeAt(peg$currPos) === 44) { s0 = peg$c8; peg$currPos++; } else { s0 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e8); } } return s0; } function peg$parseintegerConstant() { let s0, s1; s0 = peg$currPos; s1 = peg$parsedigitSequence(); if (s1 !== peg$FAILED) { peg$savedPos = s0; s1 = peg$f12(s1); } s0 = s1; return s0; } function peg$parsefloatingPointConstant() { let s0, s1, s2; s0 = peg$currPos; s1 = peg$parsefractionalConstant(); if (s1 !== peg$FAILED) { s2 = peg$parseexponent(); if (s2 === peg$FAILED) { s2 = null; } peg$savedPos = s0; s0 = peg$f13(s1, s2); } else { peg$currPos = s0; s0 = peg$FAILED; } if (s0 === peg$FAILED) { s0 = peg$currPos; s1 = peg$parsedigitSequence(); if (s1 !== peg$FAILED) { s2 = peg$parseexponent(); if (s2 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f14(s1, s2); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } return s0; } function peg$parsefractionalConstant() { let s0, s1, s2, s3; peg$silentFails++; s0 = peg$currPos; s1 = peg$parsedigitSequence(); if (s1 === peg$FAILED) { s1 = null; } if (input.charCodeAt(peg$currPos) === 46) { s2 = peg$c9; peg$currPos++; } else { s2 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e10); } } if (s2 !== peg$FAILED) { s3 = peg$parsedigitSequence(); if (s3 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f15(s1, s3); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } if (s0 === peg$FAILED) { s0 = peg$currPos; s1 = peg$parsedigitSequence(); if (s1 !== peg$FAILED) { if (input.charCodeAt(peg$currPos) === 46) { s2 = peg$c9; peg$currPos++; } else { s2 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e10); } } if (s2 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f16(s1); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } } peg$silentFails--; if (s0 === peg$FAILED) { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e9); } } return s0; } function peg$parseexponent() { let s0, s1, s2, s3; s0 = peg$currPos; s1 = input.charAt(peg$currPos); if (peg$r0.test(s1)) { peg$currPos++; } else { s1 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e11); } } if (s1 !== peg$FAILED) { s2 = peg$parsesign(); if (s2 === peg$FAILED) { s2 = null; } s3 = peg$parsedigitSequence(); if (s3 !== peg$FAILED) { peg$savedPos = s0; s0 = peg$f17(s2, s3); } else { peg$currPos = s0; s0 = peg$FAILED; } } else { peg$currPos = s0; s0 = peg$FAILED; } return s0; } function peg$parsesign() { let s0; s0 = input.charAt(peg$currPos); if (peg$r1.test(s0)) { peg$currPos++; } else { s0 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e12); } } return s0; } function peg$parsedigitSequence() { let s0, s1; s0 = []; s1 = peg$parsedigit(); if (s1 !== peg$FAILED) { while (s1 !== peg$FAILED) { s0.push(s1); s1 = peg$parsedigit(); } } else { s0 = peg$FAILED; } return s0; } function peg$parsedigit() { let s0; s0 = input.charAt(peg$currPos); if (peg$r2.test(s0)) { peg$currPos++; } else { s0 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e13); } } return s0; } function peg$parsewsp() { let s0; s0 = input.charAt(peg$currPos); if (peg$r3.test(s0)) { peg$currPos++; } else { s0 = peg$FAILED; if (peg$silentFails === 0) { peg$fail(peg$e14); } } return s0; } peg$result = peg$startRuleFunction(); const peg$success = (peg$result !== peg$FAILED && peg$currPos === input.length); function peg$throw() { if (peg$result !== peg$FAILED && peg$currPos < input.length) { peg$fail(peg$endExpectation()); } throw peg$buildStructuredError( peg$maxFailExpected, peg$maxFailPos < input.length ? peg$getUnicode(peg$maxFailPos) : null, peg$maxFailPos < input.length ? peg$computeLocation(peg$maxFailPos, peg$maxFailPos + 1) : peg$computeLocation(peg$maxFailPos, peg$maxFailPos) ); } if (options.peg$library) { return /** @type {any} */ ({ peg$result, peg$currPos, peg$FAILED, peg$maxFailExpected, peg$maxFailPos, peg$success, peg$throw: peg$success ? undefined : peg$throw, }); } if (peg$success) { return peg$result; } else { peg$throw(); } } const peg$allowedStartRules = [ "transformList" ]; export { peg$allowedStartRules as StartRules, peg$SyntaxError as SyntaxError, peg$parse as parse };