{"version":3,"file":"tga-spectrum.esm.min.js","sources":["../node_modules/is-any-array/lib-esm/index.js","../node_modules/ml-spectra-processing/lib/x/getOutputArray.js","../node_modules/ml-spectra-processing/lib/x/xMedian.js","../node_modules/ml-spectra-processing/lib/x/xCheck.js","../node_modules/ml-spectra-processing/lib/x/xFindClosestIndex.js","../node_modules/ml-spectra-processing/lib/x/xGetFromToIndex.js","../node_modules/ml-spectra-processing/lib/x/xAdd.js","../node_modules/ml-spectra-processing/lib/x/xApplyFunctionStr.js","../node_modules/ml-spectra-processing/lib/x/xMultiply.js","../node_modules/ml-array-rescale/lib-es6/index.js","../node_modules/ml-array-min/lib-es6/index.js","../node_modules/ml-array-max/lib-es6/index.js","../node_modules/ml-matrix/matrix.js","../node_modules/ml-matrix/matrix.mjs","../node_modules/ml-spectra-processing/lib/x/xMean.js","../node_modules/ml-spectra-processing/lib/x/xStandardDeviation.js","../node_modules/ml-spectra-processing/lib/x/xVariance.js","../node_modules/ml-spectra-processing/lib/x/xEnsureFloat64.js","../node_modules/fft.js/lib/fft.js","../node_modules/ml-spectra-processing/lib/utils/createFromToArray.js","../node_modules/ml-spectra-processing/lib/x/xMaxValue.js","../node_modules/ml-spectra-processing/lib/x/xMinValue.js","../node_modules/ml-spectra-processing/lib/x/xIsMonotonic.js","../node_modules/ml-spectra-processing/lib/x/xMinMaxValues.js","../node_modules/ml-spectra-processing/lib/x/utils/erfcinv.js","../node_modules/ml-spectra-processing/lib/x/utils/simpleNormInv.js","../node_modules/ml-spectra-processing/lib/x/xNoiseSanPlot.js","../node_modules/ml-spectra-processing/lib/x/xNoiseStandardDeviation.js","../node_modules/ml-spectra-processing/lib/x/xMedianAbsoluteDeviation.js","../node_modules/ml-spectra-processing/lib/x/xNormed.js","../node_modules/ml-spectra-processing/lib/x/xSum.js","../node_modules/ml-spectra-processing/lib/x/xParetoNormalization.js","../node_modules/ml-spectra-processing/lib/x/xRolling.js","../node_modules/ml-spectra-processing/lib/x/xPadding.js","../node_modules/ml-spectra-processing/lib/matrix/matrixMinMaxZ.js","../node_modules/ml-spectra-processing/lib/matrix/matrixCheck.js","../node_modules/ml-spectra-processing/lib/xy/xyCheck.js","../node_modules/ml-spectra-processing/lib/xy/xyEnsureGrowingX.js","../node_modules/ml-spectra-processing/lib/zones/zonesNormalize.js","../node_modules/ml-spectra-processing/lib/xy/utils/integral.js","../node_modules/ml-spectra-processing/lib/xy/utils/equallySpacedSmooth.js","../node_modules/ml-spectra-processing/lib/xy/xyEquallySpaced.js","../node_modules/ml-spectra-processing/lib/zones/zonesWithPoints.js","../node_modules/ml-spectra-processing/lib/xy/utils/equallySpacedSlot.js","../node_modules/ml-spectra-processing/lib/xy/xyFilterX.js","../node_modules/ml-spectra-processing/lib/xy/xyFilterXPositive.js","../node_modules/ml-spectra-processing/lib/xy/xyGrowingX.js","../node_modules/common-spectrum/lib/jsgraph/addStyle.js","../node_modules/common-spectrum/lib/jsgraph/colors.js","../node_modules/common-spectrum/lib/jsgraph/getNormalizationAnnotations.js","../node_modules/ml-airpls/src/choleskySolver.js","../node_modules/cuthill-mckee/cuthill-mckee.js","../node_modules/ml-airpls/src/utils.js","../node_modules/ml-airpls/src/index.js","../node_modules/ml-spectra-processing/lib/x/xAbsoluteSum.js","../node_modules/ml-array-sequential-fill/lib-es6/index.js","../node_modules/ml-regression-base/lib-esm/checkArrayLength.js","../node_modules/ml-regression-base/lib-esm/BaseRegression.js","../node_modules/ml-regression-base/lib-esm/maybeToPrecision.js","../node_modules/ml-regression-polynomial/lib-esm/index.js","../node_modules/baselines/src/iterativePolynomial.js","../node_modules/ml-baseline-correction-regression/src/index.js","../node_modules/baselines/src/rollingAverage.js","../node_modules/ml-spectra-processing/lib/x/xRollingAverage.js","../node_modules/baselines/src/rollingBall.js","../node_modules/ml-rolling-ball-baseline/lib-esm/rollingBall.js","../node_modules/baselines/src/rollingMedian.js","../node_modules/ml-spectra-processing/lib/x/xRollingMedian.js","../node_modules/ml-savitzky-golay-generalized/lib-esm/index.js","../node_modules/ml-gsd/lib/algorithms/getMinMaxIntervals.js","../node_modules/ml-gsd/lib/algorithms/tryMatchOneIntervalWithMinData.js","../node_modules/ml-gsd/lib/algorithms/getPeaksFromIntervals.js","../node_modules/ml-gsd/lib/algorithms/xGetCrossZeroPoints.js","../node_modules/ml-gsd/lib/algorithms/firstDerivative.js","../node_modules/ml-gsd/lib/gsd.js","../node_modules/ml-spectra-processing/lib/x/xIsEquallySpaced.js","../node_modules/ml-gsd/lib/algorithms/secondDerivative.js","../node_modules/ml-gsd/lib/algorithms/autoAlgorithm.js","../node_modules/ml-gsd/lib/utils/optimizeTop.js","../node_modules/ml-signal-processing/lib/filters/baseline/airPLSBaseline.js","../node_modules/baselines/src/airPLS.js","../node_modules/ml-signal-processing/lib/filters/x/calibrateX.js","../node_modules/ml-signal-processing/lib/filters/scaling/centerMean.js","../node_modules/ml-signal-processing/lib/filters/scaling/centerMedian.js","../node_modules/ml-signal-processing/lib/filters/scaling/divideBySD.js","../node_modules/ml-signal-processing/lib/filters/x/ensureGrowing.js","../node_modules/ml-signal-processing/lib/filters/x/equallySpaced.js","../node_modules/ml-signal-processing/lib/filters/x/filterX.js","../node_modules/ml-signal-processing/lib/filters/sg/firstDerivative.js","../node_modules/ml-signal-processing/lib/filters/x/fromTo.js","../node_modules/ml-signal-processing/lib/filters/baseline/iterativePolynomialBaseline.js","../node_modules/ml-signal-processing/lib/filters/scaling/normed.js","../node_modules/ml-signal-processing/lib/filters/scaling/paretoNormalization.js","../node_modules/ml-signal-processing/lib/filters/scaling/rescale.js","../node_modules/ml-spectra-processing/lib/x/xRescale.js","../node_modules/ml-signal-processing/lib/filters/x/reverseIfNeeded.js","../node_modules/ml-signal-processing/lib/filters/baseline/rollingAverageBaseline.js","../node_modules/ml-signal-processing/lib/filters/baseline/rollingBallBaseline.js","../node_modules/ml-signal-processing/lib/filters/baseline/rollingMedianBaseline.js","../node_modules/ml-signal-processing/lib/filters/sg/savitzkyGolay.js","../node_modules/ml-signal-processing/lib/filters/sg/secondDerivative.js","../node_modules/ml-signal-processing/lib/filters/x/setMaxX.js","../node_modules/ml-signal-processing/lib/filters/y/setMaxY.js","../node_modules/ml-signal-processing/lib/filters/x/setMinX.js","../node_modules/ml-signal-processing/lib/filters/y/setMinY.js","../node_modules/ml-signal-processing/lib/filters/sg/thirdDerivative.js","../node_modules/ml-signal-processing/lib/filters/x/xFunction.js","../node_modules/ml-signal-processing/lib/filters/scaling/yFunction.js","../node_modules/common-spectrum/lib/util/getNormalizedSpectrum.js","../node_modules/ml-signal-processing/lib/filterXY.js","../node_modules/js-quantities/build/quantities.js","../node_modules/common-spectrum/lib/util/convertUnit.js","../node_modules/common-spectrum/lib/util/ensureRegexp.js","../node_modules/common-spectrum/lib/util/getConvertedVariable.js","../node_modules/common-spectrum/lib/util/getXYSpectra.js","../node_modules/common-spectrum/lib/Analysis.js","../node_modules/ml-spectra-processing/lib/utils/stringify.js","../node_modules/common-spectrum/lib/util/getXYSpectrum.js","../node_modules/common-spectrum/lib/util/appendDistinctParameter.js","../node_modules/common-spectrum/lib/util/appendDistinctValue.js","../node_modules/common-spectrum/lib/AnalysesManager.js","../node_modules/ensure-string/lib-esm/index.js","../node_modules/isutf8/dist/index.esm.js","../node_modules/dynamic-typing/lib-esm/parseString.js","../node_modules/gyromagnetic-ratio/lib-esm/getGyromagneticRatio.js","../node_modules/gyromagnetic-ratio/lib-esm/getGyromagneticNucleus.js","../node_modules/gyromagnetic-ratio/lib-esm/index.js","../node_modules/gyromagnetic-ratio/lib-esm/gyromagneticRatioMHzT.js","../node_modules/median-quickselect/lib/median-quickselect.min.js","../node_modules/ml-array-median/lib-es6/index.js","../node_modules/jcampconverter/dist/jcampconverter.js","../node_modules/common-spectrum/lib/from/fromJcamp.js","../node_modules/convert-to-jcamp/lib-esm/utils/addInfoData.js","../node_modules/convert-to-jcamp/lib-esm/utils/checkNumberOrArray.js","../node_modules/convert-to-jcamp/lib-esm/utils/getExtremeValues.js","../node_modules/convert-to-jcamp/lib-esm/utils/checkMatrix.js","../node_modules/convert-to-jcamp/lib-esm/utils/getBestFactor.js","../node_modules/convert-to-jcamp/lib-esm/utils/getFactorNumber.js","../node_modules/convert-to-jcamp/lib-esm/utils/getNumber.js","../node_modules/convert-to-jcamp/lib-esm/utils/rescaleAndEnsureInteger.js","../node_modules/ml-spectra-processing/lib/x/xDivide.js","../node_modules/convert-to-jcamp/lib-esm/utils/vectorEncoder.js","../node_modules/convert-to-jcamp/lib-esm/fromJSON.js","../node_modules/convert-to-jcamp/lib-esm/utils/xyDataCreator.js","../node_modules/convert-to-jcamp/lib-esm/utils/peakTableCreator.js","../node_modules/convert-to-jcamp/lib-esm/fromVariables.js","../node_modules/convert-to-jcamp/lib-esm/creatorNtuples.js","../node_modules/common-spectrum/lib/to/toJcamps.js","../node_modules/common-spectrum/lib/to/toJcamp.js","../node_modules/common-spectrum/lib/index.js","../node_modules/common-spectrum/lib/jsgraph/getJSGraph.js","../node_modules/xlsx/xlsx.mjs","../node_modules/physical-chemistry-parser/src/utils/taInstrumentsUtilities.js","../node_modules/physical-chemistry-parser/src/tga/mettlerToledo/util/calculateResidual.js","../node_modules/physical-chemistry-parser/src/tga/mettlerToledo/util/createLabeledRecords.js","../node_modules/value-units/src/split.js","../node_modules/physical-chemistry-parser/src/tga/mettlerToledo/util/getMetaTGA.js","../node_modules/physical-chemistry-parser/src/tga/mettlerToledo/util/improveRelativeResult.js","../node_modules/physical-chemistry-parser/src/tga/mettlerToledo/util/parseCurveValues.js","../node_modules/physical-chemistry-parser/src/hgPorosimetry/thermoFinnigan/hgParseThermoFinnigan.js","../node_modules/physical-chemistry-parser/src/tga/mettlerToledo/tgaParseMettlerToledo.js","../node_modules/physical-chemistry-parser/src/tga/taInstruments/tgaParseTAInstrumentsXLS.js","../node_modules/physical-chemistry-parser/src/utils/getAllSheetsFromXLS.js","../node_modules/fast-xml-parser/src/util.js","../node_modules/fast-xml-parser/src/validator.js","../node_modules/fast-xml-parser/src/xmlbuilder/orderedJs2Xml.js","../node_modules/fast-xml-parser/src/xmlbuilder/json2xml.js","../node_modules/fast-xml-parser/src/ignoreAttributes.js","../lib/from/fromMettlerToledo.js","../lib/from/fromNetzsch.js","../lib/from/parser/parsePerkinElmerAscii.js","../lib/from/fromPerkinElmer.js","../node_modules/physical-chemistry-parser/src/xrf/panalytical/xrfParserPanalytical.js","../node_modules/papaparse/papaparse.min.js","../lib/from/fromPerkinElmerCSV.js","../lib/from/parser/parseTAInstruments.js","../lib/from/fromTAInstruments.js","../lib/from/fromTAInstrumentsExcel.js"],"sourcesContent":["// eslint-disable-next-line @typescript-eslint/unbound-method\nconst toString = Object.prototype.toString;\n/**\n * Checks if an object is an instance of an Array (array or typed array, except those that contain bigint values).\n *\n * @param value - Object to check.\n * @returns True if the object is an array or a typed array.\n */\nexport function isAnyArray(value) {\n    const tag = toString.call(value);\n    return tag.endsWith('Array]') && !tag.includes('Big');\n}\n//# sourceMappingURL=index.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * This function\n * @param output - undefined or a new array\n * @param length - length of the output array\n * @returns\n */\nexport function getOutputArray(output, length) {\n    if (output !== undefined) {\n        if (!isAnyArray(output)) {\n            throw new TypeError('output option must be an array if specified');\n        }\n        if (output.length !== length) {\n            throw new TypeError('the output array does not have the correct length');\n        }\n        return output;\n    }\n    else {\n        return new Float64Array(length);\n    }\n}\n//# sourceMappingURL=getOutputArray.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Calculates the median of an array.\n * @param input - Array containing values\n * @param options\n * @returns - median\n */\nexport function xMedian(input, options = {}) {\n    if (!isAnyArray(input)) {\n        throw new TypeError('input must be an array');\n    }\n    if (input.length === 0) {\n        throw new TypeError('input must not be empty');\n    }\n    const { exact = false } = options || {};\n    const array = input.slice();\n    const middleIndex = calcMiddle(0, array.length - 1);\n    const median = quickSelect(array, middleIndex);\n    if (array.length % 2 === 1 || !exact) {\n        return median;\n    }\n    const medianNext = quickSelect(array, middleIndex + 1);\n    return (median + medianNext) / 2;\n}\nfunction quickSelect(array, middleIndex) {\n    let low = 0;\n    let high = array.length - 1;\n    let middle = 0;\n    let currentLow = 0;\n    let currentHigh = 0;\n    while (true) {\n        if (high <= low) {\n            return array[middleIndex];\n        }\n        if (high === low + 1) {\n            if (array[low] > array[high]) {\n                swap(array, low, high);\n            }\n            return array[middleIndex];\n        }\n        // Find median of low, middle and high items; swap into position low\n        middle = calcMiddle(low, high);\n        if (array[middle] > array[high])\n            swap(array, middle, high);\n        if (array[low] > array[high])\n            swap(array, low, high);\n        if (array[middle] > array[low])\n            swap(array, middle, low);\n        // Swap low item (now in position middle) into position (low+1)\n        swap(array, middle, low + 1);\n        // Nibble from each end towards middle, swapping items when stuck\n        currentLow = low + 1;\n        currentHigh = high;\n        while (true) {\n            do\n                currentLow++;\n            while (array[low] > array[currentLow]);\n            do\n                currentHigh--;\n            while (array[currentHigh] > array[low]);\n            if (currentHigh < currentLow) {\n                break;\n            }\n            swap(array, currentLow, currentHigh);\n        }\n        // Swap middle item (in position low) back into correct position\n        swap(array, low, currentHigh);\n        // Re-set active partition\n        if (currentHigh <= middleIndex) {\n            low = currentLow;\n        }\n        if (currentHigh >= middleIndex) {\n            high = currentHigh - 1;\n        }\n    }\n}\nfunction swap(array, i, j) {\n    const temp = array[j];\n    array[j] = array[i];\n    array[i] = temp;\n}\nfunction calcMiddle(i, j) {\n    return Math.floor((i + j) / 2);\n}\n//# sourceMappingURL=xMedian.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Checks if the input is a non-empty array of numbers.\n * Only checks the first element.\n * @param input - Array to check.\n * @param options - Additional checks.\n */\nexport function xCheck(input, options = {}) {\n    const { minLength } = options;\n    if (!isAnyArray(input)) {\n        throw new TypeError('input must be an array');\n    }\n    if (input.length === 0) {\n        throw new TypeError('input must not be empty');\n    }\n    if (typeof input[0] !== 'number') {\n        throw new TypeError('input must contain numbers');\n    }\n    if (minLength && input.length < minLength) {\n        throw new Error(`input must have a length of at least ${minLength}`);\n    }\n}\n//# sourceMappingURL=xCheck.js.map","/**\n * Returns the closest index of a `target`\n * @param array - array of numbers\n * @param target - target\n * @param options\n * @returns - closest index\n */\nexport function xFindClosestIndex(array, target, options = {}) {\n    const { sorted = true } = options;\n    if (sorted) {\n        let low = 0;\n        let high = array.length - 1;\n        let middle = 0;\n        while (high - low > 1) {\n            middle = low + ((high - low) >> 1);\n            if (array[middle] < target) {\n                low = middle;\n            }\n            else if (array[middle] > target) {\n                high = middle;\n            }\n            else {\n                return middle;\n            }\n        }\n        if (low < array.length - 1) {\n            if (Math.abs(target - array[low]) < Math.abs(array[low + 1] - target)) {\n                return low;\n            }\n            else {\n                return low + 1;\n            }\n        }\n        else {\n            return low;\n        }\n    }\n    else {\n        let index = 0;\n        let diff = Number.POSITIVE_INFINITY;\n        for (let i = 0; i < array.length; i++) {\n            const currentDiff = Math.abs(array[i] - target);\n            if (currentDiff < diff) {\n                diff = currentDiff;\n                index = i;\n            }\n        }\n        return index;\n    }\n}\n//# sourceMappingURL=xFindClosestIndex.js.map","import { xFindClosestIndex } from \"./xFindClosestIndex.js\";\n/**\n * Returns an object with {fromIndex, toIndex} for a specific from / to\n * @param x - array of numbers\n * @param options - Options\n */\nexport function xGetFromToIndex(x, options = {}) {\n    let { fromIndex, toIndex } = options;\n    const { from, to } = options;\n    if (fromIndex === undefined) {\n        if (from !== undefined) {\n            fromIndex = xFindClosestIndex(x, from);\n        }\n        else {\n            fromIndex = 0;\n        }\n    }\n    if (toIndex === undefined) {\n        if (to !== undefined) {\n            toIndex = xFindClosestIndex(x, to);\n        }\n        else {\n            toIndex = x.length - 1;\n        }\n    }\n    if (fromIndex < 0)\n        fromIndex = 0;\n    if (toIndex < 0)\n        toIndex = 0;\n    if (fromIndex >= x.length)\n        fromIndex = x.length - 1;\n    if (toIndex >= x.length)\n        toIndex = x.length - 1;\n    if (fromIndex > toIndex)\n        [fromIndex, toIndex] = [toIndex, fromIndex];\n    return { fromIndex, toIndex };\n}\n//# sourceMappingURL=xGetFromToIndex.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * This function xAdd the first array by the second array or a constant value to each element of the first array\n * @param array1 - the first array\n * @param array2 - the second array or number\n * @returns the result of the addition\n */\nexport function xAdd(array1, array2) {\n    let isConstant = false;\n    let constant = 0;\n    if (isAnyArray(array2)) {\n        if (array1.length !== array2.length) {\n            throw new Error('size of array1 and array2 must be identical');\n        }\n    }\n    else {\n        isConstant = true;\n        constant = array2;\n    }\n    const array3 = new Float64Array(array1.length);\n    if (isConstant) {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] + constant;\n        }\n    }\n    else {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] + array2[i];\n        }\n    }\n    return array3;\n}\n//# sourceMappingURL=xAdd.js.map","/**\n * Will apply a function on each element of the array described as a string\n * By default we will use as variable 'x'\n * In front of sequence of lowercase we will add 'Math.'. This allows to write\n * `sin(x) + cos(x)` and it will be replace internally by (x) => (Math.sin(x) + Math.cos(x))\n * @param array\n * @param options\n * @returns\n */\nexport function xApplyFunctionStr(array, options = {}) {\n    const { variableLabel = 'x', fctString = variableLabel } = options;\n    const fct = new Function(variableLabel, `return Number(${fctString\n        .replaceAll(/(?<before>^|\\W)(?<after>[\\da-z]{2,}\\()/g, '$<before>Math.$<after>')\n        .replaceAll('Math.Math', 'Math')})`);\n    const toReturn = Float64Array.from(array);\n    for (let i = 0; i < array.length; i++) {\n        toReturn[i] = fct(array[i]);\n        if (Number.isNaN(toReturn[i])) {\n            throw new Error(`The callback ${fctString} does not return a number: ${array[i]}`);\n        }\n    }\n    return toReturn;\n}\n//# sourceMappingURL=xApplyFunctionStr.js.map","import { isAnyArray } from 'is-any-array';\nimport { getOutputArray } from \"./getOutputArray.js\";\n/**\n * This function xMultiply the first array by the second array or a constant value to each element of the first array\n * @param array1 - first array\n * @param array2 - second array\n * @param options - options\n */\nexport function xMultiply(array1, array2, options = {}) {\n    let isConstant = false;\n    let constant = 0;\n    if (isAnyArray(array2)) {\n        if (array1.length !== array2.length) {\n            throw new Error('size of array1 and array2 must be identical');\n        }\n    }\n    else {\n        isConstant = true;\n        constant = array2;\n    }\n    const array3 = getOutputArray(options.output, array1.length);\n    if (isConstant) {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] * constant;\n        }\n    }\n    else {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] * array2[i];\n        }\n    }\n    return array3;\n}\n//# sourceMappingURL=xMultiply.js.map","import { isAnyArray } from 'is-any-array';\nimport max from 'ml-array-max';\nimport min from 'ml-array-min';\n\nfunction rescale(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  } else if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var output;\n\n  if (options.output !== undefined) {\n    if (!isAnyArray(options.output)) {\n      throw new TypeError('output option must be an array if specified');\n    }\n\n    output = options.output;\n  } else {\n    output = new Array(input.length);\n  }\n\n  var currentMin = min(input);\n  var currentMax = max(input);\n\n  if (currentMin === currentMax) {\n    throw new RangeError('minimum and maximum input values are equal. Cannot rescale a constant array');\n  }\n\n  var _options$min = options.min,\n      minValue = _options$min === void 0 ? options.autoMinMax ? currentMin : 0 : _options$min,\n      _options$max = options.max,\n      maxValue = _options$max === void 0 ? options.autoMinMax ? currentMax : 1 : _options$max;\n\n  if (minValue >= maxValue) {\n    throw new RangeError('min option must be smaller than max option');\n  }\n\n  var factor = (maxValue - minValue) / (currentMax - currentMin);\n\n  for (var i = 0; i < input.length; i++) {\n    output[i] = (input[i] - currentMin) * factor + minValue;\n  }\n\n  return output;\n}\n\nexport { rescale as default };\n","import { isAnyArray } from 'is-any-array';\n\nfunction min(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var _options$fromIndex = options.fromIndex,\n      fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n      _options$toIndex = options.toIndex,\n      toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n  if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n    throw new Error('fromIndex must be a positive integer smaller than length');\n  }\n\n  if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n    throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n  }\n\n  var minValue = input[fromIndex];\n\n  for (var i = fromIndex + 1; i < toIndex; i++) {\n    if (input[i] < minValue) minValue = input[i];\n  }\n\n  return minValue;\n}\n\nexport { min as default };\n","import { isAnyArray } from 'is-any-array';\n\nfunction max(input) {\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  var _options$fromIndex = options.fromIndex,\n      fromIndex = _options$fromIndex === void 0 ? 0 : _options$fromIndex,\n      _options$toIndex = options.toIndex,\n      toIndex = _options$toIndex === void 0 ? input.length : _options$toIndex;\n\n  if (fromIndex < 0 || fromIndex >= input.length || !Number.isInteger(fromIndex)) {\n    throw new Error('fromIndex must be a positive integer smaller than length');\n  }\n\n  if (toIndex <= fromIndex || toIndex > input.length || !Number.isInteger(toIndex)) {\n    throw new Error('toIndex must be an integer greater than fromIndex and at most equal to length');\n  }\n\n  var maxValue = input[fromIndex];\n\n  for (var i = fromIndex + 1; i < toIndex; i++) {\n    if (input[i] > maxValue) maxValue = input[i];\n  }\n\n  return maxValue;\n}\n\nexport { max as default };\n","'use strict';\n\nObject.defineProperty(exports, '__esModule', { value: true });\n\nvar isAnyArray = require('is-any-array');\nvar rescale = require('ml-array-rescale');\n\nconst indent = ' '.repeat(2);\nconst indentData = ' '.repeat(4);\n\n/**\n * @this {Matrix}\n * @returns {string}\n */\nfunction inspectMatrix() {\n  return inspectMatrixWithOptions(this);\n}\n\nfunction inspectMatrixWithOptions(matrix, options = {}) {\n  const {\n    maxRows = 15,\n    maxColumns = 10,\n    maxNumSize = 8,\n    padMinus = 'auto',\n  } = options;\n  return `${matrix.constructor.name} {\n${indent}[\n${indentData}${inspectData(matrix, maxRows, maxColumns, maxNumSize, padMinus)}\n${indent}]\n${indent}rows: ${matrix.rows}\n${indent}columns: ${matrix.columns}\n}`;\n}\n\nfunction inspectData(matrix, maxRows, maxColumns, maxNumSize, padMinus) {\n  const { rows, columns } = matrix;\n  const maxI = Math.min(rows, maxRows);\n  const maxJ = Math.min(columns, maxColumns);\n  const result = [];\n\n  if (padMinus === 'auto') {\n    padMinus = false;\n    loop: for (let i = 0; i < maxI; i++) {\n      for (let j = 0; j < maxJ; j++) {\n        if (matrix.get(i, j) < 0) {\n          padMinus = true;\n          break loop;\n        }\n      }\n    }\n  }\n\n  for (let i = 0; i < maxI; i++) {\n    let line = [];\n    for (let j = 0; j < maxJ; j++) {\n      line.push(formatNumber(matrix.get(i, j), maxNumSize, padMinus));\n    }\n    result.push(`${line.join(' ')}`);\n  }\n  if (maxJ !== columns) {\n    result[result.length - 1] += ` ... ${columns - maxColumns} more columns`;\n  }\n  if (maxI !== rows) {\n    result.push(`... ${rows - maxRows} more rows`);\n  }\n  return result.join(`\\n${indentData}`);\n}\n\nfunction formatNumber(num, maxNumSize, padMinus) {\n  return (\n    num >= 0 && padMinus\n      ? ` ${formatNumber2(num, maxNumSize - 1)}`\n      : formatNumber2(num, maxNumSize)\n  ).padEnd(maxNumSize);\n}\n\nfunction formatNumber2(num, len) {\n  // small.length numbers should be as is\n  let str = num.toString();\n  if (str.length <= len) return str;\n\n  // (7)'0.00123' is better then (7)'1.23e-2'\n  // (8)'0.000123' is worse then (7)'1.23e-3',\n  let fix = num.toFixed(len);\n  if (fix.length > len) {\n    fix = num.toFixed(Math.max(0, len - (fix.length - len)));\n  }\n  if (\n    fix.length <= len &&\n    !fix.startsWith('0.000') &&\n    !fix.startsWith('-0.000')\n  ) {\n    return fix;\n  }\n\n  // well, if it's still too long the user should've used longer numbers\n  let exp = num.toExponential(len);\n  if (exp.length > len) {\n    exp = num.toExponential(Math.max(0, len - (exp.length - len)));\n  }\n  return exp.slice(0);\n}\n\nfunction installMathOperations(AbstractMatrix, Matrix) {\n  AbstractMatrix.prototype.add = function add(value) {\n    if (typeof value === 'number') return this.addS(value);\n    return this.addM(value);\n  };\n\n  AbstractMatrix.prototype.addS = function addS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.addM = function addM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.add = function add(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.add(value);\n  };\n\n  AbstractMatrix.prototype.sub = function sub(value) {\n    if (typeof value === 'number') return this.subS(value);\n    return this.subM(value);\n  };\n\n  AbstractMatrix.prototype.subS = function subS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.subM = function subM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sub = function sub(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sub(value);\n  };\n  AbstractMatrix.prototype.subtract = AbstractMatrix.prototype.sub;\n  AbstractMatrix.prototype.subtractS = AbstractMatrix.prototype.subS;\n  AbstractMatrix.prototype.subtractM = AbstractMatrix.prototype.subM;\n  AbstractMatrix.subtract = AbstractMatrix.sub;\n\n  AbstractMatrix.prototype.mul = function mul(value) {\n    if (typeof value === 'number') return this.mulS(value);\n    return this.mulM(value);\n  };\n\n  AbstractMatrix.prototype.mulS = function mulS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.mulM = function mulM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.mul = function mul(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.mul(value);\n  };\n  AbstractMatrix.prototype.multiply = AbstractMatrix.prototype.mul;\n  AbstractMatrix.prototype.multiplyS = AbstractMatrix.prototype.mulS;\n  AbstractMatrix.prototype.multiplyM = AbstractMatrix.prototype.mulM;\n  AbstractMatrix.multiply = AbstractMatrix.mul;\n\n  AbstractMatrix.prototype.div = function div(value) {\n    if (typeof value === 'number') return this.divS(value);\n    return this.divM(value);\n  };\n\n  AbstractMatrix.prototype.divS = function divS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.divM = function divM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.div = function div(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.div(value);\n  };\n  AbstractMatrix.prototype.divide = AbstractMatrix.prototype.div;\n  AbstractMatrix.prototype.divideS = AbstractMatrix.prototype.divS;\n  AbstractMatrix.prototype.divideM = AbstractMatrix.prototype.divM;\n  AbstractMatrix.divide = AbstractMatrix.div;\n\n  AbstractMatrix.prototype.mod = function mod(value) {\n    if (typeof value === 'number') return this.modS(value);\n    return this.modM(value);\n  };\n\n  AbstractMatrix.prototype.modS = function modS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) % value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.modM = function modM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) % matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.mod = function mod(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.mod(value);\n  };\n  AbstractMatrix.prototype.modulus = AbstractMatrix.prototype.mod;\n  AbstractMatrix.prototype.modulusS = AbstractMatrix.prototype.modS;\n  AbstractMatrix.prototype.modulusM = AbstractMatrix.prototype.modM;\n  AbstractMatrix.modulus = AbstractMatrix.mod;\n\n  AbstractMatrix.prototype.and = function and(value) {\n    if (typeof value === 'number') return this.andS(value);\n    return this.andM(value);\n  };\n\n  AbstractMatrix.prototype.andS = function andS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) & value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.andM = function andM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) & matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.and = function and(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.and(value);\n  };\n\n  AbstractMatrix.prototype.or = function or(value) {\n    if (typeof value === 'number') return this.orS(value);\n    return this.orM(value);\n  };\n\n  AbstractMatrix.prototype.orS = function orS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) | value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.orM = function orM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) | matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.or = function or(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.or(value);\n  };\n\n  AbstractMatrix.prototype.xor = function xor(value) {\n    if (typeof value === 'number') return this.xorS(value);\n    return this.xorM(value);\n  };\n\n  AbstractMatrix.prototype.xorS = function xorS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ^ value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.xorM = function xorM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ^ matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.xor = function xor(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.xor(value);\n  };\n\n  AbstractMatrix.prototype.leftShift = function leftShift(value) {\n    if (typeof value === 'number') return this.leftShiftS(value);\n    return this.leftShiftM(value);\n  };\n\n  AbstractMatrix.prototype.leftShiftS = function leftShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) << value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.leftShiftM = function leftShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) << matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.leftShift = function leftShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.leftShift(value);\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShift = function signPropagatingRightShift(value) {\n    if (typeof value === 'number') return this.signPropagatingRightShiftS(value);\n    return this.signPropagatingRightShiftM(value);\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShiftS = function signPropagatingRightShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >> value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.signPropagatingRightShiftM = function signPropagatingRightShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >> matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.signPropagatingRightShift = function signPropagatingRightShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.signPropagatingRightShift(value);\n  };\n\n  AbstractMatrix.prototype.rightShift = function rightShift(value) {\n    if (typeof value === 'number') return this.rightShiftS(value);\n    return this.rightShiftM(value);\n  };\n\n  AbstractMatrix.prototype.rightShiftS = function rightShiftS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >>> value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.rightShiftM = function rightShiftM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) >>> matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.rightShift = function rightShift(matrix, value) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.rightShift(value);\n  };\n  AbstractMatrix.prototype.zeroFillRightShift = AbstractMatrix.prototype.rightShift;\n  AbstractMatrix.prototype.zeroFillRightShiftS = AbstractMatrix.prototype.rightShiftS;\n  AbstractMatrix.prototype.zeroFillRightShiftM = AbstractMatrix.prototype.rightShiftM;\n  AbstractMatrix.zeroFillRightShift = AbstractMatrix.rightShift;\n\n  AbstractMatrix.prototype.not = function not() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, ~(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.not = function not(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.not();\n  };\n\n  AbstractMatrix.prototype.abs = function abs() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.abs(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.abs = function abs(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.abs();\n  };\n\n  AbstractMatrix.prototype.acos = function acos() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.acos(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.acos = function acos(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.acos();\n  };\n\n  AbstractMatrix.prototype.acosh = function acosh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.acosh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.acosh = function acosh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.acosh();\n  };\n\n  AbstractMatrix.prototype.asin = function asin() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.asin(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.asin = function asin(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.asin();\n  };\n\n  AbstractMatrix.prototype.asinh = function asinh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.asinh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.asinh = function asinh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.asinh();\n  };\n\n  AbstractMatrix.prototype.atan = function atan() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.atan(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.atan = function atan(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.atan();\n  };\n\n  AbstractMatrix.prototype.atanh = function atanh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.atanh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.atanh = function atanh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.atanh();\n  };\n\n  AbstractMatrix.prototype.cbrt = function cbrt() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cbrt(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cbrt = function cbrt(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cbrt();\n  };\n\n  AbstractMatrix.prototype.ceil = function ceil() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.ceil(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.ceil = function ceil(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.ceil();\n  };\n\n  AbstractMatrix.prototype.clz32 = function clz32() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.clz32(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.clz32 = function clz32(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.clz32();\n  };\n\n  AbstractMatrix.prototype.cos = function cos() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cos(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cos = function cos(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cos();\n  };\n\n  AbstractMatrix.prototype.cosh = function cosh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.cosh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.cosh = function cosh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.cosh();\n  };\n\n  AbstractMatrix.prototype.exp = function exp() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.exp(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.exp = function exp(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.exp();\n  };\n\n  AbstractMatrix.prototype.expm1 = function expm1() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.expm1(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.expm1 = function expm1(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.expm1();\n  };\n\n  AbstractMatrix.prototype.floor = function floor() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.floor(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.floor = function floor(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.floor();\n  };\n\n  AbstractMatrix.prototype.fround = function fround() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.fround(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.fround = function fround(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.fround();\n  };\n\n  AbstractMatrix.prototype.log = function log() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log = function log(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log();\n  };\n\n  AbstractMatrix.prototype.log1p = function log1p() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log1p(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log1p = function log1p(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log1p();\n  };\n\n  AbstractMatrix.prototype.log10 = function log10() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log10(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log10 = function log10(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log10();\n  };\n\n  AbstractMatrix.prototype.log2 = function log2() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.log2(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.log2 = function log2(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.log2();\n  };\n\n  AbstractMatrix.prototype.round = function round() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.round(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.round = function round(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.round();\n  };\n\n  AbstractMatrix.prototype.sign = function sign() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sign(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sign = function sign(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sign();\n  };\n\n  AbstractMatrix.prototype.sin = function sin() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sin(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sin = function sin(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sin();\n  };\n\n  AbstractMatrix.prototype.sinh = function sinh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sinh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sinh = function sinh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sinh();\n  };\n\n  AbstractMatrix.prototype.sqrt = function sqrt() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.sqrt(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.sqrt = function sqrt(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.sqrt();\n  };\n\n  AbstractMatrix.prototype.tan = function tan() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.tan(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.tan = function tan(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.tan();\n  };\n\n  AbstractMatrix.prototype.tanh = function tanh() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.tanh(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.tanh = function tanh(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.tanh();\n  };\n\n  AbstractMatrix.prototype.trunc = function trunc() {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, Math.trunc(this.get(i, j)));\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.trunc = function trunc(matrix) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.trunc();\n  };\n\n  AbstractMatrix.pow = function pow(matrix, arg0) {\n    const newMatrix = new Matrix(matrix);\n    return newMatrix.pow(arg0);\n  };\n\n  AbstractMatrix.prototype.pow = function pow(value) {\n    if (typeof value === 'number') return this.powS(value);\n    return this.powM(value);\n  };\n\n  AbstractMatrix.prototype.powS = function powS(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ** value);\n      }\n    }\n    return this;\n  };\n\n  AbstractMatrix.prototype.powM = function powM(matrix) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (this.rows !== matrix.rows ||\n      this.columns !== matrix.columns) {\n      throw new RangeError('Matrices dimensions must be equal');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) ** matrix.get(i, j));\n      }\n    }\n    return this;\n  };\n}\n\n/**\n * @private\n * Check that a row index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nfunction checkRowIndex(matrix, index, outer) {\n  let max = outer ? matrix.rows : matrix.rows - 1;\n  if (index < 0 || index > max) {\n    throw new RangeError('Row index out of range');\n  }\n}\n\n/**\n * @private\n * Check that a column index is not out of bounds\n * @param {Matrix} matrix\n * @param {number} index\n * @param {boolean} [outer]\n */\nfunction checkColumnIndex(matrix, index, outer) {\n  let max = outer ? matrix.columns : matrix.columns - 1;\n  if (index < 0 || index > max) {\n    throw new RangeError('Column index out of range');\n  }\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nfunction checkRowVector(matrix, vector) {\n  if (vector.to1DArray) {\n    vector = vector.to1DArray();\n  }\n  if (vector.length !== matrix.columns) {\n    throw new RangeError(\n      'vector size must be the same as the number of columns',\n    );\n  }\n  return vector;\n}\n\n/**\n * @private\n * Check that the provided vector is an array with the right length\n * @param {Matrix} matrix\n * @param {Array|Matrix} vector\n * @return {Array}\n * @throws {RangeError}\n */\nfunction checkColumnVector(matrix, vector) {\n  if (vector.to1DArray) {\n    vector = vector.to1DArray();\n  }\n  if (vector.length !== matrix.rows) {\n    throw new RangeError('vector size must be the same as the number of rows');\n  }\n  return vector;\n}\n\nfunction checkRowIndices(matrix, rowIndices) {\n  if (!isAnyArray.isAnyArray(rowIndices)) {\n    throw new TypeError('row indices must be an array');\n  }\n\n  for (let i = 0; i < rowIndices.length; i++) {\n    if (rowIndices[i] < 0 || rowIndices[i] >= matrix.rows) {\n      throw new RangeError('row indices are out of range');\n    }\n  }\n}\n\nfunction checkColumnIndices(matrix, columnIndices) {\n  if (!isAnyArray.isAnyArray(columnIndices)) {\n    throw new TypeError('column indices must be an array');\n  }\n\n  for (let i = 0; i < columnIndices.length; i++) {\n    if (columnIndices[i] < 0 || columnIndices[i] >= matrix.columns) {\n      throw new RangeError('column indices are out of range');\n    }\n  }\n}\n\nfunction checkRange(matrix, startRow, endRow, startColumn, endColumn) {\n  if (arguments.length !== 5) {\n    throw new RangeError('expected 4 arguments');\n  }\n  checkNumber('startRow', startRow);\n  checkNumber('endRow', endRow);\n  checkNumber('startColumn', startColumn);\n  checkNumber('endColumn', endColumn);\n  if (\n    startRow > endRow ||\n    startColumn > endColumn ||\n    startRow < 0 ||\n    startRow >= matrix.rows ||\n    endRow < 0 ||\n    endRow >= matrix.rows ||\n    startColumn < 0 ||\n    startColumn >= matrix.columns ||\n    endColumn < 0 ||\n    endColumn >= matrix.columns\n  ) {\n    throw new RangeError('Submatrix indices are out of range');\n  }\n}\n\nfunction newArray(length, value = 0) {\n  let array = [];\n  for (let i = 0; i < length; i++) {\n    array.push(value);\n  }\n  return array;\n}\n\nfunction checkNumber(name, value) {\n  if (typeof value !== 'number') {\n    throw new TypeError(`${name} must be a number`);\n  }\n}\n\nfunction checkNonEmpty(matrix) {\n  if (matrix.isEmpty()) {\n    throw new Error('Empty matrix has no elements to index');\n  }\n}\n\nfunction sumByRow(matrix) {\n  let sum = newArray(matrix.rows);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[i] += matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction sumByColumn(matrix) {\n  let sum = newArray(matrix.columns);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[j] += matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction sumAll(matrix) {\n  let v = 0;\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      v += matrix.get(i, j);\n    }\n  }\n  return v;\n}\n\nfunction productByRow(matrix) {\n  let sum = newArray(matrix.rows, 1);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[i] *= matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction productByColumn(matrix) {\n  let sum = newArray(matrix.columns, 1);\n  for (let i = 0; i < matrix.rows; ++i) {\n    for (let j = 0; j < matrix.columns; ++j) {\n      sum[j] *= matrix.get(i, j);\n    }\n  }\n  return sum;\n}\n\nfunction productAll(matrix) {\n  let v = 1;\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      v *= matrix.get(i, j);\n    }\n  }\n  return v;\n}\n\nfunction varianceByRow(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const variance = [];\n\n  for (let i = 0; i < rows; i++) {\n    let sum1 = 0;\n    let sum2 = 0;\n    let x = 0;\n    for (let j = 0; j < cols; j++) {\n      x = matrix.get(i, j) - mean[i];\n      sum1 += x;\n      sum2 += x * x;\n    }\n    if (unbiased) {\n      variance.push((sum2 - (sum1 * sum1) / cols) / (cols - 1));\n    } else {\n      variance.push((sum2 - (sum1 * sum1) / cols) / cols);\n    }\n  }\n  return variance;\n}\n\nfunction varianceByColumn(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const variance = [];\n\n  for (let j = 0; j < cols; j++) {\n    let sum1 = 0;\n    let sum2 = 0;\n    let x = 0;\n    for (let i = 0; i < rows; i++) {\n      x = matrix.get(i, j) - mean[j];\n      sum1 += x;\n      sum2 += x * x;\n    }\n    if (unbiased) {\n      variance.push((sum2 - (sum1 * sum1) / rows) / (rows - 1));\n    } else {\n      variance.push((sum2 - (sum1 * sum1) / rows) / rows);\n    }\n  }\n  return variance;\n}\n\nfunction varianceAll(matrix, unbiased, mean) {\n  const rows = matrix.rows;\n  const cols = matrix.columns;\n  const size = rows * cols;\n\n  let sum1 = 0;\n  let sum2 = 0;\n  let x = 0;\n  for (let i = 0; i < rows; i++) {\n    for (let j = 0; j < cols; j++) {\n      x = matrix.get(i, j) - mean;\n      sum1 += x;\n      sum2 += x * x;\n    }\n  }\n  if (unbiased) {\n    return (sum2 - (sum1 * sum1) / size) / (size - 1);\n  } else {\n    return (sum2 - (sum1 * sum1) / size) / size;\n  }\n}\n\nfunction centerByRow(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean[i]);\n    }\n  }\n}\n\nfunction centerByColumn(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean[j]);\n    }\n  }\n}\n\nfunction centerAll(matrix, mean) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) - mean);\n    }\n  }\n}\n\nfunction getScaleByRow(matrix) {\n  const scale = [];\n  for (let i = 0; i < matrix.rows; i++) {\n    let sum = 0;\n    for (let j = 0; j < matrix.columns; j++) {\n      sum += matrix.get(i, j) ** 2 / (matrix.columns - 1);\n    }\n    scale.push(Math.sqrt(sum));\n  }\n  return scale;\n}\n\nfunction scaleByRow(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale[i]);\n    }\n  }\n}\n\nfunction getScaleByColumn(matrix) {\n  const scale = [];\n  for (let j = 0; j < matrix.columns; j++) {\n    let sum = 0;\n    for (let i = 0; i < matrix.rows; i++) {\n      sum += matrix.get(i, j) ** 2 / (matrix.rows - 1);\n    }\n    scale.push(Math.sqrt(sum));\n  }\n  return scale;\n}\n\nfunction scaleByColumn(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale[j]);\n    }\n  }\n}\n\nfunction getScaleAll(matrix) {\n  const divider = matrix.size - 1;\n  let sum = 0;\n  for (let j = 0; j < matrix.columns; j++) {\n    for (let i = 0; i < matrix.rows; i++) {\n      sum += matrix.get(i, j) ** 2 / divider;\n    }\n  }\n  return Math.sqrt(sum);\n}\n\nfunction scaleAll(matrix, scale) {\n  for (let i = 0; i < matrix.rows; i++) {\n    for (let j = 0; j < matrix.columns; j++) {\n      matrix.set(i, j, matrix.get(i, j) / scale);\n    }\n  }\n}\n\nclass AbstractMatrix {\n  static from1DArray(newRows, newColumns, newData) {\n    let length = newRows * newColumns;\n    if (length !== newData.length) {\n      throw new RangeError('data length does not match given dimensions');\n    }\n    let newMatrix = new Matrix(newRows, newColumns);\n    for (let row = 0; row < newRows; row++) {\n      for (let column = 0; column < newColumns; column++) {\n        newMatrix.set(row, column, newData[row * newColumns + column]);\n      }\n    }\n    return newMatrix;\n  }\n\n  static rowVector(newData) {\n    let vector = new Matrix(1, newData.length);\n    for (let i = 0; i < newData.length; i++) {\n      vector.set(0, i, newData[i]);\n    }\n    return vector;\n  }\n\n  static columnVector(newData) {\n    let vector = new Matrix(newData.length, 1);\n    for (let i = 0; i < newData.length; i++) {\n      vector.set(i, 0, newData[i]);\n    }\n    return vector;\n  }\n\n  static zeros(rows, columns) {\n    return new Matrix(rows, columns);\n  }\n\n  static ones(rows, columns) {\n    return new Matrix(rows, columns).fill(1);\n  }\n\n  static rand(rows, columns, options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { random = Math.random } = options;\n    let matrix = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        matrix.set(i, j, random());\n      }\n    }\n    return matrix;\n  }\n\n  static randInt(rows, columns, options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1000, random = Math.random } = options;\n    if (!Number.isInteger(min)) throw new TypeError('min must be an integer');\n    if (!Number.isInteger(max)) throw new TypeError('max must be an integer');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let interval = max - min;\n    let matrix = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        let value = min + Math.round(random() * interval);\n        matrix.set(i, j, value);\n      }\n    }\n    return matrix;\n  }\n\n  static eye(rows, columns, value) {\n    if (columns === undefined) columns = rows;\n    if (value === undefined) value = 1;\n    let min = Math.min(rows, columns);\n    let matrix = this.zeros(rows, columns);\n    for (let i = 0; i < min; i++) {\n      matrix.set(i, i, value);\n    }\n    return matrix;\n  }\n\n  static diag(data, rows, columns) {\n    let l = data.length;\n    if (rows === undefined) rows = l;\n    if (columns === undefined) columns = rows;\n    let min = Math.min(l, rows, columns);\n    let matrix = this.zeros(rows, columns);\n    for (let i = 0; i < min; i++) {\n      matrix.set(i, i, data[i]);\n    }\n    return matrix;\n  }\n\n  static min(matrix1, matrix2) {\n    matrix1 = this.checkMatrix(matrix1);\n    matrix2 = this.checkMatrix(matrix2);\n    let rows = matrix1.rows;\n    let columns = matrix1.columns;\n    let result = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        result.set(i, j, Math.min(matrix1.get(i, j), matrix2.get(i, j)));\n      }\n    }\n    return result;\n  }\n\n  static max(matrix1, matrix2) {\n    matrix1 = this.checkMatrix(matrix1);\n    matrix2 = this.checkMatrix(matrix2);\n    let rows = matrix1.rows;\n    let columns = matrix1.columns;\n    let result = new this(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        result.set(i, j, Math.max(matrix1.get(i, j), matrix2.get(i, j)));\n      }\n    }\n    return result;\n  }\n\n  static checkMatrix(value) {\n    return AbstractMatrix.isMatrix(value) ? value : new Matrix(value);\n  }\n\n  static isMatrix(value) {\n    return value != null && value.klass === 'Matrix';\n  }\n\n  get size() {\n    return this.rows * this.columns;\n  }\n\n  apply(callback) {\n    if (typeof callback !== 'function') {\n      throw new TypeError('callback must be a function');\n    }\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        callback.call(this, i, j);\n      }\n    }\n    return this;\n  }\n\n  to1DArray() {\n    let array = [];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        array.push(this.get(i, j));\n      }\n    }\n    return array;\n  }\n\n  to2DArray() {\n    let copy = [];\n    for (let i = 0; i < this.rows; i++) {\n      copy.push([]);\n      for (let j = 0; j < this.columns; j++) {\n        copy[i].push(this.get(i, j));\n      }\n    }\n    return copy;\n  }\n\n  toJSON() {\n    return this.to2DArray();\n  }\n\n  isRowVector() {\n    return this.rows === 1;\n  }\n\n  isColumnVector() {\n    return this.columns === 1;\n  }\n\n  isVector() {\n    return this.rows === 1 || this.columns === 1;\n  }\n\n  isSquare() {\n    return this.rows === this.columns;\n  }\n\n  isEmpty() {\n    return this.rows === 0 || this.columns === 0;\n  }\n\n  isSymmetric() {\n    if (this.isSquare()) {\n      for (let i = 0; i < this.rows; i++) {\n        for (let j = 0; j <= i; j++) {\n          if (this.get(i, j) !== this.get(j, i)) {\n            return false;\n          }\n        }\n      }\n      return true;\n    }\n    return false;\n  }\n\n  isDistance() {\n    if (!this.isSymmetric()) return false;\n\n    for (let i = 0; i < this.rows; i++) {\n      if (this.get(i, i) !== 0) return false;\n    }\n\n    return true;\n  }\n\n  isEchelonForm() {\n    let i = 0;\n    let j = 0;\n    let previousColumn = -1;\n    let isEchelonForm = true;\n    let checked = false;\n    while (i < this.rows && isEchelonForm) {\n      j = 0;\n      checked = false;\n      while (j < this.columns && checked === false) {\n        if (this.get(i, j) === 0) {\n          j++;\n        } else if (this.get(i, j) === 1 && j > previousColumn) {\n          checked = true;\n          previousColumn = j;\n        } else {\n          isEchelonForm = false;\n          checked = true;\n        }\n      }\n      i++;\n    }\n    return isEchelonForm;\n  }\n\n  isReducedEchelonForm() {\n    let i = 0;\n    let j = 0;\n    let previousColumn = -1;\n    let isReducedEchelonForm = true;\n    let checked = false;\n    while (i < this.rows && isReducedEchelonForm) {\n      j = 0;\n      checked = false;\n      while (j < this.columns && checked === false) {\n        if (this.get(i, j) === 0) {\n          j++;\n        } else if (this.get(i, j) === 1 && j > previousColumn) {\n          checked = true;\n          previousColumn = j;\n        } else {\n          isReducedEchelonForm = false;\n          checked = true;\n        }\n      }\n      for (let k = j + 1; k < this.rows; k++) {\n        if (this.get(i, k) !== 0) {\n          isReducedEchelonForm = false;\n        }\n      }\n      i++;\n    }\n    return isReducedEchelonForm;\n  }\n\n  echelonForm() {\n    let result = this.clone();\n    let h = 0;\n    let k = 0;\n    while (h < result.rows && k < result.columns) {\n      let iMax = h;\n      for (let i = h; i < result.rows; i++) {\n        if (result.get(i, k) > result.get(iMax, k)) {\n          iMax = i;\n        }\n      }\n      if (result.get(iMax, k) === 0) {\n        k++;\n      } else {\n        result.swapRows(h, iMax);\n        let tmp = result.get(h, k);\n        for (let j = k; j < result.columns; j++) {\n          result.set(h, j, result.get(h, j) / tmp);\n        }\n        for (let i = h + 1; i < result.rows; i++) {\n          let factor = result.get(i, k) / result.get(h, k);\n          result.set(i, k, 0);\n          for (let j = k + 1; j < result.columns; j++) {\n            result.set(i, j, result.get(i, j) - result.get(h, j) * factor);\n          }\n        }\n        h++;\n        k++;\n      }\n    }\n    return result;\n  }\n\n  reducedEchelonForm() {\n    let result = this.echelonForm();\n    let m = result.columns;\n    let n = result.rows;\n    let h = n - 1;\n    while (h >= 0) {\n      if (result.maxRow(h) === 0) {\n        h--;\n      } else {\n        let p = 0;\n        let pivot = false;\n        while (p < n && pivot === false) {\n          if (result.get(h, p) === 1) {\n            pivot = true;\n          } else {\n            p++;\n          }\n        }\n        for (let i = 0; i < h; i++) {\n          let factor = result.get(i, p);\n          for (let j = p; j < m; j++) {\n            let tmp = result.get(i, j) - factor * result.get(h, j);\n            result.set(i, j, tmp);\n          }\n        }\n        h--;\n      }\n    }\n    return result;\n  }\n\n  set() {\n    throw new Error('set method is unimplemented');\n  }\n\n  get() {\n    throw new Error('get method is unimplemented');\n  }\n\n  repeat(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { rows = 1, columns = 1 } = options;\n    if (!Number.isInteger(rows) || rows <= 0) {\n      throw new TypeError('rows must be a positive integer');\n    }\n    if (!Number.isInteger(columns) || columns <= 0) {\n      throw new TypeError('columns must be a positive integer');\n    }\n    let matrix = new Matrix(this.rows * rows, this.columns * columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        matrix.setSubMatrix(this, this.rows * i, this.columns * j);\n      }\n    }\n    return matrix;\n  }\n\n  fill(value) {\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, value);\n      }\n    }\n    return this;\n  }\n\n  neg() {\n    return this.mulS(-1);\n  }\n\n  getRow(index) {\n    checkRowIndex(this, index);\n    let row = [];\n    for (let i = 0; i < this.columns; i++) {\n      row.push(this.get(index, i));\n    }\n    return row;\n  }\n\n  getRowVector(index) {\n    return Matrix.rowVector(this.getRow(index));\n  }\n\n  setRow(index, array) {\n    checkRowIndex(this, index);\n    array = checkRowVector(this, array);\n    for (let i = 0; i < this.columns; i++) {\n      this.set(index, i, array[i]);\n    }\n    return this;\n  }\n\n  swapRows(row1, row2) {\n    checkRowIndex(this, row1);\n    checkRowIndex(this, row2);\n    for (let i = 0; i < this.columns; i++) {\n      let temp = this.get(row1, i);\n      this.set(row1, i, this.get(row2, i));\n      this.set(row2, i, temp);\n    }\n    return this;\n  }\n\n  getColumn(index) {\n    checkColumnIndex(this, index);\n    let column = [];\n    for (let i = 0; i < this.rows; i++) {\n      column.push(this.get(i, index));\n    }\n    return column;\n  }\n\n  getColumnVector(index) {\n    return Matrix.columnVector(this.getColumn(index));\n  }\n\n  setColumn(index, array) {\n    checkColumnIndex(this, index);\n    array = checkColumnVector(this, array);\n    for (let i = 0; i < this.rows; i++) {\n      this.set(i, index, array[i]);\n    }\n    return this;\n  }\n\n  swapColumns(column1, column2) {\n    checkColumnIndex(this, column1);\n    checkColumnIndex(this, column2);\n    for (let i = 0; i < this.rows; i++) {\n      let temp = this.get(i, column1);\n      this.set(i, column1, this.get(i, column2));\n      this.set(i, column2, temp);\n    }\n    return this;\n  }\n\n  addRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + vector[j]);\n      }\n    }\n    return this;\n  }\n\n  subRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - vector[j]);\n      }\n    }\n    return this;\n  }\n\n  mulRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * vector[j]);\n      }\n    }\n    return this;\n  }\n\n  divRowVector(vector) {\n    vector = checkRowVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / vector[j]);\n      }\n    }\n    return this;\n  }\n\n  addColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) + vector[i]);\n      }\n    }\n    return this;\n  }\n\n  subColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) - vector[i]);\n      }\n    }\n    return this;\n  }\n\n  mulColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) * vector[i]);\n      }\n    }\n    return this;\n  }\n\n  divColumnVector(vector) {\n    vector = checkColumnVector(this, vector);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        this.set(i, j, this.get(i, j) / vector[i]);\n      }\n    }\n    return this;\n  }\n\n  mulRow(index, value) {\n    checkRowIndex(this, index);\n    for (let i = 0; i < this.columns; i++) {\n      this.set(index, i, this.get(index, i) * value);\n    }\n    return this;\n  }\n\n  mulColumn(index, value) {\n    checkColumnIndex(this, index);\n    for (let i = 0; i < this.rows; i++) {\n      this.set(i, index, this.get(i, index) * value);\n    }\n    return this;\n  }\n\n  max(by) {\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    switch (by) {\n      case 'row': {\n        const max = new Array(this.rows).fill(Number.NEGATIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max[row]) {\n              max[row] = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      case 'column': {\n        const max = new Array(this.columns).fill(Number.NEGATIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max[column]) {\n              max[column] = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      case undefined: {\n        let max = this.get(0, 0);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) > max) {\n              max = this.get(row, column);\n            }\n          }\n        }\n        return max;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  maxIndex() {\n    checkNonEmpty(this);\n    let v = this.get(0, 0);\n    let idx = [0, 0];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        if (this.get(i, j) > v) {\n          v = this.get(i, j);\n          idx[0] = i;\n          idx[1] = j;\n        }\n      }\n    }\n    return idx;\n  }\n\n  min(by) {\n    if (this.isEmpty()) {\n      return NaN;\n    }\n\n    switch (by) {\n      case 'row': {\n        const min = new Array(this.rows).fill(Number.POSITIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min[row]) {\n              min[row] = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      case 'column': {\n        const min = new Array(this.columns).fill(Number.POSITIVE_INFINITY);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min[column]) {\n              min[column] = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      case undefined: {\n        let min = this.get(0, 0);\n        for (let row = 0; row < this.rows; row++) {\n          for (let column = 0; column < this.columns; column++) {\n            if (this.get(row, column) < min) {\n              min = this.get(row, column);\n            }\n          }\n        }\n        return min;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  minIndex() {\n    checkNonEmpty(this);\n    let v = this.get(0, 0);\n    let idx = [0, 0];\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        if (this.get(i, j) < v) {\n          v = this.get(i, j);\n          idx[0] = i;\n          idx[1] = j;\n        }\n      }\n    }\n    return idx;\n  }\n\n  maxRow(row) {\n    checkRowIndex(this, row);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(row, 0);\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) > v) {\n        v = this.get(row, i);\n      }\n    }\n    return v;\n  }\n\n  maxRowIndex(row) {\n    checkRowIndex(this, row);\n    checkNonEmpty(this);\n    let v = this.get(row, 0);\n    let idx = [row, 0];\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) > v) {\n        v = this.get(row, i);\n        idx[1] = i;\n      }\n    }\n    return idx;\n  }\n\n  minRow(row) {\n    checkRowIndex(this, row);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(row, 0);\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) < v) {\n        v = this.get(row, i);\n      }\n    }\n    return v;\n  }\n\n  minRowIndex(row) {\n    checkRowIndex(this, row);\n    checkNonEmpty(this);\n    let v = this.get(row, 0);\n    let idx = [row, 0];\n    for (let i = 1; i < this.columns; i++) {\n      if (this.get(row, i) < v) {\n        v = this.get(row, i);\n        idx[1] = i;\n      }\n    }\n    return idx;\n  }\n\n  maxColumn(column) {\n    checkColumnIndex(this, column);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(0, column);\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) > v) {\n        v = this.get(i, column);\n      }\n    }\n    return v;\n  }\n\n  maxColumnIndex(column) {\n    checkColumnIndex(this, column);\n    checkNonEmpty(this);\n    let v = this.get(0, column);\n    let idx = [0, column];\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) > v) {\n        v = this.get(i, column);\n        idx[0] = i;\n      }\n    }\n    return idx;\n  }\n\n  minColumn(column) {\n    checkColumnIndex(this, column);\n    if (this.isEmpty()) {\n      return NaN;\n    }\n    let v = this.get(0, column);\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) < v) {\n        v = this.get(i, column);\n      }\n    }\n    return v;\n  }\n\n  minColumnIndex(column) {\n    checkColumnIndex(this, column);\n    checkNonEmpty(this);\n    let v = this.get(0, column);\n    let idx = [0, column];\n    for (let i = 1; i < this.rows; i++) {\n      if (this.get(i, column) < v) {\n        v = this.get(i, column);\n        idx[0] = i;\n      }\n    }\n    return idx;\n  }\n\n  diag() {\n    let min = Math.min(this.rows, this.columns);\n    let diag = [];\n    for (let i = 0; i < min; i++) {\n      diag.push(this.get(i, i));\n    }\n    return diag;\n  }\n\n  norm(type = 'frobenius') {\n    switch (type) {\n      case 'max':\n        return this.max();\n      case 'frobenius':\n        return Math.sqrt(this.dot(this));\n      default:\n        throw new RangeError(`unknown norm type: ${type}`);\n    }\n  }\n\n  cumulativeSum() {\n    let sum = 0;\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        sum += this.get(i, j);\n        this.set(i, j, sum);\n      }\n    }\n    return this;\n  }\n\n  dot(vector2) {\n    if (AbstractMatrix.isMatrix(vector2)) vector2 = vector2.to1DArray();\n    let vector1 = this.to1DArray();\n    if (vector1.length !== vector2.length) {\n      throw new RangeError('vectors do not have the same size');\n    }\n    let dot = 0;\n    for (let i = 0; i < vector1.length; i++) {\n      dot += vector1[i] * vector2[i];\n    }\n    return dot;\n  }\n\n  mmul(other) {\n    other = Matrix.checkMatrix(other);\n\n    let m = this.rows;\n    let n = this.columns;\n    let p = other.columns;\n\n    let result = new Matrix(m, p);\n\n    let Bcolj = new Float64Array(n);\n    for (let j = 0; j < p; j++) {\n      for (let k = 0; k < n; k++) {\n        Bcolj[k] = other.get(k, j);\n      }\n\n      for (let i = 0; i < m; i++) {\n        let s = 0;\n        for (let k = 0; k < n; k++) {\n          s += this.get(i, k) * Bcolj[k];\n        }\n\n        result.set(i, j, s);\n      }\n    }\n    return result;\n  }\n\n  mpow(scalar) {\n    if (!this.isSquare()) {\n      throw new RangeError('Matrix must be square');\n    }\n    if (!Number.isInteger(scalar) || scalar < 0) {\n      throw new RangeError('Exponent must be a non-negative integer');\n    }\n    // Russian Peasant exponentiation, i.e. exponentiation by squaring\n    let result = Matrix.eye(this.rows);\n    let bb = this;\n    // Note: Don't bit shift. In JS, that would truncate at 32 bits\n    for (let e = scalar; e >= 1; e /= 2) {\n      if ((e & 1) !== 0) {\n        result = result.mmul(bb);\n      }\n      bb = bb.mmul(bb);\n    }\n    return result;\n  }\n\n  strassen2x2(other) {\n    other = Matrix.checkMatrix(other);\n    let result = new Matrix(2, 2);\n    const a11 = this.get(0, 0);\n    const b11 = other.get(0, 0);\n    const a12 = this.get(0, 1);\n    const b12 = other.get(0, 1);\n    const a21 = this.get(1, 0);\n    const b21 = other.get(1, 0);\n    const a22 = this.get(1, 1);\n    const b22 = other.get(1, 1);\n\n    // Compute intermediate values.\n    const m1 = (a11 + a22) * (b11 + b22);\n    const m2 = (a21 + a22) * b11;\n    const m3 = a11 * (b12 - b22);\n    const m4 = a22 * (b21 - b11);\n    const m5 = (a11 + a12) * b22;\n    const m6 = (a21 - a11) * (b11 + b12);\n    const m7 = (a12 - a22) * (b21 + b22);\n\n    // Combine intermediate values into the output.\n    const c00 = m1 + m4 - m5 + m7;\n    const c01 = m3 + m5;\n    const c10 = m2 + m4;\n    const c11 = m1 - m2 + m3 + m6;\n\n    result.set(0, 0, c00);\n    result.set(0, 1, c01);\n    result.set(1, 0, c10);\n    result.set(1, 1, c11);\n    return result;\n  }\n\n  strassen3x3(other) {\n    other = Matrix.checkMatrix(other);\n    let result = new Matrix(3, 3);\n\n    const a00 = this.get(0, 0);\n    const a01 = this.get(0, 1);\n    const a02 = this.get(0, 2);\n    const a10 = this.get(1, 0);\n    const a11 = this.get(1, 1);\n    const a12 = this.get(1, 2);\n    const a20 = this.get(2, 0);\n    const a21 = this.get(2, 1);\n    const a22 = this.get(2, 2);\n\n    const b00 = other.get(0, 0);\n    const b01 = other.get(0, 1);\n    const b02 = other.get(0, 2);\n    const b10 = other.get(1, 0);\n    const b11 = other.get(1, 1);\n    const b12 = other.get(1, 2);\n    const b20 = other.get(2, 0);\n    const b21 = other.get(2, 1);\n    const b22 = other.get(2, 2);\n\n    const m1 = (a00 + a01 + a02 - a10 - a11 - a21 - a22) * b11;\n    const m2 = (a00 - a10) * (-b01 + b11);\n    const m3 = a11 * (-b00 + b01 + b10 - b11 - b12 - b20 + b22);\n    const m4 = (-a00 + a10 + a11) * (b00 - b01 + b11);\n    const m5 = (a10 + a11) * (-b00 + b01);\n    const m6 = a00 * b00;\n    const m7 = (-a00 + a20 + a21) * (b00 - b02 + b12);\n    const m8 = (-a00 + a20) * (b02 - b12);\n    const m9 = (a20 + a21) * (-b00 + b02);\n    const m10 = (a00 + a01 + a02 - a11 - a12 - a20 - a21) * b12;\n    const m11 = a21 * (-b00 + b02 + b10 - b11 - b12 - b20 + b21);\n    const m12 = (-a02 + a21 + a22) * (b11 + b20 - b21);\n    const m13 = (a02 - a22) * (b11 - b21);\n    const m14 = a02 * b20;\n    const m15 = (a21 + a22) * (-b20 + b21);\n    const m16 = (-a02 + a11 + a12) * (b12 + b20 - b22);\n    const m17 = (a02 - a12) * (b12 - b22);\n    const m18 = (a11 + a12) * (-b20 + b22);\n    const m19 = a01 * b10;\n    const m20 = a12 * b21;\n    const m21 = a10 * b02;\n    const m22 = a20 * b01;\n    const m23 = a22 * b22;\n\n    const c00 = m6 + m14 + m19;\n    const c01 = m1 + m4 + m5 + m6 + m12 + m14 + m15;\n    const c02 = m6 + m7 + m9 + m10 + m14 + m16 + m18;\n    const c10 = m2 + m3 + m4 + m6 + m14 + m16 + m17;\n    const c11 = m2 + m4 + m5 + m6 + m20;\n    const c12 = m14 + m16 + m17 + m18 + m21;\n    const c20 = m6 + m7 + m8 + m11 + m12 + m13 + m14;\n    const c21 = m12 + m13 + m14 + m15 + m22;\n    const c22 = m6 + m7 + m8 + m9 + m23;\n\n    result.set(0, 0, c00);\n    result.set(0, 1, c01);\n    result.set(0, 2, c02);\n    result.set(1, 0, c10);\n    result.set(1, 1, c11);\n    result.set(1, 2, c12);\n    result.set(2, 0, c20);\n    result.set(2, 1, c21);\n    result.set(2, 2, c22);\n    return result;\n  }\n\n  mmulStrassen(y) {\n    y = Matrix.checkMatrix(y);\n    let x = this.clone();\n    let r1 = x.rows;\n    let c1 = x.columns;\n    let r2 = y.rows;\n    let c2 = y.columns;\n    if (c1 !== r2) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        `Multiplying ${r1} x ${c1} and ${r2} x ${c2} matrix: dimensions do not match.`,\n      );\n    }\n\n    // Put a matrix into the top left of a matrix of zeros.\n    // `rows` and `cols` are the dimensions of the output matrix.\n    function embed(mat, rows, cols) {\n      let r = mat.rows;\n      let c = mat.columns;\n      if (r === rows && c === cols) {\n        return mat;\n      } else {\n        let resultat = AbstractMatrix.zeros(rows, cols);\n        resultat = resultat.setSubMatrix(mat, 0, 0);\n        return resultat;\n      }\n    }\n\n    // Make sure both matrices are the same size.\n    // This is exclusively for simplicity:\n    // this algorithm can be implemented with matrices of different sizes.\n\n    let r = Math.max(r1, r2);\n    let c = Math.max(c1, c2);\n    x = embed(x, r, c);\n    y = embed(y, r, c);\n\n    // Our recursive multiplication function.\n    function blockMult(a, b, rows, cols) {\n      // For small matrices, resort to naive multiplication.\n      if (rows <= 512 || cols <= 512) {\n        return a.mmul(b); // a is equivalent to this\n      }\n\n      // Apply dynamic padding.\n      if (rows % 2 === 1 && cols % 2 === 1) {\n        a = embed(a, rows + 1, cols + 1);\n        b = embed(b, rows + 1, cols + 1);\n      } else if (rows % 2 === 1) {\n        a = embed(a, rows + 1, cols);\n        b = embed(b, rows + 1, cols);\n      } else if (cols % 2 === 1) {\n        a = embed(a, rows, cols + 1);\n        b = embed(b, rows, cols + 1);\n      }\n\n      let halfRows = parseInt(a.rows / 2, 10);\n      let halfCols = parseInt(a.columns / 2, 10);\n      // Subdivide input matrices.\n      let a11 = a.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n      let b11 = b.subMatrix(0, halfRows - 1, 0, halfCols - 1);\n\n      let a12 = a.subMatrix(0, halfRows - 1, halfCols, a.columns - 1);\n      let b12 = b.subMatrix(0, halfRows - 1, halfCols, b.columns - 1);\n\n      let a21 = a.subMatrix(halfRows, a.rows - 1, 0, halfCols - 1);\n      let b21 = b.subMatrix(halfRows, b.rows - 1, 0, halfCols - 1);\n\n      let a22 = a.subMatrix(halfRows, a.rows - 1, halfCols, a.columns - 1);\n      let b22 = b.subMatrix(halfRows, b.rows - 1, halfCols, b.columns - 1);\n\n      // Compute intermediate values.\n      let m1 = blockMult(\n        AbstractMatrix.add(a11, a22),\n        AbstractMatrix.add(b11, b22),\n        halfRows,\n        halfCols,\n      );\n      let m2 = blockMult(AbstractMatrix.add(a21, a22), b11, halfRows, halfCols);\n      let m3 = blockMult(a11, AbstractMatrix.sub(b12, b22), halfRows, halfCols);\n      let m4 = blockMult(a22, AbstractMatrix.sub(b21, b11), halfRows, halfCols);\n      let m5 = blockMult(AbstractMatrix.add(a11, a12), b22, halfRows, halfCols);\n      let m6 = blockMult(\n        AbstractMatrix.sub(a21, a11),\n        AbstractMatrix.add(b11, b12),\n        halfRows,\n        halfCols,\n      );\n      let m7 = blockMult(\n        AbstractMatrix.sub(a12, a22),\n        AbstractMatrix.add(b21, b22),\n        halfRows,\n        halfCols,\n      );\n\n      // Combine intermediate values into the output.\n      let c11 = AbstractMatrix.add(m1, m4);\n      c11.sub(m5);\n      c11.add(m7);\n      let c12 = AbstractMatrix.add(m3, m5);\n      let c21 = AbstractMatrix.add(m2, m4);\n      let c22 = AbstractMatrix.sub(m1, m2);\n      c22.add(m3);\n      c22.add(m6);\n\n      // Crop output to the desired size (undo dynamic padding).\n      let result = AbstractMatrix.zeros(2 * c11.rows, 2 * c11.columns);\n      result = result.setSubMatrix(c11, 0, 0);\n      result = result.setSubMatrix(c12, c11.rows, 0);\n      result = result.setSubMatrix(c21, 0, c11.columns);\n      result = result.setSubMatrix(c22, c11.rows, c11.columns);\n      return result.subMatrix(0, rows - 1, 0, cols - 1);\n    }\n\n    return blockMult(x, y, r, c);\n  }\n\n  scaleRows(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1 } = options;\n    if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n    if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let newMatrix = new Matrix(this.rows, this.columns);\n    for (let i = 0; i < this.rows; i++) {\n      const row = this.getRow(i);\n      if (row.length > 0) {\n        rescale(row, { min, max, output: row });\n      }\n      newMatrix.setRow(i, row);\n    }\n    return newMatrix;\n  }\n\n  scaleColumns(options = {}) {\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { min = 0, max = 1 } = options;\n    if (!Number.isFinite(min)) throw new TypeError('min must be a number');\n    if (!Number.isFinite(max)) throw new TypeError('max must be a number');\n    if (min >= max) throw new RangeError('min must be smaller than max');\n    let newMatrix = new Matrix(this.rows, this.columns);\n    for (let i = 0; i < this.columns; i++) {\n      const column = this.getColumn(i);\n      if (column.length) {\n        rescale(column, {\n          min,\n          max,\n          output: column,\n        });\n      }\n      newMatrix.setColumn(i, column);\n    }\n    return newMatrix;\n  }\n\n  flipRows() {\n    const middle = Math.ceil(this.columns / 2);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < middle; j++) {\n        let first = this.get(i, j);\n        let last = this.get(i, this.columns - 1 - j);\n        this.set(i, j, last);\n        this.set(i, this.columns - 1 - j, first);\n      }\n    }\n    return this;\n  }\n\n  flipColumns() {\n    const middle = Math.ceil(this.rows / 2);\n    for (let j = 0; j < this.columns; j++) {\n      for (let i = 0; i < middle; i++) {\n        let first = this.get(i, j);\n        let last = this.get(this.rows - 1 - i, j);\n        this.set(i, j, last);\n        this.set(this.rows - 1 - i, j, first);\n      }\n    }\n    return this;\n  }\n\n  kroneckerProduct(other) {\n    other = Matrix.checkMatrix(other);\n\n    let m = this.rows;\n    let n = this.columns;\n    let p = other.rows;\n    let q = other.columns;\n\n    let result = new Matrix(m * p, n * q);\n    for (let i = 0; i < m; i++) {\n      for (let j = 0; j < n; j++) {\n        for (let k = 0; k < p; k++) {\n          for (let l = 0; l < q; l++) {\n            result.set(p * i + k, q * j + l, this.get(i, j) * other.get(k, l));\n          }\n        }\n      }\n    }\n    return result;\n  }\n\n  kroneckerSum(other) {\n    other = Matrix.checkMatrix(other);\n    if (!this.isSquare() || !other.isSquare()) {\n      throw new Error('Kronecker Sum needs two Square Matrices');\n    }\n    let m = this.rows;\n    let n = other.rows;\n    let AxI = this.kroneckerProduct(Matrix.eye(n, n));\n    let IxB = Matrix.eye(m, m).kroneckerProduct(other);\n    return AxI.add(IxB);\n  }\n\n  transpose() {\n    let result = new Matrix(this.columns, this.rows);\n    for (let i = 0; i < this.rows; i++) {\n      for (let j = 0; j < this.columns; j++) {\n        result.set(j, i, this.get(i, j));\n      }\n    }\n    return result;\n  }\n\n  sortRows(compareFunction = compareNumbers) {\n    for (let i = 0; i < this.rows; i++) {\n      this.setRow(i, this.getRow(i).sort(compareFunction));\n    }\n    return this;\n  }\n\n  sortColumns(compareFunction = compareNumbers) {\n    for (let i = 0; i < this.columns; i++) {\n      this.setColumn(i, this.getColumn(i).sort(compareFunction));\n    }\n    return this;\n  }\n\n  subMatrix(startRow, endRow, startColumn, endColumn) {\n    checkRange(this, startRow, endRow, startColumn, endColumn);\n    let newMatrix = new Matrix(\n      endRow - startRow + 1,\n      endColumn - startColumn + 1,\n    );\n    for (let i = startRow; i <= endRow; i++) {\n      for (let j = startColumn; j <= endColumn; j++) {\n        newMatrix.set(i - startRow, j - startColumn, this.get(i, j));\n      }\n    }\n    return newMatrix;\n  }\n\n  subMatrixRow(indices, startColumn, endColumn) {\n    if (startColumn === undefined) startColumn = 0;\n    if (endColumn === undefined) endColumn = this.columns - 1;\n    if (\n      startColumn > endColumn ||\n      startColumn < 0 ||\n      startColumn >= this.columns ||\n      endColumn < 0 ||\n      endColumn >= this.columns\n    ) {\n      throw new RangeError('Argument out of range');\n    }\n\n    let newMatrix = new Matrix(indices.length, endColumn - startColumn + 1);\n    for (let i = 0; i < indices.length; i++) {\n      for (let j = startColumn; j <= endColumn; j++) {\n        if (indices[i] < 0 || indices[i] >= this.rows) {\n          throw new RangeError(`Row index out of range: ${indices[i]}`);\n        }\n        newMatrix.set(i, j - startColumn, this.get(indices[i], j));\n      }\n    }\n    return newMatrix;\n  }\n\n  subMatrixColumn(indices, startRow, endRow) {\n    if (startRow === undefined) startRow = 0;\n    if (endRow === undefined) endRow = this.rows - 1;\n    if (\n      startRow > endRow ||\n      startRow < 0 ||\n      startRow >= this.rows ||\n      endRow < 0 ||\n      endRow >= this.rows\n    ) {\n      throw new RangeError('Argument out of range');\n    }\n\n    let newMatrix = new Matrix(endRow - startRow + 1, indices.length);\n    for (let i = 0; i < indices.length; i++) {\n      for (let j = startRow; j <= endRow; j++) {\n        if (indices[i] < 0 || indices[i] >= this.columns) {\n          throw new RangeError(`Column index out of range: ${indices[i]}`);\n        }\n        newMatrix.set(j - startRow, i, this.get(j, indices[i]));\n      }\n    }\n    return newMatrix;\n  }\n\n  setSubMatrix(matrix, startRow, startColumn) {\n    matrix = Matrix.checkMatrix(matrix);\n    if (matrix.isEmpty()) {\n      return this;\n    }\n    let endRow = startRow + matrix.rows - 1;\n    let endColumn = startColumn + matrix.columns - 1;\n    checkRange(this, startRow, endRow, startColumn, endColumn);\n    for (let i = 0; i < matrix.rows; i++) {\n      for (let j = 0; j < matrix.columns; j++) {\n        this.set(startRow + i, startColumn + j, matrix.get(i, j));\n      }\n    }\n    return this;\n  }\n\n  selection(rowIndices, columnIndices) {\n    checkRowIndices(this, rowIndices);\n    checkColumnIndices(this, columnIndices);\n    let newMatrix = new Matrix(rowIndices.length, columnIndices.length);\n    for (let i = 0; i < rowIndices.length; i++) {\n      let rowIndex = rowIndices[i];\n      for (let j = 0; j < columnIndices.length; j++) {\n        let columnIndex = columnIndices[j];\n        newMatrix.set(i, j, this.get(rowIndex, columnIndex));\n      }\n    }\n    return newMatrix;\n  }\n\n  trace() {\n    let min = Math.min(this.rows, this.columns);\n    let trace = 0;\n    for (let i = 0; i < min; i++) {\n      trace += this.get(i, i);\n    }\n    return trace;\n  }\n\n  clone() {\n    return this.constructor.copy(this, new Matrix(this.rows, this.columns));\n  }\n\n  /**\n   * @template {AbstractMatrix} M\n   * @param {AbstractMatrix} from\n   * @param {M} to\n   * @return {M}\n   */\n  static copy(from, to) {\n    for (const [row, column, value] of from.entries()) {\n      to.set(row, column, value);\n    }\n\n    return to;\n  }\n\n  sum(by) {\n    switch (by) {\n      case 'row':\n        return sumByRow(this);\n      case 'column':\n        return sumByColumn(this);\n      case undefined:\n        return sumAll(this);\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  product(by) {\n    switch (by) {\n      case 'row':\n        return productByRow(this);\n      case 'column':\n        return productByColumn(this);\n      case undefined:\n        return productAll(this);\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  mean(by) {\n    const sum = this.sum(by);\n    switch (by) {\n      case 'row': {\n        for (let i = 0; i < this.rows; i++) {\n          sum[i] /= this.columns;\n        }\n        return sum;\n      }\n      case 'column': {\n        for (let i = 0; i < this.columns; i++) {\n          sum[i] /= this.rows;\n        }\n        return sum;\n      }\n      case undefined:\n        return sum / this.size;\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  variance(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { unbiased = true, mean = this.mean(by) } = options;\n    if (typeof unbiased !== 'boolean') {\n      throw new TypeError('unbiased must be a boolean');\n    }\n    switch (by) {\n      case 'row': {\n        if (!isAnyArray.isAnyArray(mean)) {\n          throw new TypeError('mean must be an array');\n        }\n        return varianceByRow(this, unbiased, mean);\n      }\n      case 'column': {\n        if (!isAnyArray.isAnyArray(mean)) {\n          throw new TypeError('mean must be an array');\n        }\n        return varianceByColumn(this, unbiased, mean);\n      }\n      case undefined: {\n        if (typeof mean !== 'number') {\n          throw new TypeError('mean must be a number');\n        }\n        return varianceAll(this, unbiased, mean);\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  standardDeviation(by, options) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    const variance = this.variance(by, options);\n    if (by === undefined) {\n      return Math.sqrt(variance);\n    } else {\n      for (let i = 0; i < variance.length; i++) {\n        variance[i] = Math.sqrt(variance[i]);\n      }\n      return variance;\n    }\n  }\n\n  center(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    const { center = this.mean(by) } = options;\n    switch (by) {\n      case 'row': {\n        if (!isAnyArray.isAnyArray(center)) {\n          throw new TypeError('center must be an array');\n        }\n        centerByRow(this, center);\n        return this;\n      }\n      case 'column': {\n        if (!isAnyArray.isAnyArray(center)) {\n          throw new TypeError('center must be an array');\n        }\n        centerByColumn(this, center);\n        return this;\n      }\n      case undefined: {\n        if (typeof center !== 'number') {\n          throw new TypeError('center must be a number');\n        }\n        centerAll(this, center);\n        return this;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  scale(by, options = {}) {\n    if (typeof by === 'object') {\n      options = by;\n      by = undefined;\n    }\n    if (typeof options !== 'object') {\n      throw new TypeError('options must be an object');\n    }\n    let scale = options.scale;\n    switch (by) {\n      case 'row': {\n        if (scale === undefined) {\n          scale = getScaleByRow(this);\n        } else if (!isAnyArray.isAnyArray(scale)) {\n          throw new TypeError('scale must be an array');\n        }\n        scaleByRow(this, scale);\n        return this;\n      }\n      case 'column': {\n        if (scale === undefined) {\n          scale = getScaleByColumn(this);\n        } else if (!isAnyArray.isAnyArray(scale)) {\n          throw new TypeError('scale must be an array');\n        }\n        scaleByColumn(this, scale);\n        return this;\n      }\n      case undefined: {\n        if (scale === undefined) {\n          scale = getScaleAll(this);\n        } else if (typeof scale !== 'number') {\n          throw new TypeError('scale must be a number');\n        }\n        scaleAll(this, scale);\n        return this;\n      }\n      default:\n        throw new Error(`invalid option: ${by}`);\n    }\n  }\n\n  toString(options) {\n    return inspectMatrixWithOptions(this, options);\n  }\n\n  [Symbol.iterator]() {\n    return this.entries();\n  }\n\n  /**\n   * iterator from left to right, from top to bottom\n   * yield [row, column, value]\n   * @returns {Generator<[number, number, number], void, void>}\n   */\n  *entries() {\n    for (let row = 0; row < this.rows; row++) {\n      for (let col = 0; col < this.columns; col++) {\n        yield [row, col, this.get(row, col)];\n      }\n    }\n  }\n\n  /**\n   * iterator from left to right, from top to bottom\n   * yield value\n   * @returns {Generator<number, void, void>}\n   */\n  *values() {\n    for (let row = 0; row < this.rows; row++) {\n      for (let col = 0; col < this.columns; col++) {\n        yield this.get(row, col);\n      }\n    }\n  }\n}\n\nAbstractMatrix.prototype.klass = 'Matrix';\nif (typeof Symbol !== 'undefined') {\n  AbstractMatrix.prototype[Symbol.for('nodejs.util.inspect.custom')] =\n    inspectMatrix;\n}\n\nfunction compareNumbers(a, b) {\n  return a - b;\n}\n\nfunction isArrayOfNumbers(array) {\n  return array.every((element) => {\n    return typeof element === 'number';\n  });\n}\n\n// Synonyms\nAbstractMatrix.random = AbstractMatrix.rand;\nAbstractMatrix.randomInt = AbstractMatrix.randInt;\nAbstractMatrix.diagonal = AbstractMatrix.diag;\nAbstractMatrix.prototype.diagonal = AbstractMatrix.prototype.diag;\nAbstractMatrix.identity = AbstractMatrix.eye;\nAbstractMatrix.prototype.negate = AbstractMatrix.prototype.neg;\nAbstractMatrix.prototype.tensorProduct =\n  AbstractMatrix.prototype.kroneckerProduct;\n\nclass Matrix extends AbstractMatrix {\n  /**\n   * @type {Float64Array[]}\n   */\n  data;\n\n  /**\n   * Init an empty matrix\n   * @param {number} nRows\n   * @param {number} nColumns\n   */\n  #initData(nRows, nColumns) {\n    this.data = [];\n\n    if (Number.isInteger(nColumns) && nColumns >= 0) {\n      for (let i = 0; i < nRows; i++) {\n        this.data.push(new Float64Array(nColumns));\n      }\n    } else {\n      throw new TypeError('nColumns must be a positive integer');\n    }\n\n    this.rows = nRows;\n    this.columns = nColumns;\n  }\n\n  constructor(nRows, nColumns) {\n    super();\n    if (Matrix.isMatrix(nRows)) {\n      this.#initData(nRows.rows, nRows.columns);\n      Matrix.copy(nRows, this);\n    } else if (Number.isInteger(nRows) && nRows >= 0) {\n      this.#initData(nRows, nColumns);\n    } else if (isAnyArray.isAnyArray(nRows)) {\n      // Copy the values from the 2D array\n      const arrayData = nRows;\n      nRows = arrayData.length;\n      nColumns = nRows ? arrayData[0].length : 0;\n      if (typeof nColumns !== 'number') {\n        throw new TypeError(\n          'Data must be a 2D array with at least one element',\n        );\n      }\n      this.data = [];\n\n      for (let i = 0; i < nRows; i++) {\n        if (arrayData[i].length !== nColumns) {\n          throw new RangeError('Inconsistent array dimensions');\n        }\n        if (!isArrayOfNumbers(arrayData[i])) {\n          throw new TypeError('Input data contains non-numeric values');\n        }\n        this.data.push(Float64Array.from(arrayData[i]));\n      }\n\n      this.rows = nRows;\n      this.columns = nColumns;\n    } else {\n      throw new TypeError(\n        'First argument must be a positive number or an array',\n      );\n    }\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.data[rowIndex][columnIndex] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.data[rowIndex][columnIndex];\n  }\n\n  removeRow(index) {\n    checkRowIndex(this, index);\n    this.data.splice(index, 1);\n    this.rows -= 1;\n    return this;\n  }\n\n  addRow(index, array) {\n    if (array === undefined) {\n      array = index;\n      index = this.rows;\n    }\n    checkRowIndex(this, index, true);\n    array = Float64Array.from(checkRowVector(this, array));\n    this.data.splice(index, 0, array);\n    this.rows += 1;\n    return this;\n  }\n\n  removeColumn(index) {\n    checkColumnIndex(this, index);\n    for (let i = 0; i < this.rows; i++) {\n      const newRow = new Float64Array(this.columns - 1);\n      for (let j = 0; j < index; j++) {\n        newRow[j] = this.data[i][j];\n      }\n      for (let j = index + 1; j < this.columns; j++) {\n        newRow[j - 1] = this.data[i][j];\n      }\n      this.data[i] = newRow;\n    }\n    this.columns -= 1;\n    return this;\n  }\n\n  addColumn(index, array) {\n    if (typeof array === 'undefined') {\n      array = index;\n      index = this.columns;\n    }\n    checkColumnIndex(this, index, true);\n    array = checkColumnVector(this, array);\n    for (let i = 0; i < this.rows; i++) {\n      const newRow = new Float64Array(this.columns + 1);\n      let j = 0;\n      for (; j < index; j++) {\n        newRow[j] = this.data[i][j];\n      }\n      newRow[j++] = array[i];\n      for (; j < this.columns + 1; j++) {\n        newRow[j] = this.data[i][j - 1];\n      }\n      this.data[i] = newRow;\n    }\n    this.columns += 1;\n    return this;\n  }\n}\n\ninstallMathOperations(AbstractMatrix, Matrix);\n\n/**\n * @typedef {0 | 1 | number | boolean} Mask\n */\n\nclass SymmetricMatrix extends AbstractMatrix {\n  /** @type {Matrix} */\n  #matrix;\n\n  get size() {\n    return this.#matrix.size;\n  }\n\n  get rows() {\n    return this.#matrix.rows;\n  }\n\n  get columns() {\n    return this.#matrix.columns;\n  }\n\n  get diagonalSize() {\n    return this.rows;\n  }\n\n  /**\n   * not the same as matrix.isSymmetric()\n   * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n   *\n   * @param value\n   * @returns {boolean}\n   */\n  static isSymmetricMatrix(value) {\n    return Matrix.isMatrix(value) && value.klassType === 'SymmetricMatrix';\n  }\n\n  /**\n   * @param diagonalSize\n   * @return {SymmetricMatrix}\n   */\n  static zeros(diagonalSize) {\n    return new this(diagonalSize);\n  }\n\n  /**\n   * @param diagonalSize\n   * @return {SymmetricMatrix}\n   */\n  static ones(diagonalSize) {\n    return new this(diagonalSize).fill(1);\n  }\n\n  /**\n   * @param {number | AbstractMatrix | ArrayLike<ArrayLike<number>>} diagonalSize\n   * @return {this}\n   */\n  constructor(diagonalSize) {\n    super();\n\n    if (Matrix.isMatrix(diagonalSize)) {\n      if (!diagonalSize.isSymmetric()) {\n        throw new TypeError('not symmetric data');\n      }\n\n      this.#matrix = Matrix.copy(\n        diagonalSize,\n        new Matrix(diagonalSize.rows, diagonalSize.rows),\n      );\n    } else if (Number.isInteger(diagonalSize) && diagonalSize >= 0) {\n      this.#matrix = new Matrix(diagonalSize, diagonalSize);\n    } else {\n      this.#matrix = new Matrix(diagonalSize);\n\n      if (!this.isSymmetric()) {\n        throw new TypeError('not symmetric data');\n      }\n    }\n  }\n\n  clone() {\n    const matrix = new SymmetricMatrix(this.diagonalSize);\n\n    for (const [row, col, value] of this.upperRightEntries()) {\n      matrix.set(row, col, value);\n    }\n\n    return matrix;\n  }\n\n  toMatrix() {\n    return new Matrix(this);\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.#matrix.get(rowIndex, columnIndex);\n  }\n  set(rowIndex, columnIndex, value) {\n    // symmetric set\n    this.#matrix.set(rowIndex, columnIndex, value);\n    this.#matrix.set(columnIndex, rowIndex, value);\n\n    return this;\n  }\n\n  removeCross(index) {\n    // symmetric remove side\n    this.#matrix.removeRow(index);\n    this.#matrix.removeColumn(index);\n\n    return this;\n  }\n\n  addCross(index, array) {\n    if (array === undefined) {\n      array = index;\n      index = this.diagonalSize;\n    }\n\n    const row = array.slice();\n    row.splice(index, 1);\n\n    this.#matrix.addRow(index, row);\n    this.#matrix.addColumn(index, array);\n\n    return this;\n  }\n\n  /**\n   * @param {Mask[]} mask\n   */\n  applyMask(mask) {\n    if (mask.length !== this.diagonalSize) {\n      throw new RangeError('Mask size do not match with matrix size');\n    }\n\n    // prepare sides to remove from matrix from mask\n    /** @type {number[]} */\n    const sidesToRemove = [];\n    for (const [index, passthroughs] of mask.entries()) {\n      if (passthroughs) continue;\n      sidesToRemove.push(index);\n    }\n    // to remove from highest to lowest for no mutation shifting\n    sidesToRemove.reverse();\n\n    // remove sides\n    for (const sideIndex of sidesToRemove) {\n      this.removeCross(sideIndex);\n    }\n\n    return this;\n  }\n\n  /**\n   * Compact format upper-right corner of matrix\n   * iterate from left to right, from top to bottom.\n   *\n   * ```\n   *   A B C D\n   * A 1 2 3 4\n   * B 2 5 6 7\n   * C 3 6 8 9\n   * D 4 7 9 10\n   * ```\n   *\n   * will return compact 1D array `[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]`\n   *\n   * length is S(i=0, n=sideSize) => 10 for a 4 sideSized matrix\n   *\n   * @returns {number[]}\n   */\n  toCompact() {\n    const { diagonalSize } = this;\n\n    /** @type {number[]} */\n    const compact = new Array((diagonalSize * (diagonalSize + 1)) / 2);\n    for (let col = 0, row = 0, index = 0; index < compact.length; index++) {\n      compact[index] = this.get(row, col);\n\n      if (++col >= diagonalSize) col = ++row;\n    }\n\n    return compact;\n  }\n\n  /**\n   * @param {number[]} compact\n   * @return {SymmetricMatrix}\n   */\n  static fromCompact(compact) {\n    const compactSize = compact.length;\n    // compactSize = (sideSize * (sideSize + 1)) / 2\n    // https://mathsolver.microsoft.com/fr/solve-problem/y%20%3D%20%20x%20%60cdot%20%20%20%60frac%7B%20%20%60left(%20x%2B1%20%20%60right)%20%20%20%20%7D%7B%202%20%20%7D\n    // sideSize = (Sqrt(8 × compactSize + 1) - 1) / 2\n    const diagonalSize = (Math.sqrt(8 * compactSize + 1) - 1) / 2;\n\n    if (!Number.isInteger(diagonalSize)) {\n      throw new TypeError(\n        `This array is not a compact representation of a Symmetric Matrix, ${JSON.stringify(\n          compact,\n        )}`,\n      );\n    }\n\n    const matrix = new SymmetricMatrix(diagonalSize);\n    for (let col = 0, row = 0, index = 0; index < compactSize; index++) {\n      matrix.set(col, row, compact[index]);\n      if (++col >= diagonalSize) col = ++row;\n    }\n\n    return matrix;\n  }\n\n  /**\n   * half iterator upper-right-corner from left to right, from top to bottom\n   * yield [row, column, value]\n   *\n   * @returns {Generator<[number, number, number], void, void>}\n   */\n  *upperRightEntries() {\n    for (let row = 0, col = 0; row < this.diagonalSize; void 0) {\n      const value = this.get(row, col);\n\n      yield [row, col, value];\n\n      // at the end of row, move cursor to next row at diagonal position\n      if (++col >= this.diagonalSize) col = ++row;\n    }\n  }\n\n  /**\n   * half iterator upper-right-corner from left to right, from top to bottom\n   * yield value\n   *\n   * @returns {Generator<[number, number, number], void, void>}\n   */\n  *upperRightValues() {\n    for (let row = 0, col = 0; row < this.diagonalSize; void 0) {\n      const value = this.get(row, col);\n\n      yield value;\n\n      // at the end of row, move cursor to next row at diagonal position\n      if (++col >= this.diagonalSize) col = ++row;\n    }\n  }\n}\nSymmetricMatrix.prototype.klassType = 'SymmetricMatrix';\n\nclass DistanceMatrix extends SymmetricMatrix {\n  /**\n   * not the same as matrix.isSymmetric()\n   * Here is to check if it's instanceof SymmetricMatrix without bundling issues\n   *\n   * @param value\n   * @returns {boolean}\n   */\n  static isDistanceMatrix(value) {\n    return (\n      SymmetricMatrix.isSymmetricMatrix(value) &&\n      value.klassSubType === 'DistanceMatrix'\n    );\n  }\n\n  constructor(sideSize) {\n    super(sideSize);\n\n    if (!this.isDistance()) {\n      throw new TypeError('Provided arguments do no produce a distance matrix');\n    }\n  }\n\n  set(rowIndex, columnIndex, value) {\n    // distance matrix diagonal is 0\n    if (rowIndex === columnIndex) value = 0;\n\n    return super.set(rowIndex, columnIndex, value);\n  }\n\n  addCross(index, array) {\n    if (array === undefined) {\n      array = index;\n      index = this.diagonalSize;\n    }\n\n    // ensure distance\n    array = array.slice();\n    array[index] = 0;\n\n    return super.addCross(index, array);\n  }\n\n  toSymmetricMatrix() {\n    return new SymmetricMatrix(this);\n  }\n\n  clone() {\n    const matrix = new DistanceMatrix(this.diagonalSize);\n\n    for (const [row, col, value] of this.upperRightEntries()) {\n      if (row === col) continue;\n      matrix.set(row, col, value);\n    }\n\n    return matrix;\n  }\n\n  /**\n   * Compact format upper-right corner of matrix\n   * no diagonal (only zeros)\n   * iterable from left to right, from top to bottom.\n   *\n   * ```\n   *   A B C D\n   * A 0 1 2 3\n   * B 1 0 4 5\n   * C 2 4 0 6\n   * D 3 5 6 0\n   * ```\n   *\n   * will return compact 1D array `[1, 2, 3, 4, 5, 6]`\n   *\n   * length is S(i=0, n=sideSize-1) => 6 for a 4 side sized matrix\n   *\n   * @returns {number[]}\n   */\n  toCompact() {\n    const { diagonalSize } = this;\n    const compactLength = ((diagonalSize - 1) * diagonalSize) / 2;\n\n    /** @type {number[]} */\n    const compact = new Array(compactLength);\n    for (let col = 1, row = 0, index = 0; index < compact.length; index++) {\n      compact[index] = this.get(row, col);\n\n      if (++col >= diagonalSize) col = ++row + 1;\n    }\n\n    return compact;\n  }\n\n  /**\n   * @param {number[]} compact\n   */\n  static fromCompact(compact) {\n    const compactSize = compact.length;\n\n    if (compactSize === 0) {\n      return new this(0);\n    }\n\n    // compactSize in Natural integer range ]0;∞]\n    // compactSize = (sideSize * (sideSize - 1)) / 2\n    // sideSize = (Sqrt(8 × compactSize + 1) + 1) / 2\n    const diagonalSize = (Math.sqrt(8 * compactSize + 1) + 1) / 2;\n\n    if (!Number.isInteger(diagonalSize)) {\n      throw new TypeError(\n        `This array is not a compact representation of a DistanceMatrix, ${JSON.stringify(\n          compact,\n        )}`,\n      );\n    }\n\n    const matrix = new this(diagonalSize);\n    for (let col = 1, row = 0, index = 0; index < compactSize; index++) {\n      matrix.set(col, row, compact[index]);\n      if (++col >= diagonalSize) col = ++row + 1;\n    }\n\n    return matrix;\n  }\n}\nDistanceMatrix.prototype.klassSubType = 'DistanceMatrix';\n\nclass BaseView extends AbstractMatrix {\n  constructor(matrix, rows, columns) {\n    super();\n    this.matrix = matrix;\n    this.rows = rows;\n    this.columns = columns;\n  }\n}\n\nclass MatrixColumnView extends BaseView {\n  constructor(matrix, column) {\n    checkColumnIndex(matrix, column);\n    super(matrix, matrix.rows, 1);\n    this.column = column;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(rowIndex, this.column, value);\n    return this;\n  }\n\n  get(rowIndex) {\n    return this.matrix.get(rowIndex, this.column);\n  }\n}\n\nclass MatrixColumnSelectionView extends BaseView {\n  constructor(matrix, columnIndices) {\n    checkColumnIndices(matrix, columnIndices);\n    super(matrix, matrix.rows, columnIndices.length);\n    this.columnIndices = columnIndices;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(rowIndex, this.columnIndices[columnIndex], value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(rowIndex, this.columnIndices[columnIndex]);\n  }\n}\n\nclass MatrixFlipColumnView extends BaseView {\n  constructor(matrix) {\n    super(matrix, matrix.rows, matrix.columns);\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(rowIndex, this.columns - columnIndex - 1, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(rowIndex, this.columns - columnIndex - 1);\n  }\n}\n\nclass MatrixFlipRowView extends BaseView {\n  constructor(matrix) {\n    super(matrix, matrix.rows, matrix.columns);\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(this.rows - rowIndex - 1, columnIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(this.rows - rowIndex - 1, columnIndex);\n  }\n}\n\nclass MatrixRowView extends BaseView {\n  constructor(matrix, row) {\n    checkRowIndex(matrix, row);\n    super(matrix, 1, matrix.columns);\n    this.row = row;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(this.row, columnIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(this.row, columnIndex);\n  }\n}\n\nclass MatrixRowSelectionView extends BaseView {\n  constructor(matrix, rowIndices) {\n    checkRowIndices(matrix, rowIndices);\n    super(matrix, rowIndices.length, matrix.columns);\n    this.rowIndices = rowIndices;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(this.rowIndices[rowIndex], columnIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(this.rowIndices[rowIndex], columnIndex);\n  }\n}\n\nclass MatrixSelectionView extends BaseView {\n  constructor(matrix, rowIndices, columnIndices) {\n    checkRowIndices(matrix, rowIndices);\n    checkColumnIndices(matrix, columnIndices);\n    super(matrix, rowIndices.length, columnIndices.length);\n    this.rowIndices = rowIndices;\n    this.columnIndices = columnIndices;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(\n      this.rowIndices[rowIndex],\n      this.columnIndices[columnIndex],\n      value,\n    );\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(\n      this.rowIndices[rowIndex],\n      this.columnIndices[columnIndex],\n    );\n  }\n}\n\nclass MatrixSubView extends BaseView {\n  constructor(matrix, startRow, endRow, startColumn, endColumn) {\n    checkRange(matrix, startRow, endRow, startColumn, endColumn);\n    super(matrix, endRow - startRow + 1, endColumn - startColumn + 1);\n    this.startRow = startRow;\n    this.startColumn = startColumn;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(\n      this.startRow + rowIndex,\n      this.startColumn + columnIndex,\n      value,\n    );\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(\n      this.startRow + rowIndex,\n      this.startColumn + columnIndex,\n    );\n  }\n}\n\nclass MatrixTransposeView extends BaseView {\n  constructor(matrix) {\n    super(matrix, matrix.columns, matrix.rows);\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.matrix.set(columnIndex, rowIndex, value);\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.matrix.get(columnIndex, rowIndex);\n  }\n}\n\nclass WrapperMatrix1D extends AbstractMatrix {\n  constructor(data, options = {}) {\n    const { rows = 1 } = options;\n\n    if (data.length % rows !== 0) {\n      throw new Error('the data length is not divisible by the number of rows');\n    }\n    super();\n    this.rows = rows;\n    this.columns = data.length / rows;\n    this.data = data;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    let index = this._calculateIndex(rowIndex, columnIndex);\n    this.data[index] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    let index = this._calculateIndex(rowIndex, columnIndex);\n    return this.data[index];\n  }\n\n  _calculateIndex(row, column) {\n    return row * this.columns + column;\n  }\n}\n\nclass WrapperMatrix2D extends AbstractMatrix {\n  constructor(data) {\n    super();\n    this.data = data;\n    this.rows = data.length;\n    this.columns = data[0].length;\n  }\n\n  set(rowIndex, columnIndex, value) {\n    this.data[rowIndex][columnIndex] = value;\n    return this;\n  }\n\n  get(rowIndex, columnIndex) {\n    return this.data[rowIndex][columnIndex];\n  }\n}\n\nfunction wrap(array, options) {\n  if (isAnyArray.isAnyArray(array)) {\n    if (array[0] && isAnyArray.isAnyArray(array[0])) {\n      return new WrapperMatrix2D(array);\n    } else {\n      return new WrapperMatrix1D(array, options);\n    }\n  } else {\n    throw new Error('the argument is not an array');\n  }\n}\n\nclass LuDecomposition {\n  constructor(matrix) {\n    matrix = WrapperMatrix2D.checkMatrix(matrix);\n\n    let lu = matrix.clone();\n    let rows = lu.rows;\n    let columns = lu.columns;\n    let pivotVector = new Float64Array(rows);\n    let pivotSign = 1;\n    let i, j, k, p, s, t, v;\n    let LUcolj, kmax;\n\n    for (i = 0; i < rows; i++) {\n      pivotVector[i] = i;\n    }\n\n    LUcolj = new Float64Array(rows);\n\n    for (j = 0; j < columns; j++) {\n      for (i = 0; i < rows; i++) {\n        LUcolj[i] = lu.get(i, j);\n      }\n\n      for (i = 0; i < rows; i++) {\n        kmax = Math.min(i, j);\n        s = 0;\n        for (k = 0; k < kmax; k++) {\n          s += lu.get(i, k) * LUcolj[k];\n        }\n        LUcolj[i] -= s;\n        lu.set(i, j, LUcolj[i]);\n      }\n\n      p = j;\n      for (i = j + 1; i < rows; i++) {\n        if (Math.abs(LUcolj[i]) > Math.abs(LUcolj[p])) {\n          p = i;\n        }\n      }\n\n      if (p !== j) {\n        for (k = 0; k < columns; k++) {\n          t = lu.get(p, k);\n          lu.set(p, k, lu.get(j, k));\n          lu.set(j, k, t);\n        }\n\n        v = pivotVector[p];\n        pivotVector[p] = pivotVector[j];\n        pivotVector[j] = v;\n\n        pivotSign = -pivotSign;\n      }\n\n      if (j < rows && lu.get(j, j) !== 0) {\n        for (i = j + 1; i < rows; i++) {\n          lu.set(i, j, lu.get(i, j) / lu.get(j, j));\n        }\n      }\n    }\n\n    this.LU = lu;\n    this.pivotVector = pivotVector;\n    this.pivotSign = pivotSign;\n  }\n\n  isSingular() {\n    let data = this.LU;\n    let col = data.columns;\n    for (let j = 0; j < col; j++) {\n      if (data.get(j, j) === 0) {\n        return true;\n      }\n    }\n    return false;\n  }\n\n  solve(value) {\n    value = Matrix.checkMatrix(value);\n\n    let lu = this.LU;\n    let rows = lu.rows;\n\n    if (rows !== value.rows) {\n      throw new Error('Invalid matrix dimensions');\n    }\n    if (this.isSingular()) {\n      throw new Error('LU matrix is singular');\n    }\n\n    let count = value.columns;\n    let X = value.subMatrixRow(this.pivotVector, 0, count - 1);\n    let columns = lu.columns;\n    let i, j, k;\n\n    for (k = 0; k < columns; k++) {\n      for (i = k + 1; i < columns; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * lu.get(i, k));\n        }\n      }\n    }\n    for (k = columns - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        X.set(k, j, X.get(k, j) / lu.get(k, k));\n      }\n      for (i = 0; i < k; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * lu.get(i, k));\n        }\n      }\n    }\n    return X;\n  }\n\n  get determinant() {\n    let data = this.LU;\n    if (!data.isSquare()) {\n      throw new Error('Matrix must be square');\n    }\n    let determinant = this.pivotSign;\n    let col = data.columns;\n    for (let j = 0; j < col; j++) {\n      determinant *= data.get(j, j);\n    }\n    return determinant;\n  }\n\n  get lowerTriangularMatrix() {\n    let data = this.LU;\n    let rows = data.rows;\n    let columns = data.columns;\n    let X = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        if (i > j) {\n          X.set(i, j, data.get(i, j));\n        } else if (i === j) {\n          X.set(i, j, 1);\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get upperTriangularMatrix() {\n    let data = this.LU;\n    let rows = data.rows;\n    let columns = data.columns;\n    let X = new Matrix(rows, columns);\n    for (let i = 0; i < rows; i++) {\n      for (let j = 0; j < columns; j++) {\n        if (i <= j) {\n          X.set(i, j, data.get(i, j));\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get pivotPermutationVector() {\n    return Array.from(this.pivotVector);\n  }\n}\n\nfunction hypotenuse(a, b) {\n  let r = 0;\n  if (Math.abs(a) > Math.abs(b)) {\n    r = b / a;\n    return Math.abs(a) * Math.sqrt(1 + r * r);\n  }\n  if (b !== 0) {\n    r = a / b;\n    return Math.abs(b) * Math.sqrt(1 + r * r);\n  }\n  return 0;\n}\n\nclass QrDecomposition {\n  constructor(value) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    let qr = value.clone();\n    let m = value.rows;\n    let n = value.columns;\n    let rdiag = new Float64Array(n);\n    let i, j, k, s;\n\n    for (k = 0; k < n; k++) {\n      let nrm = 0;\n      for (i = k; i < m; i++) {\n        nrm = hypotenuse(nrm, qr.get(i, k));\n      }\n      if (nrm !== 0) {\n        if (qr.get(k, k) < 0) {\n          nrm = -nrm;\n        }\n        for (i = k; i < m; i++) {\n          qr.set(i, k, qr.get(i, k) / nrm);\n        }\n        qr.set(k, k, qr.get(k, k) + 1);\n        for (j = k + 1; j < n; j++) {\n          s = 0;\n          for (i = k; i < m; i++) {\n            s += qr.get(i, k) * qr.get(i, j);\n          }\n          s = -s / qr.get(k, k);\n          for (i = k; i < m; i++) {\n            qr.set(i, j, qr.get(i, j) + s * qr.get(i, k));\n          }\n        }\n      }\n      rdiag[k] = -nrm;\n    }\n\n    this.QR = qr;\n    this.Rdiag = rdiag;\n  }\n\n  solve(value) {\n    value = Matrix.checkMatrix(value);\n\n    let qr = this.QR;\n    let m = qr.rows;\n\n    if (value.rows !== m) {\n      throw new Error('Matrix row dimensions must agree');\n    }\n    if (!this.isFullRank()) {\n      throw new Error('Matrix is rank deficient');\n    }\n\n    let count = value.columns;\n    let X = value.clone();\n    let n = qr.columns;\n    let i, j, k, s;\n\n    for (k = 0; k < n; k++) {\n      for (j = 0; j < count; j++) {\n        s = 0;\n        for (i = k; i < m; i++) {\n          s += qr.get(i, k) * X.get(i, j);\n        }\n        s = -s / qr.get(k, k);\n        for (i = k; i < m; i++) {\n          X.set(i, j, X.get(i, j) + s * qr.get(i, k));\n        }\n      }\n    }\n    for (k = n - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        X.set(k, j, X.get(k, j) / this.Rdiag[k]);\n      }\n      for (i = 0; i < k; i++) {\n        for (j = 0; j < count; j++) {\n          X.set(i, j, X.get(i, j) - X.get(k, j) * qr.get(i, k));\n        }\n      }\n    }\n\n    return X.subMatrix(0, n - 1, 0, count - 1);\n  }\n\n  isFullRank() {\n    let columns = this.QR.columns;\n    for (let i = 0; i < columns; i++) {\n      if (this.Rdiag[i] === 0) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  get upperTriangularMatrix() {\n    let qr = this.QR;\n    let n = qr.columns;\n    let X = new Matrix(n, n);\n    let i, j;\n    for (i = 0; i < n; i++) {\n      for (j = 0; j < n; j++) {\n        if (i < j) {\n          X.set(i, j, qr.get(i, j));\n        } else if (i === j) {\n          X.set(i, j, this.Rdiag[i]);\n        } else {\n          X.set(i, j, 0);\n        }\n      }\n    }\n    return X;\n  }\n\n  get orthogonalMatrix() {\n    let qr = this.QR;\n    let rows = qr.rows;\n    let columns = qr.columns;\n    let X = new Matrix(rows, columns);\n    let i, j, k, s;\n\n    for (k = columns - 1; k >= 0; k--) {\n      for (i = 0; i < rows; i++) {\n        X.set(i, k, 0);\n      }\n      X.set(k, k, 1);\n      for (j = k; j < columns; j++) {\n        if (qr.get(k, k) !== 0) {\n          s = 0;\n          for (i = k; i < rows; i++) {\n            s += qr.get(i, k) * X.get(i, j);\n          }\n\n          s = -s / qr.get(k, k);\n\n          for (i = k; i < rows; i++) {\n            X.set(i, j, X.get(i, j) + s * qr.get(i, k));\n          }\n        }\n      }\n    }\n    return X;\n  }\n}\n\nclass SingularValueDecomposition {\n  constructor(value, options = {}) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    if (value.isEmpty()) {\n      throw new Error('Matrix must be non-empty');\n    }\n\n    let m = value.rows;\n    let n = value.columns;\n\n    const {\n      computeLeftSingularVectors = true,\n      computeRightSingularVectors = true,\n      autoTranspose = false,\n    } = options;\n\n    let wantu = Boolean(computeLeftSingularVectors);\n    let wantv = Boolean(computeRightSingularVectors);\n\n    let swapped = false;\n    let a;\n    if (m < n) {\n      if (!autoTranspose) {\n        a = value.clone();\n        // eslint-disable-next-line no-console\n        console.warn(\n          'Computing SVD on a matrix with more columns than rows. Consider enabling autoTranspose',\n        );\n      } else {\n        a = value.transpose();\n        m = a.rows;\n        n = a.columns;\n        swapped = true;\n        let aux = wantu;\n        wantu = wantv;\n        wantv = aux;\n      }\n    } else {\n      a = value.clone();\n    }\n\n    let nu = Math.min(m, n);\n    let ni = Math.min(m + 1, n);\n    let s = new Float64Array(ni);\n    let U = new Matrix(m, nu);\n    let V = new Matrix(n, n);\n\n    let e = new Float64Array(n);\n    let work = new Float64Array(m);\n\n    let si = new Float64Array(ni);\n    for (let i = 0; i < ni; i++) si[i] = i;\n\n    let nct = Math.min(m - 1, n);\n    let nrt = Math.max(0, Math.min(n - 2, m));\n    let mrc = Math.max(nct, nrt);\n\n    for (let k = 0; k < mrc; k++) {\n      if (k < nct) {\n        s[k] = 0;\n        for (let i = k; i < m; i++) {\n          s[k] = hypotenuse(s[k], a.get(i, k));\n        }\n        if (s[k] !== 0) {\n          if (a.get(k, k) < 0) {\n            s[k] = -s[k];\n          }\n          for (let i = k; i < m; i++) {\n            a.set(i, k, a.get(i, k) / s[k]);\n          }\n          a.set(k, k, a.get(k, k) + 1);\n        }\n        s[k] = -s[k];\n      }\n\n      for (let j = k + 1; j < n; j++) {\n        if (k < nct && s[k] !== 0) {\n          let t = 0;\n          for (let i = k; i < m; i++) {\n            t += a.get(i, k) * a.get(i, j);\n          }\n          t = -t / a.get(k, k);\n          for (let i = k; i < m; i++) {\n            a.set(i, j, a.get(i, j) + t * a.get(i, k));\n          }\n        }\n        e[j] = a.get(k, j);\n      }\n\n      if (wantu && k < nct) {\n        for (let i = k; i < m; i++) {\n          U.set(i, k, a.get(i, k));\n        }\n      }\n\n      if (k < nrt) {\n        e[k] = 0;\n        for (let i = k + 1; i < n; i++) {\n          e[k] = hypotenuse(e[k], e[i]);\n        }\n        if (e[k] !== 0) {\n          if (e[k + 1] < 0) {\n            e[k] = 0 - e[k];\n          }\n          for (let i = k + 1; i < n; i++) {\n            e[i] /= e[k];\n          }\n          e[k + 1] += 1;\n        }\n        e[k] = -e[k];\n        if (k + 1 < m && e[k] !== 0) {\n          for (let i = k + 1; i < m; i++) {\n            work[i] = 0;\n          }\n          for (let i = k + 1; i < m; i++) {\n            for (let j = k + 1; j < n; j++) {\n              work[i] += e[j] * a.get(i, j);\n            }\n          }\n          for (let j = k + 1; j < n; j++) {\n            let t = -e[j] / e[k + 1];\n            for (let i = k + 1; i < m; i++) {\n              a.set(i, j, a.get(i, j) + t * work[i]);\n            }\n          }\n        }\n        if (wantv) {\n          for (let i = k + 1; i < n; i++) {\n            V.set(i, k, e[i]);\n          }\n        }\n      }\n    }\n\n    let p = Math.min(n, m + 1);\n    if (nct < n) {\n      s[nct] = a.get(nct, nct);\n    }\n    if (m < p) {\n      s[p - 1] = 0;\n    }\n    if (nrt + 1 < p) {\n      e[nrt] = a.get(nrt, p - 1);\n    }\n    e[p - 1] = 0;\n\n    if (wantu) {\n      for (let j = nct; j < nu; j++) {\n        for (let i = 0; i < m; i++) {\n          U.set(i, j, 0);\n        }\n        U.set(j, j, 1);\n      }\n      for (let k = nct - 1; k >= 0; k--) {\n        if (s[k] !== 0) {\n          for (let j = k + 1; j < nu; j++) {\n            let t = 0;\n            for (let i = k; i < m; i++) {\n              t += U.get(i, k) * U.get(i, j);\n            }\n            t = -t / U.get(k, k);\n            for (let i = k; i < m; i++) {\n              U.set(i, j, U.get(i, j) + t * U.get(i, k));\n            }\n          }\n          for (let i = k; i < m; i++) {\n            U.set(i, k, -U.get(i, k));\n          }\n          U.set(k, k, 1 + U.get(k, k));\n          for (let i = 0; i < k - 1; i++) {\n            U.set(i, k, 0);\n          }\n        } else {\n          for (let i = 0; i < m; i++) {\n            U.set(i, k, 0);\n          }\n          U.set(k, k, 1);\n        }\n      }\n    }\n\n    if (wantv) {\n      for (let k = n - 1; k >= 0; k--) {\n        if (k < nrt && e[k] !== 0) {\n          for (let j = k + 1; j < n; j++) {\n            let t = 0;\n            for (let i = k + 1; i < n; i++) {\n              t += V.get(i, k) * V.get(i, j);\n            }\n            t = -t / V.get(k + 1, k);\n            for (let i = k + 1; i < n; i++) {\n              V.set(i, j, V.get(i, j) + t * V.get(i, k));\n            }\n          }\n        }\n        for (let i = 0; i < n; i++) {\n          V.set(i, k, 0);\n        }\n        V.set(k, k, 1);\n      }\n    }\n\n    let pp = p - 1;\n    let eps = Number.EPSILON;\n    while (p > 0) {\n      let k, kase;\n      for (k = p - 2; k >= -1; k--) {\n        if (k === -1) {\n          break;\n        }\n        const alpha =\n          Number.MIN_VALUE + eps * Math.abs(s[k] + Math.abs(s[k + 1]));\n        if (Math.abs(e[k]) <= alpha || Number.isNaN(e[k])) {\n          e[k] = 0;\n          break;\n        }\n      }\n      if (k === p - 2) {\n        kase = 4;\n      } else {\n        let ks;\n        for (ks = p - 1; ks >= k; ks--) {\n          if (ks === k) {\n            break;\n          }\n          let t =\n            (ks !== p ? Math.abs(e[ks]) : 0) +\n            (ks !== k + 1 ? Math.abs(e[ks - 1]) : 0);\n          if (Math.abs(s[ks]) <= eps * t) {\n            s[ks] = 0;\n            break;\n          }\n        }\n        if (ks === k) {\n          kase = 3;\n        } else if (ks === p - 1) {\n          kase = 1;\n        } else {\n          kase = 2;\n          k = ks;\n        }\n      }\n\n      k++;\n\n      switch (kase) {\n        case 1: {\n          let f = e[p - 2];\n          e[p - 2] = 0;\n          for (let j = p - 2; j >= k; j--) {\n            let t = hypotenuse(s[j], f);\n            let cs = s[j] / t;\n            let sn = f / t;\n            s[j] = t;\n            if (j !== k) {\n              f = -sn * e[j - 1];\n              e[j - 1] = cs * e[j - 1];\n            }\n            if (wantv) {\n              for (let i = 0; i < n; i++) {\n                t = cs * V.get(i, j) + sn * V.get(i, p - 1);\n                V.set(i, p - 1, -sn * V.get(i, j) + cs * V.get(i, p - 1));\n                V.set(i, j, t);\n              }\n            }\n          }\n          break;\n        }\n        case 2: {\n          let f = e[k - 1];\n          e[k - 1] = 0;\n          for (let j = k; j < p; j++) {\n            let t = hypotenuse(s[j], f);\n            let cs = s[j] / t;\n            let sn = f / t;\n            s[j] = t;\n            f = -sn * e[j];\n            e[j] = cs * e[j];\n            if (wantu) {\n              for (let i = 0; i < m; i++) {\n                t = cs * U.get(i, j) + sn * U.get(i, k - 1);\n                U.set(i, k - 1, -sn * U.get(i, j) + cs * U.get(i, k - 1));\n                U.set(i, j, t);\n              }\n            }\n          }\n          break;\n        }\n        case 3: {\n          const scale = Math.max(\n            Math.abs(s[p - 1]),\n            Math.abs(s[p - 2]),\n            Math.abs(e[p - 2]),\n            Math.abs(s[k]),\n            Math.abs(e[k]),\n          );\n          const sp = s[p - 1] / scale;\n          const spm1 = s[p - 2] / scale;\n          const epm1 = e[p - 2] / scale;\n          const sk = s[k] / scale;\n          const ek = e[k] / scale;\n          const b = ((spm1 + sp) * (spm1 - sp) + epm1 * epm1) / 2;\n          const c = sp * epm1 * (sp * epm1);\n          let shift = 0;\n          if (b !== 0 || c !== 0) {\n            if (b < 0) {\n              shift = 0 - Math.sqrt(b * b + c);\n            } else {\n              shift = Math.sqrt(b * b + c);\n            }\n            shift = c / (b + shift);\n          }\n          let f = (sk + sp) * (sk - sp) + shift;\n          let g = sk * ek;\n          for (let j = k; j < p - 1; j++) {\n            let t = hypotenuse(f, g);\n            if (t === 0) t = Number.MIN_VALUE;\n            let cs = f / t;\n            let sn = g / t;\n            if (j !== k) {\n              e[j - 1] = t;\n            }\n            f = cs * s[j] + sn * e[j];\n            e[j] = cs * e[j] - sn * s[j];\n            g = sn * s[j + 1];\n            s[j + 1] = cs * s[j + 1];\n            if (wantv) {\n              for (let i = 0; i < n; i++) {\n                t = cs * V.get(i, j) + sn * V.get(i, j + 1);\n                V.set(i, j + 1, -sn * V.get(i, j) + cs * V.get(i, j + 1));\n                V.set(i, j, t);\n              }\n            }\n            t = hypotenuse(f, g);\n            if (t === 0) t = Number.MIN_VALUE;\n            cs = f / t;\n            sn = g / t;\n            s[j] = t;\n            f = cs * e[j] + sn * s[j + 1];\n            s[j + 1] = -sn * e[j] + cs * s[j + 1];\n            g = sn * e[j + 1];\n            e[j + 1] = cs * e[j + 1];\n            if (wantu && j < m - 1) {\n              for (let i = 0; i < m; i++) {\n                t = cs * U.get(i, j) + sn * U.get(i, j + 1);\n                U.set(i, j + 1, -sn * U.get(i, j) + cs * U.get(i, j + 1));\n                U.set(i, j, t);\n              }\n            }\n          }\n          e[p - 2] = f;\n          break;\n        }\n        case 4: {\n          if (s[k] <= 0) {\n            s[k] = s[k] < 0 ? -s[k] : 0;\n            if (wantv) {\n              for (let i = 0; i <= pp; i++) {\n                V.set(i, k, -V.get(i, k));\n              }\n            }\n          }\n          while (k < pp) {\n            if (s[k] >= s[k + 1]) {\n              break;\n            }\n            let t = s[k];\n            s[k] = s[k + 1];\n            s[k + 1] = t;\n            if (wantv && k < n - 1) {\n              for (let i = 0; i < n; i++) {\n                t = V.get(i, k + 1);\n                V.set(i, k + 1, V.get(i, k));\n                V.set(i, k, t);\n              }\n            }\n            if (wantu && k < m - 1) {\n              for (let i = 0; i < m; i++) {\n                t = U.get(i, k + 1);\n                U.set(i, k + 1, U.get(i, k));\n                U.set(i, k, t);\n              }\n            }\n            k++;\n          }\n          p--;\n          break;\n        }\n        // no default\n      }\n    }\n\n    if (swapped) {\n      let tmp = V;\n      V = U;\n      U = tmp;\n    }\n\n    this.m = m;\n    this.n = n;\n    this.s = s;\n    this.U = U;\n    this.V = V;\n  }\n\n  solve(value) {\n    let Y = value;\n    let e = this.threshold;\n    let scols = this.s.length;\n    let Ls = Matrix.zeros(scols, scols);\n\n    for (let i = 0; i < scols; i++) {\n      if (Math.abs(this.s[i]) <= e) {\n        Ls.set(i, i, 0);\n      } else {\n        Ls.set(i, i, 1 / this.s[i]);\n      }\n    }\n\n    let U = this.U;\n    let V = this.rightSingularVectors;\n\n    let VL = V.mmul(Ls);\n    let vrows = V.rows;\n    let urows = U.rows;\n    let VLU = Matrix.zeros(vrows, urows);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < urows; j++) {\n        let sum = 0;\n        for (let k = 0; k < scols; k++) {\n          sum += VL.get(i, k) * U.get(j, k);\n        }\n        VLU.set(i, j, sum);\n      }\n    }\n\n    return VLU.mmul(Y);\n  }\n\n  solveForDiagonal(value) {\n    return this.solve(Matrix.diag(value));\n  }\n\n  inverse() {\n    let V = this.V;\n    let e = this.threshold;\n    let vrows = V.rows;\n    let vcols = V.columns;\n    let X = new Matrix(vrows, this.s.length);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < vcols; j++) {\n        if (Math.abs(this.s[j]) > e) {\n          X.set(i, j, V.get(i, j) / this.s[j]);\n        }\n      }\n    }\n\n    let U = this.U;\n\n    let urows = U.rows;\n    let ucols = U.columns;\n    let Y = new Matrix(vrows, urows);\n\n    for (let i = 0; i < vrows; i++) {\n      for (let j = 0; j < urows; j++) {\n        let sum = 0;\n        for (let k = 0; k < ucols; k++) {\n          sum += X.get(i, k) * U.get(j, k);\n        }\n        Y.set(i, j, sum);\n      }\n    }\n\n    return Y;\n  }\n\n  get condition() {\n    return this.s[0] / this.s[Math.min(this.m, this.n) - 1];\n  }\n\n  get norm2() {\n    return this.s[0];\n  }\n\n  get rank() {\n    let tol = Math.max(this.m, this.n) * this.s[0] * Number.EPSILON;\n    let r = 0;\n    let s = this.s;\n    for (let i = 0, ii = s.length; i < ii; i++) {\n      if (s[i] > tol) {\n        r++;\n      }\n    }\n    return r;\n  }\n\n  get diagonal() {\n    return Array.from(this.s);\n  }\n\n  get threshold() {\n    return (Number.EPSILON / 2) * Math.max(this.m, this.n) * this.s[0];\n  }\n\n  get leftSingularVectors() {\n    return this.U;\n  }\n\n  get rightSingularVectors() {\n    return this.V;\n  }\n\n  get diagonalMatrix() {\n    return Matrix.diag(this.s);\n  }\n}\n\nfunction inverse(matrix, useSVD = false) {\n  matrix = WrapperMatrix2D.checkMatrix(matrix);\n  if (useSVD) {\n    return new SingularValueDecomposition(matrix).inverse();\n  } else {\n    return solve(matrix, Matrix.eye(matrix.rows));\n  }\n}\n\nfunction solve(leftHandSide, rightHandSide, useSVD = false) {\n  leftHandSide = WrapperMatrix2D.checkMatrix(leftHandSide);\n  rightHandSide = WrapperMatrix2D.checkMatrix(rightHandSide);\n  if (useSVD) {\n    return new SingularValueDecomposition(leftHandSide).solve(rightHandSide);\n  } else {\n    return leftHandSide.isSquare()\n      ? new LuDecomposition(leftHandSide).solve(rightHandSide)\n      : new QrDecomposition(leftHandSide).solve(rightHandSide);\n  }\n}\n\nfunction determinant(matrix) {\n  matrix = Matrix.checkMatrix(matrix);\n  if (matrix.isSquare()) {\n    if (matrix.columns === 0) {\n      return 1;\n    }\n\n    let a, b, c, d;\n    if (matrix.columns === 2) {\n      // 2 x 2 matrix\n      a = matrix.get(0, 0);\n      b = matrix.get(0, 1);\n      c = matrix.get(1, 0);\n      d = matrix.get(1, 1);\n\n      return a * d - b * c;\n    } else if (matrix.columns === 3) {\n      // 3 x 3 matrix\n      let subMatrix0, subMatrix1, subMatrix2;\n      subMatrix0 = new MatrixSelectionView(matrix, [1, 2], [1, 2]);\n      subMatrix1 = new MatrixSelectionView(matrix, [1, 2], [0, 2]);\n      subMatrix2 = new MatrixSelectionView(matrix, [1, 2], [0, 1]);\n      a = matrix.get(0, 0);\n      b = matrix.get(0, 1);\n      c = matrix.get(0, 2);\n\n      return (\n        a * determinant(subMatrix0) -\n        b * determinant(subMatrix1) +\n        c * determinant(subMatrix2)\n      );\n    } else {\n      // general purpose determinant using the LU decomposition\n      return new LuDecomposition(matrix).determinant;\n    }\n  } else {\n    throw Error('determinant can only be calculated for a square matrix');\n  }\n}\n\nfunction xrange(n, exception) {\n  let range = [];\n  for (let i = 0; i < n; i++) {\n    if (i !== exception) {\n      range.push(i);\n    }\n  }\n  return range;\n}\n\nfunction dependenciesOneRow(\n  error,\n  matrix,\n  index,\n  thresholdValue = 10e-10,\n  thresholdError = 10e-10,\n) {\n  if (error > thresholdError) {\n    return new Array(matrix.rows + 1).fill(0);\n  } else {\n    let returnArray = matrix.addRow(index, [0]);\n    for (let i = 0; i < returnArray.rows; i++) {\n      if (Math.abs(returnArray.get(i, 0)) < thresholdValue) {\n        returnArray.set(i, 0, 0);\n      }\n    }\n    return returnArray.to1DArray();\n  }\n}\n\nfunction linearDependencies(matrix, options = {}) {\n  const { thresholdValue = 10e-10, thresholdError = 10e-10 } = options;\n  matrix = Matrix.checkMatrix(matrix);\n\n  let n = matrix.rows;\n  let results = new Matrix(n, n);\n\n  for (let i = 0; i < n; i++) {\n    let b = Matrix.columnVector(matrix.getRow(i));\n    let Abis = matrix.subMatrixRow(xrange(n, i)).transpose();\n    let svd = new SingularValueDecomposition(Abis);\n    let x = svd.solve(b);\n    let error = Matrix.sub(b, Abis.mmul(x)).abs().max();\n    results.setRow(\n      i,\n      dependenciesOneRow(error, x, i, thresholdValue, thresholdError),\n    );\n  }\n  return results;\n}\n\nfunction pseudoInverse(matrix, threshold = Number.EPSILON) {\n  matrix = Matrix.checkMatrix(matrix);\n  if (matrix.isEmpty()) {\n    // with a zero dimension, the pseudo-inverse is the transpose, since all 0xn and nx0 matrices are singular\n    // (0xn)*(nx0)*(0xn) = 0xn\n    // (nx0)*(0xn)*(nx0) = nx0\n    return matrix.transpose();\n  }\n  let svdSolution = new SingularValueDecomposition(matrix, { autoTranspose: true });\n\n  let U = svdSolution.leftSingularVectors;\n  let V = svdSolution.rightSingularVectors;\n  let s = svdSolution.diagonal;\n\n  for (let i = 0; i < s.length; i++) {\n    if (Math.abs(s[i]) > threshold) {\n      s[i] = 1.0 / s[i];\n    } else {\n      s[i] = 0.0;\n    }\n  }\n\n  return V.mmul(Matrix.diag(s).mmul(U.transpose()));\n}\n\nfunction covariance(xMatrix, yMatrix = xMatrix, options = {}) {\n  xMatrix = new Matrix(xMatrix);\n  let yIsSame = false;\n  if (\n    typeof yMatrix === 'object' &&\n    !Matrix.isMatrix(yMatrix) &&\n    !isAnyArray.isAnyArray(yMatrix)\n  ) {\n    options = yMatrix;\n    yMatrix = xMatrix;\n    yIsSame = true;\n  } else {\n    yMatrix = new Matrix(yMatrix);\n  }\n  if (xMatrix.rows !== yMatrix.rows) {\n    throw new TypeError('Both matrices must have the same number of rows');\n  }\n  const { center = true } = options;\n  if (center) {\n    xMatrix = xMatrix.center('column');\n    if (!yIsSame) {\n      yMatrix = yMatrix.center('column');\n    }\n  }\n  const cov = xMatrix.transpose().mmul(yMatrix);\n  for (let i = 0; i < cov.rows; i++) {\n    for (let j = 0; j < cov.columns; j++) {\n      cov.set(i, j, cov.get(i, j) * (1 / (xMatrix.rows - 1)));\n    }\n  }\n  return cov;\n}\n\nfunction correlation(xMatrix, yMatrix = xMatrix, options = {}) {\n  xMatrix = new Matrix(xMatrix);\n  let yIsSame = false;\n  if (\n    typeof yMatrix === 'object' &&\n    !Matrix.isMatrix(yMatrix) &&\n    !isAnyArray.isAnyArray(yMatrix)\n  ) {\n    options = yMatrix;\n    yMatrix = xMatrix;\n    yIsSame = true;\n  } else {\n    yMatrix = new Matrix(yMatrix);\n  }\n  if (xMatrix.rows !== yMatrix.rows) {\n    throw new TypeError('Both matrices must have the same number of rows');\n  }\n\n  const { center = true, scale = true } = options;\n  if (center) {\n    xMatrix.center('column');\n    if (!yIsSame) {\n      yMatrix.center('column');\n    }\n  }\n  if (scale) {\n    xMatrix.scale('column');\n    if (!yIsSame) {\n      yMatrix.scale('column');\n    }\n  }\n\n  const sdx = xMatrix.standardDeviation('column', { unbiased: true });\n  const sdy = yIsSame\n    ? sdx\n    : yMatrix.standardDeviation('column', { unbiased: true });\n\n  const corr = xMatrix.transpose().mmul(yMatrix);\n  for (let i = 0; i < corr.rows; i++) {\n    for (let j = 0; j < corr.columns; j++) {\n      corr.set(\n        i,\n        j,\n        corr.get(i, j) * (1 / (sdx[i] * sdy[j])) * (1 / (xMatrix.rows - 1)),\n      );\n    }\n  }\n  return corr;\n}\n\nclass EigenvalueDecomposition {\n  constructor(matrix, options = {}) {\n    const { assumeSymmetric = false } = options;\n\n    matrix = WrapperMatrix2D.checkMatrix(matrix);\n    if (!matrix.isSquare()) {\n      throw new Error('Matrix is not a square matrix');\n    }\n\n    if (matrix.isEmpty()) {\n      throw new Error('Matrix must be non-empty');\n    }\n\n    let n = matrix.columns;\n    let V = new Matrix(n, n);\n    let d = new Float64Array(n);\n    let e = new Float64Array(n);\n    let value = matrix;\n    let i, j;\n\n    let isSymmetric = false;\n    if (assumeSymmetric) {\n      isSymmetric = true;\n    } else {\n      isSymmetric = matrix.isSymmetric();\n    }\n\n    if (isSymmetric) {\n      for (i = 0; i < n; i++) {\n        for (j = 0; j < n; j++) {\n          V.set(i, j, value.get(i, j));\n        }\n      }\n      tred2(n, e, d, V);\n      tql2(n, e, d, V);\n    } else {\n      let H = new Matrix(n, n);\n      let ort = new Float64Array(n);\n      for (j = 0; j < n; j++) {\n        for (i = 0; i < n; i++) {\n          H.set(i, j, value.get(i, j));\n        }\n      }\n      orthes(n, H, ort, V);\n      hqr2(n, e, d, V, H);\n    }\n\n    this.n = n;\n    this.e = e;\n    this.d = d;\n    this.V = V;\n  }\n\n  get realEigenvalues() {\n    return Array.from(this.d);\n  }\n\n  get imaginaryEigenvalues() {\n    return Array.from(this.e);\n  }\n\n  get eigenvectorMatrix() {\n    return this.V;\n  }\n\n  get diagonalMatrix() {\n    let n = this.n;\n    let e = this.e;\n    let d = this.d;\n    let X = new Matrix(n, n);\n    let i, j;\n    for (i = 0; i < n; i++) {\n      for (j = 0; j < n; j++) {\n        X.set(i, j, 0);\n      }\n      X.set(i, i, d[i]);\n      if (e[i] > 0) {\n        X.set(i, i + 1, e[i]);\n      } else if (e[i] < 0) {\n        X.set(i, i - 1, e[i]);\n      }\n    }\n    return X;\n  }\n}\n\nfunction tred2(n, e, d, V) {\n  let f, g, h, i, j, k, hh, scale;\n\n  for (j = 0; j < n; j++) {\n    d[j] = V.get(n - 1, j);\n  }\n\n  for (i = n - 1; i > 0; i--) {\n    scale = 0;\n    h = 0;\n    for (k = 0; k < i; k++) {\n      scale = scale + Math.abs(d[k]);\n    }\n\n    if (scale === 0) {\n      e[i] = d[i - 1];\n      for (j = 0; j < i; j++) {\n        d[j] = V.get(i - 1, j);\n        V.set(i, j, 0);\n        V.set(j, i, 0);\n      }\n    } else {\n      for (k = 0; k < i; k++) {\n        d[k] /= scale;\n        h += d[k] * d[k];\n      }\n\n      f = d[i - 1];\n      g = Math.sqrt(h);\n      if (f > 0) {\n        g = -g;\n      }\n\n      e[i] = scale * g;\n      h = h - f * g;\n      d[i - 1] = f - g;\n      for (j = 0; j < i; j++) {\n        e[j] = 0;\n      }\n\n      for (j = 0; j < i; j++) {\n        f = d[j];\n        V.set(j, i, f);\n        g = e[j] + V.get(j, j) * f;\n        for (k = j + 1; k <= i - 1; k++) {\n          g += V.get(k, j) * d[k];\n          e[k] += V.get(k, j) * f;\n        }\n        e[j] = g;\n      }\n\n      f = 0;\n      for (j = 0; j < i; j++) {\n        e[j] /= h;\n        f += e[j] * d[j];\n      }\n\n      hh = f / (h + h);\n      for (j = 0; j < i; j++) {\n        e[j] -= hh * d[j];\n      }\n\n      for (j = 0; j < i; j++) {\n        f = d[j];\n        g = e[j];\n        for (k = j; k <= i - 1; k++) {\n          V.set(k, j, V.get(k, j) - (f * e[k] + g * d[k]));\n        }\n        d[j] = V.get(i - 1, j);\n        V.set(i, j, 0);\n      }\n    }\n    d[i] = h;\n  }\n\n  for (i = 0; i < n - 1; i++) {\n    V.set(n - 1, i, V.get(i, i));\n    V.set(i, i, 1);\n    h = d[i + 1];\n    if (h !== 0) {\n      for (k = 0; k <= i; k++) {\n        d[k] = V.get(k, i + 1) / h;\n      }\n\n      for (j = 0; j <= i; j++) {\n        g = 0;\n        for (k = 0; k <= i; k++) {\n          g += V.get(k, i + 1) * V.get(k, j);\n        }\n        for (k = 0; k <= i; k++) {\n          V.set(k, j, V.get(k, j) - g * d[k]);\n        }\n      }\n    }\n\n    for (k = 0; k <= i; k++) {\n      V.set(k, i + 1, 0);\n    }\n  }\n\n  for (j = 0; j < n; j++) {\n    d[j] = V.get(n - 1, j);\n    V.set(n - 1, j, 0);\n  }\n\n  V.set(n - 1, n - 1, 1);\n  e[0] = 0;\n}\n\nfunction tql2(n, e, d, V) {\n  let g, h, i, j, k, l, m, p, r, dl1, c, c2, c3, el1, s, s2;\n\n  for (i = 1; i < n; i++) {\n    e[i - 1] = e[i];\n  }\n\n  e[n - 1] = 0;\n\n  let f = 0;\n  let tst1 = 0;\n  let eps = Number.EPSILON;\n\n  for (l = 0; l < n; l++) {\n    tst1 = Math.max(tst1, Math.abs(d[l]) + Math.abs(e[l]));\n    m = l;\n    while (m < n) {\n      if (Math.abs(e[m]) <= eps * tst1) {\n        break;\n      }\n      m++;\n    }\n\n    if (m > l) {\n      do {\n\n        g = d[l];\n        p = (d[l + 1] - g) / (2 * e[l]);\n        r = hypotenuse(p, 1);\n        if (p < 0) {\n          r = -r;\n        }\n\n        d[l] = e[l] / (p + r);\n        d[l + 1] = e[l] * (p + r);\n        dl1 = d[l + 1];\n        h = g - d[l];\n        for (i = l + 2; i < n; i++) {\n          d[i] -= h;\n        }\n\n        f = f + h;\n\n        p = d[m];\n        c = 1;\n        c2 = c;\n        c3 = c;\n        el1 = e[l + 1];\n        s = 0;\n        s2 = 0;\n        for (i = m - 1; i >= l; i--) {\n          c3 = c2;\n          c2 = c;\n          s2 = s;\n          g = c * e[i];\n          h = c * p;\n          r = hypotenuse(p, e[i]);\n          e[i + 1] = s * r;\n          s = e[i] / r;\n          c = p / r;\n          p = c * d[i] - s * g;\n          d[i + 1] = h + s * (c * g + s * d[i]);\n\n          for (k = 0; k < n; k++) {\n            h = V.get(k, i + 1);\n            V.set(k, i + 1, s * V.get(k, i) + c * h);\n            V.set(k, i, c * V.get(k, i) - s * h);\n          }\n        }\n\n        p = (-s * s2 * c3 * el1 * e[l]) / dl1;\n        e[l] = s * p;\n        d[l] = c * p;\n      } while (Math.abs(e[l]) > eps * tst1);\n    }\n    d[l] = d[l] + f;\n    e[l] = 0;\n  }\n\n  for (i = 0; i < n - 1; i++) {\n    k = i;\n    p = d[i];\n    for (j = i + 1; j < n; j++) {\n      if (d[j] < p) {\n        k = j;\n        p = d[j];\n      }\n    }\n\n    if (k !== i) {\n      d[k] = d[i];\n      d[i] = p;\n      for (j = 0; j < n; j++) {\n        p = V.get(j, i);\n        V.set(j, i, V.get(j, k));\n        V.set(j, k, p);\n      }\n    }\n  }\n}\n\nfunction orthes(n, H, ort, V) {\n  let low = 0;\n  let high = n - 1;\n  let f, g, h, i, j, m;\n  let scale;\n\n  for (m = low + 1; m <= high - 1; m++) {\n    scale = 0;\n    for (i = m; i <= high; i++) {\n      scale = scale + Math.abs(H.get(i, m - 1));\n    }\n\n    if (scale !== 0) {\n      h = 0;\n      for (i = high; i >= m; i--) {\n        ort[i] = H.get(i, m - 1) / scale;\n        h += ort[i] * ort[i];\n      }\n\n      g = Math.sqrt(h);\n      if (ort[m] > 0) {\n        g = -g;\n      }\n\n      h = h - ort[m] * g;\n      ort[m] = ort[m] - g;\n\n      for (j = m; j < n; j++) {\n        f = 0;\n        for (i = high; i >= m; i--) {\n          f += ort[i] * H.get(i, j);\n        }\n\n        f = f / h;\n        for (i = m; i <= high; i++) {\n          H.set(i, j, H.get(i, j) - f * ort[i]);\n        }\n      }\n\n      for (i = 0; i <= high; i++) {\n        f = 0;\n        for (j = high; j >= m; j--) {\n          f += ort[j] * H.get(i, j);\n        }\n\n        f = f / h;\n        for (j = m; j <= high; j++) {\n          H.set(i, j, H.get(i, j) - f * ort[j]);\n        }\n      }\n\n      ort[m] = scale * ort[m];\n      H.set(m, m - 1, scale * g);\n    }\n  }\n\n  for (i = 0; i < n; i++) {\n    for (j = 0; j < n; j++) {\n      V.set(i, j, i === j ? 1 : 0);\n    }\n  }\n\n  for (m = high - 1; m >= low + 1; m--) {\n    if (H.get(m, m - 1) !== 0) {\n      for (i = m + 1; i <= high; i++) {\n        ort[i] = H.get(i, m - 1);\n      }\n\n      for (j = m; j <= high; j++) {\n        g = 0;\n        for (i = m; i <= high; i++) {\n          g += ort[i] * V.get(i, j);\n        }\n\n        g = g / ort[m] / H.get(m, m - 1);\n        for (i = m; i <= high; i++) {\n          V.set(i, j, V.get(i, j) + g * ort[i]);\n        }\n      }\n    }\n  }\n}\n\nfunction hqr2(nn, e, d, V, H) {\n  let n = nn - 1;\n  let low = 0;\n  let high = nn - 1;\n  let eps = Number.EPSILON;\n  let exshift = 0;\n  let norm = 0;\n  let p = 0;\n  let q = 0;\n  let r = 0;\n  let s = 0;\n  let z = 0;\n  let iter = 0;\n  let i, j, k, l, m, t, w, x, y;\n  let ra, sa, vr, vi;\n  let notlast, cdivres;\n\n  for (i = 0; i < nn; i++) {\n    if (i < low || i > high) {\n      d[i] = H.get(i, i);\n      e[i] = 0;\n    }\n\n    for (j = Math.max(i - 1, 0); j < nn; j++) {\n      norm = norm + Math.abs(H.get(i, j));\n    }\n  }\n\n  while (n >= low) {\n    l = n;\n    while (l > low) {\n      s = Math.abs(H.get(l - 1, l - 1)) + Math.abs(H.get(l, l));\n      if (s === 0) {\n        s = norm;\n      }\n      if (Math.abs(H.get(l, l - 1)) < eps * s) {\n        break;\n      }\n      l--;\n    }\n\n    if (l === n) {\n      H.set(n, n, H.get(n, n) + exshift);\n      d[n] = H.get(n, n);\n      e[n] = 0;\n      n--;\n      iter = 0;\n    } else if (l === n - 1) {\n      w = H.get(n, n - 1) * H.get(n - 1, n);\n      p = (H.get(n - 1, n - 1) - H.get(n, n)) / 2;\n      q = p * p + w;\n      z = Math.sqrt(Math.abs(q));\n      H.set(n, n, H.get(n, n) + exshift);\n      H.set(n - 1, n - 1, H.get(n - 1, n - 1) + exshift);\n      x = H.get(n, n);\n\n      if (q >= 0) {\n        z = p >= 0 ? p + z : p - z;\n        d[n - 1] = x + z;\n        d[n] = d[n - 1];\n        if (z !== 0) {\n          d[n] = x - w / z;\n        }\n        e[n - 1] = 0;\n        e[n] = 0;\n        x = H.get(n, n - 1);\n        s = Math.abs(x) + Math.abs(z);\n        p = x / s;\n        q = z / s;\n        r = Math.sqrt(p * p + q * q);\n        p = p / r;\n        q = q / r;\n\n        for (j = n - 1; j < nn; j++) {\n          z = H.get(n - 1, j);\n          H.set(n - 1, j, q * z + p * H.get(n, j));\n          H.set(n, j, q * H.get(n, j) - p * z);\n        }\n\n        for (i = 0; i <= n; i++) {\n          z = H.get(i, n - 1);\n          H.set(i, n - 1, q * z + p * H.get(i, n));\n          H.set(i, n, q * H.get(i, n) - p * z);\n        }\n\n        for (i = low; i <= high; i++) {\n          z = V.get(i, n - 1);\n          V.set(i, n - 1, q * z + p * V.get(i, n));\n          V.set(i, n, q * V.get(i, n) - p * z);\n        }\n      } else {\n        d[n - 1] = x + p;\n        d[n] = x + p;\n        e[n - 1] = z;\n        e[n] = -z;\n      }\n\n      n = n - 2;\n      iter = 0;\n    } else {\n      x = H.get(n, n);\n      y = 0;\n      w = 0;\n      if (l < n) {\n        y = H.get(n - 1, n - 1);\n        w = H.get(n, n - 1) * H.get(n - 1, n);\n      }\n\n      if (iter === 10) {\n        exshift += x;\n        for (i = low; i <= n; i++) {\n          H.set(i, i, H.get(i, i) - x);\n        }\n        s = Math.abs(H.get(n, n - 1)) + Math.abs(H.get(n - 1, n - 2));\n        // eslint-disable-next-line no-multi-assign\n        x = y = 0.75 * s;\n        w = -0.4375 * s * s;\n      }\n\n      if (iter === 30) {\n        s = (y - x) / 2;\n        s = s * s + w;\n        if (s > 0) {\n          s = Math.sqrt(s);\n          if (y < x) {\n            s = -s;\n          }\n          s = x - w / ((y - x) / 2 + s);\n          for (i = low; i <= n; i++) {\n            H.set(i, i, H.get(i, i) - s);\n          }\n          exshift += s;\n          // eslint-disable-next-line no-multi-assign\n          x = y = w = 0.964;\n        }\n      }\n\n      iter = iter + 1;\n\n      m = n - 2;\n      while (m >= l) {\n        z = H.get(m, m);\n        r = x - z;\n        s = y - z;\n        p = (r * s - w) / H.get(m + 1, m) + H.get(m, m + 1);\n        q = H.get(m + 1, m + 1) - z - r - s;\n        r = H.get(m + 2, m + 1);\n        s = Math.abs(p) + Math.abs(q) + Math.abs(r);\n        p = p / s;\n        q = q / s;\n        r = r / s;\n        if (m === l) {\n          break;\n        }\n        if (\n          Math.abs(H.get(m, m - 1)) * (Math.abs(q) + Math.abs(r)) <\n          eps *\n            (Math.abs(p) *\n              (Math.abs(H.get(m - 1, m - 1)) +\n                Math.abs(z) +\n                Math.abs(H.get(m + 1, m + 1))))\n        ) {\n          break;\n        }\n        m--;\n      }\n\n      for (i = m + 2; i <= n; i++) {\n        H.set(i, i - 2, 0);\n        if (i > m + 2) {\n          H.set(i, i - 3, 0);\n        }\n      }\n\n      for (k = m; k <= n - 1; k++) {\n        notlast = k !== n - 1;\n        if (k !== m) {\n          p = H.get(k, k - 1);\n          q = H.get(k + 1, k - 1);\n          r = notlast ? H.get(k + 2, k - 1) : 0;\n          x = Math.abs(p) + Math.abs(q) + Math.abs(r);\n          if (x !== 0) {\n            p = p / x;\n            q = q / x;\n            r = r / x;\n          }\n        }\n\n        if (x === 0) {\n          break;\n        }\n\n        s = Math.sqrt(p * p + q * q + r * r);\n        if (p < 0) {\n          s = -s;\n        }\n\n        if (s !== 0) {\n          if (k !== m) {\n            H.set(k, k - 1, -s * x);\n          } else if (l !== m) {\n            H.set(k, k - 1, -H.get(k, k - 1));\n          }\n\n          p = p + s;\n          x = p / s;\n          y = q / s;\n          z = r / s;\n          q = q / p;\n          r = r / p;\n\n          for (j = k; j < nn; j++) {\n            p = H.get(k, j) + q * H.get(k + 1, j);\n            if (notlast) {\n              p = p + r * H.get(k + 2, j);\n              H.set(k + 2, j, H.get(k + 2, j) - p * z);\n            }\n\n            H.set(k, j, H.get(k, j) - p * x);\n            H.set(k + 1, j, H.get(k + 1, j) - p * y);\n          }\n\n          for (i = 0; i <= Math.min(n, k + 3); i++) {\n            p = x * H.get(i, k) + y * H.get(i, k + 1);\n            if (notlast) {\n              p = p + z * H.get(i, k + 2);\n              H.set(i, k + 2, H.get(i, k + 2) - p * r);\n            }\n\n            H.set(i, k, H.get(i, k) - p);\n            H.set(i, k + 1, H.get(i, k + 1) - p * q);\n          }\n\n          for (i = low; i <= high; i++) {\n            p = x * V.get(i, k) + y * V.get(i, k + 1);\n            if (notlast) {\n              p = p + z * V.get(i, k + 2);\n              V.set(i, k + 2, V.get(i, k + 2) - p * r);\n            }\n\n            V.set(i, k, V.get(i, k) - p);\n            V.set(i, k + 1, V.get(i, k + 1) - p * q);\n          }\n        }\n      }\n    }\n  }\n\n  if (norm === 0) {\n    return;\n  }\n\n  for (n = nn - 1; n >= 0; n--) {\n    p = d[n];\n    q = e[n];\n\n    if (q === 0) {\n      l = n;\n      H.set(n, n, 1);\n      for (i = n - 1; i >= 0; i--) {\n        w = H.get(i, i) - p;\n        r = 0;\n        for (j = l; j <= n; j++) {\n          r = r + H.get(i, j) * H.get(j, n);\n        }\n\n        if (e[i] < 0) {\n          z = w;\n          s = r;\n        } else {\n          l = i;\n          if (e[i] === 0) {\n            H.set(i, n, w !== 0 ? -r / w : -r / (eps * norm));\n          } else {\n            x = H.get(i, i + 1);\n            y = H.get(i + 1, i);\n            q = (d[i] - p) * (d[i] - p) + e[i] * e[i];\n            t = (x * s - z * r) / q;\n            H.set(i, n, t);\n            H.set(\n              i + 1,\n              n,\n              Math.abs(x) > Math.abs(z) ? (-r - w * t) / x : (-s - y * t) / z,\n            );\n          }\n\n          t = Math.abs(H.get(i, n));\n          if (eps * t * t > 1) {\n            for (j = i; j <= n; j++) {\n              H.set(j, n, H.get(j, n) / t);\n            }\n          }\n        }\n      }\n    } else if (q < 0) {\n      l = n - 1;\n\n      if (Math.abs(H.get(n, n - 1)) > Math.abs(H.get(n - 1, n))) {\n        H.set(n - 1, n - 1, q / H.get(n, n - 1));\n        H.set(n - 1, n, -(H.get(n, n) - p) / H.get(n, n - 1));\n      } else {\n        cdivres = cdiv(0, -H.get(n - 1, n), H.get(n - 1, n - 1) - p, q);\n        H.set(n - 1, n - 1, cdivres[0]);\n        H.set(n - 1, n, cdivres[1]);\n      }\n\n      H.set(n, n - 1, 0);\n      H.set(n, n, 1);\n      for (i = n - 2; i >= 0; i--) {\n        ra = 0;\n        sa = 0;\n        for (j = l; j <= n; j++) {\n          ra = ra + H.get(i, j) * H.get(j, n - 1);\n          sa = sa + H.get(i, j) * H.get(j, n);\n        }\n\n        w = H.get(i, i) - p;\n\n        if (e[i] < 0) {\n          z = w;\n          r = ra;\n          s = sa;\n        } else {\n          l = i;\n          if (e[i] === 0) {\n            cdivres = cdiv(-ra, -sa, w, q);\n            H.set(i, n - 1, cdivres[0]);\n            H.set(i, n, cdivres[1]);\n          } else {\n            x = H.get(i, i + 1);\n            y = H.get(i + 1, i);\n            vr = (d[i] - p) * (d[i] - p) + e[i] * e[i] - q * q;\n            vi = (d[i] - p) * 2 * q;\n            if (vr === 0 && vi === 0) {\n              vr =\n                eps *\n                norm *\n                (Math.abs(w) +\n                  Math.abs(q) +\n                  Math.abs(x) +\n                  Math.abs(y) +\n                  Math.abs(z));\n            }\n            cdivres = cdiv(\n              x * r - z * ra + q * sa,\n              x * s - z * sa - q * ra,\n              vr,\n              vi,\n            );\n            H.set(i, n - 1, cdivres[0]);\n            H.set(i, n, cdivres[1]);\n            if (Math.abs(x) > Math.abs(z) + Math.abs(q)) {\n              H.set(\n                i + 1,\n                n - 1,\n                (-ra - w * H.get(i, n - 1) + q * H.get(i, n)) / x,\n              );\n              H.set(\n                i + 1,\n                n,\n                (-sa - w * H.get(i, n) - q * H.get(i, n - 1)) / x,\n              );\n            } else {\n              cdivres = cdiv(\n                -r - y * H.get(i, n - 1),\n                -s - y * H.get(i, n),\n                z,\n                q,\n              );\n              H.set(i + 1, n - 1, cdivres[0]);\n              H.set(i + 1, n, cdivres[1]);\n            }\n          }\n\n          t = Math.max(Math.abs(H.get(i, n - 1)), Math.abs(H.get(i, n)));\n          if (eps * t * t > 1) {\n            for (j = i; j <= n; j++) {\n              H.set(j, n - 1, H.get(j, n - 1) / t);\n              H.set(j, n, H.get(j, n) / t);\n            }\n          }\n        }\n      }\n    }\n  }\n\n  for (i = 0; i < nn; i++) {\n    if (i < low || i > high) {\n      for (j = i; j < nn; j++) {\n        V.set(i, j, H.get(i, j));\n      }\n    }\n  }\n\n  for (j = nn - 1; j >= low; j--) {\n    for (i = low; i <= high; i++) {\n      z = 0;\n      for (k = low; k <= Math.min(j, high); k++) {\n        z = z + V.get(i, k) * H.get(k, j);\n      }\n      V.set(i, j, z);\n    }\n  }\n}\n\nfunction cdiv(xr, xi, yr, yi) {\n  let r, d;\n  if (Math.abs(yr) > Math.abs(yi)) {\n    r = yi / yr;\n    d = yr + r * yi;\n    return [(xr + r * xi) / d, (xi - r * xr) / d];\n  } else {\n    r = yr / yi;\n    d = yi + r * yr;\n    return [(r * xr + xi) / d, (r * xi - xr) / d];\n  }\n}\n\nclass CholeskyDecomposition {\n  constructor(value) {\n    value = WrapperMatrix2D.checkMatrix(value);\n    if (!value.isSymmetric()) {\n      throw new Error('Matrix is not symmetric');\n    }\n\n    let a = value;\n    let dimension = a.rows;\n    let l = new Matrix(dimension, dimension);\n    let positiveDefinite = true;\n    let i, j, k;\n\n    for (j = 0; j < dimension; j++) {\n      let d = 0;\n      for (k = 0; k < j; k++) {\n        let s = 0;\n        for (i = 0; i < k; i++) {\n          s += l.get(k, i) * l.get(j, i);\n        }\n        s = (a.get(j, k) - s) / l.get(k, k);\n        l.set(j, k, s);\n        d = d + s * s;\n      }\n\n      d = a.get(j, j) - d;\n\n      positiveDefinite &&= d > 0;\n      l.set(j, j, Math.sqrt(Math.max(d, 0)));\n      for (k = j + 1; k < dimension; k++) {\n        l.set(j, k, 0);\n      }\n    }\n\n    this.L = l;\n    this.positiveDefinite = positiveDefinite;\n  }\n\n  isPositiveDefinite() {\n    return this.positiveDefinite;\n  }\n\n  solve(value) {\n    value = WrapperMatrix2D.checkMatrix(value);\n\n    let l = this.L;\n    let dimension = l.rows;\n\n    if (value.rows !== dimension) {\n      throw new Error('Matrix dimensions do not match');\n    }\n    if (this.isPositiveDefinite() === false) {\n      throw new Error('Matrix is not positive definite');\n    }\n\n    let count = value.columns;\n    let B = value.clone();\n    let i, j, k;\n\n    for (k = 0; k < dimension; k++) {\n      for (j = 0; j < count; j++) {\n        for (i = 0; i < k; i++) {\n          B.set(k, j, B.get(k, j) - B.get(i, j) * l.get(k, i));\n        }\n        B.set(k, j, B.get(k, j) / l.get(k, k));\n      }\n    }\n\n    for (k = dimension - 1; k >= 0; k--) {\n      for (j = 0; j < count; j++) {\n        for (i = k + 1; i < dimension; i++) {\n          B.set(k, j, B.get(k, j) - B.get(i, j) * l.get(i, k));\n        }\n        B.set(k, j, B.get(k, j) / l.get(k, k));\n      }\n    }\n\n    return B;\n  }\n\n  get lowerTriangularMatrix() {\n    return this.L;\n  }\n}\n\nclass nipals {\n  constructor(X, options = {}) {\n    X = WrapperMatrix2D.checkMatrix(X);\n    let { Y } = options;\n    const {\n      scaleScores = false,\n      maxIterations = 1000,\n      terminationCriteria = 1e-10,\n    } = options;\n\n    let u;\n    if (Y) {\n      if (isAnyArray.isAnyArray(Y) && typeof Y[0] === 'number') {\n        Y = Matrix.columnVector(Y);\n      } else {\n        Y = WrapperMatrix2D.checkMatrix(Y);\n      }\n      if (Y.rows !== X.rows) {\n        throw new Error('Y should have the same number of rows as X');\n      }\n      u = Y.getColumnVector(0);\n    } else {\n      u = X.getColumnVector(0);\n    }\n\n    let diff = 1;\n    let t, q, w, tOld;\n\n    for (\n      let counter = 0;\n      counter < maxIterations && diff > terminationCriteria;\n      counter++\n    ) {\n      w = X.transpose().mmul(u).div(u.transpose().mmul(u).get(0, 0));\n      w = w.div(w.norm());\n\n      t = X.mmul(w).div(w.transpose().mmul(w).get(0, 0));\n\n      if (counter > 0) {\n        diff = t.clone().sub(tOld).pow(2).sum();\n      }\n      tOld = t.clone();\n\n      if (Y) {\n        q = Y.transpose().mmul(t).div(t.transpose().mmul(t).get(0, 0));\n        q = q.div(q.norm());\n\n        u = Y.mmul(q).div(q.transpose().mmul(q).get(0, 0));\n      } else {\n        u = t;\n      }\n    }\n\n    if (Y) {\n      let p = X.transpose().mmul(t).div(t.transpose().mmul(t).get(0, 0));\n      p = p.div(p.norm());\n      let xResidual = X.clone().sub(t.clone().mmul(p.transpose()));\n      let residual = u.transpose().mmul(t).div(t.transpose().mmul(t).get(0, 0));\n      let yResidual = Y.clone().sub(\n        t.clone().mulS(residual.get(0, 0)).mmul(q.transpose()),\n      );\n\n      this.t = t;\n      this.p = p.transpose();\n      this.w = w.transpose();\n      this.q = q;\n      this.u = u;\n      this.s = t.transpose().mmul(t);\n      this.xResidual = xResidual;\n      this.yResidual = yResidual;\n      this.betas = residual;\n    } else {\n      this.w = w.transpose();\n      this.s = t.transpose().mmul(t).sqrt();\n      if (scaleScores) {\n        this.t = t.clone().div(this.s.get(0, 0));\n      } else {\n        this.t = t;\n      }\n      this.xResidual = X.sub(t.mmul(w.transpose()));\n    }\n  }\n}\n\nexports.AbstractMatrix = AbstractMatrix;\nexports.CHO = CholeskyDecomposition;\nexports.CholeskyDecomposition = CholeskyDecomposition;\nexports.DistanceMatrix = DistanceMatrix;\nexports.EVD = EigenvalueDecomposition;\nexports.EigenvalueDecomposition = EigenvalueDecomposition;\nexports.LU = LuDecomposition;\nexports.LuDecomposition = LuDecomposition;\nexports.Matrix = Matrix;\nexports.MatrixColumnSelectionView = MatrixColumnSelectionView;\nexports.MatrixColumnView = MatrixColumnView;\nexports.MatrixFlipColumnView = MatrixFlipColumnView;\nexports.MatrixFlipRowView = MatrixFlipRowView;\nexports.MatrixRowSelectionView = MatrixRowSelectionView;\nexports.MatrixRowView = MatrixRowView;\nexports.MatrixSelectionView = MatrixSelectionView;\nexports.MatrixSubView = MatrixSubView;\nexports.MatrixTransposeView = MatrixTransposeView;\nexports.NIPALS = nipals;\nexports.Nipals = nipals;\nexports.QR = QrDecomposition;\nexports.QrDecomposition = QrDecomposition;\nexports.SVD = SingularValueDecomposition;\nexports.SingularValueDecomposition = SingularValueDecomposition;\nexports.SymmetricMatrix = SymmetricMatrix;\nexports.WrapperMatrix1D = WrapperMatrix1D;\nexports.WrapperMatrix2D = WrapperMatrix2D;\nexports.correlation = correlation;\nexports.covariance = covariance;\nexports.default = Matrix;\nexports.determinant = determinant;\nexports.inverse = inverse;\nexports.linearDependencies = linearDependencies;\nexports.pseudoInverse = pseudoInverse;\nexports.solve = solve;\nexports.wrap = wrap;\n","import * as matrix from './matrix.js';\n\nexport const AbstractMatrix = matrix.AbstractMatrix;\nexport const CHO = matrix.CHO;\nexport const CholeskyDecomposition = matrix.CholeskyDecomposition;\nexport const DistanceMatrix = matrix.DistanceMatrix;\nexport const EVD = matrix.EVD;\nexport const EigenvalueDecomposition = matrix.EigenvalueDecomposition;\nexport const LU = matrix.LU;\nexport const LuDecomposition = matrix.LuDecomposition;\nexport const Matrix = matrix.Matrix;\nexport const MatrixColumnSelectionView = matrix.MatrixColumnSelectionView;\nexport const MatrixColumnView = matrix.MatrixColumnView;\nexport const MatrixFlipColumnView = matrix.MatrixFlipColumnView;\nexport const MatrixFlipRowView = matrix.MatrixFlipRowView;\nexport const MatrixRowSelectionView = matrix.MatrixRowSelectionView;\nexport const MatrixRowView = matrix.MatrixRowView;\nexport const MatrixSelectionView = matrix.MatrixSelectionView;\nexport const MatrixSubView = matrix.MatrixSubView;\nexport const MatrixTransposeView = matrix.MatrixTransposeView;\nexport const NIPALS = matrix.NIPALS;\nexport const Nipals = matrix.Nipals;\nexport const QR = matrix.QR;\nexport const QrDecomposition = matrix.QrDecomposition;\nexport const SVD = matrix.SVD;\nexport const SingularValueDecomposition = matrix.SingularValueDecomposition;\nexport const SymmetricMatrix = matrix.SymmetricMatrix;\nexport const WrapperMatrix1D = matrix.WrapperMatrix1D;\nexport const WrapperMatrix2D = matrix.WrapperMatrix2D;\nexport const correlation = matrix.correlation;\nexport const covariance = matrix.covariance;\nexport default matrix.default.Matrix ? matrix.default.Matrix : matrix.Matrix;\nexport const determinant = matrix.determinant;\nexport const inverse = matrix.inverse;\nexport const linearDependencies = matrix.linearDependencies;\nexport const pseudoInverse = matrix.pseudoInverse;\nexport const solve = matrix.solve;\nexport const wrap = matrix.wrap;\n","import { xCheck } from \"./xCheck.js\";\nimport { xGetFromToIndex } from \"./xGetFromToIndex.js\";\n/**\n * Computes the mean value of an array of values.\n * @param array - array of numbers\n * @param options - options\n */\nexport function xMean(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let sumValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        sumValue += array[i];\n    }\n    return sumValue / (toIndex - fromIndex + 1);\n}\n//# sourceMappingURL=xMean.js.map","import { xVariance } from \"./xVariance.js\";\n/**\n * Finds the standard deviation for the data at hand\n * @param values - values in the data\n * @param options - options\n * @returns standard deviation\n */\nexport function xStandardDeviation(values, options = {}) {\n    return Math.sqrt(xVariance(values, options));\n}\n//# sourceMappingURL=xStandardDeviation.js.map","import { isAnyArray } from 'is-any-array';\nimport { xMean } from \"./xMean.js\";\n/**\n * Finds the variance of the data\n * @param values - the values of the array\n * @param options - options\n * @returns variance\n */\nexport function xVariance(values, options = {}) {\n    if (!isAnyArray(values)) {\n        throw new TypeError('input must be an array');\n    }\n    const { unbiased = true, mean = xMean(values) } = options;\n    let sqrError = 0;\n    for (const value of values) {\n        const x = value - mean;\n        sqrError += x * x;\n    }\n    if (unbiased) {\n        return sqrError / (values.length - 1);\n    }\n    else {\n        return sqrError / values.length;\n    }\n}\n//# sourceMappingURL=xVariance.js.map","import { xCheck } from \"./xCheck.js\";\n/**\n * Returns a copy of the data as a Float64Array.\n * @param array - array of numbers\n */\nexport function xEnsureFloat64(array) {\n    xCheck(array);\n    if (array instanceof Float64Array) {\n        return array.slice(0);\n    }\n    return Float64Array.from(array);\n}\n//# sourceMappingURL=xEnsureFloat64.js.map","'use strict';\n\nfunction FFT(size) {\n  this.size = size | 0;\n  if (this.size <= 1 || (this.size & (this.size - 1)) !== 0)\n    throw new Error('FFT size must be a power of two and bigger than 1');\n\n  this._csize = size << 1;\n\n  // NOTE: Use of `var` is intentional for old V8 versions\n  var table = new Array(this.size * 2);\n  for (var i = 0; i < table.length; i += 2) {\n    const angle = Math.PI * i / this.size;\n    table[i] = Math.cos(angle);\n    table[i + 1] = -Math.sin(angle);\n  }\n  this.table = table;\n\n  // Find size's power of two\n  var power = 0;\n  for (var t = 1; this.size > t; t <<= 1)\n    power++;\n\n  // Calculate initial step's width:\n  //   * If we are full radix-4 - it is 2x smaller to give inital len=8\n  //   * Otherwise it is the same as `power` to give len=4\n  this._width = power % 2 === 0 ? power - 1 : power;\n\n  // Pre-compute bit-reversal patterns\n  this._bitrev = new Array(1 << this._width);\n  for (var j = 0; j < this._bitrev.length; j++) {\n    this._bitrev[j] = 0;\n    for (var shift = 0; shift < this._width; shift += 2) {\n      var revShift = this._width - shift - 2;\n      this._bitrev[j] |= ((j >>> shift) & 3) << revShift;\n    }\n  }\n\n  this._out = null;\n  this._data = null;\n  this._inv = 0;\n}\nmodule.exports = FFT;\n\nFFT.prototype.fromComplexArray = function fromComplexArray(complex, storage) {\n  var res = storage || new Array(complex.length >>> 1);\n  for (var i = 0; i < complex.length; i += 2)\n    res[i >>> 1] = complex[i];\n  return res;\n};\n\nFFT.prototype.createComplexArray = function createComplexArray() {\n  const res = new Array(this._csize);\n  for (var i = 0; i < res.length; i++)\n    res[i] = 0;\n  return res;\n};\n\nFFT.prototype.toComplexArray = function toComplexArray(input, storage) {\n  var res = storage || this.createComplexArray();\n  for (var i = 0; i < res.length; i += 2) {\n    res[i] = input[i >>> 1];\n    res[i + 1] = 0;\n  }\n  return res;\n};\n\nFFT.prototype.completeSpectrum = function completeSpectrum(spectrum) {\n  var size = this._csize;\n  var half = size >>> 1;\n  for (var i = 2; i < half; i += 2) {\n    spectrum[size - i] = spectrum[i];\n    spectrum[size - i + 1] = -spectrum[i + 1];\n  }\n};\n\nFFT.prototype.transform = function transform(out, data) {\n  if (out === data)\n    throw new Error('Input and output buffers must be different');\n\n  this._out = out;\n  this._data = data;\n  this._inv = 0;\n  this._transform4();\n  this._out = null;\n  this._data = null;\n};\n\nFFT.prototype.realTransform = function realTransform(out, data) {\n  if (out === data)\n    throw new Error('Input and output buffers must be different');\n\n  this._out = out;\n  this._data = data;\n  this._inv = 0;\n  this._realTransform4();\n  this._out = null;\n  this._data = null;\n};\n\nFFT.prototype.inverseTransform = function inverseTransform(out, data) {\n  if (out === data)\n    throw new Error('Input and output buffers must be different');\n\n  this._out = out;\n  this._data = data;\n  this._inv = 1;\n  this._transform4();\n  for (var i = 0; i < out.length; i++)\n    out[i] /= this.size;\n  this._out = null;\n  this._data = null;\n};\n\n// radix-4 implementation\n//\n// NOTE: Uses of `var` are intentional for older V8 version that do not\n// support both `let compound assignments` and `const phi`\nFFT.prototype._transform4 = function _transform4() {\n  var out = this._out;\n  var size = this._csize;\n\n  // Initial step (permute and transform)\n  var width = this._width;\n  var step = 1 << width;\n  var len = (size / step) << 1;\n\n  var outOff;\n  var t;\n  var bitrev = this._bitrev;\n  if (len === 4) {\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleTransform2(outOff, off, step);\n    }\n  } else {\n    // len === 8\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleTransform4(outOff, off, step);\n    }\n  }\n\n  // Loop through steps in decreasing order\n  var inv = this._inv ? -1 : 1;\n  var table = this.table;\n  for (step >>= 2; step >= 2; step >>= 2) {\n    len = (size / step) << 1;\n    var quarterLen = len >>> 2;\n\n    // Loop through offsets in the data\n    for (outOff = 0; outOff < size; outOff += len) {\n      // Full case\n      var limit = outOff + quarterLen;\n      for (var i = outOff, k = 0; i < limit; i += 2, k += step) {\n        const A = i;\n        const B = A + quarterLen;\n        const C = B + quarterLen;\n        const D = C + quarterLen;\n\n        // Original values\n        const Ar = out[A];\n        const Ai = out[A + 1];\n        const Br = out[B];\n        const Bi = out[B + 1];\n        const Cr = out[C];\n        const Ci = out[C + 1];\n        const Dr = out[D];\n        const Di = out[D + 1];\n\n        // Middle values\n        const MAr = Ar;\n        const MAi = Ai;\n\n        const tableBr = table[k];\n        const tableBi = inv * table[k + 1];\n        const MBr = Br * tableBr - Bi * tableBi;\n        const MBi = Br * tableBi + Bi * tableBr;\n\n        const tableCr = table[2 * k];\n        const tableCi = inv * table[2 * k + 1];\n        const MCr = Cr * tableCr - Ci * tableCi;\n        const MCi = Cr * tableCi + Ci * tableCr;\n\n        const tableDr = table[3 * k];\n        const tableDi = inv * table[3 * k + 1];\n        const MDr = Dr * tableDr - Di * tableDi;\n        const MDi = Dr * tableDi + Di * tableDr;\n\n        // Pre-Final values\n        const T0r = MAr + MCr;\n        const T0i = MAi + MCi;\n        const T1r = MAr - MCr;\n        const T1i = MAi - MCi;\n        const T2r = MBr + MDr;\n        const T2i = MBi + MDi;\n        const T3r = inv * (MBr - MDr);\n        const T3i = inv * (MBi - MDi);\n\n        // Final values\n        const FAr = T0r + T2r;\n        const FAi = T0i + T2i;\n\n        const FCr = T0r - T2r;\n        const FCi = T0i - T2i;\n\n        const FBr = T1r + T3i;\n        const FBi = T1i - T3r;\n\n        const FDr = T1r - T3i;\n        const FDi = T1i + T3r;\n\n        out[A] = FAr;\n        out[A + 1] = FAi;\n        out[B] = FBr;\n        out[B + 1] = FBi;\n        out[C] = FCr;\n        out[C + 1] = FCi;\n        out[D] = FDr;\n        out[D + 1] = FDi;\n      }\n    }\n  }\n};\n\n// radix-2 implementation\n//\n// NOTE: Only called for len=4\nFFT.prototype._singleTransform2 = function _singleTransform2(outOff, off,\n                                                             step) {\n  const out = this._out;\n  const data = this._data;\n\n  const evenR = data[off];\n  const evenI = data[off + 1];\n  const oddR = data[off + step];\n  const oddI = data[off + step + 1];\n\n  const leftR = evenR + oddR;\n  const leftI = evenI + oddI;\n  const rightR = evenR - oddR;\n  const rightI = evenI - oddI;\n\n  out[outOff] = leftR;\n  out[outOff + 1] = leftI;\n  out[outOff + 2] = rightR;\n  out[outOff + 3] = rightI;\n};\n\n// radix-4\n//\n// NOTE: Only called for len=8\nFFT.prototype._singleTransform4 = function _singleTransform4(outOff, off,\n                                                             step) {\n  const out = this._out;\n  const data = this._data;\n  const inv = this._inv ? -1 : 1;\n  const step2 = step * 2;\n  const step3 = step * 3;\n\n  // Original values\n  const Ar = data[off];\n  const Ai = data[off + 1];\n  const Br = data[off + step];\n  const Bi = data[off + step + 1];\n  const Cr = data[off + step2];\n  const Ci = data[off + step2 + 1];\n  const Dr = data[off + step3];\n  const Di = data[off + step3 + 1];\n\n  // Pre-Final values\n  const T0r = Ar + Cr;\n  const T0i = Ai + Ci;\n  const T1r = Ar - Cr;\n  const T1i = Ai - Ci;\n  const T2r = Br + Dr;\n  const T2i = Bi + Di;\n  const T3r = inv * (Br - Dr);\n  const T3i = inv * (Bi - Di);\n\n  // Final values\n  const FAr = T0r + T2r;\n  const FAi = T0i + T2i;\n\n  const FBr = T1r + T3i;\n  const FBi = T1i - T3r;\n\n  const FCr = T0r - T2r;\n  const FCi = T0i - T2i;\n\n  const FDr = T1r - T3i;\n  const FDi = T1i + T3r;\n\n  out[outOff] = FAr;\n  out[outOff + 1] = FAi;\n  out[outOff + 2] = FBr;\n  out[outOff + 3] = FBi;\n  out[outOff + 4] = FCr;\n  out[outOff + 5] = FCi;\n  out[outOff + 6] = FDr;\n  out[outOff + 7] = FDi;\n};\n\n// Real input radix-4 implementation\nFFT.prototype._realTransform4 = function _realTransform4() {\n  var out = this._out;\n  var size = this._csize;\n\n  // Initial step (permute and transform)\n  var width = this._width;\n  var step = 1 << width;\n  var len = (size / step) << 1;\n\n  var outOff;\n  var t;\n  var bitrev = this._bitrev;\n  if (len === 4) {\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleRealTransform2(outOff, off >>> 1, step >>> 1);\n    }\n  } else {\n    // len === 8\n    for (outOff = 0, t = 0; outOff < size; outOff += len, t++) {\n      const off = bitrev[t];\n      this._singleRealTransform4(outOff, off >>> 1, step >>> 1);\n    }\n  }\n\n  // Loop through steps in decreasing order\n  var inv = this._inv ? -1 : 1;\n  var table = this.table;\n  for (step >>= 2; step >= 2; step >>= 2) {\n    len = (size / step) << 1;\n    var halfLen = len >>> 1;\n    var quarterLen = halfLen >>> 1;\n    var hquarterLen = quarterLen >>> 1;\n\n    // Loop through offsets in the data\n    for (outOff = 0; outOff < size; outOff += len) {\n      for (var i = 0, k = 0; i <= hquarterLen; i += 2, k += step) {\n        var A = outOff + i;\n        var B = A + quarterLen;\n        var C = B + quarterLen;\n        var D = C + quarterLen;\n\n        // Original values\n        var Ar = out[A];\n        var Ai = out[A + 1];\n        var Br = out[B];\n        var Bi = out[B + 1];\n        var Cr = out[C];\n        var Ci = out[C + 1];\n        var Dr = out[D];\n        var Di = out[D + 1];\n\n        // Middle values\n        var MAr = Ar;\n        var MAi = Ai;\n\n        var tableBr = table[k];\n        var tableBi = inv * table[k + 1];\n        var MBr = Br * tableBr - Bi * tableBi;\n        var MBi = Br * tableBi + Bi * tableBr;\n\n        var tableCr = table[2 * k];\n        var tableCi = inv * table[2 * k + 1];\n        var MCr = Cr * tableCr - Ci * tableCi;\n        var MCi = Cr * tableCi + Ci * tableCr;\n\n        var tableDr = table[3 * k];\n        var tableDi = inv * table[3 * k + 1];\n        var MDr = Dr * tableDr - Di * tableDi;\n        var MDi = Dr * tableDi + Di * tableDr;\n\n        // Pre-Final values\n        var T0r = MAr + MCr;\n        var T0i = MAi + MCi;\n        var T1r = MAr - MCr;\n        var T1i = MAi - MCi;\n        var T2r = MBr + MDr;\n        var T2i = MBi + MDi;\n        var T3r = inv * (MBr - MDr);\n        var T3i = inv * (MBi - MDi);\n\n        // Final values\n        var FAr = T0r + T2r;\n        var FAi = T0i + T2i;\n\n        var FBr = T1r + T3i;\n        var FBi = T1i - T3r;\n\n        out[A] = FAr;\n        out[A + 1] = FAi;\n        out[B] = FBr;\n        out[B + 1] = FBi;\n\n        // Output final middle point\n        if (i === 0) {\n          var FCr = T0r - T2r;\n          var FCi = T0i - T2i;\n          out[C] = FCr;\n          out[C + 1] = FCi;\n          continue;\n        }\n\n        // Do not overwrite ourselves\n        if (i === hquarterLen)\n          continue;\n\n        // In the flipped case:\n        // MAi = -MAi\n        // MBr=-MBi, MBi=-MBr\n        // MCr=-MCr\n        // MDr=MDi, MDi=MDr\n        var ST0r = T1r;\n        var ST0i = -T1i;\n        var ST1r = T0r;\n        var ST1i = -T0i;\n        var ST2r = -inv * T3i;\n        var ST2i = -inv * T3r;\n        var ST3r = -inv * T2i;\n        var ST3i = -inv * T2r;\n\n        var SFAr = ST0r + ST2r;\n        var SFAi = ST0i + ST2i;\n\n        var SFBr = ST1r + ST3i;\n        var SFBi = ST1i - ST3r;\n\n        var SA = outOff + quarterLen - i;\n        var SB = outOff + halfLen - i;\n\n        out[SA] = SFAr;\n        out[SA + 1] = SFAi;\n        out[SB] = SFBr;\n        out[SB + 1] = SFBi;\n      }\n    }\n  }\n};\n\n// radix-2 implementation\n//\n// NOTE: Only called for len=4\nFFT.prototype._singleRealTransform2 = function _singleRealTransform2(outOff,\n                                                                     off,\n                                                                     step) {\n  const out = this._out;\n  const data = this._data;\n\n  const evenR = data[off];\n  const oddR = data[off + step];\n\n  const leftR = evenR + oddR;\n  const rightR = evenR - oddR;\n\n  out[outOff] = leftR;\n  out[outOff + 1] = 0;\n  out[outOff + 2] = rightR;\n  out[outOff + 3] = 0;\n};\n\n// radix-4\n//\n// NOTE: Only called for len=8\nFFT.prototype._singleRealTransform4 = function _singleRealTransform4(outOff,\n                                                                     off,\n                                                                     step) {\n  const out = this._out;\n  const data = this._data;\n  const inv = this._inv ? -1 : 1;\n  const step2 = step * 2;\n  const step3 = step * 3;\n\n  // Original values\n  const Ar = data[off];\n  const Br = data[off + step];\n  const Cr = data[off + step2];\n  const Dr = data[off + step3];\n\n  // Pre-Final values\n  const T0r = Ar + Cr;\n  const T1r = Ar - Cr;\n  const T2r = Br + Dr;\n  const T3r = inv * (Br - Dr);\n\n  // Final values\n  const FAr = T0r + T2r;\n\n  const FBr = T1r;\n  const FBi = -T3r;\n\n  const FCr = T0r - T2r;\n\n  const FDr = T1r;\n  const FDi = T3r;\n\n  out[outOff] = FAr;\n  out[outOff + 1] = 0;\n  out[outOff + 2] = FBr;\n  out[outOff + 3] = FBi;\n  out[outOff + 4] = FCr;\n  out[outOff + 5] = 0;\n  out[outOff + 6] = FDr;\n  out[outOff + 7] = FDi;\n};\n","/**\n * Create an array with numbers between \"from\" and \"to\" of length \"length\"\n * @param options - options\n * @returns - array of distributed numbers between \"from\" and \"to\"\n */\nexport function createFromToArray(options = {}) {\n    const { from = 0, to = 1, length = 1000, includeFrom = true, includeTo = true, distribution = 'uniform', } = options;\n    const array = new Float64Array(length);\n    let div = length;\n    if (includeFrom && includeTo) {\n        div = length - 1;\n    }\n    else if ((!includeFrom && includeTo) || (includeFrom && !includeTo)) {\n        div = length;\n    }\n    else if (!includeFrom && !includeTo) {\n        div = length + 1;\n    }\n    const delta = (to - from) / div;\n    if (distribution === 'uniform') {\n        if (includeFrom) {\n            let index = 0;\n            while (index < length) {\n                array[index] = from + delta * index;\n                index++;\n            }\n        }\n        else {\n            let index = 0;\n            while (index < length) {\n                array[index] = from + delta * (index + 1);\n                index++;\n            }\n        }\n    }\n    else if (distribution === 'log') {\n        const base = (to / from) ** (1 / div);\n        const firstExponent = Math.log(from) / Math.log(base);\n        if (includeFrom) {\n            let index = 0;\n            while (index < length) {\n                array[index] = base ** (firstExponent + index);\n                index++;\n            }\n        }\n        else {\n            let index = 0;\n            while (index < length) {\n                array[index] = base ** (firstExponent + index + 1);\n                index++;\n            }\n        }\n    }\n    else {\n        throw new Error('distribution must be uniform or log');\n    }\n    return array;\n}\n//# sourceMappingURL=createFromToArray.js.map","import { xCheck } from \"./xCheck.js\";\nimport { xGetFromToIndex } from \"./xGetFromToIndex.js\";\n/**\n * Computes the maximal value of an array of values\n * @param array - array of numbers\n * @param options - options\n */\nexport function xMaxValue(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let maxValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        if (array[i] > maxValue) {\n            maxValue = array[i];\n        }\n    }\n    return maxValue;\n}\n//# sourceMappingURL=xMaxValue.js.map","import { xCheck } from \"./xCheck.js\";\nimport { xGetFromToIndex } from \"./xGetFromToIndex.js\";\n/**\n * Computes the minimal value of an array of values.\n * @param array - array of numbers\n * @param options - options\n */\nexport function xMinValue(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let minValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        if (array[i] < minValue) {\n            minValue = array[i];\n        }\n    }\n    return minValue;\n}\n//# sourceMappingURL=xMinValue.js.map","/**\n * Returns true if x is monotonic.\n * @param array - array of numbers.\n * @returns 1 if monotonic increasing, -1 if monotonic decreasing, 0 if not monotonic.\n */\nexport function xIsMonotonic(array) {\n    if (array.length <= 2) {\n        return 1;\n    }\n    if (array[0] === array[1]) {\n        // maybe a constant series\n        for (let i = 1; i < array.length - 1; i++) {\n            if (array[i] !== array[i + 1])\n                return 0;\n        }\n        return 1;\n    }\n    if (array[0] < array.at(-1)) {\n        for (let i = 0; i < array.length - 1; i++) {\n            if (array[i] >= array[i + 1])\n                return 0;\n        }\n        return 1;\n    }\n    else {\n        for (let i = 0; i < array.length - 1; i++) {\n            if (array[i] <= array[i + 1])\n                return 0;\n        }\n        return -1;\n    }\n}\n//# sourceMappingURL=xIsMonotonic.js.map","import { xCheck } from \"./xCheck.js\";\n/**\n * Return min and max values of an array.\n * @param array - array of number\n * @returns - Object with 2 properties, min and max.\n */\nexport function xMinMaxValues(array) {\n    xCheck(array);\n    let min = array[0];\n    let max = array[0];\n    for (const value of array) {\n        if (value < min)\n            min = value;\n        if (value > max)\n            max = value;\n    }\n    return { min, max };\n}\n//# sourceMappingURL=xMinMaxValues.js.map","/*\nAdapted from: https://github.com/compute-io/erfcinv/blob/aa116e23883839359e310ad41a7c42f72815fc1e/lib/number.js\n\nThe MIT License (MIT)\n\nCopyright (c) 2014-2015 The Compute.io Authors. All rights reserved.\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n\n\nBoost Software License - Version 1.0 - August 17th, 2003\n\nPermission is hereby granted, free of charge, to any person or organization obtaining a copy of the software and accompanying documentation covered by this license (the \"Software\") to use, reproduce, display, distribute, execute, and transmit the Software, and to prepare derivative works of the Software, and to permit third-parties to whom the Software is furnished to do so, all subject to the following:\n\nThe copyright notices in the Software and this entire statement, including the above license grant, this restriction and the following disclaimer, must be included in all copies of the Software, in whole or in part, and all derivative works of the Software, unless such copies or derivative works are solely in the form of machine-executable object code generated by a source language processor.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.\n*/\n/* eslint-disable no-loss-of-precision */\n// Coefficients for erfcinv on [0, 0.5]:\nconst Y1 = 8.91314744949340820313e-2;\nconst P1 = [\n    -5.38772965071242932965e-3, 8.22687874676915743155e-3,\n    2.19878681111168899165e-2, -3.65637971411762664006e-2,\n    -1.26926147662974029034e-2, 3.34806625409744615033e-2,\n    -8.36874819741736770379e-3, -5.08781949658280665617e-4,\n];\nconst Q1 = [\n    8.86216390456424707504e-4, -2.33393759374190016776e-3,\n    7.95283687341571680018e-2, -5.27396382340099713954e-2,\n    -7.1228902341542847553e-1, 6.62328840472002992063e-1, 1.56221558398423026363,\n    -1.56574558234175846809, -9.70005043303290640362e-1, 1,\n];\n// Coefficients for erfcinv for 0.5 > 1-x >= 0:\nconst Y2 = 2.249481201171875;\nconst P2 = [\n    -3.67192254707729348546, 2.11294655448340526258e1, 1.7445385985570866523e1,\n    -4.46382324441786960818e1, -1.88510648058714251895e1,\n    1.76447298408374015486e1, 8.37050328343119927838, 1.05264680699391713268e-1,\n    -2.02433508355938759655e-1,\n];\nconst Q2 = [\n    1.72114765761200282724, -2.26436933413139721736e1, 1.08268667355460159008e1,\n    4.85609213108739935468e1, -2.01432634680485188801e1,\n    -2.86608180499800029974e1, 3.9713437953343869095, 6.24264124854247537712, 1,\n];\n// Coefficients for erfcinv for sqrt( -log(1-x)):\nconst Y3 = 8.07220458984375e-1;\nconst P3 = [\n    -6.81149956853776992068e-10, 2.85225331782217055858e-8,\n    -6.79465575181126350155e-7, 2.14558995388805277169e-3,\n    2.90157910005329060432e-2, 1.42869534408157156766e-1,\n    3.37785538912035898924e-1, 3.87079738972604337464e-1,\n    1.17030156341995252019e-1, -1.63794047193317060787e-1,\n    -1.31102781679951906451e-1,\n];\nconst Q3 = [\n    1.105924229346489121e-2, 1.52264338295331783612e-1, 8.48854343457902036425e-1,\n    2.59301921623620271374, 4.77846592945843778382, 5.38168345707006855425,\n    3.46625407242567245975, 1,\n];\nconst Y4 = 9.3995571136474609375e-1;\nconst P4 = [\n    2.66339227425782031962e-12, -2.30404776911882601748e-10,\n    4.60469890584317994083e-6, 1.57544617424960554631e-4,\n    1.87123492819559223345e-3, 9.50804701325919603619e-3,\n    1.85573306514231072324e-2, -2.22426529213447927281e-3,\n    -3.50353787183177984712e-2,\n];\nconst Q4 = [\n    7.64675292302794483503e-5, 2.63861676657015992959e-3,\n    3.41589143670947727934e-2, 2.20091105764131249824e-1,\n    7.62059164553623404043e-1, 1.3653349817554063097, 1,\n];\nconst Y5 = 9.8362827301025390625e-1;\nconst P5 = [\n    9.9055709973310326855e-17, -2.81128735628831791805e-14,\n    4.62596163522878599135e-9, 4.49696789927706453732e-7,\n    1.49624783758342370182e-5, 2.09386317487588078668e-4,\n    1.05628862152492910091e-3, -1.12951438745580278863e-3,\n    -1.67431005076633737133e-2,\n];\nconst Q5 = [\n    2.82243172016108031869e-7, 2.75335474764726041141e-5,\n    9.64011807005165528527e-4, 1.60746087093676504695e-2,\n    1.38151865749083321638e-1, 5.91429344886417493481e-1, 1,\n];\n/**\n * Polyval.\n * @param c - Array of Number.\n * @param x - Number.\n * @returns Number.\n */\nfunction polyval(c, x) {\n    let p = 0;\n    for (const coef of c) {\n        p = p * x + coef;\n    }\n    return p;\n}\n/**\n * Calculates a rational approximation.\n * @private\n * @param x - Number.\n * @param v - Number.\n * @param P - Array of polynomial coefficients.\n * @param Q - Array of polynomial coefficients.\n * @param Y - Number.\n * @returns Rational approximation.\n */\nfunction calc(x, v, P, Q, Y) {\n    const s = x - v;\n    const r = polyval(P, s) / polyval(Q, s);\n    return Y * x + r * x;\n}\n/**\n * Evaluates the complementary inverse error function for an input value.\n * @private\n * @param x - Input value.\n * @returns Evaluated complementary inverse error function.\n */\nexport default function erfcinv(x) {\n    let sign = false;\n    let val;\n    let q;\n    let g;\n    let r;\n    // [1] Special cases...\n    // NaN:\n    if (Number.isNaN(x)) {\n        return Number.NaN;\n    }\n    // x not on the interval: [0,2]\n    if (x < 0 || x > 2) {\n        throw new RangeError(`erfcinv()::invalid input argument. Value must be on the interval [0,2]. Value: \\`${x}\\`.`);\n    }\n    if (x === 0) {\n        return Number.POSITIVE_INFINITY;\n    }\n    if (x === 2) {\n        return Number.NEGATIVE_INFINITY;\n    }\n    if (x === 1) {\n        return 0;\n    }\n    // [2] Get the sign and make use of `erfc` reflection formula: `erfc(-z)=2 - erfc(z)`...\n    if (x > 1) {\n        q = 2 - x;\n        x = 1 - q;\n        sign = true;\n    }\n    else {\n        q = x;\n        x = 1 - x;\n    }\n    // [3] |x| <= 0.5\n    if (x <= 0.5) {\n        g = x * (x + 10);\n        r = polyval(P1, x) / polyval(Q1, x);\n        val = g * Y1 + g * r;\n        return sign ? -val : val;\n    }\n    // [4] 1-|x| >= 0.25\n    if (q >= 0.25) {\n        g = Math.sqrt(-2 * Math.log(q));\n        q = q - 0.25;\n        r = polyval(P2, q) / polyval(Q2, q);\n        val = g / (Y2 + r);\n        return sign ? -val : val;\n    }\n    q = Math.sqrt(-Math.log(q));\n    // [5] q < 3\n    if (q < 3) {\n        return calc(q, 1.125, P3, Q3, Y3);\n    }\n    // [6] q < 6\n    if (q < 6) {\n        return calc(q, 3, P4, Q4, Y4);\n    }\n    // Note that the smallest number in JavaScript is 5e-324. Math.sqrt( -Math.log( 5e-324 ) ) ~27.2844\n    return calc(q, 6, P5, Q5, Y5);\n    // Note that in the boost library, they are able to go to much smaller values, as 128 bit long doubles support ~1e-5000; something which JavaScript does not natively support.\n}\n//# sourceMappingURL=erfcinv.js.map","import erfcinv from \"./erfcinv.js\";\n/**\n * Applies a simple normalization inverse transformation to the input data.\n * @param data - The input array of numbers to be transformed.\n * @param options - Optional parameters for the transformation.\n * @returns A new Float64Array containing the transformed data.\n */\nexport function simpleNormInv(data, options = {}) {\n    const { magnitudeMode = false } = options;\n    const result = new Float64Array(data.length);\n    if (magnitudeMode) {\n        for (let i = 0; i < result.length; i++) {\n            result[i] = -Math.sqrt(-2 * Math.log(1 - data[i]));\n        }\n    }\n    else {\n        for (let i = 0; i < result.length; i++) {\n            result[i] = -1 * Math.SQRT2 * erfcinv(2 * data[i]);\n        }\n    }\n    return result;\n}\n/**\n * Convenience wrapper for single number processing by simpleNormInv function.\n * @param data - The number to be normalized.\n * @param options - The options for the normalization process.\n * @returns The normalized number.\n */\nexport function simpleNormInvNumber(data, options = {}) {\n    return simpleNormInv([data], options)[0];\n}\n//# sourceMappingURL=simpleNormInv.js.map","import { isAnyArray } from 'is-any-array';\nimport { createFromToArray } from \"../utils/index.js\";\nimport { simpleNormInvNumber } from \"./utils/simpleNormInv.js\";\nimport { xEnsureFloat64 } from \"./xEnsureFloat64.js\";\n/**\n * Determine noise level by san plot methodology (https://doi.org/10.1002/mrc.4882)\n * @param array - real or magnitude spectra data.\n * @param options - options\n * @returns noise level\n */\nexport function xNoiseSanPlot(array, options = {}) {\n    const { mask, cutOff, refine = true, magnitudeMode = false, scaleFactor = 1, factorStd = 5, fixOffset = true, } = options;\n    const input = prepareData(array, { scaleFactor, mask });\n    if (fixOffset && !magnitudeMode) {\n        const medianIndex = Math.floor(input.length / 2);\n        const median = input.length % 2 === 0\n            ? 0.5 * (input[medianIndex - 1] + input[medianIndex])\n            : input[medianIndex];\n        for (let i = 0; i < input.length; i++) {\n            input[i] -= median;\n        }\n    }\n    const firstNegativeValueIndex = input.at(-1) >= 0\n        ? input.length\n        : input.findIndex((e) => e < 0);\n    let lastPositiveValueIndex = firstNegativeValueIndex - 1;\n    for (let i = lastPositiveValueIndex; i >= 0; i--) {\n        if (input[i] > 0) {\n            lastPositiveValueIndex = i;\n            break;\n        }\n    }\n    const signPositive = input.slice(0, lastPositiveValueIndex + 1);\n    const signNegative = input.slice(firstNegativeValueIndex);\n    const cutOffDist = cutOff || determineCutOff(signPositive, { magnitudeMode });\n    const pIndex = Math.floor(signPositive.length * cutOffDist);\n    const initialNoiseLevelPositive = signPositive[pIndex];\n    const skyPoint = signPositive[0];\n    let initialNoiseLevelNegative;\n    if (signNegative.length > 0) {\n        const nIndex = Math.floor(signNegative.length * (1 - cutOffDist));\n        initialNoiseLevelNegative = -1 * signNegative[nIndex];\n    }\n    else {\n        initialNoiseLevelNegative = 0;\n    }\n    let noiseLevelPositive = initialNoiseLevelPositive;\n    let noiseLevelNegative = initialNoiseLevelNegative;\n    let cloneSignPositive = signPositive.slice();\n    let cloneSignNegative = signNegative.slice();\n    let cutOffSignalsIndexPlus = 0;\n    let cutOffSignalsIndexNeg = 2;\n    if (refine) {\n        let cutOffSignals = noiseLevelPositive * factorStd;\n        cutOffSignalsIndexPlus = signPositive.findIndex((e) => e < cutOffSignals);\n        if (cutOffSignalsIndexPlus > -1) {\n            cloneSignPositive = signPositive.slice(cutOffSignalsIndexPlus);\n            noiseLevelPositive =\n                cloneSignPositive[Math.floor(cloneSignPositive.length * cutOffDist)];\n        }\n        cutOffSignals = noiseLevelNegative * factorStd;\n        cutOffSignalsIndexNeg = signNegative.findIndex((e) => e < cutOffSignals);\n        if (cutOffSignalsIndexNeg > -1) {\n            cloneSignNegative = signNegative.slice(cutOffSignalsIndexNeg);\n            noiseLevelNegative =\n                cloneSignPositive[Math.floor(cloneSignNegative.length * (1 - cutOffDist))];\n        }\n    }\n    const correctionFactor = -simpleNormInvNumber(cutOffDist / 2, {\n        magnitudeMode,\n    });\n    let effectiveCutOffDist, refinedCorrectionFactor;\n    if (refine && cutOffSignalsIndexPlus > -1) {\n        effectiveCutOffDist =\n            (cutOffDist * cloneSignPositive.length + cutOffSignalsIndexPlus) /\n                (cloneSignPositive.length + cutOffSignalsIndexPlus);\n        refinedCorrectionFactor =\n            -1 * simpleNormInvNumber(effectiveCutOffDist / 2, { magnitudeMode });\n        noiseLevelPositive /= refinedCorrectionFactor;\n        if (cutOffSignalsIndexNeg > -1) {\n            effectiveCutOffDist =\n                (cutOffDist * cloneSignNegative.length + cutOffSignalsIndexNeg) /\n                    (cloneSignNegative.length + cutOffSignalsIndexNeg);\n            refinedCorrectionFactor =\n                -1 * simpleNormInvNumber(effectiveCutOffDist / 2, { magnitudeMode });\n            if (noiseLevelNegative !== 0) {\n                noiseLevelNegative /= refinedCorrectionFactor;\n            }\n        }\n    }\n    else {\n        noiseLevelPositive /= correctionFactor;\n        noiseLevelNegative /= correctionFactor;\n    }\n    return {\n        positive: noiseLevelPositive,\n        negative: noiseLevelNegative,\n        snr: skyPoint / noiseLevelPositive,\n        sanplot: generateSanPlot(input, {\n            fromTo: {\n                positive: { from: 0, to: lastPositiveValueIndex },\n                negative: { from: firstNegativeValueIndex, to: input.length },\n            },\n        }),\n    };\n}\n/**\n * Determines the optimal cut-off point for a given array of positive numbers.\n * @param signPositive - An array of positive numbers.\n * @param options - Optional parameters to configure the cut-off determination.\n * @param options.magnitudeMode - If true, uses magnitude mode for normalization. Default is false.\n * @param options.considerList - An object specifying the range and step for consideration.\n * @param options.considerList.from - The starting point of the range. Default is 0.5.\n * @param options.considerList.step - The step size for the range. Default is 0.1.\n * @param options.considerList.to - The ending point of the range. Default is 0.9.\n * @returns The optimal cut-off point as a number.\n */\nfunction determineCutOff(signPositive, options = {}) {\n    const { magnitudeMode = false, considerList = { from: 0.5, step: 0.1, to: 0.9 }, } = options;\n    //generate a list of values for\n    const cutOff = [];\n    const indexMax = signPositive.length - 1;\n    for (let i = 0.01; i <= 0.99; i += 0.01) {\n        const index = Math.round(indexMax * i);\n        const value = -signPositive[index] / simpleNormInvNumber(i / 2, { magnitudeMode });\n        cutOff.push([i, value]);\n    }\n    let minKi = Number.MAX_SAFE_INTEGER;\n    const { from, to, step } = considerList;\n    const delta = step / 2;\n    let whereToCutStat = 0.5;\n    for (let i = from; i <= to; i += step) {\n        const floor = i - delta;\n        const top = i + delta;\n        const elementsOfCutOff = cutOff.filter((e) => e[0] < top && e[0] > floor);\n        let averageValue = 0;\n        for (const element of elementsOfCutOff) {\n            averageValue += Math.abs(element[1]);\n        }\n        let kiSqrt = 0;\n        for (const element of elementsOfCutOff) {\n            kiSqrt += (element[1] - averageValue) ** 2;\n        }\n        if (kiSqrt < minKi) {\n            minKi = kiSqrt;\n            whereToCutStat = i;\n        }\n    }\n    return whereToCutStat;\n}\n/**\n * Generates a SAN plot from the given array based on the specified options.\n * @param array - The input array of numbers to be processed.\n * @param options - An optional object containing configuration options.\n * @param options.logBaseY - The logarithmic base for the Y-axis. Defaults to 2.\n * @param options.fromTo - An object specifying the range for each key. Each key maps to an object with `from` and `to` properties.\n * @returns An object where each key maps to a DataXY object containing the processed data.\n */\nfunction generateSanPlot(array, options = {}) {\n    const { fromTo, logBaseY = 2 } = options;\n    const sanplot = {};\n    for (const key in fromTo) {\n        const { from, to } = fromTo[key];\n        sanplot[key] =\n            from !== to\n                ? scale(array.slice(from, to), {\n                    logBaseY,\n                })\n                : { x: [], y: [] };\n        if (key === 'negative') {\n            sanplot[key].y.reverse();\n        }\n    }\n    return sanplot;\n}\n/**\n * Scales the input array based on the provided options.\n * @param array - The input array to be scaled.\n * @param options - An optional object containing scaling options.\n * @param options.logBaseY - If provided, the array values will be scaled using the logarithm of this base.\n * @returns An object containing the scaled x and y arrays.\n */\nfunction scale(array, options = {}) {\n    const { log10, abs } = Math;\n    const { logBaseY } = options;\n    if (logBaseY) {\n        array = array.slice(0);\n        const logOfBase = log10(logBaseY);\n        for (let i = 0; i < array.length; i++) {\n            array[i] = log10(abs(array[i])) / logOfBase;\n        }\n    }\n    const xAxis = createFromToArray({\n        from: 0,\n        to: array.length - 1,\n        length: array.length,\n    });\n    return { x: xAxis, y: array };\n}\n/**\n * Prepares and processes the input data array based on the provided options.\n * @param array - The input array of numbers to be processed.\n * @param options - An object containing the following properties:\n *   - scaleFactor: A number by which to scale each element of the array.\n *   - mask: An optional array of the same length as the input array, where\n *           elements corresponding to `true` values will be excluded from processing.\n * @param options.scaleFactor\n * @param options.mask\n * @returns A new Float64Array containing the processed data, scaled by the\n *          scaleFactor and sorted in descending order.\n */\nfunction prepareData(array, options) {\n    const { scaleFactor, mask } = options;\n    const input = xEnsureFloat64(isAnyArray(mask) && mask.length === array.length\n        ? array.filter((_e, i) => !mask[i])\n        : array);\n    if (scaleFactor > 1) {\n        for (let i = 0; i < input.length; i++) {\n            input[i] *= scaleFactor;\n        }\n    }\n    input.sort();\n    input.reverse();\n    return input;\n}\n//# sourceMappingURL=xNoiseSanPlot.js.map","import { xMedianAbsoluteDeviation } from \"./xMedianAbsoluteDeviation.js\";\n/**\n * Determine noise level using MAD https://en.wikipedia.org/wiki/Median_absolute_deviation\n * Constant to convert mad to sd calculated using https://www.wolframalpha.com/input?i=sqrt%282%29+inverse+erf%280.5%29\n * This assumes a gaussian distribution of the noise\n * @param array\n * @returns noise level corresponding to one standard deviation\n */\nexport function xNoiseStandardDeviation(array) {\n    const { mad, median } = xMedianAbsoluteDeviation(array);\n    return { sd: mad / 0.6744897501960817, mad, median };\n}\n//# sourceMappingURL=xNoiseStandardDeviation.js.map","import { xMedian } from \"./xMedian.js\";\n/**\n * This function calculates the median absolute deviation (MAD).\n * https://en.wikipedia.org/wiki/Median_absolute_deviation\n * @param array\n */\nexport function xMedianAbsoluteDeviation(array) {\n    const median = xMedian(array);\n    const averageDeviations = new Float64Array(array.length);\n    for (let i = 0; i < array.length; i++) {\n        averageDeviations[i] = Math.abs(array[i] - median);\n    }\n    return {\n        median,\n        mad: xMedian(averageDeviations),\n    };\n}\n//# sourceMappingURL=xMedianAbsoluteDeviation.js.map","import { getOutputArray } from \"./getOutputArray.js\";\nimport { xCheck } from \"./xCheck.js\";\nimport { xMaxValue } from \"./xMaxValue.js\";\nimport { xSum } from \"./xSum.js\";\n/**\n * Divides the data with either the sum, the absolute sum or the maximum of the data\n * @param input - Array containing values\n * @param options - options\n * @returns - normalized data\n */\nexport function xNormed(input, options = {}) {\n    const { algorithm = 'absolute', value = 1 } = options;\n    xCheck(input);\n    const output = getOutputArray(options.output, input.length);\n    if (input.length === 0) {\n        throw new Error('input must not be empty');\n    }\n    switch (algorithm) {\n        case 'absolute': {\n            const absoluteSumValue = absoluteSum(input) / value;\n            if (absoluteSumValue === 0) {\n                throw new Error('trying to divide by 0');\n            }\n            for (let i = 0; i < input.length; i++) {\n                output[i] = input[i] / absoluteSumValue;\n            }\n            return output;\n        }\n        case 'max': {\n            const currentMaxValue = xMaxValue(input);\n            if (currentMaxValue === 0) {\n                throw new Error('trying to divide by 0');\n            }\n            const factor = value / currentMaxValue;\n            for (let i = 0; i < input.length; i++) {\n                output[i] = input[i] * factor;\n            }\n            return output;\n        }\n        case 'sum': {\n            const sumFactor = xSum(input) / value;\n            if (sumFactor === 0) {\n                throw new Error('trying to divide by 0');\n            }\n            for (let i = 0; i < input.length; i++) {\n                output[i] = input[i] / sumFactor;\n            }\n            return output;\n        }\n        default:\n            throw new Error(`unknown algorithm: ${String(algorithm)}`);\n    }\n}\nfunction absoluteSum(input) {\n    let sumValue = 0;\n    for (const value of input) {\n        sumValue += Math.abs(value);\n    }\n    return sumValue;\n}\n//# sourceMappingURL=xNormed.js.map","import { xCheck } from \"./xCheck.js\";\nimport { xGetFromToIndex } from \"./xGetFromToIndex.js\";\n/**\n * Calculate the sum of the values\n * @param array - Object that contains property x (an ordered increasing array) and y (an array).\n * @param options - Options.\n * @returns XSum value on the specified range.\n */\nexport function xSum(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let sumValue = array[fromIndex];\n    for (let i = fromIndex + 1; i <= toIndex; i++) {\n        sumValue += array[i];\n    }\n    return sumValue;\n}\n//# sourceMappingURL=xSum.js.map","import { xCheck } from \"./xCheck.js\";\nimport { xStandardDeviation } from \"./xStandardDeviation.js\";\n/**\n * Pareto scaling, which uses the square root of standard deviation as the scaling factor, circumvents the amplification of noise by retaining a small portion of magnitude information.\n * Noda, I. (2008). Scaling techniques to enhance two-dimensional correlation spectra. Journal of Molecular Structure, 883, 216-227.\n * DOI: 10.1016/j.molstruc.2007.12.026\n * @param array - array of number\n */\nexport function xParetoNormalization(array) {\n    xCheck(array);\n    const result = new Float64Array(array.length);\n    const sqrtSD = Math.sqrt(xStandardDeviation(array));\n    for (let i = 0; i < array.length; i++) {\n        result[i] = array[i] / sqrtSD;\n    }\n    return result;\n}\n//# sourceMappingURL=xParetoNormalization.js.map","import { xCheck } from \"./xCheck.js\";\nimport { xPadding } from \"./xPadding.js\";\n/**\n * This function calculates a rolling average\n * @param array - array\n * @param fct - callback function that from an array returns a value\n * @param options - options\n */\nexport function xRolling(array, fct, options = {}) {\n    xCheck(array);\n    if (typeof fct !== 'function') {\n        throw new TypeError('fct must be a function');\n    }\n    const { window = 5, padding = {} } = options;\n    const { size = window - 1, algorithm, value } = padding;\n    const padded = xPadding(array, { size, algorithm, value }); // ensure we get a copy and it is float64\n    const newArray = [];\n    for (let i = 0; i < padded.length - window + 1; i++) {\n        // we will send a view to the original buffer\n        newArray.push(fct(padded.subarray(i, i + window)));\n    }\n    return newArray;\n}\n//# sourceMappingURL=xRolling.js.map","import { xCheck } from \"./xCheck.js\";\nimport { xEnsureFloat64 } from \"./xEnsureFloat64.js\";\n/**\n * This function pads an array\n *s\n * @param array - the array that will be padded\n * @param options - options\n */\nexport function xPadding(array, options = {}) {\n    const { size = 0, value = 0, algorithm } = options;\n    xCheck(array);\n    if (!algorithm) {\n        return xEnsureFloat64(array);\n    }\n    const result = new Float64Array(array.length + size * 2);\n    for (let i = 0; i < array.length; i++) {\n        result[i + size] = array[i];\n    }\n    const fromEnd = size + array.length;\n    const toEnd = 2 * size + array.length;\n    switch (algorithm) {\n        case 'value':\n            for (let i = 0; i < size; i++) {\n                result[i] = value;\n            }\n            for (let i = fromEnd; i < toEnd; i++) {\n                result[i] = value;\n            }\n            break;\n        case 'duplicate':\n            for (let i = 0; i < size; i++) {\n                result[i] = array[0];\n            }\n            for (let i = fromEnd; i < toEnd; i++) {\n                result[i] = array.at(-1);\n            }\n            break;\n        case 'circular':\n            for (let i = 0; i < size; i++) {\n                result[i] =\n                    array[(array.length - (size % array.length) + i) % array.length];\n            }\n            for (let i = 0; i < size; i++) {\n                result[i + fromEnd] = array[i % array.length];\n            }\n            break;\n        default:\n            throw new Error(`unknown algorithm ${String(algorithm)}`);\n    }\n    return result;\n}\n//# sourceMappingURL=xPadding.js.map","import { matrixCheck } from \"./matrixCheck.js\";\n/**\n * Get min and max Z.\n * @param matrix - matrix [rows][cols].\n */\nexport function matrixMinMaxZ(matrix) {\n    matrixCheck(matrix);\n    const nbRows = matrix.length;\n    const nbColumns = matrix[0].length;\n    let min = matrix[0][0];\n    let max = matrix[0][0];\n    for (let column = 0; column < nbColumns; column++) {\n        for (let row = 0; row < nbRows; row++) {\n            if (matrix[row][column] < min)\n                min = matrix[row][column];\n            if (matrix[row][column] > max)\n                max = matrix[row][column];\n        }\n    }\n    return { min, max };\n}\n//# sourceMappingURL=matrixMinMaxZ.js.map","export function matrixCheck(data) {\n    if (data.length === 0 || data[0].length === 0) {\n        throw new RangeError('matrix must contain data');\n    }\n    const firstLength = data[0].length;\n    for (let i = 1; i < data.length; i++) {\n        if (data[i].length !== firstLength) {\n            throw new RangeError('all rows must has the same length');\n        }\n    }\n}\n//# sourceMappingURL=matrixCheck.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Verify that `data` is an object of x,y arrays.\n * Throws an error if it's not.\n * @param data\n * @param options\n * @param options.minLength\n */\nexport function xyCheck(data, options = {}) {\n    const { minLength } = options;\n    if (data === null ||\n        typeof data !== 'object' ||\n        // @ts-expect-error Typechecking\n        !isAnyArray(data.x) ||\n        // @ts-expect-error Typechecking\n        !isAnyArray(data.y)) {\n        throw new Error('data must be an object of x and y arrays');\n    }\n    // @ts-expect-error Typechecking\n    if (data.x.length !== data.y.length) {\n        throw new Error('the x and y arrays must have the same length');\n    }\n    // @ts-expect-error Typechecking\n    if (minLength && data.x.length < minLength) {\n        throw new Error(`data.x must have a length of at least ${minLength}`);\n    }\n}\n//# sourceMappingURL=xyCheck.js.map","import { xIsMonotonic } from \"../x/index.js\";\nimport { xyCheck } from \"./xyCheck.js\";\n/**\n * Filters x,y values to allow strictly growing values in x-axis.\n * @param data - Object that contains property x (an ordered increasing array) and y (an array).\n */\nexport function xyEnsureGrowingX(data) {\n    xyCheck(data);\n    if (xIsMonotonic(data.x) === 1)\n        return data;\n    const x = Array.from(data.x);\n    const y = Array.from(data.y);\n    let prevX = Number.NEGATIVE_INFINITY;\n    let currentIndex = 0;\n    for (let index = 0; index < x.length; index++) {\n        if (prevX < x[index]) {\n            if (currentIndex < index) {\n                x[currentIndex] = x[index];\n                y[currentIndex] = y[index];\n            }\n            currentIndex++;\n            prevX = x[index];\n        }\n    }\n    x.length = currentIndex;\n    y.length = currentIndex;\n    return { x, y };\n}\n//# sourceMappingURL=xyEnsureGrowingX.js.map","/**\n * Normalize an array of zones:\n * - ensure than from < to\n * - merge overlapping zones\n * - deal with exclusions zones\n * - if no zones is specified add one between -Infinity and +Infinity\n * @param zones - array of zones\n * @param options - options\n * @returns array of zones\n */\nexport function zonesNormalize(zones = [], options = {}) {\n    const { exclusions = [] } = options;\n    let { from = Number.NEGATIVE_INFINITY, to = Number.POSITIVE_INFINITY } = options;\n    if (from > to)\n        [from, to] = [to, from];\n    zones = zones.map((zone) => zone.from > zone.to ? { from: zone.to, to: zone.from } : { ...zone });\n    zones.sort((a, b) => {\n        if (a.from !== b.from)\n            return a.from - b.from;\n        return a.to - b.to;\n    });\n    if (zones.length === 0) {\n        zones.push({ from, to });\n    }\n    for (const zone of zones) {\n        if (from > zone.from)\n            zone.from = from;\n        if (to < zone.to)\n            zone.to = to;\n    }\n    zones = zones.filter((zone) => zone.from <= zone.to);\n    if (zones.length === 0)\n        return [];\n    let currentZone = zones[0];\n    const beforeExclusionsZones = [currentZone];\n    for (let i = 1; i < zones.length; i++) {\n        const zone = zones[i];\n        if (zone.from <= currentZone.to) {\n            if (currentZone.to < zone.to) {\n                currentZone.to = zone.to;\n            }\n        }\n        else {\n            currentZone = zone;\n            beforeExclusionsZones.push(currentZone);\n        }\n    }\n    if (exclusions.length === 0)\n        return beforeExclusionsZones;\n    const normalizedExclusions = zonesNormalize(exclusions);\n    let currentExclusionIndex = 0;\n    const results = [];\n    for (let zoneIndex = 0; zoneIndex < beforeExclusionsZones.length; zoneIndex++) {\n        const zone = beforeExclusionsZones[zoneIndex];\n        if (currentExclusionIndex === normalizedExclusions.length) {\n            // we analysed all the exclusion zones\n            results.push(zone);\n            continue;\n        }\n        while (currentExclusionIndex < normalizedExclusions.length &&\n            normalizedExclusions[currentExclusionIndex].to <= zone.from) {\n            currentExclusionIndex++;\n        }\n        if (currentExclusionIndex === normalizedExclusions.length) {\n            // we analysed all the exclusion zones\n            results.push(zone);\n            continue;\n        }\n        if (zone.to < normalizedExclusions[currentExclusionIndex].from) {\n            // no problems, not yet in exclusion\n            results.push(zone);\n            continue;\n        }\n        if (normalizedExclusions[currentExclusionIndex].to >= zone.to) {\n            // could be totally excluded\n            if (normalizedExclusions[currentExclusionIndex].from <= zone.from) {\n                continue;\n            }\n            results.push({\n                from: normalizedExclusions[currentExclusionIndex].to,\n                to: zone.to,\n            });\n        }\n        // we cut in the middle, we need to create more zones, annoying !\n        if (normalizedExclusions[currentExclusionIndex].from > zone.from) {\n            results.push({\n                from: zone.from,\n                to: normalizedExclusions[currentExclusionIndex].from,\n            });\n        }\n        zone.from = normalizedExclusions[currentExclusionIndex].to;\n        zoneIndex--;\n    }\n    return results;\n}\n//# sourceMappingURL=zonesNormalize.js.map","/**\n * Function that calculates the integral of the line between two\n * x-coordinates, given the slope and intercept of the line.\n * @param x0\n * @param x1\n * @param slope\n * @param intercept\n * @returns integral value.\n */\nexport default function integral(\n/** first coordinate of point */\nx0, \n/** second coordinate of point */\nx1, \n/** slope of the line */\nslope, \n/** intercept of the line on the y axis */\nintercept) {\n    return (0.5 * slope * x1 * x1 +\n        intercept * x1 -\n        (0.5 * slope * x0 * x0 + intercept * x0));\n}\n//# sourceMappingURL=integral.js.map","import integral from \"./integral.js\";\n/**\n * Function that retrieves the getEquallySpacedData with the variant \"smooth\".\n * @param x\n * @param y\n * @param from\n * @param to\n * @param numberOfPoints\n * @returns - Array of y's equally spaced with the variant \"smooth\"\n */\nexport default function equallySpacedSmooth(\n/** x coordinates */\nx, \n/** y coordinates */\ny, \n/** from value */\nfrom, \n/** to value */\nto, \n/** number of points */\nnumberOfPoints) {\n    const xLength = x.length;\n    const step = (to - from) / (numberOfPoints > 1 ? numberOfPoints - 1 : 1);\n    const halfStep = step / 2;\n    // Changed Array to Float64Array\n    const output = new Float64Array(numberOfPoints);\n    const initialOriginalStep = x[1] - x[0];\n    const lastOriginalStep = x[xLength - 1] - x[xLength - 2];\n    // Init main variables\n    let min = from - halfStep;\n    let max = from + halfStep;\n    let previousX = Number.MIN_SAFE_INTEGER;\n    let previousY = 0;\n    let nextX = x[0] - initialOriginalStep;\n    let nextY = 0;\n    let currentValue = 0;\n    let slope = 0;\n    let intercept = 0;\n    let sumAtMin = 0;\n    let sumAtMax = 0;\n    let i = 0; // index of input\n    let j = 0; // index of output\n    let add = 0;\n    main: while (true) {\n        if (previousX >= nextX)\n            throw new Error('x must be a growing series');\n        if (previousX <= min && min <= nextX) {\n            add = integral(0, min - previousX, slope, previousY);\n            sumAtMin = currentValue + add;\n        }\n        while (nextX - max >= 0) {\n            // no overlap with original point, just consume current value\n            add = integral(0, max - previousX, slope, previousY);\n            sumAtMax = currentValue + add;\n            output[j++] = (sumAtMax - sumAtMin) / step;\n            if (j === numberOfPoints) {\n                break main;\n            }\n            min = max;\n            max += step;\n            sumAtMin = sumAtMax;\n        }\n        currentValue += integral(previousX, nextX, slope, intercept);\n        previousX = nextX;\n        previousY = nextY;\n        if (i < xLength) {\n            nextX = x[i];\n            nextY = y[i];\n            i++;\n        }\n        else if (i === xLength) {\n            nextX += lastOriginalStep;\n            nextY = 0;\n        }\n        slope = getSlope(previousX, previousY, nextX, nextY);\n        intercept = -slope * previousX + previousY;\n    }\n    return output;\n}\nfunction getSlope(x0, y0, x1, y1) {\n    return (y1 - y0) / (x1 - x0);\n}\n//# sourceMappingURL=equallySpacedSmooth.js.map","import { createFromToArray } from \"../utils/index.js\";\nimport { zonesNormalize, zonesWithPoints } from \"../zones/index.js\";\nimport equallySpacedSlot from \"./utils/equallySpacedSlot.js\";\nimport equallySpacedSmooth from \"./utils/equallySpacedSmooth.js\";\nimport { xyCheck } from \"./xyCheck.js\";\n/**\n * Function that returns a Number array of equally spaced numberOfPoints\n * containing a representation of intensities of the spectra arguments x\n * and y.\n *\n * The options parameter contains an object in the following form:\n * from: starting point\n * to: last point\n * numberOfPoints: number of points between from and to\n * variant: \"slot\" or \"smooth\" - smooth is the default option\n *\n * The slot variant consist that each point in an array is calculated\n * averaging the existing points between the slot that belongs to the current\n * value. The smooth variant is the same but takes the integral of the range\n * of the slot and divide by the step size between two points in an array.\n *\n * If exclusions zone are present, zones are ignored !\n * @param data - object containing 2 properties x and y\n * @param options - options\n * @returns new object with x / y array with the equally spaced data.\n */\nexport function xyEquallySpaced(data, options = {}) {\n    const { x, y } = data;\n    const xLength = x.length;\n    const { from = x[0], to = x[xLength - 1], variant = 'smooth', numberOfPoints = 100, exclusions = [], zones = [{ from, to }], } = options;\n    if (from > to) {\n        throw new RangeError('from should be larger than to');\n    }\n    xyCheck(data);\n    if (numberOfPoints < 2) {\n        throw new RangeError(\"'numberOfPoints' option must be greater than 1\");\n    }\n    const normalizedZones = zonesNormalize(zones, { from, to, exclusions });\n    const zonesWithPointsRes = zonesWithPoints(normalizedZones, numberOfPoints, {\n        from,\n        to,\n    }).filter((zone) => zone.numberOfPoints);\n    let xResult = [];\n    let yResult = [];\n    for (const zone of zonesWithPointsRes) {\n        if (!zone.numberOfPoints) {\n            zone.numberOfPoints = 0;\n        }\n        const zoneResult = processZone(Array.from(x), Array.from(y), zone.from, zone.to, zone.numberOfPoints, variant);\n        xResult = xResult.concat(zoneResult.x);\n        yResult = yResult.concat(zoneResult.y);\n    }\n    return { x: xResult, y: yResult };\n}\nfunction processZone(x, y, from, to, numberOfPoints, variant) {\n    if (numberOfPoints < 1) {\n        throw new RangeError('the number of points must be at least 1');\n    }\n    const output = variant === 'slot'\n        ? Array.from(equallySpacedSlot(x, y, from, to, numberOfPoints))\n        : Array.from(equallySpacedSmooth(x, y, from, to, numberOfPoints));\n    return {\n        x: Array.from(createFromToArray({\n            from,\n            to,\n            length: numberOfPoints,\n        })),\n        y: output,\n    };\n}\n//# sourceMappingURL=xyEquallySpaced.js.map","import { zonesNormalize } from \"./zonesNormalize.js\";\n/**\n * Add the number of points per zone to reach a specified total\n * @param zones - array of zones\n * @param numberOfPoints - total number of points to distribute between zones\n * @param options - options\n * @returns array of zones with points\n */\nexport function zonesWithPoints(zones = [], \n/**\n * total number of points to distribute between zones\n * @default 10\n */\nnumberOfPoints = 10, options = {}) {\n    if (zones.length === 0)\n        return [];\n    const normalizedZones = zonesNormalize(zones, options);\n    const zonesWithNumberOfPoints = [];\n    const totalSize = normalizedZones.reduce((previous, current) => {\n        return previous + (current.to - current.from);\n    }, 0);\n    const unitsPerPoint = totalSize / numberOfPoints;\n    let currentTotal = 0;\n    for (let i = 0; i < normalizedZones.length - 1; i++) {\n        const tempZone = normalizedZones[i];\n        const tempZoneNumberOfPoints = Math.min(Math.round((tempZone.to - tempZone.from) / unitsPerPoint), numberOfPoints - currentTotal);\n        zonesWithNumberOfPoints.push({\n            ...tempZone,\n            numberOfPoints: tempZoneNumberOfPoints,\n        });\n        currentTotal += tempZoneNumberOfPoints;\n    }\n    zonesWithNumberOfPoints.push({\n        ...normalizedZones.at(-1),\n        numberOfPoints: numberOfPoints - currentTotal,\n    });\n    return zonesWithNumberOfPoints;\n}\n//# sourceMappingURL=zonesWithPoints.js.map","/**\n * Function that retrieves the getEquallySpacedData with the variant \"slot\".\n * @param x\n * @param y\n * @param from\n * @param to\n * @param numberOfPoints\n * @returns Array of y's equally spaced with the variant \"slot\"\n */\nexport default function equallySpacedSlot(\n/** x coordinates */\nx, \n/** y coordinates */\ny, \n/** from value */\nfrom, \n/** to value */\nto, \n/** number of points */\nnumberOfPoints) {\n    const xLength = x.length;\n    if (xLength < 2) {\n        return Float64Array.from(x);\n    }\n    const step = (to - from) / (numberOfPoints > 1 ? numberOfPoints - 1 : 1);\n    const halfStep = step / 2;\n    const lastStep = x.at(-1) - x.at(-2);\n    const start = from - halfStep;\n    // Changed Array to Float64Array\n    const output = new Float64Array(numberOfPoints);\n    // Init main variables\n    let min = start;\n    let max = start + step;\n    let previousX = -Number.MAX_VALUE;\n    let previousY = 0;\n    let nextX = x[0];\n    let nextY = y[0];\n    let frontOutsideSpectra = 0;\n    let backOutsideSpectra = true;\n    let currentValue = 0;\n    // for slot algorithm\n    let currentPoints = 0;\n    let i = 1; // index of input\n    let j = 0; // index of output\n    main: while (true) {\n        if (previousX >= nextX)\n            throw new Error('x must be a growing series');\n        while (previousX - max > 0) {\n            // no overlap with original point, just consume current value\n            if (backOutsideSpectra) {\n                currentPoints++;\n                backOutsideSpectra = false;\n            }\n            output[j] = currentPoints <= 0 ? 0 : currentValue / currentPoints;\n            j++;\n            if (j === numberOfPoints) {\n                break main;\n            }\n            min = max;\n            max += step;\n            currentValue = 0;\n            currentPoints = 0;\n        }\n        if (previousX > min) {\n            currentValue += previousY;\n            currentPoints++;\n        }\n        if (previousX === -Number.MAX_VALUE || frontOutsideSpectra > 1) {\n            currentPoints--;\n        }\n        previousX = nextX;\n        previousY = nextY;\n        if (i < xLength) {\n            nextX = x[i];\n            nextY = y[i];\n            i++;\n        }\n        else {\n            nextX += lastStep;\n            nextY = 0;\n            frontOutsideSpectra++;\n        }\n    }\n    return output;\n}\n//# sourceMappingURL=equallySpacedSlot.js.map","import { zonesNormalize } from \"../zones/index.js\";\n/**\n * Filter an array x/y based on various criteria x points are expected to be sorted\n * @param data - object containing 2 properties x and y\n * @param options - options\n * @returns filtered array\n */\nexport function xyFilterX(data, options = {}) {\n    const { x, y } = data;\n    if (x.length === 0) {\n        return {\n            x: Array.from(x),\n            y: Array.from(y),\n        };\n    }\n    const { from = x[0], to = x.at(-1), zones = [{ from, to }], exclusions = [], } = options;\n    const normalizedZones = zonesNormalize(zones, { from, to, exclusions });\n    let currentZoneIndex = 0;\n    const newX = [];\n    const newY = [];\n    let position = 0;\n    while (position < x.length) {\n        if (x[position] <= normalizedZones[currentZoneIndex].to &&\n            x[position] >= normalizedZones[currentZoneIndex].from) {\n            newX.push(x[position]);\n            newY.push(y[position]);\n        }\n        else if (x[position] > normalizedZones[currentZoneIndex].to) {\n            currentZoneIndex++;\n            if (!normalizedZones[currentZoneIndex])\n                break;\n        }\n        position++;\n    }\n    return {\n        x: newX,\n        y: newY,\n    };\n}\n//# sourceMappingURL=xyFilterX.js.map","import { xyCheck } from \"./xyCheck.js\";\n/**\n * Filter out all the points for which x <= 0. Useful to display log scale data\n * @param data - data\n * @returns - An object with the filtered data\n */\nexport function xyFilterXPositive(data) {\n    xyCheck(data);\n    const { x, y } = data;\n    const newX = [];\n    const newY = [];\n    if (x === undefined || y === undefined) {\n        return { x: newX, y: newY };\n    }\n    for (let i = 0; i < x.length; i++) {\n        if (x[i] > 0) {\n            newX.push(x[i]);\n            newY.push(y[i]);\n        }\n    }\n    return { x: newX, y: newY };\n}\n//# sourceMappingURL=xyFilterXPositive.js.map","/**\n * Order object of array, x has to be monotone. Ensure x is growing\n * @param data - Object of kind {x:[], y:[]}.\n */\nexport function xyGrowingX(data) {\n    const { x, y } = data;\n    if (x.length !== y.length) {\n        throw new TypeError('length of x and y must be identical');\n    }\n    if (x.length < 2 || x[0] < x.at(-1))\n        return data;\n    return {\n        x: x.toReversed(),\n        y: y.toReversed(),\n    };\n}\n//# sourceMappingURL=xyGrowingX.js.map","export function addStyle(serie, spectrum, options = {}) {\n    let { color = '#A9A9A9' } = options;\n    const { opacity = 1, lineWidth = 1 } = options;\n    if (color.match(/#[\\da-f]{6}$/i)) {\n        color = (color + ((opacity * 255) >> 0).toString(16)).toUpperCase();\n    }\n    else {\n        color = color.replace(/rgb ?\\((.*)\\)/, `rgba($1,${opacity})`);\n    }\n    serie.style = [\n        {\n            name: 'unselected',\n            style: {\n                line: {\n                    color,\n                    width: lineWidth,\n                    dash: 1,\n                },\n            },\n        },\n        {\n            name: 'selected',\n            style: {\n                line: {\n                    color,\n                    width: lineWidth + 2,\n                    dash: 1,\n                },\n            },\n        },\n    ];\n    serie.name = spectrum.label || spectrum.id;\n}\n//# sourceMappingURL=addStyle.js.map","export const COLORS = [\n    '#FFB300',\n    '#803E75',\n    '#FF6800',\n    '#A6BDD7',\n    '#C10020',\n    '#CEA262',\n    '#817066',\n    '#007D34',\n    '#F6768E',\n    '#00538A',\n    '#FF7A5C',\n    '#53377A',\n    '#FF8E00',\n    '#B32851',\n    '#F4C800',\n    '#7F180D',\n    '#93AA00',\n    '#593315',\n    '#F13A13',\n    '#232C16',\n];\n//# sourceMappingURL=colors.js.map","const defaultBoundary = { y: { min: '0px', max: '2000px' } };\nexport function getNormalizationAnnotations(filter = {}, boundary = defaultBoundary) {\n    let { exclusions = [] } = filter;\n    let annotations = [];\n    exclusions = exclusions.filter((exclusion) => !exclusion.ignore);\n    annotations = exclusions.map((exclusion) => {\n        const annotation = {\n            type: 'rect',\n            position: [\n                { x: exclusion.from, y: boundary.y.min },\n                { x: exclusion.to, y: boundary.y.max },\n            ],\n            strokeWidth: 0,\n            fillColor: 'rgba(255,255,224,1)',\n        };\n        return annotation;\n    });\n    if (filter.from !== undefined) {\n        annotations.push({\n            type: 'rect',\n            position: [\n                { x: Number.MIN_SAFE_INTEGER, y: boundary.y.min },\n                { x: filter.from, y: boundary.y.max },\n            ],\n            strokeWidth: 0,\n            fillColor: 'rgba(255,255,224,1)',\n        });\n    }\n    if (filter.to !== undefined) {\n        annotations.push({\n            type: 'rect',\n            position: [\n                { x: filter.to, y: boundary.y.min },\n                { x: Number.MAX_SAFE_INTEGER, y: boundary.y.max },\n            ],\n            strokeWidth: 0,\n            fillColor: 'rgba(255,255,224,1)',\n        });\n    }\n    return annotations;\n}\n//# sourceMappingURL=getNormalizationAnnotations.js.map","// Based on https://github.com/scijs/cholesky-solve\n\n/*\nThe MIT License (MIT)\n\nCopyright (c) 2013 Eric Arnebäck\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n\nfunction ldlSymbolic(\n  n /* A and L are n-by-n, where n >= 0 */,\n  Ap /* input of size n + 1, not modified */,\n  Ai /* input of size nz=Ap[n], not modified */,\n  Lp /* output of size n + 1, not defined on input */,\n  Parent /* output of size n, not defined on input */,\n  Lnz /* output of size n, not defined on input */,\n  Flag /* workspace of size n, not defn. on input or output */,\n) {\n  let i, k, p, kk, p2;\n\n  for (k = 0; k < n; k++) {\n    /* L(k,:) pattern: all nodes reachable in etree from nz in A(0:k-1,k) */\n    Parent[k] = -1; /* parent of k is not yet known */\n    Flag[k] = k; /* mark node k as visited */\n    Lnz[k] = 0; /* count of nonzeros in column k of L */\n    kk = k; /* kth original, or permuted, column */\n    p2 = Ap[kk + 1];\n    for (p = Ap[kk]; p < p2; p++) {\n      /* A (i,k) is nonzero (original or permuted A) */\n      i = Ai[p];\n\n      if (i < k) {\n        /* follow path from i to root of etree, stop at flagged node */\n        for (; Flag[i] !== k; i = Parent[i]) {\n          /* find parent of i if not yet determined */\n          if (Parent[i] === -1) Parent[i] = k;\n          Lnz[i]++; /* L (k,i) is nonzero */\n          Flag[i] = k; /* mark i as visited */\n        }\n      }\n    }\n  }\n  /* construct Lp index array from Lnz column counts */\n  Lp[0] = 0;\n  for (k = 0; k < n; k++) {\n    Lp[k + 1] = Lp[k] + Lnz[k];\n  }\n}\n\nfunction ldlNumeric(\n  n /* A and L are n-by-n, where n >= 0 */,\n  Ap /* input of size n+1, not modified */,\n  Ai /* input of size nz=Ap[n], not modified */,\n  Ax /* input of size nz=Ap[n], not modified */,\n  Lp /* input of size n+1, not modified */,\n  Parent /* input of size n, not modified */,\n  Lnz /* output of size n, not defn. on input */,\n  Li /* output of size lnz=Lp[n], not defined on input */,\n  Lx /* output of size lnz=Lp[n], not defined on input */,\n  D /* output of size n, not defined on input */,\n  Y /* workspace of size n, not defn. on input or output */,\n  Pattern /* workspace of size n, not defn. on input or output */,\n  Flag /* workspace of size n, not defn. on input or output */,\n) {\n  let yi, lKi;\n  let i, k, p, kk, p2, len, top;\n  for (k = 0; k < n; k++) {\n    /* compute nonzero Pattern of kth row of L, in topological order */\n    Y[k] = 0.0; /* Y(0:k) is now all zero */\n    top = n; /* stack for pattern is empty */\n    Flag[k] = k; /* mark node k as visited */\n    Lnz[k] = 0; /* count of nonzeros in column k of L */\n    kk = k; /* kth original, or permuted, column */\n    p2 = Ap[kk + 1];\n    for (p = Ap[kk]; p < p2; p++) {\n      i = Ai[p]; /* get A(i,k) */\n      if (i <= k) {\n        Y[i] += Ax[p]; /* scatter A(i,k) into Y (sum duplicates) */\n        for (len = 0; Flag[i] !== k; i = Parent[i]) {\n          Pattern[len++] = i; /* L(k,i) is nonzero */\n          Flag[i] = k; /* mark i as visited */\n        }\n        while (len > 0) Pattern[--top] = Pattern[--len];\n      }\n    }\n    /* compute numerical values kth row of L (a sparse triangular solve) */\n    D[k] = Y[k]; /* get D(k,k) and clear Y(k) */\n    Y[k] = 0.0;\n    for (; top < n; top++) {\n      i = Pattern[top]; /* Pattern[top:n-1] is pattern of L(:,k) */\n      yi = Y[i]; /* get and clear Y(i) */\n      Y[i] = 0.0;\n      p2 = Lp[i] + Lnz[i];\n      for (p = Lp[i]; p < p2; p++) {\n        Y[Li[p]] -= Lx[p] * yi;\n      }\n      lKi = yi / D[i]; /* the nonzero entry L(k,i) */\n      D[k] -= lKi * yi;\n      Li[p] = k; /* store L(k,i) in column form of L */\n      Lx[p] = lKi;\n      Lnz[i]++; /* increment count of nonzeros in col i */\n    }\n\n    if (D[k] === 0.0) return k; /* failure, D(k,k) is zero */\n  }\n\n  return n; /* success, diagonal of D is all nonzero */\n}\n\nfunction ldlLsolve(\n  n /* L is n-by-n, where n >= 0 */,\n  X /* size n. right-hand-side on input, soln. on output */,\n  Lp /* input of size n+1, not modified */,\n  Li /* input of size lnz=Lp[n], not modified */,\n  Lx /* input of size lnz=Lp[n], not modified */,\n) {\n  let j, p, p2;\n  for (j = 0; j < n; j++) {\n    p2 = Lp[j + 1];\n    for (p = Lp[j]; p < p2; p++) {\n      X[Li[p]] -= Lx[p] * X[j];\n    }\n  }\n}\n\nfunction ldlDsolve(\n  n /* D is n-by-n, where n >= 0 */,\n  X /* size n. right-hand-side on input, soln. on output */,\n  D /* input of size n, not modified */,\n) {\n  let j;\n  for (j = 0; j < n; j++) {\n    X[j] /= D[j];\n  }\n}\n\nfunction ldlLTsolve(\n  n /* L is n-by-n, where n >= 0 */,\n  X /* size n. right-hand-side on input, soln. on output */,\n  Lp /* input of size n+1, not modified */,\n  Li /* input of size lnz=Lp[n], not modified */,\n  Lx /* input of size lnz=Lp[n], not modified */,\n) {\n  let j, p, p2;\n  for (j = n - 1; j >= 0; j--) {\n    p2 = Lp[j + 1];\n    for (p = Lp[j]; p < p2; p++) {\n      X[j] -= Lx[p] * X[Li[p]];\n    }\n  }\n}\n\nfunction ldlPerm(\n  n /* size of X, B, and P */,\n  X /* output of size n. */,\n  B /* input of size n. */,\n  P /* input permutation array of size n. */,\n) {\n  let j;\n  for (j = 0; j < n; j++) {\n    X[j] = B[P[j]];\n  }\n}\n\nfunction ldlPermt(\n  n /* size of X, B, and P */,\n  X /* output of size n. */,\n  B /* input of size n. */,\n  P /* input permutation array of size n. */,\n) {\n  let j;\n  for (j = 0; j < n; j++) {\n    X[P[j]] = B[j];\n  }\n}\n\nfunction prepare(M, n, P) {\n  // if a permutation was specified, apply it.\n  if (P) {\n    let Pinv = new Array(n);\n\n    for (let k = 0; k < n; k++) {\n      Pinv[P[k]] = k;\n    }\n\n    let Mt = []; // scratch memory\n    // Apply permutation. We make M into P*M*P^T\n    for (let a = 0; a < M.length; ++a) {\n      let ar = Pinv[M[a][0]];\n      let ac = Pinv[M[a][1]];\n\n      // we only store the upper-diagonal elements(since we assume matrix is symmetric, we only need to store these)\n      // if permuted element is below diagonal, we simply transpose it.\n      if (ac < ar) {\n        let t = ac;\n        ac = ar;\n        ar = t;\n      }\n\n      Mt[a] = [];\n      Mt[a][0] = ar;\n      Mt[a][1] = ac;\n      Mt[a][2] = M[a][2];\n    }\n\n    M = Mt; // copy scratch memory.\n  } else {\n    // if P argument is null, we just use an identity permutation.\n    P = [];\n    for (let i = 0; i < n; ++i) {\n      P[i] = i;\n    }\n  }\n\n  // The sparse matrix we are decomposing is A.\n  // Now we shall create A from M.\n  let Ap = new Array(n + 1);\n  let Ai = new Array(M.length);\n  let Ax = new Array(M.length);\n\n  // count number of non-zero elements in columns.\n  let LNZ = [];\n  for (let i = 0; i < n; ++i) {\n    LNZ[i] = 0;\n  }\n  for (let a = 0; a < M.length; ++a) {\n    LNZ[M[a][1]]++;\n  }\n\n  Ap[0] = 0;\n  for (let i = 0; i < n; ++i) {\n    Ap[i + 1] = Ap[i] + LNZ[i];\n  }\n\n  let coloffset = [];\n  for (let a = 0; a < n; ++a) {\n    coloffset[a] = 0;\n  }\n\n  // go through all elements in M, and add them to sparse matrix A.\n  for (let i = 0; i < M.length; ++i) {\n    let e = M[i];\n    let col = e[1];\n\n    let adr = Ap[col] + coloffset[col];\n    Ai[adr] = e[0];\n    Ax[adr] = e[2];\n\n    coloffset[col]++;\n  }\n\n  let D = new Array(n);\n  let Y = new Array(n);\n  let Lp = new Array(n + 1);\n  let Parent = new Array(n);\n  let Lnz = new Array(n);\n  let Flag = new Array(n);\n  let Pattern = new Array(n);\n  let bp1 = new Array(n);\n  let x = new Array(n);\n  let d;\n\n  ldlSymbolic(n, Ap, Ai, Lp, Parent, Lnz, Flag);\n\n  let Lx = new Array(Lp[n]);\n  let Li = new Array(Lp[n]);\n\n  d = ldlNumeric(n, Ap, Ai, Ax, Lp, Parent, Lnz, Li, Lx, D, Y, Pattern, Flag);\n\n  if (d === n) {\n    return (b) => {\n      ldlPerm(n, bp1, b, P);\n      ldlLsolve(n, bp1, Lp, Li, Lx);\n      ldlDsolve(n, bp1, D);\n      ldlLTsolve(n, bp1, Lp, Li, Lx);\n      ldlPermt(n, x, bp1, P);\n\n      return x;\n    };\n  } else {\n    return null;\n  }\n}\n\nexport { prepare as default };\n","'use strict'\n\nmodule.exports = cuthillMckee\n\nfunction compareNum(a, b) { return a - b }\n\nfunction cuthillMckee(list, n) {\n  var adj = new Array(n)\n  var visited = new Array(n)\n  for(var i=0; i<n; ++i) {\n    adj[i]     = []\n    visited[i] = false\n  }\n\n  for(var i=0; i<list.length; ++i) {\n    var l = list[i]\n    adj[l[0]].push(l[1])\n  }\n\n  var toVisit = new Array(n)\n  var eol = 0\n  var ptr = 0\n  for(var i=0; i<n; ++i) {\n    if(visited[i]) {\n      continue\n    }\n    toVisit[eol++] = i\n    visited[i] = true\n    while(ptr < eol) {\n      var v = toVisit[ptr++]\n      var nbhd = adj[v]\n      nbhd.sort(compareNum)\n      for(var j=0; j<nbhd.length; ++j) {\n        var u = nbhd[j]\n        if(visited[u]) {\n          continue\n        }\n        visited[u] = true\n        toVisit[eol++] = u\n      }\n    }\n  }\n\n  var result = new Array(n)\n  for(var i=0; i<n; ++i) {\n    result[toVisit[i]] = i\n  }\n\n  return result\n}\n","import cuthillMckee from 'cuthill-mckee';\n\nconst getClosestNumber = (array = [], goal = 0) => {\n  const closest = array.reduce((prev, curr) => {\n    return Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev;\n  });\n  return closest;\n};\n\nconst getCloseIndex = (array = [], goal = 0) => {\n  const closest = getClosestNumber(array, goal);\n  return array.indexOf(closest);\n};\n\nconst updateSystem = (matrix, y, weights) => {\n  let nbPoints = y.length;\n  let l = nbPoints - 1;\n  let newMatrix = new Array(matrix.length);\n  let newVector = new Float64Array(nbPoints);\n  for (let i = 0; i < l; i++) {\n    let w = weights[i];\n    let diag = i * 2;\n    let next = diag + 1;\n    newMatrix[diag] = matrix[diag].slice();\n    newMatrix[next] = matrix[next].slice();\n    if (w === 0) {\n      newVector[i] = 0;\n    } else {\n      newVector[i] = y[i] * w;\n      newMatrix[diag][2] += w;\n    }\n  }\n  newVector[l] = y[l] * weights[l];\n  newMatrix[l * 2] = matrix[l * 2].slice();\n  newMatrix[l * 2][2] += weights[l];\n\n  return [newMatrix, newVector];\n};\n\nconst getDeltaMatrix = (nbPoints, lambda) => {\n  let matrix = [];\n  let last = nbPoints - 1;\n  for (let i = 0; i < last; i++) {\n    matrix.push([i, i, lambda * 2]);\n    matrix.push([i + 1, i, -1 * lambda]);\n  }\n  matrix[0][2] = lambda;\n  matrix.push([last, last, lambda]);\n  return {\n    lowerTriangularNonZeros: matrix,\n    permutationEncodedArray: cuthillMckee(matrix, nbPoints),\n  };\n};\n\nexport { updateSystem, getDeltaMatrix, getCloseIndex, getClosestNumber };\n","import { xMultiply, xNoiseSanPlot, xAbsoluteSum } from 'ml-spectra-processing';\n\nimport cholesky from './choleskySolver';\nimport { updateSystem, getDeltaMatrix, getCloseIndex } from './utils';\n\nfunction getControlPoints(x, y, options = {}) {\n  const { length } = x;\n  let { controlPoints = Int8Array.from({ length }).fill(0) } = options;\n  const { zones = [], weights = Float64Array.from({ length }).fill(1) } =\n    options;\n\n  if (x.length !== y.length) {\n    throw new RangeError('Y should match the length with X');\n  } else if (controlPoints.length !== x.length) {\n    throw new RangeError('controlPoints should match the length with X');\n  } else if (weights.length !== x.length) {\n    throw new RangeError('weights should match the length with X');\n  }\n\n  zones.forEach((range) => {\n    let indexFrom = getCloseIndex(x, range.from);\n    let indexTo = getCloseIndex(x, range.to);\n    if (indexFrom > indexTo) [indexFrom, indexTo] = [indexTo, indexFrom];\n    for (let i = indexFrom; i < indexTo; i++) {\n      controlPoints[i] = 1;\n    }\n  });\n\n  return {\n    weights:\n      'controlPoints' in options || zones.length > 0\n        ? xMultiply(weights, controlPoints)\n        : weights,\n    controlPoints,\n  };\n}\n\n/**\n * Fit the baseline drift by iteratively changing weights of sum square error between the fitted baseline and original signals,\n * for further information about the parameters you can get the [paper of airPLS](https://github.com/zmzhang/airPLS/blob/main/airPLS_manuscript.pdf)\n * @param {Array<number>} x - x axis data useful when control points or zones are submitted\n * @param {Array<number>} y - Original data\n * @param {object} [options={}] - Options object\n * @param {number} [options.maxIterations = 100] - Maximal number of iterations if the method does not reach the stop criterion\n * @param {number} [options.tolerance = 0.001] - Factor of the sum of absolute value of original data, to compute stop criterion\n * @param {Array<number>} [options.weights = [1,1,...]] - Initial weights vector, default each point has the same weight\n * @param {number} [options.lambda = 100] - Factor of weights matrix in -> [I + lambda D'D]z = x\n * @param {Array<number>} [options.controlPoints = []] - Array of 0|1 to force the baseline cross those points.\n * @param {Array<number>} [options.zones = []] - Array of x axis values (as from - to), to force that baseline cross those zones.\n * @returns {{corrected: Array<number>, error: number, iteration: number, baseline: Array<number>}}\n */\n\nexport default function airPLS(x, y, options = {}) {\n  const { weights, controlPoints } = getControlPoints(x, y, options);\n  let { maxIterations = 100, lambda = 10, tolerance = 0.001 } = options;\n\n  let baseline, iteration;\n  let sumNegDifferences = Number.MAX_SAFE_INTEGER;\n  const corrected = Float64Array.from(y);\n  let stopCriterion = getStopCriterion(y, tolerance);\n\n  const { length } = y;\n  let { lowerTriangularNonZeros, permutationEncodedArray } = getDeltaMatrix(\n    length,\n    lambda,\n  );\n\n  let threshold = 1;\n  const l = length - 1;\n  let prevNegSum = Number.MAX_SAFE_INTEGER;\n  for (\n    iteration = 0;\n    iteration < maxIterations && Math.abs(sumNegDifferences) > stopCriterion;\n    iteration++\n  ) {\n    let [leftHandSide, rightHandSide] = updateSystem(\n      lowerTriangularNonZeros,\n      y,\n      weights,\n    );\n\n    let cho = cholesky(leftHandSide, length, permutationEncodedArray);\n\n    baseline = cho(rightHandSide);\n\n    sumNegDifferences = applyCorrection(y, baseline, corrected);\n    if (iteration === 1) {\n      const { positive } = xNoiseSanPlot(corrected);\n      threshold = positive;\n    } else {\n      const absChange = Math.abs(prevNegSum / sumNegDifferences);\n      if (absChange < 1.01 && absChange > 0.99) {\n        break;\n      }\n    }\n\n    prevNegSum = sumNegDifferences + 0;\n    for (let i = 1; i < l; i++) {\n      const diff = corrected[i];\n      if (controlPoints[i] < 1 && Math.abs(diff) > threshold) {\n        weights[i] = 0;\n      } else {\n        const factor = diff > 0 ? -1 : 1;\n        weights[i] = Math.exp(\n          (factor * (iteration * diff)) / Math.abs(sumNegDifferences),\n        );\n      }\n    }\n\n    weights[0] = 1;\n    weights[l] = 1;\n  }\n\n  return {\n    corrected,\n    baseline,\n    iteration,\n    error: sumNegDifferences,\n  };\n\n  function applyCorrection(y, baseline, corrected) {\n    let sumNegDifferences = 0;\n    for (let i = 0; i < y.length; i++) {\n      let diff = y[i] - baseline[i];\n      if (diff < 0) sumNegDifferences += diff;\n      corrected[i] = diff;\n    }\n\n    return sumNegDifferences;\n  }\n}\n\nfunction getStopCriterion(y, tolerance) {\n  let sum = xAbsoluteSum(y);\n  return tolerance * sum;\n}\n","import { xCheck } from \"./xCheck.js\";\nimport { xGetFromToIndex } from \"./xGetFromToIndex.js\";\nexport function xAbsoluteSum(array, options = {}) {\n    xCheck(array);\n    const { fromIndex, toIndex } = xGetFromToIndex(array, options);\n    let sum = 0;\n    for (let i = fromIndex; i <= toIndex; i++) {\n        sum += Math.abs(array[i]);\n    }\n    return sum;\n}\n//# sourceMappingURL=xAbsoluteSum.js.map","import { isAnyArray } from 'is-any-array';\n\nfunction _typeof(obj) {\n  \"@babel/helpers - typeof\";\n\n  if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n    _typeof = function (obj) {\n      return typeof obj;\n    };\n  } else {\n    _typeof = function (obj) {\n      return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n    };\n  }\n\n  return _typeof(obj);\n}\n\n/**\n * Fill an array with sequential numbers\n * @param {Array<number>} [input] - optional destination array (if not provided a new array will be created)\n * @param {object} [options={}]\n * @param {number} [options.from=0] - first value in the array\n * @param {number} [options.to=10] - last value in the array\n * @param {number} [options.size=input.length] - size of the array (if not provided calculated from step)\n * @param {number} [options.step] - if not provided calculated from size\n * @return {Array<number>}\n */\n\nfunction sequentialFill() {\n  var input = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];\n  var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n\n  if (_typeof(input) === 'object' && !isAnyArray(input)) {\n    options = input;\n    input = [];\n  }\n\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  var _options = options,\n      _options$from = _options.from,\n      from = _options$from === void 0 ? 0 : _options$from,\n      _options$to = _options.to,\n      to = _options$to === void 0 ? 10 : _options$to,\n      _options$size = _options.size,\n      size = _options$size === void 0 ? input.length : _options$size,\n      step = _options.step;\n\n  if (size !== 0 && step) {\n    throw new Error('step is defined by the array size');\n  }\n\n  if (!size) {\n    if (step) {\n      size = Math.floor((to - from) / step) + 1;\n    } else {\n      size = to - from + 1;\n    }\n  }\n\n  if (!step && size) {\n    step = (to - from) / (size - 1);\n  }\n\n  if (Array.isArray(input)) {\n    // only works with normal array\n    input.length = 0;\n\n    for (var i = 0; i < size; i++) {\n      input.push(from);\n      from += step;\n    }\n  } else {\n    if (input.length !== size) {\n      throw new Error('sequentialFill typed array must have the correct length');\n    }\n\n    for (var _i = 0; _i < size; _i++) {\n      input[_i] = from;\n      from += step;\n    }\n  }\n\n  return input;\n}\n\nexport { sequentialFill as default };\n","import { isAnyArray } from 'is-any-array';\n/**\n * Check that x and y are arrays with the same length.\n * @param x - first array\n * @param y - second array\n * @throws if x or y are not the same length, or if they are not arrays\n */\nexport function checkArrayLength(x, y) {\n    if (!isAnyArray(x) || !isAnyArray(y)) {\n        throw new TypeError('x and y must be arrays');\n    }\n    if (x.length !== y.length) {\n        throw new RangeError('x and y arrays must have the same length');\n    }\n}\n//# sourceMappingURL=checkArrayLength.js.map","import { isAnyArray } from 'is-any-array';\nimport { checkArrayLength } from './checkArrayLength';\nexport class BaseRegression {\n    constructor() {\n        if (new.target === BaseRegression) {\n            throw new Error('BaseRegression must be subclassed');\n        }\n    }\n    predict(x) {\n        if (typeof x === 'number') {\n            return this._predict(x);\n        }\n        else if (isAnyArray(x)) {\n            const y = [];\n            for (const xVal of x) {\n                y.push(this._predict(xVal));\n            }\n            return y;\n        }\n        else {\n            throw new TypeError('x must be a number or array');\n        }\n    }\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    _predict(x) {\n        throw new Error('_predict must be implemented');\n    }\n    train() {\n        // Do nothing for this package\n    }\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    toString(precision) {\n        return '';\n    }\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    toLaTeX(precision) {\n        return '';\n    }\n    /**\n     * Return the correlation coefficient of determination (r) and chi-square.\n     * @param x - explanatory variable\n     * @param y - response variable\n     * @return - Object with further statistics.\n     */\n    score(x, y) {\n        checkArrayLength(x, y);\n        const n = x.length;\n        const y2 = new Array(n);\n        for (let i = 0; i < n; i++) {\n            y2[i] = this._predict(x[i]);\n        }\n        let xSum = 0;\n        let ySum = 0;\n        let chi2 = 0;\n        let rmsd = 0;\n        let xSquared = 0;\n        let ySquared = 0;\n        let xY = 0;\n        for (let i = 0; i < n; i++) {\n            xSum += y2[i];\n            ySum += y[i];\n            xSquared += y2[i] * y2[i];\n            ySquared += y[i] * y[i];\n            xY += y2[i] * y[i];\n            if (y[i] !== 0) {\n                chi2 += ((y[i] - y2[i]) * (y[i] - y2[i])) / y[i];\n            }\n            rmsd += (y[i] - y2[i]) * (y[i] - y2[i]);\n        }\n        const r = (n * xY - xSum * ySum) /\n            Math.sqrt((n * xSquared - xSum * xSum) * (n * ySquared - ySum * ySum));\n        return {\n            r,\n            r2: r * r,\n            chi2,\n            rmsd: Math.sqrt(rmsd / n),\n        };\n    }\n}\n//# sourceMappingURL=BaseRegression.js.map","/**\n * Cast `number` to string. Optionally `digits` specifies significant figures.\n * @param number\n * @param figures\n * @returns - A string representation of `number`.\n */\nexport function maybeToPrecision(number, figures) {\n    if (number < 0) {\n        number = 0 - number;\n        if (typeof figures === 'number') {\n            return `- ${number.toPrecision(figures)}`;\n        }\n        else {\n            return `- ${number.toString()}`;\n        }\n    }\n    else if (typeof figures === 'number') {\n        return number.toPrecision(figures);\n    }\n    else {\n        return number.toString();\n    }\n}\n//# sourceMappingURL=maybeToPrecision.js.map","import { Matrix, MatrixTransposeView, solve } from 'ml-matrix';\nimport { BaseRegression, checkArrayLength, maybeToPrecision, } from 'ml-regression-base';\nexport class PolynomialRegression extends BaseRegression {\n    /**\n     * @param x - independent or explanatory variable\n     * @param y - dependent or response variable\n     * @param degree - degree of the polynomial regression, or array of powers to be used. When degree is an array, intercept at zero is forced to false/ignored.\n     * @example `new PolynomialRegression(x, y, 2)`, in this case, you can pass the option `interceptAtZero`, if you need it.\n     * @param options\n     * @example `new PolynomialRegression(x, y, [1, 3, 5])`\n     * Each of the degrees corresponds to a column, so if you have them switched, just do:\n     * @example `new PolynomialRegression(x, y, [3, 1, 5])`\n     * @param options.interceptAtZero - force the polynomial regression so that f(0) = 0\n     */\n    constructor(x, y, degree, options = {}) {\n        super();\n        // @ts-expect-error internal use only\n        if (x === true) {\n            // @ts-expect-error internal use only\n            this.degree = y.degree;\n            // @ts-expect-error internal use only\n            this.powers = y.powers;\n            // @ts-expect-error internal use only\n            this.coefficients = y.coefficients;\n        }\n        else {\n            checkArrayLength(x, y);\n            const result = regress(x, y, degree, options);\n            this.degree = result.degree;\n            this.powers = result.powers;\n            this.coefficients = result.coefficients;\n        }\n    }\n    _predict(x) {\n        let y = 0;\n        for (let k = 0; k < this.powers.length; k++) {\n            y += this.coefficients[k] * x ** this.powers[k];\n        }\n        return y;\n    }\n    toJSON() {\n        return {\n            name: 'polynomialRegression',\n            degree: this.degree,\n            powers: this.powers,\n            coefficients: this.coefficients,\n        };\n    }\n    toString(precision) {\n        return this._toFormula(precision, false);\n    }\n    toLaTeX(precision) {\n        return this._toFormula(precision, true);\n    }\n    _toFormula(precision, isLaTeX) {\n        let sup = '^';\n        let closeSup = '';\n        let times = ' * ';\n        if (isLaTeX) {\n            sup = '^{';\n            closeSup = '}';\n            times = '';\n        }\n        let fn = '';\n        let str = '';\n        for (let k = 0; k < this.coefficients.length; k++) {\n            str = '';\n            if (this.coefficients[k] !== 0) {\n                if (this.powers[k] === 0) {\n                    str = maybeToPrecision(this.coefficients[k], precision);\n                }\n                else if (this.powers[k] === 1) {\n                    str = `${maybeToPrecision(this.coefficients[k], precision) + times}x`;\n                }\n                else {\n                    str = `${maybeToPrecision(this.coefficients[k], precision) + times}x${sup}${this.powers[k]}${closeSup}`;\n                }\n                if (this.coefficients[k] > 0 && k !== this.coefficients.length - 1) {\n                    str = ` + ${str}`;\n                }\n                else if (k !== this.coefficients.length - 1) {\n                    str = ` ${str}`;\n                }\n            }\n            fn = str + fn;\n        }\n        if (fn.startsWith('+')) {\n            fn = fn.slice(1);\n        }\n        return `f(x) = ${fn}`;\n    }\n    static load(json) {\n        if (json.name !== 'polynomialRegression') {\n            throw new TypeError('not a polynomial regression model');\n        }\n        // @ts-expect-error internal use only\n        return new PolynomialRegression(true, json);\n    }\n}\n/**\n * Perform a polynomial regression on the given data set.\n * This is an internal function.\n * @param x - independent or explanatory variable\n * @param y - dependent or response variable\n * @param degree - degree of the polynomial regression\n * @param options.interceptAtZero - force the polynomial regression so that $f(0) = 0$\n * @param options\n */\nfunction regress(x, y, degree, options = {}) {\n    const n = x.length;\n    let { interceptAtZero = false } = options;\n    let powers = [];\n    if (Array.isArray(degree)) {\n        powers = degree;\n        interceptAtZero = false; //must be false in this case\n    }\n    else if (typeof degree === 'number') {\n        if (interceptAtZero) {\n            powers = new Array(degree);\n            for (let k = 0; k < degree; k++) {\n                powers[k] = k + 1;\n            }\n        }\n        else {\n            powers = new Array(degree + 1);\n            for (let k = 0; k <= degree; k++) {\n                powers[k] = k;\n            }\n        }\n    }\n    const nCoefficients = powers.length; //1 per power, in any case.\n    const F = new Matrix(n, nCoefficients);\n    const Y = new Matrix([y]);\n    for (let k = 0; k < nCoefficients; k++) {\n        for (let i = 0; i < n; i++) {\n            if (powers[k] === 0) {\n                F.set(i, k, 1);\n            }\n            else {\n                F.set(i, k, x[i] ** powers[k]);\n            }\n        }\n    }\n    const FT = new MatrixTransposeView(F);\n    const A = FT.mmul(F);\n    const B = FT.mmul(new MatrixTransposeView(Y));\n    return {\n        coefficients: solve(A, B).to1DArray(),\n        degree: Math.max(...powers),\n        powers,\n    };\n}\n//# sourceMappingURL=index.js.map","import sequentialFill from 'ml-array-sequential-fill';\nimport { baselineCorrectionRegression } from 'ml-baseline-correction-regression';\n\n/**\n * Iterative polynomial fitting [1]\n *\n * Implementation based on ml-baseline-correction-regression\n *\n * References:\n * [1] Gan, F.; Ruan, G.; Mo, J.\n * Baseline Correction by Improved Iterative Polynomial Fitting with Automatic Threshold.\n *  Chemometrics and Intelligent Laboratory Systems 2006, 82 (1), 59–65.\n * https://doi.org/10.1016/j.chemolab.2005.08.009.\n * @export\n * @param {Array<number>} ys\n * @param {object} [options] - Options object\n * @param {Array<number>} [options.x] Optional, Independent axis variable. If not specified, we use a linear grid\n * @param {Object} [options.regression]\n * @param {number} [options.regression.maxIterations = 100] - Maximum number of allowed iterations\n * @param {Object} [options.regression]\n * @param {function} [options.regression.Regression = PolynomialRegression] - Regression class with a predict method\n * @param {Object} [options.regression.regressionOptions] - Options for regressionFunction\n * @param {number} [options.regression.tolerance = 0.001] - Convergence error tolerance\n * @returns {BaselineOutput}\n */\nexport function iterativePolynomialBaseline(ys, options = {}) {\n  const numberPoints = ys.length;\n  let { x, regressionOptions } = options;\n  if (!x) {\n    x = sequentialFill({ from: 0, to: numberPoints - 1, size: numberPoints });\n  }\n\n  let output = baselineCorrectionRegression(x, ys, regressionOptions);\n\n  return { baseline: output.baseline, correctedSpectrum: output.corrected };\n}\n","import { PolynomialRegression } from 'ml-regression-polynomial';\n\n/**\n * Iterative regression-based baseline correction\n * @param {Array<number>} x - Independent axis variable\n * @param {Array<number>} y - Dependent axis variable\n * @param {object} [options] - Options object\n * @param {number} [options.maxIterations = 100] - Maximum number of allowed iterations\n * @param {function} [options.Regression = PolynomialRegression] - Regression class with a predict method\n * @param {*} [options.regressionOptions] - Options for regressionFunction\n * @param {number} [options.tolerance = 0.001] - Convergence error tolerance\n * @return {{corrected: Array<number>, delta: number, iteration: number, baseline: Array<number>}}\n */\nexport function baselineCorrectionRegression(x, y, options = {}) {\n  let {\n    maxIterations = 100,\n    Regression = PolynomialRegression,\n    regressionOptions,\n    tolerance = 0.001,\n  } = options;\n\n  if (!regressionOptions && Regression === PolynomialRegression) {\n    regressionOptions = 3;\n  }\n\n  let baseline = y.slice();\n  let fitting = y.slice();\n  let oldFitting = y;\n  let iteration = 0;\n  let delta;\n  let regression;\n  while (iteration < maxIterations) {\n    // Calculate the fitting result\n    regression = new Regression(x, baseline, regressionOptions);\n\n    delta = 0;\n    for (let i = 0; i < baseline.length; i++) {\n      fitting[i] = regression.predict(x[i]);\n      if (baseline[i] > fitting[i]) {\n        baseline[i] = fitting[i];\n      }\n\n      delta += Math.abs((fitting[i] - oldFitting[i]) / oldFitting[i]);\n    }\n\n    // Stop criterion\n    if (delta < tolerance) {\n      break;\n    } else {\n      oldFitting = fitting.slice();\n      iteration++;\n    }\n  }\n\n  // removes baseline\n  let corrected = new Array(baseline.length);\n  for (let j = 0; j < baseline.length; j++) {\n    corrected[j] = y[j] - baseline[j];\n  }\n\n  return {\n    corrected,\n    delta,\n    iteration,\n    baseline,\n    regression,\n  };\n}\n","import { xRollingAverage } from 'ml-spectra-processing';\n\n/**\n\n *\n * @export\n * @param {Array<number>} ys\n * @param {Object} [options={}]\n * @param {number} [options.window] rolling window size, defaults to 10% of the length of the spectrum\n * @param {string} [options.padding.size=window-1] none, value, circular, duplicate\n * @param {string} [options.padding.algorithm='duplicate'] none, value, circular, duplicate\n * @param {number} [options.padding.value=0] value to use for padding (if algorithm='value')\n * @returns {BaselineOutput}\n */\nexport function rollingAverageBaseline(ys, options = {}) {\n  let window = Math.max(Math.round(ys.length * 0.1), 2);\n  let defaults = {\n    window,\n    padding: {\n      size: window - 1,\n      algorithm: 'duplicate',\n      value: 0,\n    },\n  };\n  let actualOptions = { ...defaults, ...options };\n  let baseline = xRollingAverage(ys, actualOptions);\n  let corrected = new Float64Array(ys.length);\n  for (let i = 0; i < corrected.length; i++) {\n    corrected[i] = ys[i] - baseline[i];\n  }\n\n  return { baseline, correctedSpectrum: corrected };\n}\n","import { xMean } from \"./xMean.js\";\nimport { xRolling } from \"./xRolling.js\";\n/**\n * This function calculates a rolling average\n * @param array - array\n * @param options - option\n */\nexport function xRollingAverage(array, options = {}) {\n    return xRolling(array, xMean, options);\n}\n//# sourceMappingURL=xRollingAverage.js.map","import { rollingBall } from 'ml-rolling-ball-baseline';\n\n/**\n * Rolling ball baseline correction algorithm.\n * From the abstract of (1):\n * \"This algorithm behaves equivalently to traditional polynomial backgrounds in simple spectra,\n * [...] and is considerably more robust for multiple overlapping peaks, rapidly varying background [...]\n *\n * The baseline is the trace one gets by rolling a ball below a spectrum. Algorithm has three steps:\n * Finding the minima in each window, find maxima among minima and then smooth over them by averaging.\n *\n * Algorithm described in (1), but in the implementation here the window width does not change.\n *\n * Reference:\n * (1) Kneen, M. A.; Annegarn, H. J.\n *     Algorithm for Fitting XRF, SEM and PIXE X-Ray Spectra Backgrounds.\n *     Nuclear Instruments and Methods in Physics Research Section B: Beam Interactions with Materials and Atoms 1996, 109–110, 209–213.\n *     https://doi.org/10.1016/0168-583X(95)00908-6.\n * (2) Kristian Hovde Liland, Bjørn-Helge Mevik, Roberto Canteri: baseline.\n *     https://cran.r-project.org/web/packages/baseline/index.html\n *\n * @export\n * @param {Array<number>} ys\n * @param {Object} [options={}]\n * @param {Number} [options.windowM] - width of local window for minimization/maximization, defaults to 4% of the spectrum length\n * @param {Number} [options.windowS] - width of local window for smoothing, defaults to 8% of the specturm length\n * @returns {BaselineOutput}\n */\nexport function rollingBallBaseline(ys, options = {}) {\n  const baseline = rollingBall(ys, options);\n  let corrected = new Float64Array(ys.length);\n  for (let i = 0; i < corrected.length; i++) {\n    corrected[i] = ys[i] - baseline[i];\n  }\n\n  return { baseline, correctedSpectrum: corrected };\n}\n","import { isAnyArray } from 'is-any-array';\nimport { xMean, xMaxValue, xMinValue } from 'ml-spectra-processing';\nexport function rollingBall(spectrum, options = {}) {\n    if (!isAnyArray(spectrum)) {\n        throw new Error('Spectrum must be an array');\n    }\n    if (spectrum.length === 0) {\n        throw new TypeError('Spectrum must not be empty');\n    }\n    const numberPoints = spectrum.length;\n    const maxima = new Float64Array(numberPoints);\n    const minima = new Float64Array(numberPoints);\n    const baseline = new Float64Array(numberPoints);\n    // windowM 4 percent of spectrum length\n    // windowS 8 percent of spectrum length\n    const { windowM = Math.round(numberPoints * 0.04), windowS = Math.round(numberPoints * 0.08), } = options;\n    // fi(1) in original paper\n    for (let i = 0; i < spectrum.length; i++) {\n        const windowLeft = Math.max(0, i - windowM);\n        const windowRight = Math.min(i + windowM + 1, spectrum.length);\n        minima[i] = xMinValue(spectrum, {\n            fromIndex: windowLeft,\n            toIndex: windowRight,\n        });\n    }\n    // fi in original paper\n    for (let i = 0; i < minima.length; i++) {\n        const windowLeft = Math.max(0, i - windowM);\n        const windowRight = Math.min(i + windowM + 1, minima.length);\n        maxima[i] = xMaxValue(minima, {\n            fromIndex: windowLeft,\n            toIndex: windowRight,\n        });\n    }\n    for (let i = 0; i < minima.length; i++) {\n        const windowLeft = Math.max(0, i - windowS);\n        const windowRight = Math.min(i + windowS + 1, maxima.length);\n        baseline[i] = xMean(maxima.subarray(windowLeft, windowRight));\n    }\n    return baseline;\n}\n//# sourceMappingURL=rollingBall.js.map","import { xRollingMedian } from 'ml-spectra-processing';\n\n/**\n\n *\n * @export\n * @param {Array<number>} ys\n * @param {Object} [options={}]\n * @param {number} [options.window] rolling window size, defaults to 10% of the length of the spectrum\n * @param {string} [options.padding.size=window-1] none, value, circular, duplicate\n * @param {string} [options.padding.algorithm='duplicate'] none, value, circular, duplicate\n * @param {number} [options.padding.value=0] value to use for padding (if algorithm='value')\n * @returns {BaselineOutput}\n */\nexport function rollingMedianBaseline(ys, options = {}) {\n  let window = Math.max(Math.round(ys.length * 0.1), 2);\n  let defaults = {\n    window,\n    padding: {\n      size: window - 1,\n      algorithm: 'duplicate',\n      value: 0,\n    },\n  };\n  let actualOptions = { ...defaults, ...options };\n  let baseline = xRollingMedian(ys, actualOptions);\n  let corrected = new Float64Array(ys.length);\n  for (let i = 0; i < corrected.length; i++) {\n    corrected[i] = ys[i] - baseline[i];\n  }\n\n  return { baseline, correctedSpectrum: corrected };\n}\n","import { xMedian } from \"./xMedian.js\";\nimport { xRolling } from \"./xRolling.js\";\n/**\n * This function calculates a rolling average\n * @param array - array\n * @param options - options\n */\nexport function xRollingMedian(array, options = {}) {\n    return xRolling(array, xMedian, options);\n}\n//# sourceMappingURL=xRollingMedian.js.map","import { isAnyArray } from 'is-any-array';\n/**\n * Apply Savitzky Golay algorithm\n * @param [ys] Array of y values\n * @param [xs] Array of X or deltaX\n * @return  Array containing the new ys (same length)\n */\nexport function sgg(ys, xs, options = {}) {\n    const { windowSize = 9, derivative = 0, polynomial = 3 } = options;\n    if (windowSize % 2 === 0 || windowSize < 5 || !Number.isInteger(windowSize)) {\n        throw new RangeError('Invalid window size (should be odd and at least 5 integer number)');\n    }\n    if (!isAnyArray(ys)) {\n        throw new TypeError('Y values must be an array');\n    }\n    if (typeof xs === 'undefined') {\n        throw new TypeError('X must be defined');\n    }\n    if (windowSize > ys.length) {\n        throw new RangeError(`Window size is higher than the data length ${windowSize}>${ys.length}`);\n    }\n    if (derivative < 0 || !Number.isInteger(derivative)) {\n        throw new RangeError('Derivative should be a positive integer');\n    }\n    if (polynomial < 1 || !Number.isInteger(polynomial)) {\n        throw new RangeError('Polynomial should be a positive integer');\n    }\n    if (polynomial >= 6) {\n        // eslint-disable-next-line no-console\n        console.warn('You should not use polynomial grade higher than 5 if you are' +\n            ' not sure that your data arises from such a model. Possible polynomial oscillation problems');\n    }\n    const half = Math.floor(windowSize / 2);\n    const np = ys.length;\n    const ans = new Float64Array(np);\n    const weights = fullWeights(windowSize, polynomial, derivative);\n    let hs = 0;\n    let constantH = true;\n    if (isAnyArray(xs)) {\n        constantH = false;\n    }\n    else {\n        hs = xs ** derivative;\n    }\n    //For the borders\n    for (let i = 0; i < half; i++) {\n        const wg1 = weights[half - i - 1];\n        const wg2 = weights[half + i + 1];\n        let d1 = 0;\n        let d2 = 0;\n        for (let l = 0; l < windowSize; l++) {\n            d1 += wg1[l] * ys[l];\n            d2 += wg2[l] * ys[np - windowSize + l];\n        }\n        if (constantH) {\n            ans[half - i - 1] = d1 / hs;\n            ans[np - half + i] = d2 / hs;\n        }\n        else {\n            hs = getHs(xs, half - i - 1, half, derivative);\n            ans[half - i - 1] = d1 / hs;\n            hs = getHs(xs, np - half + i, half, derivative);\n            ans[np - half + i] = d2 / hs;\n        }\n    }\n    //For the internal points\n    const wg = weights[half];\n    for (let i = windowSize; i <= np; i++) {\n        let d = 0;\n        for (let l = 0; l < windowSize; l++)\n            d += wg[l] * ys[l + i - windowSize];\n        if (!constantH) {\n            hs = getHs(xs, i - half - 1, half, derivative);\n        }\n        ans[i - half - 1] = d / hs;\n    }\n    return ans;\n}\nfunction getHs(h, center, half, derivative) {\n    let hs = 0;\n    let count = 0;\n    for (let i = center - half; i < center + half; i++) {\n        if (i >= 0 && i < h.length - 1) {\n            hs += h[i + 1] - h[i];\n            count++;\n        }\n    }\n    return (hs / count) ** derivative;\n}\nfunction gramPoly(i, m, k, s) {\n    let Grampoly = 0;\n    if (k > 0) {\n        Grampoly =\n            ((4 * k - 2) / (k * (2 * m - k + 1))) *\n                (i * gramPoly(i, m, k - 1, s) + s * gramPoly(i, m, k - 1, s - 1)) -\n                (((k - 1) * (2 * m + k)) / (k * (2 * m - k + 1))) *\n                    gramPoly(i, m, k - 2, s);\n    }\n    else if (k === 0 && s === 0) {\n        Grampoly = 1;\n    }\n    else {\n        Grampoly = 0;\n    }\n    return Grampoly;\n}\nfunction genFact(a, b) {\n    let gf = 1;\n    if (a >= b) {\n        for (let j = a - b + 1; j <= a; j++) {\n            gf *= j;\n        }\n    }\n    return gf;\n}\nfunction weight(i, t, m, n, s) {\n    let sum = 0;\n    for (let k = 0; k <= n; k++) {\n        sum +=\n            (2 * k + 1) *\n                (genFact(2 * m, k) / genFact(2 * m + k + 1, k + 1)) *\n                gramPoly(i, m, k, 0) *\n                gramPoly(t, m, k, s);\n    }\n    return sum;\n}\n/**\n * @private\n * @param m  Number of points\n * @param n  Polynomial grade\n * @param s  Derivative\n */\nfunction fullWeights(m, n, s) {\n    const weights = new Array(m);\n    const np = Math.floor(m / 2);\n    for (let t = -np; t <= np; t++) {\n        weights[t + np] = new Float64Array(m);\n        for (let j = -np; j <= np; j++) {\n            weights[t + np][j + np] = weight(j, t, np, n, s);\n        }\n    }\n    return weights;\n}\n//# sourceMappingURL=index.js.map","export function getMinMaxIntervalsDy(y, x, dY, dX) {\n    let lastMax = null;\n    let lastMin = null;\n    const intervalL = [];\n    const intervalR = [];\n    for (let i = 1; i < y.length - 1; ++i) {\n        if ((dY[i] < dY[i - 1] && dY[i] <= dY[i + 1]) ||\n            (dY[i] <= dY[i - 1] && dY[i] < dY[i + 1])) {\n            lastMin = {\n                x: x[i],\n                index: i,\n            };\n            if (dX > 0 && lastMax !== null) {\n                intervalL.push(lastMax);\n                intervalR.push(lastMin);\n            }\n        }\n        // Maximum in first derivative\n        if ((dY[i] >= dY[i - 1] && dY[i] > dY[i + 1]) ||\n            (dY[i] > dY[i - 1] && dY[i] >= dY[i + 1])) {\n            lastMax = {\n                x: x[i],\n                index: i,\n            };\n            if (dX < 0 && lastMin !== null) {\n                intervalL.push(lastMax);\n                intervalR.push(lastMin);\n            }\n        }\n    }\n    return { intervalL, intervalR };\n}\n//# sourceMappingURL=getMinMaxIntervals.js.map","export function tryMatchOneIntervalWithMinData(options) {\n    const { x, lastK, minData, yThreshold, intervalWidth, intervalCenter, yData, } = options;\n    let minDistance = Number.POSITIVE_INFINITY;\n    let possible = -1;\n    let newLastIndex = lastK;\n    for (let k = newLastIndex + 1; k < minData.length; k++) {\n        const centerIndex = minData[k];\n        if (yData[centerIndex] <= yThreshold) {\n            continue;\n        }\n        const deltaX = x[centerIndex];\n        const currentDistance = Math.abs(deltaX - intervalCenter);\n        if (currentDistance < intervalWidth) {\n            if (currentDistance < minDistance) {\n                possible = k;\n            }\n            newLastIndex = k;\n        }\n        if (currentDistance >= minDistance)\n            break;\n        minDistance = currentDistance;\n    }\n    return { lastIndex: newLastIndex, possible };\n}\n//# sourceMappingURL=tryMatchOneIntervalWithMinData.js.map","import { tryMatchOneIntervalWithMinData } from \"./tryMatchOneIntervalWithMinData.js\";\nexport function getPeakFromIntervals(options) {\n    let lastK = -1;\n    const peaks = [];\n    const { x, ddY, yData, yThreshold, intervalR, intervalL, minData } = options;\n    for (let i = 0; i < intervalL.length; i++) {\n        const intervalWidth = (intervalR[i].x - intervalL[i].x) / 2;\n        const intervalCenter = (intervalR[i].x + intervalL[i].x) / 2;\n        const { possible = -1, lastIndex } = tryMatchOneIntervalWithMinData({\n            x,\n            lastK,\n            minData,\n            yThreshold,\n            intervalWidth,\n            intervalCenter,\n            yData,\n        });\n        if (possible !== -1) {\n            const centerIndex = minData[possible];\n            const width = Math.abs(intervalR[i].x - intervalL[i].x);\n            peaks.push({\n                id: crypto.randomUUID(),\n                x: x[centerIndex],\n                y: yData[centerIndex],\n                width,\n                index: centerIndex,\n                ddY: ddY[centerIndex],\n                inflectionPoints: {\n                    from: intervalL[i],\n                    to: intervalR[i],\n                },\n            });\n        }\n        lastK = lastIndex;\n    }\n    return peaks;\n}\n//# sourceMappingURL=getPeaksFromIntervals.js.map","/**\n * Finds the indices where the first derivative crosses zero (sign change),\n * which are potential peak positions. This function does not detect zero-crossings\n * in regions with consecutive zero values in the derivative (flat regions).\n *\n * @param input - Object containing the y values and their first derivative (dY).\n * @returns Array of indices where the first derivative crosses zero (excluding consecutive zeros).\n */\nexport function xGetCrossZeroPoints(input) {\n    const { y, dY } = input;\n    const crossDy = [];\n    for (let i = 1; i < y.length - 1; ++i) {\n        if (isLessAndGreaterThanZero(dY[i], dY[i + 1])) {\n            // push the index of the element closer to zero\n            crossDy.push(Math.abs(dY[i]) < Math.abs(dY[i + 1]) ? i : i + 1);\n        }\n        else if (\n        // Handle exact zero\n        dY[i] === 0 &&\n            isLessAndGreaterThanZero(dY[i - 1], dY[i + 1])) {\n            crossDy.push(i);\n        }\n    }\n    return crossDy;\n}\nfunction isLessAndGreaterThanZero(back, next) {\n    return (back < 0 && next > 0) || (back > 0 && next < 0);\n}\n//# sourceMappingURL=xGetCrossZeroPoints.js.map","import { getMinMaxIntervalsDy } from \"./getMinMaxIntervals.js\";\nimport { getPeakFromIntervals } from \"./getPeaksFromIntervals.js\";\nimport { xGetCrossZeroPoints } from \"./xGetCrossZeroPoints.js\";\nexport function firstDerivative(input) {\n    const { y, x, dY, dX, yData, yThreshold, ddY } = input;\n    const crossDy = xGetCrossZeroPoints(input);\n    const { intervalL, intervalR } = getMinMaxIntervalsDy(y, x, dY, dX);\n    return getPeakFromIntervals({\n        minData: crossDy,\n        intervalL,\n        intervalR,\n        x,\n        yData,\n        yThreshold,\n        ddY,\n    });\n}\n//# sourceMappingURL=firstDerivative.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\nimport { xIsEquallySpaced, xIsMonotonic, xMinMaxValues, xNoiseStandardDeviation, } from 'ml-spectra-processing';\nimport { autoAlgorithm } from \"./algorithms/autoAlgorithm.js\";\nimport { firstDerivative } from \"./algorithms/firstDerivative.js\";\nimport { secondDerivative } from \"./algorithms/secondDerivative.js\";\nimport { optimizeTop } from \"./utils/optimizeTop.js\";\n/**\n * Global spectra deconvolution\n * @param  data - Object data with x and y arrays. Values in x has to be growing\n * @param options\n * @param {number} [options.broadRatio = 0.00] - If `broadRatio` is higher than 0, then all the peaks which second derivative\n * smaller than `broadRatio * maxAbsSecondDerivative` will be marked with the soft mask equal to true.\n */\nexport function gsd(data, options = {}) {\n    let { noiseLevel } = options;\n    const { sgOptions = {\n        windowSize: 9,\n        polynomial: 3,\n    }, smoothY = false, maxCriteria = true, minMaxRatio = 0.00025, realTopDetection = false, peakDetectionAlgorithm = 'second', } = options;\n    const { x } = data;\n    let { y } = data;\n    if (xIsMonotonic(x) !== 1) {\n        throw new Error('GSD only accepts monotone increasing x values');\n    }\n    //rescale;\n    y = y.slice();\n    // If the max difference between delta x is less than 5%, then,\n    // we can assume it to be equally spaced variable\n    const isEquallySpaced = xIsEquallySpaced(x);\n    if (noiseLevel === undefined) {\n        if (isEquallySpaced) {\n            const noiseInfo = xNoiseStandardDeviation(y);\n            if (maxCriteria) {\n                noiseLevel = noiseInfo.median + 1.5 * noiseInfo.sd;\n            }\n            else {\n                noiseLevel = -noiseInfo.median + 1.5 * noiseInfo.sd;\n            }\n        }\n        else {\n            noiseLevel = 0;\n        }\n    }\n    else if (!maxCriteria) {\n        noiseLevel *= -1;\n    }\n    if (!maxCriteria) {\n        for (let i = 0; i < y.length; i++) {\n            y[i] *= -1;\n        }\n    }\n    if (noiseLevel !== undefined) {\n        for (let i = 0; i < y.length; i++) {\n            if (y[i] < noiseLevel) {\n                y[i] = noiseLevel;\n            }\n        }\n    }\n    const xValue = isEquallySpaced ? x[1] - x[0] : x;\n    const yData = smoothY\n        ? sgg(y, xValue, {\n            ...sgOptions,\n            derivative: 0,\n        })\n        : y;\n    const { min: minY, max: maxY } = xMinMaxValues(yData);\n    if (minY > maxY || minY === maxY)\n        return [];\n    const dY = sgg(y, xValue, {\n        ...sgOptions,\n        derivative: 1,\n    });\n    const ddY = sgg(y, xValue, {\n        ...sgOptions,\n        derivative: 2,\n    });\n    const yThreshold = Math.max(noiseLevel, minY + (maxY - minY) * minMaxRatio);\n    const dX = x[1] - x[0];\n    const peakData = { x, y, yData, dY, ddY, dX, yThreshold };\n    let peaks = [];\n    if (peakDetectionAlgorithm === 'first') {\n        peaks = firstDerivative(peakData);\n    }\n    else if (peakDetectionAlgorithm === 'second') {\n        peaks = secondDerivative(peakData);\n    }\n    else {\n        peaks = autoAlgorithm(peakData);\n    }\n    if (realTopDetection) {\n        optimizeTop({ x, y: yData }, peaks);\n    }\n    peaks.forEach((peak) => {\n        if (!maxCriteria) {\n            peak.y *= -1;\n            peak.ddY = peak.ddY * -1;\n        }\n    });\n    peaks.sort((a, b) => {\n        return a.x - b.x;\n    });\n    return peaks;\n}\n//# sourceMappingURL=gsd.js.map","/**\n * Check if the values are separated always by the same difference\n * @param array - Monotone growing array of number\n * @param options\n */\nexport function xIsEquallySpaced(array, options = {}) {\n    if (array.length < 3)\n        return true;\n    const { tolerance = 0.05 } = options;\n    let maxDx = 0;\n    let minDx = Number.MAX_SAFE_INTEGER;\n    for (let i = 0; i < array.length - 1; ++i) {\n        const absoluteDifference = array[i + 1] - array[i];\n        if (absoluteDifference < minDx) {\n            minDx = absoluteDifference;\n        }\n        if (absoluteDifference > maxDx) {\n            maxDx = absoluteDifference;\n        }\n    }\n    return (maxDx - minDx) / maxDx < tolerance;\n}\n//# sourceMappingURL=xIsEquallySpaced.js.map","import { getMinMaxIntervalsDy } from \"./getMinMaxIntervals.js\";\nimport { getPeakFromIntervals } from \"./getPeaksFromIntervals.js\";\nexport function secondDerivative(input) {\n    const { x, y, yData, dY, ddY, dX, yThreshold } = input;\n    const minddY = [];\n    const { intervalL, intervalR } = getMinMaxIntervalsDy(y, x, dY, dX);\n    // By the intermediate value theorem We cannot find 2 consecutive maximum or minimum\n    for (let i = 1; i < y.length - 1; ++i) {\n        // Minimum in second derivative\n        if (ddY[i] < ddY[i - 1] && ddY[i] < ddY[i + 1]) {\n            minddY.push(i);\n        }\n    }\n    return getPeakFromIntervals({\n        minData: minddY,\n        intervalL,\n        intervalR,\n        x,\n        yData,\n        yThreshold,\n        ddY,\n    });\n}\n//# sourceMappingURL=secondDerivative.js.map","import { getMinMaxIntervalsDy } from \"./getMinMaxIntervals.js\";\nimport { tryMatchOneIntervalWithMinData } from \"./tryMatchOneIntervalWithMinData.js\";\nexport function autoAlgorithm(input) {\n    const { x, y, yData, dY, ddY, dX, yThreshold } = input;\n    const minddY = [];\n    const crossDy = [];\n    const { intervalL, intervalR } = getMinMaxIntervalsDy(y, x, dY, dX);\n    for (let i = 1; i < y.length - 1; ++i) {\n        if ((dY[i] < 0 && dY[i + 1] > 0) || (dY[i] > 0 && dY[i + 1] < 0)) {\n            // push the index of the element closer to zero\n            crossDy.push(Math.abs(dY[i]) < Math.abs(dY[i + 1]) ? i : i + 1);\n        }\n        // Handle exact zero\n        if (dY[i] === 0 &&\n            dY[i] < Math.abs(dY[i + 1]) &&\n            dY[i] < Math.abs(dY[i - 1])) {\n            crossDy.push(i);\n        }\n        // Minimum in second derivative\n        if (ddY[i] < ddY[i - 1] && ddY[i] < ddY[i + 1]) {\n            minddY.push(i);\n        }\n    }\n    const peaks = [];\n    let [lastK, lastJ] = [-1, -1];\n    for (let i = 0; i < intervalL.length; i++) {\n        const intervalWidth = (intervalR[i].x - intervalL[i].x) / 2;\n        const intervalCenter = (intervalR[i].x + intervalL[i].x) / 2;\n        let yIndex = -1;\n        let match = tryMatchOneIntervalWithMinData({\n            x,\n            yData,\n            lastK,\n            yThreshold,\n            intervalWidth,\n            intervalCenter,\n            minData: crossDy,\n        });\n        lastK = match.lastIndex;\n        if (match.possible !== -1) {\n            yIndex = crossDy[match.possible];\n        }\n        else {\n            match = tryMatchOneIntervalWithMinData({\n                x,\n                yData,\n                yThreshold,\n                lastK: lastJ,\n                intervalWidth,\n                intervalCenter,\n                minData: minddY,\n            });\n            if (match.possible !== -1) {\n                yIndex = minddY[match.possible];\n            }\n            lastJ = match.lastIndex;\n        }\n        if (yIndex !== -1) {\n            const width = Math.abs(intervalR[i].x - intervalL[i].x);\n            peaks.push({\n                id: crypto.randomUUID(),\n                x: x[yIndex],\n                y: y[yIndex],\n                width,\n                index: yIndex,\n                ddY: ddY[yIndex],\n                inflectionPoints: {\n                    from: intervalL[i],\n                    to: intervalR[i],\n                },\n            });\n        }\n    }\n    return peaks;\n}\n//# sourceMappingURL=autoAlgorithm.js.map","/**\n * Correction of the x and y coordinates using a quadratic optimizations with the peak and its 3 closest neighbors to determine the true x,y values of the peak.\n * This process is done in place and is very fast.\n * @param data\n * @param peaks\n */\nexport function optimizeTop(data, peaks) {\n    const { x, y } = data;\n    for (const peak of peaks) {\n        let currentIndex = peak.index;\n        // The detected peak could be moved 1 or 2 units to left or right.\n        if (y[currentIndex - 1] >= y[currentIndex - 2] &&\n            y[currentIndex - 1] >= y[currentIndex]) {\n            currentIndex--;\n        }\n        else if (y[currentIndex + 1] >= y[currentIndex] &&\n            y[currentIndex + 1] >= y[currentIndex + 2]) {\n            currentIndex++;\n        }\n        else if (y[currentIndex - 2] >= y[currentIndex - 3] &&\n            y[currentIndex - 2] >= y[currentIndex - 1]) {\n            currentIndex -= 2;\n        }\n        else if (y[currentIndex + 2] >= y[currentIndex + 1] &&\n            y[currentIndex + 2] >= y[currentIndex + 3]) {\n            currentIndex += 2;\n        }\n        // interpolation to a sin() function\n        if (y[currentIndex - 1] > 0 &&\n            y[currentIndex + 1] > 0 &&\n            y[currentIndex] >= y[currentIndex - 1] &&\n            y[currentIndex] >= y[currentIndex + 1] &&\n            (y[currentIndex] !== y[currentIndex - 1] ||\n                y[currentIndex] !== y[currentIndex + 1])) {\n            const alpha = 20 * Math.log10(y[currentIndex - 1]);\n            const beta = 20 * Math.log10(y[currentIndex]);\n            const gamma = 20 * Math.log10(y[currentIndex + 1]);\n            const p = (0.5 * (alpha - gamma)) / (alpha - 2 * beta + gamma);\n            const xCurrent = x[currentIndex];\n            const xPrevious = x[currentIndex - 1];\n            peak.x = xCurrent + (xCurrent - xPrevious) * p;\n            peak.y =\n                y[currentIndex] -\n                    0.25 * (y[currentIndex - 1] - y[currentIndex + 1]) * p;\n        }\n    }\n}\n//# sourceMappingURL=optimizeTop.js.map","//@ts-expect-error no type definition for baselines\nimport { airPLSBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function airPLSBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=airPLSBaseline.js.map","import airpls from 'ml-airpls';\nimport sequentialFill from 'ml-array-sequential-fill';\n/**\n * Adaptive iteratively reweighted penalized least squares [1]\n *\n * This function calls ml-airpls\n *\n * References:\n * [1] Zhang, Z.-M.; Chen, S.; Liang, Y.-Z.\n * Baseline Correction Using Adaptive Iteratively Reweighted Penalized Least Squares.\n * Analyst 2010, 135 (5), 1138–1146. https://doi.org/10.1039/B922045C.\n * @export\n * @param {Array<number>} ys\n * @param {object} [options] - Options object\n * @param {Array<number>} [options.x] Optional, Independent axis variable. If not specified, we use a linear grid\n * @param {object} [options.regression] - Options for the regression\n * @param {number} [options.regression.maxIterations = 100] - Maximum number of allowed iterations\n * @param {function} [options.regression.§Regression = PolynomialRegression] - Regression class with a predict method\n * @param {*} [options.regression.regressionOptions] - Options for regressionFunction\n * @param {number} [options.regression.tolerance = 0.001] - Convergence error tolerance\n * @returns {BaselineOutput}\n */\nexport function airPLSBaseline(ys, options = {}) {\n  const numberPoints = ys.length;\n  let { x, regressionOptions } = options;\n  if (!x) {\n    x = sequentialFill({ from: 0, to: numberPoints - 1, size: numberPoints });\n  }\n  let output = airpls(x, ys, regressionOptions);\n\n  return { baseline: output.baseline, correctedSpectrum: output.corrected };\n}\n","import { gsd } from 'ml-gsd';\nimport { xAdd, xFindClosestIndex, xMean } from 'ml-spectra-processing';\n/**\n * Filter that allows to calibrateX the x axis based on the presence of peaks\n * @param data\n * @param options\n */\nexport function calibrateX(data, options = {}) {\n    const { targetX = 0, nbPeaks = 1, from = data.x[0], to = data.x.at(-1), gsd: gsdOptions = {\n        minMaxRatio: 0.1,\n        realTopDetection: true,\n        smoothY: true,\n        sgOptions: {\n            windowSize: 7,\n            polynomial: 3,\n        },\n    }, } = options;\n    const fromIndex = xFindClosestIndex(data.x, from);\n    const toIndex = xFindClosestIndex(data.x, to);\n    let peaks = gsd({\n        x: data.x.subarray(fromIndex, toIndex),\n        y: data.y.subarray(fromIndex, toIndex),\n    }, gsdOptions);\n    peaks.sort((a, b) => b.y - a.y);\n    peaks = peaks.slice(0, nbPeaks);\n    if (peaks.length < nbPeaks)\n        return { data };\n    const middle = xMean(peaks.map((peak) => peak.x));\n    return { data: { x: xAdd(data.x, targetX - middle), y: data.y } };\n}\n//# sourceMappingURL=calibrateX.js.map","import { xMean } from 'ml-spectra-processing';\n/**\n * Center the mean\n * @param data\n */\nexport function centerMean(data) {\n    const { y } = data;\n    const mean = xMean(y);\n    for (let i = 0; i < y.length; i++) {\n        y[i] -= mean;\n    }\n    return { data };\n}\n//# sourceMappingURL=centerMean.js.map","import { xMedian } from 'ml-spectra-processing';\n/**\n * Center the median\n * @param data\n */\nexport function centerMedian(data) {\n    const { y } = data;\n    const median = xMedian(y);\n    for (let i = 0; i < y.length; i++) {\n        y[i] -= median;\n    }\n    return { data };\n}\n//# sourceMappingURL=centerMedian.js.map","import { xStandardDeviation } from 'ml-spectra-processing';\n/**\n * Center the mean\n * @param data\n */\nexport function divideBySD(data) {\n    const { y } = data;\n    const sd = xStandardDeviation(y);\n    for (let i = 0; i < y.length; i++) {\n        y[i] /= sd;\n    }\n    return { data };\n}\n//# sourceMappingURL=divideBySD.js.map","import { xyEnsureGrowingX } from 'ml-spectra-processing';\n/**\n * Ensure X values are strictly monotonic increasing\n * http://www-groups.mcs.st-andrews.ac.uk/~john/analysis/Lectures/L8.html\n * @param data\n */\nexport function ensureGrowing(data) {\n    return { data: xyEnsureGrowingX(data) };\n}\n//# sourceMappingURL=ensureGrowing.js.map","import { xyEquallySpaced } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function equallySpaced(data, options = {}) {\n    return { data: xyEquallySpaced(data, options) };\n}\n//# sourceMappingURL=equallySpaced.js.map","import { xyFilterX } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function filterX(data, options = {}) {\n    return {\n        data: xyFilterX(data, options),\n    };\n}\n//# sourceMappingURL=filterX.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Calculate the first derivative using Savitzky–Golay filter.\n * @param data\n * @param options\n */\nexport function firstDerivative(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, { ...options, derivative: 1 }) } };\n}\n//# sourceMappingURL=firstDerivative.js.map","import { xGetFromToIndex } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function fromTo(data, options = {}) {\n    const { fromIndex, toIndex } = xGetFromToIndex(data.x, options);\n    return {\n        data: {\n            x: data.x.subarray(fromIndex, toIndex + 1),\n            y: data.y.subarray(fromIndex, toIndex + 1),\n        },\n    };\n}\n//# sourceMappingURL=fromTo.js.map","//@ts-expect-error no type definition for baselines\nimport { iterativePolynomialBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function iterativePolynomialBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=iterativePolynomialBaseline.js.map","import { xNormed } from 'ml-spectra-processing';\n/**\n * Norm the Y values\n * @param data\n * @param options\n */\nexport function normed(data, options = {}) {\n    xNormed(data.y, { ...options, output: data.y });\n    return { data };\n}\n//# sourceMappingURL=normed.js.map","import { xParetoNormalization } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n */\nexport function paretoNormalization(data) {\n    return {\n        data: {\n            x: data.x,\n            y: xParetoNormalization(data.y),\n        },\n    };\n}\n//# sourceMappingURL=paretoNormalization.js.map","import { xRescale } from 'ml-spectra-processing';\n/**\n * Center the mean\n * @param data\n * @param options\n */\nexport function rescale(data, options = {}) {\n    xRescale(data.y, { ...options, output: data.y });\n    return { data };\n}\n//# sourceMappingURL=rescale.js.map","import { getOutputArray } from \"./getOutputArray.js\";\nimport { xCheck } from \"./xCheck.js\";\nimport { xMaxValue } from \"./xMaxValue.js\";\nimport { xMinValue } from \"./xMinValue.js\";\n/**\n * Function used to rescale data\n * @param input - input for the rescale\n * @param options - options\n * @returns rescaled data\n */\nexport function xRescale(input, options = {}) {\n    xCheck(input);\n    const output = getOutputArray(options.output, input.length);\n    const currentMin = xMinValue(input);\n    const currentMax = xMaxValue(input);\n    if (currentMin === currentMax) {\n        throw new RangeError('minimum and maximum input values are equal. Cannot rescale a constant array');\n    }\n    const { min = 0, max = 1 } = options;\n    if (min >= max) {\n        throw new RangeError('min option must be smaller than max option');\n    }\n    const factor = (max - min) / (currentMax - currentMin);\n    for (let i = 0; i < input.length; i++) {\n        output[i] = (input[i] - currentMin) * factor + min;\n    }\n    return output;\n}\n//# sourceMappingURL=xRescale.js.map","import { xyGrowingX } from 'ml-spectra-processing';\n/**\n * Ensure X values are strictly monotonic increasing\n * http://www-groups.mcs.st-andrews.ac.uk/~john/analysis/Lectures/L8.html\n * @param data\n */\nexport function reverseIfNeeded(data) {\n    return { data: xyGrowingX(data) };\n}\n//# sourceMappingURL=reverseIfNeeded.js.map","//@ts-expect-error no type definition for baselines\nimport { rollingAverageBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function rollingAverageBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=rollingAverageBaseline.js.map","//@ts-expect-error no type definition for baselines\nimport { rollingBallBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function rollingBallBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=rollingBallBaseline.js.map","//@ts-expect-error no type definition for baselines\nimport { rollingMedianBaseline as baselineFct } from 'baselines';\n/**\n * @param data\n */\nexport function rollingMedianBaseline(data) {\n    data.y = baselineFct(data.y).correctedSpectrum;\n    return { data };\n}\n//# sourceMappingURL=rollingMedianBaseline.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Apply the Savitzky Golay Generalized Filter\n * @param data\n * @param options\n */\nexport function savitzkyGolay(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, options) } };\n}\n//# sourceMappingURL=savitzkyGolay.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Calculate the second derivative using Savitzky–Golay filter.\n * @param data\n * @param options\n */\nexport function secondDerivative(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, { ...options, derivative: 2 }) } };\n}\n//# sourceMappingURL=secondDerivative.js.map","import { xAdd, xMaxValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMaxX(data, options = {}) {\n    const { max = 1 } = options;\n    const existingMax = xMaxValue(data.x);\n    if (existingMax === max) {\n        return { data };\n    }\n    return {\n        data: {\n            x: xAdd(data.x, max - existingMax),\n            y: data.y,\n        },\n    };\n}\n//# sourceMappingURL=setMaxX.js.map","import { xAdd, xMaxValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMaxY(data, options = {}) {\n    const { max = 1 } = options;\n    const existingMax = xMaxValue(data.y);\n    if (existingMax === max) {\n        return { data };\n    }\n    return {\n        data: {\n            x: data.x,\n            y: xAdd(data.y, max - existingMax),\n        },\n    };\n}\n//# sourceMappingURL=setMaxY.js.map","import { xAdd, xMinValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMinX(data, options = {}) {\n    const { min = 0 } = options;\n    const existingMin = xMinValue(data.x);\n    if (existingMin === min) {\n        return { data };\n    }\n    return {\n        data: {\n            x: xAdd(data.x, min - existingMin),\n            y: data.y,\n        },\n    };\n}\n//# sourceMappingURL=setMinX.js.map","import { xAdd, xMinValue } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function setMinY(data, options = {}) {\n    const { min = 0 } = options;\n    const existingMin = xMinValue(data.y);\n    if (existingMin === min) {\n        return { data };\n    }\n    return {\n        data: {\n            x: data.x,\n            y: xAdd(data.y, min - existingMin),\n        },\n    };\n}\n//# sourceMappingURL=setMinY.js.map","import { sgg } from 'ml-savitzky-golay-generalized';\n/**\n * Calculate the third derivative using Savitzky–Golay filter.\n * @param data\n * @param options\n */\nexport function thirdDerivative(data, options = {}) {\n    const { x, y } = data;\n    return { data: { x, y: sgg(y, x, { ...options, derivative: 3 }) } };\n}\n//# sourceMappingURL=thirdDerivative.js.map","import { xApplyFunctionStr } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function xFunction(data, options = {}) {\n    return {\n        data: {\n            x: xApplyFunctionStr(data.x, {\n                variableLabel: 'x',\n                fctString: options.function,\n            }),\n            y: data.y,\n        },\n    };\n}\n//# sourceMappingURL=xFunction.js.map","import { xApplyFunctionStr } from 'ml-spectra-processing';\n/**\n * Filter that allows to\n * @param data\n * @param options\n */\nexport function yFunction(data, options = {}) {\n    return {\n        data: {\n            x: data.x,\n            y: xApplyFunctionStr(data.y, {\n                variableLabel: 'y',\n                fctString: options.function,\n            }),\n        },\n    };\n}\n//# sourceMappingURL=yFunction.js.map","import { filterXY } from 'ml-signal-processing';\nimport { xIsMonotonic, xMaxValue, xMinValue } from 'ml-spectra-processing';\nexport function getNormalizedSpectrum(spectrum, options = {}) {\n    const data = {\n        x: spectrum.variables.x.data,\n        y: spectrum.variables.y.data,\n    };\n    const newSpectrum = {\n        variables: {\n            x: {\n                data: spectrum.variables.x.data,\n                units: spectrum.variables.x.units,\n                label: spectrum.variables.x.label,\n            },\n            y: {\n                data: spectrum.variables.y.data,\n                units: spectrum.variables.y.units,\n                label: spectrum.variables.y.label,\n            },\n        },\n    };\n    if (spectrum.title)\n        newSpectrum.title = spectrum.title;\n    if (spectrum.dataType)\n        newSpectrum.dataType = spectrum.dataType;\n    if (spectrum.meta)\n        newSpectrum.meta = spectrum.meta;\n    if (spectrum.id)\n        newSpectrum.id = spectrum.id;\n    const { from = spectrum.variables.x.min, to = spectrum.variables.x.max, numberOfPoints, applyRangeSelectionFirst = false, exclusions = [], zones = [], } = options;\n    let { filters = [] } = options;\n    filters = structuredClone(filters);\n    if (numberOfPoints) {\n        if (applyRangeSelectionFirst) {\n            filters.unshift({\n                name: 'equallySpaced',\n                options: { from, to, exclusions, zones, numberOfPoints },\n            });\n        }\n        else {\n            filters.push({\n                name: 'equallySpaced',\n                options: { from, to, exclusions, zones, numberOfPoints },\n            });\n        }\n    }\n    else if (applyRangeSelectionFirst) {\n        filters.unshift({\n            name: 'filterX',\n            options: { from, to, exclusions, zones },\n        });\n    }\n    else {\n        filters.push({\n            name: 'filterX',\n            options: { from, to, exclusions, zones },\n        });\n    }\n    const { x, y } = filterXY(data, filters).data;\n    // filters change the y axis, we get rid of the units\n    // TODO we should deal correctly with this problem\n    if (filters.length > 1) {\n        newSpectrum.variables.y.units = '';\n        newSpectrum.variables.y.label = newSpectrum.variables.y.label?.replace(/\\s*\\[.*]/, '');\n    }\n    newSpectrum.variables.x.data = x;\n    newSpectrum.variables.x.min = xMinValue(x);\n    newSpectrum.variables.x.max = xMaxValue(x);\n    newSpectrum.variables.x.isMonotonic = xIsMonotonic(x);\n    newSpectrum.variables.y.data = y;\n    newSpectrum.variables.y.min = xMinValue(y);\n    newSpectrum.variables.y.max = xMaxValue(y);\n    newSpectrum.variables.y.isMonotonic = xIsMonotonic(y);\n    return newSpectrum;\n}\n//# sourceMappingURL=getNormalizedSpectrum.js.map","import { xEnsureFloat64, xyGrowingX } from 'ml-spectra-processing';\nimport * as Filters from \"./filters/filters.js\";\n/**\n * Apply filters on {x:[], y:[]}\n * @param data\n * @param filters\n * @returns\n */\nexport function filterXY(data, filters) {\n    let result = {\n        data: xyGrowingX({ x: xEnsureFloat64(data.x), y: xEnsureFloat64(data.y) }),\n    };\n    const logs = [];\n    for (const filter of filters) {\n        const start = Date.now();\n        if (!filter.name) {\n            // we ignore empty filter names\n            continue;\n        }\n        const filterFct = Filters[filter.name];\n        if (!filterFct) {\n            throw new Error(`Unknown filter: ${filter.name}`);\n        }\n        // @ts-expect-error some method have options and some other ones don't have any options\n        result = filterFct(result.data, filter.options);\n        result.data = xyGrowingX(result.data);\n        logs.push({\n            name: filter.name,\n            time: Date.now() - start,\n        });\n    }\n    return { logs, data: result.data };\n}\n//# sourceMappingURL=filterXY.js.map","/*\nThe MIT License (MIT)\nCopyright © 2006-2007 Kevin C. Olbrich\nCopyright © 2010-2016 LIM SAS (http://lim.eu) - Julien Sanchez\n\nPermission is hereby granted, free of charge, to any person obtaining a copy of\nthis software and associated documentation files (the \"Software\"), to deal in\nthe Software without restriction, including without limitation the rights to\nuse, copy, modify, merge, publish, distribute, sublicense, and/or sell copies\nof the Software, and to permit persons to whom the Software is furnished to do\nso, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE.\n*/\n(function (global, factory) {\n  typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n  typeof define === 'function' && define.amd ? define(factory) :\n  (global = typeof globalThis !== 'undefined' ? globalThis : global || self, global.Qty = factory());\n})(this, (function () { 'use strict';\n\n  /**\n   * Tests if a value is a string\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a string, false otherwise\n   */\n  function isString(value) {\n    return typeof value === \"string\" || value instanceof String;\n  }\n\n  /*\n   * Prefer stricter Number.isFinite if currently supported.\n   * To be dropped when ES6 is finalized. Obsolete browsers will\n   * have to use ES6 polyfills.\n   */\n  var isFiniteImpl = Number.isFinite || window.isFinite;\n  /**\n   * Tests if a value is a number\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a number, false otherwise\n   */\n  function isNumber(value) {\n    // Number.isFinite allows not to consider NaN or '1' as numbers\n    return isFiniteImpl(value);\n  }\n\n  /*\n   * Identity function\n   */\n  function identity(value) {\n    return value;\n  }\n\n  /**\n   * Returns unique strings from list\n   *\n   * @param {string[]} strings - array of strings\n   *\n   *\n   * @returns {string[]} a new array of strings without duplicates\n   */\n  function uniq(strings) {\n    var seen = {};\n    return strings.filter(function(item) {\n      return seen.hasOwnProperty(item) ? false : (seen[item] = true);\n    });\n  }\n\n  function compareArray(array1, array2) {\n    if (array2.length !== array1.length) {\n      return false;\n    }\n    for (var i = 0; i < array1.length; i++) {\n      if (array2[i].compareArray) {\n        if (!array2[i].compareArray(array1[i])) {\n          return false;\n        }\n      }\n      if (array2[i] !== array1[i]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  function assign(target, properties) {\n    Object.keys(properties).forEach(function(key) {\n      target[key] = properties[key];\n    });\n  }\n\n  /**\n   * Safely multiplies numbers while avoiding floating errors\n   * like 0.1 * 0.1 => 0.010000000000000002\n   *\n   * @param {...number} numbers - numbers to multiply\n   *\n   * @returns {number} result\n   */\n  function mulSafe() {\n    var result = 1, decimals = 0;\n    for (var i = 0; i < arguments.length; i++) {\n      var arg = arguments[i];\n      decimals = decimals + getFractional(arg);\n      result *= arg;\n    }\n\n    return decimals !== 0 ? round(result, decimals) : result;\n  }\n\n  /**\n   * Safely divides two numbers while avoiding floating errors\n   * like 0.3 / 0.05 => 5.999999999999999\n   *\n   * @returns {number} result\n   * @param {number} num Numerator\n   * @param {number} den Denominator\n   */\n  function divSafe(num, den) {\n    if (den === 0) {\n      throw new Error(\"Divide by zero\");\n    }\n\n    var factor = Math.pow(10, getFractional(den));\n    var invDen = factor / (factor * den);\n\n    return mulSafe(num, invDen);\n  }\n\n  /**\n   * Rounds value at the specified number of decimals\n   *\n   * @param {number} val - value to round\n   * @param {number} decimals - number of decimals\n   *\n   * @returns {number} rounded number\n   */\n  function round(val, decimals) {\n    return Math.round(val * Math.pow(10, decimals)) / Math.pow(10, decimals);\n  }\n\n  function getFractional(num) {\n    // Check for NaNs or Infinities\n    if (!isFinite(num)) {\n      return 0;\n    }\n\n    // Faster than parsing strings\n    // http://jsperf.com/count-decimals/2\n    var count = 0;\n    while (num % 1 !== 0) {\n      num *= 10;\n      count++;\n    }\n    return count;\n  }\n\n  /**\n   * Custom error type definition\n   * @constructor\n   */\n  function QtyError() {\n    var err;\n    if (!this) { // Allows to instantiate QtyError without new()\n      err = Object.create(QtyError.prototype);\n      QtyError.apply(err, arguments);\n      return err;\n    }\n    err = Error.apply(this, arguments);\n    this.name = \"QtyError\";\n    this.message = err.message;\n    this.stack = err.stack;\n  }\n  QtyError.prototype = Object.create(Error.prototype, {constructor: { value: QtyError }});\n\n  /*\n   * Throws incompatible units error\n   * @param {string} left - units\n   * @param {string} right - units incompatible with first argument\n   * @throws \"Incompatible units\" error\n   */\n  function throwIncompatibleUnits(left, right) {\n    throw new QtyError(\"Incompatible units: \" + left + \" and \" + right);\n  }\n\n  var UNITS = {\n    /* prefixes */\n    \"<googol>\" : [[\"googol\"], 1e100, \"prefix\"],\n    \"<kibi>\"  :  [[\"Ki\",\"Kibi\",\"kibi\"], Math.pow(2,10), \"prefix\"],\n    \"<mebi>\"  :  [[\"Mi\",\"Mebi\",\"mebi\"], Math.pow(2,20), \"prefix\"],\n    \"<gibi>\"  :  [[\"Gi\",\"Gibi\",\"gibi\"], Math.pow(2,30), \"prefix\"],\n    \"<tebi>\"  :  [[\"Ti\",\"Tebi\",\"tebi\"], Math.pow(2,40), \"prefix\"],\n    \"<pebi>\"  :  [[\"Pi\",\"Pebi\",\"pebi\"], Math.pow(2,50), \"prefix\"],\n    \"<exi>\"   :  [[\"Ei\",\"Exi\",\"exi\"], Math.pow(2,60), \"prefix\"],\n    \"<zebi>\"  :  [[\"Zi\",\"Zebi\",\"zebi\"], Math.pow(2,70), \"prefix\"],\n    \"<yebi>\"  :  [[\"Yi\",\"Yebi\",\"yebi\"], Math.pow(2,80), \"prefix\"],\n    \"<yotta>\" :  [[\"Y\",\"Yotta\",\"yotta\"], 1e24, \"prefix\"],\n    \"<zetta>\" :  [[\"Z\",\"Zetta\",\"zetta\"], 1e21, \"prefix\"],\n    \"<exa>\"   :  [[\"E\",\"Exa\",\"exa\"], 1e18, \"prefix\"],\n    \"<peta>\"  :  [[\"P\",\"Peta\",\"peta\"], 1e15, \"prefix\"],\n    \"<tera>\"  :  [[\"T\",\"Tera\",\"tera\"], 1e12, \"prefix\"],\n    \"<giga>\"  :  [[\"G\",\"Giga\",\"giga\"], 1e9, \"prefix\"],\n    \"<mega>\"  :  [[\"M\",\"Mega\",\"mega\"], 1e6, \"prefix\"],\n    \"<kilo>\"  :  [[\"k\",\"kilo\"], 1e3, \"prefix\"],\n    \"<hecto>\" :  [[\"h\",\"Hecto\",\"hecto\"], 1e2, \"prefix\"],\n    \"<deca>\"  :  [[\"da\",\"Deca\",\"deca\",\"deka\"], 1e1, \"prefix\"],\n    \"<deci>\"  :  [[\"d\",\"Deci\",\"deci\"], 1e-1, \"prefix\"],\n    \"<centi>\"  : [[\"c\",\"Centi\",\"centi\"], 1e-2, \"prefix\"],\n    \"<milli>\" :  [[\"m\",\"Milli\",\"milli\"], 1e-3, \"prefix\"],\n    \"<micro>\"  : [\n      [\"u\",\"\\u03BC\"/*µ as greek letter*/,\"\\u00B5\"/*µ as micro sign*/,\"Micro\",\"mc\",\"micro\"],\n      1e-6,\n      \"prefix\"\n    ],\n    \"<nano>\"  :  [[\"n\",\"Nano\",\"nano\"], 1e-9, \"prefix\"],\n    \"<pico>\"  :  [[\"p\",\"Pico\",\"pico\"], 1e-12, \"prefix\"],\n    \"<femto>\" :  [[\"f\",\"Femto\",\"femto\"], 1e-15, \"prefix\"],\n    \"<atto>\"  :  [[\"a\",\"Atto\",\"atto\"], 1e-18, \"prefix\"],\n    \"<zepto>\" :  [[\"z\",\"Zepto\",\"zepto\"], 1e-21, \"prefix\"],\n    \"<yocto>\" :  [[\"y\",\"Yocto\",\"yocto\"], 1e-24, \"prefix\"],\n\n    \"<1>\"     :  [[\"1\", \"<1>\"], 1, \"\"],\n    /* length units */\n    \"<meter>\" :  [[\"m\",\"meter\",\"meters\",\"metre\",\"metres\"], 1.0, \"length\", [\"<meter>\"] ],\n    \"<inch>\"  :  [[\"in\",\"inch\",\"inches\",\"\\\"\"], 0.0254, \"length\", [\"<meter>\"]],\n    \"<foot>\"  :  [[\"ft\",\"foot\",\"feet\",\"'\"], 0.3048, \"length\", [\"<meter>\"]],\n    \"<yard>\"  :  [[\"yd\",\"yard\",\"yards\"], 0.9144, \"length\", [\"<meter>\"]],\n    \"<mile>\"  :  [[\"mi\",\"mile\",\"miles\"], 1609.344, \"length\", [\"<meter>\"]],\n    \"<naut-mile>\" : [[\"nmi\",\"naut-mile\"], 1852, \"length\", [\"<meter>\"]],\n    \"<league>\":  [[\"league\",\"leagues\"], 4828, \"length\", [\"<meter>\"]],\n    \"<furlong>\": [[\"furlong\",\"furlongs\"], 201.2, \"length\", [\"<meter>\"]],\n    \"<rod>\"   :  [[\"rd\",\"rod\",\"rods\"], 5.029, \"length\", [\"<meter>\"]],\n    \"<mil>\"   :  [[\"mil\",\"mils\"], 0.0000254, \"length\", [\"<meter>\"]],\n    \"<angstrom>\"  :[[\"ang\",\"angstrom\",\"angstroms\"], 1e-10, \"length\", [\"<meter>\"]],\n    \"<fathom>\" : [[\"fathom\",\"fathoms\"], 1.829, \"length\", [\"<meter>\"]],\n    \"<pica>\"  : [[\"pica\",\"picas\"], 0.00423333333, \"length\", [\"<meter>\"]],\n    \"<point>\" : [[\"pt\",\"point\",\"points\"], 0.000352777778, \"length\", [\"<meter>\"]],\n    \"<redshift>\" : [[\"z\",\"red-shift\", \"redshift\"], 1.302773e26, \"length\", [\"<meter>\"]],\n    \"<AU>\"    : [[\"AU\",\"astronomical-unit\"], 149597900000, \"length\", [\"<meter>\"]],\n    \"<light-second>\":[[\"ls\",\"light-second\"], 299792500, \"length\", [\"<meter>\"]],\n    \"<light-minute>\":[[\"lmin\",\"light-minute\"], 17987550000, \"length\", [\"<meter>\"]],\n    \"<light-year>\" : [[\"ly\",\"light-year\"], 9460528000000000, \"length\", [\"<meter>\"]],\n    \"<parsec>\"  : [[\"pc\",\"parsec\",\"parsecs\"], 30856780000000000, \"length\", [\"<meter>\"]],\n    \"<datamile>\"  :  [[\"DM\",\"datamile\"], 1828.8, \"length\", [\"<meter>\"]],\n\n    /* mass */\n    \"<kilogram>\" : [[\"kg\",\"kilogram\",\"kilograms\"], 1.0, \"mass\", [\"<kilogram>\"]],\n    \"<AMU>\" : [[\"u\",\"AMU\",\"amu\"], 1.660538921e-27, \"mass\", [\"<kilogram>\"]],\n    \"<dalton>\" : [[\"Da\",\"Dalton\",\"Daltons\",\"dalton\",\"daltons\"], 1.660538921e-27, \"mass\", [\"<kilogram>\"]],\n    \"<slug>\" : [[\"slug\",\"slugs\"], 14.5939029, \"mass\", [\"<kilogram>\"]],\n    \"<short-ton>\" : [[\"tn\",\"ton\",\"short-ton\"], 907.18474, \"mass\", [\"<kilogram>\"]],\n    \"<metric-ton>\":[[\"t\",\"tonne\",\"metric-ton\"], 1000, \"mass\", [\"<kilogram>\"]],\n    \"<carat>\" : [[\"ct\",\"carat\",\"carats\"], 0.0002, \"mass\", [\"<kilogram>\"]],\n    \"<pound>\" : [[\"lbs\",\"lb\",\"pound\",\"pounds\",\"#\"], 0.45359237, \"mass\", [\"<kilogram>\"]],\n    \"<ounce>\" : [[\"oz\",\"ounce\",\"ounces\"], 0.0283495231, \"mass\", [\"<kilogram>\"]],\n    \"<gram>\"    :  [[\"g\",\"gram\",\"grams\",\"gramme\",\"grammes\"], 1e-3, \"mass\", [\"<kilogram>\"]],\n    \"<grain>\" : [[\"grain\",\"grains\",\"gr\"], 6.479891e-5, \"mass\", [\"<kilogram>\"]],\n    \"<dram>\"  : [[\"dram\",\"drams\",\"dr\"], 0.0017718452, \"mass\",[\"<kilogram>\"]],\n    \"<stone>\" : [[\"stone\",\"stones\",\"st\"],6.35029318, \"mass\",[\"<kilogram>\"]],\n\n    /* area */\n    \"<hectare>\":[[\"hectare\"], 10000, \"area\", [\"<meter>\",\"<meter>\"]],\n    \"<acre>\":[[\"acre\",\"acres\"], 4046.85642, \"area\", [\"<meter>\",\"<meter>\"]],\n    \"<sqft>\":[[\"sqft\"], 1, \"area\", [\"<foot>\",\"<foot>\"]],\n\n    /* volume */\n    \"<liter>\" : [[\"l\",\"L\",\"liter\",\"liters\",\"litre\",\"litres\"], 0.001, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<gallon>\":  [[\"gal\",\"gallon\",\"gallons\"], 0.0037854118, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<gallon-imp>\":  [[\"galimp\",\"gallon-imp\",\"gallons-imp\"], 0.0045460900, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<quart>\":  [[\"qt\",\"quart\",\"quarts\"], 0.00094635295, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<pint>\":  [[\"pt\",\"pint\",\"pints\"], 0.000473176475, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<pint-imp>\":  [[\"ptimp\",\"pint-imp\",\"pints-imp\"], 5.6826125e-4, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<cup>\":  [[\"cu\",\"cup\",\"cups\"], 0.000236588238, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<fluid-ounce>\":  [[\"floz\",\"fluid-ounce\",\"fluid-ounces\"], 2.95735297e-5, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<fluid-ounce-imp>\":  [[\"flozimp\", \"floz-imp\",\"fluid-ounce-imp\",\"fluid-ounces-imp\"], 2.84130625e-5, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<tablespoon>\":  [[\"tb\",\"tbsp\",\"tbs\",\"tablespoon\",\"tablespoons\"], 1.47867648e-5, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<teaspoon>\":  [[\"tsp\",\"teaspoon\",\"teaspoons\"], 4.92892161e-6, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<bushel>\":  [[\"bu\",\"bsh\",\"bushel\",\"bushels\"], 0.035239072, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<oilbarrel>\":  [[\"bbl\",\"oilbarrel\", \"oilbarrels\", \"oil-barrel\",\"oil-barrels\"], 0.158987294928, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<beerbarrel>\":  [[\"bl\",\"bl-us\",\"beerbarrel\", \"beerbarrels\", \"beer-barrel\",\"beer-barrels\"], 0.1173477658, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<beerbarrel-imp>\":  [[\"blimp\",\"bl-imp\",\"beerbarrel-imp\", \"beerbarrels-imp\", \"beer-barrel-imp\",\"beer-barrels-imp\"], 0.16365924, \"volume\", [\"<meter>\",\"<meter>\",\"<meter>\"]],\n\n    /* speed */\n    \"<kph>\" : [[\"kph\"], 0.277777778, \"speed\", [\"<meter>\"], [\"<second>\"]],\n    \"<mph>\" : [[\"mph\"], 0.44704, \"speed\", [\"<meter>\"], [\"<second>\"]],\n    \"<knot>\" : [[\"kt\",\"kn\",\"kts\",\"knot\",\"knots\"], 0.514444444, \"speed\", [\"<meter>\"], [\"<second>\"]],\n    \"<fps>\"  : [[\"fps\"], 0.3048, \"speed\", [\"<meter>\"], [\"<second>\"]],\n\n    /* acceleration */\n    \"<gee>\" : [[\"gee\"], 9.80665, \"acceleration\", [\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<Gal>\" : [[\"Gal\"], 1e-2, \"acceleration\", [\"<meter>\"], [\"<second>\",\"<second>\"]],\n\n    /* temperature_difference */\n    \"<kelvin>\" : [[\"degK\",\"kelvin\"], 1.0, \"temperature\", [\"<kelvin>\"]],\n    \"<celsius>\" : [[\"degC\",\"celsius\",\"celsius\",\"centigrade\"], 1.0, \"temperature\", [\"<kelvin>\"]],\n    \"<fahrenheit>\" : [[\"degF\",\"fahrenheit\"], 5 / 9, \"temperature\", [\"<kelvin>\"]],\n    \"<rankine>\" : [[\"degR\",\"rankine\"], 5 / 9, \"temperature\", [\"<kelvin>\"]],\n    \"<temp-K>\"  : [[\"tempK\",\"temp-K\"], 1.0, \"temperature\", [\"<temp-K>\"]],\n    \"<temp-C>\"  : [[\"tempC\",\"temp-C\"], 1.0, \"temperature\", [\"<temp-K>\"]],\n    \"<temp-F>\"  : [[\"tempF\",\"temp-F\"], 5 / 9, \"temperature\", [\"<temp-K>\"]],\n    \"<temp-R>\"  : [[\"tempR\",\"temp-R\"], 5 / 9, \"temperature\", [\"<temp-K>\"]],\n\n    /* time */\n    \"<second>\":  [[\"s\",\"sec\",\"secs\",\"second\",\"seconds\"], 1.0, \"time\", [\"<second>\"]],\n    \"<minute>\":  [[\"min\",\"mins\",\"minute\",\"minutes\"], 60.0, \"time\", [\"<second>\"]],\n    \"<hour>\":  [[\"h\",\"hr\",\"hrs\",\"hour\",\"hours\"], 3600.0, \"time\", [\"<second>\"]],\n    \"<day>\":  [[\"d\",\"day\",\"days\"], 3600 * 24, \"time\", [\"<second>\"]],\n    \"<week>\":  [[\"wk\",\"week\",\"weeks\"], 7 * 3600 * 24, \"time\", [\"<second>\"]],\n    \"<fortnight>\": [[\"fortnight\",\"fortnights\"], 1209600, \"time\", [\"<second>\"]],\n    \"<year>\":  [[\"y\",\"yr\",\"year\",\"years\",\"annum\"], 31556926, \"time\", [\"<second>\"]],\n    \"<decade>\":[[\"decade\",\"decades\"], 315569260, \"time\", [\"<second>\"]],\n    \"<century>\":[[\"century\",\"centuries\"], 3155692600, \"time\", [\"<second>\"]],\n\n    /* pressure */\n    \"<pascal>\" : [[\"Pa\",\"pascal\",\"Pascal\"], 1.0, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<bar>\" : [[\"bar\",\"bars\"], 100000, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<mmHg>\" : [[\"mmHg\"], 133.322368, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<inHg>\" : [[\"inHg\"], 3386.3881472, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<torr>\" : [[\"torr\"], 133.322368, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<atm>\" : [[\"atm\",\"ATM\",\"atmosphere\",\"atmospheres\"], 101325, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<psi>\" : [[\"psi\"], 6894.76, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<cmh2o>\" : [[\"cmH2O\",\"cmh2o\"], 98.0638, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n    \"<inh2o>\" : [[\"inH2O\",\"inh2o\"], 249.082052, \"pressure\", [\"<kilogram>\"],[\"<meter>\",\"<second>\",\"<second>\"]],\n\n    /* viscosity */\n    \"<poise>\"  : [[\"P\",\"poise\"], 0.1, \"viscosity\", [\"<kilogram>\"],[\"<meter>\",\"<second>\"] ],\n    \"<stokes>\" : [[\"St\",\"stokes\"], 1e-4, \"viscosity\", [\"<meter>\",\"<meter>\"], [\"<second>\"]],\n\n    /* substance */\n    \"<mole>\"  :  [[\"mol\",\"mole\"], 1.0, \"substance\", [\"<mole>\"]],\n\n    /* molar_concentration */\n    \"<molar>\" : [[\"M\",\"molar\"], 1000, \"molar_concentration\", [\"<mole>\"], [\"<meter>\",\"<meter>\",\"<meter>\"]],\n    \"<wtpercent>\"  : [[\"wt%\",\"wtpercent\"], 10, \"molar_concentration\", [\"<kilogram>\"], [\"<meter>\",\"<meter>\",\"<meter>\"]],\n\n    /* activity */\n    \"<katal>\" :  [[\"kat\",\"katal\",\"Katal\"], 1.0, \"activity\", [\"<mole>\"], [\"<second>\"]],\n    \"<unit>\"  :  [[\"U\",\"enzUnit\",\"unit\"], 16.667e-16, \"activity\", [\"<mole>\"], [\"<second>\"]],\n\n    /* capacitance */\n    \"<farad>\" :  [[\"F\",\"farad\",\"Farad\"], 1.0, \"capacitance\", [\"<second>\",\"<second>\",\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"], [\"<meter>\", \"<meter>\", \"<kilogram>\"]],\n\n    /* charge */\n    \"<coulomb>\" :  [[\"C\",\"coulomb\",\"Coulomb\"], 1.0, \"charge\", [\"<ampere>\",\"<second>\"]],\n    \"<Ah>\" :  [[\"Ah\"], 3600, \"charge\", [\"<ampere>\",\"<second>\"]],\n\n    /* current */\n    \"<ampere>\"  :  [[\"A\",\"Ampere\",\"ampere\",\"amp\",\"amps\"], 1.0, \"current\", [\"<ampere>\"]],\n\n    /* conductance */\n    \"<siemens>\" : [[\"S\",\"Siemens\",\"siemens\"], 1.0, \"conductance\", [\"<second>\",\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"], [\"<kilogram>\",\"<meter>\",\"<meter>\"]],\n\n    /* inductance */\n    \"<henry>\" :  [[\"H\",\"Henry\",\"henry\"], 1.0, \"inductance\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"]],\n\n    /* potential */\n    \"<volt>\"  :  [[\"V\",\"Volt\",\"volt\",\"volts\"], 1.0, \"potential\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<second>\",\"<ampere>\"]],\n\n    /* resistance */\n    \"<ohm>\" :  [\n      [\"Ohm\",\"ohm\",\"\\u03A9\"/*Ω as greek letter*/,\"\\u2126\"/*Ω as ohm sign*/],\n      1.0,\n      \"resistance\",\n      [\"<meter>\",\"<meter>\",\"<kilogram>\"],[\"<second>\",\"<second>\",\"<second>\",\"<ampere>\",\"<ampere>\"]\n    ],\n    /* magnetism */\n    \"<weber>\" : [[\"Wb\",\"weber\",\"webers\"], 1.0, \"magnetism\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<tesla>\"  : [[\"T\",\"tesla\",\"teslas\"], 1.0, \"magnetism\", [\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<gauss>\" : [[\"G\",\"gauss\"], 1e-4, \"magnetism\",  [\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<maxwell>\" : [[\"Mx\",\"maxwell\",\"maxwells\"], 1e-8, \"magnetism\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\",\"<ampere>\"]],\n    \"<oersted>\"  : [[\"Oe\",\"oersted\",\"oersteds\"], 250.0 / Math.PI, \"magnetism\", [\"<ampere>\"], [\"<meter>\"]],\n\n    /* energy */\n    \"<joule>\" :  [[\"J\",\"joule\",\"Joule\",\"joules\",\"Joules\"], 1.0, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<erg>\"   :  [[\"erg\",\"ergs\"], 1e-7, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<btu>\"   :  [[\"BTU\",\"btu\",\"BTUs\"], 1055.056, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<calorie>\" :  [[\"cal\",\"calorie\",\"calories\"], 4.18400, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<Calorie>\" :  [[\"Cal\",\"Calorie\",\"Calories\"], 4184.00, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<therm-US>\" : [[\"th\",\"therm\",\"therms\",\"Therm\",\"therm-US\"], 105480400, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<Wh>\" : [[\"Wh\"], 3600, \"energy\",[\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n    \"<electronvolt>\" : [[\"eV\", \"electronvolt\", \"electronvolts\"], 1.602176634E-19, \"energy\", [\"<meter>\",\"<meter>\",\"<kilogram>\"], [\"<second>\",\"<second>\"]],\n\n    /* force */\n    \"<newton>\"  : [[\"N\",\"Newton\",\"newton\"], 1.0, \"force\", [\"<kilogram>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<dyne>\"  : [[\"dyn\",\"dyne\"], 1e-5, \"force\", [\"<kilogram>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<pound-force>\"  : [[\"lbf\",\"pound-force\"], 4.448222, \"force\", [\"<kilogram>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n\n    /* frequency */\n    \"<hertz>\" : [[\"Hz\",\"hertz\",\"Hertz\"], 1.0, \"frequency\", [\"<1>\"], [\"<second>\"]],\n\n    /* angle */\n    \"<radian>\" :[[\"rad\",\"radian\",\"radians\"], 1.0, \"angle\", [\"<radian>\"]],\n    \"<degree>\" :[[\"deg\",\"degree\",\"degrees\"], Math.PI / 180.0, \"angle\", [\"<radian>\"]],\n    \"<arcminute>\" :[[\"arcmin\",\"arcminute\",\"arcminutes\"], Math.PI / 10800.0, \"angle\", [\"<radian>\"]],\n    \"<arcsecond>\" :[[\"arcsec\",\"arcsecond\",\"arcseconds\"], Math.PI / 648000.0, \"angle\", [\"<radian>\"]],\n    \"<gradian>\"   :[[\"gon\",\"grad\",\"gradian\",\"grads\"], Math.PI / 200.0, \"angle\", [\"<radian>\"]],\n    \"<steradian>\"  : [[\"sr\",\"steradian\",\"steradians\"], 1.0, \"solid_angle\", [\"<steradian>\"]],\n\n    /* rotation */\n    \"<rotation>\" : [[\"rotation\"], 2.0 * Math.PI, \"angle\", [\"<radian>\"]],\n    \"<rpm>\"   :[[\"rpm\"], 2.0 * Math.PI / 60.0, \"angular_velocity\", [\"<radian>\"], [\"<second>\"]],\n\n    /* information */\n    \"<byte>\"  :[[\"B\",\"byte\",\"bytes\"], 1.0, \"information\", [\"<byte>\"]],\n    \"<bit>\"  :[[\"b\",\"bit\",\"bits\"], 0.125, \"information\", [\"<byte>\"]],\n\n    /* information rate */\n    \"<Bps>\" : [[\"Bps\"], 1.0, \"information_rate\", [\"<byte>\"], [\"<second>\"]],\n    \"<bps>\" : [[\"bps\"], 0.125, \"information_rate\", [\"<byte>\"], [\"<second>\"]],\n\n    /* currency */\n    \"<dollar>\":[[\"USD\",\"dollar\"], 1.0, \"currency\", [\"<dollar>\"]],\n    \"<cents>\" :[[\"cents\"], 0.01, \"currency\", [\"<dollar>\"]],\n\n    /* luminosity */\n    \"<candela>\" : [[\"cd\",\"candela\"], 1.0, \"luminosity\", [\"<candela>\"]],\n    \"<lumen>\" : [[\"lm\",\"lumen\"], 1.0, \"luminous_power\", [\"<candela>\",\"<steradian>\"]],\n    \"<lux>\" :[[\"lux\"], 1.0, \"illuminance\", [\"<candela>\",\"<steradian>\"], [\"<meter>\",\"<meter>\"]],\n\n    /* power */\n    \"<watt>\"  : [[\"W\",\"watt\",\"watts\"], 1.0, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n    \"<volt-ampere>\"  : [[\"VA\",\"volt-ampere\"], 1.0, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n    \"<volt-ampere-reactive>\"  : [[\"var\",\"Var\",\"VAr\",\"VAR\",\"volt-ampere-reactive\"], 1.0, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n    \"<horsepower>\"  :  [[\"hp\",\"horsepower\"], 745.699872, \"power\", [\"<kilogram>\",\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\",\"<second>\"]],\n\n    /* radiation */\n    \"<gray>\" : [[\"Gy\",\"gray\",\"grays\"], 1.0, \"radiation\", [\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<roentgen>\" : [[\"R\",\"roentgen\"], 0.009330, \"radiation\", [\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<sievert>\" : [[\"Sv\",\"sievert\",\"sieverts\"], 1.0, \"radiation\", [\"<meter>\",\"<meter>\"], [\"<second>\",\"<second>\"]],\n    \"<becquerel>\" : [[\"Bq\",\"becquerel\",\"becquerels\"], 1.0, \"radiation\", [\"<1>\"],[\"<second>\"]],\n    \"<curie>\" : [[\"Ci\",\"curie\",\"curies\"], 3.7e10, \"radiation\", [\"<1>\"],[\"<second>\"]],\n\n    /* rate */\n    \"<cpm>\" : [[\"cpm\"], 1.0 / 60.0, \"rate\", [\"<count>\"],[\"<second>\"]],\n    \"<dpm>\" : [[\"dpm\"], 1.0 / 60.0, \"rate\", [\"<count>\"],[\"<second>\"]],\n    \"<bpm>\" : [[\"bpm\"], 1.0 / 60.0, \"rate\", [\"<count>\"],[\"<second>\"]],\n\n    /* resolution / typography */\n    \"<dot>\" : [[\"dot\",\"dots\"], 1, \"resolution\", [\"<each>\"]],\n    \"<pixel>\" : [[\"pixel\",\"px\"], 1, \"resolution\", [\"<each>\"]],\n    \"<ppi>\" : [[\"ppi\"], 1, \"resolution\", [\"<pixel>\"], [\"<inch>\"]],\n    \"<dpi>\" : [[\"dpi\"], 1, \"typography\", [\"<dot>\"], [\"<inch>\"]],\n\n    /* other */\n    \"<cell>\" : [[\"cells\",\"cell\"], 1, \"counting\", [\"<each>\"]],\n    \"<each>\" : [[\"each\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<count>\" : [[\"count\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<base-pair>\"  : [[\"bp\",\"base-pair\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<nucleotide>\" : [[\"nt\",\"nucleotide\"], 1.0, \"counting\", [\"<each>\"]],\n    \"<molecule>\" : [[\"molecule\",\"molecules\"], 1.0, \"counting\", [\"<1>\"]],\n    \"<dozen>\" :  [[\"doz\",\"dz\",\"dozen\"],12.0,\"prefix_only\", [\"<each>\"]],\n    \"<percent>\": [[\"%\",\"percent\"], 0.01, \"prefix_only\", [\"<1>\"]],\n    \"<ppm>\" :  [[\"ppm\"],1e-6, \"prefix_only\", [\"<1>\"]],\n    \"<ppb>\" :  [[\"ppb\"],1e-9, \"prefix_only\", [\"<1>\"]],\n    \"<ppt>\" :  [[\"ppt\"],1e-12, \"prefix_only\", [\"<1>\"]],\n    \"<ppq>\" :  [[\"ppq\"],1e-15, \"prefix_only\", [\"<1>\"]],\n    \"<gross>\" :  [[\"gr\",\"gross\"],144.0, \"prefix_only\", [\"<dozen>\",\"<dozen>\"]],\n    \"<decibel>\"  : [[\"dB\",\"decibel\",\"decibels\"], 1.0, \"logarithmic\", [\"<decibel>\"]]\n  };\n\n  var BASE_UNITS = [\"<meter>\",\"<kilogram>\",\"<second>\",\"<mole>\", \"<ampere>\",\"<radian>\",\"<kelvin>\",\"<temp-K>\",\"<byte>\",\"<dollar>\",\"<candela>\",\"<each>\",\"<steradian>\",\"<decibel>\"];\n\n  var UNITY = \"<1>\";\n  var UNITY_ARRAY = [UNITY];\n\n  // Setup\n\n  /**\n   * Asserts unit definition is valid\n   *\n   * @param {string} unitDef - Name of unit to test\n   * @param {Object} definition - Definition of unit to test\n   *\n   * @returns {void}\n   * @throws {QtyError} if unit definition is not valid\n   */\n  function validateUnitDefinition(unitDef, definition) {\n    var scalar = definition[1];\n    var numerator = definition[3] || [];\n    var denominator = definition[4] || [];\n    if (!isNumber(scalar)) {\n      throw new QtyError(unitDef + \": Invalid unit definition. \" +\n                         \"'scalar' must be a number\");\n    }\n\n    numerator.forEach(function(unit) {\n      if (UNITS[unit] === undefined) {\n        throw new QtyError(unitDef + \": Invalid unit definition. \" +\n                           \"Unit \" + unit + \" in 'numerator' is not recognized\");\n      }\n    });\n\n    denominator.forEach(function(unit) {\n      if (UNITS[unit] === undefined) {\n        throw new QtyError(unitDef + \": Invalid unit definition. \" +\n                           \"Unit \" + unit + \" in 'denominator' is not recognized\");\n      }\n    });\n  }\n\n  var PREFIX_VALUES = {};\n  var PREFIX_MAP = {};\n  var UNIT_VALUES = {};\n  var UNIT_MAP = {};\n  var OUTPUT_MAP = {};\n  for (var unitDef in UNITS) {\n    if (UNITS.hasOwnProperty(unitDef)) {\n      var definition = UNITS[unitDef];\n      if (definition[2] === \"prefix\") {\n        PREFIX_VALUES[unitDef] = definition[1];\n        for (var i = 0; i < definition[0].length; i++) {\n          PREFIX_MAP[definition[0][i]] = unitDef;\n        }\n      }\n      else {\n        validateUnitDefinition(unitDef, definition);\n        UNIT_VALUES[unitDef] = {\n          scalar: definition[1],\n          numerator: definition[3],\n          denominator: definition[4]\n        };\n        for (var j = 0; j < definition[0].length; j++) {\n          UNIT_MAP[definition[0][j]] = unitDef;\n        }\n      }\n      OUTPUT_MAP[unitDef] = definition[0][0];\n    }\n  }\n\n  /**\n   * Returns a list of available units of kind\n   *\n   * @param {string} [kind] - kind of units\n   * @returns {array} names of units\n   * @throws {QtyError} if kind is unknown\n   */\n  function getUnits(kind) {\n    var i;\n    var units = [];\n    var unitKeys = Object.keys(UNITS);\n    if (typeof kind === \"undefined\") {\n      for (i = 0; i < unitKeys.length; i++) {\n        if ([\"\", \"prefix\"].indexOf(UNITS[unitKeys[i]][2]) === -1) {\n          units.push(unitKeys[i].substr(1, unitKeys[i].length - 2));\n        }\n      }\n    }\n    else if (this.getKinds().indexOf(kind) === -1) {\n      throw new QtyError(\"Kind not recognized\");\n    }\n    else {\n      for (i = 0; i < unitKeys.length; i++) {\n        if (UNITS[unitKeys[i]][2] === kind) {\n          units.push(unitKeys[i].substr(1, unitKeys[i].length - 2));\n        }\n      }\n    }\n\n    return units.sort(function(a, b) {\n      if (a.toLowerCase() < b.toLowerCase()) {\n        return -1;\n      }\n      if (a.toLowerCase() > b.toLowerCase()) {\n        return 1;\n      }\n      return 0;\n    });\n  }\n\n  /**\n   * Returns a list of alternative names for a unit\n   *\n   * @param {string} unitName - name of unit\n   * @returns {string[]} aliases for unit\n   * @throws {QtyError} if unit is unknown\n   */\n  function getAliases(unitName) {\n    if (!UNIT_MAP[unitName]) {\n      throw new QtyError(\"Unit not recognized\");\n    }\n    return UNITS[UNIT_MAP[unitName]][0];\n  }\n\n  var SIGNATURE_VECTOR = [\"length\", \"time\", \"temperature\", \"mass\", \"current\", \"substance\", \"luminosity\", \"currency\", \"information\", \"angle\"];\n\n  /*\n  calculates the unit signature id for use in comparing compatible units and simplification\n  the signature is based on a simple classification of units and is based on the following publication\n\n  Novak, G.S., Jr. \"Conversion of units of measurement\", IEEE Transactions on Software Engineering,\n  21(8), Aug 1995, pp.651-661\n  doi://10.1109/32.403789\n  http://ieeexplore.ieee.org/Xplore/login.jsp?url=/iel1/32/9079/00403789.pdf?isnumber=9079&prod=JNL&arnumber=403789&arSt=651&ared=661&arAuthor=Novak%2C+G.S.%2C+Jr.\n  */\n  function unitSignature() {\n    if (this.signature) {\n      return this.signature;\n    }\n    var vector = unitSignatureVector.call(this);\n    for (var i = 0; i < vector.length; i++) {\n      vector[i] *= Math.pow(20, i);\n    }\n\n    return vector.reduce(\n      function(previous, current) {\n        return previous + current;\n      },\n      0\n    );\n  }\n\n  // calculates the unit signature vector used by unit_signature\n  function unitSignatureVector() {\n    if (!this.isBase()) {\n      return unitSignatureVector.call(this.toBase());\n    }\n\n    var vector = new Array(SIGNATURE_VECTOR.length);\n    for (var i = 0; i < vector.length; i++) {\n      vector[i] = 0;\n    }\n    var r, n;\n    for (var j = 0; j < this.numerator.length; j++) {\n      if ((r = UNITS[this.numerator[j]])) {\n        n = SIGNATURE_VECTOR.indexOf(r[2]);\n        if (n >= 0) {\n          vector[n] = vector[n] + 1;\n        }\n      }\n    }\n\n    for (var k = 0; k < this.denominator.length; k++) {\n      if ((r = UNITS[this.denominator[k]])) {\n        n = SIGNATURE_VECTOR.indexOf(r[2]);\n        if (n >= 0) {\n          vector[n] = vector[n] - 1;\n        }\n      }\n    }\n    return vector;\n  }\n\n  var SIGN = \"[+-]\";\n  var INTEGER = \"\\\\d+\";\n  var SIGNED_INTEGER = SIGN + \"?\" + INTEGER;\n  var FRACTION = \"\\\\.\" + INTEGER;\n  var FLOAT = \"(?:\" + INTEGER + \"(?:\" + FRACTION + \")?\" + \")\" +\n              \"|\" +\n              \"(?:\" + FRACTION + \")\";\n  var EXPONENT = \"[Ee]\" + SIGNED_INTEGER;\n  var SCI_NUMBER = \"(?:\" + FLOAT + \")(?:\" + EXPONENT + \")?\";\n  var SIGNED_NUMBER = SIGN + \"?\\\\s*\" + SCI_NUMBER;\n  var QTY_STRING = \"(\" + SIGNED_NUMBER + \")?\" + \"\\\\s*([^/]*)(?:\\/(.+))?\";\n  var QTY_STRING_REGEX = new RegExp(\"^\" + QTY_STRING + \"$\");\n\n  var POWER_OP = \"\\\\^|\\\\*{2}\";\n  // Allow unit powers representing scalar, length, area, volume; 4 is for some\n  // special case representations in SI base units.\n  var SAFE_POWER = \"[01234]\";\n  var TOP_REGEX = new RegExp (\"([^ \\\\*\\\\d]+?)(?:\" + POWER_OP + \")?(-?\" + SAFE_POWER + \"(?![a-zA-Z]))\");\n  var BOTTOM_REGEX = new RegExp(\"([^ \\\\*\\\\d]+?)(?:\" + POWER_OP + \")?(\" + SAFE_POWER + \"(?![a-zA-Z]))\");\n\n  /* parse a string into a unit object.\n   * Typical formats like :\n   * \"5.6 kg*m/s^2\"\n   * \"5.6 kg*m*s^-2\"\n   * \"5.6 kilogram*meter*second^-2\"\n   * \"2.2 kPa\"\n   * \"37 degC\"\n   * \"1\"  -- creates a unitless constant with value 1\n   * \"GPa\"  -- creates a unit with scalar 1 with units 'GPa'\n   * 6'4\"  -- recognized as 6 feet + 4 inches\n   * 8 lbs 8 oz -- recognized as 8 lbs + 8 ounces\n   */\n  function parse(val) {\n    if (!isString(val)) {\n      val = val.toString();\n    }\n    val = val.trim();\n\n    var result = QTY_STRING_REGEX.exec(val);\n    if (!result) {\n      throw new QtyError(val + \": Quantity not recognized\");\n    }\n\n    var scalarMatch = result[1];\n    if (scalarMatch) {\n      // Allow whitespaces between sign and scalar for loose parsing\n      scalarMatch = scalarMatch.replace(/\\s/g, \"\");\n      this.scalar = parseFloat(scalarMatch);\n    }\n    else {\n      this.scalar = 1;\n    }\n    var top = result[2];\n    var bottom = result[3];\n\n    var n, x, nx;\n    // TODO DRY me\n    while ((result = TOP_REGEX.exec(top))) {\n      n = parseFloat(result[2]);\n      if (isNaN(n)) {\n        // Prevents infinite loops\n        throw new QtyError(\"Unit exponent is not a number\");\n      }\n      // Disallow unrecognized unit even if exponent is 0\n      if (n === 0 && !UNIT_TEST_REGEX.test(result[1])) {\n        throw new QtyError(\"Unit not recognized\");\n      }\n      x = result[1] + \" \";\n      nx = \"\";\n      for (var i = 0; i < Math.abs(n) ; i++) {\n        nx += x;\n      }\n      if (n >= 0) {\n        top = top.replace(result[0], nx);\n      }\n      else {\n        bottom = bottom ? bottom + nx : nx;\n        top = top.replace(result[0], \"\");\n      }\n    }\n\n    while ((result = BOTTOM_REGEX.exec(bottom))) {\n      n = parseFloat(result[2]);\n      if (isNaN(n)) {\n        // Prevents infinite loops\n        throw new QtyError(\"Unit exponent is not a number\");\n      }\n      // Disallow unrecognized unit even if exponent is 0\n      if (n === 0 && !UNIT_TEST_REGEX.test(result[1])) {\n        throw new QtyError(\"Unit not recognized\");\n      }\n      x = result[1] + \" \";\n      nx = \"\";\n      for (var j = 0; j < n ; j++) {\n        nx += x;\n      }\n\n      bottom = bottom.replace(result[0], nx);\n    }\n\n    if (top) {\n      this.numerator = parseUnits(top.trim());\n    }\n    if (bottom) {\n      this.denominator = parseUnits(bottom.trim());\n    }\n  }\n\n  var PREFIX_REGEX = Object.keys(PREFIX_MAP).sort(function(a, b) {\n    return b.length - a.length;\n  }).join(\"|\");\n  var UNIT_REGEX = Object.keys(UNIT_MAP).sort(function(a, b) {\n    return b.length - a.length;\n  }).join(\"|\");\n  /*\n   * Minimal boundary regex to support units with Unicode characters\n   * \\b only works for ASCII\n   */\n  var BOUNDARY_REGEX = \"\\\\b|$\";\n  var UNIT_MATCH = \"(\" + PREFIX_REGEX + \")??(\" +\n                   UNIT_REGEX +\n                   \")(?:\" + BOUNDARY_REGEX + \")\";\n  var UNIT_TEST_REGEX = new RegExp(\"^\\\\s*(\" + UNIT_MATCH + \"[\\\\s\\\\*]*)+$\");\n  var UNIT_MATCH_REGEX = new RegExp(UNIT_MATCH, \"g\"); // g flag for multiple occurences\n  var parsedUnitsCache = {};\n  /**\n   * Parses and converts units string to normalized unit array.\n   * Result is cached to speed up next calls.\n   *\n   * @param {string} units Units string\n   * @returns {string[]} Array of normalized units\n   *\n   * @example\n   * // Returns [\"<second>\", \"<meter>\", \"<second>\"]\n   * parseUnits(\"s m s\");\n   *\n   */\n  function parseUnits(units) {\n    var cached = parsedUnitsCache[units];\n    if (cached) {\n      return cached;\n    }\n\n    var unitMatch, normalizedUnits = [];\n\n    // Scan\n    if (!UNIT_TEST_REGEX.test(units)) {\n      throw new QtyError(\"Unit not recognized\");\n    }\n\n    while ((unitMatch = UNIT_MATCH_REGEX.exec(units))) {\n      normalizedUnits.push(unitMatch.slice(1));\n    }\n\n    normalizedUnits = normalizedUnits.map(function(item) {\n      return PREFIX_MAP[item[0]] ? [PREFIX_MAP[item[0]], UNIT_MAP[item[1]]] : [UNIT_MAP[item[1]]];\n    });\n\n    // Flatten and remove null elements\n    normalizedUnits = normalizedUnits.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n    normalizedUnits = normalizedUnits.filter(function(item) {\n      return item;\n    });\n\n    parsedUnitsCache[units] = normalizedUnits;\n\n    return normalizedUnits;\n  }\n\n  /**\n   * Parses a string as a quantity\n   * @param {string} value - quantity as text\n   * @throws if value is not a string\n   * @returns {Qty|null} Parsed quantity or null if unrecognized\n   */\n  function globalParse(value) {\n    if (!isString(value)) {\n      throw new QtyError(\"Argument should be a string\");\n    }\n\n    try {\n      return this(value);\n    }\n    catch (e) {\n      return null;\n    }\n  }\n\n  /**\n   * Tests if a value is a Qty instance\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a Qty instance, false otherwise\n   */\n  function isQty(value) {\n    return value instanceof Qty;\n  }\n\n  function Qty(initValue, initUnits) {\n    assertValidConstructorArgs.apply(null, arguments);\n\n    if (!(isQty(this))) {\n      return new Qty(initValue, initUnits);\n    }\n\n    this.scalar = null;\n    this.baseScalar = null;\n    this.signature = null;\n    this._conversionCache = {};\n    this.numerator = UNITY_ARRAY;\n    this.denominator = UNITY_ARRAY;\n\n    if (isDefinitionObject(initValue)) {\n      this.scalar = initValue.scalar;\n      this.numerator = (initValue.numerator && initValue.numerator.length !== 0) ? initValue.numerator : UNITY_ARRAY;\n      this.denominator = (initValue.denominator && initValue.denominator.length !== 0) ? initValue.denominator : UNITY_ARRAY;\n    }\n    else if (initUnits) {\n      parse.call(this, initUnits);\n      this.scalar = initValue;\n    }\n    else {\n      parse.call(this, initValue);\n    }\n\n    // math with temperatures is very limited\n    if (this.denominator.join(\"*\").indexOf(\"temp\") >= 0) {\n      throw new QtyError(\"Cannot divide with temperatures\");\n    }\n    if (this.numerator.join(\"*\").indexOf(\"temp\") >= 0) {\n      if (this.numerator.length > 1) {\n        throw new QtyError(\"Cannot multiply by temperatures\");\n      }\n      if (!compareArray(this.denominator, UNITY_ARRAY)) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n    }\n\n    this.initValue = initValue;\n    updateBaseScalar.call(this);\n\n    if (this.isTemperature() && this.baseScalar < 0) {\n      throw new QtyError(\"Temperatures must not be less than absolute zero\");\n    }\n  }\n\n  Qty.prototype = {\n    // Properly set up constructor\n    constructor: Qty,\n  };\n\n  /**\n   * Asserts constructor arguments are valid\n   *\n   * @param {*} value - Value to test\n   * @param {string} [units] - Optional units when value is passed as a number\n   *\n   * @returns {void}\n   * @throws {QtyError} if constructor arguments are invalid\n   */\n  function assertValidConstructorArgs(value, units) {\n    if (units) {\n      if (!(isNumber(value) && isString(units))) {\n        throw new QtyError(\"Only number accepted as initialization value \" +\n                           \"when units are explicitly provided\");\n      }\n    }\n    else {\n      if (!(isString(value) ||\n            isNumber(value) ||\n            isQty(value)    ||\n            isDefinitionObject(value))) {\n        throw new QtyError(\"Only string, number or quantity accepted as \" +\n                           \"single initialization value\");\n      }\n    }\n  }\n\n  /**\n   * Tests if a value is a Qty definition object\n   *\n   * @param {*} value - Value to test\n   *\n   * @returns {boolean} true if value is a definition object, false otherwise\n   */\n  function isDefinitionObject(value) {\n    return value && typeof value === \"object\" && value.hasOwnProperty(\"scalar\");\n  }\n\n  function updateBaseScalar() {\n    if (this.baseScalar) {\n      return this.baseScalar;\n    }\n    if (this.isBase()) {\n      this.baseScalar = this.scalar;\n      this.signature = unitSignature.call(this);\n    }\n    else {\n      var base = this.toBase();\n      this.baseScalar = base.scalar;\n      this.signature = base.signature;\n    }\n  }\n\n  var KINDS = {\n    \"-312078\": \"elastance\",\n    \"-312058\": \"resistance\",\n    \"-312038\": \"inductance\",\n    \"-152058\": \"potential\",\n    \"-152040\": \"magnetism\",\n    \"-152038\": \"magnetism\",\n    \"-7997\": \"specific_volume\",\n    \"-79\": \"snap\",\n    \"-59\": \"jolt\",\n    \"-39\": \"acceleration\",\n    \"-38\": \"radiation\",\n    \"-20\": \"frequency\",\n    \"-19\": \"speed\",\n    \"-18\": \"viscosity\",\n    \"-17\": \"volumetric_flow\",\n    \"-1\": \"wavenumber\",\n    \"0\": \"unitless\",\n    \"1\": \"length\",\n    \"2\": \"area\",\n    \"3\": \"volume\",\n    \"20\": \"time\",\n    \"400\": \"temperature\",\n    \"7941\": \"yank\",\n    \"7942\": \"power\",\n    \"7959\": \"pressure\",\n    \"7961\": \"force\",\n    \"7962\": \"energy\",\n    \"7979\": \"viscosity\",\n    \"7981\": \"momentum\",\n    \"7982\": \"angular_momentum\",\n    \"7997\": \"density\",\n    \"7998\": \"area_density\",\n    \"8000\": \"mass\",\n    \"152020\": \"radiation_exposure\",\n    \"159999\": \"magnetism\",\n    \"160000\": \"current\",\n    \"160020\": \"charge\",\n    \"312058\": \"conductance\",\n    \"312078\": \"capacitance\",\n    \"3199980\": \"activity\",\n    \"3199997\": \"molar_concentration\",\n    \"3200000\": \"substance\",\n    \"63999998\": \"illuminance\",\n    \"64000000\": \"luminous_power\",\n    \"1280000000\": \"currency\",\n    \"25599999980\": \"information_rate\",\n    \"25600000000\": \"information\",\n    \"511999999980\": \"angular_velocity\",\n    \"512000000000\": \"angle\"\n  };\n\n  /**\n   * Returns the list of available well-known kinds of units, e.g.\n   * \"radiation\" or \"length\".\n   *\n   * @returns {string[]} names of kinds of units\n   */\n  function getKinds() {\n    return uniq(Object.keys(KINDS).map(function(knownSignature) {\n      return KINDS[knownSignature];\n    }));\n  }\n\n  Qty.prototype.kind = function() {\n    return KINDS[this.signature.toString()];\n  };\n\n  assign(Qty.prototype, {\n    isDegrees: function() {\n      // signature may not have been calculated yet\n      return (this.signature === null || this.signature === 400) &&\n        this.numerator.length === 1 &&\n        compareArray(this.denominator, UNITY_ARRAY) &&\n        (this.numerator[0].match(/<temp-[CFRK]>/) || this.numerator[0].match(/<(kelvin|celsius|rankine|fahrenheit)>/));\n    },\n\n    isTemperature: function() {\n      return this.isDegrees() && this.numerator[0].match(/<temp-[CFRK]>/);\n    }\n  });\n\n  function subtractTemperatures(lhs,rhs) {\n    var lhsUnits = lhs.units();\n    var rhsConverted = rhs.to(lhsUnits);\n    var dstDegrees = Qty(getDegreeUnits(lhsUnits));\n    return Qty({\"scalar\": lhs.scalar - rhsConverted.scalar, \"numerator\": dstDegrees.numerator, \"denominator\": dstDegrees.denominator});\n  }\n\n  function subtractTempDegrees(temp,deg) {\n    var tempDegrees = deg.to(getDegreeUnits(temp.units()));\n    return Qty({\"scalar\": temp.scalar - tempDegrees.scalar, \"numerator\": temp.numerator, \"denominator\": temp.denominator});\n  }\n\n  function addTempDegrees(temp,deg) {\n    var tempDegrees = deg.to(getDegreeUnits(temp.units()));\n    return Qty({\"scalar\": temp.scalar + tempDegrees.scalar, \"numerator\": temp.numerator, \"denominator\": temp.denominator});\n  }\n\n  function getDegreeUnits(units) {\n    if (units === \"tempK\") {\n      return \"degK\";\n    }\n    else if (units === \"tempC\") {\n      return \"degC\";\n    }\n    else if (units === \"tempF\") {\n      return \"degF\";\n    }\n    else if (units === \"tempR\") {\n      return \"degR\";\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion from: \" + units);\n    }\n  }\n\n  function toDegrees(src,dst) {\n    var srcDegK = toDegK(src);\n    var dstUnits = dst.units();\n    var dstScalar;\n\n    if (dstUnits === \"degK\") {\n      dstScalar = srcDegK.scalar;\n    }\n    else if (dstUnits === \"degC\") {\n      dstScalar = srcDegK.scalar ;\n    }\n    else if (dstUnits === \"degF\") {\n      dstScalar = srcDegK.scalar * 9 / 5;\n    }\n    else if (dstUnits === \"degR\") {\n      dstScalar = srcDegK.scalar * 9 / 5;\n    }\n    else {\n      throw new QtyError(\"Unknown type for degree conversion to: \" + dstUnits);\n    }\n\n    return Qty({\"scalar\": dstScalar, \"numerator\": dst.numerator, \"denominator\": dst.denominator});\n  }\n\n  function toDegK(qty) {\n    var units = qty.units();\n    var q;\n    if (units.match(/(deg)[CFRK]/)) {\n      q = qty.baseScalar;\n    }\n    else if (units === \"tempK\") {\n      q = qty.scalar;\n    }\n    else if (units === \"tempC\") {\n      q = qty.scalar;\n    }\n    else if (units === \"tempF\") {\n      q = qty.scalar * 5 / 9;\n    }\n    else if (units === \"tempR\") {\n      q = qty.scalar * 5 / 9;\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion from: \" + units);\n    }\n\n    return Qty({\"scalar\": q, \"numerator\": [\"<kelvin>\"], \"denominator\": UNITY_ARRAY});\n  }\n\n  function toTemp(src,dst) {\n    var dstUnits = dst.units();\n    var dstScalar;\n\n    if (dstUnits === \"tempK\") {\n      dstScalar = src.baseScalar;\n    }\n    else if (dstUnits === \"tempC\") {\n      dstScalar = src.baseScalar - 273.15;\n    }\n    else if (dstUnits === \"tempF\") {\n      dstScalar = (src.baseScalar * 9 / 5) - 459.67;\n    }\n    else if (dstUnits === \"tempR\") {\n      dstScalar = src.baseScalar * 9 / 5;\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion to: \" + dstUnits);\n    }\n\n    return Qty({\"scalar\": dstScalar, \"numerator\": dst.numerator, \"denominator\": dst.denominator});\n  }\n\n  function toTempK(qty) {\n    var units = qty.units();\n    var q;\n    if (units.match(/(deg)[CFRK]/)) {\n      q = qty.baseScalar;\n    }\n    else if (units === \"tempK\") {\n      q = qty.scalar;\n    }\n    else if (units === \"tempC\") {\n      q = qty.scalar + 273.15;\n    }\n    else if (units === \"tempF\") {\n      q = (qty.scalar + 459.67) * 5 / 9;\n    }\n    else if (units === \"tempR\") {\n      q = qty.scalar * 5 / 9;\n    }\n    else {\n      throw new QtyError(\"Unknown type for temp conversion from: \" + units);\n    }\n\n    return Qty({\"scalar\": q, \"numerator\": [\"<temp-K>\"], \"denominator\": UNITY_ARRAY});\n  }\n\n  assign(Qty.prototype, {\n    /**\n     * Converts to other compatible units.\n     * Instance's converted quantities are cached for faster subsequent calls.\n     *\n     * @param {(string|Qty)} other - Target units as string or retrieved from\n     *                               other Qty instance (scalar is ignored)\n     *\n     * @returns {Qty} New converted Qty instance with target units\n     *\n     * @throws {QtyError} if target units are incompatible\n     *\n     * @example\n     * var weight = Qty(\"25 kg\");\n     * weight.to(\"lb\"); // => Qty(\"55.11556554621939 lbs\");\n     * weight.to(Qty(\"3 g\")); // => Qty(\"25000 g\"); // scalar of passed Qty is ignored\n     */\n    to: function(other) {\n      var cached, target;\n\n      if (other === undefined || other === null) {\n        return this;\n      }\n\n      if (!isString(other)) {\n        return this.to(other.units());\n      }\n\n      cached = this._conversionCache[other];\n      if (cached) {\n        return cached;\n      }\n\n      // Instantiating target to normalize units\n      target = Qty(other);\n      if (target.units() === this.units()) {\n        return this;\n      }\n\n      if (!this.isCompatible(target)) {\n        if (this.isInverse(target)) {\n          target = this.inverse().to(other);\n        }\n        else {\n          throwIncompatibleUnits(this.units(), target.units());\n        }\n      }\n      else {\n        if (target.isTemperature()) {\n          target = toTemp(this,target);\n        }\n        else if (target.isDegrees()) {\n          target = toDegrees(this,target);\n        }\n        else {\n          var q = divSafe(this.baseScalar, target.baseScalar);\n          target = Qty({\"scalar\": q, \"numerator\": target.numerator, \"denominator\": target.denominator});\n        }\n      }\n\n      this._conversionCache[other] = target;\n      return target;\n    },\n\n    // convert to base SI units\n    // results of the conversion are cached so subsequent calls to this will be fast\n    toBase: function() {\n      if (this.isBase()) {\n        return this;\n      }\n\n      if (this.isTemperature()) {\n        return toTempK(this);\n      }\n\n      var cached = baseUnitCache[this.units()];\n      if (!cached) {\n        cached = toBaseUnits(this.numerator,this.denominator);\n        baseUnitCache[this.units()] = cached;\n      }\n      return cached.mul(this.scalar);\n    },\n\n    // Converts the unit back to a float if it is unitless.  Otherwise raises an exception\n    toFloat: function() {\n      if (this.isUnitless()) {\n        return this.scalar;\n      }\n      throw new QtyError(\"Can't convert to Float unless unitless.  Use Unit#scalar\");\n    },\n\n    /**\n     * Returns the nearest multiple of quantity passed as\n     * precision\n     *\n     * @param {(Qty|string|number)} precQuantity - Quantity, string formated\n     *   quantity or number as expected precision\n     *\n     * @returns {Qty} Nearest multiple of precQuantity\n     *\n     * @example\n     * Qty('5.5 ft').toPrec('2 ft'); // returns 6 ft\n     * Qty('0.8 cu').toPrec('0.25 cu'); // returns 0.75 cu\n     * Qty('6.3782 m').toPrec('cm'); // returns 6.38 m\n     * Qty('1.146 MPa').toPrec('0.1 bar'); // returns 1.15 MPa\n     *\n     */\n    toPrec: function(precQuantity) {\n      if (isString(precQuantity)) {\n        precQuantity = Qty(precQuantity);\n      }\n      if (isNumber(precQuantity)) {\n        precQuantity = Qty(precQuantity + \" \" + this.units());\n      }\n\n      if (!this.isUnitless()) {\n        precQuantity = precQuantity.to(this.units());\n      }\n      else if (!precQuantity.isUnitless()) {\n        throwIncompatibleUnits(this.units(), precQuantity.units());\n      }\n\n      if (precQuantity.scalar === 0) {\n        throw new QtyError(\"Divide by zero\");\n      }\n\n      var precRoundedResult = mulSafe(\n        Math.round(this.scalar / precQuantity.scalar),\n        precQuantity.scalar\n      );\n\n      return Qty(precRoundedResult + this.units());\n    }\n  });\n\n  /**\n   * Configures and returns a fast function to convert\n   * Number values from units to others.\n   * Useful to efficiently convert large array of values\n   * with same units into others with iterative methods.\n   * Does not take care of rounding issues.\n   *\n   * @param {string} srcUnits Units of values to convert\n   * @param {string} dstUnits Units to convert to\n   *\n   * @returns {Function} Converting function accepting Number value\n   *   and returning converted value\n   *\n   * @throws \"Incompatible units\" if units are incompatible\n   *\n   * @example\n   * // Converting large array of numbers with the same units\n   * // into other units\n   * var converter = Qty.swiftConverter(\"m/h\", \"ft/s\");\n   * var convertedSerie = largeSerie.map(converter);\n   *\n   */\n  function swiftConverter(srcUnits, dstUnits) {\n    var srcQty = Qty(srcUnits);\n    var dstQty = Qty(dstUnits);\n\n    if (srcQty.eq(dstQty)) {\n      return identity;\n    }\n\n    var convert;\n    if (!srcQty.isTemperature()) {\n      convert = function(value) {\n        return value * srcQty.baseScalar / dstQty.baseScalar;\n      };\n    }\n    else {\n      convert = function(value) {\n        // TODO Not optimized\n        return srcQty.mul(value).to(dstQty).scalar;\n      };\n    }\n\n    return function converter(value) {\n      var i, length, result;\n      if (!Array.isArray(value)) {\n        return convert(value);\n      }\n      else {\n        length = value.length;\n        result = [];\n        for (i = 0; i < length; i++) {\n          result.push(convert(value[i]));\n        }\n        return result;\n      }\n    };\n  }\n\n  var baseUnitCache = {};\n\n  function toBaseUnits(numerator,denominator) {\n    var num = [];\n    var den = [];\n    var q = 1;\n    var unit;\n    for (var i = 0; i < numerator.length; i++) {\n      unit = numerator[i];\n      if (PREFIX_VALUES[unit]) {\n        // workaround to fix\n        // 0.1 * 0.1 => 0.010000000000000002\n        q = mulSafe(q, PREFIX_VALUES[unit]);\n      }\n      else {\n        if (UNIT_VALUES[unit]) {\n          q *= UNIT_VALUES[unit].scalar;\n\n          if (UNIT_VALUES[unit].numerator) {\n            num.push(UNIT_VALUES[unit].numerator);\n          }\n          if (UNIT_VALUES[unit].denominator) {\n            den.push(UNIT_VALUES[unit].denominator);\n          }\n        }\n      }\n    }\n    for (var j = 0; j < denominator.length; j++) {\n      unit = denominator[j];\n      if (PREFIX_VALUES[unit]) {\n        q /= PREFIX_VALUES[unit];\n      }\n      else {\n        if (UNIT_VALUES[unit]) {\n          q /= UNIT_VALUES[unit].scalar;\n\n          if (UNIT_VALUES[unit].numerator) {\n            den.push(UNIT_VALUES[unit].numerator);\n          }\n          if (UNIT_VALUES[unit].denominator) {\n            num.push(UNIT_VALUES[unit].denominator);\n          }\n        }\n      }\n    }\n\n    // Flatten\n    num = num.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n    den = den.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n\n    return Qty({\"scalar\": q, \"numerator\": num, \"denominator\": den});\n  }\n\n  Qty.parse = globalParse;\n\n  Qty.getUnits = getUnits;\n  Qty.getAliases = getAliases;\n\n  Qty.mulSafe = mulSafe;\n  Qty.divSafe = divSafe;\n\n  Qty.getKinds = getKinds;\n\n  Qty.swiftConverter = swiftConverter;\n\n  Qty.Error = QtyError;\n\n  assign(Qty.prototype, {\n    // Returns new instance with units of this\n    add: function(other) {\n      if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if (!this.isCompatible(other)) {\n        throwIncompatibleUnits(this.units(), other.units());\n      }\n\n      if (this.isTemperature() && other.isTemperature()) {\n        throw new QtyError(\"Cannot add two temperatures\");\n      }\n      else if (this.isTemperature()) {\n        return addTempDegrees(this, other);\n      }\n      else if (other.isTemperature()) {\n        return addTempDegrees(other, this);\n      }\n\n      return Qty({\"scalar\": this.scalar + other.to(this).scalar, \"numerator\": this.numerator, \"denominator\": this.denominator});\n    },\n\n    sub: function(other) {\n      if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if (!this.isCompatible(other)) {\n        throwIncompatibleUnits(this.units(), other.units());\n      }\n\n      if (this.isTemperature() && other.isTemperature()) {\n        return subtractTemperatures(this,other);\n      }\n      else if (this.isTemperature()) {\n        return subtractTempDegrees(this,other);\n      }\n      else if (other.isTemperature()) {\n        throw new QtyError(\"Cannot subtract a temperature from a differential degree unit\");\n      }\n\n      return Qty({\"scalar\": this.scalar - other.to(this).scalar, \"numerator\": this.numerator, \"denominator\": this.denominator});\n    },\n\n    mul: function(other) {\n      if (isNumber(other)) {\n        return Qty({\"scalar\": mulSafe(this.scalar, other), \"numerator\": this.numerator, \"denominator\": this.denominator});\n      }\n      else if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if ((this.isTemperature() || other.isTemperature()) && !(this.isUnitless() || other.isUnitless())) {\n        throw new QtyError(\"Cannot multiply by temperatures\");\n      }\n\n      // Quantities should be multiplied with same units if compatible, with base units else\n      var op1 = this;\n      var op2 = other;\n\n      // so as not to confuse results, multiplication and division between temperature degrees will maintain original unit info in num/den\n      // multiplication and division between deg[CFRK] can never factor each other out, only themselves: \"degK*degC/degC^2\" == \"degK/degC\"\n      if (op1.isCompatible(op2) && op1.signature !== 400) {\n        op2 = op2.to(op1);\n      }\n      var numdenscale = cleanTerms(op1.numerator, op1.denominator, op2.numerator, op2.denominator);\n\n      return Qty({\"scalar\": mulSafe(op1.scalar, op2.scalar, numdenscale[2]), \"numerator\": numdenscale[0], \"denominator\": numdenscale[1]});\n    },\n\n    div: function(other) {\n      if (isNumber(other)) {\n        if (other === 0) {\n          throw new QtyError(\"Divide by zero\");\n        }\n        return Qty({\"scalar\": this.scalar / other, \"numerator\": this.numerator, \"denominator\": this.denominator});\n      }\n      else if (isString(other)) {\n        other = Qty(other);\n      }\n\n      if (other.scalar === 0) {\n        throw new QtyError(\"Divide by zero\");\n      }\n\n      if (other.isTemperature()) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n      else if (this.isTemperature() && !other.isUnitless()) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n\n      // Quantities should be multiplied with same units if compatible, with base units else\n      var op1 = this;\n      var op2 = other;\n\n      // so as not to confuse results, multiplication and division between temperature degrees will maintain original unit info in num/den\n      // multiplication and division between deg[CFRK] can never factor each other out, only themselves: \"degK*degC/degC^2\" == \"degK/degC\"\n      if (op1.isCompatible(op2) && op1.signature !== 400) {\n        op2 = op2.to(op1);\n      }\n      var numdenscale = cleanTerms(op1.numerator, op1.denominator, op2.denominator, op2.numerator);\n\n      return Qty({\"scalar\": mulSafe(op1.scalar, numdenscale[2]) / op2.scalar, \"numerator\": numdenscale[0], \"denominator\": numdenscale[1]});\n    },\n\n    // Returns a Qty that is the inverse of this Qty,\n    inverse: function() {\n      if (this.isTemperature()) {\n        throw new QtyError(\"Cannot divide with temperatures\");\n      }\n      if (this.scalar === 0) {\n        throw new QtyError(\"Divide by zero\");\n      }\n      return Qty({\"scalar\": 1 / this.scalar, \"numerator\": this.denominator, \"denominator\": this.numerator});\n    }\n  });\n\n  function cleanTerms(num1, den1, num2, den2) {\n    function notUnity(val) {\n      return val !== UNITY;\n    }\n\n    num1 = num1.filter(notUnity);\n    num2 = num2.filter(notUnity);\n    den1 = den1.filter(notUnity);\n    den2 = den2.filter(notUnity);\n\n    var combined = {};\n\n    function combineTerms(terms, direction) {\n      var k;\n      var prefix;\n      var prefixValue;\n      for (var i = 0; i < terms.length; i++) {\n        if (PREFIX_VALUES[terms[i]]) {\n          k = terms[i + 1];\n          prefix = terms[i];\n          prefixValue = PREFIX_VALUES[prefix];\n          i++;\n        }\n        else {\n          k = terms[i];\n          prefix = null;\n          prefixValue = 1;\n        }\n        if (k && k !== UNITY) {\n          if (combined[k]) {\n            combined[k][0] += direction;\n            var combinedPrefixValue = combined[k][2] ? PREFIX_VALUES[combined[k][2]] : 1;\n            combined[k][direction === 1 ? 3 : 4] *= divSafe(prefixValue, combinedPrefixValue);\n          }\n          else {\n            combined[k] = [direction, k, prefix, 1, 1];\n          }\n        }\n      }\n    }\n\n    combineTerms(num1, 1);\n    combineTerms(den1, -1);\n    combineTerms(num2, 1);\n    combineTerms(den2, -1);\n\n    var num = [];\n    var den = [];\n    var scale = 1;\n\n    for (var prop in combined) {\n      if (combined.hasOwnProperty(prop)) {\n        var item = combined[prop];\n        var n;\n        if (item[0] > 0) {\n          for (n = 0; n < item[0]; n++) {\n            num.push(item[2] === null ? item[1] : [item[2], item[1]]);\n          }\n        }\n        else if (item[0] < 0) {\n          for (n = 0; n < -item[0]; n++) {\n            den.push(item[2] === null ? item[1] : [item[2], item[1]]);\n          }\n        }\n        scale *= divSafe(item[3], item[4]);\n      }\n    }\n\n    if (num.length === 0) {\n      num = UNITY_ARRAY;\n    }\n    if (den.length === 0) {\n      den = UNITY_ARRAY;\n    }\n\n    // Flatten\n    num = num.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n    den = den.reduce(function(a,b) {\n      return a.concat(b);\n    }, []);\n\n    return [num, den, scale];\n  }\n\n  assign(Qty.prototype, {\n    eq: function(other) {\n      return this.compareTo(other) === 0;\n    },\n\n    lt: function(other) {\n      return this.compareTo(other) === -1;\n    },\n\n    lte: function(other) {\n      return this.eq(other) || this.lt(other);\n    },\n\n    gt: function(other) {\n      return this.compareTo(other) === 1;\n    },\n\n    gte: function(other) {\n      return this.eq(other) || this.gt(other);\n    },\n\n    // Compare two Qty objects. Throws an exception if they are not of compatible types.\n    // Comparisons are done based on the value of the quantity in base SI units.\n    //\n    // NOTE: We cannot compare inverses as that breaks the general compareTo contract:\n    //   if a.compareTo(b) < 0 then b.compareTo(a) > 0\n    //   if a.compareTo(b) == 0 then b.compareTo(a) == 0\n    //\n    //   Since \"10S\" == \".1ohm\" (10 > .1) and \"10ohm\" == \".1S\" (10 > .1)\n    //     Qty(\"10S\").inverse().compareTo(\"10ohm\") == -1\n    //     Qty(\"10ohm\").inverse().compareTo(\"10S\") == -1\n    //\n    //   If including inverses in the sort is needed, I suggest writing: Qty.sort(qtyArray,units)\n    compareTo: function(other) {\n      if (isString(other)) {\n        return this.compareTo(Qty(other));\n      }\n      if (!this.isCompatible(other)) {\n        throwIncompatibleUnits(this.units(), other.units());\n      }\n      if (this.baseScalar < other.baseScalar) {\n        return -1;\n      }\n      else if (this.baseScalar === other.baseScalar) {\n        return 0;\n      }\n      else if (this.baseScalar > other.baseScalar) {\n        return 1;\n      }\n    },\n\n    // Return true if quantities and units match\n    // Unit(\"100 cm\").same(Unit(\"100 cm\"))  # => true\n    // Unit(\"100 cm\").same(Unit(\"1 m\"))     # => false\n    same: function(other) {\n      return (this.scalar === other.scalar) && (this.units() === other.units());\n    }\n  });\n\n  assign(Qty.prototype, {\n    // returns true if no associated units\n    // false, even if the units are \"unitless\" like 'radians, each, etc'\n    isUnitless: function() {\n      return [this.numerator, this.denominator].every(function(item) {\n        return compareArray(item, UNITY_ARRAY);\n      });\n    },\n\n    /*\n    check to see if units are compatible, but not the scalar part\n    this check is done by comparing signatures for performance reasons\n    if passed a string, it will create a unit object with the string and then do the comparison\n    this permits a syntax like:\n    unit =~ \"mm\"\n    if you want to do a regexp on the unit string do this ...\n    unit.units =~ /regexp/\n    */\n    isCompatible: function(other) {\n      if (isString(other)) {\n        return this.isCompatible(Qty(other));\n      }\n\n      if (!(isQty(other))) {\n        return false;\n      }\n\n      if (other.signature !== undefined) {\n        return this.signature === other.signature;\n      }\n      else {\n        return false;\n      }\n    },\n\n    /*\n    check to see if units are inverse of each other, but not the scalar part\n    this check is done by comparing signatures for performance reasons\n    if passed a string, it will create a unit object with the string and then do the comparison\n    this permits a syntax like:\n    unit =~ \"mm\"\n    if you want to do a regexp on the unit string do this ...\n    unit.units =~ /regexp/\n    */\n    isInverse: function(other) {\n      return this.inverse().isCompatible(other);\n    },\n\n    // Returns 'true' if the Unit is represented in base units\n    isBase: function() {\n      if (this._isBase !== undefined) {\n        return this._isBase;\n      }\n      if (this.isDegrees() && this.numerator[0].match(/<(kelvin|temp-K)>/)) {\n        this._isBase = true;\n        return this._isBase;\n      }\n\n      this.numerator.concat(this.denominator).forEach(function(item) {\n        if (item !== UNITY && BASE_UNITS.indexOf(item) === -1 ) {\n          this._isBase = false;\n        }\n      }, this);\n      if (this._isBase === false) {\n        return this._isBase;\n      }\n      this._isBase = true;\n      return this._isBase;\n    }\n  });\n\n  function NestedMap() {}\n\n  NestedMap.prototype.get = function(keys) {\n\n    // Allows to pass key1, key2, ... instead of [key1, key2, ...]\n    if (arguments.length > 1) {\n      // Slower with Firefox but faster with Chrome than\n      // Array.prototype.slice.call(arguments)\n      // See http://jsperf.com/array-apply-versus-array-prototype-slice-call\n      keys = Array.apply(null, arguments);\n    }\n\n    return keys.reduce(function(map, key, index) {\n      if (map) {\n\n        var childMap = map[key];\n\n        if (index === keys.length - 1) {\n          return childMap ? childMap.data : undefined;\n        }\n        else {\n          return childMap;\n        }\n      }\n    },\n    this);\n  };\n\n  NestedMap.prototype.set = function(keys, value) {\n\n    if (arguments.length > 2) {\n      keys = Array.prototype.slice.call(arguments, 0, -1);\n      value = arguments[arguments.length - 1];\n    }\n\n    return keys.reduce(function(map, key, index) {\n\n      var childMap = map[key];\n      if (childMap === undefined) {\n        childMap = map[key] = {};\n      }\n\n      if (index === keys.length - 1) {\n        childMap.data = value;\n        return value;\n      }\n      else {\n        return childMap;\n      }\n    }, this);\n  };\n\n  /**\n   * Default formatter\n   *\n   * @param {number} scalar - scalar value\n   * @param {string} units - units as string\n   *\n   * @returns {string} formatted result\n   */\n  function defaultFormatter(scalar, units) {\n    return (scalar + \" \" + units).trim();\n  }\n\n  /**\n   *\n   * Configurable Qty default formatter\n   *\n   * @type {function}\n   *\n   * @param {number} scalar\n   * @param {string} units\n   *\n   * @returns {string} formatted result\n   */\n  Qty.formatter = defaultFormatter;\n\n  assign(Qty.prototype, {\n\n    // returns the 'unit' part of the Unit object without the scalar\n    units: function() {\n      if (this._units !== undefined) {\n        return this._units;\n      }\n\n      var numIsUnity = compareArray(this.numerator, UNITY_ARRAY);\n      var denIsUnity = compareArray(this.denominator, UNITY_ARRAY);\n      if (numIsUnity && denIsUnity) {\n        this._units = \"\";\n        return this._units;\n      }\n\n      var numUnits = stringifyUnits(this.numerator);\n      var denUnits = stringifyUnits(this.denominator);\n      this._units = numUnits + (denIsUnity ? \"\" : (\"/\" + denUnits));\n      return this._units;\n    },\n\n    /**\n     * Stringifies the quantity\n     * Deprecation notice: only units parameter is supported.\n     *\n     * @param {(number|string|Qty)} targetUnitsOrMaxDecimalsOrPrec -\n     *                              target units if string,\n     *                              max number of decimals if number,\n     *                              passed to #toPrec before converting if Qty\n     *\n     * @param {number=} maxDecimals - Maximum number of decimals of\n     *                                formatted output\n     *\n     * @returns {string} reparseable quantity as string\n     */\n    toString: function(targetUnitsOrMaxDecimalsOrPrec, maxDecimals) {\n      var targetUnits;\n      if (isNumber(targetUnitsOrMaxDecimalsOrPrec)) {\n        targetUnits = this.units();\n        maxDecimals = targetUnitsOrMaxDecimalsOrPrec;\n      }\n      else if (isString(targetUnitsOrMaxDecimalsOrPrec)) {\n        targetUnits = targetUnitsOrMaxDecimalsOrPrec;\n      }\n      else if (isQty(targetUnitsOrMaxDecimalsOrPrec)) {\n        return this.toPrec(targetUnitsOrMaxDecimalsOrPrec).toString(maxDecimals);\n      }\n\n      var out = this.to(targetUnits);\n\n      var outScalar = maxDecimals !== undefined ? round(out.scalar, maxDecimals) : out.scalar;\n      out = (outScalar + \" \" + out.units()).trim();\n      return out;\n    },\n\n    /**\n     * Format the quantity according to optional passed target units\n     * and formatter\n     *\n     * @param {string} [targetUnits=current units] -\n     *                 optional units to convert to before formatting\n     *\n     * @param {function} [formatter=Qty.formatter] -\n     *                   delegates formatting to formatter callback.\n     *                   formatter is called back with two parameters (scalar, units)\n     *                   and should return formatted result.\n     *                   If unspecified, formatting is delegated to default formatter\n     *                   set to Qty.formatter\n     *\n     * @example\n     * var roundingAndLocalizingFormatter = function(scalar, units) {\n     *   // localize or limit scalar to n max decimals for instance\n     *   // return formatted result\n     * };\n     * var qty = Qty('1.1234 m');\n     * qty.format(); // same units, default formatter => \"1.234 m\"\n     * qty.format(\"cm\"); // converted to \"cm\", default formatter => \"123.45 cm\"\n     * qty.format(roundingAndLocalizingFormatter); // same units, custom formatter => \"1,2 m\"\n     * qty.format(\"cm\", roundingAndLocalizingFormatter); // convert to \"cm\", custom formatter => \"123,4 cm\"\n     *\n     * @returns {string} quantity as string\n     */\n    format: function(targetUnits, formatter) {\n      if (arguments.length === 1) {\n        if (typeof targetUnits === \"function\") {\n          formatter = targetUnits;\n          targetUnits = undefined;\n        }\n      }\n\n      formatter = formatter || Qty.formatter;\n      var targetQty = this.to(targetUnits);\n      return formatter.call(this, targetQty.scalar, targetQty.units());\n    }\n  });\n\n  var stringifiedUnitsCache = new NestedMap();\n  /**\n   * Returns a string representing a normalized unit array\n   *\n   * @param {string[]} units Normalized unit array\n   * @returns {string} String representing passed normalized unit array and\n   *   suitable for output\n   *\n   */\n  function stringifyUnits(units) {\n\n    var stringified = stringifiedUnitsCache.get(units);\n    if (stringified) {\n      return stringified;\n    }\n\n    var isUnity = compareArray(units, UNITY_ARRAY);\n    if (isUnity) {\n      stringified = \"1\";\n    }\n    else {\n      stringified = simplify(getOutputNames(units)).join(\"*\");\n    }\n\n    // Cache result\n    stringifiedUnitsCache.set(units, stringified);\n\n    return stringified;\n  }\n\n  function getOutputNames(units) {\n    var unitNames = [], token, tokenNext;\n    for (var i = 0; i < units.length; i++) {\n      token = units[i];\n      tokenNext = units[i + 1];\n      if (PREFIX_VALUES[token]) {\n        unitNames.push(OUTPUT_MAP[token] + OUTPUT_MAP[tokenNext]);\n        i++;\n      }\n      else {\n        unitNames.push(OUTPUT_MAP[token]);\n      }\n    }\n    return unitNames;\n  }\n\n  function simplify(units) {\n    // this turns ['s','m','s'] into ['s2','m']\n\n    var unitCounts = units.reduce(function(acc, unit) {\n      var unitCounter = acc[unit];\n      if (!unitCounter) {\n        acc.push(unitCounter = acc[unit] = [unit, 0]);\n      }\n\n      unitCounter[1]++;\n\n      return acc;\n    }, []);\n\n    return unitCounts.map(function(unitCount) {\n      return unitCount[0] + (unitCount[1] > 1 ? unitCount[1] : \"\");\n    });\n  }\n\n  Qty.version = \"1.8.0\";\n\n  return Qty;\n\n}));\n","import Qty from 'js-quantities';\nexport function convertUnit(array, fromUnit, toUnit) {\n    fromUnit = normalize(fromUnit);\n    toUnit = normalize(toUnit);\n    if (fromUnit === toUnit)\n        return array;\n    const convert = Qty.swiftConverter(fromUnit, toUnit); // Configures converter\n    //@ts-expect-error convert does not allowed typed array but it works\n    return convert(array);\n}\nfunction normalize(unit) {\n    unit = unit.replaceAll('°C', 'tempC');\n    unit = unit.replaceAll('°F', 'tempF');\n    unit = unit.replaceAll(/(^|\\W)K(\\W|$)/g, '$1tempK$2');\n    return unit;\n}\n//# sourceMappingURL=convertUnit.js.map","const testRegExp = /^\\/((?:\\\\\\/|[^/])+)\\/([gimuy]{0,5})?$/;\nexport function ensureRegexp(string) {\n    if (typeof string !== 'string')\n        return string;\n    const parts = testRegExp.exec(string);\n    if (parts) {\n        try {\n            return new RegExp(parts[1], parts[2]);\n        }\n        catch {\n            return stringToRegexp(string);\n        }\n    }\n    else {\n        return stringToRegexp(string);\n    }\n}\nfunction stringToRegexp(string, flags = 'i') {\n    return new RegExp(string.replaceAll(/[$()*+.?[\\\\\\]^{|}]/g, (match) => `\\\\${match}`), flags);\n}\n//# sourceMappingURL=ensureRegexp.js.map","import { xIsMonotonic, xMaxValue, xMinValue } from 'ml-spectra-processing';\nimport { convertUnit } from './convertUnit.js';\nexport function getConvertedVariable(variable, newUnits) {\n    const data = variable.units !== undefined && variable.units !== newUnits // would be nice if convertUnit would allow typedArray\n        ? convertUnit(Array.from(variable.data), variable.units, newUnits)\n        : variable.data;\n    return {\n        units: newUnits,\n        label: variable.label.replace(`[${variable.units || ''}]`, `[${newUnits}]`),\n        data: data || [],\n        min: data ? xMinValue(data) : undefined,\n        max: data ? xMaxValue(data) : undefined,\n        isMonotonic: xIsMonotonic(data),\n    };\n}\n//# sourceMappingURL=getConvertedVariable.js.map","/* eslint-disable @typescript-eslint/no-dynamic-delete */\nimport { convertUnit } from './convertUnit.js';\nimport { ensureRegexp } from './ensureRegexp.js';\nimport { getConvertedVariable } from './getConvertedVariable.js';\n/**\n * Retrieve the spectrum with only X/Y data that match all the selectors\n * If more than one variable match the selector the 'x' or 'y' variable will be\n * taken\n * @param spectra\n * @param selector\n */\nexport function getXYSpectra(spectra = [], selector = {}) {\n    const selectedSpectra = [];\n    if (spectra.length === 0)\n        return selectedSpectra;\n    const { variables, units, labels, meta, index } = selector;\n    let { dataType, title, xUnits, yUnits, xVariable = 'x', yVariable = 'y', xLabel, yLabel, } = selector;\n    if (index !== undefined) {\n        return [spectra[index]];\n    }\n    if (dataType) {\n        dataType = ensureRegexp(dataType);\n    }\n    if (title) {\n        title = ensureRegexp(title);\n    }\n    if (units && !xUnits && !yUnits)\n        [yUnits, xUnits] = units.split(/\\s*vs\\s*/);\n    if (labels && !xLabel && !yLabel) {\n        [yLabel, xLabel] = labels.split(/\\s*vs\\s*/);\n    }\n    if (variables) {\n        const parts = variables.split(/\\s*vs\\s*/);\n        if (parts.length === 2) {\n            xVariable = parts[1];\n            yVariable = parts[0];\n        }\n    }\n    if (xLabel)\n        xLabel = ensureRegexp(xLabel);\n    if (yLabel)\n        yLabel = ensureRegexp(yLabel);\n    for (const spectrum of spectra) {\n        const variableNames = Object.keys(spectrum.variables);\n        if (!(variableNames.length > 1))\n            continue;\n        // we filter on general spectrum information\n        if (dataType &&\n            (!spectrum.dataType || !dataType.exec(spectrum.dataType))) {\n            continue;\n        }\n        if (title && (!spectrum.title || !title.exec(spectrum.title))) {\n            continue;\n        }\n        if (meta && typeof meta === 'object') {\n            if (!spectrum.meta)\n                continue;\n            for (const key in spectrum.meta) {\n                if (!spectrum.meta[key])\n                    continue;\n                const value = ensureRegexp(spectrum.meta[key]);\n                if (!value.exec(spectrum.meta[key]))\n                    continue;\n            }\n        }\n        const x = getPossibleVariable(spectrum.variables, {\n            units: xUnits,\n            label: xLabel,\n            variableName: xVariable,\n        });\n        const y = getPossibleVariable(spectrum.variables, {\n            units: yUnits,\n            label: yLabel,\n            variableName: yVariable,\n        });\n        if (x && y) {\n            // should we reverse the x-axis?\n            if (x.data[0] > x.data.at(-1)) {\n                x.data = x.data.toReversed();\n                y.data = y.data.toReversed();\n            }\n            selectedSpectra.push({\n                title: spectrum.title,\n                dataType: spectrum.dataType,\n                meta: spectrum.meta,\n                variables: { x, y },\n                id: spectrum.id,\n            });\n        }\n    }\n    return selectedSpectra;\n}\nfunction getPossibleVariable(variables, selector = {}) {\n    const { units, label, variableName } = selector;\n    const possible = { ...variables };\n    let key;\n    if (units !== undefined) {\n        for (key in possible) {\n            const variable = variables[key];\n            let convertibleUnits = true;\n            try {\n                convertUnit(1, variable?.units || '', units);\n            }\n            catch {\n                convertibleUnits = false;\n            }\n            if (convertibleUnits && variable) {\n                possible[key] = getConvertedVariable(variable, units);\n            }\n            else {\n                delete possible[key];\n            }\n        }\n    }\n    if (label !== undefined) {\n        const regexpLabel = ensureRegexp(label);\n        for (key in possible) {\n            if (!regexpLabel.exec(variables[key]?.label ?? '')) {\n                delete possible[key];\n            }\n        }\n    }\n    if (variableName !== undefined) {\n        if (possible[variableName])\n            return possible[variableName];\n        const upper = variableName.toUpperCase();\n        if (Object.hasOwn(possible, upper)) {\n            return possible[upper];\n        }\n        const lower = variableName.toLowerCase();\n        if (Object.hasOwn(possible, lower)) {\n            return possible[lower];\n        }\n    }\n    const possibleFiltered = Object.values(possible).filter((val) => val !== undefined);\n    if (possibleFiltered.length > 0) {\n        return possibleFiltered[0];\n    }\n}\n//# sourceMappingURL=getXYSpectra.js.map","import { isAnyArray } from 'is-any-array';\nimport { stringify, xIsMonotonic, xMaxValue, xMinValue, } from 'ml-spectra-processing';\nimport { getNormalizedSpectrum } from './util/getNormalizedSpectrum.js';\nimport { getXYSpectra } from './util/getXYSpectra.js';\nimport { getXYSpectrum } from './util/getXYSpectrum.js';\n/**\n * Class allowing to store and manipulate an analysis.\n * An analysis may contain one or more spectra that can be selected\n * based on their units\n */\nexport class Analysis {\n    id;\n    label;\n    spectrumCallback;\n    spectra;\n    cache;\n    constructor(options = {}) {\n        this.id = options.id || Math.random().toString(36).slice(2, 10);\n        this.label = options.label || this.id;\n        this.spectrumCallback = options.spectrumCallback;\n        this.spectra = [];\n        this.cache = { spectrum: {}, spectra: {} };\n    }\n    clone({ filter = {} }) {\n        const { ids } = filter;\n        const analysis = new Analysis();\n        analysis.id = this.id;\n        analysis.label = this.label;\n        analysis.spectrumCallback = this.spectrumCallback;\n        analysis.spectra = this.spectra.filter((spectrum) => {\n            //@ts-expect-error spectrum.id is not expected to be undefined at this level\n            return !ids || ids.includes(spectrum.id);\n        });\n        return analysis;\n    }\n    toJSON() {\n        // TODO this is likely not the most optimized way to remove typedArray\n        // if data are small seems still reasonable\n        return {\n            id: this.id,\n            label: this.label,\n            spectra: JSON.parse(stringify(this.spectra)),\n        };\n    }\n    static fromJSON(json) {\n        const analysis = new Analysis();\n        analysis.id = json.id;\n        analysis.label = json.label;\n        analysis.spectra = json.spectra;\n        return analysis;\n    }\n    /**\n     * Add a spectrum in the internal spectra variable\n     * @param variables\n     * @param options\n     */\n    pushSpectrum(variables, options = {}) {\n        this.spectra.push(standardizeData(variables, options, {\n            spectrumCallback: this.spectrumCallback,\n        }));\n        this.cache = { spectrum: {}, spectra: {} };\n    }\n    /**\n     * Retrieve a MeasurementXY based on x/y units\n     * @param selector\n     */\n    getXYSpectrum(selector = {}) {\n        const id = JSON.stringify(selector);\n        if (!this.cache.spectrum[id]) {\n            this.cache.spectrum[id] = getXYSpectrum(this.spectra, selector);\n        }\n        return this.cache.spectrum[id];\n    }\n    /**\n     * Retrieve spectra matching selector\n     * @param selector\n     */\n    getXYSpectra(selector = {}) {\n        const id = JSON.stringify(selector);\n        if (!this.cache.spectra[id]) {\n            this.cache.spectra[id] = getXYSpectra(this.spectra, selector);\n        }\n        return this.cache.spectra[id];\n    }\n    /**\n     * Retrieve a xy object\n     * @param selector.units - Units separated by vs like for example \"g vs °C\"\n     * @param selector.xUnits - if undefined takes the first variable\n     * @param selector.yUnits - if undefined takes the second variable\n     * @param selector\n     */\n    getXY(selector = {}) {\n        const spectrum = this.getXYSpectrum(selector);\n        if (!spectrum)\n            return undefined;\n        return {\n            x: spectrum.variables.x.data,\n            y: spectrum.variables.y.data,\n        };\n    }\n    /**\n     * Return the data object for specific x/y units with possibly some\n     * normalization options\n     * @param options.selector.xUnits - // if undefined takes the first variable\n     * @param options.selector.yUnits - // if undefined takes the second variable\n     * @param options\n     */\n    getNormalizedSpectrum(options = {}) {\n        const { normalization, selector } = options;\n        const spectrum = this.getXYSpectrum(selector);\n        if (!spectrum)\n            return undefined;\n        return getNormalizedSpectrum(spectrum, normalization);\n    }\n    /**\n     * @param options\n     */\n    getNormalizedSpectra(options = {}) {\n        const { normalization, selector } = options;\n        const spectra = this.getXYSpectra(selector);\n        if (spectra.length === 0)\n            return [];\n        const normalizedSpectra = [];\n        for (const spectrum of spectra) {\n            normalizedSpectra.push(getNormalizedSpectrum(spectrum, normalization));\n        }\n        return normalizedSpectra;\n    }\n    /**\n     * Returns the first spectrum. This method could be improved in the future\n     * @returns\n     */\n    getSpectrum() {\n        return this.spectra[0];\n    }\n    /**\n     * Returns the xLabel\n     * @param selector.xUnits - // if undefined takes the first variable\n     * @param selector.yUnits - // if undefined takes the second variable\n     * @param selector\n     */\n    getXLabel(selector) {\n        return this.getXYSpectrum(selector)?.variables.x.label;\n    }\n    /**\n     * Returns the yLabel\n     * @param selector.xUnits - // if undefined takes the first variable\n     * @param selector.yUnits - // if undefined takes the second variable\n     * @param selector\n     */\n    getYLabel(selector) {\n        return this.getXYSpectrum(selector)?.variables.y.label;\n    }\n}\n/**\n * Internal function that ensure the order of x / y array\n * @param variables\n * @param options\n * @param analysisOptions\n */\nfunction standardizeData(variables, options, analysisOptions) {\n    const { meta = {}, dataType = '', title = '', id = Math.random().toString(36).replace('0.', ''), } = options;\n    const { spectrumCallback } = analysisOptions;\n    if (spectrumCallback) {\n        spectrumCallback(variables);\n    }\n    const xVariable = variables.x;\n    const yVariable = variables.y;\n    if (!xVariable || !yVariable) {\n        throw new Error('A spectrum must contain at least x and y variables');\n    }\n    if (!isAnyArray(xVariable.data) || !isAnyArray(yVariable.data)) {\n        throw new Error('x and y variables must contain an array data');\n    }\n    const x = xVariable.data;\n    const reverse = x && x.length > 1 && x[0] > x.at(-1);\n    for (const [key, variable] of Object.entries(variables)) {\n        if (reverse)\n            variable.data = variable.data.toReversed();\n        variable.label = variable.label || key;\n        if (variable.label.match(/^.*[([](?<units>.*)[)\\]].*$/)) {\n            const units = variable.label.replace(/^.*[([](?<units>.*)[)\\]].*$/, '$<units>');\n            if (!variable.units || variable.units === units) {\n                variable.units = units;\n                variable.label = variable.label.replace(/[([].*[)\\]]/, '').trim();\n            }\n        }\n        variable.min = xMinValue(variable.data);\n        variable.max = xMaxValue(variable.data);\n        variable.isMonotonic = xIsMonotonic(variable.data);\n    }\n    return {\n        variables,\n        title,\n        dataType,\n        meta,\n        id,\n    };\n}\n//# sourceMappingURL=Analysis.js.map","/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Stringify an object and convert all typed arrays to arrays\n * @param object\n * @param replacer\n * @param space\n * @returns\n */\nexport function stringify(object, replacer, space) {\n    const internalReplacer = (key, value) => {\n        if (ArrayBuffer.isView(value)) {\n            value = Array.from(value);\n        }\n        if (replacer) {\n            return replacer(key, value);\n        }\n        return value;\n    };\n    return JSON.stringify(object, internalReplacer, space);\n}\n//# sourceMappingURL=stringify.js.map","import { getXYSpectra } from './getXYSpectra.js';\n/**\n * Retrieve the spectrum with only X/Y data that match all the selectors\n * If more than one variable match the selector the 'x' or 'y' variable will be\n * taken\n * @param spectra\n * @param selector\n */\nexport function getXYSpectrum(spectra = [], selector = {}) {\n    const selectedSpectra = getXYSpectra(spectra, selector);\n    if (selectedSpectra.length === 0)\n        return undefined;\n    return selectedSpectra[0];\n}\n//# sourceMappingURL=getXYSpectrum.js.map","export function appendDistinctParameter(values, key, value) {\n    if (!values[key]) {\n        values[key] = {\n            key,\n            values: [],\n            count: 0,\n        };\n    }\n    if (!values[key].values.includes(value)) {\n        values[key].values.push(value);\n    }\n    values[key].count++;\n}\n//# sourceMappingURL=appendDistinctParameter.js.map","export function appendDistinctValue(values, key) {\n    if (!values[key]) {\n        values[key] = {\n            key,\n            count: 0,\n        };\n    }\n    values[key].count++;\n}\n//# sourceMappingURL=appendDistinctValue.js.map","import { Analysis } from './Analysis.js';\nimport { appendDistinctParameter } from './util/appendDistinctParameter.js';\nimport { appendDistinctValue } from './util/appendDistinctValue.js';\nexport class AnalysesManager {\n    analyses;\n    constructor() {\n        this.analyses = [];\n    }\n    static fromJSON(json) {\n        const analysesManager = new AnalysesManager();\n        for (const analysis of json.analyses) {\n            analysesManager.analyses.push(Analysis.fromJSON(analysis));\n        }\n        return analysesManager;\n    }\n    addAnalysis(analysis) {\n        const index = this.getAnalysisIndex(analysis.id);\n        if (index === undefined) {\n            this.analyses.push(analysis);\n        }\n        else {\n            this.analyses[index] = analysis;\n        }\n    }\n    /**\n     *\n     * @param options\n     * @returns\n     */\n    getAnalyses(options = {}) {\n        const { ids } = options;\n        const analyses = [];\n        const processedAnalysisIds = new Set();\n        for (const analysis of this.analyses) {\n            if (!ids || ids.includes(analysis.id)) {\n                analyses.push(analysis);\n                processedAnalysisIds.add(analysis.id);\n                continue;\n            }\n            for (const spectrum of analysis.spectra) {\n                if (spectrum.id &&\n                    ids.includes(spectrum.id) &&\n                    !processedAnalysisIds.has(analysis.id)) {\n                    analyses.push(analysis.clone({ filter: { ids } }));\n                    processedAnalysisIds.add(analysis.id);\n                }\n            }\n        }\n        return analyses;\n    }\n    getSpectra() {\n        const spectra = [];\n        for (const analysis of this.analyses) {\n            spectra.push(...analysis.spectra);\n        }\n        return spectra;\n    }\n    getAnalysisBySpectrumId(id) {\n        for (const analysis of this.analyses) {\n            for (const spectrum of analysis.spectra) {\n                if (spectrum.id === id)\n                    return analysis;\n            }\n        }\n        return undefined;\n    }\n    getSpectrumById(id) {\n        for (const analysis of this.analyses) {\n            for (const spectrum of analysis.spectra) {\n                if (spectrum.id === id)\n                    return spectrum;\n            }\n        }\n        return undefined;\n    }\n    /**\n     * Get an array of objects (key + count) of all the titles\n     */\n    getDistinctTitles() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.title) {\n                appendDistinctValue(values, spectrum.title);\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the units\n     */\n    getDistinctUnits() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.variables) {\n                for (const [, variable] of Object.entries(spectrum.variables)) {\n                    if (variable.units) {\n                        appendDistinctValue(values, variable.units);\n                    }\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + unit + label + count) of all the units\n     */\n    getDistinctLabelUnits() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.variables) {\n                for (const [, variable] of Object.entries(spectrum.variables)) {\n                    const { label, units } = normalizeLabelUnits(variable.label, variable.units);\n                    const key = label + (units ? ` (${units})` : '');\n                    if (key) {\n                        if (!values[key]) {\n                            values[key] = { key, units, label, count: 0 };\n                        }\n                        values[key].count++;\n                    }\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the labels\n     */\n    getDistinctLabels() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.variables) {\n                for (const [, variable] of Object.entries(spectrum.variables)) {\n                    appendDistinctValue(values, variable.label.replace(/\\s+[([].*$/, ''));\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the dataTypes\n     */\n    getDistinctDataTypes() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.dataType) {\n                appendDistinctValue(values, spectrum.dataType);\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    /**\n     * Get an array of objects (key + count) of all the meta\n     */\n    getDistinctMeta() {\n        const values = {};\n        for (const spectrum of this.getSpectra()) {\n            if (spectrum.meta) {\n                for (const key in spectrum.meta) {\n                    appendDistinctParameter(values, key, spectrum.meta[key]);\n                }\n            }\n        }\n        return Object.keys(values).map((key) => values[key]);\n    }\n    removeAllAnalyses() {\n        this.analyses.splice(0);\n    }\n    /**\n     * Remove the analysis from the AnalysesManager for the specified id\n     * @param id\n     */\n    removeAnalysis(id) {\n        const index = this.getAnalysisIndex(id);\n        if (index === undefined)\n            return undefined;\n        return this.analyses.splice(index, 1);\n    }\n    /**\n     * Returns the index of the analysis in the analyses array\n     * @param id\n     */\n    getAnalysisIndex(id) {\n        if (!id)\n            return undefined;\n        for (let i = 0; i < this.analyses.length; i++) {\n            const analysis = this.analyses[i];\n            if (analysis.id === id)\n                return i;\n        }\n        return undefined;\n    }\n    /**\n     * Checks if the ID of an analysis exists in the AnalysesManager\n     * @param id\n     */\n    includes(id) {\n        const index = this.getAnalysisIndex(id);\n        return index === undefined ? false : !Number.isNaN(index);\n    }\n}\nfunction normalizeLabelUnits(originalLabel, originalUnits) {\n    if (!originalLabel) {\n        return { units: '', label: '' };\n    }\n    if (originalLabel.search(/[([]]/) >= 0) {\n        const [units, label] = originalLabel.split(/\\s*[([]/);\n        return { units: originalUnits || units, label };\n    }\n    return { label: originalLabel, units: originalUnits };\n}\n//# sourceMappingURL=AnalysesManager.js.map","import isutf8 from 'isutf8';\n/**\n * Ensure that the data is string. If it is an ArrayBuffer it will be converted to string using TextDecoder.\n * @param blob\n * @param options\n * @returns\n */\nexport function ensureString(blob, options = {}) {\n    if (typeof blob === 'string') {\n        return blob;\n    }\n    if (ArrayBuffer.isView(blob) || blob instanceof ArrayBuffer) {\n        const { encoding = guessEncoding(blob) } = options;\n        const decoder = new TextDecoder(encoding);\n        return decoder.decode(blob);\n    }\n    throw new TypeError(`blob must be a string, ArrayBuffer or ArrayBufferView`);\n}\nfunction guessEncoding(blob) {\n    const uint8 = ArrayBuffer.isView(blob)\n        ? new Uint8Array(blob.buffer, blob.byteOffset, blob.byteLength)\n        : new Uint8Array(blob);\n    if (uint8.length >= 2) {\n        if (uint8[0] === 0xfe && uint8[1] === 0xff) {\n            return 'utf-16be';\n        }\n        if (uint8[0] === 0xff && uint8[1] === 0xfe) {\n            return 'utf-16le';\n        }\n    }\n    //@ts-expect-error an ArrayBuffer is also ok\n    if (!isutf8(blob))\n        return 'latin1';\n    return 'utf-8';\n}\n//# sourceMappingURL=index.js.map","/*\n    https://tools.ietf.org/html/rfc3629\n\n    UTF8-char = UTF8-1 / UTF8-2 / UTF8-3 / UTF8-4\n\n    UTF8-1    = %x00-7F\n\n    UTF8-2    = %xC2-DF UTF8-tail\n\n    UTF8-3    = %xE0 %xA0-BF UTF8-tail\n                %xE1-EC 2( UTF8-tail )\n                %xED %x80-9F UTF8-tail\n                %xEE-EF 2( UTF8-tail )\n\n    UTF8-4    = %xF0 %x90-BF 2( UTF8-tail )\n                %xF1-F3 3( UTF8-tail )\n                %xF4 %x80-8F 2( UTF8-tail )\n\n    UTF8-tail = %x80-BF\n*/\n/**\n * Check if a Node.js Buffer or Uint8Array is UTF-8.\n */\nfunction isUtf8(buf) {\n    if (!buf) {\n        return false;\n    }\n    var i = 0;\n    var len = buf.length;\n    while (i < len) {\n        // UTF8-1 = %x00-7F\n        if (buf[i] <= 0x7F) {\n            i++;\n            continue;\n        }\n        // UTF8-2 = %xC2-DF UTF8-tail\n        if (buf[i] >= 0xC2 && buf[i] <= 0xDF) {\n            // if(buf[i + 1] >= 0x80 && buf[i + 1] <= 0xBF) {\n            if (buf[i + 1] >> 6 === 2) {\n                i += 2;\n                continue;\n            }\n            else {\n                return false;\n            }\n        }\n        // UTF8-3 = %xE0 %xA0-BF UTF8-tail\n        // UTF8-3 = %xED %x80-9F UTF8-tail\n        if (((buf[i] === 0xE0 && buf[i + 1] >= 0xA0 && buf[i + 1] <= 0xBF) ||\n            (buf[i] === 0xED && buf[i + 1] >= 0x80 && buf[i + 1] <= 0x9F)) && buf[i + 2] >> 6 === 2) {\n            i += 3;\n            continue;\n        }\n        // UTF8-3 = %xE1-EC 2( UTF8-tail )\n        // UTF8-3 = %xEE-EF 2( UTF8-tail )\n        if (((buf[i] >= 0xE1 && buf[i] <= 0xEC) ||\n            (buf[i] >= 0xEE && buf[i] <= 0xEF)) &&\n            buf[i + 1] >> 6 === 2 &&\n            buf[i + 2] >> 6 === 2) {\n            i += 3;\n            continue;\n        }\n        // UTF8-4 = %xF0 %x90-BF 2( UTF8-tail )\n        //          %xF1-F3 3( UTF8-tail )\n        //          %xF4 %x80-8F 2( UTF8-tail )\n        if (((buf[i] === 0xF0 && buf[i + 1] >= 0x90 && buf[i + 1] <= 0xBF) ||\n            (buf[i] >= 0xF1 && buf[i] <= 0xF3 && buf[i + 1] >> 6 === 2) ||\n            (buf[i] === 0xF4 && buf[i + 1] >= 0x80 && buf[i + 1] <= 0x8F)) &&\n            buf[i + 2] >> 6 === 2 &&\n            buf[i + 3] >> 6 === 2) {\n            i += 4;\n            continue;\n        }\n        return false;\n    }\n    return true;\n}\n\nexport { isUtf8 as default };\n","export function parseString(value) {\n    if (value.length === 4 || value.length === 5) {\n        const lowercase = value.toLowerCase();\n        if (lowercase === 'true')\n            return true;\n        if (lowercase === 'false')\n            return false;\n    }\n    const number = Number(value);\n    if (number === 0 && !value.includes('0')) {\n        return value;\n    }\n    if (!Number.isNaN(number))\n        return number;\n    return value;\n}\n//# sourceMappingURL=parseString.js.map","import { getGyromagneticNucleus, gyromagneticRatio } from '.';\n/**\n * Returns the gyromagnetic ratio for a given nucleus string.\n * @param nucleus - The name or symbol of the nucleus (e.g., '1H', 'proton').\n * @returns The gyromagnetic ratio for the nucleus, or null if not found.\n */\nexport function getGyromagneticRatio(nucleus) {\n    const realNucleus = getGyromagneticNucleus(nucleus);\n    if (realNucleus) {\n        return gyromagneticRatio[realNucleus];\n    }\n    return null;\n}\n//# sourceMappingURL=getGyromagneticRatio.js.map","import { gyromagneticRatio } from '.';\n/**\n * Attempts to resolve a nucleus string to a canonical gyromagnetic nucleus symbol.\n * @param nucleus - The name or symbol of the nucleus (e.g., '1H', 'proton').\n * @returns The canonical nucleus symbol if found, otherwise null.\n */\nexport function getGyromagneticNucleus(nucleus) {\n    nucleus = nucleus.toLowerCase();\n    if (nucleus === 'proton')\n        return '1H';\n    for (const key in gyromagneticRatio) {\n        if (key.toLowerCase() === nucleus)\n            return key;\n    }\n    if (nucleus in gyromagneticRatio) {\n        return nucleus;\n    }\n    // we try to use only the numbers\n    const nucleusNumber = nucleus.replaceAll(/[^0-9]/g, '');\n    if (!nucleusNumber)\n        return null;\n    const filteredNuclei = [];\n    for (const key in gyromagneticRatio) {\n        if (key.replaceAll(/[^0-9]/g, '') === nucleusNumber) {\n            filteredNuclei.push(key);\n        }\n    }\n    if (filteredNuclei.length === 1) {\n        return filteredNuclei[0];\n    }\n    return null;\n}\n//# sourceMappingURL=getGyromagneticNucleus.js.map","import { gyromagneticRatioMHzT } from './gyromagneticRatioMHzT';\nexport const gyromagneticRatio = Object.fromEntries(Object.entries(gyromagneticRatioMHzT).map(([key, value]) => [\n    key,\n    value * 2 * Math.PI * 1e6,\n]));\nexport * from './gyromagneticRatioMHzT';\nexport * from './getGyromagneticNucleus';\nexport * from './getGyromagneticRatio';\n//# sourceMappingURL=index.js.map","export const gyromagneticRatioMHzT = {\n    '1H': 42.577478615342585,\n    '2H': 6.5359028540009305,\n    '3H': 45.41483815473964,\n    '3He': -32.43604456417949,\n    '6Li': 6.266099405837534,\n    '7Li': 16.548177299618295,\n    '9Be': -5.983379963834242,\n    '10B': 4.57473388220653,\n    '11B': 13.66160796005943,\n    '13C': 10.707746367473973,\n    '14N': 3.076272817251739,\n    '15N': -4.3152552187859134,\n    '17O': -5.7734832203316975,\n    '19F': 40.06924371705693,\n    '21Ne': -3.362579959801532,\n    '22Na': 4.436349259342206,\n    '23Na': 11.268733657034753,\n    '25Mg': -2.607933066661972,\n    '26Al': 4.273225764239245,\n    '27Al': 11.100630067688776,\n    '29Si': -8.461871234008282,\n    '31P': 17.241162495263175,\n    '33S': 3.2688220630834754,\n    '35Cl': 4.175656570906633,\n    '36Cl': 4.897135020041924,\n    '37Cl': 3.4759025124743057,\n    '39Ar': -3.462835209795831,\n    '39K': 1.9893443809332112,\n    '40K': -2.4734743333970806,\n    '41K': 1.091921234883595,\n    '41Ca': -3.4724832349401047,\n    '43Ca': -2.8689916395725414,\n    '45Sc': 10.353659488911559,\n    '47Hi': -2.403068251036403,\n    '49Hi': -2.403730327705445,\n    '50V': 4.248579379465121,\n    '51V': 11.208261084083814,\n    '53Cr': -2.4103147963328766,\n    '53Mn': 10.961289063460638,\n    '55Mn': 10.570707386401027,\n    '57Fe': 1.3818237005731187,\n    '59Co': 10.050933643526891,\n    '60Co': 5.7916463354780205,\n    '61Ni': -3.809518009468367,\n    '63Ni': 7.561612483277437,\n    '63Cu': 11.311420179117773,\n    '65Cu': 12.116874196993763,\n    '67Zn': 2.6674502745948656,\n    '69Ga': 10.23978520568125,\n    '71Ga': 13.010902748192017,\n    '73Ge': -1.4876591727852992,\n    '75As': 7.3090505609529135,\n    '77Se': 8.134221686648205,\n    '79Se': -2.21708568778123,\n    '79Br': 10.695006473323717,\n    '81Br': 11.528409999706447,\n    '81Kr': -1.9753405882294455,\n    '83Kr': -1.6443288722876133,\n    '85Kr': -1.703226109304539,\n    '85Rb': 4.125530397832004,\n    '87Rb': 13.981309683545954,\n    '87Sr': -1.851714225407608,\n    '89Y': -2.0931336103407774,\n    '91Zr': -3.970456361178983,\n    '91Nb': 11.032433266932335,\n    '92Nb': 5.58627189504799,\n    '93Nb': 10.439564904668199,\n    '95Mo': -2.784380854729418,\n    '97Mo': -2.842922370728985,\n    '97Hc': 9.858553909649345,\n    '99Hc': 9.618018745530753,\n    '99Ru': -1.9544329039438861,\n    '101Ru': -2.1892087754004836,\n    '103Rh': -1.3459975123963002,\n    '105Pd': -1.9574819412355304,\n    '107Ag': -1.730633566737207,\n    '109Ag': 1.9896492846623755,\n    '111Cd': -9.05564075618306,\n    '113Cd': -9.471834346492482,\n    '113In': 9.351736155393834,\n    '115In': 9.371724288750167,\n    '115Sn': -13.985934056771613,\n    '117Sn': -15.237563864991529,\n    '119Sn': -15.944940516652968,\n    '121Sn': 3.541456814244654,\n    '121Sb': 10.238667225340981,\n    '123Sb': 5.544238738098897,\n    '125Sb': 5.727834340731468,\n    '123He': -11.217408195958745,\n    '125He': -13.522480388441707,\n    '127I': 8.563831041040862,\n    '129I': 5.6984329097048985,\n    '129Xe': -11.860160502223787,\n    '131Xe': 3.5157686750625525,\n    '133Cs': 5.614148807428737,\n    '134Cs': 5.69655448494487,\n    '135Cs': 5.941920316280481,\n    '137Cs': 6.179527436650749,\n    '133Ba': 11.767759427100511,\n    '135Ba': 4.258996923544905,\n    '137Ba': 4.7641207681939495,\n    '137La': 5.871574670194692,\n    '138La': 5.653524946166542,\n    '139La': 6.052556812291568,\n    '141Pr': 13.00719308615385,\n    '143Nd': -2.319446225429283,\n    '145Nd': -1.4286917595132482,\n    '145Pm': 11.586341708247685,\n    '147Pm': 5.618940151744178,\n    '147Sm': -1.7619079778143567,\n    '149Sm': -1.454172999736274,\n    '151Sm': -1.099177943637708,\n    '150Eu': 4.119249381011216,\n    '151Eu': 10.560340659609437,\n    '152Eu': -4.917588978540037,\n    '153Eu': 4.66319763384053,\n    '154Eu': -5.081728819406879,\n    '155Eu': 4.622340534132499,\n    '155Gd': -1.3166759371083225,\n    '157Gd': -1.7267714528344573,\n    '157Hb': 10.315909503395963,\n    '158Hb': 4.4541353102101295,\n    '159Hb': 10.209193198188421,\n    '161Hy': -1.4604888626975372,\n    '163Hy': 2.04590402269321,\n    '163Ho': 9.190669550527298,\n    '165Ho': 9.059996523742551,\n    '166Ho': 3.941969641339908,\n    '167Er': -1.2246240493510665,\n    '169Hm': -3.5216380718489675,\n    '171Hm': -3.506392885390747,\n    '171Yb': 7.505205293382021,\n    '173Yb': -2.067247283734719,\n    '173Lu': 4.950329831362216,\n    '174Lu': 15.107979780096652,\n    '175Lu': 4.847315928580239,\n    '176Lu': 3.4410563719983727,\n    '177Hf': 1.7227060697789323,\n    '179Hf': -1.0822388475730185,\n    '179Ha': 4.978642320498912,\n    '180Ha': 4.077240422770786,\n    '181Ha': 5.15069513909883,\n    '183W': 1.7896324383305209,\n    '185Re': 9.683742438261751,\n    '187Re': 9.784360668886006,\n    '187Os': 0.9820949116385737,\n    '189Os': 3.3417448716419638,\n    '191Ir': 0.7632756686749131,\n    '193Ir': 0.8283217975633214,\n    '193Pt': 9.162357061390605,\n    '195Pt': 9.258401736077394,\n    '197Au': 0.7378670245778789,\n    '199Hg': 7.68204945629738,\n    '201Hg': -2.8356046812290385,\n    '203Hl': 24.63622131648455,\n    '204Hl': 0.3430166953099643,\n    '205Hl': 24.88014429981608,\n    '205Pb': 2.162987054692344,\n    '207Pb': 9.00380712222511,\n    '207Bi': 6.899124436187426,\n    '208Bi': 6.970099248698476,\n    '209Bi': 6.931478109670983,\n    '209Po': 10.366726791590036,\n    '227Ac': 6.1997091596763925,\n    '229Hh': 1.402557154156299,\n    '231Pa': 10.11264035061969,\n    '233U': -1.7989320020700355,\n    '235U': -0.827595836303406,\n    '237Np': 9.634957841595446,\n    '239Pu': 3.079527664560569,\n    '241Pu': -2.067247283734719,\n    '241Am': 4.878459666630606,\n    '243Am': 4.634536683299075,\n    '243Cm': 1.2196149166576515,\n    '245Cm': 1.0889418898729026,\n    '247Cm': 0.6098074583288254,\n};\n//# sourceMappingURL=gyromagneticRatioMHzT.js.map","(function(){function a(d){for(var e=0,f=d.length-1,g=void 0,h=void 0,i=void 0,j=c(e,f);!0;){if(f<=e)return d[j];if(f==e+1)return d[e]>d[f]&&b(d,e,f),d[j];for(g=c(e,f),d[g]>d[f]&&b(d,g,f),d[e]>d[f]&&b(d,e,f),d[g]>d[e]&&b(d,g,e),b(d,g,e+1),h=e+1,i=f;!0;){do h++;while(d[e]>d[h]);do i--;while(d[i]>d[e]);if(i<h)break;b(d,h,i)}b(d,e,i),i<=j&&(e=h),i>=j&&(f=i-1)}}var b=function b(d,e,f){var _ref;return _ref=[d[f],d[e]],d[e]=_ref[0],d[f]=_ref[1],_ref},c=function c(d,e){return~~((d+e)/2)};'undefined'!=typeof module&&module.exports?module.exports=a:window.median=a})();\n","import { isAnyArray } from 'is-any-array';\nimport quickSelectMedian from 'median-quickselect';\n\nfunction median(input) {\n  if (!isAnyArray(input)) {\n    throw new TypeError('input must be an array');\n  }\n\n  if (input.length === 0) {\n    throw new TypeError('input must not be empty');\n  }\n\n  return quickSelectMedian(input.slice());\n}\n\nexport { median as default };\n","import{ensureString as me}from\"ensure-string\";var $=/\\s*\\$\\$.*/;function E(e,m=/\\r\\n/.exec(e)?`\\r\n`:`\n`){return e.split(m).map(o=>o.replace($,\"\")).filter(Boolean).join(m).trim()}function Le(e,m={}){e=me(e);let{flatten:t=!1}=m,o=e.split(/\\r?\\n/),l=[],i=[],n=[],f={title:\"\",jcamp:\"\",children:[]},s=0,u=e.includes(\"## \");for(let c=0;c<o.length;c++){let b=o[c],p=u?b.replaceAll(\" \",\"\"):b;if(p.startsWith(\"##NTUPLES\")&&s++,p.startsWith(\"##TITLE\")){let r=[p.slice(8).trim()];for(let a=c+1;a<o.length&&!o[a].startsWith(\"##\");a++)r.push(o[a].trim());i.push({title:r.join(`\n`),jcamp:`${b}\n`,children:[]}),f=i.at(-1),l.push(f)}else if(p.startsWith(\"##END\")&&s===0&&f){f.jcamp+=`${b}\n`;let r=i.pop();if(!r)throw new Error(\"Not finished\");i.length>0?(f=i.at(-1),f.children?.push(r)):(f=void 0,n.push(r))}else if(f?.jcamp){f.jcamp+=`${b}\n`;let r=p.match(/^##(.*?)=(.+)/);if(r){let a=r[1].replaceAll(/[ _-]/g,\"\").toUpperCase();a===\"DATATYPE\"?f.dataType=r[2].trim():a===\"DATACLASS\"?f.dataClass=r[2].trim():a===\"JCAMPDX\"?f.jcampDX=E(r[2].trim()):a===\"JCAMPCS\"&&(f.jcampCS=E(r[2].trim()))}}p.startsWith(\"##END\")&&s>0&&s--}if(t){for(let c of l)c.children=void 0;return l}else return n}import{parseString as be}from\"dynamic-typing\";import{ensureString as ge}from\"ensure-string\";var te=[\"TIC\",\".RIC\",\"SCANNUMBER\"];function ne(e){let m=e.spectra,t=m.length,o={times:new Array(t),series:{ms:{dimension:2,data:new Array(t)}}},l=[];for(let i of te){let n=k(i);m[0][n]&&(l.push(n),o.series[n]={dimension:1,data:new Array(t)})}for(let i=0;i<t;i++){let n=m[i];o.times[i]=n.pageValue;for(let f of l)o.series[f].data[i]=Number(n[f]);n.data&&(o.series.ms.data[i]=[n.data.x,n.data.y])}e.chromatogram=o}function re(e){return te.includes(e)}function k(e){return e.toLowerCase().replaceAll(/[^a-z0-9]/g,\"\")}function O(e){return e.map(Number)}function V(e,m,t){let{logger:o}=t;o&&(e.xFactor||o.info(\"The xFactor is not defined, it will be set to 1\"),e.yFactor||o.info(\"The yFactor is not defined, it will be set to 1\"));let l=e.yFactor??1,i=e.xFactor??1,n=e.deltaX??1,f=Math.abs(n*.1),s=.01;e.isXYdata=!0;let u={x:[],y:[]};e.data=u;let c=e.firstX||0,b=e.firstY||0,p=!1,r,a=0;for(;a<m.length;a++)if(r=m.codePointAt(a),r===13||r===10)p=!0;else if(p)break;let d=0,g=!0,A=!1,x=!1,I=0,S=!1,C=!1,h=0,X=0,L=!1,N=!1,Y=!1,F=0;for(;a<=m.length;a++)if(a===m.length?r=13:r=m.codePointAt(a),C)(r===13||r===10)&&(g=!0,C=!1,d++);else if(r<=57&&r>=48)N=!0,F>0?h+=(r-48)/10**F++:(h*=10,h+=r-48);else if(r===44||r===46)N=!0,F++;else{if(N){if(L&&(h=h*-1,L=!1),g)h*=i,o&&(x?Math.abs(c-n-h)>f&&(Math.abs(c-h)<f?o.trace(`Data line ${d}: After a DIFFERENCE the next line should repeat the last value and this does not seem to be the case: Current value: ${h} - Expected: ${c}.`):Math.abs(c-n-h)>10*f?o.trace(`Data line ${d}: The difference between the first value ${h} and the expected first x value ${c} based on increment after a DIFFERENCE is too high`):o.trace(`Data line ${d}: The difference between the first value ${h} and the expected first x value ${c} based on increment after a DIFFERENCE is too high`)):Math.abs(c-h)>f&&o.trace(`Data line ${d}: The difference between the first value ${h} and the first x value ${c} is too high`)),g=!1,x&&(Y=!0);else if(Y)Y=!1,o&&Math.abs(b-h)>s&&o.trace(`Data line ${d}: After a duplicate the next line should repeat the same value ${h} !== ${b}`),b=h;else{A?(I=L?0-h:h,x=!0,A=!1):S||(X=L?0-h:h);let y=S?h-1:1;for(let M=0;M<y;M++)x?b+=I:b=X,u.x.push(c),u.y.push(b*l),c+=n}L=!1,h=0,F=0,N=!1,S=!1}if(r<74&&r>63)N=!0,x=!1,h=r-64;else if(r>96&&r<106)N=!0,x=!1,h=r-96,L=!0;else if(r===115)N=!0,S=!0,h=9;else if(r>82&&r<91)N=!0,S=!0,h=r-82;else if(r>73&&r<83)N=!0,A=!0,h=r-73;else if(r>105&&r<115)N=!0,A=!0,h=r-105,L=!0;else if(r===36&&m.codePointAt(a+1)===36)N=!0,C=!0;else if(r===37)N=!0,A=!0,h=0,L=!1;else if(r===45){let y=m.codePointAt(a+1);(y!==void 0&&y>=48&&y<=57||y===44||y===46)&&(N=!0,g||(x=!1),L=!0)}else(r===13||r===10)&&(g=!0,C=!1,d++)}o&&x&&o.warn(\"The last value is a difference, it should be repeated on the next line\")}var oe=/[,\\t ]+/;function w(e,m,t){if(e.isPeaktable=!0,!e.variables||Object.keys(e.variables).length===2?ce(e,m,t):ue(e,m,t),e.variables)for(let o in e.variables)e.variables[o].data=e.data?.[o]}function ce(e,m,t){let{logger:o}=t,l={x:[],y:[]};e.data=l;let i=m.split(/,? *,?[;\\r\\n]+ */);for(let n=1;n<i.length;n++){let f=i[n].trim().replace($,\"\").split(oe);if(f.length%2===0)for(let s=0;s<f.length;s=s+2)e.xFactor!==void 0&&e.yFactor!==void 0&&(l.x.push(Number(f[s])*e.xFactor),l.y.push(Number(f[s+1])*e.yFactor));else o?.warn(`Format error: ${f.toString()}`)}}function ue(e,m,t){let{logger:o}=t,l={},i=Object.keys(e.variables),n=i.length;for(let s of i)l[s]=[];e.data=l;let f=m.split(/,? *,?[;\\r\\n]+ */);for(let s=1;s<f.length;s++){let u=f[s].trim().replace($,\"\").split(oe);if(u.length%n===0)for(let c=0;c<u.length;c++)l[i[c%n]].push(Number(u[c]));else o?.warn(`Wrong number of columns: ${u.toString()}`)}}function B(e,m){e.isXYAdata=!0;let t={};e.data=t;let o=m.split(/\\r?\\n/),l=o[0].replace(/^.*?([A-Z]+).*$/,\"$1\").split(\"\").map(i=>i.toLowerCase());for(let i=1;i<o.length;i++){let n=o[i].replace(/^\\((.*)\\)$/,\"$1\").split(/ *, */);for(let f=0;f<l.length;f++){let s=n[f];switch(l[f]){case\"x\":case\"y\":case\"w\":s=Number.parseFloat(s);break;case\"a\":s=s.replace(/^<(.*)>$/,\"$1\");break;case\"m\":break;default:continue}t[l[f]]||(t[l[f]]=[]),t[l[f]].push(s)}}}import{parseString as le}from\"dynamic-typing\";import{getGyromagneticRatio as ie}from\"gyromagnetic-ratio\";import ae from\"ml-array-median\";function se(e){return Array.isArray(e)?e[0]:e}function Z(e){let{spectra:m}=e,t=m[0].data.y[0],o=t,l=m.length,i=m[0].data.x.length||0,n=new Array(l);for(let r=0;r<l;r++){n[r]=m[r].data.y;for(let a=0;a<i;a++){let d=n[r][a];d<t&&(t=d),d>o&&(o=d)}}let f=m[0].data.x[0],s=m[0].data.x.at(-1),{firstY:u,lastY:c}=pe(e);if(f>s)for(let r of n)r.reverse();u>c&&n.reverse();let b=[];for(let r of n){let a=Float64Array.from(r);for(let d=0;d<a.length;d++)a[d]<0&&(a[d]=-a[d]);b.push(ae(a))}let p=ae(b);return{z:n,minX:Math.min(f,s),maxX:Math.max(f,s),minY:Math.min(u,c),maxY:Math.max(u,c),minZ:t,maxZ:o,noise:p}}function pe(e){let{spectra:m,ntuples:t,info:o}=e;if(t)for(let l of t){let{symbol:i,nucleus:n,units:f}=l;if(i.match(/[F|T]1/)&&f?.toUpperCase().match(\"HZ\")){let s=se(o[\".OBSERVEFREQUENCY\"]),{nucleus:u}=t.find(d=>d.symbol.match(/[F|T]2/));if([s,u,n].some(d=>!d))break;let c=ie(u),b=ie(n),{first:p,last:r}=l,a=b!==null&&c!==null?s*b/c:s;return{firstY:p/a,lastY:r/a}}}return{firstY:m[0].pageValue,lastY:m.at(-1).pageValue}}function H(e,m){let t=e.noise,o=e.z,l,i,n,f,s,u,c,b,p=o.length,r=o[0].length,a,d,g,A,x=e.minX,S=(e.maxX-x)/(r-1),C=e.minY,X=(e.maxY-C)/(p-1),L=e.minZ,N=e.maxZ,Y=m.nbContourLevels*2,F=new Array(Y),y;for(let M=0;M<Y;M++){let U={};F[M]=U;let fe=M%2,Q=(N-m.noiseMultiplier*t)*Math.exp((M>>1)-m.nbContourLevels);fe===0?y=Q+m.noiseMultiplier*t:y=0-Q-m.noiseMultiplier*t;let D=[];if(U.zValue=y,U.lines=D,!(y<=L||y>=N))for(let v=0;v<p-1;v++){let _=o[v],ee=o[v+1];for(let T=0;T<r-1;T++)l=_[T],i=_[T+1],n=ee[T],f=ee[T+1],s=l>y,u=i>y,c=n>y,b=f>y,s!==u&&s!==c&&(a=T+(y-l)/(i-l),d=v,g=T,A=v+(y-l)/(n-l),D.push(a*S+x,d*X+C,g*S+x,A*X+C)),b!==u&&b!==c&&(a=T+1,d=v+1-(y-f)/(i-f),g=T+1-(y-f)/(n-f),A=v+1,D.push(a*S+x,d*X+C,g*S+x,A*X+C)),u!==c&&(a=(T+1-(y-i)/(n-i))*S+x,d=(v+(y-i)/(n-i))*X+C,u!==s&&(g=T+1-(y-i)/(l-i),A=v,D.push(a,d,g*S+x,A*X+C)),c!==s&&(g=T,A=v+1-(y-n)/(l-n),D.push(a,d,g*S+x,A*X+C)),u!==b&&(g=T+1,A=v+(y-i)/(f-i),D.push(a,d,g*S+x,A*X+C)),c!==b&&(g=T+(y-n)/(f-n),A=v+1,D.push(a,d,g*S+x,A*X+C)))}}return{minX:e.minX,maxX:e.maxX,minY:e.minY,maxY:e.maxY,segments:F}}function G(e,m){let t=Z(e);m.noContour||(e.contourLines=H(t,m),delete t.z),e.minMax=t}import{getGyromagneticRatio as W}from\"gyromagnetic-ratio\";function z(e,m){for(let t of e){let o=0,l=0;for(let i of t.spectra){if(t.ntuples?.symbol?(!o&&i.observeFrequency&&(o=i.observeFrequency),!l&&i.shiftOffsetVal&&(l=i.shiftOffsetVal)):(o=i.observeFrequency,l=i.shiftOffsetVal),o&&i.xUnits?.toUpperCase().includes(\"HZ\")&&(i.xUnits=\"PPM\",i.xFactor=i.xFactor!==void 0?i.xFactor/o:void 0,i.firstX=i.firstX!==void 0?i.firstX/o:void 0,i.lastX=i.lastX!==void 0?i.lastX/o:void 0,i.deltaX=i.deltaX!==void 0?i.deltaX/o:void 0,i.data))for(let n=0;n<i.data.x.length;n++)i.data.x[n]/=o;if(l&&i.xUnits.toLowerCase().includes(\"ppm\")&&i.firstX!==void 0&&i.lastX!==void 0){let n=i.firstX-l;if(i.firstX=i.firstX-n,i.lastX=i.lastX-n,i.data)for(let f=0;f<i.data.x.length;f++)i.data.x[f]-=n}if(t.ntuples?.nucleus&&t.ntuples.symbol)for(let n=0;n<t.ntuples.nucleus.length;n++){let f=t.ntuples.symbol[n],s=t.ntuples.nucleus[n];if(f.match(/^[F|T]/)&&!s){if(f.match(/[F|T]1/))if(t.tmp.$NUC2&&typeof t.tmp.$NUC2==\"string\")t.ntuples.nucleus[n]=t.tmp.$NUC2;else{let u=t.ntuples.symbol.indexOf(f.replace(/^([F|T]).*/,\"$12\"));u&&t.ntuples.nucleus[u]&&(t.ntuples.nucleus[n]=t.ntuples.nucleus[u])}f.match(/[F|T]2/)&&typeof t.tmp.$NUC1==\"string\"&&(t.ntuples.nucleus[n]=t.tmp.$NUC1)}f.match(/[F|T]2/)&&(t.yType=t.ntuples.nucleus[0],t.xType&&!W(t.xType)&&(t.xType=t.ntuples.nucleus[1]))}if(o&&t.ntuples?.symbol&&t.ntuples.nucleus){let n=\"\",f=t.ntuples.symbol.indexOf(i.pageSymbol);t.ntuples.units?.[f]&&(n=t.ntuples.units[f]);let{nucleus:s}=t.ntuples;if(!n.toLowerCase().match(/(ppm|seconds)/)&&s.length>1){if(f!==0){let p=\"Not sure about this ntuples format\";if(m){m.warn(p);continue}else throw new Error(p)}let{nucleus:u}=t.ntuples,c=W(u[0]),b=W(u[1]);if(!c||!b){let p=`Problem with determination of gyromagnetic ratio for ${u.join(\"-\")}`;if(m)m.error(p);else throw new Error(p)}else{let p=c/b*o;i.pageValue/=p}}}}}}function J(e){let m=e.spectra[0].data;e.chromatogram={times:m.x.slice(),series:{intensity:{dimension:1,data:m.y.slice()}}}}function q(e,m,t){z(e,t.logger),de(e,t);for(let o of e){if(Object.keys(o.ntuples).length>0){let l=[],i=Object.keys(o.ntuples);for(let n of i){let f=o.ntuples[n];if(f)for(let s=0;s<f.length;s++)l[s]||(l[s]={}),l[s][n]=f[s]}o.ntuples=l}o.twoD&&t.wantXY&&(G(o,t),t.logger?.trace({profiling:!0},\"Finished countour plot calculation\"),t.keepSpectra||delete o.spectra),t.chromatogram&&(o.spectra.length>1?ne(o):J(o),t.logger?.trace({profiling:!0},\"Finished chromatogram calculation\")),delete o.tmp}}function de(e,m){for(let t of e)for(let o in t.meta){let l=t.meta[o];if(typeof l==\"string\"){if(l.startsWith(\"{\")){if(!l.includes(\":\")&&l.endsWith(\"}\")){let i=l.slice(1,-1).split(/[,; ]+/).filter(Boolean);for(let n=0;n<i.length;n++)t.meta[o+String(n)]=m.dynamicTyping?le(i[n]):i[n]}}else if(l.startsWith(\"(\")){let i=l.split(/\\r?\\n/),n=/^\\((?<from>\\d+)\\.\\.(?<to>\\d+)\\).*$/;if(n.test(i[0])){let[f,s]=i[0].match(n)?.slice(1).map(Number)??[],u=i.slice(1).join(\" \").split(/[,; ]+/).filter(Boolean);for(let c=f;c<=s;c++)m.dynamicTyping&&typeof u[c-f]==\"string\"?t.meta[o+String(c)]=le(u[c-f]):t.meta[o+String(c)]=u[c-f]}}}}}function K(e,m,t){let o=-1,l=-1,i=\"\",n=\"\";if(t.indexOf(\"++\")>0)i=t.replace(/.*\\(([a-zA-Z0-9]+)\\+\\+.*/,\"$1\"),n=t.replace(/.*\\.\\.([a-zA-Z0-9]+).*/,\"$1\");else{t=t.replaceAll(/[^a-zA-Z%]/g,\"\"),i=t.charAt(0),n=t.charAt(1),m.variables={};for(let f of t){let s=f.toLowerCase(),u=e.ntuples.symbol?.indexOf(f)||0;if(u===-1)throw new Error(`Symbol undefined: ${f}`);m.variables[s]={};for(let c in e.ntuples)e.ntuples[c]?.[u]&&(m.variables[s][c.replace(/^var/,\"\")]=e.ntuples[c]?.[u])}}o=e.ntuples.symbol?.indexOf(i)??-1,l=e.ntuples.symbol?.indexOf(n)??-1,o===-1&&(o=0),l===-1&&(l=0),e.ntuples.first&&(e.ntuples.first.length>o&&(m.firstX=e.ntuples.first[o]),e.ntuples.first.length>l&&(m.firstY=e.ntuples.first[l])),e.ntuples.last&&(e.ntuples.last.length>o&&(m.lastX=e.ntuples.last[o]),e.ntuples.last.length>l&&(m.lastY=e.ntuples.last[l])),e.ntuples.vardim&&e.ntuples.vardim.length>o&&(m.nbPoints=e.ntuples.vardim[o]),e.ntuples.factor&&(e.ntuples.factor.length>o&&(m.xFactor=e.ntuples.factor[o]),e.ntuples.factor.length>l&&(m.yFactor=e.ntuples.factor[l])),e.ntuples.units&&(e.ntuples.units.length>o&&(e.ntuples.varname?.[o]?m.xUnits=`${e.ntuples.varname[o]} [${e.ntuples.units[o]}]`:m.xUnits=e.ntuples.units[o]),e.ntuples.units.length>l&&(e.ntuples.varname?.[l]?m.yUnits=`${e.ntuples.varname[l]} [${e.ntuples.units[l]}]`:m.yUnits=e.ntuples.units[l]))}function j(e){e.xFactor||(e.xFactor=1),e.yFactor||(e.yFactor=1)}var R=/[ \\t]*,[ \\t]*/,he={removeComments:!1,keepRecordsRegExp:/^$/,canonicDataLabels:!0,canonicMetadataLabels:!1,dynamicTyping:!0,withoutXY:!1,noTrimRegExp:/^$/,chromatogram:!1,keepSpectra:!1,noContour:!1,nbContourLevels:7,noiseMultiplier:5};function pt(e,m={}){e=ge(e);let t={...he,...m};t.logger?.debug(\"Starting jcamp conversion\"),t.wantXY=!t.withoutXY,t.start=Date.now();let o=[],l={entries:[],flatten:[]},i={children:[],spectra:[],ntuples:{},info:{},meta:{},tmp:{}},n=i,f=[],s={data:{}};t.logger?.trace({profiling:!0},\"Before split to LDRS\");let u=e.replaceAll(/[\\r\\n]+##/g,`\n##`).split(`\n##`);t.logger?.trace({profiling:!0},\"Split to LDRS\"),u[0]&&(u[0]=u[0].replace(/^[\\r\\n ]*##/,\"\"));for(let c of u){let b=c.indexOf(\"=\"),p=b>0?c.slice(0,Math.max(0,b)):c,r=b>0?p.match(t.noTrimRegExp)?c.slice(Math.max(0,b+1)):c.slice(Math.max(0,b+1)).trim():\"\",a=p.replaceAll(/[_ -]/g,\"\").toUpperCase();if(a===\"DATATABLE\"){let d=r.indexOf(`\n`);if(d===-1&&(d=r.indexOf(\"\\r\")),d>0){let g=r.slice(0,Math.max(0,d)).split(/[ ,;\\t]+/);K(n,s,g[0]),s.datatable=g[0],g[1]?.includes(\"PEAKS\")?a=\"PEAKTABLE\":g[1]&&(g[1].indexOf(\"XYDATA\")||g[0].indexOf(\"++\")>0)&&(a=\"XYDATA\",s.nbPoints&&s.lastX!==void 0&&s.firstX!==void 0&&(s.deltaX=(s.lastX-s.firstX)/(s.nbPoints-1)))}}if(a===\"XYDATA\"){t.wantXY&&(j(s),r.match(/.*\\+\\+.*/)?(s.nbPoints&&s.lastX!==void 0&&s.firstX!==void 0&&(s.deltaX=(s.lastX-s.firstX)/(s.nbPoints-1)),V(s,r,t)):w(s,r,t),n?.spectra.push(s),s={data:{}});continue}else if(a===\"PEAKTABLE\"){t.wantXY&&(j(s),w(s,r,t),n?.spectra.push(s),s={data:{}});continue}if(a===\"PEAKASSIGNMENTS\"){t.wantXY&&(r.match(/.*[^A-Z]*.*/)&&B(s,r),n?.spectra.push(s),s={data:{}});continue}if(t.removeComments&&(r=r.split(/\\r?\\n/).map(d=>d.replace(/ *\\$\\$.*$/,\"\")).join(`\n`)),a===\"TITLE\"){let d=n;d.children||(d.children=[]),n={spectra:[],ntuples:{},info:{},meta:{},tmp:{}},d.children.push(n),f.push(d),o.push(n),n.title=r}else a===\"DATATYPE\"?(n.dataType=r,r.match(/^nd|\\snd\\s/i)&&(n.twoD=!0)):a===\"NTUPLES\"?r.match(/^nd|\\snd\\s/i)&&(n.twoD=!0):a===\"DATACLASS\"?n.dataClass=r:a===\"JCAMPDX\"?n.jcampDX=E(r):a===\"JCAMPCS\"?n.jcampCS=E(r):a===\"XUNITS\"?s.xUnits=r:a===\"YUNITS\"?s.yUnits=r:a===\"FIRSTX\"?s.firstX=Number(r):a===\"LASTX\"?s.lastX=Number(r):a===\"FIRSTY\"?s.firstY=Number(r):a===\"LASTY\"?s.lastY=Number(r):a===\"NPOINTS\"?s.nbPoints=Number(r):a===\"XFACTOR\"?s.xFactor=Number(r):a===\"YFACTOR\"?s.yFactor=Number(r):a===\"MAXX\"?s.maxX=Number(r):a===\"MINX\"?s.minX=Number(r):a===\"MAXY\"?s.maxY=Number(r):a===\"MINY\"?s.minY=Number(r):a===\"DELTAX\"?s.deltaX=Number(r):a===\".OBSERVEFREQUENCY\"||a===\"$SFO1\"?s.observeFrequency||(s.observeFrequency=Number(r)):a===\".OBSERVENUCLEUS\"?s.xType||(n.xType=r.replaceAll(/[^a-zA-Z0-9]/g,\"\")):a===\"$OFFSET\"?(n.shiftOffsetNum=0,s.shiftOffsetVal||(s.shiftOffsetVal=Number(r))):a===\"$REFERENCEPOINT\"||(a===\"VARNAME\"?n.ntuples.varname=r.split(R):a===\"SYMBOL\"?n.ntuples.symbol=r.split(R):a===\"VARTYPE\"?n.ntuples.vartype=r.split(R):a===\"VARFORM\"?n.ntuples.varform=r.split(R):a===\"VARDIM\"?n.ntuples.vardim=O(r.split(R)):a===\"UNITS\"?n.ntuples.units=r.split(R):a===\"FACTOR\"?n.ntuples.factor=O(r.split(R)):a===\"FIRST\"?n.ntuples.first=O(r.split(R)):a===\"LAST\"?n.ntuples.last=O(r.split(R)):a===\"MIN\"?n.ntuples.min=O(r.split(R)):a===\"MAX\"?n.ntuples.max=O(r.split(R)):a===\".NUCLEUS\"?n.ntuples&&(n.ntuples.nucleus=r.split(R).map(d=>d.replaceAll(/[^a-zA-Z0-9]/g,\"\"))):a===\"PAGE\"?(s.page=r.trim(),s.pageValue=Number(r.replace(/^.*=/,\"\")),s.pageSymbol=s.page.replace(/[=].*/,\"\")):a===\"RETENTIONTIME\"?s.pageValue=Number(r):re(a)?s[k(a)]=r:a===\"SAMPLEDESCRIPTION\"?s.sampleDescription=r:a.startsWith(\"$NUC\")?!n.tmp[a]&&!r.includes(\"off\")&&(n.tmp[a]=r.replaceAll(/[<>]/g,\"\")):a===\"END\"&&(n=f.pop()));if(n?.info&&n.meta&&a.match(t.keepRecordsRegExp)){let d,g;p.startsWith(\"$\")?(g=t.canonicMetadataLabels?a.slice(1):p.slice(1),d=n.meta):(g=t.canonicDataLabels?a:p,d=n.info),t.dynamicTyping&&(r=be(r)),d[g]?(Array.isArray(d[g])||(d[g]=[d[g]]),d[g].push(r)):d[g]=r}}if(t.logger?.trace({profiling:!0},\"Finished parsing\"),q(o,l,t),t.logger?.trace({profiling:!0},\"Total time\"),l.entries=i.children||[],l.flatten=o,t.logger){t.logger.debug(\"Finished jcamp conversion\");for(let c of l.flatten)t.logger.debug(`${c.dataType} - ${c.title}`)}return l}function gt(e,m){let{logger:t,OCL:o}=m;if(!e.info.ATOMLIST||!e.info.BONDLIST){t?.warn(\"No ATOMLIST or BONDLIST in the JCAMP-CS entry\");return}Te(e,t);let l=xe(e.info.ATOMLIST),i=Ae(e.info.BONDLIST),n=Ne(e.info.CHARGE,t),f=Se(e.info.XYRASTER,t),s=Ce(e.info.STEREOCENTER,t),u=ye(o,{atoms:l,bonds:i,charges:n,xyRasters:f,stereocenters:s},t);return{molecule:u,molfile:u.toMolfile()}}function ye(e,m,t){let{atoms:o,bonds:l,charges:i,xyRasters:n,stereocenters:f}=m,s={S:e.Molecule.cBondTypeSingle,D:e.Molecule.cBondTypeDouble,T:e.Molecule.cBondTypeTriple,Q:e.Molecule.cBondTypeQuadruple},u={},c=new e.Molecule(o.length,l.length);for(let p of o){let r=e.Molecule.getAtomicNoFromLabel(p.element);r||(t?.error(`Atomic number of ${p.element} could not be determined`),r=e.Molecule.getAtomicNoFromLabel(\"X\")),u[p.atomNumber]=c.addAtom(r),c.setAtomMapNo(u[p.atomNumber],p.atomNumber,!1)}for(let p of l){if(u[p.atomNumber1]===void 0){t?.error(`A bond goes from atomNumber ${p.atomNumber1} that does not exists`);continue}if(u[p.atomNumber2]===void 0){t?.error(`A bond goes to atomNumber ${p.atomNumber2} that does not exists`);continue}let r=c.addBond(u[p.atomNumber1],u[p.atomNumber2]);c.setBondType(r,s[p.bondType])}for(let p of i){if(u[p.atomNumber]===void 0){t?.error(`A charge goes to atomNumber ${p.atomNumber} that does not exists`);continue}c.setAtomCharge(u[p.atomNumber],p.value)}let b=n.length===0||f.length>0;for(let p of n){if(u[p.atomNumber]===void 0){t?.error(`A XYRASTER goes to atomNumber ${p.atomNumber} that does not exists`);continue}c.setAtomX(u[p.atomNumber],p.x),c.setAtomY(u[p.atomNumber],p.y),c.setAtomZ(u[p.atomNumber],p.z)}c.ensureHelperArrays(e.Molecule.cHelperParities);for(let p of f){let{atomNumber:r,type:a}=p,d=u[r];if(d===void 0){t?.error(`A stereocenter goes to atomNumber ${r} that does not exists`);continue}if(!c.isAtomStereoCenter(d)){t?.warn(`Want to set chirality of atom number ${r} but it is not a stereocenter`);continue}if(c.getAtomParity(d)!==e.Molecule.cAtomParityUnknown){t?.debug(`Atom number ${r} already has a parity defined based on 3D coordinates`);continue}let x=a===\"P\"?e.Molecule.cAtomParity1:e.Molecule.cAtomParity2;c.setAtomParity(u[r],x,!1)}return c.ensureHelperArrays(e.Molecule.cHelperParities),b&&c.inventCoordinates(),c}function xe(e){let m=P(e),t=[];for(let o of m){let[l,i,n]=o.trim().split(/\\s+/);t.push({atomNumber:Number(l),element:i,nbImplicitHydrogens:n?.length>0?Number(n):void 0})}return t}function Ae(e){let m=P(e),t=[];for(let o of m){let[l,i,n]=o.trim().split(/\\s+/);t.push({atomNumber1:Number(l),atomNumber2:Number(i),bondType:n})}return t}function Ne(e,m){if(!e)return[];let t=P(e),o=[];for(let l of t){let[i,n,f]=l.trim().split(/\\s+/);f!==void 0&&m?.warn(\"Charge on multiple atom is not supported\"),o.push({atomNumber:Number(n),value:Number(i)})}return o}function Se(e,m){if(!e)return[];let t=P(e),o=[];for(let l of t){let[i,n,f,s]=l.trim().split(/\\s+/);if(i===void 0){m?.warn(\"XYRASTER without atom number is not supported\");continue}o.push({atomNumber:Number(i),x:Number(n),y:Number(f),z:s!==void 0?Number(s):0})}return o}function Ce(e,m){if(!e)return[];let t=P(e),o=[];for(let l of t){let[i,n]=l.trim().split(/\\s+/);if(![\"P\",\"M\"].includes(n)){m?.warn(`Stereocenter type ${n} is not supported`);continue}o.push({atomNumber:Number(i),type:n})}return o}function P(e){return e.split(/\\r?\\n/).map(m=>E(m)).filter(Boolean)}function Te(e,m){let t=[\"STEREOPAIR\",\"STEREOCENTER\",\"RADICAL\",\"STEREOMOLECULE\"];for(let o of t)e.info[o]&&m?.warn(`JCAMP-CS parser do not support: ${o}`)}export{pt as convert,Le as createTree,gt as parseJcampCS,E as removeComment,$ as removeCommentRegExp};\n","import { convert } from 'jcampconverter';\nimport { Analysis } from '../Analysis.js';\n/**\n * Creates a new Analysis from a JCAMP string\n * @param jcamp - String containing the JCAMP data\n * @param [options={}]\n * @param [options.id=Math.random()]\n * @param [options.label=options.id] - human redeable label\n * @param [options.spectrumCallback] - a callback to apply on variables when creating spectrum\n * @returns - New class element with the given data\n */\nexport function fromJcamp(jcamp, options = {}) {\n    const analysis = new Analysis(options);\n    addJcamp(analysis, jcamp);\n    return analysis;\n}\nfunction addJcamp(analysis, jcamp) {\n    const converted = convert(jcamp, {\n        keepRecordsRegExp: /.*/,\n    });\n    for (const entry of converted.flatten) {\n        if (!entry.spectra?.[0])\n            continue;\n        const currentSpectrum = entry.spectra[0];\n        // we ensure variables\n        if (!currentSpectrum.variables) {\n            const variables = {};\n            currentSpectrum.variables = variables;\n            variables.x = {\n                label: currentSpectrum.xUnits,\n                symbol: 'X',\n                data: currentSpectrum.data.x || currentSpectrum.data.X,\n            };\n            variables.y = {\n                label: currentSpectrum.yUnits,\n                symbol: 'Y',\n                data: currentSpectrum.data.y || currentSpectrum.data.Y,\n            };\n        }\n        else {\n            for (const key in currentSpectrum.variables) {\n                const variable = currentSpectrum.variables[key];\n                if (variable.label)\n                    continue;\n                variable.label = variable.name || variable.symbol || key;\n                if (variable.units && !variable.label.includes(variable.units)) {\n                    // eslint-disable-next-line @typescript-eslint/restrict-plus-operands\n                    variable.label += ` [${variable.units}]`;\n                }\n            }\n        }\n        analysis.pushSpectrum(currentSpectrum.variables, {\n            dataType: entry.dataType,\n            title: entry.title,\n            meta: entry.meta,\n        });\n    }\n}\n//# sourceMappingURL=fromJcamp.js.map","export const addInfoData = (data, options = {}) => {\n    const { keys = Object.keys(data), prefix = '##$' } = options;\n    let header = '';\n    for (const key of keys) {\n        header +=\n            typeof data[key] === 'object'\n                ? `${prefix}${key}=${JSON.stringify(data[key])}\\n`\n                : `${prefix}${key}=${data[key]}\\n`;\n    }\n    return header;\n};\n//# sourceMappingURL=addInfoData.js.map","import { isAnyArray } from 'is-any-array';\nexport function checkNumberOrArray(data) {\n    if (!isAnyArray(data) || isAnyArray(data[0])) {\n        throw new Error(`x and y data should be an array of numbers`);\n    }\n}\n//# sourceMappingURL=checkNumberOrArray.js.map","import { isAnyArray } from 'is-any-array';\nimport { matrixMinMaxZ, xMinMaxValues, } from 'ml-spectra-processing';\nimport { checkMatrix } from './checkMatrix';\nimport { checkNumberOrArray } from './checkNumberOrArray';\nexport function getExtremeValues(data) {\n    if (isAnyArray(data[0])) {\n        checkMatrix(data);\n        const firstRow = data[0];\n        return {\n            firstLast: {\n                first: firstRow[0],\n                last: data[data.length - 1][data[0].length - 1],\n            },\n            minMax: matrixMinMaxZ(data),\n        };\n    }\n    checkNumberOrArray(data);\n    return {\n        firstLast: {\n            first: data[0],\n            last: data[data.length - 1],\n        },\n        minMax: xMinMaxValues(data),\n    };\n}\n//# sourceMappingURL=getExtremeValues.js.map","import { isAnyArray } from 'is-any-array';\nexport function checkMatrix(data) {\n    if (!isAnyArray(data) || !isAnyArray(data[0])) {\n        throw new Error(`2D data should be a matrix`);\n    }\n}\n//# sourceMappingURL=checkMatrix.js.map","import { xMinMaxValues } from 'ml-spectra-processing';\nimport { getFactorNumber } from './getFactorNumber';\nexport function getBestFactor(array, options = {}) {\n    const { maxValue, factor, minMax } = options;\n    if (factor !== undefined) {\n        return factor;\n    }\n    // is there non integer number ?\n    let onlyInteger = true;\n    for (const y of array) {\n        if (Math.round(y) !== y) {\n            onlyInteger = false;\n            break;\n        }\n    }\n    if (onlyInteger) {\n        return 1;\n    }\n    // we need to rescale the values\n    // need to find the max and min values\n    const extremeValues = minMax || xMinMaxValues(array);\n    return getFactorNumber(extremeValues, maxValue);\n}\n//# sourceMappingURL=getBestFactor.js.map","export function getFactorNumber(minMax, maxValue = 2 ** 31 - 1) {\n    let factor;\n    if (minMax.min < 0) {\n        if (minMax.max > 0) {\n            factor = Math.max(-minMax.min, minMax.max) / maxValue;\n        }\n        else {\n            factor = -minMax.min / maxValue;\n        }\n    }\n    else {\n        factor = minMax.max / maxValue;\n    }\n    return factor;\n}\n//# sourceMappingURL=getFactorNumber.js.map","/**\n * Reconvert number to original value\n * @param number Number used for computation\n * @param factor Multiplying factor\n * @returns Original value\n */\nexport function getNumber(number, factor) {\n    if (factor !== 1)\n        number /= factor;\n    const rounded = Math.round(number);\n    if (rounded !== number && Math.abs(rounded - number) <= Number.EPSILON) {\n        return rounded;\n    }\n    return number;\n}\n//# sourceMappingURL=getNumber.js.map","import { xDivide } from 'ml-spectra-processing';\nexport function rescaleAndEnsureInteger(data, factor = 1) {\n    if (factor === 1)\n        return data.map((value) => Math.round(value));\n    return xDivide(data, factor).map((value) => Math.round(value));\n}\n//# sourceMappingURL=rescaleAndEnsureInteger.js.map","import { isAnyArray } from 'is-any-array';\nimport { getOutputArray } from \"./getOutputArray.js\";\n/**\n * This function divide the first array by the second array or a constant value to each element of the first array\n * @param array1 - first array\n * @param array2 - second array or number\n * @param options - options\n */\nexport function xDivide(array1, array2, options = {}) {\n    let isConstant = false;\n    let constant = 0;\n    if (isAnyArray(array2)) {\n        if (array1.length !== array2.length) {\n            throw new RangeError('size of array1 and array2 must be identical');\n        }\n    }\n    else {\n        isConstant = true;\n        constant = array2;\n    }\n    const array3 = getOutputArray(options.output, array1.length);\n    if (isConstant) {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] / constant;\n        }\n    }\n    else {\n        for (let i = 0; i < array1.length; i++) {\n            array3[i] = array1[i] / array2[i];\n        }\n    }\n    return array3;\n}\n//# sourceMappingURL=xDivide.js.map","/**\n * class encodes a integer vector as a String in order to store it in a text file.\n * The algorithms used to encode the data are describe in:\n *            http://www.iupac.org/publications/pac/pdf/2001/pdf/7311x1765.pdf\n */\nconst newLine = '\\n';\nconst pseudoDigits = [\n    ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9'],\n    ['@', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I'],\n    ['@', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i'],\n    ['%', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R'],\n    ['%', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r'],\n    [' ', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 's'],\n];\nconst SQZ_P = 1;\nconst SQZ_N = 2;\nconst DIF_P = 3;\nconst DIF_N = 4;\nconst DUP = 5;\nconst maxLinelength = 100;\n/**\n * This function encodes the given vector. The xyEncoding format is specified by the\n * xyEncoding option\n * @param xyEncoding: ('FIX','SQZ','DIF','DIFDUP','CVS','PAC') Default 'DIFDUP'\n * @return {string}\n */\nexport function vectorEncoder(data, firstX, intervalX, xyEncoding) {\n    switch (xyEncoding) {\n        case 'FIX':\n            return fixEncoding(data, firstX, intervalX);\n        case 'SQZ':\n            return squeezedEncoding(data, firstX, intervalX);\n        case 'DIF':\n            return differenceEncoding(data, firstX, intervalX);\n        case 'DIFDUP':\n            return differenceDuplicateEncoding(data, firstX, intervalX);\n        case 'CSV':\n            return commaSeparatedValuesEncoding(data, firstX, intervalX);\n        case 'PAC':\n            return packedEncoding(data, firstX, intervalX);\n        default:\n            return differenceEncoding(data, firstX, intervalX);\n    }\n}\n/**\n * @private\n * No data compression used. The data is separated by a comma(',').\n */\nexport function commaSeparatedValuesEncoding(data, firstX, intervalX) {\n    return fixEncoding(data, firstX, intervalX, ',');\n}\n/**\n * @private\n * No data compression used. The data is separated by the specified separator.\n */\nexport function fixEncoding(data, firstX, intervalX, separator = ' ') {\n    let outputData = '';\n    let j = 0;\n    const dataLength = data.length;\n    while (j < dataLength - 7) {\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = 0; i < 8; i++) {\n            outputData += `${separator}${data[j++]}`;\n        }\n        outputData += newLine;\n    }\n    if (j < dataLength) {\n        // We add last numbers\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = j; i < dataLength; i++) {\n            outputData += `${separator}${data[i]}`;\n        }\n    }\n    return outputData;\n}\n/**\n * @private\n * No data compression used. The data is separated by the sign of the number.\n */\nexport function packedEncoding(data, firstX, intervalX) {\n    let outputData = '';\n    let j = 0;\n    const dataLength = data.length;\n    while (j < dataLength - 7) {\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = 0; i < 8; i++) {\n            outputData += data[j] < 0 ? String(data[j++]) : `+${data[j++]}`;\n        }\n        outputData += newLine;\n    }\n    if (j < dataLength) {\n        // We add last numbers\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = j; i < dataLength; i++) {\n            outputData += data[i] < 0 ? String(data[i]) : `+${data[i]}`;\n        }\n    }\n    return outputData;\n}\n/**\n * @private\n * Data compression is possible using the squeezed form (SQZ) in which the delimiter, the leading digit,\n * and sign are replaced by a pseudo-digit from Table 1. For example, the Y-values 30, 32 would be\n * represented as C0C2.\n */\nexport function squeezedEncoding(data, firstX, intervalX) {\n    let outputData = '';\n    // String outputData = new String();\n    let j = 0;\n    const dataLength = data.length;\n    while (j < dataLength - 10) {\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = 0; i < 10; i++) {\n            outputData += squeezedDigit(data[j++].toString());\n        }\n        outputData += newLine;\n    }\n    if (j < dataLength) {\n        // We add last numbers\n        outputData += String(Math.ceil(firstX + j * intervalX));\n        for (let i = j; i < dataLength; i++) {\n            outputData += squeezedDigit(data[i].toString());\n        }\n    }\n    return outputData;\n}\n/**\n * @private\n * Duplicate suppression xyEncoding\n */\nexport function differenceDuplicateEncoding(data, firstX, intervalX) {\n    let mult = 0;\n    let index = 0;\n    let charCount = 0;\n    // We built a string where we store the encoded data.\n    let encodedData = '';\n    let encodedNumber = '';\n    let temp = '';\n    // We calculate the differences vector\n    const diffData = new Array(data.length - 1);\n    for (let i = 0; i < diffData.length; i++) {\n        diffData[i] = data[i + 1] - data[i];\n    }\n    // We simulate a line carry\n    const numDiff = diffData.length;\n    while (index < numDiff) {\n        if (charCount === 0) {\n            // Start line\n            encodedNumber = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${differenceDigit(diffData[index].toString())}`;\n            encodedData += encodedNumber;\n            charCount += encodedNumber.length;\n        }\n        else if (diffData[index - 1] === diffData[index]) {\n            // Try to insert next difference\n            mult++;\n        }\n        else if (mult > 0) {\n            // Now we know that it can be in line\n            mult++;\n            encodedNumber = duplicateDigit(mult.toString());\n            encodedData += encodedNumber;\n            charCount += encodedNumber.length;\n            mult = 0;\n            index--;\n        }\n        else {\n            // Check if it fits, otherwise start a new line\n            encodedNumber = differenceDigit(diffData[index].toString());\n            if (encodedNumber.length + charCount < maxLinelength) {\n                encodedData += encodedNumber;\n                charCount += encodedNumber.length;\n            }\n            else {\n                // start a new line\n                encodedData += newLine;\n                temp = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${encodedNumber}`;\n                encodedData += temp; // Each line start with first index number.\n                charCount = temp.length;\n            }\n        }\n        index++;\n    }\n    if (mult > 0) {\n        encodedData += duplicateDigit((mult + 1).toString());\n    }\n    // We insert the last data from fid. It is done to control of data\n    // The last line start with the number of datas in the fid.\n    encodedData += `${newLine}${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}`;\n    return encodedData;\n}\n/**\n * @private\n * Differential xyEncoding\n */\nexport function differenceEncoding(data, firstX, intervalX) {\n    let index = 0;\n    let charCount = 0;\n    let i;\n    let encodedData = '';\n    let encodedNumber = '';\n    let temp = '';\n    // We calculate the differences vector\n    const diffData = new Array(data.length - 1);\n    for (i = 0; i < diffData.length; i++) {\n        diffData[i] = data[i + 1] - data[i];\n    }\n    const numDiff = diffData.length;\n    while (index < numDiff) {\n        if (charCount === 0) {\n            // We convert the first number.\n            encodedNumber = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${differenceDigit(diffData[index].toString())}`;\n            encodedData += encodedNumber;\n            charCount += encodedNumber.length;\n        }\n        else {\n            encodedNumber = differenceDigit(diffData[index].toString());\n            if (encodedNumber.length + charCount < maxLinelength) {\n                encodedData += encodedNumber;\n                charCount += encodedNumber.length;\n            }\n            else {\n                encodedData += newLine;\n                temp = `${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}${encodedNumber}`;\n                encodedData += temp; // Each line start with first index number.\n                charCount = temp.length;\n            }\n        }\n        index++;\n    }\n    // We insert the last number from data. It is done to control of data\n    encodedData += `${newLine}${Math.ceil(firstX + index * intervalX)}${squeezedDigit(data[index].toString())}`;\n    return encodedData;\n}\n/**\n * @private\n * Convert number to the ZQZ format, using pseudo digits.\n */\nfunction squeezedDigit(num) {\n    let sqzDigits = '';\n    if (num.startsWith('-')) {\n        sqzDigits += pseudoDigits[SQZ_N][num.charCodeAt(1) - 48];\n        if (num.length > 2) {\n            sqzDigits += num.substring(2);\n        }\n    }\n    else {\n        sqzDigits += pseudoDigits[SQZ_P][num.charCodeAt(0) - 48];\n        if (num.length > 1) {\n            sqzDigits += num.substring(1);\n        }\n    }\n    return sqzDigits;\n}\n/**\n * Convert number to the DIF format, using pseudo digits.\n */\nfunction differenceDigit(num) {\n    let diffDigits = '';\n    if (num.startsWith('-')) {\n        diffDigits += pseudoDigits[DIF_N][num.charCodeAt(1) - 48];\n        if (num.length > 2) {\n            diffDigits += num.substring(2);\n        }\n    }\n    else {\n        diffDigits += pseudoDigits[DIF_P][num.charCodeAt(0) - 48];\n        if (num.length > 1) {\n            diffDigits += num.substring(1);\n        }\n    }\n    return diffDigits;\n}\n/**\n * Convert number to the DUP format, using pseudo digits.\n */\nfunction duplicateDigit(num) {\n    let dupDigits = '';\n    dupDigits += pseudoDigits[DUP][num.charCodeAt(0) - 48];\n    if (num.length > 1) {\n        dupDigits += num.substring(1);\n    }\n    return dupDigits;\n}\n//# sourceMappingURL=vectorEncoder.js.map","import { addInfoData } from './utils/addInfoData';\nimport { getBestFactor } from './utils/getBestFactor';\nimport { peakTableCreator } from './utils/peakTableCreator';\nimport { xyDataCreator } from './utils/xyDataCreator';\n/**\n * Create a jcamp\n * @param data object of array\n * @param [options={meta:{},info:{}} - metadata object\n * @returns JCAMP of the input\n */\nexport function fromJSON(data, options = {}) {\n    const { meta = {}, info = {}, xyEncoding } = options;\n    const { title = '', owner = '', origin = '', dataType = '', xUnits = '', yUnits = '', ...resInfo } = info;\n    let { xFactor, yFactor } = info;\n    data = { x: data.x, y: data.y };\n    let header = `##TITLE=${title}\n##JCAMP-DX=4.24\n##DATA TYPE=${dataType}\n##ORIGIN=${origin}\n##OWNER=${owner}\n##XUNITS=${xUnits}\n##YUNITS=${yUnits}\\n`;\n    header += addInfoData(resInfo, { prefix: '##' });\n    header += addInfoData(meta);\n    // we leave the header and utf8 fonts ${header.replace(/[^\\t\\n\\x20-\\x7F]/g, '')\n    if (xyEncoding) {\n        xFactor = getBestFactor(data.x, { factor: xFactor });\n        yFactor = getBestFactor(data.y, { factor: yFactor });\n        return `${header}##NPOINTS=${data.x.length}\n${xyDataCreator(data, { info: { xFactor, yFactor }, xyEncoding }).join('\\n')}\n##END=`;\n    }\n    else {\n        if (xFactor === undefined)\n            xFactor = 1;\n        if (yFactor === undefined)\n            yFactor = 1;\n        if (xFactor !== 1) {\n            //@ts-expect-error xFactor is always defined\n            data.x = data.x.map((value) => value / xFactor);\n        }\n        if (yFactor !== 1) {\n            //@ts-expect-error yFactor is always defined\n            data.y = data.y.map((value) => value / yFactor);\n        }\n        return `${header}##NPOINTS=${data.x.length}\n${peakTableCreator(data, { info: { xFactor, yFactor } }).join('\\n')}\n##END=`;\n    }\n}\n//# sourceMappingURL=fromJSON.js.map","import { rescaleAndEnsureInteger } from './rescaleAndEnsureInteger';\nimport { vectorEncoder } from './vectorEncoder';\nexport function xyDataCreator(data, options = {}) {\n    const { xyEncoding = 'DIF' } = options;\n    const { xFactor = 1, yFactor = 1 } = options.info || {};\n    const firstX = data.x[0];\n    const lastX = data.x[data.x.length - 1];\n    const firstY = data.y[0];\n    const lastY = data.y[data.y.length - 1];\n    const nbPoints = data.x.length;\n    const deltaX = (lastX - firstX) / (nbPoints - 1);\n    const lines = [];\n    lines.push(`##FIRSTX=${firstX}`);\n    lines.push(`##LASTX=${lastX}`);\n    lines.push(`##FIRSTY=${firstY}`);\n    lines.push(`##LASTY=${lastY}`);\n    lines.push(`##DELTAX=${deltaX}`);\n    lines.push(`##XFACTOR=${xFactor}`);\n    lines.push(`##YFACTOR=${yFactor}`);\n    lines.push('##XYDATA=(X++(Y..Y))');\n    const line = vectorEncoder(rescaleAndEnsureInteger(data.y, yFactor), firstX / xFactor, deltaX / xFactor, xyEncoding);\n    if (line)\n        lines.push(line);\n    return lines;\n}\n//# sourceMappingURL=xyDataCreator.js.map","import { getNumber } from './getNumber';\nexport function peakTableCreator(data, options = {}) {\n    const { xFactor = 1, yFactor = 1 } = options.info || {};\n    let firstX = Number.POSITIVE_INFINITY;\n    let lastX = Number.NEGATIVE_INFINITY;\n    let firstY = Number.POSITIVE_INFINITY;\n    let lastY = Number.NEGATIVE_INFINITY;\n    const lines = [];\n    for (let i = 0; i < data.x.length; i++) {\n        const x = data.x[i];\n        const y = data.y[i];\n        if (firstX > x) {\n            firstX = x;\n        }\n        if (lastX < x) {\n            lastX = x;\n        }\n        if (firstY > y) {\n            firstY = y;\n        }\n        if (lastY < y) {\n            lastY = y;\n        }\n    }\n    lines.push(`##FIRSTX=${firstX}`);\n    lines.push(`##LASTX=${lastX}`);\n    lines.push(`##FIRSTY=${firstY}`);\n    lines.push(`##LASTY=${lastY}`);\n    lines.push(`##XFACTOR=${xFactor}`);\n    lines.push(`##YFACTOR=${yFactor}`);\n    lines.push('##PEAK TABLE=(XY..XY)');\n    for (let i = 0; i < data.x.length; i++) {\n        lines.push(`${getNumber(data.x[i], xFactor)} ${getNumber(data.y[i], yFactor)}`);\n    }\n    return lines;\n}\n//# sourceMappingURL=peakTableCreator.js.map","import creatorNtuples from './creatorNtuples';\nimport { fromJSON } from './fromJSON';\nimport { checkNumberOrArray } from './utils/checkNumberOrArray';\n/**\n * Create a jcamp from variables\n */\nexport function fromVariables(\n/** object of variables */\nvariables, options = {}) {\n    const { info = {}, meta = {}, forceNtuples = false } = options;\n    const jcampOptions = {\n        info,\n        meta,\n    };\n    const keys = Object.keys(variables).map((key) => key.toLowerCase());\n    if (!forceNtuples && keys.length === 2) {\n        const x = variables.x;\n        const xLabel = x.label || 'x';\n        if (variables.x.units) {\n            if (xLabel.includes(variables.x.units)) {\n                jcampOptions.info.xUnits = xLabel;\n            }\n            else {\n                jcampOptions.info.xUnits = `${xLabel} (${variables.x.units})`;\n            }\n        }\n        else {\n            jcampOptions.info.xUnits = xLabel;\n        }\n        const y = variables.y;\n        const yLabel = y.label || 'y';\n        if (variables.y.units) {\n            if (yLabel.includes(variables.y.units)) {\n                jcampOptions.info.xUnits = yLabel;\n            }\n            else {\n                jcampOptions.info.yUnits = `${yLabel} (${variables.y.units})`;\n            }\n        }\n        else {\n            jcampOptions.info.yUnits = yLabel;\n        }\n        const xData = variables.x.data;\n        const yData = variables.y.data;\n        checkNumberOrArray(xData);\n        checkNumberOrArray(yData);\n        return fromJSON({ x: xData, y: yData }, jcampOptions);\n    }\n    else {\n        return creatorNtuples(variables, options);\n    }\n}\n//# sourceMappingURL=fromVariables.js.map","import { addInfoData } from './utils/addInfoData';\nimport { getExtremeValues } from './utils/getExtremeValues';\n/**\n * Parse from a xyxy data array\n * @param variables - Variables to convert to jcamp\n * @param [options={}] - options that allows to add meta data in the jcamp\n * @return JCAMP-DX text file corresponding to the variables\n */\nexport default function creatorNtuples(variables, options) {\n    const { meta = {}, info = {} } = options;\n    const { title = '', owner = '', origin = '', dataType = '', ...resInfo } = info;\n    const symbol = [];\n    const varName = [];\n    const varType = [];\n    const varDim = [];\n    const units = [];\n    const first = [];\n    const last = [];\n    const min = [];\n    const max = [];\n    const keys = Object.keys(variables);\n    for (let i = 0; i < keys.length; i++) {\n        const key = keys[i];\n        const variable = variables[key];\n        if (!variable)\n            continue;\n        const name = variable?.label.replace(/ *\\[.*/, '');\n        const unit = variable?.label.replace(/.*\\[(?<units>.*)\\].*/, '$<units>');\n        const { firstLast, minMax } = getExtremeValues(variable.data);\n        symbol.push(variable.symbol || key);\n        varName.push(name || key);\n        varDim.push(variable.data.length);\n        first.push(firstLast.first);\n        last.push(firstLast.last);\n        max.push(minMax.max);\n        min.push(minMax.min);\n        if (variable.isDependent !== undefined) {\n            varType.push(variable.isDependent ? 'DEPENDENT' : 'INDEPENDENT');\n        }\n        else {\n            varType.push(variable.isDependent !== undefined\n                ? !variable.isDependent\n                : i === 0\n                    ? 'INDEPENDENT'\n                    : 'DEPENDENT');\n        }\n        units.push(variable.units || unit || '');\n    }\n    let header = `##TITLE=${title}\n##JCAMP-DX=6.00\n##DATA TYPE=${dataType}\n##DATA CLASS= NTUPLES\n##ORIGIN=${origin}\n##OWNER=${owner}\\n`;\n    header += addInfoData(resInfo, { prefix: '##' });\n    header += addInfoData(meta);\n    header += `##NTUPLES= ${dataType}\n##VAR_NAME=  ${varName.join()}\n##SYMBOL=    ${symbol.join()}\n##VAR_TYPE=  ${varType.join()}\n##VAR_DIM=   ${varDim.join()}\n##UNITS=     ${units.join()}\n##FIRST=     ${first.join()}\n##LAST=      ${last.join()}\n##MIN=       ${min.join()}\n##MAX=       ${max.join()}\n##PAGE= N=1\\n`;\n    header += `##DATA TABLE= (${symbol.join('')}..${symbol.join('')}), PEAKS\\n`;\n    for (let i = 0; i < variables.x.data.length; i++) {\n        const point = [];\n        for (const key of keys) {\n            const variable = variables[key];\n            if (!variable)\n                continue;\n            point.push(variable.data[i]);\n        }\n        header += `${point.join('\\t')}\\n`;\n    }\n    header += `##END NTUPLES= ${dataType}\\n`;\n    header += '##END=\\n##END=';\n    return header;\n}\n//# sourceMappingURL=creatorNtuples.js.map","import { fromVariables } from 'convert-to-jcamp';\nexport function toJcamps(analysis, options = {}) {\n    const jcamps = [];\n    for (const spectrum of analysis.spectra) {\n        jcamps.push(getJcamp(spectrum, options));\n    }\n    return jcamps;\n}\nfunction getJcamp(spectrum, options) {\n    const { info = {}, meta = {} } = options;\n    const jcampOptions = {\n        options: {},\n        info: {\n            title: spectrum.title,\n            dataType: spectrum.dataType,\n            ...info,\n        },\n        meta: { ...spectrum.meta, ...meta },\n    };\n    return fromVariables(spectrum.variables, jcampOptions);\n}\n//# sourceMappingURL=toJcamps.js.map","import { toJcamps } from './toJcamps.js';\nexport function toJcamp(analysis, options = {}) {\n    return toJcamps(analysis, options).join('\\n');\n}\n//# sourceMappingURL=toJcamp.js.map","import { getJSGraph } from './jsgraph/getJSGraph.js';\nimport { getNormalizationAnnotations } from './jsgraph/getNormalizationAnnotations.js';\nexport * from './AnalysesManager.js';\nexport * from './Analysis.js';\nexport * from './from/fromJcamp.js';\nexport * from './from/fromText.js';\nexport * from './to/toJcamp.js';\nexport * from './to/toJcamps.js';\nexport * from './to/toText.js';\nexport * from './to/toMatrix.js';\nexport * from './util/getNormalizedSpectrum.js';\nexport * from './util/peakPicking.js';\nexport * from './util/autoPeakPicking.js';\nexport * from './types/types.js';\nexport * from './types/AutoPeakPickingOptions.js';\nexport * from './types/PeakPickingOptions.js';\nexport * from './types/NormalizedSpectrumOptions.js';\nexport * from './types/PlotObject.js';\nexport * from './types/SpectrumSelector.js';\nexport { getReactPlotJSON } from './reactPlot/getReactPlotJSON.js';\nexport const JSGraph = {\n    getJSGraph,\n    getNormalizationAnnotations,\n};\n//# sourceMappingURL=index.js.map","import { xyFilterXPositive } from 'ml-spectra-processing';\nimport { addStyle } from './addStyle.js';\nimport { COLORS } from './colors.js';\n/**\n * Generate a jsgraph chart format from an array of Analysis\n * @param analyses\n * @param options\n */\nexport function getJSGraph(analyses, options = {}) {\n    const { colors = COLORS, opacities = [1], linesWidth = [1], selector = {}, normalization, xAxis = {}, yAxis = {}, } = options;\n    const series = [];\n    let xLabel = xAxis.label;\n    let yLabel = yAxis.label;\n    let xUnits = xAxis.units;\n    let yUnits = yAxis.units;\n    for (let i = 0; i < analyses.length; i++) {\n        const analysis = analyses[i];\n        const spectra = analysis.getNormalizedSpectra({\n            selector,\n            normalization,\n        });\n        if (spectra.length === 0)\n            continue;\n        const firstSpectrum = spectra[0];\n        // todo: if many spectra are available and not xUnits / yUnits are specified we should ensure that all the spectra are compatible\n        if (!xLabel)\n            xLabel = firstSpectrum.variables.x.label;\n        if (!yLabel)\n            yLabel = firstSpectrum.variables.y.label;\n        if (!xUnits)\n            xUnits = firstSpectrum.variables.x.units;\n        if (!yUnits)\n            yUnits = firstSpectrum.variables.y.units;\n        for (const spectrum of spectra) {\n            const serie = {};\n            addStyle(serie, analysis, {\n                color: colors[i % colors.length],\n                opacity: opacities[i % opacities.length],\n                lineWidth: linesWidth[i % linesWidth.length],\n            });\n            serie.data = {\n                x: spectrum.variables.x.data,\n                y: spectrum.variables.y.data,\n            };\n            serie.id = spectrum.id;\n            if (xAxis.logScale) {\n                serie.data = xyFilterXPositive(serie.data);\n            }\n            series.push(serie);\n        }\n    }\n    return {\n        axes: {\n            x: {\n                label: xLabel,\n                unit: xUnits,\n                unitWrapperBefore: '(',\n                unitWrapperAfter: ')',\n                flipped: false,\n                display: true,\n                ...xAxis,\n            },\n            y: {\n                label: yLabel,\n                unit: yUnits,\n                unitWrapperBefore: '(',\n                unitWrapperAfter: ')',\n                flipped: false,\n                display: true,\n                ...yAxis,\n            },\n        },\n        series,\n    };\n}\n//# sourceMappingURL=getJSGraph.js.map","/*! xlsx.js (C) 2013-present SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*exported XLSX */\n/*global process:false, Buffer:false, ArrayBuffer:false, DataView:false, Deno:false */\nvar XLSX = {};\nXLSX.version = '0.18.5';\nvar current_codepage = 1200, current_ansi = 1252;\n\nvar VALID_ANSI = [ 874, 932, 936, 949, 950, 1250, 1251, 1252, 1253, 1254, 1255, 1256, 1257, 1258, 10000 ];\n/* ECMA-376 Part I 18.4.1 charset to codepage mapping */\nvar CS2CP = ({\n\t/*::[*/0/*::]*/:    1252, /* ANSI */\n\t/*::[*/1/*::]*/:   65001, /* DEFAULT */\n\t/*::[*/2/*::]*/:   65001, /* SYMBOL */\n\t/*::[*/77/*::]*/:  10000, /* MAC */\n\t/*::[*/128/*::]*/:   932, /* SHIFTJIS */\n\t/*::[*/129/*::]*/:   949, /* HANGUL */\n\t/*::[*/130/*::]*/:  1361, /* JOHAB */\n\t/*::[*/134/*::]*/:   936, /* GB2312 */\n\t/*::[*/136/*::]*/:   950, /* CHINESEBIG5 */\n\t/*::[*/161/*::]*/:  1253, /* GREEK */\n\t/*::[*/162/*::]*/:  1254, /* TURKISH */\n\t/*::[*/163/*::]*/:  1258, /* VIETNAMESE */\n\t/*::[*/177/*::]*/:  1255, /* HEBREW */\n\t/*::[*/178/*::]*/:  1256, /* ARABIC */\n\t/*::[*/186/*::]*/:  1257, /* BALTIC */\n\t/*::[*/204/*::]*/:  1251, /* RUSSIAN */\n\t/*::[*/222/*::]*/:   874, /* THAI */\n\t/*::[*/238/*::]*/:  1250, /* EASTEUROPE */\n\t/*::[*/255/*::]*/:  1252, /* OEM */\n\t/*::[*/69/*::]*/:   6969  /* MISC */\n}/*:any*/);\n\nvar set_ansi = function(cp/*:number*/) { if(VALID_ANSI.indexOf(cp) == -1) return; current_ansi = CS2CP[0] = cp; };\nfunction reset_ansi() { set_ansi(1252); }\n\nvar set_cp = function(cp/*:number*/) { current_codepage = cp; set_ansi(cp); };\nfunction reset_cp() { set_cp(1200); reset_ansi(); }\n\nfunction char_codes(data/*:string*/)/*:Array<number>*/ { var o/*:Array<number>*/ = []; for(var i = 0, len = data.length; i < len; ++i) o[i] = data.charCodeAt(i); return o; }\n\nfunction utf16leread(data/*:string*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tfor(var i = 0; i < (data.length>>1); ++i) o[i] = String.fromCharCode(data.charCodeAt(2*i) + (data.charCodeAt(2*i+1)<<8));\n\treturn o.join(\"\");\n}\nfunction utf16beread(data/*:string*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tfor(var i = 0; i < (data.length>>1); ++i) o[i] = String.fromCharCode(data.charCodeAt(2*i+1) + (data.charCodeAt(2*i)<<8));\n\treturn o.join(\"\");\n}\n\nvar debom = function(data/*:string*/)/*:string*/ {\n\tvar c1 = data.charCodeAt(0), c2 = data.charCodeAt(1);\n\tif(c1 == 0xFF && c2 == 0xFE) return utf16leread(data.slice(2));\n\tif(c1 == 0xFE && c2 == 0xFF) return utf16beread(data.slice(2));\n\tif(c1 == 0xFEFF) return data.slice(1);\n\treturn data;\n};\n\nvar _getchar = function _gc1(x/*:number*/)/*:string*/ { return String.fromCharCode(x); };\nvar _getansi = function _ga1(x/*:number*/)/*:string*/ { return String.fromCharCode(x); };\n\nvar $cptable;\nfunction set_cptable(cptable) {\n\t$cptable = cptable;\n\tset_cp = function(cp/*:number*/) { current_codepage = cp; set_ansi(cp); };\n\tdebom = function(data/*:string*/) {\n\t\tif(data.charCodeAt(0) === 0xFF && data.charCodeAt(1) === 0xFE) { return $cptable.utils.decode(1200, char_codes(data.slice(2))); }\n\t\treturn data;\n\t};\n\t_getchar = function _gc2(x/*:number*/)/*:string*/ {\n\t\tif(current_codepage === 1200) return String.fromCharCode(x);\n\t\treturn $cptable.utils.decode(current_codepage, [x&255,x>>8])[0];\n\t};\n\t_getansi = function _ga2(x/*:number*/)/*:string*/ {\n\t\treturn $cptable.utils.decode(current_ansi, [x])[0];\n\t};\n\tcpdoit();\n}\nexport { set_cptable };\nvar DENSE = null;\nvar DIF_XL = true;\nvar Base64_map = \"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=\";\nfunction Base64_encode(input) {\n  var o = \"\";\n  var c1 = 0, c2 = 0, c3 = 0, e1 = 0, e2 = 0, e3 = 0, e4 = 0;\n  for (var i = 0; i < input.length; ) {\n    c1 = input.charCodeAt(i++);\n    e1 = c1 >> 2;\n    c2 = input.charCodeAt(i++);\n    e2 = (c1 & 3) << 4 | c2 >> 4;\n    c3 = input.charCodeAt(i++);\n    e3 = (c2 & 15) << 2 | c3 >> 6;\n    e4 = c3 & 63;\n    if (isNaN(c2)) {\n      e3 = e4 = 64;\n    } else if (isNaN(c3)) {\n      e4 = 64;\n    }\n    o += Base64_map.charAt(e1) + Base64_map.charAt(e2) + Base64_map.charAt(e3) + Base64_map.charAt(e4);\n  }\n  return o;\n}\nfunction Base64_decode(input) {\n  var o = \"\";\n  var c1 = 0, c2 = 0, c3 = 0, e1 = 0, e2 = 0, e3 = 0, e4 = 0;\n  input = input.replace(/[^\\w\\+\\/\\=]/g, \"\");\n  for (var i = 0; i < input.length; ) {\n    e1 = Base64_map.indexOf(input.charAt(i++));\n    e2 = Base64_map.indexOf(input.charAt(i++));\n    c1 = e1 << 2 | e2 >> 4;\n    o += String.fromCharCode(c1);\n    e3 = Base64_map.indexOf(input.charAt(i++));\n    c2 = (e2 & 15) << 4 | e3 >> 2;\n    if (e3 !== 64) {\n      o += String.fromCharCode(c2);\n    }\n    e4 = Base64_map.indexOf(input.charAt(i++));\n    c3 = (e3 & 3) << 6 | e4;\n    if (e4 !== 64) {\n      o += String.fromCharCode(c3);\n    }\n  }\n  return o;\n}\nvar has_buf = /*#__PURE__*/(function() { return typeof Buffer !== 'undefined' && typeof process !== 'undefined' && typeof process.versions !== 'undefined' && !!process.versions.node; })();\n\nvar Buffer_from = /*#__PURE__*/(function() {\n\tif(typeof Buffer !== 'undefined') {\n\t\tvar nbfs = !Buffer.from;\n\t\tif(!nbfs) try { Buffer.from(\"foo\", \"utf8\"); } catch(e) { nbfs = true; }\n\t\treturn nbfs ? function(buf, enc) { return (enc) ? new Buffer(buf, enc) : new Buffer(buf); } : Buffer.from.bind(Buffer);\n\t}\n\treturn function() {};\n})();\n\n\nfunction new_raw_buf(len/*:number*/) {\n\t/* jshint -W056 */\n\tif(has_buf) return Buffer.alloc ? Buffer.alloc(len) : new Buffer(len);\n\treturn typeof Uint8Array != \"undefined\" ? new Uint8Array(len) : new Array(len);\n\t/* jshint +W056 */\n}\n\nfunction new_unsafe_buf(len/*:number*/) {\n\t/* jshint -W056 */\n\tif(has_buf) return Buffer.allocUnsafe ? Buffer.allocUnsafe(len) : new Buffer(len);\n\treturn typeof Uint8Array != \"undefined\" ? new Uint8Array(len) : new Array(len);\n\t/* jshint +W056 */\n}\n\nvar s2a = function s2a(s/*:string*/)/*:any*/ {\n\tif(has_buf) return Buffer_from(s, \"binary\");\n\treturn s.split(\"\").map(function(x/*:string*/)/*:number*/{ return x.charCodeAt(0) & 0xff; });\n};\n\nfunction s2ab(s/*:string*/)/*:any*/ {\n\tif(typeof ArrayBuffer === 'undefined') return s2a(s);\n\tvar buf = new ArrayBuffer(s.length), view = new Uint8Array(buf);\n\tfor (var i=0; i!=s.length; ++i) view[i] = s.charCodeAt(i) & 0xFF;\n\treturn buf;\n}\n\nfunction a2s(data/*:any*/)/*:string*/ {\n\tif(Array.isArray(data)) return data.map(function(c) { return String.fromCharCode(c); }).join(\"\");\n\tvar o/*:Array<string>*/ = []; for(var i = 0; i < data.length; ++i) o[i] = String.fromCharCode(data[i]); return o.join(\"\");\n}\n\nfunction a2u(data/*:Array<number>*/)/*:Uint8Array*/ {\n\tif(typeof Uint8Array === 'undefined') throw new Error(\"Unsupported\");\n\treturn new Uint8Array(data);\n}\n\nfunction ab2a(data/*:ArrayBuffer|Uint8Array*/)/*:Array<number>*/ {\n\tif(typeof ArrayBuffer == 'undefined') throw new Error(\"Unsupported\");\n\tif(data instanceof ArrayBuffer) return ab2a(new Uint8Array(data));\n\t/*:: if(data instanceof ArrayBuffer) throw new Error(\"unreachable\"); */\n\tvar o = new Array(data.length);\n\tfor(var i = 0; i < data.length; ++i) o[i] = data[i];\n\treturn o;\n}\n\nvar bconcat = has_buf ? function(bufs) { return Buffer.concat(bufs.map(function(buf) { return Buffer.isBuffer(buf) ? buf : Buffer_from(buf); })); } : function(bufs) {\n\tif(typeof Uint8Array !== \"undefined\") {\n\t\tvar i = 0, maxlen = 0;\n\t\tfor(i = 0; i < bufs.length; ++i) maxlen += bufs[i].length;\n\t\tvar o = new Uint8Array(maxlen);\n\t\tvar len = 0;\n\t\tfor(i = 0, maxlen = 0; i < bufs.length; maxlen += len, ++i) {\n\t\t\tlen = bufs[i].length;\n\t\t\tif(bufs[i] instanceof Uint8Array) o.set(bufs[i], maxlen);\n\t\t\telse if(typeof bufs[i] == \"string\") { throw \"wtf\"; }\n\t\t\telse o.set(new Uint8Array(bufs[i]), maxlen);\n\t\t}\n\t\treturn o;\n\t}\n\treturn [].concat.apply([], bufs.map(function(buf) { return Array.isArray(buf) ? buf : [].slice.call(buf); }));\n};\n\nfunction utf8decode(content/*:string*/) {\n\tvar out = [], widx = 0, L = content.length + 250;\n\tvar o = new_raw_buf(content.length + 255);\n\tfor(var ridx = 0; ridx < content.length; ++ridx) {\n\t\tvar c = content.charCodeAt(ridx);\n\t\tif(c < 0x80) o[widx++] = c;\n\t\telse if(c < 0x800) {\n\t\t\to[widx++] = (192|((c>>6)&31));\n\t\t\to[widx++] = (128|(c&63));\n\t\t} else if(c >= 0xD800 && c < 0xE000) {\n\t\t\tc = (c&1023)+64;\n\t\t\tvar d = content.charCodeAt(++ridx)&1023;\n\t\t\to[widx++] = (240|((c>>8)&7));\n\t\t\to[widx++] = (128|((c>>2)&63));\n\t\t\to[widx++] = (128|((d>>6)&15)|((c&3)<<4));\n\t\t\to[widx++] = (128|(d&63));\n\t\t} else {\n\t\t\to[widx++] = (224|((c>>12)&15));\n\t\t\to[widx++] = (128|((c>>6)&63));\n\t\t\to[widx++] = (128|(c&63));\n\t\t}\n\t\tif(widx > L) {\n\t\t\tout.push(o.slice(0, widx));\n\t\t\twidx = 0;\n\t\t\to = new_raw_buf(65535);\n\t\t\tL = 65530;\n\t\t}\n\t}\n\tout.push(o.slice(0, widx));\n\treturn bconcat(out);\n}\n\nvar chr0 = /\\u0000/g, chr1 = /[\\u0001-\\u0006]/g;\n/*::\ndeclare type Block = any;\ndeclare type BufArray = {\n\tnewblk(sz:number):Block;\n\tnext(sz:number):Block;\n\tend():any;\n\tpush(buf:Block):void;\n};\n\ntype RecordHopperCB = {(d:any, Rn:string, RT:number):?boolean;};\n\ntype EvertType = {[string]:string};\ntype EvertNumType = {[string]:number};\ntype EvertArrType = {[string]:Array<string>};\n\ntype StringConv = {(string):string};\n\n*/\n/* ssf.js (C) 2013-present SheetJS -- http://sheetjs.com */\n/*jshint -W041 */\nfunction _strrev(x/*:string*/)/*:string*/ { var o = \"\", i = x.length-1; while(i>=0) o += x.charAt(i--); return o; }\nfunction pad0(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v; return t.length>=d?t:fill('0',d-t.length)+t;}\nfunction pad_(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v;return t.length>=d?t:fill(' ',d-t.length)+t;}\nfunction rpad_(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v; return t.length>=d?t:t+fill(' ',d-t.length);}\nfunction pad0r1(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+Math.round(v); return t.length>=d?t:fill('0',d-t.length)+t;}\nfunction pad0r2(v/*:any*/,d/*:number*/)/*:string*/{var t=\"\"+v; return t.length>=d?t:fill('0',d-t.length)+t;}\nvar p2_32 = /*#__PURE__*/Math.pow(2,32);\nfunction pad0r(v/*:any*/,d/*:number*/)/*:string*/{if(v>p2_32||v<-p2_32) return pad0r1(v,d); var i = Math.round(v); return pad0r2(i,d); }\n/* yes, in 2022 this is still faster than string compare */\nfunction SSF_isgeneral(s/*:string*/, i/*:?number*/)/*:boolean*/ { i = i || 0; return s.length >= 7 + i && (s.charCodeAt(i)|32) === 103 && (s.charCodeAt(i+1)|32) === 101 && (s.charCodeAt(i+2)|32) === 110 && (s.charCodeAt(i+3)|32) === 101 && (s.charCodeAt(i+4)|32) === 114 && (s.charCodeAt(i+5)|32) === 97 && (s.charCodeAt(i+6)|32) === 108; }\nvar days/*:Array<Array<string> >*/ = [\n\t['Sun', 'Sunday'],\n\t['Mon', 'Monday'],\n\t['Tue', 'Tuesday'],\n\t['Wed', 'Wednesday'],\n\t['Thu', 'Thursday'],\n\t['Fri', 'Friday'],\n\t['Sat', 'Saturday']\n];\nvar months/*:Array<Array<string> >*/ = [\n\t['J', 'Jan', 'January'],\n\t['F', 'Feb', 'February'],\n\t['M', 'Mar', 'March'],\n\t['A', 'Apr', 'April'],\n\t['M', 'May', 'May'],\n\t['J', 'Jun', 'June'],\n\t['J', 'Jul', 'July'],\n\t['A', 'Aug', 'August'],\n\t['S', 'Sep', 'September'],\n\t['O', 'Oct', 'October'],\n\t['N', 'Nov', 'November'],\n\t['D', 'Dec', 'December']\n];\nfunction SSF_init_table(t/*:any*/) {\n\tif(!t) t = {};\n\tt[0]=  'General';\n\tt[1]=  '0';\n\tt[2]=  '0.00';\n\tt[3]=  '#,##0';\n\tt[4]=  '#,##0.00';\n\tt[9]=  '0%';\n\tt[10]= '0.00%';\n\tt[11]= '0.00E+00';\n\tt[12]= '# ?/?';\n\tt[13]= '# ??/??';\n\tt[14]= 'm/d/yy';\n\tt[15]= 'd-mmm-yy';\n\tt[16]= 'd-mmm';\n\tt[17]= 'mmm-yy';\n\tt[18]= 'h:mm AM/PM';\n\tt[19]= 'h:mm:ss AM/PM';\n\tt[20]= 'h:mm';\n\tt[21]= 'h:mm:ss';\n\tt[22]= 'm/d/yy h:mm';\n\tt[37]= '#,##0 ;(#,##0)';\n\tt[38]= '#,##0 ;[Red](#,##0)';\n\tt[39]= '#,##0.00;(#,##0.00)';\n\tt[40]= '#,##0.00;[Red](#,##0.00)';\n\tt[45]= 'mm:ss';\n\tt[46]= '[h]:mm:ss';\n\tt[47]= 'mmss.0';\n\tt[48]= '##0.0E+0';\n\tt[49]= '@';\n\tt[56]= '\"上午/下午 \"hh\"時\"mm\"分\"ss\"秒 \"';\n\treturn t;\n}\n/* repeated to satiate webpack */\nvar table_fmt = {\n\t0:  'General',\n\t1:  '0',\n\t2:  '0.00',\n\t3:  '#,##0',\n\t4:  '#,##0.00',\n\t9:  '0%',\n\t10: '0.00%',\n\t11: '0.00E+00',\n\t12: '# ?/?',\n\t13: '# ??/??',\n\t14: 'm/d/yy',\n\t15: 'd-mmm-yy',\n\t16: 'd-mmm',\n\t17: 'mmm-yy',\n\t18: 'h:mm AM/PM',\n\t19: 'h:mm:ss AM/PM',\n\t20: 'h:mm',\n\t21: 'h:mm:ss',\n\t22: 'm/d/yy h:mm',\n\t37: '#,##0 ;(#,##0)',\n\t38: '#,##0 ;[Red](#,##0)',\n\t39: '#,##0.00;(#,##0.00)',\n\t40: '#,##0.00;[Red](#,##0.00)',\n\t45: 'mm:ss',\n\t46: '[h]:mm:ss',\n\t47: 'mmss.0',\n\t48: '##0.0E+0',\n\t49: '@',\n\t56: '\"上午/下午 \"hh\"時\"mm\"分\"ss\"秒 \"'\n};\n\n/* Defaults determined by systematically testing in Excel 2019 */\n\n/* These formats appear to default to other formats in the table */\nvar SSF_default_map = {\n\t5:  37, 6:  38, 7:  39, 8:  40,         //  5 -> 37 ...  8 -> 40\n\n\t23:  0, 24:  0, 25:  0, 26:  0,         // 23 ->  0 ... 26 ->  0\n\n\t27: 14, 28: 14, 29: 14, 30: 14, 31: 14, // 27 -> 14 ... 31 -> 14\n\n\t50: 14, 51: 14, 52: 14, 53: 14, 54: 14, // 50 -> 14 ... 58 -> 14\n\t55: 14, 56: 14, 57: 14, 58: 14,\n\t59:  1, 60:  2, 61:  3, 62:  4,         // 59 ->  1 ... 62 ->  4\n\n\t67:  9, 68: 10,                         // 67 ->  9 ... 68 -> 10\n\t69: 12, 70: 13, 71: 14,                 // 69 -> 12 ... 71 -> 14\n\t72: 14, 73: 15, 74: 16, 75: 17,         // 72 -> 14 ... 75 -> 17\n\t76: 20, 77: 21, 78: 22,                 // 76 -> 20 ... 78 -> 22\n\t79: 45, 80: 46, 81: 47,                 // 79 -> 45 ... 81 -> 47\n\t82: 0                                   // 82 ->  0 ... 65536 -> 0 (omitted)\n};\n\n\n/* These formats technically refer to Accounting formats with no equivalent */\nvar SSF_default_str = {\n\t//  5 -- Currency,   0 decimal, black negative\n\t5:  '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\t63: '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\n\t//  6 -- Currency,   0 decimal, red   negative\n\t6:  '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\t64: '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\n\t//  7 -- Currency,   2 decimal, black negative\n\t7:  '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\t65: '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\n\t//  8 -- Currency,   2 decimal, red   negative\n\t8:  '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t66: '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\n\t// 41 -- Accounting, 0 decimal, No Symbol\n\t41: '_(* #,##0_);_(* \\\\(#,##0\\\\);_(* \"-\"_);_(@_)',\n\n\t// 42 -- Accounting, 0 decimal, $  Symbol\n\t42: '_(\"$\"* #,##0_);_(\"$\"* \\\\(#,##0\\\\);_(\"$\"* \"-\"_);_(@_)',\n\n\t// 43 -- Accounting, 2 decimal, No Symbol\n\t43: '_(* #,##0.00_);_(* \\\\(#,##0.00\\\\);_(* \"-\"??_);_(@_)',\n\n\t// 44 -- Accounting, 2 decimal, $  Symbol\n\t44: '_(\"$\"* #,##0.00_);_(\"$\"* \\\\(#,##0.00\\\\);_(\"$\"* \"-\"??_);_(@_)'\n};\n\nfunction SSF_frac(x/*:number*/, D/*:number*/, mixed/*:?boolean*/)/*:Array<number>*/ {\n\tvar sgn = x < 0 ? -1 : 1;\n\tvar B = x * sgn;\n\tvar P_2 = 0, P_1 = 1, P = 0;\n\tvar Q_2 = 1, Q_1 = 0, Q = 0;\n\tvar A = Math.floor(B);\n\twhile(Q_1 < D) {\n\t\tA = Math.floor(B);\n\t\tP = A * P_1 + P_2;\n\t\tQ = A * Q_1 + Q_2;\n\t\tif((B - A) < 0.00000005) break;\n\t\tB = 1 / (B - A);\n\t\tP_2 = P_1; P_1 = P;\n\t\tQ_2 = Q_1; Q_1 = Q;\n\t}\n\tif(Q > D) { if(Q_1 > D) { Q = Q_2; P = P_2; } else { Q = Q_1; P = P_1; } }\n\tif(!mixed) return [0, sgn * P, Q];\n\tvar q = Math.floor(sgn * P/Q);\n\treturn [q, sgn*P - q*Q, Q];\n}\nfunction SSF_parse_date_code(v/*:number*/,opts/*:?any*/,b2/*:?boolean*/) {\n\tif(v > 2958465 || v < 0) return null;\n\tvar date = (v|0), time = Math.floor(86400 * (v - date)), dow=0;\n\tvar dout=[];\n\tvar out={D:date, T:time, u:86400*(v-date)-time,y:0,m:0,d:0,H:0,M:0,S:0,q:0};\n\tif(Math.abs(out.u) < 1e-6) out.u = 0;\n\tif(opts && opts.date1904) date += 1462;\n\tif(out.u > 0.9999) {\n\t\tout.u = 0;\n\t\tif(++time == 86400) { out.T = time = 0; ++date; ++out.D; }\n\t}\n\tif(date === 60) {dout = b2 ? [1317,10,29] : [1900,2,29]; dow=3;}\n\telse if(date === 0) {dout = b2 ? [1317,8,29] : [1900,1,0]; dow=6;}\n\telse {\n\t\tif(date > 60) --date;\n\t\t/* 1 = Jan 1 1900 in Gregorian */\n\t\tvar d = new Date(1900, 0, 1);\n\t\td.setDate(d.getDate() + date - 1);\n\t\tdout = [d.getFullYear(), d.getMonth()+1,d.getDate()];\n\t\tdow = d.getDay();\n\t\tif(date < 60) dow = (dow + 6) % 7;\n\t\tif(b2) dow = SSF_fix_hijri(d, dout);\n\t}\n\tout.y = dout[0]; out.m = dout[1]; out.d = dout[2];\n\tout.S = time % 60; time = Math.floor(time / 60);\n\tout.M = time % 60; time = Math.floor(time / 60);\n\tout.H = time;\n\tout.q = dow;\n\treturn out;\n}\nvar SSFbasedate = /*#__PURE__*/new Date(1899, 11, 31, 0, 0, 0);\nvar SSFdnthresh = /*#__PURE__*/SSFbasedate.getTime();\nvar SSFbase1904 = /*#__PURE__*/new Date(1900, 2, 1, 0, 0, 0);\nfunction datenum_local(v/*:Date*/, date1904/*:?boolean*/)/*:number*/ {\n\tvar epoch = /*#__PURE__*/v.getTime();\n\tif(date1904) epoch -= 1461*24*60*60*1000;\n\telse if(v >= SSFbase1904) epoch += 24*60*60*1000;\n\treturn (epoch - (SSFdnthresh + (/*#__PURE__*/v.getTimezoneOffset() - /*#__PURE__*/SSFbasedate.getTimezoneOffset()) * 60000)) / (24 * 60 * 60 * 1000);\n}\n/* ECMA-376 18.8.30 numFmt*/\n/* Note: `toPrecision` uses standard form when prec > E and E >= -6 */\n/* exponent >= -9 and <= 9 */\nfunction SSF_strip_decimal(o/*:string*/)/*:string*/ {\n\treturn (o.indexOf(\".\") == -1) ? o : o.replace(/(?:\\.0*|(\\.\\d*[1-9])0+)$/, \"$1\");\n}\n\n/* General Exponential always shows 2 digits exp and trims the mantissa */\nfunction SSF_normalize_exp(o/*:string*/)/*:string*/ {\n\tif(o.indexOf(\"E\") == -1) return o;\n\treturn o.replace(/(?:\\.0*|(\\.\\d*[1-9])0+)[Ee]/,\"$1E\").replace(/(E[+-])(\\d)$/,\"$10$2\");\n}\n\n/* exponent >= -9 and <= 9 */\nfunction SSF_small_exp(v/*:number*/)/*:string*/ {\n\tvar w = (v<0?12:11);\n\tvar o = SSF_strip_decimal(v.toFixed(12)); if(o.length <= w) return o;\n\to = v.toPrecision(10); if(o.length <= w) return o;\n\treturn v.toExponential(5);\n}\n\n/* exponent >= 11 or <= -10 likely exponential */\nfunction SSF_large_exp(v/*:number*/)/*:string*/ {\n\tvar o = SSF_strip_decimal(v.toFixed(11));\n\treturn (o.length > (v<0?12:11) || o === \"0\" || o === \"-0\") ? v.toPrecision(6) : o;\n}\n\nfunction SSF_general_num(v/*:number*/)/*:string*/ {\n\tvar V = Math.floor(Math.log(Math.abs(v))*Math.LOG10E), o;\n\n\tif(V >= -4 && V <= -1) o = v.toPrecision(10+V);\n\telse if(Math.abs(V) <= 9) o = SSF_small_exp(v);\n\telse if(V === 10) o = v.toFixed(10).substr(0,12);\n\telse o = SSF_large_exp(v);\n\n\treturn SSF_strip_decimal(SSF_normalize_exp(o.toUpperCase()));\n}\n\n\n/*\n\t\"General\" rules:\n\t- text is passed through (\"@\")\n\t- booleans are rendered as TRUE/FALSE\n\t- \"up to 11 characters\" displayed for numbers\n\t- Default date format (code 14) used for Dates\n\n\tThe longest 32-bit integer text is \"-2147483648\", exactly 11 chars\n\tTODO: technically the display depends on the width of the cell\n*/\nfunction SSF_general(v/*:any*/, opts/*:any*/) {\n\tswitch(typeof v) {\n\t\tcase 'string': return v;\n\t\tcase 'boolean': return v ? \"TRUE\" : \"FALSE\";\n\t\tcase 'number': return (v|0) === v ? v.toString(10) : SSF_general_num(v);\n\t\tcase 'undefined': return \"\";\n\t\tcase 'object':\n\t\t\tif(v == null) return \"\";\n\t\t\tif(v instanceof Date) return SSF_format(14, datenum_local(v, opts && opts.date1904), opts);\n\t}\n\tthrow new Error(\"unsupported value in General format: \" + v);\n}\n\nfunction SSF_fix_hijri(date/*:Date*/, o/*:[number, number, number]*/) {\n  /* TODO: properly adjust y/m/d and  */\n  o[0] -= 581;\n  var dow = date.getDay();\n  if(date < 60) dow = (dow + 6) % 7;\n  return dow;\n}\n//var THAI_DIGITS = \"\\u0E50\\u0E51\\u0E52\\u0E53\\u0E54\\u0E55\\u0E56\\u0E57\\u0E58\\u0E59\".split(\"\");\nfunction SSF_write_date(type/*:number*/, fmt/*:string*/, val, ss0/*:?number*/)/*:string*/ {\n\tvar o=\"\", ss=0, tt=0, y = val.y, out, outl = 0;\n\tswitch(type) {\n\t\tcase 98: /* 'b' buddhist year */\n\t\t\ty = val.y + 543;\n\t\t\t/* falls through */\n\t\tcase 121: /* 'y' year */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = y % 100; outl = 2; break;\n\t\t\tdefault: out = y % 10000; outl = 4; break;\n\t\t} break;\n\t\tcase 109: /* 'm' month */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.m; outl = fmt.length; break;\n\t\t\tcase 3: return months[val.m-1][1];\n\t\t\tcase 5: return months[val.m-1][0];\n\t\t\tdefault: return months[val.m-1][2];\n\t\t} break;\n\t\tcase 100: /* 'd' day */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.d; outl = fmt.length; break;\n\t\t\tcase 3: return days[val.q][0];\n\t\t\tdefault: return days[val.q][1];\n\t\t} break;\n\t\tcase 104: /* 'h' 12-hour */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = 1+(val.H+11)%12; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad hour format: ' + fmt;\n\t\t} break;\n\t\tcase 72: /* 'H' 24-hour */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.H; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad hour format: ' + fmt;\n\t\t} break;\n\t\tcase 77: /* 'M' minutes */\n\t\tswitch(fmt.length) {\n\t\t\tcase 1: case 2: out = val.M; outl = fmt.length; break;\n\t\t\tdefault: throw 'bad minute format: ' + fmt;\n\t\t} break;\n\t\tcase 115: /* 's' seconds */\n\t\t\tif(fmt != 's' && fmt != 'ss' && fmt != '.0' && fmt != '.00' && fmt != '.000') throw 'bad second format: ' + fmt;\n\t\t\tif(val.u === 0 && (fmt == \"s\" || fmt == \"ss\")) return pad0(val.S, fmt.length);\n\t\t\t/*::if(!ss0) ss0 = 0; */\n\t\t\tif(ss0 >= 2) tt = ss0 === 3 ? 1000 : 100;\n\t\t\telse tt = ss0 === 1 ? 10 : 1;\n\t\t\tss = Math.round((tt)*(val.S + val.u));\n\t\t\tif(ss >= 60*tt) ss = 0;\n\t\t\tif(fmt === 's') return ss === 0 ? \"0\" : \"\"+ss/tt;\n\t\t\to = pad0(ss,2 + ss0);\n\t\t\tif(fmt === 'ss') return o.substr(0,2);\n\t\t\treturn \".\" + o.substr(2,fmt.length-1);\n\t\tcase 90: /* 'Z' absolute time */\n\t\tswitch(fmt) {\n\t\t\tcase '[h]': case '[hh]': out = val.D*24+val.H; break;\n\t\t\tcase '[m]': case '[mm]': out = (val.D*24+val.H)*60+val.M; break;\n\t\t\tcase '[s]': case '[ss]': out = ((val.D*24+val.H)*60+val.M)*60+Math.round(val.S+val.u); break;\n\t\t\tdefault: throw 'bad abstime format: ' + fmt;\n\t\t} outl = fmt.length === 3 ? 1 : 2; break;\n\t\tcase 101: /* 'e' era */\n\t\t\tout = y; outl = 1; break;\n\t}\n\tvar outstr = outl > 0 ? pad0(out, outl) : \"\";\n\treturn outstr;\n}\n\n\n/*jshint -W086 */\n/*jshint +W086 */\nfunction commaify(s/*:string*/)/*:string*/ {\n\tvar w = 3;\n\tif(s.length <= w) return s;\n\tvar j = (s.length % w), o = s.substr(0,j);\n\tfor(; j!=s.length; j+=w) o+=(o.length > 0 ? \",\" : \"\") + s.substr(j,w);\n\treturn o;\n}\nvar pct1 = /%/g;\nfunction write_num_pct(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar sfmt = fmt.replace(pct1,\"\"), mul = fmt.length - sfmt.length;\n\treturn write_num(type, sfmt, val * Math.pow(10,2*mul)) + fill(\"%\",mul);\n}\n\nfunction write_num_cm(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar idx = fmt.length - 1;\n\twhile(fmt.charCodeAt(idx-1) === 44) --idx;\n\treturn write_num(type, fmt.substr(0,idx), val / Math.pow(10,3*(fmt.length-idx)));\n}\n\nfunction write_num_exp(fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar o/*:string*/;\n\tvar idx = fmt.indexOf(\"E\") - fmt.indexOf(\".\") - 1;\n\tif(fmt.match(/^#+0.0E\\+0$/)) {\n\t\tif(val == 0) return \"0.0E+0\";\n\t\telse if(val < 0) return \"-\" + write_num_exp(fmt, -val);\n\t\tvar period = fmt.indexOf(\".\"); if(period === -1) period=fmt.indexOf('E');\n\t\tvar ee = Math.floor(Math.log(val)*Math.LOG10E)%period;\n\t\tif(ee < 0) ee += period;\n\t\to = (val/Math.pow(10,ee)).toPrecision(idx+1+(period+ee)%period);\n\t\tif(o.indexOf(\"e\") === -1) {\n\t\t\tvar fakee = Math.floor(Math.log(val)*Math.LOG10E);\n\t\t\tif(o.indexOf(\".\") === -1) o = o.charAt(0) + \".\" + o.substr(1) + \"E+\" + (fakee - o.length+ee);\n\t\t\telse o += \"E+\" + (fakee - ee);\n\t\t\twhile(o.substr(0,2) === \"0.\") {\n\t\t\t\to = o.charAt(0) + o.substr(2,period) + \".\" + o.substr(2+period);\n\t\t\t\to = o.replace(/^0+([1-9])/,\"$1\").replace(/^0+\\./,\"0.\");\n\t\t\t}\n\t\t\to = o.replace(/\\+-/,\"-\");\n\t\t}\n\t\to = o.replace(/^([+-]?)(\\d*)\\.(\\d*)[Ee]/,function($$,$1,$2,$3) { return $1 + $2 + $3.substr(0,(period+ee)%period) + \".\" + $3.substr(ee) + \"E\"; });\n\t} else o = val.toExponential(idx);\n\tif(fmt.match(/E\\+00$/) && o.match(/e[+-]\\d$/)) o = o.substr(0,o.length-1) + \"0\" + o.charAt(o.length-1);\n\tif(fmt.match(/E\\-/) && o.match(/e\\+/)) o = o.replace(/e\\+/,\"e\");\n\treturn o.replace(\"e\",\"E\");\n}\nvar frac1 = /# (\\?+)( ?)\\/( ?)(\\d+)/;\nfunction write_num_f1(r/*:Array<string>*/, aval/*:number*/, sign/*:string*/)/*:string*/ {\n\tvar den = parseInt(r[4],10), rr = Math.round(aval * den), base = Math.floor(rr/den);\n\tvar myn = (rr - base*den), myd = den;\n\treturn sign + (base === 0 ? \"\" : \"\"+base) + \" \" + (myn === 0 ? fill(\" \", r[1].length + 1 + r[4].length) : pad_(myn,r[1].length) + r[2] + \"/\" + r[3] + pad0(myd,r[4].length));\n}\nfunction write_num_f2(r/*:Array<string>*/, aval/*:number*/, sign/*:string*/)/*:string*/ {\n\treturn sign + (aval === 0 ? \"\" : \"\"+aval) + fill(\" \", r[1].length + 2 + r[4].length);\n}\nvar dec1 = /^#*0*\\.([0#]+)/;\nvar closeparen = /\\).*[0#]/;\nvar phone = /\\(###\\) ###\\\\?-####/;\nfunction hashq(str/*:string*/)/*:string*/ {\n\tvar o = \"\", cc;\n\tfor(var i = 0; i != str.length; ++i) switch((cc=str.charCodeAt(i))) {\n\t\tcase 35: break;\n\t\tcase 63: o+= \" \"; break;\n\t\tcase 48: o+= \"0\"; break;\n\t\tdefault: o+= String.fromCharCode(cc);\n\t}\n\treturn o;\n}\nfunction rnd(val/*:number*/, d/*:number*/)/*:string*/ { var dd = Math.pow(10,d); return \"\"+(Math.round(val * dd)/dd); }\nfunction dec(val/*:number*/, d/*:number*/)/*:number*/ {\n\tvar _frac = val - Math.floor(val), dd = Math.pow(10,d);\n\tif (d < ('' + Math.round(_frac * dd)).length) return 0;\n\treturn Math.round(_frac * dd);\n}\nfunction carry(val/*:number*/, d/*:number*/)/*:number*/ {\n\tif (d < ('' + Math.round((val-Math.floor(val))*Math.pow(10,d))).length) {\n\t\treturn 1;\n\t}\n\treturn 0;\n}\nfunction flr(val/*:number*/)/*:string*/ {\n\tif(val < 2147483647 && val > -2147483648) return \"\"+(val >= 0 ? (val|0) : (val-1|0));\n\treturn \"\"+Math.floor(val);\n}\nfunction write_num_flt(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/ {\n\tif(type.charCodeAt(0) === 40 && !fmt.match(closeparen)) {\n\t\tvar ffmt = fmt.replace(/\\( */,\"\").replace(/ \\)/,\"\").replace(/\\)/,\"\");\n\t\tif(val >= 0) return write_num_flt('n', ffmt, val);\n\t\treturn '(' + write_num_flt('n', ffmt, -val) + ')';\n\t}\n\tif(fmt.charCodeAt(fmt.length - 1) === 44) return write_num_cm(type, fmt, val);\n\tif(fmt.indexOf('%') !== -1) return write_num_pct(type, fmt, val);\n\tif(fmt.indexOf('E') !== -1) return write_num_exp(fmt, val);\n\tif(fmt.charCodeAt(0) === 36) return \"$\"+write_num_flt(type,fmt.substr(fmt.charAt(1)==' '?2:1),val);\n\tvar o;\n\tvar r/*:?Array<string>*/, ri, ff, aval = Math.abs(val), sign = val < 0 ? \"-\" : \"\";\n\tif(fmt.match(/^00+$/)) return sign + pad0r(aval,fmt.length);\n\tif(fmt.match(/^[#?]+$/)) {\n\t\to = pad0r(val,0); if(o === \"0\") o = \"\";\n\t\treturn o.length > fmt.length ? o : hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(frac1))) return write_num_f1(r, aval, sign);\n\tif(fmt.match(/^#+0+$/)) return sign + pad0r(aval,fmt.length - fmt.indexOf(\"0\"));\n\tif((r = fmt.match(dec1))) {\n\t\to = rnd(val, r[1].length).replace(/^([^\\.]+)$/,\"$1.\"+hashq(r[1])).replace(/\\.$/,\".\"+hashq(r[1])).replace(/\\.(\\d*)$/,function($$, $1) { return \".\" + $1 + fill(\"0\", hashq(/*::(*/r/*::||[\"\"])*/[1]).length-$1.length); });\n\t\treturn fmt.indexOf(\"0.\") !== -1 ? o : o.replace(/^0\\./,\".\");\n\t}\n\tfmt = fmt.replace(/^#+([0.])/, \"$1\");\n\tif((r = fmt.match(/^(0*)\\.(#*)$/))) {\n\t\treturn sign + rnd(aval, r[2].length).replace(/\\.(\\d*[1-9])0*$/,\".$1\").replace(/^(-?\\d*)$/,\"$1.\").replace(/^0\\./,r[1].length?\"0.\":\".\");\n\t}\n\tif((r = fmt.match(/^#{1,3},##0(\\.?)$/))) return sign + commaify(pad0r(aval,0));\n\tif((r = fmt.match(/^#,##0\\.([#0]*0)$/))) {\n\t\treturn val < 0 ? \"-\" + write_num_flt(type, fmt, -val) : commaify(\"\"+(Math.floor(val) + carry(val, r[1].length))) + \".\" + pad0(dec(val, r[1].length),r[1].length);\n\t}\n\tif((r = fmt.match(/^#,#*,#0/))) return write_num_flt(type,fmt.replace(/^#,#*,/,\"\"),val);\n\tif((r = fmt.match(/^([0#]+)(\\\\?-([0#]+))+$/))) {\n\t\to = _strrev(write_num_flt(type, fmt.replace(/[\\\\-]/g,\"\"), val));\n\t\tri = 0;\n\t\treturn _strrev(_strrev(fmt.replace(/\\\\/g,\"\")).replace(/[0#]/g,function(x){return ri<o.length?o.charAt(ri++):x==='0'?'0':\"\";}));\n\t}\n\tif(fmt.match(phone)) {\n\t\to = write_num_flt(type, \"##########\", val);\n\t\treturn \"(\" + o.substr(0,3) + \") \" + o.substr(3, 3) + \"-\" + o.substr(6);\n\t}\n\tvar oa = \"\";\n\tif((r = fmt.match(/^([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(/*::String(*/r[4]/*::)*/.length,7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, false);\n\t\to = \"\" + sign;\n\t\toa = write_num(\"n\", /*::String(*/r[1]/*::)*/, ff[1]);\n\t\tif(oa.charAt(oa.length-1) == \" \") oa = oa.substr(0,oa.length-1) + \"0\";\n\t\to += oa + /*::String(*/r[2]/*::)*/ + \"/\" + /*::String(*/r[3]/*::)*/;\n\t\toa = rpad_(ff[2],ri);\n\t\tif(oa.length < r[4].length) oa = hashq(r[4].substr(r[4].length-oa.length)) + oa;\n\t\to += oa;\n\t\treturn o;\n\t}\n\tif((r = fmt.match(/^# ([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(Math.max(r[1].length, r[4].length),7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, true);\n\t\treturn sign + (ff[0]||(ff[1] ? \"\" : \"0\")) + \" \" + (ff[1] ? pad_(ff[1],ri) + r[2] + \"/\" + r[3] + rpad_(ff[2],ri): fill(\" \", 2*ri+1 + r[2].length + r[3].length));\n\t}\n\tif((r = fmt.match(/^[#0?]+$/))) {\n\t\to = pad0r(val, 0);\n\t\tif(fmt.length <= o.length) return o;\n\t\treturn hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(/^([#0?]+)\\.([#0]+)$/))) {\n\t\to = \"\" + val.toFixed(Math.min(r[2].length,10)).replace(/([^0])0+$/,\"$1\");\n\t\tri = o.indexOf(\".\");\n\t\tvar lres = fmt.indexOf(\".\") - ri, rres = fmt.length - o.length - lres;\n\t\treturn hashq(fmt.substr(0,lres) + o + fmt.substr(fmt.length-rres));\n\t}\n\tif((r = fmt.match(/^00,000\\.([#0]*0)$/))) {\n\t\tri = dec(val, r[1].length);\n\t\treturn val < 0 ? \"-\" + write_num_flt(type, fmt, -val) : commaify(flr(val)).replace(/^\\d,\\d{3}$/,\"0$&\").replace(/^\\d*$/,function($$) { return \"00,\" + ($$.length < 3 ? pad0(0,3-$$.length) : \"\") + $$; }) + \".\" + pad0(ri,r[1].length);\n\t}\n\tswitch(fmt) {\n\t\tcase \"###,##0.00\": return write_num_flt(type, \"#,##0.00\", val);\n\t\tcase \"###,###\":\n\t\tcase \"##,###\":\n\t\tcase \"#,###\": var x = commaify(pad0r(aval,0)); return x !== \"0\" ? sign + x : \"\";\n\t\tcase \"###,###.00\": return write_num_flt(type, \"###,##0.00\",val).replace(/^0\\./,\".\");\n\t\tcase \"#,###.00\": return write_num_flt(type, \"#,##0.00\",val).replace(/^0\\./,\".\");\n\t\tdefault:\n\t}\n\tthrow new Error(\"unsupported format |\" + fmt + \"|\");\n}\nfunction write_num_cm2(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar idx = fmt.length - 1;\n\twhile(fmt.charCodeAt(idx-1) === 44) --idx;\n\treturn write_num(type, fmt.substr(0,idx), val / Math.pow(10,3*(fmt.length-idx)));\n}\nfunction write_num_pct2(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar sfmt = fmt.replace(pct1,\"\"), mul = fmt.length - sfmt.length;\n\treturn write_num(type, sfmt, val * Math.pow(10,2*mul)) + fill(\"%\",mul);\n}\nfunction write_num_exp2(fmt/*:string*/, val/*:number*/)/*:string*/{\n\tvar o/*:string*/;\n\tvar idx = fmt.indexOf(\"E\") - fmt.indexOf(\".\") - 1;\n\tif(fmt.match(/^#+0.0E\\+0$/)) {\n\t\tif(val == 0) return \"0.0E+0\";\n\t\telse if(val < 0) return \"-\" + write_num_exp2(fmt, -val);\n\t\tvar period = fmt.indexOf(\".\"); if(period === -1) period=fmt.indexOf('E');\n\t\tvar ee = Math.floor(Math.log(val)*Math.LOG10E)%period;\n\t\tif(ee < 0) ee += period;\n\t\to = (val/Math.pow(10,ee)).toPrecision(idx+1+(period+ee)%period);\n\t\tif(!o.match(/[Ee]/)) {\n\t\t\tvar fakee = Math.floor(Math.log(val)*Math.LOG10E);\n\t\t\tif(o.indexOf(\".\") === -1) o = o.charAt(0) + \".\" + o.substr(1) + \"E+\" + (fakee - o.length+ee);\n\t\t\telse o += \"E+\" + (fakee - ee);\n\t\t\to = o.replace(/\\+-/,\"-\");\n\t\t}\n\t\to = o.replace(/^([+-]?)(\\d*)\\.(\\d*)[Ee]/,function($$,$1,$2,$3) { return $1 + $2 + $3.substr(0,(period+ee)%period) + \".\" + $3.substr(ee) + \"E\"; });\n\t} else o = val.toExponential(idx);\n\tif(fmt.match(/E\\+00$/) && o.match(/e[+-]\\d$/)) o = o.substr(0,o.length-1) + \"0\" + o.charAt(o.length-1);\n\tif(fmt.match(/E\\-/) && o.match(/e\\+/)) o = o.replace(/e\\+/,\"e\");\n\treturn o.replace(\"e\",\"E\");\n}\nfunction write_num_int(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/ {\n\tif(type.charCodeAt(0) === 40 && !fmt.match(closeparen)) {\n\t\tvar ffmt = fmt.replace(/\\( */,\"\").replace(/ \\)/,\"\").replace(/\\)/,\"\");\n\t\tif(val >= 0) return write_num_int('n', ffmt, val);\n\t\treturn '(' + write_num_int('n', ffmt, -val) + ')';\n\t}\n\tif(fmt.charCodeAt(fmt.length - 1) === 44) return write_num_cm2(type, fmt, val);\n\tif(fmt.indexOf('%') !== -1) return write_num_pct2(type, fmt, val);\n\tif(fmt.indexOf('E') !== -1) return write_num_exp2(fmt, val);\n\tif(fmt.charCodeAt(0) === 36) return \"$\"+write_num_int(type,fmt.substr(fmt.charAt(1)==' '?2:1),val);\n\tvar o;\n\tvar r/*:?Array<string>*/, ri, ff, aval = Math.abs(val), sign = val < 0 ? \"-\" : \"\";\n\tif(fmt.match(/^00+$/)) return sign + pad0(aval,fmt.length);\n\tif(fmt.match(/^[#?]+$/)) {\n\t\to = (\"\"+val); if(val === 0) o = \"\";\n\t\treturn o.length > fmt.length ? o : hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(frac1))) return write_num_f2(r, aval, sign);\n\tif(fmt.match(/^#+0+$/)) return sign + pad0(aval,fmt.length - fmt.indexOf(\"0\"));\n\tif((r = fmt.match(dec1))) {\n\t\t/*:: if(!Array.isArray(r)) throw new Error(\"unreachable\"); */\n\t\to = (\"\"+val).replace(/^([^\\.]+)$/,\"$1.\"+hashq(r[1])).replace(/\\.$/,\".\"+hashq(r[1]));\n\t\to = o.replace(/\\.(\\d*)$/,function($$, $1) {\n\t\t/*:: if(!Array.isArray(r)) throw new Error(\"unreachable\"); */\n\t\t\treturn \".\" + $1 + fill(\"0\", hashq(r[1]).length-$1.length); });\n\t\treturn fmt.indexOf(\"0.\") !== -1 ? o : o.replace(/^0\\./,\".\");\n\t}\n\tfmt = fmt.replace(/^#+([0.])/, \"$1\");\n\tif((r = fmt.match(/^(0*)\\.(#*)$/))) {\n\t\treturn sign + (\"\"+aval).replace(/\\.(\\d*[1-9])0*$/,\".$1\").replace(/^(-?\\d*)$/,\"$1.\").replace(/^0\\./,r[1].length?\"0.\":\".\");\n\t}\n\tif((r = fmt.match(/^#{1,3},##0(\\.?)$/))) return sign + commaify((\"\"+aval));\n\tif((r = fmt.match(/^#,##0\\.([#0]*0)$/))) {\n\t\treturn val < 0 ? \"-\" + write_num_int(type, fmt, -val) : commaify((\"\"+val)) + \".\" + fill('0',r[1].length);\n\t}\n\tif((r = fmt.match(/^#,#*,#0/))) return write_num_int(type,fmt.replace(/^#,#*,/,\"\"),val);\n\tif((r = fmt.match(/^([0#]+)(\\\\?-([0#]+))+$/))) {\n\t\to = _strrev(write_num_int(type, fmt.replace(/[\\\\-]/g,\"\"), val));\n\t\tri = 0;\n\t\treturn _strrev(_strrev(fmt.replace(/\\\\/g,\"\")).replace(/[0#]/g,function(x){return ri<o.length?o.charAt(ri++):x==='0'?'0':\"\";}));\n\t}\n\tif(fmt.match(phone)) {\n\t\to = write_num_int(type, \"##########\", val);\n\t\treturn \"(\" + o.substr(0,3) + \") \" + o.substr(3, 3) + \"-\" + o.substr(6);\n\t}\n\tvar oa = \"\";\n\tif((r = fmt.match(/^([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(/*::String(*/r[4]/*::)*/.length,7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, false);\n\t\to = \"\" + sign;\n\t\toa = write_num(\"n\", /*::String(*/r[1]/*::)*/, ff[1]);\n\t\tif(oa.charAt(oa.length-1) == \" \") oa = oa.substr(0,oa.length-1) + \"0\";\n\t\to += oa + /*::String(*/r[2]/*::)*/ + \"/\" + /*::String(*/r[3]/*::)*/;\n\t\toa = rpad_(ff[2],ri);\n\t\tif(oa.length < r[4].length) oa = hashq(r[4].substr(r[4].length-oa.length)) + oa;\n\t\to += oa;\n\t\treturn o;\n\t}\n\tif((r = fmt.match(/^# ([#0?]+)( ?)\\/( ?)([#0?]+)/))) {\n\t\tri = Math.min(Math.max(r[1].length, r[4].length),7);\n\t\tff = SSF_frac(aval, Math.pow(10,ri)-1, true);\n\t\treturn sign + (ff[0]||(ff[1] ? \"\" : \"0\")) + \" \" + (ff[1] ? pad_(ff[1],ri) + r[2] + \"/\" + r[3] + rpad_(ff[2],ri): fill(\" \", 2*ri+1 + r[2].length + r[3].length));\n\t}\n\tif((r = fmt.match(/^[#0?]+$/))) {\n\t\to = \"\" + val;\n\t\tif(fmt.length <= o.length) return o;\n\t\treturn hashq(fmt.substr(0,fmt.length-o.length)) + o;\n\t}\n\tif((r = fmt.match(/^([#0]+)\\.([#0]+)$/))) {\n\t\to = \"\" + val.toFixed(Math.min(r[2].length,10)).replace(/([^0])0+$/,\"$1\");\n\t\tri = o.indexOf(\".\");\n\t\tvar lres = fmt.indexOf(\".\") - ri, rres = fmt.length - o.length - lres;\n\t\treturn hashq(fmt.substr(0,lres) + o + fmt.substr(fmt.length-rres));\n\t}\n\tif((r = fmt.match(/^00,000\\.([#0]*0)$/))) {\n\t\treturn val < 0 ? \"-\" + write_num_int(type, fmt, -val) : commaify(\"\"+val).replace(/^\\d,\\d{3}$/,\"0$&\").replace(/^\\d*$/,function($$) { return \"00,\" + ($$.length < 3 ? pad0(0,3-$$.length) : \"\") + $$; }) + \".\" + pad0(0,r[1].length);\n\t}\n\tswitch(fmt) {\n\t\tcase \"###,###\":\n\t\tcase \"##,###\":\n\t\tcase \"#,###\": var x = commaify(\"\"+aval); return x !== \"0\" ? sign + x : \"\";\n\t\tdefault:\n\t\t\tif(fmt.match(/\\.[0#?]*$/)) return write_num_int(type, fmt.slice(0,fmt.lastIndexOf(\".\")), val) + hashq(fmt.slice(fmt.lastIndexOf(\".\")));\n\t}\n\tthrow new Error(\"unsupported format |\" + fmt + \"|\");\n}\nfunction write_num(type/*:string*/, fmt/*:string*/, val/*:number*/)/*:string*/ {\n\treturn (val|0) === val ? write_num_int(type, fmt, val) : write_num_flt(type, fmt, val);\n}\nfunction SSF_split_fmt(fmt/*:string*/)/*:Array<string>*/ {\n\tvar out/*:Array<string>*/ = [];\n\tvar in_str = false/*, cc*/;\n\tfor(var i = 0, j = 0; i < fmt.length; ++i) switch((/*cc=*/fmt.charCodeAt(i))) {\n\t\tcase 34: /* '\"' */\n\t\t\tin_str = !in_str; break;\n\t\tcase 95: case 42: case 92: /* '_' '*' '\\\\' */\n\t\t\t++i; break;\n\t\tcase 59: /* ';' */\n\t\t\tout[out.length] = fmt.substr(j,i-j);\n\t\t\tj = i+1;\n\t}\n\tout[out.length] = fmt.substr(j);\n\tif(in_str === true) throw new Error(\"Format |\" + fmt + \"| unterminated string \");\n\treturn out;\n}\n\nvar SSF_abstime = /\\[[HhMmSs\\u0E0A\\u0E19\\u0E17]*\\]/;\nfunction fmt_is_date(fmt/*:string*/)/*:boolean*/ {\n\tvar i = 0, /*cc = 0,*/ c = \"\", o = \"\";\n\twhile(i < fmt.length) {\n\t\tswitch((c = fmt.charAt(i))) {\n\t\t\tcase 'G': if(SSF_isgeneral(fmt, i)) i+= 6; i++; break;\n\t\t\tcase '\"': for(;(/*cc=*/fmt.charCodeAt(++i)) !== 34 && i < fmt.length;){/*empty*/} ++i; break;\n\t\t\tcase '\\\\': i+=2; break;\n\t\t\tcase '_': i+=2; break;\n\t\t\tcase '@': ++i; break;\n\t\t\tcase 'B': case 'b':\n\t\t\t\tif(fmt.charAt(i+1) === \"1\" || fmt.charAt(i+1) === \"2\") return true;\n\t\t\t\t/* falls through */\n\t\t\tcase 'M': case 'D': case 'Y': case 'H': case 'S': case 'E':\n\t\t\t\t/* falls through */\n\t\t\tcase 'm': case 'd': case 'y': case 'h': case 's': case 'e': case 'g': return true;\n\t\t\tcase 'A': case 'a': case '上':\n\t\t\t\tif(fmt.substr(i, 3).toUpperCase() === \"A/P\") return true;\n\t\t\t\tif(fmt.substr(i, 5).toUpperCase() === \"AM/PM\") return true;\n\t\t\t\tif(fmt.substr(i, 5).toUpperCase() === \"上午/下午\") return true;\n\t\t\t\t++i; break;\n\t\t\tcase '[':\n\t\t\t\to = c;\n\t\t\t\twhile(fmt.charAt(i++) !== ']' && i < fmt.length) o += fmt.charAt(i);\n\t\t\t\tif(o.match(SSF_abstime)) return true;\n\t\t\t\tbreak;\n\t\t\tcase '.':\n\t\t\t\t/* falls through */\n\t\t\tcase '0': case '#':\n\t\t\t\twhile(i < fmt.length && (\"0#?.,E+-%\".indexOf(c=fmt.charAt(++i)) > -1 || (c=='\\\\' && fmt.charAt(i+1) == \"-\" && \"0#\".indexOf(fmt.charAt(i+2))>-1))){/* empty */}\n\t\t\t\tbreak;\n\t\t\tcase '?': while(fmt.charAt(++i) === c){/* empty */} break;\n\t\t\tcase '*': ++i; if(fmt.charAt(i) == ' ' || fmt.charAt(i) == '*') ++i; break;\n\t\t\tcase '(': case ')': ++i; break;\n\t\t\tcase '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9':\n\t\t\t\twhile(i < fmt.length && \"0123456789\".indexOf(fmt.charAt(++i)) > -1){/* empty */} break;\n\t\t\tcase ' ': ++i; break;\n\t\t\tdefault: ++i; break;\n\t\t}\n\t}\n\treturn false;\n}\n\nfunction eval_fmt(fmt/*:string*/, v/*:any*/, opts/*:any*/, flen/*:number*/) {\n\tvar out = [], o = \"\", i = 0, c = \"\", lst='t', dt, j, cc;\n\tvar hr='H';\n\t/* Tokenize */\n\twhile(i < fmt.length) {\n\t\tswitch((c = fmt.charAt(i))) {\n\t\t\tcase 'G': /* General */\n\t\t\t\tif(!SSF_isgeneral(fmt, i)) throw new Error('unrecognized character ' + c + ' in ' +fmt);\n\t\t\t\tout[out.length] = {t:'G', v:'General'}; i+=7; break;\n\t\t\tcase '\"': /* Literal text */\n\t\t\t\tfor(o=\"\";(cc=fmt.charCodeAt(++i)) !== 34 && i < fmt.length;) o += String.fromCharCode(cc);\n\t\t\t\tout[out.length] = {t:'t', v:o}; ++i; break;\n\t\t\tcase '\\\\': var w = fmt.charAt(++i), t = (w === \"(\" || w === \")\") ? w : 't';\n\t\t\t\tout[out.length] = {t:t, v:w}; ++i; break;\n\t\t\tcase '_': out[out.length] = {t:'t', v:\" \"}; i+=2; break;\n\t\t\tcase '@': /* Text Placeholder */\n\t\t\t\tout[out.length] = {t:'T', v:v}; ++i; break;\n\t\t\tcase 'B': case 'b':\n\t\t\t\tif(fmt.charAt(i+1) === \"1\" || fmt.charAt(i+1) === \"2\") {\n\t\t\t\t\tif(dt==null) { dt=SSF_parse_date_code(v, opts, fmt.charAt(i+1) === \"2\"); if(dt==null) return \"\"; }\n\t\t\t\t\tout[out.length] = {t:'X', v:fmt.substr(i,2)}; lst = c; i+=2; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase 'M': case 'D': case 'Y': case 'H': case 'S': case 'E':\n\t\t\t\tc = c.toLowerCase();\n\t\t\t\t/* falls through */\n\t\t\tcase 'm': case 'd': case 'y': case 'h': case 's': case 'e': case 'g':\n\t\t\t\tif(v < 0) return \"\";\n\t\t\t\tif(dt==null) { dt=SSF_parse_date_code(v, opts); if(dt==null) return \"\"; }\n\t\t\t\to = c; while(++i < fmt.length && fmt.charAt(i).toLowerCase() === c) o+=c;\n\t\t\t\tif(c === 'm' && lst.toLowerCase() === 'h') c = 'M';\n\t\t\t\tif(c === 'h') c = hr;\n\t\t\t\tout[out.length] = {t:c, v:o}; lst = c; break;\n\t\t\tcase 'A': case 'a': case '上':\n\t\t\t\tvar q={t:c, v:c};\n\t\t\t\tif(dt==null) dt=SSF_parse_date_code(v, opts);\n\t\t\t\tif(fmt.substr(i, 3).toUpperCase() === \"A/P\") { if(dt!=null) q.v = dt.H >= 12 ? \"P\" : \"A\"; q.t = 'T'; hr='h';i+=3;}\n\t\t\t\telse if(fmt.substr(i,5).toUpperCase() === \"AM/PM\") { if(dt!=null) q.v = dt.H >= 12 ? \"PM\" : \"AM\"; q.t = 'T'; i+=5; hr='h'; }\n\t\t\t\telse if(fmt.substr(i,5).toUpperCase() === \"上午/下午\") { if(dt!=null) q.v = dt.H >= 12 ? \"下午\" : \"上午\"; q.t = 'T'; i+=5; hr='h'; }\n\t\t\t\telse { q.t = \"t\"; ++i; }\n\t\t\t\tif(dt==null && q.t === 'T') return \"\";\n\t\t\t\tout[out.length] = q; lst = c; break;\n\t\t\tcase '[':\n\t\t\t\to = c;\n\t\t\t\twhile(fmt.charAt(i++) !== ']' && i < fmt.length) o += fmt.charAt(i);\n\t\t\t\tif(o.slice(-1) !== ']') throw 'unterminated \"[\" block: |' + o + '|';\n\t\t\t\tif(o.match(SSF_abstime)) {\n\t\t\t\t\tif(dt==null) { dt=SSF_parse_date_code(v, opts); if(dt==null) return \"\"; }\n\t\t\t\t\tout[out.length] = {t:'Z', v:o.toLowerCase()};\n\t\t\t\t\tlst = o.charAt(1);\n\t\t\t\t} else if(o.indexOf(\"$\") > -1) {\n\t\t\t\t\to = (o.match(/\\$([^-\\[\\]]*)/)||[])[1]||\"$\";\n\t\t\t\t\tif(!fmt_is_date(fmt)) out[out.length] = {t:'t',v:o};\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\t/* Numbers */\n\t\t\tcase '.':\n\t\t\t\tif(dt != null) {\n\t\t\t\t\to = c; while(++i < fmt.length && (c=fmt.charAt(i)) === \"0\") o += c;\n\t\t\t\t\tout[out.length] = {t:'s', v:o}; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase '0': case '#':\n\t\t\t\to = c; while(++i < fmt.length && \"0#?.,E+-%\".indexOf(c=fmt.charAt(i)) > -1) o += c;\n\t\t\t\tout[out.length] = {t:'n', v:o}; break;\n\t\t\tcase '?':\n\t\t\t\to = c; while(fmt.charAt(++i) === c) o+=c;\n\t\t\t\tout[out.length] = {t:c, v:o}; lst = c; break;\n\t\t\tcase '*': ++i; if(fmt.charAt(i) == ' ' || fmt.charAt(i) == '*') ++i; break; // **\n\t\t\tcase '(': case ')': out[out.length] = {t:(flen===1?'t':c), v:c}; ++i; break;\n\t\t\tcase '1': case '2': case '3': case '4': case '5': case '6': case '7': case '8': case '9':\n\t\t\t\to = c; while(i < fmt.length && \"0123456789\".indexOf(fmt.charAt(++i)) > -1) o+=fmt.charAt(i);\n\t\t\t\tout[out.length] = {t:'D', v:o}; break;\n\t\t\tcase ' ': out[out.length] = {t:c, v:c}; ++i; break;\n\t\t\tcase '$': out[out.length] = {t:'t', v:'$'}; ++i; break;\n\t\t\tdefault:\n\t\t\t\tif(\",$-+/():!^&'~{}<>=€acfijklopqrtuvwxzP\".indexOf(c) === -1) throw new Error('unrecognized character ' + c + ' in ' + fmt);\n\t\t\t\tout[out.length] = {t:'t', v:c}; ++i; break;\n\t\t}\n\t}\n\n\t/* Scan for date/time parts */\n\tvar bt = 0, ss0 = 0, ssm;\n\tfor(i=out.length-1, lst='t'; i >= 0; --i) {\n\t\tswitch(out[i].t) {\n\t\t\tcase 'h': case 'H': out[i].t = hr; lst='h'; if(bt < 1) bt = 1; break;\n\t\t\tcase 's':\n\t\t\t\tif((ssm=out[i].v.match(/\\.0+$/))) ss0=Math.max(ss0,ssm[0].length-1);\n\t\t\t\tif(bt < 3) bt = 3;\n\t\t\t/* falls through */\n\t\t\tcase 'd': case 'y': case 'M': case 'e': lst=out[i].t; break;\n\t\t\tcase 'm': if(lst === 's') { out[i].t = 'M'; if(bt < 2) bt = 2; } break;\n\t\t\tcase 'X': /*if(out[i].v === \"B2\");*/\n\t\t\t\tbreak;\n\t\t\tcase 'Z':\n\t\t\t\tif(bt < 1 && out[i].v.match(/[Hh]/)) bt = 1;\n\t\t\t\tif(bt < 2 && out[i].v.match(/[Mm]/)) bt = 2;\n\t\t\t\tif(bt < 3 && out[i].v.match(/[Ss]/)) bt = 3;\n\t\t}\n\t}\n\t/* time rounding depends on presence of minute / second / usec fields */\n\tswitch(bt) {\n\t\tcase 0: break;\n\t\tcase 1:\n\t\t\t/*::if(!dt) break;*/\n\t\t\tif(dt.u >= 0.5) { dt.u = 0; ++dt.S; }\n\t\t\tif(dt.S >=  60) { dt.S = 0; ++dt.M; }\n\t\t\tif(dt.M >=  60) { dt.M = 0; ++dt.H; }\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\t/*::if(!dt) break;*/\n\t\t\tif(dt.u >= 0.5) { dt.u = 0; ++dt.S; }\n\t\t\tif(dt.S >=  60) { dt.S = 0; ++dt.M; }\n\t\t\tbreak;\n\t}\n\n\t/* replace fields */\n\tvar nstr = \"\", jj;\n\tfor(i=0; i < out.length; ++i) {\n\t\tswitch(out[i].t) {\n\t\t\tcase 't': case 'T': case ' ': case 'D': break;\n\t\t\tcase 'X': out[i].v = \"\"; out[i].t = \";\"; break;\n\t\t\tcase 'd': case 'm': case 'y': case 'h': case 'H': case 'M': case 's': case 'e': case 'b': case 'Z':\n\t\t\t\t/*::if(!dt) throw \"unreachable\"; */\n\t\t\t\tout[i].v = SSF_write_date(out[i].t.charCodeAt(0), out[i].v, dt, ss0);\n\t\t\t\tout[i].t = 't'; break;\n\t\t\tcase 'n': case '?':\n\t\t\t\tjj = i+1;\n\t\t\t\twhile(out[jj] != null && (\n\t\t\t\t\t(c=out[jj].t) === \"?\" || c === \"D\" ||\n\t\t\t\t\t((c === \" \" || c === \"t\") && out[jj+1] != null && (out[jj+1].t === '?' || out[jj+1].t === \"t\" && out[jj+1].v === '/')) ||\n\t\t\t\t\t(out[i].t === '(' && (c === ' ' || c === 'n' || c === ')')) ||\n\t\t\t\t\t(c === 't' && (out[jj].v === '/' || out[jj].v === ' ' && out[jj+1] != null && out[jj+1].t == '?'))\n\t\t\t\t)) {\n\t\t\t\t\tout[i].v += out[jj].v;\n\t\t\t\t\tout[jj] = {v:\"\", t:\";\"}; ++jj;\n\t\t\t\t}\n\t\t\t\tnstr += out[i].v;\n\t\t\t\ti = jj-1; break;\n\t\t\tcase 'G': out[i].t = 't'; out[i].v = SSF_general(v,opts); break;\n\t\t}\n\t}\n\tvar vv = \"\", myv, ostr;\n\tif(nstr.length > 0) {\n\t\tif(nstr.charCodeAt(0) == 40) /* '(' */ {\n\t\t\tmyv = (v<0&&nstr.charCodeAt(0) === 45 ? -v : v);\n\t\t\tostr = write_num('n', nstr, myv);\n\t\t} else {\n\t\t\tmyv = (v<0 && flen > 1 ? -v : v);\n\t\t\tostr = write_num('n', nstr, myv);\n\t\t\tif(myv < 0 && out[0] && out[0].t == 't') {\n\t\t\t\tostr = ostr.substr(1);\n\t\t\t\tout[0].v = \"-\" + out[0].v;\n\t\t\t}\n\t\t}\n\t\tjj=ostr.length-1;\n\t\tvar decpt = out.length;\n\t\tfor(i=0; i < out.length; ++i) if(out[i] != null && out[i].t != 't' && out[i].v.indexOf(\".\") > -1) { decpt = i; break; }\n\t\tvar lasti=out.length;\n\t\tif(decpt === out.length && ostr.indexOf(\"E\") === -1) {\n\t\t\tfor(i=out.length-1; i>= 0;--i) {\n\t\t\t\tif(out[i] == null || 'n?'.indexOf(out[i].t) === -1) continue;\n\t\t\t\tif(jj>=out[i].v.length-1) { jj -= out[i].v.length; out[i].v = ostr.substr(jj+1, out[i].v.length); }\n\t\t\t\telse if(jj < 0) out[i].v = \"\";\n\t\t\t\telse { out[i].v = ostr.substr(0, jj+1); jj = -1; }\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t\tif(jj>=0 && lasti<out.length) out[lasti].v = ostr.substr(0,jj+1) + out[lasti].v;\n\t\t}\n\t\telse if(decpt !== out.length && ostr.indexOf(\"E\") === -1) {\n\t\t\tjj = ostr.indexOf(\".\")-1;\n\t\t\tfor(i=decpt; i>= 0; --i) {\n\t\t\t\tif(out[i] == null || 'n?'.indexOf(out[i].t) === -1) continue;\n\t\t\t\tj=out[i].v.indexOf(\".\")>-1&&i===decpt?out[i].v.indexOf(\".\")-1:out[i].v.length-1;\n\t\t\t\tvv = out[i].v.substr(j+1);\n\t\t\t\tfor(; j>=0; --j) {\n\t\t\t\t\tif(jj>=0 && (out[i].v.charAt(j) === \"0\" || out[i].v.charAt(j) === \"#\")) vv = ostr.charAt(jj--) + vv;\n\t\t\t\t}\n\t\t\t\tout[i].v = vv;\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t\tif(jj>=0 && lasti<out.length) out[lasti].v = ostr.substr(0,jj+1) + out[lasti].v;\n\t\t\tjj = ostr.indexOf(\".\")+1;\n\t\t\tfor(i=decpt; i<out.length; ++i) {\n\t\t\t\tif(out[i] == null || ('n?('.indexOf(out[i].t) === -1 && i !== decpt)) continue;\n\t\t\t\tj=out[i].v.indexOf(\".\")>-1&&i===decpt?out[i].v.indexOf(\".\")+1:0;\n\t\t\t\tvv = out[i].v.substr(0,j);\n\t\t\t\tfor(; j<out[i].v.length; ++j) {\n\t\t\t\t\tif(jj<ostr.length) vv += ostr.charAt(jj++);\n\t\t\t\t}\n\t\t\t\tout[i].v = vv;\n\t\t\t\tout[i].t = 't';\n\t\t\t\tlasti = i;\n\t\t\t}\n\t\t}\n\t}\n\tfor(i=0; i<out.length; ++i) if(out[i] != null && 'n?'.indexOf(out[i].t)>-1) {\n\t\tmyv = (flen >1 && v < 0 && i>0 && out[i-1].v === \"-\" ? -v:v);\n\t\tout[i].v = write_num(out[i].t, out[i].v, myv);\n\t\tout[i].t = 't';\n\t}\n\tvar retval = \"\";\n\tfor(i=0; i !== out.length; ++i) if(out[i] != null) retval += out[i].v;\n\treturn retval;\n}\n\nvar cfregex2 = /\\[(=|>[=]?|<[>=]?)(-?\\d+(?:\\.\\d*)?)\\]/;\nfunction chkcond(v, rr) {\n\tif(rr == null) return false;\n\tvar thresh = parseFloat(rr[2]);\n\tswitch(rr[1]) {\n\t\tcase \"=\":  if(v == thresh) return true; break;\n\t\tcase \">\":  if(v >  thresh) return true; break;\n\t\tcase \"<\":  if(v <  thresh) return true; break;\n\t\tcase \"<>\": if(v != thresh) return true; break;\n\t\tcase \">=\": if(v >= thresh) return true; break;\n\t\tcase \"<=\": if(v <= thresh) return true; break;\n\t}\n\treturn false;\n}\nfunction choose_fmt(f/*:string*/, v/*:any*/) {\n\tvar fmt = SSF_split_fmt(f);\n\tvar l = fmt.length, lat = fmt[l-1].indexOf(\"@\");\n\tif(l<4 && lat>-1) --l;\n\tif(fmt.length > 4) throw new Error(\"cannot find right format for |\" + fmt.join(\"|\") + \"|\");\n\tif(typeof v !== \"number\") return [4, fmt.length === 4 || lat>-1?fmt[fmt.length-1]:\"@\"];\n\tswitch(fmt.length) {\n\t\tcase 1: fmt = lat>-1 ? [\"General\", \"General\", \"General\", fmt[0]] : [fmt[0], fmt[0], fmt[0], \"@\"]; break;\n\t\tcase 2: fmt = lat>-1 ? [fmt[0], fmt[0], fmt[0], fmt[1]] : [fmt[0], fmt[1], fmt[0], \"@\"]; break;\n\t\tcase 3: fmt = lat>-1 ? [fmt[0], fmt[1], fmt[0], fmt[2]] : [fmt[0], fmt[1], fmt[2], \"@\"]; break;\n\t\tcase 4: break;\n\t}\n\tvar ff = v > 0 ? fmt[0] : v < 0 ? fmt[1] : fmt[2];\n\tif(fmt[0].indexOf(\"[\") === -1 && fmt[1].indexOf(\"[\") === -1) return [l, ff];\n\tif(fmt[0].match(/\\[[=<>]/) != null || fmt[1].match(/\\[[=<>]/) != null) {\n\t\tvar m1 = fmt[0].match(cfregex2);\n\t\tvar m2 = fmt[1].match(cfregex2);\n\t\treturn chkcond(v, m1) ? [l, fmt[0]] : chkcond(v, m2) ? [l, fmt[1]] : [l, fmt[m1 != null && m2 != null ? 2 : 1]];\n\t}\n\treturn [l, ff];\n}\nfunction SSF_format(fmt/*:string|number*/,v/*:any*/,o/*:?any*/) {\n\tif(o == null) o = {};\n\tvar sfmt = \"\";\n\tswitch(typeof fmt) {\n\t\tcase \"string\":\n\t\t\tif(fmt == \"m/d/yy\" && o.dateNF) sfmt = o.dateNF;\n\t\t\telse sfmt = fmt;\n\t\t\tbreak;\n\t\tcase \"number\":\n\t\t\tif(fmt == 14 && o.dateNF) sfmt = o.dateNF;\n\t\t\telse sfmt = (o.table != null ? (o.table/*:any*/) : table_fmt)[fmt];\n\t\t\tif(sfmt == null) sfmt = (o.table && o.table[SSF_default_map[fmt]]) || table_fmt[SSF_default_map[fmt]];\n\t\t\tif(sfmt == null) sfmt = SSF_default_str[fmt] || \"General\";\n\t\t\tbreak;\n\t}\n\tif(SSF_isgeneral(sfmt,0)) return SSF_general(v, o);\n\tif(v instanceof Date) v = datenum_local(v, o.date1904);\n\tvar f = choose_fmt(sfmt, v);\n\tif(SSF_isgeneral(f[1])) return SSF_general(v, o);\n\tif(v === true) v = \"TRUE\"; else if(v === false) v = \"FALSE\";\n\telse if(v === \"\" || v == null) return \"\";\n\treturn eval_fmt(f[1], v, o, f[0]);\n}\nfunction SSF_load(fmt/*:string*/, idx/*:?number*/)/*:number*/ {\n\tif(typeof idx != 'number') {\n\t\tidx = +idx || -1;\n/*::if(typeof idx != 'number') return 0x188; */\n\t\tfor(var i = 0; i < 0x0188; ++i) {\n/*::if(typeof idx != 'number') return 0x188; */\n\t\t\tif(table_fmt[i] == undefined) { if(idx < 0) idx = i; continue; }\n\t\t\tif(table_fmt[i] == fmt) { idx = i; break; }\n\t\t}\n/*::if(typeof idx != 'number') return 0x188; */\n\t\tif(idx < 0) idx = 0x187;\n\t}\n/*::if(typeof idx != 'number') return 0x188; */\n\ttable_fmt[idx] = fmt;\n\treturn idx;\n}\nfunction SSF_load_table(tbl/*:SSFTable*/)/*:void*/ {\n\tfor(var i=0; i!=0x0188; ++i)\n\t\tif(tbl[i] !== undefined) SSF_load(tbl[i], i);\n}\n\nfunction make_ssf() {\n\ttable_fmt = SSF_init_table();\n}\n\nvar SSF = {\n\tformat: SSF_format,\n\tload: SSF_load,\n\t_table: table_fmt,\n\tload_table: SSF_load_table,\n\tparse_date_code: SSF_parse_date_code,\n\tis_date: fmt_is_date,\n\tget_table: function get_table() { return SSF._table = table_fmt; }\n};\n\nvar SSFImplicit/*{[number]:string}*/ = ({\n\t\"5\": '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\t\"6\": '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\t\"7\": '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\t\"8\": '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t\"23\": 'General', \"24\": 'General', \"25\": 'General', \"26\": 'General',\n\t\"27\": 'm/d/yy', \"28\": 'm/d/yy', \"29\": 'm/d/yy', \"30\": 'm/d/yy', \"31\": 'm/d/yy',\n\t\"32\": 'h:mm:ss', \"33\": 'h:mm:ss', \"34\": 'h:mm:ss', \"35\": 'h:mm:ss',\n\t\"36\": 'm/d/yy',\n\t\"41\": '_(* #,##0_);_(* \\(#,##0\\);_(* \"-\"_);_(@_)',\n\t\"42\": '_(\"$\"* #,##0_);_(\"$\"* \\(#,##0\\);_(\"$\"* \"-\"_);_(@_)',\n\t\"43\": '_(* #,##0.00_);_(* \\(#,##0.00\\);_(* \"-\"??_);_(@_)',\n\t\"44\": '_(\"$\"* #,##0.00_);_(\"$\"* \\(#,##0.00\\);_(\"$\"* \"-\"??_);_(@_)',\n\t\"50\": 'm/d/yy', \"51\": 'm/d/yy', \"52\": 'm/d/yy', \"53\": 'm/d/yy', \"54\": 'm/d/yy',\n\t\"55\": 'm/d/yy', \"56\": 'm/d/yy', \"57\": 'm/d/yy', \"58\": 'm/d/yy',\n\t\"59\": '0',\n\t\"60\": '0.00',\n\t\"61\": '#,##0',\n\t\"62\": '#,##0.00',\n\t\"63\": '\"$\"#,##0_);\\\\(\"$\"#,##0\\\\)',\n\t\"64\": '\"$\"#,##0_);[Red]\\\\(\"$\"#,##0\\\\)',\n\t\"65\": '\"$\"#,##0.00_);\\\\(\"$\"#,##0.00\\\\)',\n\t\"66\": '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t\"67\": '0%',\n\t\"68\": '0.00%',\n\t\"69\": '# ?/?',\n\t\"70\": '# ??/??',\n\t\"71\": 'm/d/yy',\n\t\"72\": 'm/d/yy',\n\t\"73\": 'd-mmm-yy',\n\t\"74\": 'd-mmm',\n\t\"75\": 'mmm-yy',\n\t\"76\": 'h:mm',\n\t\"77\": 'h:mm:ss',\n\t\"78\": 'm/d/yy h:mm',\n\t\"79\": 'mm:ss',\n\t\"80\": '[h]:mm:ss',\n\t\"81\": 'mmss.0'\n}/*:any*/);\n\n/* dateNF parse TODO: move to SSF */\nvar dateNFregex = /[dD]+|[mM]+|[yYeE]+|[Hh]+|[Ss]+/g;\nfunction dateNF_regex(dateNF/*:string|number*/)/*:RegExp*/ {\n\tvar fmt = typeof dateNF == \"number\" ? table_fmt[dateNF] : dateNF;\n\tfmt = fmt.replace(dateNFregex, \"(\\\\d+)\");\n\treturn new RegExp(\"^\" + fmt + \"$\");\n}\nfunction dateNF_fix(str/*:string*/, dateNF/*:string*/, match/*:Array<string>*/)/*:string*/ {\n\tvar Y = -1, m = -1, d = -1, H = -1, M = -1, S = -1;\n\t(dateNF.match(dateNFregex)||[]).forEach(function(n, i) {\n\t\tvar v = parseInt(match[i+1], 10);\n\t\tswitch(n.toLowerCase().charAt(0)) {\n\t\t\tcase 'y': Y = v; break; case 'd': d = v; break;\n\t\t\tcase 'h': H = v; break; case 's': S = v; break;\n\t\t\tcase 'm': if(H >= 0) M = v; else m = v; break;\n\t\t}\n\t});\n\tif(S >= 0 && M == -1 && m >= 0) { M = m; m = -1; }\n\tvar datestr = ((\"\" + (Y>=0?Y: new Date().getFullYear())).slice(-4) + \"-\" + (\"00\" + (m>=1?m:1)).slice(-2) + \"-\" + (\"00\" + (d>=1?d:1)).slice(-2));\n\tif(datestr.length == 7) datestr = \"0\" + datestr;\n\tif(datestr.length == 8) datestr = \"20\" + datestr;\n\tvar timestr = ((\"00\" + (H>=0?H:0)).slice(-2) + \":\" + (\"00\" + (M>=0?M:0)).slice(-2) + \":\" + (\"00\" + (S>=0?S:0)).slice(-2));\n\tif(H == -1 && M == -1 && S == -1) return datestr;\n\tif(Y == -1 && m == -1 && d == -1) return timestr;\n\treturn datestr + \"T\" + timestr;\n}\n\n/*::\ndeclare var ReadShift:any;\ndeclare var CheckField:any;\ndeclare var prep_blob:any;\ndeclare var __readUInt32LE:any;\ndeclare var __readInt32LE:any;\ndeclare var __toBuffer:any;\ndeclare var __utf16le:any;\ndeclare var bconcat:any;\ndeclare var s2a:any;\ndeclare var chr0:any;\ndeclare var chr1:any;\ndeclare var has_buf:boolean;\ndeclare var new_buf:any;\ndeclare var new_raw_buf:any;\ndeclare var new_unsafe_buf:any;\ndeclare var Buffer_from:any;\n*/\n/* cfb.js (C) 2013-present SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*jshint eqnull:true */\n/*exported CFB */\n/*global Uint8Array:false, Uint16Array:false */\n\n/*::\ntype SectorEntry = {\n\tname?:string;\n\tnodes?:Array<number>;\n\tdata:RawBytes;\n};\ntype SectorList = {\n\t[k:string|number]:SectorEntry;\n\tname:?string;\n\tfat_addrs:Array<number>;\n\tssz:number;\n}\ntype CFBFiles = {[n:string]:CFBEntry};\n*/\n/* crc32.js (C) 2014-present SheetJS -- http://sheetjs.com */\n/* vim: set ts=2: */\n/*exported CRC32 */\nvar CRC32 = /*#__PURE__*/(function() {\nvar CRC32 = {};\nCRC32.version = '1.2.0';\n/* see perf/crc32table.js */\n/*global Int32Array */\nfunction signed_crc_table()/*:any*/ {\n\tvar c = 0, table/*:Array<number>*/ = new Array(256);\n\n\tfor(var n =0; n != 256; ++n){\n\t\tc = n;\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\tc = ((c&1) ? (-306674912 ^ (c >>> 1)) : (c >>> 1));\n\t\ttable[n] = c;\n\t}\n\n\treturn typeof Int32Array !== 'undefined' ? new Int32Array(table) : table;\n}\n\nvar T0 = signed_crc_table();\nfunction slice_by_16_tables(T) {\n\tvar c = 0, v = 0, n = 0, table/*:Array<number>*/ = typeof Int32Array !== 'undefined' ? new Int32Array(4096) : new Array(4096) ;\n\n\tfor(n = 0; n != 256; ++n) table[n] = T[n];\n\tfor(n = 0; n != 256; ++n) {\n\t\tv = T[n];\n\t\tfor(c = 256 + n; c < 4096; c += 256) v = table[c] = (v >>> 8) ^ T[v & 0xFF];\n\t}\n\tvar out = [];\n\tfor(n = 1; n != 16; ++n) out[n - 1] = typeof Int32Array !== 'undefined' ? table.subarray(n * 256, n * 256 + 256) : table.slice(n * 256, n * 256 + 256);\n\treturn out;\n}\nvar TT = slice_by_16_tables(T0);\nvar T1 = TT[0],  T2 = TT[1],  T3 = TT[2],  T4 = TT[3],  T5 = TT[4];\nvar T6 = TT[5],  T7 = TT[6],  T8 = TT[7],  T9 = TT[8],  Ta = TT[9];\nvar Tb = TT[10], Tc = TT[11], Td = TT[12], Te = TT[13], Tf = TT[14];\nfunction crc32_bstr(bstr/*:string*/, seed/*:number*/)/*:number*/ {\n\tvar C = seed/*:: ? 0 : 0 */ ^ -1;\n\tfor(var i = 0, L = bstr.length; i < L;) C = (C>>>8) ^ T0[(C^bstr.charCodeAt(i++))&0xFF];\n\treturn ~C;\n}\n\nfunction crc32_buf(B/*:Uint8Array|Array<number>*/, seed/*:number*/)/*:number*/ {\n\tvar C = seed/*:: ? 0 : 0 */ ^ -1, L = B.length - 15, i = 0;\n\tfor(; i < L;) C =\n\t\tTf[B[i++] ^ (C & 255)] ^\n\t\tTe[B[i++] ^ ((C >> 8) & 255)] ^\n\t\tTd[B[i++] ^ ((C >> 16) & 255)] ^\n\t\tTc[B[i++] ^ (C >>> 24)] ^\n\t\tTb[B[i++]] ^ Ta[B[i++]] ^ T9[B[i++]] ^ T8[B[i++]] ^\n\t\tT7[B[i++]] ^ T6[B[i++]] ^ T5[B[i++]] ^ T4[B[i++]] ^\n\t\tT3[B[i++]] ^ T2[B[i++]] ^ T1[B[i++]] ^ T0[B[i++]];\n\tL += 15;\n\twhile(i < L) C = (C>>>8) ^ T0[(C^B[i++])&0xFF];\n\treturn ~C;\n}\n\nfunction crc32_str(str/*:string*/, seed/*:number*/)/*:number*/ {\n\tvar C = seed ^ -1;\n\tfor(var i = 0, L = str.length, c = 0, d = 0; i < L;) {\n\t\tc = str.charCodeAt(i++);\n\t\tif(c < 0x80) {\n\t\t\tC = (C>>>8) ^ T0[(C^c)&0xFF];\n\t\t} else if(c < 0x800) {\n\t\t\tC = (C>>>8) ^ T0[(C ^ (192|((c>>6)&31)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|(c&63)))&0xFF];\n\t\t} else if(c >= 0xD800 && c < 0xE000) {\n\t\t\tc = (c&1023)+64; d = str.charCodeAt(i++)&1023;\n\t\t\tC = (C>>>8) ^ T0[(C ^ (240|((c>>8)&7)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|((c>>2)&63)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|((d>>6)&15)|((c&3)<<4)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|(d&63)))&0xFF];\n\t\t} else {\n\t\t\tC = (C>>>8) ^ T0[(C ^ (224|((c>>12)&15)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|((c>>6)&63)))&0xFF];\n\t\t\tC = (C>>>8) ^ T0[(C ^ (128|(c&63)))&0xFF];\n\t\t}\n\t}\n\treturn ~C;\n}\nCRC32.table = T0;\nCRC32.bstr = crc32_bstr;\nCRC32.buf = crc32_buf;\nCRC32.str = crc32_str;\nreturn CRC32;\n})();\n/* [MS-CFB] v20171201 */\nvar CFB = /*#__PURE__*/(function _CFB(){\nvar exports = {};\nexports.version = '1.2.1';\n/* [MS-CFB] 2.6.4 */\nfunction namecmp(l/*:string*/, r/*:string*/)/*:number*/ {\n\tvar L = l.split(\"/\"), R = r.split(\"/\");\n\tfor(var i = 0, c = 0, Z = Math.min(L.length, R.length); i < Z; ++i) {\n\t\tif((c = L[i].length - R[i].length)) return c;\n\t\tif(L[i] != R[i]) return L[i] < R[i] ? -1 : 1;\n\t}\n\treturn L.length - R.length;\n}\nfunction dirname(p/*:string*/)/*:string*/ {\n\tif(p.charAt(p.length - 1) == \"/\") return (p.slice(0,-1).indexOf(\"/\") === -1) ? p : dirname(p.slice(0, -1));\n\tvar c = p.lastIndexOf(\"/\");\n\treturn (c === -1) ? p : p.slice(0, c+1);\n}\n\nfunction filename(p/*:string*/)/*:string*/ {\n\tif(p.charAt(p.length - 1) == \"/\") return filename(p.slice(0, -1));\n\tvar c = p.lastIndexOf(\"/\");\n\treturn (c === -1) ? p : p.slice(c+1);\n}\n/* -------------------------------------------------------------------------- */\n/* DOS Date format:\n   high|YYYYYYYm.mmmddddd.HHHHHMMM.MMMSSSSS|low\n   add 1980 to stored year\n   stored second should be doubled\n*/\n\n/* write JS date to buf as a DOS date */\nfunction write_dos_date(buf/*:CFBlob*/, date/*:Date|string*/) {\n\tif(typeof date === \"string\") date = new Date(date);\n\tvar hms/*:number*/ = date.getHours();\n\thms = hms << 6 | date.getMinutes();\n\thms = hms << 5 | (date.getSeconds()>>>1);\n\tbuf.write_shift(2, hms);\n\tvar ymd/*:number*/ = (date.getFullYear() - 1980);\n\tymd = ymd << 4 | (date.getMonth()+1);\n\tymd = ymd << 5 | date.getDate();\n\tbuf.write_shift(2, ymd);\n}\n\n/* read four bytes from buf and interpret as a DOS date */\nfunction parse_dos_date(buf/*:CFBlob*/)/*:Date*/ {\n\tvar hms = buf.read_shift(2) & 0xFFFF;\n\tvar ymd = buf.read_shift(2) & 0xFFFF;\n\tvar val = new Date();\n\tvar d = ymd & 0x1F; ymd >>>= 5;\n\tvar m = ymd & 0x0F; ymd >>>= 4;\n\tval.setMilliseconds(0);\n\tval.setFullYear(ymd + 1980);\n\tval.setMonth(m-1);\n\tval.setDate(d);\n\tvar S = hms & 0x1F; hms >>>= 5;\n\tvar M = hms & 0x3F; hms >>>= 6;\n\tval.setHours(hms);\n\tval.setMinutes(M);\n\tval.setSeconds(S<<1);\n\treturn val;\n}\nfunction parse_extra_field(blob/*:CFBlob*/)/*:any*/ {\n\tprep_blob(blob, 0);\n\tvar o = /*::(*/{}/*:: :any)*/;\n\tvar flags = 0;\n\twhile(blob.l <= blob.length - 4) {\n\t\tvar type = blob.read_shift(2);\n\t\tvar sz = blob.read_shift(2), tgt = blob.l + sz;\n\t\tvar p = {};\n\t\tswitch(type) {\n\t\t\t/* UNIX-style Timestamps */\n\t\t\tcase 0x5455: {\n\t\t\t\tflags = blob.read_shift(1);\n\t\t\t\tif(flags & 1) p.mtime = blob.read_shift(4);\n\t\t\t\t/* for some reason, CD flag corresponds to LFH */\n\t\t\t\tif(sz > 5) {\n\t\t\t\t\tif(flags & 2) p.atime = blob.read_shift(4);\n\t\t\t\t\tif(flags & 4) p.ctime = blob.read_shift(4);\n\t\t\t\t}\n\t\t\t\tif(p.mtime) p.mt = new Date(p.mtime*1000);\n\t\t\t}\n\t\t\tbreak;\n\t\t}\n\t\tblob.l = tgt;\n\t\to[type] = p;\n\t}\n\treturn o;\n}\nvar fs/*:: = require('fs'); */;\nfunction get_fs() { return fs || (fs = {}); }\nfunction parse(file/*:RawBytes*/, options/*:CFBReadOpts*/)/*:CFBContainer*/ {\nif(file[0] == 0x50 && file[1] == 0x4b) return parse_zip(file, options);\nif((file[0] | 0x20) == 0x6d && (file[1]|0x20) == 0x69) return parse_mad(file, options);\nif(file.length < 512) throw new Error(\"CFB file size \" + file.length + \" < 512\");\nvar mver = 3;\nvar ssz = 512;\nvar nmfs = 0; // number of mini FAT sectors\nvar difat_sec_cnt = 0;\nvar dir_start = 0;\nvar minifat_start = 0;\nvar difat_start = 0;\n\nvar fat_addrs/*:Array<number>*/ = []; // locations of FAT sectors\n\n/* [MS-CFB] 2.2 Compound File Header */\nvar blob/*:CFBlob*/ = /*::(*/file.slice(0,512)/*:: :any)*/;\nprep_blob(blob, 0);\n\n/* major version */\nvar mv = check_get_mver(blob);\nmver = mv[0];\nswitch(mver) {\n\tcase 3: ssz = 512; break; case 4: ssz = 4096; break;\n\tcase 0: if(mv[1] == 0) return parse_zip(file, options);\n\t/* falls through */\n\tdefault: throw new Error(\"Major Version: Expected 3 or 4 saw \" + mver);\n}\n\n/* reprocess header */\nif(ssz !== 512) { blob = /*::(*/file.slice(0,ssz)/*:: :any)*/; prep_blob(blob, 28 /* blob.l */); }\n/* Save header for final object */\nvar header/*:RawBytes*/ = file.slice(0,ssz);\n\ncheck_shifts(blob, mver);\n\n// Number of Directory Sectors\nvar dir_cnt/*:number*/ = blob.read_shift(4, 'i');\nif(mver === 3 && dir_cnt !== 0) throw new Error('# Directory Sectors: Expected 0 saw ' + dir_cnt);\n\n// Number of FAT Sectors\nblob.l += 4;\n\n// First Directory Sector Location\ndir_start = blob.read_shift(4, 'i');\n\n// Transaction Signature\nblob.l += 4;\n\n// Mini Stream Cutoff Size\nblob.chk('00100000', 'Mini Stream Cutoff Size: ');\n\n// First Mini FAT Sector Location\nminifat_start = blob.read_shift(4, 'i');\n\n// Number of Mini FAT Sectors\nnmfs = blob.read_shift(4, 'i');\n\n// First DIFAT sector location\ndifat_start = blob.read_shift(4, 'i');\n\n// Number of DIFAT Sectors\ndifat_sec_cnt = blob.read_shift(4, 'i');\n\n// Grab FAT Sector Locations\nfor(var q = -1, j = 0; j < 109; ++j) { /* 109 = (512 - blob.l)>>>2; */\n\tq = blob.read_shift(4, 'i');\n\tif(q<0) break;\n\tfat_addrs[j] = q;\n}\n\n/** Break the file up into sectors */\nvar sectors/*:Array<RawBytes>*/ = sectorify(file, ssz);\n\nsleuth_fat(difat_start, difat_sec_cnt, sectors, ssz, fat_addrs);\n\n/** Chains */\nvar sector_list/*:SectorList*/ = make_sector_list(sectors, dir_start, fat_addrs, ssz);\n\nsector_list[dir_start].name = \"!Directory\";\nif(nmfs > 0 && minifat_start !== ENDOFCHAIN) sector_list[minifat_start].name = \"!MiniFAT\";\nsector_list[fat_addrs[0]].name = \"!FAT\";\nsector_list.fat_addrs = fat_addrs;\nsector_list.ssz = ssz;\n\n/* [MS-CFB] 2.6.1 Compound File Directory Entry */\nvar files/*:CFBFiles*/ = {}, Paths/*:Array<string>*/ = [], FileIndex/*:CFBFileIndex*/ = [], FullPaths/*:Array<string>*/ = [];\nread_directory(dir_start, sector_list, sectors, Paths, nmfs, files, FileIndex, minifat_start);\n\nbuild_full_paths(FileIndex, FullPaths, Paths);\nPaths.shift();\n\nvar o = {\n\tFileIndex: FileIndex,\n\tFullPaths: FullPaths\n};\n\n// $FlowIgnore\nif(options && options.raw) o.raw = {header: header, sectors: sectors};\nreturn o;\n} // parse\n\n/* [MS-CFB] 2.2 Compound File Header -- read up to major version */\nfunction check_get_mver(blob/*:CFBlob*/)/*:[number, number]*/ {\n\tif(blob[blob.l] == 0x50 && blob[blob.l + 1] == 0x4b) return [0, 0];\n\t// header signature 8\n\tblob.chk(HEADER_SIGNATURE, 'Header Signature: ');\n\n\t// clsid 16\n\t//blob.chk(HEADER_CLSID, 'CLSID: ');\n\tblob.l += 16;\n\n\t// minor version 2\n\tvar mver/*:number*/ = blob.read_shift(2, 'u');\n\n\treturn [blob.read_shift(2,'u'), mver];\n}\nfunction check_shifts(blob/*:CFBlob*/, mver/*:number*/)/*:void*/ {\n\tvar shift = 0x09;\n\n\t// Byte Order\n\t//blob.chk('feff', 'Byte Order: '); // note: some writers put 0xffff\n\tblob.l += 2;\n\n\t// Sector Shift\n\tswitch((shift = blob.read_shift(2))) {\n\t\tcase 0x09: if(mver != 3) throw new Error('Sector Shift: Expected 9 saw ' + shift); break;\n\t\tcase 0x0c: if(mver != 4) throw new Error('Sector Shift: Expected 12 saw ' + shift); break;\n\t\tdefault: throw new Error('Sector Shift: Expected 9 or 12 saw ' + shift);\n\t}\n\n\t// Mini Sector Shift\n\tblob.chk('0600', 'Mini Sector Shift: ');\n\n\t// Reserved\n\tblob.chk('000000000000', 'Reserved: ');\n}\n\n/** Break the file up into sectors */\nfunction sectorify(file/*:RawBytes*/, ssz/*:number*/)/*:Array<RawBytes>*/ {\n\tvar nsectors = Math.ceil(file.length/ssz)-1;\n\tvar sectors/*:Array<RawBytes>*/ = [];\n\tfor(var i=1; i < nsectors; ++i) sectors[i-1] = file.slice(i*ssz,(i+1)*ssz);\n\tsectors[nsectors-1] = file.slice(nsectors*ssz);\n\treturn sectors;\n}\n\n/* [MS-CFB] 2.6.4 Red-Black Tree */\nfunction build_full_paths(FI/*:CFBFileIndex*/, FP/*:Array<string>*/, Paths/*:Array<string>*/)/*:void*/ {\n\tvar i = 0, L = 0, R = 0, C = 0, j = 0, pl = Paths.length;\n\tvar dad/*:Array<number>*/ = [], q/*:Array<number>*/ = [];\n\n\tfor(; i < pl; ++i) { dad[i]=q[i]=i; FP[i]=Paths[i]; }\n\n\tfor(; j < q.length; ++j) {\n\t\ti = q[j];\n\t\tL = FI[i].L; R = FI[i].R; C = FI[i].C;\n\t\tif(dad[i] === i) {\n\t\t\tif(L !== -1 /*NOSTREAM*/ && dad[L] !== L) dad[i] = dad[L];\n\t\t\tif(R !== -1 && dad[R] !== R) dad[i] = dad[R];\n\t\t}\n\t\tif(C !== -1 /*NOSTREAM*/) dad[C] = i;\n\t\tif(L !== -1 && i != dad[i]) { dad[L] = dad[i]; if(q.lastIndexOf(L) < j) q.push(L); }\n\t\tif(R !== -1 && i != dad[i]) { dad[R] = dad[i]; if(q.lastIndexOf(R) < j) q.push(R); }\n\t}\n\tfor(i=1; i < pl; ++i) if(dad[i] === i) {\n\t\tif(R !== -1 /*NOSTREAM*/ && dad[R] !== R) dad[i] = dad[R];\n\t\telse if(L !== -1 && dad[L] !== L) dad[i] = dad[L];\n\t}\n\n\tfor(i=1; i < pl; ++i) {\n\t\tif(FI[i].type === 0 /* unknown */) continue;\n\t\tj = i;\n\t\tif(j != dad[j]) do {\n\t\t\tj = dad[j];\n\t\t\tFP[i] = FP[j] + \"/\" + FP[i];\n\t\t} while (j !== 0 && -1 !== dad[j] && j != dad[j]);\n\t\tdad[i] = -1;\n\t}\n\n\tFP[0] += \"/\";\n\tfor(i=1; i < pl; ++i) {\n\t\tif(FI[i].type !== 2 /* stream */) FP[i] += \"/\";\n\t}\n}\n\nfunction get_mfat_entry(entry/*:CFBEntry*/, payload/*:RawBytes*/, mini/*:?RawBytes*/)/*:CFBlob*/ {\n\tvar start = entry.start, size = entry.size;\n\t//return (payload.slice(start*MSSZ, start*MSSZ + size)/*:any*/);\n\tvar o = [];\n\tvar idx = start;\n\twhile(mini && size > 0 && idx >= 0) {\n\t\to.push(payload.slice(idx * MSSZ, idx * MSSZ + MSSZ));\n\t\tsize -= MSSZ;\n\t\tidx = __readInt32LE(mini, idx * 4);\n\t}\n\tif(o.length === 0) return (new_buf(0)/*:any*/);\n\treturn (bconcat(o).slice(0, entry.size)/*:any*/);\n}\n\n/** Chase down the rest of the DIFAT chain to build a comprehensive list\n    DIFAT chains by storing the next sector number as the last 32 bits */\nfunction sleuth_fat(idx/*:number*/, cnt/*:number*/, sectors/*:Array<RawBytes>*/, ssz/*:number*/, fat_addrs)/*:void*/ {\n\tvar q/*:number*/ = ENDOFCHAIN;\n\tif(idx === ENDOFCHAIN) {\n\t\tif(cnt !== 0) throw new Error(\"DIFAT chain shorter than expected\");\n\t} else if(idx !== -1 /*FREESECT*/) {\n\t\tvar sector = sectors[idx], m = (ssz>>>2)-1;\n\t\tif(!sector) return;\n\t\tfor(var i = 0; i < m; ++i) {\n\t\t\tif((q = __readInt32LE(sector,i*4)) === ENDOFCHAIN) break;\n\t\t\tfat_addrs.push(q);\n\t\t}\n\t\tsleuth_fat(__readInt32LE(sector,ssz-4),cnt - 1, sectors, ssz, fat_addrs);\n\t}\n}\n\n/** Follow the linked list of sectors for a given starting point */\nfunction get_sector_list(sectors/*:Array<RawBytes>*/, start/*:number*/, fat_addrs/*:Array<number>*/, ssz/*:number*/, chkd/*:?Array<boolean>*/)/*:SectorEntry*/ {\n\tvar buf/*:Array<number>*/ = [], buf_chain/*:Array<any>*/ = [];\n\tif(!chkd) chkd = [];\n\tvar modulus = ssz - 1, j = 0, jj = 0;\n\tfor(j=start; j>=0;) {\n\t\tchkd[j] = true;\n\t\tbuf[buf.length] = j;\n\t\tbuf_chain.push(sectors[j]);\n\t\tvar addr = fat_addrs[Math.floor(j*4/ssz)];\n\t\tjj = ((j*4) & modulus);\n\t\tif(ssz < 4 + jj) throw new Error(\"FAT boundary crossed: \" + j + \" 4 \"+ssz);\n\t\tif(!sectors[addr]) break;\n\t\tj = __readInt32LE(sectors[addr], jj);\n\t}\n\treturn {nodes: buf, data:__toBuffer([buf_chain])};\n}\n\n/** Chase down the sector linked lists */\nfunction make_sector_list(sectors/*:Array<RawBytes>*/, dir_start/*:number*/, fat_addrs/*:Array<number>*/, ssz/*:number*/)/*:SectorList*/ {\n\tvar sl = sectors.length, sector_list/*:SectorList*/ = ([]/*:any*/);\n\tvar chkd/*:Array<boolean>*/ = [], buf/*:Array<number>*/ = [], buf_chain/*:Array<RawBytes>*/ = [];\n\tvar modulus = ssz - 1, i=0, j=0, k=0, jj=0;\n\tfor(i=0; i < sl; ++i) {\n\t\tbuf = ([]/*:Array<number>*/);\n\t\tk = (i + dir_start); if(k >= sl) k-=sl;\n\t\tif(chkd[k]) continue;\n\t\tbuf_chain = [];\n\t\tvar seen = [];\n\t\tfor(j=k; j>=0;) {\n\t\t\tseen[j] = true;\n\t\t\tchkd[j] = true;\n\t\t\tbuf[buf.length] = j;\n\t\t\tbuf_chain.push(sectors[j]);\n\t\t\tvar addr/*:number*/ = fat_addrs[Math.floor(j*4/ssz)];\n\t\t\tjj = ((j*4) & modulus);\n\t\t\tif(ssz < 4 + jj) throw new Error(\"FAT boundary crossed: \" + j + \" 4 \"+ssz);\n\t\t\tif(!sectors[addr]) break;\n\t\t\tj = __readInt32LE(sectors[addr], jj);\n\t\t\tif(seen[j]) break;\n\t\t}\n\t\tsector_list[k] = ({nodes: buf, data:__toBuffer([buf_chain])}/*:SectorEntry*/);\n\t}\n\treturn sector_list;\n}\n\n/* [MS-CFB] 2.6.1 Compound File Directory Entry */\nfunction read_directory(dir_start/*:number*/, sector_list/*:SectorList*/, sectors/*:Array<RawBytes>*/, Paths/*:Array<string>*/, nmfs, files, FileIndex, mini) {\n\tvar minifat_store = 0, pl = (Paths.length?2:0);\n\tvar sector = sector_list[dir_start].data;\n\tvar i = 0, namelen = 0, name;\n\tfor(; i < sector.length; i+= 128) {\n\t\tvar blob/*:CFBlob*/ = /*::(*/sector.slice(i, i+128)/*:: :any)*/;\n\t\tprep_blob(blob, 64);\n\t\tnamelen = blob.read_shift(2);\n\t\tname = __utf16le(blob,0,namelen-pl);\n\t\tPaths.push(name);\n\t\tvar o/*:CFBEntry*/ = ({\n\t\t\tname:  name,\n\t\t\ttype:  blob.read_shift(1),\n\t\t\tcolor: blob.read_shift(1),\n\t\t\tL:     blob.read_shift(4, 'i'),\n\t\t\tR:     blob.read_shift(4, 'i'),\n\t\t\tC:     blob.read_shift(4, 'i'),\n\t\t\tclsid: blob.read_shift(16),\n\t\t\tstate: blob.read_shift(4, 'i'),\n\t\t\tstart: 0,\n\t\t\tsize: 0\n\t\t});\n\t\tvar ctime/*:number*/ = blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2);\n\t\tif(ctime !== 0) o.ct = read_date(blob, blob.l-8);\n\t\tvar mtime/*:number*/ = blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2) + blob.read_shift(2);\n\t\tif(mtime !== 0) o.mt = read_date(blob, blob.l-8);\n\t\to.start = blob.read_shift(4, 'i');\n\t\to.size = blob.read_shift(4, 'i');\n\t\tif(o.size < 0 && o.start < 0) { o.size = o.type = 0; o.start = ENDOFCHAIN; o.name = \"\"; }\n\t\tif(o.type === 5) { /* root */\n\t\t\tminifat_store = o.start;\n\t\t\tif(nmfs > 0 && minifat_store !== ENDOFCHAIN) sector_list[minifat_store].name = \"!StreamData\";\n\t\t\t/*minifat_size = o.size;*/\n\t\t} else if(o.size >= 4096 /* MSCSZ */) {\n\t\t\to.storage = 'fat';\n\t\t\tif(sector_list[o.start] === undefined) sector_list[o.start] = get_sector_list(sectors, o.start, sector_list.fat_addrs, sector_list.ssz);\n\t\t\tsector_list[o.start].name = o.name;\n\t\t\to.content = (sector_list[o.start].data.slice(0,o.size)/*:any*/);\n\t\t} else {\n\t\t\to.storage = 'minifat';\n\t\t\tif(o.size < 0) o.size = 0;\n\t\t\telse if(minifat_store !== ENDOFCHAIN && o.start !== ENDOFCHAIN && sector_list[minifat_store]) {\n\t\t\t\to.content = get_mfat_entry(o, sector_list[minifat_store].data, (sector_list[mini]||{}).data);\n\t\t\t}\n\t\t}\n\t\tif(o.content) prep_blob(o.content, 0);\n\t\tfiles[name] = o;\n\t\tFileIndex.push(o);\n\t}\n}\n\nfunction read_date(blob/*:RawBytes|CFBlob*/, offset/*:number*/)/*:Date*/ {\n\treturn new Date(( ( (__readUInt32LE(blob,offset+4)/1e7)*Math.pow(2,32)+__readUInt32LE(blob,offset)/1e7 ) - 11644473600)*1000);\n}\n\nfunction read_file(filename/*:string*/, options/*:CFBReadOpts*/) {\n\tget_fs();\n\treturn parse(fs.readFileSync(filename), options);\n}\n\nfunction read(blob/*:RawBytes|string*/, options/*:CFBReadOpts*/) {\n\tvar type = options && options.type;\n\tif(!type) {\n\t\tif(has_buf && Buffer.isBuffer(blob)) type = \"buffer\";\n\t}\n\tswitch(type || \"base64\") {\n\t\tcase \"file\": /*:: if(typeof blob !== 'string') throw \"Must pass a filename when type='file'\"; */return read_file(blob, options);\n\t\tcase \"base64\": /*:: if(typeof blob !== 'string') throw \"Must pass a base64-encoded binary string when type='file'\"; */return parse(s2a(Base64_decode(blob)), options);\n\t\tcase \"binary\": /*:: if(typeof blob !== 'string') throw \"Must pass a binary string when type='file'\"; */return parse(s2a(blob), options);\n\t}\n\treturn parse(/*::typeof blob == 'string' ? new Buffer(blob, 'utf-8') : */blob, options);\n}\n\nfunction init_cfb(cfb/*:CFBContainer*/, opts/*:?any*/)/*:void*/ {\n\tvar o = opts || {}, root = o.root || \"Root Entry\";\n\tif(!cfb.FullPaths) cfb.FullPaths = [];\n\tif(!cfb.FileIndex) cfb.FileIndex = [];\n\tif(cfb.FullPaths.length !== cfb.FileIndex.length) throw new Error(\"inconsistent CFB structure\");\n\tif(cfb.FullPaths.length === 0) {\n\t\tcfb.FullPaths[0] = root + \"/\";\n\t\tcfb.FileIndex[0] = ({ name: root, type: 5 }/*:any*/);\n\t}\n\tif(o.CLSID) cfb.FileIndex[0].clsid = o.CLSID;\n\tseed_cfb(cfb);\n}\nfunction seed_cfb(cfb/*:CFBContainer*/)/*:void*/ {\n\tvar nm = \"\\u0001Sh33tJ5\";\n\tif(CFB.find(cfb, \"/\" + nm)) return;\n\tvar p = new_buf(4); p[0] = 55; p[1] = p[3] = 50; p[2] = 54;\n\tcfb.FileIndex.push(({ name: nm, type: 2, content:p, size:4, L:69, R:69, C:69 }/*:any*/));\n\tcfb.FullPaths.push(cfb.FullPaths[0] + nm);\n\trebuild_cfb(cfb);\n}\nfunction rebuild_cfb(cfb/*:CFBContainer*/, f/*:?boolean*/)/*:void*/ {\n\tinit_cfb(cfb);\n\tvar gc = false, s = false;\n\tfor(var i = cfb.FullPaths.length - 1; i >= 0; --i) {\n\t\tvar _file = cfb.FileIndex[i];\n\t\tswitch(_file.type) {\n\t\t\tcase 0:\n\t\t\t\tif(s) gc = true;\n\t\t\t\telse { cfb.FileIndex.pop(); cfb.FullPaths.pop(); }\n\t\t\t\tbreak;\n\t\t\tcase 1: case 2: case 5:\n\t\t\t\ts = true;\n\t\t\t\tif(isNaN(_file.R * _file.L * _file.C)) gc = true;\n\t\t\t\tif(_file.R > -1 && _file.L > -1 && _file.R == _file.L) gc = true;\n\t\t\t\tbreak;\n\t\t\tdefault: gc = true; break;\n\t\t}\n\t}\n\tif(!gc && !f) return;\n\n\tvar now = new Date(1987, 1, 19), j = 0;\n\t// Track which names exist\n\tvar fullPaths = Object.create ? Object.create(null) : {};\n\tvar data/*:Array<[string, CFBEntry]>*/ = [];\n\tfor(i = 0; i < cfb.FullPaths.length; ++i) {\n\t\tfullPaths[cfb.FullPaths[i]] = true;\n\t\tif(cfb.FileIndex[i].type === 0) continue;\n\t\tdata.push([cfb.FullPaths[i], cfb.FileIndex[i]]);\n\t}\n\tfor(i = 0; i < data.length; ++i) {\n\t\tvar dad = dirname(data[i][0]);\n\t\ts = fullPaths[dad];\n\t\tif(!s) {\n\t\t\tdata.push([dad, ({\n\t\t\t\tname: filename(dad).replace(\"/\",\"\"),\n\t\t\t\ttype: 1,\n\t\t\t\tclsid: HEADER_CLSID,\n\t\t\t\tct: now, mt: now,\n\t\t\t\tcontent: null\n\t\t\t}/*:any*/)]);\n\t\t\t// Add name to set\n\t\t\tfullPaths[dad] = true;\n\t\t}\n\t}\n\n\tdata.sort(function(x,y) { return namecmp(x[0], y[0]); });\n\tcfb.FullPaths = []; cfb.FileIndex = [];\n\tfor(i = 0; i < data.length; ++i) { cfb.FullPaths[i] = data[i][0]; cfb.FileIndex[i] = data[i][1]; }\n\tfor(i = 0; i < data.length; ++i) {\n\t\tvar elt = cfb.FileIndex[i];\n\t\tvar nm = cfb.FullPaths[i];\n\n\t\telt.name =  filename(nm).replace(\"/\",\"\");\n\t\telt.L = elt.R = elt.C = -(elt.color = 1);\n\t\telt.size = elt.content ? elt.content.length : 0;\n\t\telt.start = 0;\n\t\telt.clsid = (elt.clsid || HEADER_CLSID);\n\t\tif(i === 0) {\n\t\t\telt.C = data.length > 1 ? 1 : -1;\n\t\t\telt.size = 0;\n\t\t\telt.type = 5;\n\t\t} else if(nm.slice(-1) == \"/\") {\n\t\t\tfor(j=i+1;j < data.length; ++j) if(dirname(cfb.FullPaths[j])==nm) break;\n\t\t\telt.C = j >= data.length ? -1 : j;\n\t\t\tfor(j=i+1;j < data.length; ++j) if(dirname(cfb.FullPaths[j])==dirname(nm)) break;\n\t\t\telt.R = j >= data.length ? -1 : j;\n\t\t\telt.type = 1;\n\t\t} else {\n\t\t\tif(dirname(cfb.FullPaths[i+1]||\"\") == dirname(nm)) elt.R = i + 1;\n\t\t\telt.type = 2;\n\t\t}\n\t}\n\n}\n\nfunction _write(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:RawBytes|string*/ {\n\tvar _opts = options || {};\n\t/* MAD is order-sensitive, skip rebuild and sort */\n\tif(_opts.fileType == 'mad') return write_mad(cfb, _opts);\n\trebuild_cfb(cfb);\n\tswitch(_opts.fileType) {\n\t\tcase 'zip': return write_zip(cfb, _opts);\n\t\t//case 'mad': return write_mad(cfb, _opts);\n\t}\n\tvar L = (function(cfb/*:CFBContainer*/)/*:Array<number>*/{\n\t\tvar mini_size = 0, fat_size = 0;\n\t\tfor(var i = 0; i < cfb.FileIndex.length; ++i) {\n\t\t\tvar file = cfb.FileIndex[i];\n\t\t\tif(!file.content) continue;\n\t\t\t/*:: if(file.content == null) throw new Error(\"unreachable\"); */\n\t\t\tvar flen = file.content.length;\n\t\t\tif(flen > 0){\n\t\t\t\tif(flen < 0x1000) mini_size += (flen + 0x3F) >> 6;\n\t\t\t\telse fat_size += (flen + 0x01FF) >> 9;\n\t\t\t}\n\t\t}\n\t\tvar dir_cnt = (cfb.FullPaths.length +3) >> 2;\n\t\tvar mini_cnt = (mini_size + 7) >> 3;\n\t\tvar mfat_cnt = (mini_size + 0x7F) >> 7;\n\t\tvar fat_base = mini_cnt + fat_size + dir_cnt + mfat_cnt;\n\t\tvar fat_cnt = (fat_base + 0x7F) >> 7;\n\t\tvar difat_cnt = fat_cnt <= 109 ? 0 : Math.ceil((fat_cnt-109)/0x7F);\n\t\twhile(((fat_base + fat_cnt + difat_cnt + 0x7F) >> 7) > fat_cnt) difat_cnt = ++fat_cnt <= 109 ? 0 : Math.ceil((fat_cnt-109)/0x7F);\n\t\tvar L =  [1, difat_cnt, fat_cnt, mfat_cnt, dir_cnt, fat_size, mini_size, 0];\n\t\tcfb.FileIndex[0].size = mini_size << 6;\n\t\tL[7] = (cfb.FileIndex[0].start=L[0]+L[1]+L[2]+L[3]+L[4]+L[5])+((L[6]+7) >> 3);\n\t\treturn L;\n\t})(cfb);\n\tvar o = new_buf(L[7] << 9);\n\tvar i = 0, T = 0;\n\t{\n\t\tfor(i = 0; i < 8; ++i) o.write_shift(1, HEADER_SIG[i]);\n\t\tfor(i = 0; i < 8; ++i) o.write_shift(2, 0);\n\t\to.write_shift(2, 0x003E);\n\t\to.write_shift(2, 0x0003);\n\t\to.write_shift(2, 0xFFFE);\n\t\to.write_shift(2, 0x0009);\n\t\to.write_shift(2, 0x0006);\n\t\tfor(i = 0; i < 3; ++i) o.write_shift(2, 0);\n\t\to.write_shift(4, 0);\n\t\to.write_shift(4, L[2]);\n\t\to.write_shift(4, L[0] + L[1] + L[2] + L[3] - 1);\n\t\to.write_shift(4, 0);\n\t\to.write_shift(4, 1<<12);\n\t\to.write_shift(4, L[3] ? L[0] + L[1] + L[2] - 1: ENDOFCHAIN);\n\t\to.write_shift(4, L[3]);\n\t\to.write_shift(-4, L[1] ? L[0] - 1: ENDOFCHAIN);\n\t\to.write_shift(4, L[1]);\n\t\tfor(i = 0; i < 109; ++i) o.write_shift(-4, i < L[2] ? L[1] + i : -1);\n\t}\n\tif(L[1]) {\n\t\tfor(T = 0; T < L[1]; ++T) {\n\t\t\tfor(; i < 236 + T * 127; ++i) o.write_shift(-4, i < L[2] ? L[1] + i : -1);\n\t\t\to.write_shift(-4, T === L[1] - 1 ? ENDOFCHAIN : T + 1);\n\t\t}\n\t}\n\tvar chainit = function(w/*:number*/)/*:void*/ {\n\t\tfor(T += w; i<T-1; ++i) o.write_shift(-4, i+1);\n\t\tif(w) { ++i; o.write_shift(-4, ENDOFCHAIN); }\n\t};\n\tT = i = 0;\n\tfor(T+=L[1]; i<T; ++i) o.write_shift(-4, consts.DIFSECT);\n\tfor(T+=L[2]; i<T; ++i) o.write_shift(-4, consts.FATSECT);\n\tchainit(L[3]);\n\tchainit(L[4]);\n\tvar j/*:number*/ = 0, flen/*:number*/ = 0;\n\tvar file/*:CFBEntry*/ = cfb.FileIndex[0];\n\tfor(; j < cfb.FileIndex.length; ++j) {\n\t\tfile = cfb.FileIndex[j];\n\t\tif(!file.content) continue;\n\t\t/*:: if(file.content == null) throw new Error(\"unreachable\"); */\n\t\tflen = file.content.length;\n\t\tif(flen < 0x1000) continue;\n\t\tfile.start = T;\n\t\tchainit((flen + 0x01FF) >> 9);\n\t}\n\tchainit((L[6] + 7) >> 3);\n\twhile(o.l & 0x1FF) o.write_shift(-4, consts.ENDOFCHAIN);\n\tT = i = 0;\n\tfor(j = 0; j < cfb.FileIndex.length; ++j) {\n\t\tfile = cfb.FileIndex[j];\n\t\tif(!file.content) continue;\n\t\t/*:: if(file.content == null) throw new Error(\"unreachable\"); */\n\t\tflen = file.content.length;\n\t\tif(!flen || flen >= 0x1000) continue;\n\t\tfile.start = T;\n\t\tchainit((flen + 0x3F) >> 6);\n\t}\n\twhile(o.l & 0x1FF) o.write_shift(-4, consts.ENDOFCHAIN);\n\tfor(i = 0; i < L[4]<<2; ++i) {\n\t\tvar nm = cfb.FullPaths[i];\n\t\tif(!nm || nm.length === 0) {\n\t\t\tfor(j = 0; j < 17; ++j) o.write_shift(4, 0);\n\t\t\tfor(j = 0; j < 3; ++j) o.write_shift(4, -1);\n\t\t\tfor(j = 0; j < 12; ++j) o.write_shift(4, 0);\n\t\t\tcontinue;\n\t\t}\n\t\tfile = cfb.FileIndex[i];\n\t\tif(i === 0) file.start = file.size ? file.start - 1 : ENDOFCHAIN;\n\t\tvar _nm/*:string*/ = (i === 0 && _opts.root) || file.name;\n\t\tflen = 2*(_nm.length+1);\n\t\to.write_shift(64, _nm, \"utf16le\");\n\t\to.write_shift(2, flen);\n\t\to.write_shift(1, file.type);\n\t\to.write_shift(1, file.color);\n\t\to.write_shift(-4, file.L);\n\t\to.write_shift(-4, file.R);\n\t\to.write_shift(-4, file.C);\n\t\tif(!file.clsid) for(j = 0; j < 4; ++j) o.write_shift(4, 0);\n\t\telse o.write_shift(16, file.clsid, \"hex\");\n\t\to.write_shift(4, file.state || 0);\n\t\to.write_shift(4, 0); o.write_shift(4, 0);\n\t\to.write_shift(4, 0); o.write_shift(4, 0);\n\t\to.write_shift(4, file.start);\n\t\to.write_shift(4, file.size); o.write_shift(4, 0);\n\t}\n\tfor(i = 1; i < cfb.FileIndex.length; ++i) {\n\t\tfile = cfb.FileIndex[i];\n\t\t/*:: if(!file.content) throw new Error(\"unreachable\"); */\n\t\tif(file.size >= 0x1000) {\n\t\t\to.l = (file.start+1) << 9;\n\t\t\tif (has_buf && Buffer.isBuffer(file.content)) {\n\t\t\t\tfile.content.copy(o, o.l, 0, file.size);\n\t\t\t\t// o is a 0-filled Buffer so just set next offset\n\t\t\t\to.l += (file.size + 511) & -512;\n\t\t\t} else {\n\t\t\t\tfor(j = 0; j < file.size; ++j) o.write_shift(1, file.content[j]);\n\t\t\t\tfor(; j & 0x1FF; ++j) o.write_shift(1, 0);\n\t\t\t}\n\t\t}\n\t}\n\tfor(i = 1; i < cfb.FileIndex.length; ++i) {\n\t\tfile = cfb.FileIndex[i];\n\t\t/*:: if(!file.content) throw new Error(\"unreachable\"); */\n\t\tif(file.size > 0 && file.size < 0x1000) {\n\t\t\tif (has_buf && Buffer.isBuffer(file.content)) {\n\t\t\t\tfile.content.copy(o, o.l, 0, file.size);\n\t\t\t\t// o is a 0-filled Buffer so just set next offset\n\t\t\t\to.l += (file.size + 63) & -64;\n\t\t\t} else {\n\t\t\t\tfor(j = 0; j < file.size; ++j) o.write_shift(1, file.content[j]);\n\t\t\t\tfor(; j & 0x3F; ++j) o.write_shift(1, 0);\n\t\t\t}\n\t\t}\n\t}\n\tif (has_buf) {\n\t\to.l = o.length;\n\t} else {\n\t\t// When using Buffer, already 0-filled\n\t\twhile(o.l < o.length) o.write_shift(1, 0);\n\t}\n\treturn o;\n}\n/* [MS-CFB] 2.6.4 (Unicode 3.0.1 case conversion) */\nfunction find(cfb/*:CFBContainer*/, path/*:string*/)/*:?CFBEntry*/ {\n\tvar UCFullPaths/*:Array<string>*/ = cfb.FullPaths.map(function(x) { return x.toUpperCase(); });\n\tvar UCPaths/*:Array<string>*/ = UCFullPaths.map(function(x) { var y = x.split(\"/\"); return y[y.length - (x.slice(-1) == \"/\" ? 2 : 1)]; });\n\tvar k/*:boolean*/ = false;\n\tif(path.charCodeAt(0) === 47 /* \"/\" */) { k = true; path = UCFullPaths[0].slice(0, -1) + path; }\n\telse k = path.indexOf(\"/\") !== -1;\n\tvar UCPath/*:string*/ = path.toUpperCase();\n\tvar w/*:number*/ = k === true ? UCFullPaths.indexOf(UCPath) : UCPaths.indexOf(UCPath);\n\tif(w !== -1) return cfb.FileIndex[w];\n\n\tvar m = !UCPath.match(chr1);\n\tUCPath = UCPath.replace(chr0,'');\n\tif(m) UCPath = UCPath.replace(chr1,'!');\n\tfor(w = 0; w < UCFullPaths.length; ++w) {\n\t\tif((m ? UCFullPaths[w].replace(chr1,'!') : UCFullPaths[w]).replace(chr0,'') == UCPath) return cfb.FileIndex[w];\n\t\tif((m ? UCPaths[w].replace(chr1,'!') : UCPaths[w]).replace(chr0,'') == UCPath) return cfb.FileIndex[w];\n\t}\n\treturn null;\n}\n/** CFB Constants */\nvar MSSZ = 64; /* Mini Sector Size = 1<<6 */\n//var MSCSZ = 4096; /* Mini Stream Cutoff Size */\n/* 2.1 Compound File Sector Numbers and Types */\nvar ENDOFCHAIN = -2;\n/* 2.2 Compound File Header */\nvar HEADER_SIGNATURE = 'd0cf11e0a1b11ae1';\nvar HEADER_SIG = [0xD0, 0xCF, 0x11, 0xE0, 0xA1, 0xB1, 0x1A, 0xE1];\nvar HEADER_CLSID = '00000000000000000000000000000000';\nvar consts = {\n\t/* 2.1 Compund File Sector Numbers and Types */\n\tMAXREGSECT: -6,\n\tDIFSECT: -4,\n\tFATSECT: -3,\n\tENDOFCHAIN: ENDOFCHAIN,\n\tFREESECT: -1,\n\t/* 2.2 Compound File Header */\n\tHEADER_SIGNATURE: HEADER_SIGNATURE,\n\tHEADER_MINOR_VERSION: '3e00',\n\tMAXREGSID: -6,\n\tNOSTREAM: -1,\n\tHEADER_CLSID: HEADER_CLSID,\n\t/* 2.6.1 Compound File Directory Entry */\n\tEntryTypes: ['unknown','storage','stream','lockbytes','property','root']\n};\n\nfunction write_file(cfb/*:CFBContainer*/, filename/*:string*/, options/*:CFBWriteOpts*/)/*:void*/ {\n\tget_fs();\n\tvar o = _write(cfb, options);\n\t/*:: if(typeof Buffer == 'undefined' || !Buffer.isBuffer(o) || !(o instanceof Buffer)) throw new Error(\"unreachable\"); */\n\tfs.writeFileSync(filename, o);\n}\n\nfunction a2s(o/*:RawBytes*/)/*:string*/ {\n\tvar out = new Array(o.length);\n\tfor(var i = 0; i < o.length; ++i) out[i] = String.fromCharCode(o[i]);\n\treturn out.join(\"\");\n}\n\nfunction write(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:RawBytes|string*/ {\n\tvar o = _write(cfb, options);\n\tswitch(options && options.type || \"buffer\") {\n\t\tcase \"file\": get_fs(); fs.writeFileSync(options.filename, (o/*:any*/)); return o;\n\t\tcase \"binary\": return typeof o == \"string\" ? o : a2s(o);\n\t\tcase \"base64\": return Base64_encode(typeof o == \"string\" ? o : a2s(o));\n\t\tcase \"buffer\": if(has_buf) return Buffer.isBuffer(o) ? o : Buffer_from(o);\n\t\t\t/* falls through */\n\t\tcase \"array\": return typeof o == \"string\" ? s2a(o) : o;\n\t}\n\treturn o;\n}\n/* node < 8.1 zlib does not expose bytesRead, so default to pure JS */\nvar _zlib;\nfunction use_zlib(zlib) { try {\n\tvar InflateRaw = zlib.InflateRaw;\n\tvar InflRaw = new InflateRaw();\n\tInflRaw._processChunk(new Uint8Array([3, 0]), InflRaw._finishFlushFlag);\n\tif(InflRaw.bytesRead) _zlib = zlib;\n\telse throw new Error(\"zlib does not expose bytesRead\");\n} catch(e) {console.error(\"cannot use native zlib: \" + (e.message || e)); } }\n\nfunction _inflateRawSync(payload, usz) {\n\tif(!_zlib) return _inflate(payload, usz);\n\tvar InflateRaw = _zlib.InflateRaw;\n\tvar InflRaw = new InflateRaw();\n\tvar out = InflRaw._processChunk(payload.slice(payload.l), InflRaw._finishFlushFlag);\n\tpayload.l += InflRaw.bytesRead;\n\treturn out;\n}\n\nfunction _deflateRawSync(payload) {\n\treturn _zlib ? _zlib.deflateRawSync(payload) : _deflate(payload);\n}\nvar CLEN_ORDER = [ 16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15 ];\n\n/*  LEN_ID = [ 257, 258, 259, 260, 261, 262, 263, 264, 265, 266, 267, 268, 269, 270, 271, 272, 273, 274, 275, 276, 277, 278, 279, 280, 281, 282, 283, 284, 285 ]; */\nvar LEN_LN = [   3,   4,   5,   6,   7,   8,   9,  10,  11,  13 , 15,  17,  19,  23,  27,  31,  35,  43,  51,  59,  67,  83,  99, 115, 131, 163, 195, 227, 258 ];\n\n/*  DST_ID = [  0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12, 13,  14,  15,  16,  17,  18,  19,   20,   21,   22,   23,   24,   25,   26,    27,    28,    29 ]; */\nvar DST_LN = [  1,  2,  3,  4,  5,  7,  9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577 ];\n\nfunction bit_swap_8(n) { var t = (((((n<<1)|(n<<11)) & 0x22110) | (((n<<5)|(n<<15)) & 0x88440))); return ((t>>16) | (t>>8) |t)&0xFF; }\n\nvar use_typed_arrays = typeof Uint8Array !== 'undefined';\n\nvar bitswap8 = use_typed_arrays ? new Uint8Array(1<<8) : [];\nfor(var q = 0; q < (1<<8); ++q) bitswap8[q] = bit_swap_8(q);\n\nfunction bit_swap_n(n, b) {\n\tvar rev = bitswap8[n & 0xFF];\n\tif(b <= 8) return rev >>> (8-b);\n\trev = (rev << 8) | bitswap8[(n>>8)&0xFF];\n\tif(b <= 16) return rev >>> (16-b);\n\trev = (rev << 8) | bitswap8[(n>>16)&0xFF];\n\treturn rev >>> (24-b);\n}\n\n/* helpers for unaligned bit reads */\nfunction read_bits_2(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 6 ? 0 : buf[h+1]<<8))>>>w)& 0x03; }\nfunction read_bits_3(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 5 ? 0 : buf[h+1]<<8))>>>w)& 0x07; }\nfunction read_bits_4(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 4 ? 0 : buf[h+1]<<8))>>>w)& 0x0F; }\nfunction read_bits_5(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 3 ? 0 : buf[h+1]<<8))>>>w)& 0x1F; }\nfunction read_bits_7(buf, bl) { var w = (bl&7), h = (bl>>>3); return ((buf[h]|(w <= 1 ? 0 : buf[h+1]<<8))>>>w)& 0x7F; }\n\n/* works up to n = 3 * 8 + 1 = 25 */\nfunction read_bits_n(buf, bl, n) {\n\tvar w = (bl&7), h = (bl>>>3), f = ((1<<n)-1);\n\tvar v = buf[h] >>> w;\n\tif(n < 8 - w) return v & f;\n\tv |= buf[h+1]<<(8-w);\n\tif(n < 16 - w) return v & f;\n\tv |= buf[h+2]<<(16-w);\n\tif(n < 24 - w) return v & f;\n\tv |= buf[h+3]<<(24-w);\n\treturn v & f;\n}\n\n/* helpers for unaligned bit writes */\nfunction write_bits_3(buf, bl, v) { var w = bl & 7, h = bl >>> 3;\n\tif(w <= 5) buf[h] |= (v & 7) << w;\n\telse {\n\t\tbuf[h] |= (v << w) & 0xFF;\n\t\tbuf[h+1] = (v&7) >> (8-w);\n\t}\n\treturn bl + 3;\n}\n\nfunction write_bits_1(buf, bl, v) {\n\tvar w = bl & 7, h = bl >>> 3;\n\tv = (v&1) << w;\n\tbuf[h] |= v;\n\treturn bl + 1;\n}\nfunction write_bits_8(buf, bl, v) {\n\tvar w = bl & 7, h = bl >>> 3;\n\tv <<= w;\n\tbuf[h] |=  v & 0xFF; v >>>= 8;\n\tbuf[h+1] = v;\n\treturn bl + 8;\n}\nfunction write_bits_16(buf, bl, v) {\n\tvar w = bl & 7, h = bl >>> 3;\n\tv <<= w;\n\tbuf[h] |=  v & 0xFF; v >>>= 8;\n\tbuf[h+1] = v & 0xFF;\n\tbuf[h+2] = v >>> 8;\n\treturn bl + 16;\n}\n\n/* until ArrayBuffer#realloc is a thing, fake a realloc */\nfunction realloc(b, sz/*:number*/) {\n\tvar L = b.length, M = 2*L > sz ? 2*L : sz + 5, i = 0;\n\tif(L >= sz) return b;\n\tif(has_buf) {\n\t\tvar o = new_unsafe_buf(M);\n\t\t// $FlowIgnore\n\t\tif(b.copy) b.copy(o);\n\t\telse for(; i < b.length; ++i) o[i] = b[i];\n\t\treturn o;\n\t} else if(use_typed_arrays) {\n\t\tvar a = new Uint8Array(M);\n\t\tif(a.set) a.set(b);\n\t\telse for(; i < L; ++i) a[i] = b[i];\n\t\treturn a;\n\t}\n\tb.length = M;\n\treturn b;\n}\n\n/* zero-filled arrays for older browsers */\nfunction zero_fill_array(n) {\n\tvar o = new Array(n);\n\tfor(var i = 0; i < n; ++i) o[i] = 0;\n\treturn o;\n}\n\n/* build tree (used for literals and lengths) */\nfunction build_tree(clens, cmap, MAX/*:number*/)/*:number*/ {\n\tvar maxlen = 1, w = 0, i = 0, j = 0, ccode = 0, L = clens.length;\n\n\tvar bl_count  = use_typed_arrays ? new Uint16Array(32) : zero_fill_array(32);\n\tfor(i = 0; i < 32; ++i) bl_count[i] = 0;\n\n\tfor(i = L; i < MAX; ++i) clens[i] = 0;\n\tL = clens.length;\n\n\tvar ctree = use_typed_arrays ? new Uint16Array(L) : zero_fill_array(L); // []\n\n\t/* build code tree */\n\tfor(i = 0; i < L; ++i) {\n\t\tbl_count[(w = clens[i])]++;\n\t\tif(maxlen < w) maxlen = w;\n\t\tctree[i] = 0;\n\t}\n\tbl_count[0] = 0;\n\tfor(i = 1; i <= maxlen; ++i) bl_count[i+16] = (ccode = (ccode + bl_count[i-1])<<1);\n\tfor(i = 0; i < L; ++i) {\n\t\tccode = clens[i];\n\t\tif(ccode != 0) ctree[i] = bl_count[ccode+16]++;\n\t}\n\n\t/* cmap[maxlen + 4 bits] = (off&15) + (lit<<4) reverse mapping */\n\tvar cleni = 0;\n\tfor(i = 0; i < L; ++i) {\n\t\tcleni = clens[i];\n\t\tif(cleni != 0) {\n\t\t\tccode = bit_swap_n(ctree[i], maxlen)>>(maxlen-cleni);\n\t\t\tfor(j = (1<<(maxlen + 4 - cleni)) - 1; j>=0; --j)\n\t\t\t\tcmap[ccode|(j<<cleni)] = (cleni&15) | (i<<4);\n\t\t}\n\t}\n\treturn maxlen;\n}\n\n/* Fixed Huffman */\nvar fix_lmap = use_typed_arrays ? new Uint16Array(512) : zero_fill_array(512);\nvar fix_dmap = use_typed_arrays ? new Uint16Array(32)  : zero_fill_array(32);\nif(!use_typed_arrays) {\n\tfor(var i = 0; i < 512; ++i) fix_lmap[i] = 0;\n\tfor(i = 0; i < 32; ++i) fix_dmap[i] = 0;\n}\n(function() {\n\tvar dlens/*:Array<number>*/ = [];\n\tvar i = 0;\n\tfor(;i<32; i++) dlens.push(5);\n\tbuild_tree(dlens, fix_dmap, 32);\n\n\tvar clens/*:Array<number>*/ = [];\n\ti = 0;\n\tfor(; i<=143; i++) clens.push(8);\n\tfor(; i<=255; i++) clens.push(9);\n\tfor(; i<=279; i++) clens.push(7);\n\tfor(; i<=287; i++) clens.push(8);\n\tbuild_tree(clens, fix_lmap, 288);\n})();var _deflateRaw = /*#__PURE__*/(function _deflateRawIIFE() {\n\tvar DST_LN_RE = use_typed_arrays ? new Uint8Array(0x8000) : [];\n\tvar j = 0, k = 0;\n\tfor(; j < DST_LN.length - 1; ++j) {\n\t\tfor(; k < DST_LN[j+1]; ++k) DST_LN_RE[k] = j;\n\t}\n\tfor(;k < 32768; ++k) DST_LN_RE[k] = 29;\n\n\tvar LEN_LN_RE = use_typed_arrays ? new Uint8Array(0x103) : [];\n\tfor(j = 0, k = 0; j < LEN_LN.length - 1; ++j) {\n\t\tfor(; k < LEN_LN[j+1]; ++k) LEN_LN_RE[k] = j;\n\t}\n\n\tfunction write_stored(data, out) {\n\t\tvar boff = 0;\n\t\twhile(boff < data.length) {\n\t\t\tvar L = Math.min(0xFFFF, data.length - boff);\n\t\t\tvar h = boff + L == data.length;\n\t\t\tout.write_shift(1, +h);\n\t\t\tout.write_shift(2, L);\n\t\t\tout.write_shift(2, (~L) & 0xFFFF);\n\t\t\twhile(L-- > 0) out[out.l++] = data[boff++];\n\t\t}\n\t\treturn out.l;\n\t}\n\n\t/* Fixed Huffman */\n\tfunction write_huff_fixed(data, out) {\n\t\tvar bl = 0;\n\t\tvar boff = 0;\n\t\tvar addrs = use_typed_arrays ? new Uint16Array(0x8000) : [];\n\t\twhile(boff < data.length) {\n\t\t\tvar L = /* data.length - boff; */ Math.min(0xFFFF, data.length - boff);\n\n\t\t\t/* write a stored block for short data */\n\t\t\tif(L < 10) {\n\t\t\t\tbl = write_bits_3(out, bl, +!!(boff + L == data.length)); // jshint ignore:line\n\t\t\t\tif(bl & 7) bl += 8 - (bl & 7);\n\t\t\t\tout.l = (bl / 8) | 0;\n\t\t\t\tout.write_shift(2, L);\n\t\t\t\tout.write_shift(2, (~L) & 0xFFFF);\n\t\t\t\twhile(L-- > 0) out[out.l++] = data[boff++];\n\t\t\t\tbl = out.l * 8;\n\t\t\t\tcontinue;\n\t\t\t}\n\n\t\t\tbl = write_bits_3(out, bl, +!!(boff + L == data.length) + 2); // jshint ignore:line\n\t\t\tvar hash = 0;\n\t\t\twhile(L-- > 0) {\n\t\t\t\tvar d = data[boff];\n\t\t\t\thash = ((hash << 5) ^ d) & 0x7FFF;\n\n\t\t\t\tvar match = -1, mlen = 0;\n\n\t\t\t\tif((match = addrs[hash])) {\n\t\t\t\t\tmatch |= boff & ~0x7FFF;\n\t\t\t\t\tif(match > boff) match -= 0x8000;\n\t\t\t\t\tif(match < boff) while(data[match + mlen] == data[boff + mlen] && mlen < 250) ++mlen;\n\t\t\t\t}\n\n\t\t\t\tif(mlen > 2) {\n\t\t\t\t\t/* Copy Token  */\n\t\t\t\t\td = LEN_LN_RE[mlen];\n\t\t\t\t\tif(d <= 22) bl = write_bits_8(out, bl, bitswap8[d+1]>>1) - 1;\n\t\t\t\t\telse {\n\t\t\t\t\t\twrite_bits_8(out, bl, 3);\n\t\t\t\t\t\tbl += 5;\n\t\t\t\t\t\twrite_bits_8(out, bl, bitswap8[d-23]>>5);\n\t\t\t\t\t\tbl += 3;\n\t\t\t\t\t}\n\t\t\t\t\tvar len_eb = (d < 8) ? 0 : ((d - 4)>>2);\n\t\t\t\t\tif(len_eb > 0) {\n\t\t\t\t\t\twrite_bits_16(out, bl, mlen - LEN_LN[d]);\n\t\t\t\t\t\tbl += len_eb;\n\t\t\t\t\t}\n\n\t\t\t\t\td = DST_LN_RE[boff - match];\n\t\t\t\t\tbl = write_bits_8(out, bl, bitswap8[d]>>3);\n\t\t\t\t\tbl -= 3;\n\n\t\t\t\t\tvar dst_eb = d < 4 ? 0 : (d-2)>>1;\n\t\t\t\t\tif(dst_eb > 0) {\n\t\t\t\t\t\twrite_bits_16(out, bl, boff - match - DST_LN[d]);\n\t\t\t\t\t\tbl += dst_eb;\n\t\t\t\t\t}\n\t\t\t\t\tfor(var q = 0; q < mlen; ++q) {\n\t\t\t\t\t\taddrs[hash] = boff & 0x7FFF;\n\t\t\t\t\t\thash = ((hash << 5) ^ data[boff]) & 0x7FFF;\n\t\t\t\t\t\t++boff;\n\t\t\t\t\t}\n\t\t\t\t\tL-= mlen - 1;\n\t\t\t\t} else {\n\t\t\t\t\t/* Literal Token */\n\t\t\t\t\tif(d <= 143) d = d + 48;\n\t\t\t\t\telse bl = write_bits_1(out, bl, 1);\n\t\t\t\t\tbl = write_bits_8(out, bl, bitswap8[d]);\n\t\t\t\t\taddrs[hash] = boff & 0x7FFF;\n\t\t\t\t\t++boff;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tbl = write_bits_8(out, bl, 0) - 1;\n\t\t}\n\t\tout.l = ((bl + 7)/8)|0;\n\t\treturn out.l;\n\t}\n\treturn function _deflateRaw(data, out) {\n\t\tif(data.length < 8) return write_stored(data, out);\n\t\treturn write_huff_fixed(data, out);\n\t};\n})();\n\nfunction _deflate(data) {\n\tvar buf = new_buf(50+Math.floor(data.length*1.1));\n\tvar off = _deflateRaw(data, buf);\n\treturn buf.slice(0, off);\n}\n/* modified inflate function also moves original read head */\n\nvar dyn_lmap = use_typed_arrays ? new Uint16Array(32768) : zero_fill_array(32768);\nvar dyn_dmap = use_typed_arrays ? new Uint16Array(32768) : zero_fill_array(32768);\nvar dyn_cmap = use_typed_arrays ? new Uint16Array(128)   : zero_fill_array(128);\nvar dyn_len_1 = 1, dyn_len_2 = 1;\n\n/* 5.5.3 Expanding Huffman Codes */\nfunction dyn(data, boff/*:number*/) {\n\t/* nomenclature from RFC1951 refers to bit values; these are offset by the implicit constant */\n\tvar _HLIT = read_bits_5(data, boff) + 257; boff += 5;\n\tvar _HDIST = read_bits_5(data, boff) + 1; boff += 5;\n\tvar _HCLEN = read_bits_4(data, boff) + 4; boff += 4;\n\tvar w = 0;\n\n\t/* grab and store code lengths */\n\tvar clens = use_typed_arrays ? new Uint8Array(19) : zero_fill_array(19);\n\tvar ctree = [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 ];\n\tvar maxlen = 1;\n\tvar bl_count =  use_typed_arrays ? new Uint8Array(8) : zero_fill_array(8);\n\tvar next_code = use_typed_arrays ? new Uint8Array(8) : zero_fill_array(8);\n\tvar L = clens.length; /* 19 */\n\tfor(var i = 0; i < _HCLEN; ++i) {\n\t\tclens[CLEN_ORDER[i]] = w = read_bits_3(data, boff);\n\t\tif(maxlen < w) maxlen = w;\n\t\tbl_count[w]++;\n\t\tboff += 3;\n\t}\n\n\t/* build code tree */\n\tvar ccode = 0;\n\tbl_count[0] = 0;\n\tfor(i = 1; i <= maxlen; ++i) next_code[i] = ccode = (ccode + bl_count[i-1])<<1;\n\tfor(i = 0; i < L; ++i) if((ccode = clens[i]) != 0) ctree[i] = next_code[ccode]++;\n\t/* cmap[7 bits from stream] = (off&7) + (lit<<3) */\n\tvar cleni = 0;\n\tfor(i = 0; i < L; ++i) {\n\t\tcleni = clens[i];\n\t\tif(cleni != 0) {\n\t\t\tccode = bitswap8[ctree[i]]>>(8-cleni);\n\t\t\tfor(var j = (1<<(7-cleni))-1; j>=0; --j) dyn_cmap[ccode|(j<<cleni)] = (cleni&7) | (i<<3);\n\t\t}\n\t}\n\n\t/* read literal and dist codes at once */\n\tvar hcodes/*:Array<number>*/ = [];\n\tmaxlen = 1;\n\tfor(; hcodes.length < _HLIT + _HDIST;) {\n\t\tccode = dyn_cmap[read_bits_7(data, boff)];\n\t\tboff += ccode & 7;\n\t\tswitch((ccode >>>= 3)) {\n\t\t\tcase 16:\n\t\t\t\tw = 3 + read_bits_2(data, boff); boff += 2;\n\t\t\t\tccode = hcodes[hcodes.length - 1];\n\t\t\t\twhile(w-- > 0) hcodes.push(ccode);\n\t\t\t\tbreak;\n\t\t\tcase 17:\n\t\t\t\tw = 3 + read_bits_3(data, boff); boff += 3;\n\t\t\t\twhile(w-- > 0) hcodes.push(0);\n\t\t\t\tbreak;\n\t\t\tcase 18:\n\t\t\t\tw = 11 + read_bits_7(data, boff); boff += 7;\n\t\t\t\twhile(w -- > 0) hcodes.push(0);\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\thcodes.push(ccode);\n\t\t\t\tif(maxlen < ccode) maxlen = ccode;\n\t\t\t\tbreak;\n\t\t}\n\t}\n\n\t/* build literal / length trees */\n\tvar h1 = hcodes.slice(0, _HLIT), h2 = hcodes.slice(_HLIT);\n\tfor(i = _HLIT; i < 286; ++i) h1[i] = 0;\n\tfor(i = _HDIST; i < 30; ++i) h2[i] = 0;\n\tdyn_len_1 = build_tree(h1, dyn_lmap, 286);\n\tdyn_len_2 = build_tree(h2, dyn_dmap, 30);\n\treturn boff;\n}\n\n/* return [ data, bytesRead ] */\nfunction inflate(data, usz/*:number*/) {\n\t/* shortcircuit for empty buffer [0x03, 0x00] */\n\tif(data[0] == 3 && !(data[1] & 0x3)) { return [new_raw_buf(usz), 2]; }\n\n\t/* bit offset */\n\tvar boff = 0;\n\n\t/* header includes final bit and type bits */\n\tvar header = 0;\n\n\tvar outbuf = new_unsafe_buf(usz ? usz : (1<<18));\n\tvar woff = 0;\n\tvar OL = outbuf.length>>>0;\n\tvar max_len_1 = 0, max_len_2 = 0;\n\n\twhile((header&1) == 0) {\n\t\theader = read_bits_3(data, boff); boff += 3;\n\t\tif((header >>> 1) == 0) {\n\t\t\t/* Stored block */\n\t\t\tif(boff & 7) boff += 8 - (boff&7);\n\t\t\t/* 2 bytes sz, 2 bytes bit inverse */\n\t\t\tvar sz = data[boff>>>3] | data[(boff>>>3)+1]<<8;\n\t\t\tboff += 32;\n\t\t\t/* push sz bytes */\n\t\t\tif(sz > 0) {\n\t\t\t\tif(!usz && OL < woff + sz) { outbuf = realloc(outbuf, woff + sz); OL = outbuf.length; }\n\t\t\t\twhile(sz-- > 0) { outbuf[woff++] = data[boff>>>3]; boff += 8; }\n\t\t\t}\n\t\t\tcontinue;\n\t\t} else if((header >> 1) == 1) {\n\t\t\t/* Fixed Huffman */\n\t\t\tmax_len_1 = 9; max_len_2 = 5;\n\t\t} else {\n\t\t\t/* Dynamic Huffman */\n\t\t\tboff = dyn(data, boff);\n\t\t\tmax_len_1 = dyn_len_1; max_len_2 = dyn_len_2;\n\t\t}\n\t\tfor(;;) { // while(true) is apparently out of vogue in modern JS circles\n\t\t\tif(!usz && (OL < woff + 32767)) { outbuf = realloc(outbuf, woff + 32767); OL = outbuf.length; }\n\t\t\t/* ingest code and move read head */\n\t\t\tvar bits = read_bits_n(data, boff, max_len_1);\n\t\t\tvar code = (header>>>1) == 1 ? fix_lmap[bits] : dyn_lmap[bits];\n\t\t\tboff += code & 15; code >>>= 4;\n\t\t\t/* 0-255 are literals, 256 is end of block token, 257+ are copy tokens */\n\t\t\tif(((code>>>8)&0xFF) === 0) outbuf[woff++] = code;\n\t\t\telse if(code == 256) break;\n\t\t\telse {\n\t\t\t\tcode -= 257;\n\t\t\t\tvar len_eb = (code < 8) ? 0 : ((code-4)>>2); if(len_eb > 5) len_eb = 0;\n\t\t\t\tvar tgt = woff + LEN_LN[code];\n\t\t\t\t/* length extra bits */\n\t\t\t\tif(len_eb > 0) {\n\t\t\t\t\ttgt += read_bits_n(data, boff, len_eb);\n\t\t\t\t\tboff += len_eb;\n\t\t\t\t}\n\n\t\t\t\t/* dist code */\n\t\t\t\tbits = read_bits_n(data, boff, max_len_2);\n\t\t\t\tcode = (header>>>1) == 1 ? fix_dmap[bits] : dyn_dmap[bits];\n\t\t\t\tboff += code & 15; code >>>= 4;\n\t\t\t\tvar dst_eb = (code < 4 ? 0 : (code-2)>>1);\n\t\t\t\tvar dst = DST_LN[code];\n\t\t\t\t/* dist extra bits */\n\t\t\t\tif(dst_eb > 0) {\n\t\t\t\t\tdst += read_bits_n(data, boff, dst_eb);\n\t\t\t\t\tboff += dst_eb;\n\t\t\t\t}\n\n\t\t\t\t/* in the common case, manual byte copy is faster than TA set / Buffer copy */\n\t\t\t\tif(!usz && OL < tgt) { outbuf = realloc(outbuf, tgt + 100); OL = outbuf.length; }\n\t\t\t\twhile(woff < tgt) { outbuf[woff] = outbuf[woff - dst]; ++woff; }\n\t\t\t}\n\t\t}\n\t}\n\tif(usz) return [outbuf, (boff+7)>>>3];\n\treturn [outbuf.slice(0, woff), (boff+7)>>>3];\n}\n\nfunction _inflate(payload, usz) {\n\tvar data = payload.slice(payload.l||0);\n\tvar out = inflate(data, usz);\n\tpayload.l += out[1];\n\treturn out[0];\n}\n\nfunction warn_or_throw(wrn, msg) {\n\tif(wrn) { if(typeof console !== 'undefined') console.error(msg); }\n\telse throw new Error(msg);\n}\n\nfunction parse_zip(file/*:RawBytes*/, options/*:CFBReadOpts*/)/*:CFBContainer*/ {\n\tvar blob/*:CFBlob*/ = /*::(*/file/*:: :any)*/;\n\tprep_blob(blob, 0);\n\n\tvar FileIndex/*:CFBFileIndex*/ = [], FullPaths/*:Array<string>*/ = [];\n\tvar o = {\n\t\tFileIndex: FileIndex,\n\t\tFullPaths: FullPaths\n\t};\n\tinit_cfb(o, { root: options.root });\n\n\t/* find end of central directory, start just after signature */\n\tvar i = blob.length - 4;\n\twhile((blob[i] != 0x50 || blob[i+1] != 0x4b || blob[i+2] != 0x05 || blob[i+3] != 0x06) && i >= 0) --i;\n\tblob.l = i + 4;\n\n\t/* parse end of central directory */\n\tblob.l += 4;\n\tvar fcnt = blob.read_shift(2);\n\tblob.l += 6;\n\tvar start_cd = blob.read_shift(4);\n\n\t/* parse central directory */\n\tblob.l = start_cd;\n\n\tfor(i = 0; i < fcnt; ++i) {\n\t\t/* trust local file header instead of CD entry */\n\t\tblob.l += 20;\n\t\tvar csz = blob.read_shift(4);\n\t\tvar usz = blob.read_shift(4);\n\t\tvar namelen = blob.read_shift(2);\n\t\tvar efsz = blob.read_shift(2);\n\t\tvar fcsz = blob.read_shift(2);\n\t\tblob.l += 8;\n\t\tvar offset = blob.read_shift(4);\n\t\tvar EF = parse_extra_field(/*::(*/blob.slice(blob.l+namelen, blob.l+namelen+efsz)/*:: :any)*/);\n\t\tblob.l += namelen + efsz + fcsz;\n\n\t\tvar L = blob.l;\n\t\tblob.l = offset + 4;\n\t\tparse_local_file(blob, csz, usz, o, EF);\n\t\tblob.l = L;\n\t}\n\treturn o;\n}\n\n\n/* head starts just after local file header signature */\nfunction parse_local_file(blob/*:CFBlob*/, csz/*:number*/, usz/*:number*/, o/*:CFBContainer*/, EF) {\n\t/* [local file header] */\n\tblob.l += 2;\n\tvar flags = blob.read_shift(2);\n\tvar meth = blob.read_shift(2);\n\tvar date = parse_dos_date(blob);\n\n\tif(flags & 0x2041) throw new Error(\"Unsupported ZIP encryption\");\n\tvar crc32 = blob.read_shift(4);\n\tvar _csz = blob.read_shift(4);\n\tvar _usz = blob.read_shift(4);\n\n\tvar namelen = blob.read_shift(2);\n\tvar efsz = blob.read_shift(2);\n\n\t// TODO: flags & (1<<11) // UTF8\n\tvar name = \"\"; for(var i = 0; i < namelen; ++i) name += String.fromCharCode(blob[blob.l++]);\n\tif(efsz) {\n\t\tvar ef = parse_extra_field(/*::(*/blob.slice(blob.l, blob.l + efsz)/*:: :any)*/);\n\t\tif((ef[0x5455]||{}).mt) date = ef[0x5455].mt;\n\t\tif(((EF||{})[0x5455]||{}).mt) date = EF[0x5455].mt;\n\t}\n\tblob.l += efsz;\n\n\t/* [encryption header] */\n\n\t/* [file data] */\n\tvar data = blob.slice(blob.l, blob.l + _csz);\n\tswitch(meth) {\n\t\tcase 8: data = _inflateRawSync(blob, _usz); break;\n\t\tcase 0: break; // TODO: scan for magic number\n\t\tdefault: throw new Error(\"Unsupported ZIP Compression method \" + meth);\n\t}\n\n\t/* [data descriptor] */\n\tvar wrn = false;\n\tif(flags & 8) {\n\t\tcrc32 = blob.read_shift(4);\n\t\tif(crc32 == 0x08074b50) { crc32 = blob.read_shift(4); wrn = true; }\n\t\t_csz = blob.read_shift(4);\n\t\t_usz = blob.read_shift(4);\n\t}\n\n\tif(_csz != csz) warn_or_throw(wrn, \"Bad compressed size: \" + csz + \" != \" + _csz);\n\tif(_usz != usz) warn_or_throw(wrn, \"Bad uncompressed size: \" + usz + \" != \" + _usz);\n\t//var _crc32 = CRC32.buf(data, 0);\n\t//if((crc32>>0) != (_crc32>>0)) warn_or_throw(wrn, \"Bad CRC32 checksum: \" + crc32 + \" != \" + _crc32);\n\tcfb_add(o, name, data, {unsafe: true, mt: date});\n}\nfunction write_zip(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:RawBytes*/ {\n\tvar _opts = options || {};\n\tvar out = [], cdirs = [];\n\tvar o/*:CFBlob*/ = new_buf(1);\n\tvar method = (_opts.compression ? 8 : 0), flags = 0;\n\tvar desc = false;\n\tif(desc) flags |= 8;\n\tvar i = 0, j = 0;\n\n\tvar start_cd = 0, fcnt = 0;\n\tvar root = cfb.FullPaths[0], fp = root, fi = cfb.FileIndex[0];\n\tvar crcs = [];\n\tvar sz_cd = 0;\n\n\tfor(i = 1; i < cfb.FullPaths.length; ++i) {\n\t\tfp = cfb.FullPaths[i].slice(root.length); fi = cfb.FileIndex[i];\n\t\tif(!fi.size || !fi.content || fp == \"\\u0001Sh33tJ5\") continue;\n\t\tvar start = start_cd;\n\n\t\t/* TODO: CP437 filename */\n\t\tvar namebuf = new_buf(fp.length);\n\t\tfor(j = 0; j < fp.length; ++j) namebuf.write_shift(1, fp.charCodeAt(j) & 0x7F);\n\t\tnamebuf = namebuf.slice(0, namebuf.l);\n\t\tcrcs[fcnt] = CRC32.buf(/*::((*/fi.content/*::||[]):any)*/, 0);\n\n\t\tvar outbuf = fi.content/*::||[]*/;\n\t\tif(method == 8) outbuf = _deflateRawSync(outbuf);\n\n\t\t/* local file header */\n\t\to = new_buf(30);\n\t\to.write_shift(4, 0x04034b50);\n\t\to.write_shift(2, 20);\n\t\to.write_shift(2, flags);\n\t\to.write_shift(2, method);\n\t\t/* TODO: last mod file time/date */\n\t\tif(fi.mt) write_dos_date(o, fi.mt);\n\t\telse o.write_shift(4, 0);\n\t\to.write_shift(-4, (flags & 8) ? 0 : crcs[fcnt]);\n\t\to.write_shift(4,  (flags & 8) ? 0 : outbuf.length);\n\t\to.write_shift(4,  (flags & 8) ? 0 : /*::(*/fi.content/*::||[])*/.length);\n\t\to.write_shift(2, namebuf.length);\n\t\to.write_shift(2, 0);\n\n\t\tstart_cd += o.length;\n\t\tout.push(o);\n\t\tstart_cd += namebuf.length;\n\t\tout.push(namebuf);\n\n\t\t/* TODO: extra fields? */\n\n\t\t/* TODO: encryption header ? */\n\n\t\tstart_cd += outbuf.length;\n\t\tout.push(outbuf);\n\n\t\t/* data descriptor */\n\t\tif(flags & 8) {\n\t\t\to = new_buf(12);\n\t\t\to.write_shift(-4, crcs[fcnt]);\n\t\t\to.write_shift(4, outbuf.length);\n\t\t\to.write_shift(4, /*::(*/fi.content/*::||[])*/.length);\n\t\t\tstart_cd += o.l;\n\t\t\tout.push(o);\n\t\t}\n\n\t\t/* central directory */\n\t\to = new_buf(46);\n\t\to.write_shift(4, 0x02014b50);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 20);\n\t\to.write_shift(2, flags);\n\t\to.write_shift(2, method);\n\t\to.write_shift(4, 0); /* TODO: last mod file time/date */\n\t\to.write_shift(-4, crcs[fcnt]);\n\n\t\to.write_shift(4, outbuf.length);\n\t\to.write_shift(4, /*::(*/fi.content/*::||[])*/.length);\n\t\to.write_shift(2, namebuf.length);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(4, 0);\n\t\to.write_shift(4, start);\n\n\t\tsz_cd += o.l;\n\t\tcdirs.push(o);\n\t\tsz_cd += namebuf.length;\n\t\tcdirs.push(namebuf);\n\t\t++fcnt;\n\t}\n\n\t/* end of central directory */\n\to = new_buf(22);\n\to.write_shift(4, 0x06054b50);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, fcnt);\n\to.write_shift(2, fcnt);\n\to.write_shift(4, sz_cd);\n\to.write_shift(4, start_cd);\n\to.write_shift(2, 0);\n\n\treturn bconcat(([bconcat((out/*:any*/)), bconcat(cdirs), o]/*:any*/));\n}\nvar ContentTypeMap = ({\n\t\"htm\": \"text/html\",\n\t\"xml\": \"text/xml\",\n\n\t\"gif\": \"image/gif\",\n\t\"jpg\": \"image/jpeg\",\n\t\"png\": \"image/png\",\n\n\t\"mso\": \"application/x-mso\",\n\t\"thmx\": \"application/vnd.ms-officetheme\",\n\t\"sh33tj5\": \"application/octet-stream\"\n}/*:any*/);\n\nfunction get_content_type(fi/*:CFBEntry*/, fp/*:string*/)/*:string*/ {\n\tif(fi.ctype) return fi.ctype;\n\n\tvar ext = fi.name || \"\", m = ext.match(/\\.([^\\.]+)$/);\n\tif(m && ContentTypeMap[m[1]]) return ContentTypeMap[m[1]];\n\n\tif(fp) {\n\t\tm = (ext = fp).match(/[\\.\\\\]([^\\.\\\\])+$/);\n\t\tif(m && ContentTypeMap[m[1]]) return ContentTypeMap[m[1]];\n\t}\n\n\treturn \"application/octet-stream\";\n}\n\n/* 76 character chunks TODO: intertwine encoding */\nfunction write_base64_76(bstr/*:string*/)/*:string*/ {\n\tvar data = Base64_encode(bstr);\n\tvar o = [];\n\tfor(var i = 0; i < data.length; i+= 76) o.push(data.slice(i, i+76));\n\treturn o.join(\"\\r\\n\") + \"\\r\\n\";\n}\n\n/*\nRules for QP:\n\t- escape =## applies for all non-display characters and literal \"=\"\n\t- space or tab at end of line must be encoded\n\t- \\r\\n newlines can be preserved, but bare \\r and \\n must be escaped\n\t- lines must not exceed 76 characters, use soft breaks =\\r\\n\n\nTODO: Some files from word appear to write line extensions with bare equals:\n\n```\n<table class=3DMsoTableGrid border=3D1 cellspacing=3D0 cellpadding=3D0 width=\n=\"70%\"\n```\n*/\nfunction write_quoted_printable(text/*:string*/)/*:string*/ {\n\tvar encoded = text.replace(/[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7E-\\xFF=]/g, function(c) {\n\t\tvar w = c.charCodeAt(0).toString(16).toUpperCase();\n\t\treturn \"=\" + (w.length == 1 ? \"0\" + w : w);\n\t});\n\n\tencoded = encoded.replace(/ $/mg, \"=20\").replace(/\\t$/mg, \"=09\");\n\n\tif(encoded.charAt(0) == \"\\n\") encoded = \"=0D\" + encoded.slice(1);\n\tencoded = encoded.replace(/\\r(?!\\n)/mg, \"=0D\").replace(/\\n\\n/mg, \"\\n=0A\").replace(/([^\\r\\n])\\n/mg, \"$1=0A\");\n\n\tvar o/*:Array<string>*/ = [], split = encoded.split(\"\\r\\n\");\n\tfor(var si = 0; si < split.length; ++si) {\n\t\tvar str = split[si];\n\t\tif(str.length == 0) { o.push(\"\"); continue; }\n\t\tfor(var i = 0; i < str.length;) {\n\t\t\tvar end = 76;\n\t\t\tvar tmp = str.slice(i, i + end);\n\t\t\tif(tmp.charAt(end - 1) == \"=\") end --;\n\t\t\telse if(tmp.charAt(end - 2) == \"=\") end -= 2;\n\t\t\telse if(tmp.charAt(end - 3) == \"=\") end -= 3;\n\t\t\ttmp = str.slice(i, i + end);\n\t\t\ti += end;\n\t\t\tif(i < str.length) tmp += \"=\";\n\t\t\to.push(tmp);\n\t\t}\n\t}\n\n\treturn o.join(\"\\r\\n\");\n}\nfunction parse_quoted_printable(data/*:Array<string>*/)/*:RawBytes*/ {\n\tvar o = [];\n\n\t/* unify long lines */\n\tfor(var di = 0; di < data.length; ++di) {\n\t\tvar line = data[di];\n\t\twhile(di <= data.length && line.charAt(line.length - 1) == \"=\") line = line.slice(0, line.length - 1) + data[++di];\n\t\to.push(line);\n\t}\n\n\t/* decode */\n\tfor(var oi = 0; oi < o.length; ++oi) o[oi] = o[oi].replace(/[=][0-9A-Fa-f]{2}/g, function($$) { return String.fromCharCode(parseInt($$.slice(1), 16)); });\n\treturn s2a(o.join(\"\\r\\n\"));\n}\n\n\nfunction parse_mime(cfb/*:CFBContainer*/, data/*:Array<string>*/, root/*:string*/)/*:void*/ {\n\tvar fname = \"\", cte = \"\", ctype = \"\", fdata;\n\tvar di = 0;\n\tfor(;di < 10; ++di) {\n\t\tvar line = data[di];\n\t\tif(!line || line.match(/^\\s*$/)) break;\n\t\tvar m = line.match(/^(.*?):\\s*([^\\s].*)$/);\n\t\tif(m) switch(m[1].toLowerCase()) {\n\t\t\tcase \"content-location\": fname = m[2].trim(); break;\n\t\t\tcase \"content-type\": ctype = m[2].trim(); break;\n\t\t\tcase \"content-transfer-encoding\": cte = m[2].trim(); break;\n\t\t}\n\t}\n\t++di;\n\tswitch(cte.toLowerCase()) {\n\t\tcase 'base64': fdata = s2a(Base64_decode(data.slice(di).join(\"\"))); break;\n\t\tcase 'quoted-printable': fdata = parse_quoted_printable(data.slice(di)); break;\n\t\tdefault: throw new Error(\"Unsupported Content-Transfer-Encoding \" + cte);\n\t}\n\tvar file = cfb_add(cfb, fname.slice(root.length), fdata, {unsafe: true});\n\tif(ctype) file.ctype = ctype;\n}\n\nfunction parse_mad(file/*:RawBytes*/, options/*:CFBReadOpts*/)/*:CFBContainer*/ {\n\tif(a2s(file.slice(0,13)).toLowerCase() != \"mime-version:\") throw new Error(\"Unsupported MAD header\");\n\tvar root = (options && options.root || \"\");\n\t// $FlowIgnore\n\tvar data = (has_buf && Buffer.isBuffer(file) ? file.toString(\"binary\") : a2s(file)).split(\"\\r\\n\");\n\tvar di = 0, row = \"\";\n\n\t/* if root is not specified, scan for the common prefix */\n\tfor(di = 0; di < data.length; ++di) {\n\t\trow = data[di];\n\t\tif(!/^Content-Location:/i.test(row)) continue;\n\t\trow = row.slice(row.indexOf(\"file\"));\n\t\tif(!root) root = row.slice(0, row.lastIndexOf(\"/\") + 1);\n\t\tif(row.slice(0, root.length) == root) continue;\n\t\twhile(root.length > 0) {\n\t\t\troot = root.slice(0, root.length - 1);\n\t\t\troot = root.slice(0, root.lastIndexOf(\"/\") + 1);\n\t\t\tif(row.slice(0,root.length) == root) break;\n\t\t}\n\t}\n\n\tvar mboundary = (data[1] || \"\").match(/boundary=\"(.*?)\"/);\n\tif(!mboundary) throw new Error(\"MAD cannot find boundary\");\n\tvar boundary = \"--\" + (mboundary[1] || \"\");\n\n\tvar FileIndex/*:CFBFileIndex*/ = [], FullPaths/*:Array<string>*/ = [];\n\tvar o = {\n\t\tFileIndex: FileIndex,\n\t\tFullPaths: FullPaths\n\t};\n\tinit_cfb(o);\n\tvar start_di, fcnt = 0;\n\tfor(di = 0; di < data.length; ++di) {\n\t\tvar line = data[di];\n\t\tif(line !== boundary && line !== boundary + \"--\") continue;\n\t\tif(fcnt++) parse_mime(o, data.slice(start_di, di), root);\n\t\tstart_di = di;\n\t}\n\treturn o;\n}\n\nfunction write_mad(cfb/*:CFBContainer*/, options/*:CFBWriteOpts*/)/*:string*/ {\n\tvar opts = options || {};\n\tvar boundary = opts.boundary || \"SheetJS\";\n\tboundary = '------=' + boundary;\n\n\tvar out = [\n\t\t'MIME-Version: 1.0',\n\t\t'Content-Type: multipart/related; boundary=\"' + boundary.slice(2) + '\"',\n\t\t'',\n\t\t'',\n\t\t''\n\t];\n\n\tvar root = cfb.FullPaths[0], fp = root, fi = cfb.FileIndex[0];\n\tfor(var i = 1; i < cfb.FullPaths.length; ++i) {\n\t\tfp = cfb.FullPaths[i].slice(root.length);\n\t\tfi = cfb.FileIndex[i];\n\t\tif(!fi.size || !fi.content || fp == \"\\u0001Sh33tJ5\") continue;\n\n\t\t/* Normalize filename */\n\t\tfp = fp.replace(/[\\x00-\\x08\\x0B\\x0C\\x0E-\\x1F\\x7E-\\xFF]/g, function(c) {\n\t\t\treturn \"_x\" + c.charCodeAt(0).toString(16) + \"_\";\n\t\t}).replace(/[\\u0080-\\uFFFF]/g, function(u) {\n\t\t\treturn \"_u\" + u.charCodeAt(0).toString(16) + \"_\";\n\t\t});\n\n\t\t/* Extract content as binary string */\n\t\tvar ca = fi.content;\n\t\t// $FlowIgnore\n\t\tvar cstr = has_buf && Buffer.isBuffer(ca) ? ca.toString(\"binary\") : a2s(ca);\n\n\t\t/* 4/5 of first 1024 chars ascii -> quoted printable, else base64 */\n\t\tvar dispcnt = 0, L = Math.min(1024, cstr.length), cc = 0;\n\t\tfor(var csl = 0; csl <= L; ++csl) if((cc=cstr.charCodeAt(csl)) >= 0x20 && cc < 0x80) ++dispcnt;\n\t\tvar qp = dispcnt >= L * 4 / 5;\n\n\t\tout.push(boundary);\n\t\tout.push('Content-Location: ' + (opts.root || 'file:///C:/SheetJS/') + fp);\n\t\tout.push('Content-Transfer-Encoding: ' + (qp ? 'quoted-printable' : 'base64'));\n\t\tout.push('Content-Type: ' + get_content_type(fi, fp));\n\t\tout.push('');\n\n\t\tout.push(qp ? write_quoted_printable(cstr) : write_base64_76(cstr));\n\t}\n\tout.push(boundary + '--\\r\\n');\n\treturn out.join(\"\\r\\n\");\n}\nfunction cfb_new(opts/*:?any*/)/*:CFBContainer*/ {\n\tvar o/*:CFBContainer*/ = ({}/*:any*/);\n\tinit_cfb(o, opts);\n\treturn o;\n}\n\nfunction cfb_add(cfb/*:CFBContainer*/, name/*:string*/, content/*:?RawBytes*/, opts/*:?any*/)/*:CFBEntry*/ {\n\tvar unsafe = opts && opts.unsafe;\n\tif(!unsafe) init_cfb(cfb);\n\tvar file = !unsafe && CFB.find(cfb, name);\n\tif(!file) {\n\t\tvar fpath/*:string*/ = cfb.FullPaths[0];\n\t\tif(name.slice(0, fpath.length) == fpath) fpath = name;\n\t\telse {\n\t\t\tif(fpath.slice(-1) != \"/\") fpath += \"/\";\n\t\t\tfpath = (fpath + name).replace(\"//\",\"/\");\n\t\t}\n\t\tfile = ({name: filename(name), type: 2}/*:any*/);\n\t\tcfb.FileIndex.push(file);\n\t\tcfb.FullPaths.push(fpath);\n\t\tif(!unsafe) CFB.utils.cfb_gc(cfb);\n\t}\n\t/*:: if(!file) throw new Error(\"unreachable\"); */\n\tfile.content = (content/*:any*/);\n\tfile.size = content ? content.length : 0;\n\tif(opts) {\n\t\tif(opts.CLSID) file.clsid = opts.CLSID;\n\t\tif(opts.mt) file.mt = opts.mt;\n\t\tif(opts.ct) file.ct = opts.ct;\n\t}\n\treturn file;\n}\n\nfunction cfb_del(cfb/*:CFBContainer*/, name/*:string*/)/*:boolean*/ {\n\tinit_cfb(cfb);\n\tvar file = CFB.find(cfb, name);\n\tif(file) for(var j = 0; j < cfb.FileIndex.length; ++j) if(cfb.FileIndex[j] == file) {\n\t\tcfb.FileIndex.splice(j, 1);\n\t\tcfb.FullPaths.splice(j, 1);\n\t\treturn true;\n\t}\n\treturn false;\n}\n\nfunction cfb_mov(cfb/*:CFBContainer*/, old_name/*:string*/, new_name/*:string*/)/*:boolean*/ {\n\tinit_cfb(cfb);\n\tvar file = CFB.find(cfb, old_name);\n\tif(file) for(var j = 0; j < cfb.FileIndex.length; ++j) if(cfb.FileIndex[j] == file) {\n\t\tcfb.FileIndex[j].name = filename(new_name);\n\t\tcfb.FullPaths[j] = new_name;\n\t\treturn true;\n\t}\n\treturn false;\n}\n\nfunction cfb_gc(cfb/*:CFBContainer*/)/*:void*/ { rebuild_cfb(cfb, true); }\n\nexports.find = find;\nexports.read = read;\nexports.parse = parse;\nexports.write = write;\nexports.writeFile = write_file;\nexports.utils = {\n\tcfb_new: cfb_new,\n\tcfb_add: cfb_add,\n\tcfb_del: cfb_del,\n\tcfb_mov: cfb_mov,\n\tcfb_gc: cfb_gc,\n\tReadShift: ReadShift,\n\tCheckField: CheckField,\n\tprep_blob: prep_blob,\n\tbconcat: bconcat,\n\tuse_zlib: use_zlib,\n\t_deflateRaw: _deflate,\n\t_inflateRaw: _inflate,\n\tconsts: consts\n};\n\nreturn exports;\n})();\n\nlet _fs = void 0;\nfunction set_fs(fs) { _fs = fs; }\nexport { set_fs };\n\n/* normalize data for blob ctor */\nfunction blobify(data) {\n\tif(typeof data === \"string\") return s2ab(data);\n\tif(Array.isArray(data)) return a2u(data);\n\treturn data;\n}\n/* write or download file */\nfunction write_dl(fname/*:string*/, payload/*:any*/, enc/*:?string*/) {\n\t/*global IE_SaveFile, Blob, navigator, saveAs, document, File, chrome */\n\tif(typeof _fs !== 'undefined' && _fs.writeFileSync) return enc ? _fs.writeFileSync(fname, payload, enc) : _fs.writeFileSync(fname, payload);\n\tif(typeof Deno !== 'undefined') {\n\t\t/* in this spot, it's safe to assume typed arrays and TextEncoder/TextDecoder exist */\n\t\tif(enc && typeof payload == \"string\") switch(enc) {\n\t\t\tcase \"utf8\": payload = new TextEncoder(enc).encode(payload); break;\n\t\t\tcase \"binary\": payload = s2ab(payload); break;\n\t\t\t/* TODO: binary equivalent */\n\t\t\tdefault: throw new Error(\"Unsupported encoding \" + enc);\n\t\t}\n\t\treturn Deno.writeFileSync(fname, payload);\n\t}\n\tvar data = (enc == \"utf8\") ? utf8write(payload) : payload;\n\t/*:: declare var IE_SaveFile: any; */\n\tif(typeof IE_SaveFile !== 'undefined') return IE_SaveFile(data, fname);\n\tif(typeof Blob !== 'undefined') {\n\t\tvar blob = new Blob([blobify(data)], {type:\"application/octet-stream\"});\n\t\t/*:: declare var navigator: any; */\n\t\tif(typeof navigator !== 'undefined' && navigator.msSaveBlob) return navigator.msSaveBlob(blob, fname);\n\t\t/*:: declare var saveAs: any; */\n\t\tif(typeof saveAs !== 'undefined') return saveAs(blob, fname);\n\t\tif(typeof URL !== 'undefined' && typeof document !== 'undefined' && document.createElement && URL.createObjectURL) {\n\t\t\tvar url = URL.createObjectURL(blob);\n\t\t\t/*:: declare var chrome: any; */\n\t\t\tif(typeof chrome === 'object' && typeof (chrome.downloads||{}).download == \"function\") {\n\t\t\t\tif(URL.revokeObjectURL && typeof setTimeout !== 'undefined') setTimeout(function() { URL.revokeObjectURL(url); }, 60000);\n\t\t\t\treturn chrome.downloads.download({ url: url, filename: fname, saveAs: true});\n\t\t\t}\n\t\t\tvar a = document.createElement(\"a\");\n\t\t\tif(a.download != null) {\n\t\t\t\t/*:: if(document.body == null) throw new Error(\"unreachable\"); */\n\t\t\t\ta.download = fname; a.href = url; document.body.appendChild(a); a.click();\n\t\t\t\t/*:: if(document.body == null) throw new Error(\"unreachable\"); */ document.body.removeChild(a);\n\t\t\t\tif(URL.revokeObjectURL && typeof setTimeout !== 'undefined') setTimeout(function() { URL.revokeObjectURL(url); }, 60000);\n\t\t\t\treturn url;\n\t\t\t}\n\t\t}\n\t}\n\t// $FlowIgnore\n\tif(typeof $ !== 'undefined' && typeof File !== 'undefined' && typeof Folder !== 'undefined') try { // extendscript\n\t\t// $FlowIgnore\n\t\tvar out = File(fname); out.open(\"w\"); out.encoding = \"binary\";\n\t\tif(Array.isArray(payload)) payload = a2s(payload);\n\t\tout.write(payload); out.close(); return payload;\n\t} catch(e) { if(!e.message || !e.message.match(/onstruct/)) throw e; }\n\tthrow new Error(\"cannot save file \" + fname);\n}\n\n/* read binary data from file */\nfunction read_binary(path/*:string*/) {\n\tif(typeof _fs !== 'undefined') return _fs.readFileSync(path);\n\tif(typeof Deno !== 'undefined') return Deno.readFileSync(path);\n\t// $FlowIgnore\n\tif(typeof $ !== 'undefined' && typeof File !== 'undefined' && typeof Folder !== 'undefined') try { // extendscript\n\t\t// $FlowIgnore\n\t\tvar infile = File(path); infile.open(\"r\"); infile.encoding = \"binary\";\n\t\tvar data = infile.read(); infile.close();\n\t\treturn data;\n\t} catch(e) { if(!e.message || !e.message.match(/onstruct/)) throw e; }\n\tthrow new Error(\"Cannot access file \" + path);\n}\nfunction keys(o/*:any*/)/*:Array<any>*/ {\n\tvar ks = Object.keys(o), o2 = [];\n\tfor(var i = 0; i < ks.length; ++i) if(Object.prototype.hasOwnProperty.call(o, ks[i])) o2.push(ks[i]);\n\treturn o2;\n}\n\nfunction evert_key(obj/*:any*/, key/*:string*/)/*:EvertType*/ {\n\tvar o = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) if(o[obj[K[i]][key]] == null) o[obj[K[i]][key]] = K[i];\n\treturn o;\n}\n\nfunction evert(obj/*:any*/)/*:EvertType*/ {\n\tvar o = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) o[obj[K[i]]] = K[i];\n\treturn o;\n}\n\nfunction evert_num(obj/*:any*/)/*:EvertNumType*/ {\n\tvar o = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) o[obj[K[i]]] = parseInt(K[i],10);\n\treturn o;\n}\n\nfunction evert_arr(obj/*:any*/)/*:EvertArrType*/ {\n\tvar o/*:EvertArrType*/ = ([]/*:any*/), K = keys(obj);\n\tfor(var i = 0; i !== K.length; ++i) {\n\t\tif(o[obj[K[i]]] == null) o[obj[K[i]]] = [];\n\t\to[obj[K[i]]].push(K[i]);\n\t}\n\treturn o;\n}\n\nvar basedate = /*#__PURE__*/new Date(1899, 11, 30, 0, 0, 0); // 2209161600000\nfunction datenum(v/*:Date*/, date1904/*:?boolean*/)/*:number*/ {\n\tvar epoch = /*#__PURE__*/v.getTime();\n\tif(date1904) epoch -= 1462*24*60*60*1000;\n\tvar dnthresh = /*#__PURE__*/basedate.getTime() + (/*#__PURE__*/v.getTimezoneOffset() - /*#__PURE__*/basedate.getTimezoneOffset()) * 60000;\n\treturn (epoch - dnthresh) / (24 * 60 * 60 * 1000);\n}\nvar refdate = /*#__PURE__*/new Date();\nvar dnthresh = /*#__PURE__*/basedate.getTime() + (/*#__PURE__*/refdate.getTimezoneOffset() - /*#__PURE__*/basedate.getTimezoneOffset()) * 60000;\nvar refoffset = /*#__PURE__*/refdate.getTimezoneOffset();\nfunction numdate(v/*:number*/)/*:Date*/ {\n\tvar out = new Date();\n\tout.setTime(v * 24 * 60 * 60 * 1000 + dnthresh);\n\tif (out.getTimezoneOffset() !== refoffset) {\n\t\tout.setTime(out.getTime() + (out.getTimezoneOffset() - refoffset) * 60000);\n\t}\n\treturn out;\n}\n\n/* ISO 8601 Duration */\nfunction parse_isodur(s) {\n\tvar sec = 0, mt = 0, time = false;\n\tvar m = s.match(/P([0-9\\.]+Y)?([0-9\\.]+M)?([0-9\\.]+D)?T([0-9\\.]+H)?([0-9\\.]+M)?([0-9\\.]+S)?/);\n\tif(!m) throw new Error(\"|\" + s + \"| is not an ISO8601 Duration\");\n\tfor(var i = 1; i != m.length; ++i) {\n\t\tif(!m[i]) continue;\n\t\tmt = 1;\n\t\tif(i > 3) time = true;\n\t\tswitch(m[i].slice(m[i].length-1)) {\n\t\t\tcase 'Y':\n\t\t\t\tthrow new Error(\"Unsupported ISO Duration Field: \" + m[i].slice(m[i].length-1));\n\t\t\tcase 'D': mt *= 24;\n\t\t\t\t/* falls through */\n\t\t\tcase 'H': mt *= 60;\n\t\t\t\t/* falls through */\n\t\t\tcase 'M':\n\t\t\t\tif(!time) throw new Error(\"Unsupported ISO Duration Field: M\");\n\t\t\t\telse mt *= 60;\n\t\t\t\t/* falls through */\n\t\t\tcase 'S': break;\n\t\t}\n\t\tsec += mt * parseInt(m[i], 10);\n\t}\n\treturn sec;\n}\n\nvar good_pd_date_1 = /*#__PURE__*/new Date('2017-02-19T19:06:09.000Z');\nvar good_pd_date = /*#__PURE__*/isNaN(/*#__PURE__*/good_pd_date_1.getFullYear()) ? /*#__PURE__*/new Date('2/19/17') : good_pd_date_1;\nvar good_pd = /*#__PURE__*/good_pd_date.getFullYear() == 2017;\n/* parses a date as a local date */\nfunction parseDate(str/*:string|Date*/, fixdate/*:?number*/)/*:Date*/ {\n\tvar d = new Date(str);\n\tif(good_pd) {\n\t\t/*:: if(fixdate == null) fixdate = 0; */\n\t\tif(fixdate > 0) d.setTime(d.getTime() + d.getTimezoneOffset() * 60 * 1000);\n\t\telse if(fixdate < 0) d.setTime(d.getTime() - d.getTimezoneOffset() * 60 * 1000);\n\t\treturn d;\n\t}\n\tif(str instanceof Date) return str;\n\tif(good_pd_date.getFullYear() == 1917 && !isNaN(d.getFullYear())) {\n\t\tvar s = d.getFullYear();\n\t\tif(str.indexOf(\"\" + s) > -1) return d;\n\t\td.setFullYear(d.getFullYear() + 100); return d;\n\t}\n\tvar n = str.match(/\\d+/g)||[\"2017\",\"2\",\"19\",\"0\",\"0\",\"0\"];\n\tvar out = new Date(+n[0], +n[1] - 1, +n[2], (+n[3]||0), (+n[4]||0), (+n[5]||0));\n\tif(str.indexOf(\"Z\") > -1) out = new Date(out.getTime() - out.getTimezoneOffset() * 60 * 1000);\n\treturn out;\n}\n\nfunction cc2str(arr/*:Array<number>*/, debomit)/*:string*/ {\n\tif(has_buf && Buffer.isBuffer(arr)) {\n\t\tif(debomit) {\n\t\t\tif(arr[0] == 0xFF && arr[1] == 0xFE) return utf8write(arr.slice(2).toString(\"utf16le\"));\n\t\t\tif(arr[1] == 0xFE && arr[2] == 0xFF) return utf8write(utf16beread(arr.slice(2).toString(\"binary\")));\n\t\t}\n\t\treturn arr.toString(\"binary\");\n\t}\n\n\tif(typeof TextDecoder !== \"undefined\") try {\n\t\tif(debomit) {\n\t\t\tif(arr[0] == 0xFF && arr[1] == 0xFE) return utf8write(new TextDecoder(\"utf-16le\").decode(arr.slice(2)));\n\t\t\tif(arr[0] == 0xFE && arr[1] == 0xFF) return utf8write(new TextDecoder(\"utf-16be\").decode(arr.slice(2)));\n\t\t}\n\t\tvar rev = {\n\t\t\t\"\\u20ac\": \"\\x80\", \"\\u201a\": \"\\x82\", \"\\u0192\": \"\\x83\", \"\\u201e\": \"\\x84\",\n\t\t\t\"\\u2026\": \"\\x85\", \"\\u2020\": \"\\x86\", \"\\u2021\": \"\\x87\", \"\\u02c6\": \"\\x88\",\n\t\t\t\"\\u2030\": \"\\x89\", \"\\u0160\": \"\\x8a\", \"\\u2039\": \"\\x8b\", \"\\u0152\": \"\\x8c\",\n\t\t\t\"\\u017d\": \"\\x8e\", \"\\u2018\": \"\\x91\", \"\\u2019\": \"\\x92\", \"\\u201c\": \"\\x93\",\n\t\t\t\"\\u201d\": \"\\x94\", \"\\u2022\": \"\\x95\", \"\\u2013\": \"\\x96\", \"\\u2014\": \"\\x97\",\n\t\t\t\"\\u02dc\": \"\\x98\", \"\\u2122\": \"\\x99\", \"\\u0161\": \"\\x9a\", \"\\u203a\": \"\\x9b\",\n\t\t\t\"\\u0153\": \"\\x9c\", \"\\u017e\": \"\\x9e\", \"\\u0178\": \"\\x9f\"\n\t\t};\n\t\tif(Array.isArray(arr)) arr = new Uint8Array(arr);\n\t\treturn new TextDecoder(\"latin1\").decode(arr).replace(/[€‚ƒ„…†‡ˆ‰Š‹ŒŽ‘’“”•–—˜™š›œžŸ]/g, function(c) { return rev[c] || c; });\n\t} catch(e) {}\n\n\tvar o = [];\n\tfor(var i = 0; i != arr.length; ++i) o.push(String.fromCharCode(arr[i]));\n\treturn o.join(\"\");\n}\n\nfunction dup(o/*:any*/)/*:any*/ {\n\tif(typeof JSON != 'undefined' && !Array.isArray(o)) return JSON.parse(JSON.stringify(o));\n\tif(typeof o != 'object' || o == null) return o;\n\tif(o instanceof Date) return new Date(o.getTime());\n\tvar out = {};\n\tfor(var k in o) if(Object.prototype.hasOwnProperty.call(o, k)) out[k] = dup(o[k]);\n\treturn out;\n}\n\nfunction fill(c/*:string*/,l/*:number*/)/*:string*/ { var o = \"\"; while(o.length < l) o+=c; return o; }\n\n/* TODO: stress test */\nfunction fuzzynum(s/*:string*/)/*:number*/ {\n\tvar v/*:number*/ = Number(s);\n\tif(!isNaN(v)) return isFinite(v) ? v : NaN;\n\tif(!/\\d/.test(s)) return v;\n\tvar wt = 1;\n\tvar ss = s.replace(/([\\d]),([\\d])/g,\"$1$2\").replace(/[$]/g,\"\").replace(/[%]/g, function() { wt *= 100; return \"\";});\n\tif(!isNaN(v = Number(ss))) return v / wt;\n\tss = ss.replace(/[(](.*)[)]/,function($$, $1) { wt = -wt; return $1;});\n\tif(!isNaN(v = Number(ss))) return v / wt;\n\treturn v;\n}\nvar lower_months = ['january', 'february', 'march', 'april', 'may', 'june', 'july', 'august', 'september', 'october', 'november', 'december'];\nfunction fuzzydate(s/*:string*/)/*:Date*/ {\n\tvar o = new Date(s), n = new Date(NaN);\n\tvar y = o.getYear(), m = o.getMonth(), d = o.getDate();\n\tif(isNaN(d)) return n;\n\tvar lower = s.toLowerCase();\n\tif(lower.match(/jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec/)) {\n\t\tlower = lower.replace(/[^a-z]/g,\"\").replace(/([^a-z]|^)[ap]m?([^a-z]|$)/,\"\");\n\t\tif(lower.length > 3 && lower_months.indexOf(lower) == -1) return n;\n\t} else if(lower.match(/[a-z]/)) return n;\n\tif(y < 0 || y > 8099) return n;\n\tif((m > 0 || d > 1) && y != 101) return o;\n\tif(s.match(/[^-0-9:,\\/\\\\]/)) return n;\n\treturn o;\n}\n\nvar split_regex = /*#__PURE__*/(function() {\n\tvar safe_split_regex = \"abacaba\".split(/(:?b)/i).length == 5;\n\treturn function split_regex(str/*:string*/, re, def/*:string*/)/*:Array<string>*/ {\n\t\tif(safe_split_regex || typeof re == \"string\") return str.split(re);\n\t\tvar p = str.split(re), o = [p[0]];\n\t\tfor(var i = 1; i < p.length; ++i) { o.push(def); o.push(p[i]); }\n\t\treturn o;\n\t};\n})();\nfunction getdatastr(data)/*:?string*/ {\n\tif(!data) return null;\n\tif(data.content && data.type) return cc2str(data.content, true);\n\tif(data.data) return debom(data.data);\n\tif(data.asNodeBuffer && has_buf) return debom(data.asNodeBuffer().toString('binary'));\n\tif(data.asBinary) return debom(data.asBinary());\n\tif(data._data && data._data.getContent) return debom(cc2str(Array.prototype.slice.call(data._data.getContent(),0)));\n\treturn null;\n}\n\nfunction getdatabin(data) {\n\tif(!data) return null;\n\tif(data.data) return char_codes(data.data);\n\tif(data.asNodeBuffer && has_buf) return data.asNodeBuffer();\n\tif(data._data && data._data.getContent) {\n\t\tvar o = data._data.getContent();\n\t\tif(typeof o == \"string\") return char_codes(o);\n\t\treturn Array.prototype.slice.call(o);\n\t}\n\tif(data.content && data.type) return data.content;\n\treturn null;\n}\n\nfunction getdata(data) { return (data && data.name.slice(-4) === \".bin\") ? getdatabin(data) : getdatastr(data); }\n\n/* Part 2 Section 10.1.2 \"Mapping Content Types\" Names are case-insensitive */\n/* OASIS does not comment on filename case sensitivity */\nfunction safegetzipfile(zip, file/*:string*/) {\n\tvar k = zip.FullPaths || keys(zip.files);\n\tvar f = file.toLowerCase().replace(/[\\/]/g, '\\\\'), g = f.replace(/\\\\/g,'\\/');\n\tfor(var i=0; i<k.length; ++i) {\n\t\tvar n = k[i].replace(/^Root Entry[\\/]/,\"\").toLowerCase();\n\t\tif(f == n || g == n) return zip.files ? zip.files[k[i]] : zip.FileIndex[i];\n\t}\n\treturn null;\n}\n\nfunction getzipfile(zip, file/*:string*/) {\n\tvar o = safegetzipfile(zip, file);\n\tif(o == null) throw new Error(\"Cannot find file \" + file + \" in zip\");\n\treturn o;\n}\n\nfunction getzipdata(zip, file/*:string*/, safe/*:?boolean*/)/*:any*/ {\n\tif(!safe) return getdata(getzipfile(zip, file));\n\tif(!file) return null;\n\ttry { return getzipdata(zip, file); } catch(e) { return null; }\n}\n\nfunction getzipstr(zip, file/*:string*/, safe/*:?boolean*/)/*:?string*/ {\n\tif(!safe) return getdatastr(getzipfile(zip, file));\n\tif(!file) return null;\n\ttry { return getzipstr(zip, file); } catch(e) { return null; }\n}\n\nfunction getzipbin(zip, file/*:string*/, safe/*:?boolean*/)/*:any*/ {\n\tif(!safe) return getdatabin(getzipfile(zip, file));\n\tif(!file) return null;\n\ttry { return getzipbin(zip, file); } catch(e) { return null; }\n}\n\nfunction zipentries(zip) {\n\tvar k = zip.FullPaths || keys(zip.files), o = [];\n\tfor(var i = 0; i < k.length; ++i) if(k[i].slice(-1) != '/') o.push(k[i].replace(/^Root Entry[\\/]/, \"\"));\n\treturn o.sort();\n}\n\nfunction zip_add_file(zip, path, content) {\n\tif(zip.FullPaths) {\n\t\tif(typeof content == \"string\") {\n\t\t\tvar res;\n\t\t\tif(has_buf) res = Buffer_from(content);\n\t\t\t/* TODO: investigate performance in Edge 13 */\n\t\t\t//else if(typeof TextEncoder !== \"undefined\") res = new TextEncoder().encode(content);\n\t\t\telse res = utf8decode(content);\n\t\t\treturn CFB.utils.cfb_add(zip, path, res);\n\t\t}\n\t\tCFB.utils.cfb_add(zip, path, content);\n\t}\n\telse zip.file(path, content);\n}\n\nfunction zip_new() { return CFB.utils.cfb_new(); }\n\nfunction zip_read(d, o) {\n\tswitch(o.type) {\n\t\tcase \"base64\": return CFB.read(d, { type: \"base64\" });\n\t\tcase \"binary\": return CFB.read(d, { type: \"binary\" });\n\t\tcase \"buffer\": case \"array\": return CFB.read(d, { type: \"buffer\" });\n\t}\n\tthrow new Error(\"Unrecognized type \" + o.type);\n}\n\nfunction resolve_path(path/*:string*/, base/*:string*/)/*:string*/ {\n\tif(path.charAt(0) == \"/\") return path.slice(1);\n\tvar result = base.split('/');\n\tif(base.slice(-1) != \"/\") result.pop(); // folder path\n\tvar target = path.split('/');\n\twhile (target.length !== 0) {\n\t\tvar step = target.shift();\n\t\tif (step === '..') result.pop();\n\t\telse if (step !== '.') result.push(step);\n\t}\n\treturn result.join('/');\n}\nvar XML_HEADER = '<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\\r\\n';\nvar attregexg=/([^\"\\s?>\\/]+)\\s*=\\s*((?:\")([^\"]*)(?:\")|(?:')([^']*)(?:')|([^'\">\\s]+))/g;\nvar tagregex1=/<[\\/\\?]?[a-zA-Z0-9:_-]+(?:\\s+[^\"\\s?>\\/]+\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[^'\">\\s=]+))*\\s*[\\/\\?]?>/mg, tagregex2 = /<[^>]*>/g;\nvar tagregex = /*#__PURE__*/XML_HEADER.match(tagregex1) ? tagregex1 : tagregex2;\nvar nsregex=/<\\w*:/, nsregex2 = /<(\\/?)\\w+:/;\nfunction parsexmltag(tag/*:string*/, skip_root/*:?boolean*/, skip_LC/*:?boolean*/)/*:any*/ {\n\tvar z = ({}/*:any*/);\n\tvar eq = 0, c = 0;\n\tfor(; eq !== tag.length; ++eq) if((c = tag.charCodeAt(eq)) === 32 || c === 10 || c === 13) break;\n\tif(!skip_root) z[0] = tag.slice(0, eq);\n\tif(eq === tag.length) return z;\n\tvar m = tag.match(attregexg), j=0, v=\"\", i=0, q=\"\", cc=\"\", quot = 1;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\tcc = m[i];\n\t\tfor(c=0; c != cc.length; ++c) if(cc.charCodeAt(c) === 61) break;\n\t\tq = cc.slice(0,c).trim();\n\t\twhile(cc.charCodeAt(c+1) == 32) ++c;\n\t\tquot = ((eq=cc.charCodeAt(c+1)) == 34 || eq == 39) ? 1 : 0;\n\t\tv = cc.slice(c+1+quot, cc.length-quot);\n\t\tfor(j=0;j!=q.length;++j) if(q.charCodeAt(j) === 58) break;\n\t\tif(j===q.length) {\n\t\t\tif(q.indexOf(\"_\") > 0) q = q.slice(0, q.indexOf(\"_\")); // from ods\n\t\t\tz[q] = v;\n\t\t\tif(!skip_LC) z[q.toLowerCase()] = v;\n\t\t}\n\t\telse {\n\t\t\tvar k = (j===5 && q.slice(0,5)===\"xmlns\"?\"xmlns\":\"\")+q.slice(j+1);\n\t\t\tif(z[k] && q.slice(j-3,j) == \"ext\") continue; // from ods\n\t\t\tz[k] = v;\n\t\t\tif(!skip_LC) z[k.toLowerCase()] = v;\n\t\t}\n\t}\n\treturn z;\n}\nfunction strip_ns(x/*:string*/)/*:string*/ { return x.replace(nsregex2, \"<$1\"); }\n\nvar encodings = {\n\t'&quot;': '\"',\n\t'&apos;': \"'\",\n\t'&gt;': '>',\n\t'&lt;': '<',\n\t'&amp;': '&'\n};\nvar rencoding = /*#__PURE__*/evert(encodings);\n//var rencstr = \"&<>'\\\"\".split(\"\");\n\n// TODO: CP remap (need to read file version to determine OS)\nvar unescapexml/*:StringConv*/ = /*#__PURE__*/(function() {\n\t/* 22.4.2.4 bstr (Basic String) */\n\tvar encregex = /&(?:quot|apos|gt|lt|amp|#x?([\\da-fA-F]+));/ig, coderegex = /_x([\\da-fA-F]{4})_/ig;\n\treturn function unescapexml(text/*:string*/)/*:string*/ {\n\t\tvar s = text + '', i = s.indexOf(\"<![CDATA[\");\n\t\tif(i == -1) return s.replace(encregex, function($$, $1) { return encodings[$$]||String.fromCharCode(parseInt($1,$$.indexOf(\"x\")>-1?16:10))||$$; }).replace(coderegex,function(m,c) {return String.fromCharCode(parseInt(c,16));});\n\t\tvar j = s.indexOf(\"]]>\");\n\t\treturn unescapexml(s.slice(0, i)) + s.slice(i+9,j) + unescapexml(s.slice(j+3));\n\t};\n})();\n\nvar decregex=/[&<>'\"]/g, charegex = /[\\u0000-\\u0008\\u000b-\\u001f]/g;\nfunction escapexml(text/*:string*/)/*:string*/{\n\tvar s = text + '';\n\treturn s.replace(decregex, function(y) { return rencoding[y]; }).replace(charegex,function(s) { return \"_x\" + (\"000\"+s.charCodeAt(0).toString(16)).slice(-4) + \"_\";});\n}\nfunction escapexmltag(text/*:string*/)/*:string*/{ return escapexml(text).replace(/ /g,\"_x0020_\"); }\n\nvar htmlcharegex = /[\\u0000-\\u001f]/g;\nfunction escapehtml(text/*:string*/)/*:string*/{\n\tvar s = text + '';\n\treturn s.replace(decregex, function(y) { return rencoding[y]; }).replace(/\\n/g, \"<br/>\").replace(htmlcharegex,function(s) { return \"&#x\" + (\"000\"+s.charCodeAt(0).toString(16)).slice(-4) + \";\"; });\n}\n\nfunction escapexlml(text/*:string*/)/*:string*/{\n\tvar s = text + '';\n\treturn s.replace(decregex, function(y) { return rencoding[y]; }).replace(htmlcharegex,function(s) { return \"&#x\" + (s.charCodeAt(0).toString(16)).toUpperCase() + \";\"; });\n}\n\n/* TODO: handle codepages */\nvar xlml_fixstr/*:StringConv*/ = /*#__PURE__*/(function() {\n\tvar entregex = /&#(\\d+);/g;\n\tfunction entrepl($$/*:string*/,$1/*:string*/)/*:string*/ { return String.fromCharCode(parseInt($1,10)); }\n\treturn function xlml_fixstr(str/*:string*/)/*:string*/ { return str.replace(entregex,entrepl); };\n})();\nfunction xlml_unfixstr(str/*:string*/)/*:string*/ { return str.replace(/(\\r\\n|[\\r\\n])/g,\"\\&#10;\"); }\n\nfunction parsexmlbool(value/*:any*/)/*:boolean*/ {\n\tswitch(value) {\n\t\tcase 1: case true: case '1': case 'true': case 'TRUE': return true;\n\t\t/* case '0': case 'false': case 'FALSE':*/\n\t\tdefault: return false;\n\t}\n}\n\nfunction utf8reada(orig/*:string*/)/*:string*/ {\n\tvar out = \"\", i = 0, c = 0, d = 0, e = 0, f = 0, w = 0;\n\twhile (i < orig.length) {\n\t\tc = orig.charCodeAt(i++);\n\t\tif (c < 128) { out += String.fromCharCode(c); continue; }\n\t\td = orig.charCodeAt(i++);\n\t\tif (c>191 && c<224) { f = ((c & 31) << 6); f |= (d & 63); out += String.fromCharCode(f); continue; }\n\t\te = orig.charCodeAt(i++);\n\t\tif (c < 240) { out += String.fromCharCode(((c & 15) << 12) | ((d & 63) << 6) | (e & 63)); continue; }\n\t\tf = orig.charCodeAt(i++);\n\t\tw = (((c & 7) << 18) | ((d & 63) << 12) | ((e & 63) << 6) | (f & 63))-65536;\n\t\tout += String.fromCharCode(0xD800 + ((w>>>10)&1023));\n\t\tout += String.fromCharCode(0xDC00 + (w&1023));\n\t}\n\treturn out;\n}\n\nfunction utf8readb(data) {\n\tvar out = new_raw_buf(2*data.length), w, i, j = 1, k = 0, ww=0, c;\n\tfor(i = 0; i < data.length; i+=j) {\n\t\tj = 1;\n\t\tif((c=data.charCodeAt(i)) < 128) w = c;\n\t\telse if(c < 224) { w = (c&31)*64+(data.charCodeAt(i+1)&63); j=2; }\n\t\telse if(c < 240) { w=(c&15)*4096+(data.charCodeAt(i+1)&63)*64+(data.charCodeAt(i+2)&63); j=3; }\n\t\telse { j = 4;\n\t\t\tw = (c & 7)*262144+(data.charCodeAt(i+1)&63)*4096+(data.charCodeAt(i+2)&63)*64+(data.charCodeAt(i+3)&63);\n\t\t\tw -= 65536; ww = 0xD800 + ((w>>>10)&1023); w = 0xDC00 + (w&1023);\n\t\t}\n\t\tif(ww !== 0) { out[k++] = ww&255; out[k++] = ww>>>8; ww = 0; }\n\t\tout[k++] = w%256; out[k++] = w>>>8;\n\t}\n\treturn out.slice(0,k).toString('ucs2');\n}\n\nfunction utf8readc(data) { return Buffer_from(data, 'binary').toString('utf8'); }\n\nvar utf8corpus = \"foo bar baz\\u00e2\\u0098\\u0083\\u00f0\\u009f\\u008d\\u00a3\";\nvar utf8read = has_buf && (/*#__PURE__*/utf8readc(utf8corpus) == /*#__PURE__*/utf8reada(utf8corpus) && utf8readc || /*#__PURE__*/utf8readb(utf8corpus) == /*#__PURE__*/utf8reada(utf8corpus) && utf8readb) || utf8reada;\n\nvar utf8write/*:StringConv*/ = has_buf ? function(data) { return Buffer_from(data, 'utf8').toString(\"binary\"); } : function(orig/*:string*/)/*:string*/ {\n\tvar out/*:Array<string>*/ = [], i = 0, c = 0, d = 0;\n\twhile(i < orig.length) {\n\t\tc = orig.charCodeAt(i++);\n\t\tswitch(true) {\n\t\t\tcase c < 128: out.push(String.fromCharCode(c)); break;\n\t\t\tcase c < 2048:\n\t\t\t\tout.push(String.fromCharCode(192 + (c >> 6)));\n\t\t\t\tout.push(String.fromCharCode(128 + (c & 63)));\n\t\t\t\tbreak;\n\t\t\tcase c >= 55296 && c < 57344:\n\t\t\t\tc -= 55296; d = orig.charCodeAt(i++) - 56320 + (c<<10);\n\t\t\t\tout.push(String.fromCharCode(240 + ((d >>18) & 7)));\n\t\t\t\tout.push(String.fromCharCode(144 + ((d >>12) & 63)));\n\t\t\t\tout.push(String.fromCharCode(128 + ((d >> 6) & 63)));\n\t\t\t\tout.push(String.fromCharCode(128 + (d & 63)));\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\tout.push(String.fromCharCode(224 + (c >> 12)));\n\t\t\t\tout.push(String.fromCharCode(128 + ((c >> 6) & 63)));\n\t\t\t\tout.push(String.fromCharCode(128 + (c & 63)));\n\t\t}\n\t}\n\treturn out.join(\"\");\n};\n\n// matches <foo>...</foo> extracts content\nvar matchtag = /*#__PURE__*/(function() {\n\tvar mtcache/*:{[k:string]:RegExp}*/ = ({}/*:any*/);\n\treturn function matchtag(f/*:string*/,g/*:?string*/)/*:RegExp*/ {\n\t\tvar t = f+\"|\"+(g||\"\");\n\t\tif(mtcache[t]) return mtcache[t];\n\t\treturn (mtcache[t] = new RegExp('<(?:\\\\w+:)?'+f+'(?: xml:space=\"preserve\")?(?:[^>]*)>([\\\\s\\\\S]*?)</(?:\\\\w+:)?'+f+'>',((g||\"\")/*:any*/)));\n\t};\n})();\n\nvar htmldecode/*:{(s:string):string}*/ = /*#__PURE__*/(function() {\n\tvar entities/*:Array<[RegExp, string]>*/ = [\n\t\t['nbsp', ' '], ['middot', '·'],\n\t\t['quot', '\"'], ['apos', \"'\"], ['gt',   '>'], ['lt',   '<'], ['amp',  '&']\n\t].map(function(x/*:[string, string]*/) { return [new RegExp('&' + x[0] + ';', \"ig\"), x[1]]; });\n\treturn function htmldecode(str/*:string*/)/*:string*/ {\n\t\tvar o = str\n\t\t\t\t// Remove new lines and spaces from start of content\n\t\t\t\t.replace(/^[\\t\\n\\r ]+/, \"\")\n\t\t\t\t// Remove new lines and spaces from end of content\n\t\t\t\t.replace(/[\\t\\n\\r ]+$/,\"\")\n\t\t\t\t// Added line which removes any white space characters after and before html tags\n\t\t\t\t.replace(/>\\s+/g,\">\").replace(/\\s+</g,\"<\")\n\t\t\t\t// Replace remaining new lines and spaces with space\n\t\t\t\t.replace(/[\\t\\n\\r ]+/g, \" \")\n\t\t\t\t// Replace <br> tags with new lines\n\t\t\t\t.replace(/<\\s*[bB][rR]\\s*\\/?>/g,\"\\n\")\n\t\t\t\t// Strip HTML elements\n\t\t\t\t.replace(/<[^>]*>/g,\"\");\n\t\tfor(var i = 0; i < entities.length; ++i) o = o.replace(entities[i][0], entities[i][1]);\n\t\treturn o;\n\t};\n})();\n\nvar vtregex = /*#__PURE__*/(function(){ var vt_cache = {};\n\treturn function vt_regex(bt) {\n\t\tif(vt_cache[bt] !== undefined) return vt_cache[bt];\n\t\treturn (vt_cache[bt] = new RegExp(\"<(?:vt:)?\" + bt + \">([\\\\s\\\\S]*?)</(?:vt:)?\" + bt + \">\", 'g') );\n};})();\nvar vtvregex = /<\\/?(?:vt:)?variant>/g, vtmregex = /<(?:vt:)([^>]*)>([\\s\\S]*)</;\nfunction parseVector(data/*:string*/, opts)/*:Array<{v:string,t:string}>*/ {\n\tvar h = parsexmltag(data);\n\n\tvar matches/*:Array<string>*/ = data.match(vtregex(h.baseType))||[];\n\tvar res/*:Array<any>*/ = [];\n\tif(matches.length != h.size) {\n\t\tif(opts.WTF) throw new Error(\"unexpected vector length \" + matches.length + \" != \" + h.size);\n\t\treturn res;\n\t}\n\tmatches.forEach(function(x/*:string*/) {\n\t\tvar v = x.replace(vtvregex,\"\").match(vtmregex);\n\t\tif(v) res.push({v:utf8read(v[2]), t:v[1]});\n\t});\n\treturn res;\n}\n\nvar wtregex = /(^\\s|\\s$|\\n)/;\nfunction writetag(f/*:string*/,g/*:string*/)/*:string*/ { return '<' + f + (g.match(wtregex)?' xml:space=\"preserve\"' : \"\") + '>' + g + '</' + f + '>'; }\n\nfunction wxt_helper(h)/*:string*/ { return keys(h).map(function(k) { return \" \" + k + '=\"' + h[k] + '\"';}).join(\"\"); }\nfunction writextag(f/*:string*/,g/*:?string*/,h) { return '<' + f + ((h != null) ? wxt_helper(h) : \"\") + ((g != null) ? (g.match(wtregex)?' xml:space=\"preserve\"' : \"\") + '>' + g + '</' + f : \"/\") + '>';}\n\nfunction write_w3cdtf(d/*:Date*/, t/*:?boolean*/)/*:string*/ { try { return d.toISOString().replace(/\\.\\d*/,\"\"); } catch(e) { if(t) throw e; } return \"\"; }\n\nfunction write_vt(s, xlsx/*:?boolean*/)/*:string*/ {\n\tswitch(typeof s) {\n\t\tcase 'string':\n\t\t\tvar o = writextag('vt:lpwstr', escapexml(s));\n\t\t\tif(xlsx) o = o.replace(/&quot;/g, \"_x0022_\");\n\t\t\treturn o;\n\t\tcase 'number': return writextag((s|0)==s?'vt:i4':'vt:r8', escapexml(String(s)));\n\t\tcase 'boolean': return writextag('vt:bool',s?'true':'false');\n\t}\n\tif(s instanceof Date) return writextag('vt:filetime', write_w3cdtf(s));\n\tthrow new Error(\"Unable to serialize \" + s);\n}\n\nfunction xlml_normalize(d)/*:string*/ {\n\tif(has_buf &&/*::typeof Buffer !== \"undefined\" && d != null && d instanceof Buffer &&*/ Buffer.isBuffer(d)) return d.toString('utf8');\n\tif(typeof d === 'string') return d;\n\t/* duktape */\n\tif(typeof Uint8Array !== 'undefined' && d instanceof Uint8Array) return utf8read(a2s(ab2a(d)));\n\tthrow new Error(\"Bad input format: expected Buffer or string\");\n}\n/* UOS uses CJK in tags */\nvar xlmlregex = /<(\\/?)([^\\s?><!\\/:]*:|)([^\\s?<>:\\/]+)(?:[\\s?:\\/][^>]*)?>/mg;\n//var xlmlregex = /<(\\/?)([a-z0-9]*:|)(\\w+)[^>]*>/mg;\n\nvar XMLNS = ({\n\tCORE_PROPS: 'http://schemas.openxmlformats.org/package/2006/metadata/core-properties',\n\tCUST_PROPS: \"http://schemas.openxmlformats.org/officeDocument/2006/custom-properties\",\n\tEXT_PROPS: \"http://schemas.openxmlformats.org/officeDocument/2006/extended-properties\",\n\tCT: 'http://schemas.openxmlformats.org/package/2006/content-types',\n\tRELS: 'http://schemas.openxmlformats.org/package/2006/relationships',\n\tTCMNT: 'http://schemas.microsoft.com/office/spreadsheetml/2018/threadedcomments',\n\t'dc': 'http://purl.org/dc/elements/1.1/',\n\t'dcterms': 'http://purl.org/dc/terms/',\n\t'dcmitype': 'http://purl.org/dc/dcmitype/',\n\t'mx': 'http://schemas.microsoft.com/office/mac/excel/2008/main',\n\t'r': 'http://schemas.openxmlformats.org/officeDocument/2006/relationships',\n\t'sjs': 'http://schemas.openxmlformats.org/package/2006/sheetjs/core-properties',\n\t'vt': 'http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes',\n\t'xsi': 'http://www.w3.org/2001/XMLSchema-instance',\n\t'xsd': 'http://www.w3.org/2001/XMLSchema'\n}/*:any*/);\n\nvar XMLNS_main = [\n\t'http://schemas.openxmlformats.org/spreadsheetml/2006/main',\n\t'http://purl.oclc.org/ooxml/spreadsheetml/main',\n\t'http://schemas.microsoft.com/office/excel/2006/main',\n\t'http://schemas.microsoft.com/office/excel/2006/2'\n];\n\nvar XLMLNS = ({\n\t'o':    'urn:schemas-microsoft-com:office:office',\n\t'x':    'urn:schemas-microsoft-com:office:excel',\n\t'ss':   'urn:schemas-microsoft-com:office:spreadsheet',\n\t'dt':   'uuid:C2F41010-65B3-11d1-A29F-00AA00C14882',\n\t'mv':   'http://macVmlSchemaUri',\n\t'v':    'urn:schemas-microsoft-com:vml',\n\t'html': 'http://www.w3.org/TR/REC-html40'\n}/*:any*/);\nfunction read_double_le(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ {\n\tvar s = 1 - 2 * (b[idx + 7] >>> 7);\n\tvar e = ((b[idx + 7] & 0x7f) << 4) + ((b[idx + 6] >>> 4) & 0x0f);\n\tvar m = (b[idx+6]&0x0f);\n\tfor(var i = 5; i >= 0; --i) m = m * 256 + b[idx + i];\n\tif(e == 0x7ff) return m == 0 ? (s * Infinity) : NaN;\n\tif(e == 0) e = -1022;\n\telse { e -= 1023; m += Math.pow(2,52); }\n\treturn s * Math.pow(2, e - 52) * m;\n}\n\nfunction write_double_le(b/*:RawBytes|CFBlob*/, v/*:number*/, idx/*:number*/) {\n\tvar bs = ((((v < 0) || (1/v == -Infinity)) ? 1 : 0) << 7), e = 0, m = 0;\n\tvar av = bs ? (-v) : v;\n\tif(!isFinite(av)) { e = 0x7ff; m = isNaN(v) ? 0x6969 : 0; }\n\telse if(av == 0) e = m = 0;\n\telse {\n\t\te = Math.floor(Math.log(av) / Math.LN2);\n\t\tm = av * Math.pow(2, 52 - e);\n\t\tif((e <= -1023) && (!isFinite(m) || (m < Math.pow(2,52)))) { e = -1022; }\n\t\telse { m -= Math.pow(2,52); e+=1023; }\n\t}\n\tfor(var i = 0; i <= 5; ++i, m/=256) b[idx + i] = m & 0xff;\n\tb[idx + 6] = ((e & 0x0f) << 4) | (m & 0xf);\n\tb[idx + 7] = (e >> 4) | bs;\n}\n\nvar ___toBuffer = function(bufs/*:Array<Array<RawBytes> >*/)/*:RawBytes*/ { var x=[],w=10240; for(var i=0;i<bufs[0].length;++i) if(bufs[0][i]) for(var j=0,L=bufs[0][i].length;j<L;j+=w) x.push.apply(x, bufs[0][i].slice(j,j+w)); return x; };\nvar __toBuffer = has_buf ? function(bufs) { return (bufs[0].length > 0 && Buffer.isBuffer(bufs[0][0])) ? Buffer.concat(bufs[0].map(function(x) { return Buffer.isBuffer(x) ? x : Buffer_from(x); })) : ___toBuffer(bufs);} : ___toBuffer;\n\nvar ___utf16le = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/)/*:string*/ { var ss/*:Array<string>*/=[]; for(var i=s; i<e; i+=2) ss.push(String.fromCharCode(__readUInt16LE(b,i))); return ss.join(\"\").replace(chr0,''); };\nvar __utf16le = has_buf ? function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/)/*:string*/ { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___utf16le(b,s,e); return b.toString('utf16le',s,e).replace(chr0,'')/*.replace(chr1,'!')*/; } : ___utf16le;\n\nvar ___hexlify = function(b/*:RawBytes|CFBlob*/,s/*:number*/,l/*:number*/)/*:string*/ { var ss/*:Array<string>*/=[]; for(var i=s; i<s+l; ++i) ss.push((\"0\" + b[i].toString(16)).slice(-2)); return ss.join(\"\"); };\nvar __hexlify = has_buf ? function(b/*:RawBytes|CFBlob*/,s/*:number*/,l/*:number*/)/*:string*/ { return Buffer.isBuffer(b)/*:: && b instanceof Buffer*/ ? b.toString('hex',s,s+l) : ___hexlify(b,s,l); } : ___hexlify;\n\nvar ___utf8 = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/) { var ss=[]; for(var i=s; i<e; i++) ss.push(String.fromCharCode(__readUInt8(b,i))); return ss.join(\"\"); };\nvar __utf8 = has_buf ? function utf8_b(b/*:RawBytes|CFBlob*/, s/*:number*/, e/*:number*/) { return (Buffer.isBuffer(b)/*:: && (b instanceof Buffer)*/) ? b.toString('utf8',s,e) : ___utf8(b,s,e); } : ___utf8;\n\nvar ___lpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __lpstr = ___lpstr;\n\nvar ___cpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __cpstr = ___cpstr;\n\nvar ___lpwstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = 2*__readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len-1) : \"\";};\nvar __lpwstr = ___lpwstr;\n\nvar ___lpp4 = function lpp4_(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf16le(b, i+4,i+4+len) : \"\";};\nvar __lpp4 = ___lpp4;\n\nvar ___8lpp4 = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? __utf8(b, i+4,i+4+len) : \"\";};\nvar __8lpp4 = ___8lpp4;\n\nvar ___double = function(b/*:RawBytes|CFBlob*/, idx/*:number*/) { return read_double_le(b, idx);};\nvar __double = ___double;\n\nvar is_buf = function is_buf_a(a) { return Array.isArray(a) || (typeof Uint8Array !== \"undefined\" && a instanceof Uint8Array); };\n\nif(has_buf/*:: && typeof Buffer !== 'undefined'*/) {\n\t__lpstr = function lpstr_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___lpstr(b, i); var len = b.readUInt32LE(i); return len > 0 ? b.toString('utf8',i+4,i+4+len-1) : \"\";};\n\t__cpstr = function cpstr_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___cpstr(b, i); var len = b.readUInt32LE(i); return len > 0 ? b.toString('utf8',i+4,i+4+len-1) : \"\";};\n\t__lpwstr = function lpwstr_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___lpwstr(b, i); var len = 2*b.readUInt32LE(i); return b.toString('utf16le',i+4,i+4+len-1);};\n\t__lpp4 = function lpp4_b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___lpp4(b, i); var len = b.readUInt32LE(i); return b.toString('utf16le',i+4,i+4+len);};\n\t__8lpp4 = function lpp4_8b(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(!Buffer.isBuffer(b)/*:: || !(b instanceof Buffer)*/) return ___8lpp4(b, i); var len = b.readUInt32LE(i); return b.toString('utf8',i+4,i+4+len);};\n\t__double = function double_(b/*:RawBytes|CFBlob*/, i/*:number*/) { if(Buffer.isBuffer(b)/*::&& b instanceof Buffer*/) return b.readDoubleLE(i); return ___double(b,i); };\n\tis_buf = function is_buf_b(a) { return Buffer.isBuffer(a) || Array.isArray(a) || (typeof Uint8Array !== \"undefined\" && a instanceof Uint8Array); };\n}\n\n/* from js-xls */\nfunction cpdoit() {\n\t__utf16le = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/) { return $cptable.utils.decode(1200, b.slice(s,e)).replace(chr0, ''); };\n\t__utf8 = function(b/*:RawBytes|CFBlob*/,s/*:number*/,e/*:number*/) { return $cptable.utils.decode(65001, b.slice(s,e)); };\n\t__lpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(current_ansi, b.slice(i+4, i+4+len-1)) : \"\";};\n\t__cpstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(current_codepage, b.slice(i+4, i+4+len-1)) : \"\";};\n\t__lpwstr = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = 2*__readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(1200, b.slice(i+4,i+4+len-1)) : \"\";};\n\t__lpp4 = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(1200, b.slice(i+4,i+4+len)) : \"\";};\n\t__8lpp4 = function(b/*:RawBytes|CFBlob*/,i/*:number*/) { var len = __readUInt32LE(b,i); return len > 0 ? $cptable.utils.decode(65001, b.slice(i+4,i+4+len)) : \"\";};\n}\nif(typeof $cptable !== 'undefined') cpdoit();\n\nvar __readUInt8 = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return b[idx]; };\nvar __readUInt16LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return (b[idx+1]*(1<<8))+b[idx]; };\nvar __readInt16LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { var u = (b[idx+1]*(1<<8))+b[idx]; return (u < 0x8000) ? u : ((0xffff - u + 1) * -1); };\nvar __readUInt32LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return b[idx+3]*(1<<24)+(b[idx+2]<<16)+(b[idx+1]<<8)+b[idx]; };\nvar __readInt32LE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return (b[idx+3]<<24)|(b[idx+2]<<16)|(b[idx+1]<<8)|b[idx]; };\nvar __readInt32BE = function(b/*:RawBytes|CFBlob*/, idx/*:number*/)/*:number*/ { return (b[idx]<<24)|(b[idx+1]<<16)|(b[idx+2]<<8)|b[idx+3]; };\n\nfunction ReadShift(size/*:number*/, t/*:?string*/)/*:number|string*/ {\n\tvar o=\"\", oI/*:: :number = 0*/, oR, oo=[], w, vv, i, loc;\n\tswitch(t) {\n\t\tcase 'dbcs':\n\t\t\tloc = this.l;\n\t\t\tif(has_buf && Buffer.isBuffer(this)) o = this.slice(this.l, this.l+2*size).toString(\"utf16le\");\n\t\t\telse for(i = 0; i < size; ++i) { o+=String.fromCharCode(__readUInt16LE(this, loc)); loc+=2; }\n\t\t\tsize *= 2;\n\t\t\tbreak;\n\n\t\tcase 'utf8': o = __utf8(this, this.l, this.l + size); break;\n\t\tcase 'utf16le': size *= 2; o = __utf16le(this, this.l, this.l + size); break;\n\n\t\tcase 'wstr':\n\t\t\tif(typeof $cptable !== 'undefined') o = $cptable.utils.decode(current_codepage, this.slice(this.l, this.l+2*size));\n\t\t\telse return ReadShift.call(this, size, 'dbcs');\n\t\t\tsize = 2 * size; break;\n\n\t\t/* [MS-OLEDS] 2.1.4 LengthPrefixedAnsiString */\n\t\tcase 'lpstr-ansi': o = __lpstr(this, this.l); size = 4 + __readUInt32LE(this, this.l); break;\n\t\tcase 'lpstr-cp': o = __cpstr(this, this.l); size = 4 + __readUInt32LE(this, this.l); break;\n\t\t/* [MS-OLEDS] 2.1.5 LengthPrefixedUnicodeString */\n\t\tcase 'lpwstr': o = __lpwstr(this, this.l); size = 4 + 2 * __readUInt32LE(this, this.l); break;\n\t\t/* [MS-OFFCRYPTO] 2.1.2 Length-Prefixed Padded Unicode String (UNICODE-LP-P4) */\n\t\tcase 'lpp4': size = 4 +  __readUInt32LE(this, this.l); o = __lpp4(this, this.l); if(size & 0x02) size += 2; break;\n\t\t/* [MS-OFFCRYPTO] 2.1.3 Length-Prefixed UTF-8 String (UTF-8-LP-P4) */\n\t\tcase '8lpp4': size = 4 +  __readUInt32LE(this, this.l); o = __8lpp4(this, this.l); if(size & 0x03) size += 4 - (size & 0x03); break;\n\n\t\tcase 'cstr': size = 0; o = \"\";\n\t\t\twhile((w=__readUInt8(this, this.l + size++))!==0) oo.push(_getchar(w));\n\t\t\to = oo.join(\"\"); break;\n\t\tcase '_wstr': size = 0; o = \"\";\n\t\t\twhile((w=__readUInt16LE(this,this.l +size))!==0){oo.push(_getchar(w));size+=2;}\n\t\t\tsize+=2; o = oo.join(\"\"); break;\n\n\t\t/* sbcs and dbcs support continue records in the SST way TODO codepages */\n\t\tcase 'dbcs-cont': o = \"\"; loc = this.l;\n\t\t\tfor(i = 0; i < size; ++i) {\n\t\t\t\tif(this.lens && this.lens.indexOf(loc) !== -1) {\n\t\t\t\t\tw = __readUInt8(this, loc);\n\t\t\t\t\tthis.l = loc + 1;\n\t\t\t\t\tvv = ReadShift.call(this, size-i, w ? 'dbcs-cont' : 'sbcs-cont');\n\t\t\t\t\treturn oo.join(\"\") + vv;\n\t\t\t\t}\n\t\t\t\too.push(_getchar(__readUInt16LE(this, loc)));\n\t\t\t\tloc+=2;\n\t\t\t} o = oo.join(\"\"); size *= 2; break;\n\n\t\tcase 'cpstr':\n\t\t\tif(typeof $cptable !== 'undefined') {\n\t\t\t\to = $cptable.utils.decode(current_codepage, this.slice(this.l, this.l + size));\n\t\t\t\tbreak;\n\t\t\t}\n\t\t/* falls through */\n\t\tcase 'sbcs-cont': o = \"\"; loc = this.l;\n\t\t\tfor(i = 0; i != size; ++i) {\n\t\t\t\tif(this.lens && this.lens.indexOf(loc) !== -1) {\n\t\t\t\t\tw = __readUInt8(this, loc);\n\t\t\t\t\tthis.l = loc + 1;\n\t\t\t\t\tvv = ReadShift.call(this, size-i, w ? 'dbcs-cont' : 'sbcs-cont');\n\t\t\t\t\treturn oo.join(\"\") + vv;\n\t\t\t\t}\n\t\t\t\too.push(_getchar(__readUInt8(this, loc)));\n\t\t\t\tloc+=1;\n\t\t\t} o = oo.join(\"\"); break;\n\n\t\tdefault:\n\tswitch(size) {\n\t\tcase 1: oI = __readUInt8(this, this.l); this.l++; return oI;\n\t\tcase 2: oI = (t === 'i' ? __readInt16LE : __readUInt16LE)(this, this.l); this.l += 2; return oI;\n\t\tcase 4: case -4:\n\t\t\tif(t === 'i' || ((this[this.l+3] & 0x80)===0)) { oI = ((size > 0) ? __readInt32LE : __readInt32BE)(this, this.l); this.l += 4; return oI; }\n\t\t\telse { oR = __readUInt32LE(this, this.l); this.l += 4; } return oR;\n\t\tcase 8: case -8:\n\t\t\tif(t === 'f') {\n\t\t\t\tif(size == 8) oR = __double(this, this.l);\n\t\t\t\telse oR = __double([this[this.l+7],this[this.l+6],this[this.l+5],this[this.l+4],this[this.l+3],this[this.l+2],this[this.l+1],this[this.l+0]], 0);\n\t\t\t\tthis.l += 8; return oR;\n\t\t\t} else size = 8;\n\t\t/* falls through */\n\t\tcase 16: o = __hexlify(this, this.l, size); break;\n\t}}\n\tthis.l+=size; return o;\n}\n\nvar __writeUInt32LE = function(b/*:RawBytes|CFBlob*/, val/*:number*/, idx/*:number*/)/*:void*/ { b[idx] = (val & 0xFF); b[idx+1] = ((val >>> 8) & 0xFF); b[idx+2] = ((val >>> 16) & 0xFF); b[idx+3] = ((val >>> 24) & 0xFF); };\nvar __writeInt32LE  = function(b/*:RawBytes|CFBlob*/, val/*:number*/, idx/*:number*/)/*:void*/ { b[idx] = (val & 0xFF); b[idx+1] = ((val >> 8) & 0xFF); b[idx+2] = ((val >> 16) & 0xFF); b[idx+3] = ((val >> 24) & 0xFF); };\nvar __writeUInt16LE = function(b/*:RawBytes|CFBlob*/, val/*:number*/, idx/*:number*/)/*:void*/ { b[idx] = (val & 0xFF); b[idx+1] = ((val >>> 8) & 0xFF); };\n\nfunction WriteShift(t/*:number*/, val/*:string|number*/, f/*:?string*/)/*:any*/ {\n\tvar size = 0, i = 0;\n\tif(f === 'dbcs') {\n\t\t/*:: if(typeof val !== 'string') throw new Error(\"unreachable\"); */\n\t\tfor(i = 0; i != val.length; ++i) __writeUInt16LE(this, val.charCodeAt(i), this.l + 2 * i);\n\t\tsize = 2 * val.length;\n\t} else if(f === 'sbcs') {\n\t\tif(typeof $cptable !== 'undefined' && current_ansi == 874) {\n\t\t\t/* TODO: use tables directly, don't encode */\n\t\t\t/*:: if(typeof val !== \"string\") throw new Error(\"unreachable\"); */\n\t\t\tfor(i = 0; i != val.length; ++i) {\n\t\t\t\tvar cppayload = $cptable.utils.encode(current_ansi, val.charAt(i));\n\t\t\t\tthis[this.l + i] = cppayload[0];\n\t\t\t}\n\t\t} else {\n\t\t\t/*:: if(typeof val !== 'string') throw new Error(\"unreachable\"); */\n\t\t\tval = val.replace(/[^\\x00-\\x7F]/g, \"_\");\n\t\t\t/*:: if(typeof val !== 'string') throw new Error(\"unreachable\"); */\n\t\t\tfor(i = 0; i != val.length; ++i) this[this.l + i] = (val.charCodeAt(i) & 0xFF);\n\t\t}\n\t\tsize = val.length;\n\t} else if(f === 'hex') {\n\t\tfor(; i < t; ++i) {\n\t\t\t/*:: if(typeof val !== \"string\") throw new Error(\"unreachable\"); */\n\t\t\tthis[this.l++] = (parseInt(val.slice(2*i, 2*i+2), 16)||0);\n\t\t} return this;\n\t} else if(f === 'utf16le') {\n\t\t\t/*:: if(typeof val !== \"string\") throw new Error(\"unreachable\"); */\n\t\t\tvar end/*:number*/ = Math.min(this.l + t, this.length);\n\t\t\tfor(i = 0; i < Math.min(val.length, t); ++i) {\n\t\t\t\tvar cc = val.charCodeAt(i);\n\t\t\t\tthis[this.l++] = (cc & 0xff);\n\t\t\t\tthis[this.l++] = (cc >> 8);\n\t\t\t}\n\t\t\twhile(this.l < end) this[this.l++] = 0;\n\t\t\treturn this;\n\t} else /*:: if(typeof val === 'number') */ switch(t) {\n\t\tcase  1: size = 1; this[this.l] = val&0xFF; break;\n\t\tcase  2: size = 2; this[this.l] = val&0xFF; val >>>= 8; this[this.l+1] = val&0xFF; break;\n\t\tcase  3: size = 3; this[this.l] = val&0xFF; val >>>= 8; this[this.l+1] = val&0xFF; val >>>= 8; this[this.l+2] = val&0xFF; break;\n\t\tcase  4: size = 4; __writeUInt32LE(this, val, this.l); break;\n\t\tcase  8: size = 8; if(f === 'f') { write_double_le(this, val, this.l); break; }\n\t\t/* falls through */\n\t\tcase 16: break;\n\t\tcase -4: size = 4; __writeInt32LE(this, val, this.l); break;\n\t}\n\tthis.l += size; return this;\n}\n\nfunction CheckField(hexstr/*:string*/, fld/*:string*/)/*:void*/ {\n\tvar m = __hexlify(this,this.l,hexstr.length>>1);\n\tif(m !== hexstr) throw new Error(fld + 'Expected ' + hexstr + ' saw ' + m);\n\tthis.l += hexstr.length>>1;\n}\n\nfunction prep_blob(blob, pos/*:number*/)/*:void*/ {\n\tblob.l = pos;\n\tblob.read_shift = /*::(*/ReadShift/*:: :any)*/;\n\tblob.chk = CheckField;\n\tblob.write_shift = WriteShift;\n}\n\nfunction parsenoop(blob, length/*:: :number, opts?:any */) { blob.l += length; }\n\nfunction new_buf(sz/*:number*/)/*:Block*/ {\n\tvar o = new_raw_buf(sz);\n\tprep_blob(o, 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.1.4 Record */\nfunction recordhopper(data, cb/*:RecordHopperCB*/, opts/*:?any*/) {\n\tif(!data) return;\n\tvar tmpbyte, cntbyte, length;\n\tprep_blob(data, data.l || 0);\n\tvar L = data.length, RT = 0, tgt = 0;\n\twhile(data.l < L) {\n\t\tRT = data.read_shift(1);\n\t\tif(RT & 0x80) RT = (RT & 0x7F) + ((data.read_shift(1) & 0x7F)<<7);\n\t\tvar R = XLSBRecordEnum[RT] || XLSBRecordEnum[0xFFFF];\n\t\ttmpbyte = data.read_shift(1);\n\t\tlength = tmpbyte & 0x7F;\n\t\tfor(cntbyte = 1; cntbyte <4 && (tmpbyte & 0x80); ++cntbyte) length += ((tmpbyte = data.read_shift(1)) & 0x7F)<<(7*cntbyte);\n\t\ttgt = data.l + length;\n\t\tvar d = R.f && R.f(data, length, opts);\n\t\tdata.l = tgt;\n\t\tif(cb(d, R, RT)) return;\n\t}\n}\n\n/* control buffer usage for fixed-length buffers */\nfunction buf_array()/*:BufArray*/ {\n\tvar bufs/*:Array<Block>*/ = [], blksz = has_buf ? 256 : 2048;\n\tvar newblk = function ba_newblk(sz/*:number*/)/*:Block*/ {\n\t\tvar o/*:Block*/ = (new_buf(sz)/*:any*/);\n\t\tprep_blob(o, 0);\n\t\treturn o;\n\t};\n\n\tvar curbuf/*:Block*/ = newblk(blksz);\n\n\tvar endbuf = function ba_endbuf() {\n\t\tif(!curbuf) return;\n\t\tif(curbuf.length > curbuf.l) { curbuf = curbuf.slice(0, curbuf.l); curbuf.l = curbuf.length; }\n\t\tif(curbuf.length > 0) bufs.push(curbuf);\n\t\tcurbuf = null;\n\t};\n\n\tvar next = function ba_next(sz/*:number*/)/*:Block*/ {\n\t\tif(curbuf && (sz < (curbuf.length - curbuf.l))) return curbuf;\n\t\tendbuf();\n\t\treturn (curbuf = newblk(Math.max(sz+1, blksz)));\n\t};\n\n\tvar end = function ba_end() {\n\t\tendbuf();\n\t\treturn bconcat(bufs);\n\t};\n\n\tvar push = function ba_push(buf) { endbuf(); curbuf = buf; if(curbuf.l == null) curbuf.l = curbuf.length; next(blksz); };\n\n\treturn ({ next:next, push:push, end:end, _bufs:bufs }/*:any*/);\n}\n\nfunction write_record(ba/*:BufArray*/, type/*:number*/, payload, length/*:?number*/) {\n\tvar t/*:number*/ = +type, l;\n\tif(isNaN(t)) return; // TODO: throw something here?\n\tif(!length) length = XLSBRecordEnum[t].p || (payload||[]).length || 0;\n\tl = 1 + (t >= 0x80 ? 1 : 0) + 1/* + length*/;\n\tif(length >= 0x80) ++l; if(length >= 0x4000) ++l; if(length >= 0x200000) ++l;\n\tvar o = ba.next(l);\n\tif(t <= 0x7F) o.write_shift(1, t);\n\telse {\n\t\to.write_shift(1, (t & 0x7F) + 0x80);\n\t\to.write_shift(1, (t >> 7));\n\t}\n\tfor(var i = 0; i != 4; ++i) {\n\t\tif(length >= 0x80) { o.write_shift(1, (length & 0x7F)+0x80); length >>= 7; }\n\t\telse { o.write_shift(1, length); break; }\n\t}\n\tif(/*:: length != null &&*/length > 0 && is_buf(payload)) ba.push(payload);\n}\n/* XLS ranges enforced */\nfunction shift_cell_xls(cell/*:CellAddress*/, tgt/*:any*/, opts/*:?any*/)/*:CellAddress*/ {\n\tvar out = dup(cell);\n\tif(tgt.s) {\n\t\tif(out.cRel) out.c += tgt.s.c;\n\t\tif(out.rRel) out.r += tgt.s.r;\n\t} else {\n\t\tif(out.cRel) out.c += tgt.c;\n\t\tif(out.rRel) out.r += tgt.r;\n\t}\n\tif(!opts || opts.biff < 12) {\n\t\twhile(out.c >= 0x100) out.c -= 0x100;\n\t\twhile(out.r >= 0x10000) out.r -= 0x10000;\n\t}\n\treturn out;\n}\n\nfunction shift_range_xls(cell, range, opts) {\n\tvar out = dup(cell);\n\tout.s = shift_cell_xls(out.s, range.s, opts);\n\tout.e = shift_cell_xls(out.e, range.s, opts);\n\treturn out;\n}\n\nfunction encode_cell_xls(c/*:CellAddress*/, biff/*:number*/)/*:string*/ {\n\tif(c.cRel && c.c < 0) { c = dup(c); while(c.c < 0) c.c += (biff > 8) ? 0x4000 : 0x100; }\n\tif(c.rRel && c.r < 0) { c = dup(c); while(c.r < 0) c.r += (biff > 8) ? 0x100000 : ((biff > 5) ? 0x10000 : 0x4000); }\n\tvar s = encode_cell(c);\n\tif(!c.cRel && c.cRel != null) s = fix_col(s);\n\tif(!c.rRel && c.rRel != null) s = fix_row(s);\n\treturn s;\n}\n\nfunction encode_range_xls(r, opts)/*:string*/ {\n\tif(r.s.r == 0 && !r.s.rRel) {\n\t\tif(r.e.r == (opts.biff >= 12 ? 0xFFFFF : (opts.biff >= 8 ? 0x10000 : 0x4000)) && !r.e.rRel) {\n\t\t\treturn (r.s.cRel ? \"\" : \"$\") + encode_col(r.s.c) + \":\" + (r.e.cRel ? \"\" : \"$\") + encode_col(r.e.c);\n\t\t}\n\t}\n\tif(r.s.c == 0 && !r.s.cRel) {\n\t\tif(r.e.c == (opts.biff >= 12 ? 0x3FFF : 0xFF) && !r.e.cRel) {\n\t\t\treturn (r.s.rRel ? \"\" : \"$\") + encode_row(r.s.r) + \":\" + (r.e.rRel ? \"\" : \"$\") + encode_row(r.e.r);\n\t\t}\n\t}\n\treturn encode_cell_xls(r.s, opts.biff) + \":\" + encode_cell_xls(r.e, opts.biff);\n}\nfunction decode_row(rowstr/*:string*/)/*:number*/ { return parseInt(unfix_row(rowstr),10) - 1; }\nfunction encode_row(row/*:number*/)/*:string*/ { return \"\" + (row + 1); }\nfunction fix_row(cstr/*:string*/)/*:string*/ { return cstr.replace(/([A-Z]|^)(\\d+)$/,\"$1$$$2\"); }\nfunction unfix_row(cstr/*:string*/)/*:string*/ { return cstr.replace(/\\$(\\d+)$/,\"$1\"); }\n\nfunction decode_col(colstr/*:string*/)/*:number*/ { var c = unfix_col(colstr), d = 0, i = 0; for(; i !== c.length; ++i) d = 26*d + c.charCodeAt(i) - 64; return d - 1; }\nfunction encode_col(col/*:number*/)/*:string*/ { if(col < 0) throw new Error(\"invalid column \" + col); var s=\"\"; for(++col; col; col=Math.floor((col-1)/26)) s = String.fromCharCode(((col-1)%26) + 65) + s; return s; }\nfunction fix_col(cstr/*:string*/)/*:string*/ { return cstr.replace(/^([A-Z])/,\"$$$1\"); }\nfunction unfix_col(cstr/*:string*/)/*:string*/ { return cstr.replace(/^\\$([A-Z])/,\"$1\"); }\n\nfunction split_cell(cstr/*:string*/)/*:Array<string>*/ { return cstr.replace(/(\\$?[A-Z]*)(\\$?\\d*)/,\"$1,$2\").split(\",\"); }\n//function decode_cell(cstr/*:string*/)/*:CellAddress*/ { var splt = split_cell(cstr); return { c:decode_col(splt[0]), r:decode_row(splt[1]) }; }\nfunction decode_cell(cstr/*:string*/)/*:CellAddress*/ {\n\tvar R = 0, C = 0;\n\tfor(var i = 0; i < cstr.length; ++i) {\n\t\tvar cc = cstr.charCodeAt(i);\n\t\tif(cc >= 48 && cc <= 57) R = 10 * R + (cc - 48);\n\t\telse if(cc >= 65 && cc <= 90) C = 26 * C + (cc - 64);\n\t}\n\treturn { c: C - 1, r:R - 1 };\n}\n//function encode_cell(cell/*:CellAddress*/)/*:string*/ { return encode_col(cell.c) + encode_row(cell.r); }\nfunction encode_cell(cell/*:CellAddress*/)/*:string*/ {\n\tvar col = cell.c + 1;\n\tvar s=\"\";\n\tfor(; col; col=((col-1)/26)|0) s = String.fromCharCode(((col-1)%26) + 65) + s;\n\treturn s + (cell.r + 1);\n}\nfunction decode_range(range/*:string*/)/*:Range*/ {\n\tvar idx = range.indexOf(\":\");\n\tif(idx == -1) return { s: decode_cell(range), e: decode_cell(range) };\n\treturn { s: decode_cell(range.slice(0, idx)), e: decode_cell(range.slice(idx + 1)) };\n}\n/*# if only one arg, it is assumed to be a Range.  If 2 args, both are cell addresses */\nfunction encode_range(cs/*:CellAddrSpec|Range*/,ce/*:?CellAddrSpec*/)/*:string*/ {\n\tif(typeof ce === 'undefined' || typeof ce === 'number') {\n/*:: if(!(cs instanceof Range)) throw \"unreachable\"; */\n\t\treturn encode_range(cs.s, cs.e);\n\t}\n/*:: if((cs instanceof Range)) throw \"unreachable\"; */\n\tif(typeof cs !== 'string') cs = encode_cell((cs/*:any*/));\n\tif(typeof ce !== 'string') ce = encode_cell((ce/*:any*/));\n/*:: if(typeof cs !== 'string') throw \"unreachable\"; */\n/*:: if(typeof ce !== 'string') throw \"unreachable\"; */\n\treturn cs == ce ? cs : cs + \":\" + ce;\n}\n\nfunction safe_decode_range(range/*:string*/)/*:Range*/ {\n\tvar o = {s:{c:0,r:0},e:{c:0,r:0}};\n\tvar idx = 0, i = 0, cc = 0;\n\tvar len = range.length;\n\tfor(idx = 0; i < len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\tidx = 26*idx + cc;\n\t}\n\to.s.c = --idx;\n\n\tfor(idx = 0; i < len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-48) < 0 || cc > 9) break;\n\t\tidx = 10*idx + cc;\n\t}\n\to.s.r = --idx;\n\n\tif(i === len || cc != 10) { o.e.c=o.s.c; o.e.r=o.s.r; return o; }\n\t++i;\n\n\tfor(idx = 0; i != len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\tidx = 26*idx + cc;\n\t}\n\to.e.c = --idx;\n\n\tfor(idx = 0; i != len; ++i) {\n\t\tif((cc=range.charCodeAt(i)-48) < 0 || cc > 9) break;\n\t\tidx = 10*idx + cc;\n\t}\n\to.e.r = --idx;\n\treturn o;\n}\n\nfunction safe_format_cell(cell/*:Cell*/, v/*:any*/) {\n\tvar q = (cell.t == 'd' && v instanceof Date);\n\tif(cell.z != null) try { return (cell.w = SSF_format(cell.z, q ? datenum(v) : v)); } catch(e) { }\n\ttry { return (cell.w = SSF_format((cell.XF||{}).numFmtId||(q ? 14 : 0),  q ? datenum(v) : v)); } catch(e) { return ''+v; }\n}\n\nfunction format_cell(cell/*:Cell*/, v/*:any*/, o/*:any*/) {\n\tif(cell == null || cell.t == null || cell.t == 'z') return \"\";\n\tif(cell.w !== undefined) return cell.w;\n\tif(cell.t == 'd' && !cell.z && o && o.dateNF) cell.z = o.dateNF;\n\tif(cell.t == \"e\") return BErr[cell.v] || cell.v;\n\tif(v == undefined) return safe_format_cell(cell, cell.v);\n\treturn safe_format_cell(cell, v);\n}\n\nfunction sheet_to_workbook(sheet/*:Worksheet*/, opts)/*:Workbook*/ {\n\tvar n = opts && opts.sheet ? opts.sheet : \"Sheet1\";\n\tvar sheets = {}; sheets[n] = sheet;\n\treturn { SheetNames: [n], Sheets: sheets };\n}\n\nfunction sheet_add_aoa(_ws/*:?Worksheet*/, data/*:AOA*/, opts/*:?any*/)/*:Worksheet*/ {\n\tvar o = opts || {};\n\tvar dense = _ws ? Array.isArray(_ws) : o.dense;\n\tif(DENSE != null && dense == null) dense = DENSE;\n\tvar ws/*:Worksheet*/ = _ws || (dense ? ([]/*:any*/) : ({}/*:any*/));\n\tvar _R = 0, _C = 0;\n\tif(ws && o.origin != null) {\n\t\tif(typeof o.origin == 'number') _R = o.origin;\n\t\telse {\n\t\t\tvar _origin/*:CellAddress*/ = typeof o.origin == \"string\" ? decode_cell(o.origin) : o.origin;\n\t\t\t_R = _origin.r; _C = _origin.c;\n\t\t}\n\t\tif(!ws[\"!ref\"]) ws[\"!ref\"] = \"A1:A1\";\n\t}\n\tvar range/*:Range*/ = ({s: {c:10000000, r:10000000}, e: {c:0, r:0}}/*:any*/);\n\tif(ws['!ref']) {\n\t\tvar _range = safe_decode_range(ws['!ref']);\n\t\trange.s.c = _range.s.c;\n\t\trange.s.r = _range.s.r;\n\t\trange.e.c = Math.max(range.e.c, _range.e.c);\n\t\trange.e.r = Math.max(range.e.r, _range.e.r);\n\t\tif(_R == -1) range.e.r = _R = _range.e.r + 1;\n\t}\n\tfor(var R = 0; R != data.length; ++R) {\n\t\tif(!data[R]) continue;\n\t\tif(!Array.isArray(data[R])) throw new Error(\"aoa_to_sheet expects an array of arrays\");\n\t\tfor(var C = 0; C != data[R].length; ++C) {\n\t\t\tif(typeof data[R][C] === 'undefined') continue;\n\t\t\tvar cell/*:Cell*/ = ({v: data[R][C] }/*:any*/);\n\t\t\tvar __R = _R + R, __C = _C + C;\n\t\t\tif(range.s.r > __R) range.s.r = __R;\n\t\t\tif(range.s.c > __C) range.s.c = __C;\n\t\t\tif(range.e.r < __R) range.e.r = __R;\n\t\t\tif(range.e.c < __C) range.e.c = __C;\n\t\t\tif(data[R][C] && typeof data[R][C] === 'object' && !Array.isArray(data[R][C]) && !(data[R][C] instanceof Date)) cell = data[R][C];\n\t\t\telse {\n\t\t\t\tif(Array.isArray(cell.v)) { cell.f = data[R][C][1]; cell.v = cell.v[0]; }\n\t\t\t\tif(cell.v === null) {\n\t\t\t\t\tif(cell.f) cell.t = 'n';\n\t\t\t\t\telse if(o.nullError) { cell.t = 'e'; cell.v = 0; }\n\t\t\t\t\telse if(!o.sheetStubs) continue;\n\t\t\t\t\telse cell.t = 'z';\n\t\t\t\t}\n\t\t\t\telse if(typeof cell.v === 'number') cell.t = 'n';\n\t\t\t\telse if(typeof cell.v === 'boolean') cell.t = 'b';\n\t\t\t\telse if(cell.v instanceof Date) {\n\t\t\t\t\tcell.z = o.dateNF || table_fmt[14];\n\t\t\t\t\tif(o.cellDates) { cell.t = 'd'; cell.w = SSF_format(cell.z, datenum(cell.v)); }\n\t\t\t\t\telse { cell.t = 'n'; cell.v = datenum(cell.v); cell.w = SSF_format(cell.z, cell.v); }\n\t\t\t\t}\n\t\t\t\telse cell.t = 's';\n\t\t\t}\n\t\t\tif(dense) {\n\t\t\t\tif(!ws[__R]) ws[__R] = [];\n\t\t\t\tif(ws[__R][__C] && ws[__R][__C].z) cell.z = ws[__R][__C].z;\n\t\t\t\tws[__R][__C] = cell;\n\t\t\t} else {\n\t\t\t\tvar cell_ref = encode_cell(({c:__C,r:__R}/*:any*/));\n\t\t\t\tif(ws[cell_ref] && ws[cell_ref].z) cell.z = ws[cell_ref].z;\n\t\t\t\tws[cell_ref] = cell;\n\t\t\t}\n\t\t}\n\t}\n\tif(range.s.c < 10000000) ws['!ref'] = encode_range(range);\n\treturn ws;\n}\nfunction aoa_to_sheet(data/*:AOA*/, opts/*:?any*/)/*:Worksheet*/ { return sheet_add_aoa(null, data, opts); }\n\nfunction parse_Int32LE(data) {\n\treturn data.read_shift(4, 'i');\n}\nfunction write_UInt32LE(x/*:number*/, o) {\n\tif (!o) o = new_buf(4);\n\to.write_shift(4, x);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.168 */\nfunction parse_XLWideString(data/*::, length*/)/*:string*/ {\n\tvar cchCharacters = data.read_shift(4);\n\treturn cchCharacters === 0 ? \"\" : data.read_shift(cchCharacters, 'dbcs');\n}\nfunction write_XLWideString(data/*:string*/, o) {\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(4 + 2 * data.length); }\n\to.write_shift(4, data.length);\n\tif (data.length > 0) o.write_shift(0, data, 'dbcs');\n\treturn _null ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.5.91 */\n//function parse_LPWideString(data/*::, length*/)/*:string*/ {\n//\tvar cchCharacters = data.read_shift(2);\n//\treturn cchCharacters === 0 ? \"\" : data.read_shift(cchCharacters, \"utf16le\");\n//}\n\n/* [MS-XLSB] 2.5.143 */\nfunction parse_StrRun(data) {\n\treturn { ich: data.read_shift(2), ifnt: data.read_shift(2) };\n}\nfunction write_StrRun(run, o) {\n\tif (!o) o = new_buf(4);\n\to.write_shift(2, run.ich || 0);\n\to.write_shift(2, run.ifnt || 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.121 */\nfunction parse_RichStr(data, length/*:number*/)/*:XLString*/ {\n\tvar start = data.l;\n\tvar flags = data.read_shift(1);\n\tvar str = parse_XLWideString(data);\n\tvar rgsStrRun = [];\n\tvar z = ({ t: str, h: str }/*:any*/);\n\tif ((flags & 1) !== 0) { /* fRichStr */\n\t\t/* TODO: formatted string */\n\t\tvar dwSizeStrRun = data.read_shift(4);\n\t\tfor (var i = 0; i != dwSizeStrRun; ++i) rgsStrRun.push(parse_StrRun(data));\n\t\tz.r = rgsStrRun;\n\t}\n\telse z.r = [{ ich: 0, ifnt: 0 }];\n\t//if((flags & 2) !== 0) { /* fExtStr */\n\t//\t/* TODO: phonetic string */\n\t//}\n\tdata.l = start + length;\n\treturn z;\n}\nfunction write_RichStr(str/*:XLString*/, o/*:?Block*/)/*:Block*/ {\n\t/* TODO: formatted string */\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(15 + 4 * str.t.length); }\n\to.write_shift(1, 0);\n\twrite_XLWideString(str.t, o);\n\treturn _null ? o.slice(0, o.l) : o;\n}\n/* [MS-XLSB] 2.4.328 BrtCommentText (RichStr w/1 run) */\nvar parse_BrtCommentText = parse_RichStr;\nfunction write_BrtCommentText(str/*:XLString*/, o/*:?Block*/)/*:Block*/ {\n\t/* TODO: formatted string */\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(23 + 4 * str.t.length); }\n\to.write_shift(1, 1);\n\twrite_XLWideString(str.t, o);\n\to.write_shift(4, 1);\n\twrite_StrRun({ ich: 0, ifnt: 0 }, o);\n\treturn _null ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.5.9 */\nfunction parse_XLSBCell(data)/*:any*/ {\n\tvar col = data.read_shift(4);\n\tvar iStyleRef = data.read_shift(2);\n\tiStyleRef += data.read_shift(1) << 16;\n\tdata.l++; //var fPhShow = data.read_shift(1);\n\treturn { c: col, iStyleRef: iStyleRef };\n}\nfunction write_XLSBCell(cell/*:any*/, o/*:?Block*/) {\n\tif (o == null) o = new_buf(8);\n\to.write_shift(-4, cell.c);\n\to.write_shift(3, cell.iStyleRef || cell.s);\n\to.write_shift(1, 0); /* fPhShow */\n\treturn o;\n}\n\n/* Short XLSB Cell does not include column */\nfunction parse_XLSBShortCell(data)/*:any*/ {\n\tvar iStyleRef = data.read_shift(2);\n\tiStyleRef += data.read_shift(1) <<16;\n\tdata.l++; //var fPhShow = data.read_shift(1);\n\treturn { c:-1, iStyleRef: iStyleRef };\n}\nfunction write_XLSBShortCell(cell/*:any*/, o/*:?Block*/) {\n\tif(o == null) o = new_buf(4);\n\to.write_shift(3, cell.iStyleRef || cell.s);\n\to.write_shift(1, 0); /* fPhShow */\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.21 */\nvar parse_XLSBCodeName = parse_XLWideString;\nvar write_XLSBCodeName = write_XLWideString;\n\n/* [MS-XLSB] 2.5.166 */\nfunction parse_XLNullableWideString(data/*::, length*/)/*:string*/ {\n\tvar cchCharacters = data.read_shift(4);\n\treturn cchCharacters === 0 || cchCharacters === 0xFFFFFFFF ? \"\" : data.read_shift(cchCharacters, 'dbcs');\n}\nfunction write_XLNullableWideString(data/*:string*/, o) {\n\tvar _null = false; if (o == null) { _null = true; o = new_buf(127); }\n\to.write_shift(4, data.length > 0 ? data.length : 0xFFFFFFFF);\n\tif (data.length > 0) o.write_shift(0, data, 'dbcs');\n\treturn _null ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.5.165 */\nvar parse_XLNameWideString = parse_XLWideString;\n//var write_XLNameWideString = write_XLWideString;\n\n/* [MS-XLSB] 2.5.114 */\nvar parse_RelID = parse_XLNullableWideString;\nvar write_RelID = write_XLNullableWideString;\n\n\n/* [MS-XLS] 2.5.217 ; [MS-XLSB] 2.5.122 */\nfunction parse_RkNumber(data)/*:number*/ {\n\tvar b = data.slice(data.l, data.l + 4);\n\tvar fX100 = (b[0] & 1), fInt = (b[0] & 2);\n\tdata.l += 4;\n\tvar RK = fInt === 0 ? __double([0, 0, 0, 0, (b[0] & 0xFC), b[1], b[2], b[3]], 0) : __readInt32LE(b, 0) >> 2;\n\treturn fX100 ? (RK / 100) : RK;\n}\nfunction write_RkNumber(data/*:number*/, o) {\n\tif (o == null) o = new_buf(4);\n\tvar fX100 = 0, fInt = 0, d100 = data * 100;\n\tif ((data == (data | 0)) && (data >= -(1 << 29)) && (data < (1 << 29))) { fInt = 1; }\n\telse if ((d100 == (d100 | 0)) && (d100 >= -(1 << 29)) && (d100 < (1 << 29))) { fInt = 1; fX100 = 1; }\n\tif (fInt) o.write_shift(-4, ((fX100 ? d100 : data) << 2) + (fX100 + 2));\n\telse throw new Error(\"unsupported RkNumber \" + data); // TODO\n}\n\n\n/* [MS-XLSB] 2.5.117 RfX */\nfunction parse_RfX(data /*::, length*/)/*:Range*/ {\n\tvar cell/*:Range*/ = ({ s: {}, e: {} }/*:any*/);\n\tcell.s.r = data.read_shift(4);\n\tcell.e.r = data.read_shift(4);\n\tcell.s.c = data.read_shift(4);\n\tcell.e.c = data.read_shift(4);\n\treturn cell;\n}\nfunction write_RfX(r/*:Range*/, o) {\n\tif (!o) o = new_buf(16);\n\to.write_shift(4, r.s.r);\n\to.write_shift(4, r.e.r);\n\to.write_shift(4, r.s.c);\n\to.write_shift(4, r.e.c);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.153 UncheckedRfX */\nvar parse_UncheckedRfX = parse_RfX;\nvar write_UncheckedRfX = write_RfX;\n\n/* [MS-XLSB] 2.5.155 UncheckedSqRfX */\n//function parse_UncheckedSqRfX(data) {\n//\tvar cnt = data.read_shift(4);\n//\tvar out = [];\n//\tfor(var i = 0; i < cnt; ++i) {\n//\t\tvar rng = parse_UncheckedRfX(data);\n//\t\tout.push(encode_range(rng));\n//\t}\n//\treturn out.join(\",\");\n//}\n//function write_UncheckedSqRfX(sqrfx/*:string*/) {\n//\tvar parts = sqrfx.split(/\\s*,\\s*/);\n//\tvar o = new_buf(4); o.write_shift(4, parts.length);\n//\tvar out = [o];\n//\tparts.forEach(function(rng) {\n//\t\tout.push(write_UncheckedRfX(safe_decode_range(rng)));\n//\t});\n//\treturn bconcat(out);\n//}\n\n/* [MS-XLS] 2.5.342 ; [MS-XLSB] 2.5.171 */\n/* TODO: error checking, NaN and Infinity values are not valid Xnum */\nfunction parse_Xnum(data/*::, length*/) {\n\tif(data.length - data.l < 8) throw \"XLS Xnum Buffer underflow\";\n\treturn data.read_shift(8, 'f');\n}\nfunction write_Xnum(data, o) { return (o || new_buf(8)).write_shift(8, data, 'f'); }\n\n/* [MS-XLSB] 2.4.324 BrtColor */\nfunction parse_BrtColor(data/*::, length*/) {\n\tvar out = {};\n\tvar d = data.read_shift(1);\n\n\t//var fValidRGB = d & 1;\n\tvar xColorType = d >>> 1;\n\n\tvar index = data.read_shift(1);\n\tvar nTS = data.read_shift(2, 'i');\n\tvar bR = data.read_shift(1);\n\tvar bG = data.read_shift(1);\n\tvar bB = data.read_shift(1);\n\tdata.l++; //var bAlpha = data.read_shift(1);\n\n\tswitch (xColorType) {\n\t\tcase 0: out.auto = 1; break;\n\t\tcase 1:\n\t\t\tout.index = index;\n\t\t\tvar icv = XLSIcv[index];\n\t\t\t/* automatic pseudo index 81 */\n\t\t\tif (icv) out.rgb = rgb2Hex(icv);\n\t\t\tbreak;\n\t\tcase 2:\n\t\t\t/* if(!fValidRGB) throw new Error(\"invalid\"); */\n\t\t\tout.rgb = rgb2Hex([bR, bG, bB]);\n\t\t\tbreak;\n\t\tcase 3: out.theme = index; break;\n\t}\n\tif (nTS != 0) out.tint = nTS > 0 ? nTS / 32767 : nTS / 32768;\n\n\treturn out;\n}\nfunction write_BrtColor(color, o) {\n\tif (!o) o = new_buf(8);\n\tif (!color || color.auto) { o.write_shift(4, 0); o.write_shift(4, 0); return o; }\n\tif (color.index != null) {\n\t\to.write_shift(1, 0x02);\n\t\to.write_shift(1, color.index);\n\t} else if (color.theme != null) {\n\t\to.write_shift(1, 0x06);\n\t\to.write_shift(1, color.theme);\n\t} else {\n\t\to.write_shift(1, 0x05);\n\t\to.write_shift(1, 0);\n\t}\n\tvar nTS = color.tint || 0;\n\tif (nTS > 0) nTS *= 32767;\n\telse if (nTS < 0) nTS *= 32768;\n\to.write_shift(2, nTS);\n\tif (!color.rgb || color.theme != null) {\n\t\to.write_shift(2, 0);\n\t\to.write_shift(1, 0);\n\t\to.write_shift(1, 0);\n\t} else {\n\t\tvar rgb = (color.rgb || 'FFFFFF');\n\t\tif (typeof rgb == 'number') rgb = (\"000000\" + rgb.toString(16)).slice(-6);\n\t\to.write_shift(1, parseInt(rgb.slice(0, 2), 16));\n\t\to.write_shift(1, parseInt(rgb.slice(2, 4), 16));\n\t\to.write_shift(1, parseInt(rgb.slice(4, 6), 16));\n\t\to.write_shift(1, 0xFF);\n\t}\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.52 */\nfunction parse_FontFlags(data/*::, length, opts*/) {\n\tvar d = data.read_shift(1);\n\tdata.l++;\n\tvar out = {\n\t\tfBold: d & 0x01,\n\t\tfItalic: d & 0x02,\n\t\tfUnderline: d & 0x04,\n\t\tfStrikeout: d & 0x08,\n\t\tfOutline: d & 0x10,\n\t\tfShadow: d & 0x20,\n\t\tfCondense: d & 0x40,\n\t\tfExtend: d & 0x80\n\t};\n\treturn out;\n}\nfunction write_FontFlags(font, o) {\n\tif (!o) o = new_buf(2);\n\tvar grbit =\n\t\t(font.italic ? 0x02 : 0) |\n\t\t(font.strike ? 0x08 : 0) |\n\t\t(font.outline ? 0x10 : 0) |\n\t\t(font.shadow ? 0x20 : 0) |\n\t\t(font.condense ? 0x40 : 0) |\n\t\t(font.extend ? 0x80 : 0);\n\to.write_shift(1, grbit);\n\to.write_shift(1, 0);\n\treturn o;\n}\n\n/* [MS-OLEDS] 2.3.1 and 2.3.2 */\nfunction parse_ClipboardFormatOrString(o, w/*:number*/)/*:string*/ {\n\t// $FlowIgnore\n\tvar ClipFmt = { 2: \"BITMAP\", 3: \"METAFILEPICT\", 8: \"DIB\", 14: \"ENHMETAFILE\" };\n\tvar m/*:number*/ = o.read_shift(4);\n\tswitch (m) {\n\t\tcase 0x00000000: return \"\";\n\t\tcase 0xffffffff: case 0xfffffffe: return ClipFmt[o.read_shift(4)] || \"\";\n\t}\n\tif (m > 0x190) throw new Error(\"Unsupported Clipboard: \" + m.toString(16));\n\to.l -= 4;\n\treturn o.read_shift(0, w == 1 ? \"lpstr\" : \"lpwstr\");\n}\nfunction parse_ClipboardFormatOrAnsiString(o) { return parse_ClipboardFormatOrString(o, 1); }\nfunction parse_ClipboardFormatOrUnicodeString(o) { return parse_ClipboardFormatOrString(o, 2); }\n\n/* [MS-OLEPS] 2.2 PropertyType */\n// Note: some tree shakers cannot handle VT_VECTOR | $CONST, hence extra vars\n//var VT_EMPTY    = 0x0000;\n//var VT_NULL     = 0x0001;\nvar VT_I2       = 0x0002;\nvar VT_I4       = 0x0003;\n//var VT_R4       = 0x0004;\n//var VT_R8       = 0x0005;\n//var VT_CY       = 0x0006;\n//var VT_DATE     = 0x0007;\n//var VT_BSTR     = 0x0008;\n//var VT_ERROR    = 0x000A;\nvar VT_BOOL     = 0x000B;\nvar VT_VARIANT  = 0x000C;\n//var VT_DECIMAL  = 0x000E;\n//var VT_I1       = 0x0010;\n//var VT_UI1      = 0x0011;\n//var VT_UI2      = 0x0012;\nvar VT_UI4      = 0x0013;\n//var VT_I8       = 0x0014;\n//var VT_UI8      = 0x0015;\n//var VT_INT      = 0x0016;\n//var VT_UINT     = 0x0017;\nvar VT_LPSTR    = 0x001E;\n//var VT_LPWSTR   = 0x001F;\nvar VT_FILETIME = 0x0040;\nvar VT_BLOB     = 0x0041;\n//var VT_STREAM   = 0x0042;\n//var VT_STORAGE  = 0x0043;\n//var VT_STREAMED_Object  = 0x0044;\n//var VT_STORED_Object    = 0x0045;\n//var VT_BLOB_Object      = 0x0046;\nvar VT_CF       = 0x0047;\n//var VT_CLSID    = 0x0048;\n//var VT_VERSIONED_STREAM = 0x0049;\nvar VT_VECTOR   = 0x1000;\nvar VT_VECTOR_VARIANT = 0x100C;\nvar VT_VECTOR_LPSTR   = 0x101E;\n//var VT_ARRAY    = 0x2000;\n\nvar VT_STRING   = 0x0050; // 2.3.3.1.11 VtString\nvar VT_USTR     = 0x0051; // 2.3.3.1.12 VtUnalignedString\nvar VT_CUSTOM   = [VT_STRING, VT_USTR];\n\n/* [MS-OSHARED] 2.3.3.2.2.1 Document Summary Information PIDDSI */\nvar DocSummaryPIDDSI = {\n\t/*::[*/0x01/*::]*/: { n: 'CodePage', t: VT_I2 },\n\t/*::[*/0x02/*::]*/: { n: 'Category', t: VT_STRING },\n\t/*::[*/0x03/*::]*/: { n: 'PresentationFormat', t: VT_STRING },\n\t/*::[*/0x04/*::]*/: { n: 'ByteCount', t: VT_I4 },\n\t/*::[*/0x05/*::]*/: { n: 'LineCount', t: VT_I4 },\n\t/*::[*/0x06/*::]*/: { n: 'ParagraphCount', t: VT_I4 },\n\t/*::[*/0x07/*::]*/: { n: 'SlideCount', t: VT_I4 },\n\t/*::[*/0x08/*::]*/: { n: 'NoteCount', t: VT_I4 },\n\t/*::[*/0x09/*::]*/: { n: 'HiddenCount', t: VT_I4 },\n\t/*::[*/0x0a/*::]*/: { n: 'MultimediaClipCount', t: VT_I4 },\n\t/*::[*/0x0b/*::]*/: { n: 'ScaleCrop', t: VT_BOOL },\n\t/*::[*/0x0c/*::]*/: { n: 'HeadingPairs', t: VT_VECTOR_VARIANT /* VT_VECTOR | VT_VARIANT */ },\n\t/*::[*/0x0d/*::]*/: { n: 'TitlesOfParts', t: VT_VECTOR_LPSTR /* VT_VECTOR | VT_LPSTR */ },\n\t/*::[*/0x0e/*::]*/: { n: 'Manager', t: VT_STRING },\n\t/*::[*/0x0f/*::]*/: { n: 'Company', t: VT_STRING },\n\t/*::[*/0x10/*::]*/: { n: 'LinksUpToDate', t: VT_BOOL },\n\t/*::[*/0x11/*::]*/: { n: 'CharacterCount', t: VT_I4 },\n\t/*::[*/0x13/*::]*/: { n: 'SharedDoc', t: VT_BOOL },\n\t/*::[*/0x16/*::]*/: { n: 'HyperlinksChanged', t: VT_BOOL },\n\t/*::[*/0x17/*::]*/: { n: 'AppVersion', t: VT_I4, p: 'version' },\n\t/*::[*/0x18/*::]*/: { n: 'DigSig', t: VT_BLOB },\n\t/*::[*/0x1A/*::]*/: { n: 'ContentType', t: VT_STRING },\n\t/*::[*/0x1B/*::]*/: { n: 'ContentStatus', t: VT_STRING },\n\t/*::[*/0x1C/*::]*/: { n: 'Language', t: VT_STRING },\n\t/*::[*/0x1D/*::]*/: { n: 'Version', t: VT_STRING },\n\t/*::[*/0xFF/*::]*/: {},\n\t/* [MS-OLEPS] 2.18 */\n\t/*::[*/0x80000000/*::]*/: { n: 'Locale', t: VT_UI4 },\n\t/*::[*/0x80000003/*::]*/: { n: 'Behavior', t: VT_UI4 },\n\t/*::[*/0x72627262/*::]*/: {}\n};\n\n/* [MS-OSHARED] 2.3.3.2.1.1 Summary Information Property Set PIDSI */\nvar SummaryPIDSI = {\n\t/*::[*/0x01/*::]*/: { n: 'CodePage', t: VT_I2 },\n\t/*::[*/0x02/*::]*/: { n: 'Title', t: VT_STRING },\n\t/*::[*/0x03/*::]*/: { n: 'Subject', t: VT_STRING },\n\t/*::[*/0x04/*::]*/: { n: 'Author', t: VT_STRING },\n\t/*::[*/0x05/*::]*/: { n: 'Keywords', t: VT_STRING },\n\t/*::[*/0x06/*::]*/: { n: 'Comments', t: VT_STRING },\n\t/*::[*/0x07/*::]*/: { n: 'Template', t: VT_STRING },\n\t/*::[*/0x08/*::]*/: { n: 'LastAuthor', t: VT_STRING },\n\t/*::[*/0x09/*::]*/: { n: 'RevNumber', t: VT_STRING },\n\t/*::[*/0x0A/*::]*/: { n: 'EditTime', t: VT_FILETIME },\n\t/*::[*/0x0B/*::]*/: { n: 'LastPrinted', t: VT_FILETIME },\n\t/*::[*/0x0C/*::]*/: { n: 'CreatedDate', t: VT_FILETIME },\n\t/*::[*/0x0D/*::]*/: { n: 'ModifiedDate', t: VT_FILETIME },\n\t/*::[*/0x0E/*::]*/: { n: 'PageCount', t: VT_I4 },\n\t/*::[*/0x0F/*::]*/: { n: 'WordCount', t: VT_I4 },\n\t/*::[*/0x10/*::]*/: { n: 'CharCount', t: VT_I4 },\n\t/*::[*/0x11/*::]*/: { n: 'Thumbnail', t: VT_CF },\n\t/*::[*/0x12/*::]*/: { n: 'Application', t: VT_STRING },\n\t/*::[*/0x13/*::]*/: { n: 'DocSecurity', t: VT_I4 },\n\t/*::[*/0xFF/*::]*/: {},\n\t/* [MS-OLEPS] 2.18 */\n\t/*::[*/0x80000000/*::]*/: { n: 'Locale', t: VT_UI4 },\n\t/*::[*/0x80000003/*::]*/: { n: 'Behavior', t: VT_UI4 },\n\t/*::[*/0x72627262/*::]*/: {}\n};\n\n/* [MS-XLS] 2.4.63 Country/Region codes */\nvar CountryEnum = {\n\t/*::[*/0x0001/*::]*/: \"US\", // United States\n\t/*::[*/0x0002/*::]*/: \"CA\", // Canada\n\t/*::[*/0x0003/*::]*/: \"\", // Latin America (except Brazil)\n\t/*::[*/0x0007/*::]*/: \"RU\", // Russia\n\t/*::[*/0x0014/*::]*/: \"EG\", // Egypt\n\t/*::[*/0x001E/*::]*/: \"GR\", // Greece\n\t/*::[*/0x001F/*::]*/: \"NL\", // Netherlands\n\t/*::[*/0x0020/*::]*/: \"BE\", // Belgium\n\t/*::[*/0x0021/*::]*/: \"FR\", // France\n\t/*::[*/0x0022/*::]*/: \"ES\", // Spain\n\t/*::[*/0x0024/*::]*/: \"HU\", // Hungary\n\t/*::[*/0x0027/*::]*/: \"IT\", // Italy\n\t/*::[*/0x0029/*::]*/: \"CH\", // Switzerland\n\t/*::[*/0x002B/*::]*/: \"AT\", // Austria\n\t/*::[*/0x002C/*::]*/: \"GB\", // United Kingdom\n\t/*::[*/0x002D/*::]*/: \"DK\", // Denmark\n\t/*::[*/0x002E/*::]*/: \"SE\", // Sweden\n\t/*::[*/0x002F/*::]*/: \"NO\", // Norway\n\t/*::[*/0x0030/*::]*/: \"PL\", // Poland\n\t/*::[*/0x0031/*::]*/: \"DE\", // Germany\n\t/*::[*/0x0034/*::]*/: \"MX\", // Mexico\n\t/*::[*/0x0037/*::]*/: \"BR\", // Brazil\n\t/*::[*/0x003d/*::]*/: \"AU\", // Australia\n\t/*::[*/0x0040/*::]*/: \"NZ\", // New Zealand\n\t/*::[*/0x0042/*::]*/: \"TH\", // Thailand\n\t/*::[*/0x0051/*::]*/: \"JP\", // Japan\n\t/*::[*/0x0052/*::]*/: \"KR\", // Korea\n\t/*::[*/0x0054/*::]*/: \"VN\", // Viet Nam\n\t/*::[*/0x0056/*::]*/: \"CN\", // China\n\t/*::[*/0x005A/*::]*/: \"TR\", // Turkey\n\t/*::[*/0x0069/*::]*/: \"JS\", // Ramastan\n\t/*::[*/0x00D5/*::]*/: \"DZ\", // Algeria\n\t/*::[*/0x00D8/*::]*/: \"MA\", // Morocco\n\t/*::[*/0x00DA/*::]*/: \"LY\", // Libya\n\t/*::[*/0x015F/*::]*/: \"PT\", // Portugal\n\t/*::[*/0x0162/*::]*/: \"IS\", // Iceland\n\t/*::[*/0x0166/*::]*/: \"FI\", // Finland\n\t/*::[*/0x01A4/*::]*/: \"CZ\", // Czech Republic\n\t/*::[*/0x0376/*::]*/: \"TW\", // Taiwan\n\t/*::[*/0x03C1/*::]*/: \"LB\", // Lebanon\n\t/*::[*/0x03C2/*::]*/: \"JO\", // Jordan\n\t/*::[*/0x03C3/*::]*/: \"SY\", // Syria\n\t/*::[*/0x03C4/*::]*/: \"IQ\", // Iraq\n\t/*::[*/0x03C5/*::]*/: \"KW\", // Kuwait\n\t/*::[*/0x03C6/*::]*/: \"SA\", // Saudi Arabia\n\t/*::[*/0x03CB/*::]*/: \"AE\", // United Arab Emirates\n\t/*::[*/0x03CC/*::]*/: \"IL\", // Israel\n\t/*::[*/0x03CE/*::]*/: \"QA\", // Qatar\n\t/*::[*/0x03D5/*::]*/: \"IR\", // Iran\n\t/*::[*/0xFFFF/*::]*/: \"US\"  // United States\n};\n\n/* [MS-XLS] 2.5.127 */\nvar XLSFillPattern = [\n\tnull,\n\t'solid',\n\t'mediumGray',\n\t'darkGray',\n\t'lightGray',\n\t'darkHorizontal',\n\t'darkVertical',\n\t'darkDown',\n\t'darkUp',\n\t'darkGrid',\n\t'darkTrellis',\n\t'lightHorizontal',\n\t'lightVertical',\n\t'lightDown',\n\t'lightUp',\n\t'lightGrid',\n\t'lightTrellis',\n\t'gray125',\n\t'gray0625'\n];\n\nfunction rgbify(arr/*:Array<number>*/)/*:Array<[number, number, number]>*/ { return arr.map(function(x) { return [(x>>16)&255,(x>>8)&255,x&255]; }); }\n\n/* [MS-XLS] 2.5.161 */\n/* [MS-XLSB] 2.5.75 Icv */\nvar _XLSIcv = /*#__PURE__*/ rgbify([\n\t/* Color Constants */\n\t0x000000,\n\t0xFFFFFF,\n\t0xFF0000,\n\t0x00FF00,\n\t0x0000FF,\n\t0xFFFF00,\n\t0xFF00FF,\n\t0x00FFFF,\n\n\t/* Overridable Defaults */\n\t0x000000,\n\t0xFFFFFF,\n\t0xFF0000,\n\t0x00FF00,\n\t0x0000FF,\n\t0xFFFF00,\n\t0xFF00FF,\n\t0x00FFFF,\n\n\t0x800000,\n\t0x008000,\n\t0x000080,\n\t0x808000,\n\t0x800080,\n\t0x008080,\n\t0xC0C0C0,\n\t0x808080,\n\t0x9999FF,\n\t0x993366,\n\t0xFFFFCC,\n\t0xCCFFFF,\n\t0x660066,\n\t0xFF8080,\n\t0x0066CC,\n\t0xCCCCFF,\n\n\t0x000080,\n\t0xFF00FF,\n\t0xFFFF00,\n\t0x00FFFF,\n\t0x800080,\n\t0x800000,\n\t0x008080,\n\t0x0000FF,\n\t0x00CCFF,\n\t0xCCFFFF,\n\t0xCCFFCC,\n\t0xFFFF99,\n\t0x99CCFF,\n\t0xFF99CC,\n\t0xCC99FF,\n\t0xFFCC99,\n\n\t0x3366FF,\n\t0x33CCCC,\n\t0x99CC00,\n\t0xFFCC00,\n\t0xFF9900,\n\t0xFF6600,\n\t0x666699,\n\t0x969696,\n\t0x003366,\n\t0x339966,\n\t0x003300,\n\t0x333300,\n\t0x993300,\n\t0x993366,\n\t0x333399,\n\t0x333333,\n\n\t/* Other entries to appease BIFF8/12 */\n\t0xFFFFFF, /* 0x40 icvForeground ?? */\n\t0x000000, /* 0x41 icvBackground ?? */\n\t0x000000, /* 0x42 icvFrame ?? */\n\t0x000000, /* 0x43 icv3D ?? */\n\t0x000000, /* 0x44 icv3DText ?? */\n\t0x000000, /* 0x45 icv3DHilite ?? */\n\t0x000000, /* 0x46 icv3DShadow ?? */\n\t0x000000, /* 0x47 icvHilite ?? */\n\t0x000000, /* 0x48 icvCtlText ?? */\n\t0x000000, /* 0x49 icvCtlScrl ?? */\n\t0x000000, /* 0x4A icvCtlInv ?? */\n\t0x000000, /* 0x4B icvCtlBody ?? */\n\t0x000000, /* 0x4C icvCtlFrame ?? */\n\t0x000000, /* 0x4D icvCtlFore ?? */\n\t0x000000, /* 0x4E icvCtlBack ?? */\n\t0x000000, /* 0x4F icvCtlNeutral */\n\t0x000000, /* 0x50 icvInfoBk ?? */\n\t0x000000 /* 0x51 icvInfoText ?? */\n]);\nvar XLSIcv = /*#__PURE__*/dup(_XLSIcv);\n\n/* [MS-XLSB] 2.5.97.2 */\nvar BErr = {\n\t/*::[*/0x00/*::]*/: \"#NULL!\",\n\t/*::[*/0x07/*::]*/: \"#DIV/0!\",\n\t/*::[*/0x0F/*::]*/: \"#VALUE!\",\n\t/*::[*/0x17/*::]*/: \"#REF!\",\n\t/*::[*/0x1D/*::]*/: \"#NAME?\",\n\t/*::[*/0x24/*::]*/: \"#NUM!\",\n\t/*::[*/0x2A/*::]*/: \"#N/A\",\n\t/*::[*/0x2B/*::]*/: \"#GETTING_DATA\",\n\t/*::[*/0xFF/*::]*/: \"#WTF?\"\n};\n//var RBErr = evert_num(BErr);\nvar RBErr = {\n\t\"#NULL!\":        0x00,\n\t\"#DIV/0!\":       0x07,\n\t\"#VALUE!\":       0x0F,\n\t\"#REF!\":         0x17,\n\t\"#NAME?\":        0x1D,\n\t\"#NUM!\":         0x24,\n\t\"#N/A\":          0x2A,\n\t\"#GETTING_DATA\": 0x2B,\n\t\"#WTF?\":         0xFF\n};\n\n/* Parts enumerated in OPC spec, MS-XLSB and MS-XLSX */\n/* 12.3 Part Summary <SpreadsheetML> */\n/* 14.2 Part Summary <DrawingML> */\n/* [MS-XLSX] 2.1 Part Enumerations ; [MS-XLSB] 2.1.7 Part Enumeration */\nvar ct2type/*{[string]:string}*/ = ({\n\t/* Workbook */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\": \"workbooks\",\n\t\"application/vnd.ms-excel.sheet.macroEnabled.main+xml\": \"workbooks\",\n\t\"application/vnd.ms-excel.sheet.binary.macroEnabled.main\": \"workbooks\",\n\t\"application/vnd.ms-excel.addin.macroEnabled.main+xml\": \"workbooks\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml\": \"workbooks\",\n\n\t/* Worksheet */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml\": \"sheets\",\n\t\"application/vnd.ms-excel.worksheet\": \"sheets\",\n\t\"application/vnd.ms-excel.binIndexWs\": \"TODO\", /* Binary Index */\n\n\t/* Chartsheet */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml\": \"charts\",\n\t\"application/vnd.ms-excel.chartsheet\": \"charts\",\n\n\t/* Macrosheet */\n\t\"application/vnd.ms-excel.macrosheet+xml\": \"macros\",\n\t\"application/vnd.ms-excel.macrosheet\": \"macros\",\n\t\"application/vnd.ms-excel.intlmacrosheet\": \"TODO\",\n\t\"application/vnd.ms-excel.binIndexMs\": \"TODO\", /* Binary Index */\n\n\t/* Dialogsheet */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml\": \"dialogs\",\n\t\"application/vnd.ms-excel.dialogsheet\": \"dialogs\",\n\n\t/* Shared Strings */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml\": \"strs\",\n\t\"application/vnd.ms-excel.sharedStrings\": \"strs\",\n\n\t/* Styles */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml\": \"styles\",\n\t\"application/vnd.ms-excel.styles\": \"styles\",\n\n\t/* File Properties */\n\t\"application/vnd.openxmlformats-package.core-properties+xml\": \"coreprops\",\n\t\"application/vnd.openxmlformats-officedocument.custom-properties+xml\": \"custprops\",\n\t\"application/vnd.openxmlformats-officedocument.extended-properties+xml\": \"extprops\",\n\n\t/* Custom Data Properties */\n\t\"application/vnd.openxmlformats-officedocument.customXmlProperties+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.customProperty\": \"TODO\",\n\n\t/* Comments */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml\": \"comments\",\n\t\"application/vnd.ms-excel.comments\": \"comments\",\n\t\"application/vnd.ms-excel.threadedcomments+xml\": \"threadedcomments\",\n\t\"application/vnd.ms-excel.person+xml\": \"people\",\n\n\t/* Metadata (Stock/Geography and Dynamic Array) */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+xml\": \"metadata\",\n\t\"application/vnd.ms-excel.sheetMetadata\": \"metadata\",\n\n\t/* PivotTable */\n\t\"application/vnd.ms-excel.pivotTable\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotTable+xml\": \"TODO\",\n\n\t/* Chart Objects */\n\t\"application/vnd.openxmlformats-officedocument.drawingml.chart+xml\": \"TODO\",\n\n\t/* Chart Colors */\n\t\"application/vnd.ms-office.chartcolorstyle+xml\": \"TODO\",\n\n\t/* Chart Style */\n\t\"application/vnd.ms-office.chartstyle+xml\": \"TODO\",\n\n\t/* Chart Advanced */\n\t\"application/vnd.ms-office.chartex+xml\": \"TODO\",\n\n\t/* Calculation Chain */\n\t\"application/vnd.ms-excel.calcChain\": \"calcchains\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.calcChain+xml\": \"calcchains\",\n\n\t/* Printer Settings */\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.printerSettings\": \"TODO\",\n\n\t/* ActiveX */\n\t\"application/vnd.ms-office.activeX\": \"TODO\",\n\t\"application/vnd.ms-office.activeX+xml\": \"TODO\",\n\n\t/* Custom Toolbars */\n\t\"application/vnd.ms-excel.attachedToolbars\": \"TODO\",\n\n\t/* External Data Connections */\n\t\"application/vnd.ms-excel.connections\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml\": \"TODO\",\n\n\t/* External Links */\n\t\"application/vnd.ms-excel.externalLink\": \"links\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.externalLink+xml\": \"links\",\n\n\t/* PivotCache */\n\t\"application/vnd.ms-excel.pivotCacheDefinition\": \"TODO\",\n\t\"application/vnd.ms-excel.pivotCacheRecords\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotCacheDefinition+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.pivotCacheRecords+xml\": \"TODO\",\n\n\t/* Query Table */\n\t\"application/vnd.ms-excel.queryTable\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.queryTable+xml\": \"TODO\",\n\n\t/* Shared Workbook */\n\t\"application/vnd.ms-excel.userNames\": \"TODO\",\n\t\"application/vnd.ms-excel.revisionHeaders\": \"TODO\",\n\t\"application/vnd.ms-excel.revisionLog\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionHeaders+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.revisionLog+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.userNames+xml\": \"TODO\",\n\n\t/* Single Cell Table */\n\t\"application/vnd.ms-excel.tableSingleCells\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.tableSingleCells+xml\": \"TODO\",\n\n\t/* Slicer */\n\t\"application/vnd.ms-excel.slicer\": \"TODO\",\n\t\"application/vnd.ms-excel.slicerCache\": \"TODO\",\n\t\"application/vnd.ms-excel.slicer+xml\": \"TODO\",\n\t\"application/vnd.ms-excel.slicerCache+xml\": \"TODO\",\n\n\t/* Sort Map */\n\t\"application/vnd.ms-excel.wsSortMap\": \"TODO\",\n\n\t/* Table */\n\t\"application/vnd.ms-excel.table\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.table+xml\": \"TODO\",\n\n\t/* Themes */\n\t\"application/vnd.openxmlformats-officedocument.theme+xml\": \"themes\",\n\n\t/* Theme Override */\n\t\"application/vnd.openxmlformats-officedocument.themeOverride+xml\": \"TODO\",\n\n\t/* Timeline */\n\t\"application/vnd.ms-excel.Timeline+xml\": \"TODO\", /* verify */\n\t\"application/vnd.ms-excel.TimelineCache+xml\": \"TODO\", /* verify */\n\n\t/* VBA */\n\t\"application/vnd.ms-office.vbaProject\": \"vba\",\n\t\"application/vnd.ms-office.vbaProjectSignature\": \"TODO\",\n\n\t/* Volatile Dependencies */\n\t\"application/vnd.ms-office.volatileDependencies\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.spreadsheetml.volatileDependencies+xml\": \"TODO\",\n\n\t/* Control Properties */\n\t\"application/vnd.ms-excel.controlproperties+xml\": \"TODO\",\n\n\t/* Data Model */\n\t\"application/vnd.openxmlformats-officedocument.model+data\": \"TODO\",\n\n\t/* Survey */\n\t\"application/vnd.ms-excel.Survey+xml\": \"TODO\",\n\n\t/* Drawing */\n\t\"application/vnd.openxmlformats-officedocument.drawing+xml\": \"drawings\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.chartshapes+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramColors+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramData+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramLayout+xml\": \"TODO\",\n\t\"application/vnd.openxmlformats-officedocument.drawingml.diagramStyle+xml\": \"TODO\",\n\n\t/* VML */\n\t\"application/vnd.openxmlformats-officedocument.vmlDrawing\": \"TODO\",\n\n\t\"application/vnd.openxmlformats-package.relationships+xml\": \"rels\",\n\t\"application/vnd.openxmlformats-officedocument.oleObject\": \"TODO\",\n\n\t/* Image */\n\t\"image/png\": \"TODO\",\n\n\t\"sheet\": \"js\"\n}/*:any*/);\n\nvar CT_LIST = {\n\t\tworkbooks: {\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml\",\n\t\t\txlsm: \"application/vnd.ms-excel.sheet.macroEnabled.main+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sheet.binary.macroEnabled.main\",\n\t\t\txlam: \"application/vnd.ms-excel.addin.macroEnabled.main+xml\",\n\t\t\txltx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml\"\n\t\t},\n\t\tstrs: { /* Shared Strings */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sharedStrings+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sharedStrings\"\n\t\t},\n\t\tcomments: { /* Comments */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.comments\"\n\t\t},\n\t\tsheets: { /* Worksheet */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.worksheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.worksheet\"\n\t\t},\n\t\tcharts: { /* Chartsheet */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.chartsheet\"\n\t\t},\n\t\tdialogs: { /* Dialogsheet */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.dialogsheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.dialogsheet\"\n\t\t},\n\t\tmacros: { /* Macrosheet (Excel 4.0 Macros) */\n\t\t\txlsx: \"application/vnd.ms-excel.macrosheet+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.macrosheet\"\n\t\t},\n\t\tmetadata: { /* Metadata (Stock/Geography and Dynamic Array) */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.sheetMetadata+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.sheetMetadata\"\n\t\t},\n\t\tstyles: { /* Styles */\n\t\t\txlsx: \"application/vnd.openxmlformats-officedocument.spreadsheetml.styles+xml\",\n\t\t\txlsb: \"application/vnd.ms-excel.styles\"\n\t\t}\n};\n\nfunction new_ct()/*:any*/ {\n\treturn ({\n\t\tworkbooks:[], sheets:[], charts:[], dialogs:[], macros:[],\n\t\trels:[], strs:[], comments:[], threadedcomments:[], links:[],\n\t\tcoreprops:[], extprops:[], custprops:[], themes:[], styles:[],\n\t\tcalcchains:[], vba: [], drawings: [], metadata: [], people:[],\n\t\tTODO:[], xmlns: \"\" }/*:any*/);\n}\n\nfunction parse_ct(data/*:?string*/) {\n\tvar ct = new_ct();\n\tif(!data || !data.match) return ct;\n\tvar ctext = {};\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0].replace(nsregex,\"<\")) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<Types': ct.xmlns = y['xmlns' + (y[0].match(/<(\\w+):/)||[\"\",\"\"])[1] ]; break;\n\t\t\tcase '<Default': ctext[y.Extension] = y.ContentType; break;\n\t\t\tcase '<Override':\n\t\t\t\tif(ct[ct2type[y.ContentType]] !== undefined) ct[ct2type[y.ContentType]].push(y.PartName);\n\t\t\t\tbreak;\n\t\t}\n\t});\n\tif(ct.xmlns !== XMLNS.CT) throw new Error(\"Unknown Namespace: \" + ct.xmlns);\n\tct.calcchain = ct.calcchains.length > 0 ? ct.calcchains[0] : \"\";\n\tct.sst = ct.strs.length > 0 ? ct.strs[0] : \"\";\n\tct.style = ct.styles.length > 0 ? ct.styles[0] : \"\";\n\tct.defaults = ctext;\n\tdelete ct.calcchains;\n\treturn ct;\n}\n\nfunction write_ct(ct, opts)/*:string*/ {\n\tvar type2ct/*{[string]:Array<string>}*/ = evert_arr(ct2type);\n\n\tvar o/*:Array<string>*/ = [], v;\n\to[o.length] = (XML_HEADER);\n\to[o.length] = writextag('Types', null, {\n\t\t'xmlns': XMLNS.CT,\n\t\t'xmlns:xsd': XMLNS.xsd,\n\t\t'xmlns:xsi': XMLNS.xsi\n\t});\n\n\to = o.concat([\n\t\t['xml', 'application/xml'],\n\t\t['bin', 'application/vnd.ms-excel.sheet.binary.macroEnabled.main'],\n\t\t['vml', 'application/vnd.openxmlformats-officedocument.vmlDrawing'],\n\t\t['data', 'application/vnd.openxmlformats-officedocument.model+data'],\n\t\t/* from test files */\n\t\t['bmp', 'image/bmp'],\n\t\t['png', 'image/png'],\n\t\t['gif', 'image/gif'],\n\t\t['emf', 'image/x-emf'],\n\t\t['wmf', 'image/x-wmf'],\n\t\t['jpg', 'image/jpeg'], ['jpeg', 'image/jpeg'],\n\t\t['tif', 'image/tiff'], ['tiff', 'image/tiff'],\n\t\t['pdf', 'application/pdf'],\n\t\t['rels', 'application/vnd.openxmlformats-package.relationships+xml']\n\t].map(function(x) {\n\t\treturn writextag('Default', null, {'Extension':x[0], 'ContentType': x[1]});\n\t}));\n\n\t/* only write first instance */\n\tvar f1 = function(w) {\n\t\tif(ct[w] && ct[w].length > 0) {\n\t\t\tv = ct[w][0];\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': CT_LIST[w][opts.bookType] || CT_LIST[w]['xlsx']\n\t\t\t}));\n\t\t}\n\t};\n\n\t/* book type-specific */\n\tvar f2 = function(w) {\n\t\t(ct[w]||[]).forEach(function(v) {\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': CT_LIST[w][opts.bookType] || CT_LIST[w]['xlsx']\n\t\t\t}));\n\t\t});\n\t};\n\n\t/* standard type */\n\tvar f3 = function(t) {\n\t\t(ct[t]||[]).forEach(function(v) {\n\t\t\to[o.length] = (writextag('Override', null, {\n\t\t\t\t'PartName': (v[0] == '/' ? \"\":\"/\") + v,\n\t\t\t\t'ContentType': type2ct[t][0]\n\t\t\t}));\n\t\t});\n\t};\n\n\tf1('workbooks');\n\tf2('sheets');\n\tf2('charts');\n\tf3('themes');\n\t['strs', 'styles'].forEach(f1);\n\t['coreprops', 'extprops', 'custprops'].forEach(f3);\n\tf3('vba');\n\tf3('comments');\n\tf3('threadedcomments');\n\tf3('drawings');\n\tf2('metadata');\n\tf3('people');\n\tif(o.length>2){ o[o.length] = ('</Types>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 9.3 Relationships */\nvar RELS = ({\n\tWB: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument\",\n\tSHEET: \"http://sheetjs.openxmlformats.org/officeDocument/2006/relationships/officeDocument\",\n\tHLINK: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink\",\n\tVML: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/vmlDrawing\",\n\tXPATH: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/externalLinkPath\",\n\tXMISS: \"http://schemas.microsoft.com/office/2006/relationships/xlExternalLinkPath/xlPathMissing\",\n\tXLINK: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/externalLink\",\n\tCXML: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/customXml\",\n\tCXMLP: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/customXmlProps\",\n\tCMNT: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/comments\",\n\tCORE_PROPS: \"http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties\",\n\tEXT_PROPS: 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties',\n\tCUST_PROPS: 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/custom-properties',\n\tSST: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sharedStrings\",\n\tSTY: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles\",\n\tTHEME: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme\",\n\tCHART: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chart\",\n\tCHARTEX: \"http://schemas.microsoft.com/office/2014/relationships/chartEx\",\n\tCS: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/chartsheet\",\n\tWS: [\n\t\t\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet\",\n\t\t\"http://purl.oclc.org/ooxml/officeDocument/relationships/worksheet\"\n\t],\n\tDS: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/dialogsheet\",\n\tMS: \"http://schemas.microsoft.com/office/2006/relationships/xlMacrosheet\",\n\tIMG: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image\",\n\tDRAW: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing\",\n\tXLMETA: \"http://schemas.openxmlformats.org/officeDocument/2006/relationships/sheetMetadata\",\n\tTCMNT: \"http://schemas.microsoft.com/office/2017/10/relationships/threadedComment\",\n\tPEOPLE: \"http://schemas.microsoft.com/office/2017/10/relationships/person\",\n\tVBA: \"http://schemas.microsoft.com/office/2006/relationships/vbaProject\"\n}/*:any*/);\n\n\n/* 9.3.3 Representing Relationships */\nfunction get_rels_path(file/*:string*/)/*:string*/ {\n\tvar n = file.lastIndexOf(\"/\");\n\treturn file.slice(0,n+1) + '_rels/' + file.slice(n+1) + \".rels\";\n}\n\nfunction parse_rels(data/*:?string*/, currentFilePath/*:string*/) {\n\tvar rels = {\"!id\":{}};\n\tif (!data) return rels;\n\tif (currentFilePath.charAt(0) !== '/') {\n\t\tcurrentFilePath = '/'+currentFilePath;\n\t}\n\tvar hash = {};\n\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\t/* 9.3.2.2 OPC_Relationships */\n\t\tif (y[0] === '<Relationship') {\n\t\t\tvar rel = {}; rel.Type = y.Type; rel.Target = y.Target; rel.Id = y.Id; if(y.TargetMode) rel.TargetMode = y.TargetMode;\n\t\t\tvar canonictarget = y.TargetMode === 'External' ? y.Target : resolve_path(y.Target, currentFilePath);\n\t\t\trels[canonictarget] = rel;\n\t\t\thash[y.Id] = rel;\n\t\t}\n\t});\n\trels[\"!id\"] = hash;\n\treturn rels;\n}\n\n\n/* TODO */\nfunction write_rels(rels)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('Relationships', null, {\n\t\t//'xmlns:ns0': XMLNS.RELS,\n\t\t'xmlns': XMLNS.RELS\n\t})];\n\tkeys(rels['!id']).forEach(function(rid) {\n\t\to[o.length] = (writextag('Relationship', null, rels['!id'][rid]));\n\t});\n\tif(o.length>2){ o[o.length] = ('</Relationships>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\nfunction add_rels(rels, rId/*:number*/, f, type, relobj, targetmode/*:?string*/)/*:number*/ {\n\tif(!relobj) relobj = {};\n\tif(!rels['!id']) rels['!id'] = {};\n\tif(!rels['!idx']) rels['!idx'] = 1;\n\tif(rId < 0) for(rId = rels['!idx']; rels['!id']['rId' + rId]; ++rId){/* empty */}\n\trels['!idx'] = rId + 1;\n\trelobj.Id = 'rId' + rId;\n\trelobj.Type = type;\n\trelobj.Target = f;\n\tif(targetmode) relobj.TargetMode = targetmode;\n\telse if([RELS.HLINK, RELS.XPATH, RELS.XMISS].indexOf(relobj.Type) > -1) relobj.TargetMode = \"External\";\n\tif(rels['!id'][relobj.Id]) throw new Error(\"Cannot rewrite rId \" + rId);\n\trels['!id'][relobj.Id] = relobj;\n\trels[('/' + relobj.Target).replace(\"//\",\"/\")] = relobj;\n\treturn rId;\n}\n/* Open Document Format for Office Applications (OpenDocument) Version 1.2 */\n/* Part 3 Section 4 Manifest File */\nvar CT_ODS = \"application/vnd.oasis.opendocument.spreadsheet\";\nfunction parse_manifest(d, opts) {\n\tvar str = xlml_normalize(d);\n\tvar Rn;\n\tvar FEtag;\n\twhile((Rn = xlmlregex.exec(str))) switch(Rn[3]) {\n\t\tcase 'manifest': break; // 4.2 <manifest:manifest>\n\t\tcase 'file-entry': // 4.3 <manifest:file-entry>\n\t\t\tFEtag = parsexmltag(Rn[0], false);\n\t\t\tif(FEtag.path == '/' && FEtag.type !== CT_ODS) throw new Error(\"This OpenDocument is not a spreadsheet\");\n\t\t\tbreak;\n\t\tcase 'encryption-data': // 4.4 <manifest:encryption-data>\n\t\tcase 'algorithm': // 4.5 <manifest:algorithm>\n\t\tcase 'start-key-generation': // 4.6 <manifest:start-key-generation>\n\t\tcase 'key-derivation': // 4.7 <manifest:key-derivation>\n\t\t\tthrow new Error(\"Unsupported ODS Encryption\");\n\t\tdefault: if(opts && opts.WTF) throw Rn;\n\t}\n}\n\nfunction write_manifest(manifest/*:Array<Array<string> >*/)/*:string*/ {\n\tvar o = [XML_HEADER];\n\to.push('<manifest:manifest xmlns:manifest=\"urn:oasis:names:tc:opendocument:xmlns:manifest:1.0\" manifest:version=\"1.2\">\\n');\n\to.push('  <manifest:file-entry manifest:full-path=\"/\" manifest:version=\"1.2\" manifest:media-type=\"application/vnd.oasis.opendocument.spreadsheet\"/>\\n');\n\tfor(var i = 0; i < manifest.length; ++i) o.push('  <manifest:file-entry manifest:full-path=\"' + manifest[i][0] + '\" manifest:media-type=\"' + manifest[i][1] + '\"/>\\n');\n\to.push('</manifest:manifest>');\n\treturn o.join(\"\");\n}\n\n/* Part 3 Section 6 Metadata Manifest File */\nfunction write_rdf_type(file/*:string*/, res/*:string*/, tag/*:?string*/) {\n\treturn [\n\t\t'  <rdf:Description rdf:about=\"' + file + '\">\\n',\n\t\t'    <rdf:type rdf:resource=\"http://docs.oasis-open.org/ns/office/1.2/meta/' + (tag || \"odf\") + '#' + res + '\"/>\\n',\n\t\t'  </rdf:Description>\\n'\n\t].join(\"\");\n}\nfunction write_rdf_has(base/*:string*/, file/*:string*/) {\n\treturn [\n\t\t'  <rdf:Description rdf:about=\"' + base + '\">\\n',\n\t\t'    <ns0:hasPart xmlns:ns0=\"http://docs.oasis-open.org/ns/office/1.2/meta/pkg#\" rdf:resource=\"' + file + '\"/>\\n',\n\t\t'  </rdf:Description>\\n'\n\t].join(\"\");\n}\nfunction write_rdf(rdf) {\n\tvar o = [XML_HEADER];\n\to.push('<rdf:RDF xmlns:rdf=\"http://www.w3.org/1999/02/22-rdf-syntax-ns#\">\\n');\n\tfor(var i = 0; i != rdf.length; ++i) {\n\t\to.push(write_rdf_type(rdf[i][0], rdf[i][1]));\n\t\to.push(write_rdf_has(\"\",rdf[i][0]));\n\t}\n\to.push(write_rdf_type(\"\",\"Document\", \"pkg\"));\n\to.push('</rdf:RDF>');\n\treturn o.join(\"\");\n}\n/* TODO: pull properties */\nfunction write_meta_ods(/*:: wb: Workbook, opts: any*/)/*:string*/ {\n\treturn '<office:document-meta xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" xmlns:meta=\"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" office:version=\"1.2\"><office:meta><meta:generator>Sheet' + 'JS ' + XLSX.version + '</meta:generator></office:meta></office:document-meta>';\n}\n\n/* ECMA-376 Part II 11.1 Core Properties Part */\n/* [MS-OSHARED] 2.3.3.2.[1-2].1 (PIDSI/PIDDSI) */\nvar CORE_PROPS/*:Array<Array<string> >*/ = [\n\t[\"cp:category\", \"Category\"],\n\t[\"cp:contentStatus\", \"ContentStatus\"],\n\t[\"cp:keywords\", \"Keywords\"],\n\t[\"cp:lastModifiedBy\", \"LastAuthor\"],\n\t[\"cp:lastPrinted\", \"LastPrinted\"],\n\t[\"cp:revision\", \"RevNumber\"],\n\t[\"cp:version\", \"Version\"],\n\t[\"dc:creator\", \"Author\"],\n\t[\"dc:description\", \"Comments\"],\n\t[\"dc:identifier\", \"Identifier\"],\n\t[\"dc:language\", \"Language\"],\n\t[\"dc:subject\", \"Subject\"],\n\t[\"dc:title\", \"Title\"],\n\t[\"dcterms:created\", \"CreatedDate\", 'date'],\n\t[\"dcterms:modified\", \"ModifiedDate\", 'date']\n];\n\nvar CORE_PROPS_REGEX/*:Array<RegExp>*/ = /*#__PURE__*/(function() {\n\tvar r = new Array(CORE_PROPS.length);\n\tfor(var i = 0; i < CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i];\n\t\tvar g = \"(?:\"+ f[0].slice(0,f[0].indexOf(\":\")) +\":)\"+ f[0].slice(f[0].indexOf(\":\")+1);\n\t\tr[i] = new RegExp(\"<\" + g + \"[^>]*>([\\\\s\\\\S]*?)<\\/\" + g + \">\");\n\t}\n\treturn r;\n})();\n\nfunction parse_core_props(data) {\n\tvar p = {};\n\tdata = utf8read(data);\n\n\tfor(var i = 0; i < CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i], cur = data.match(CORE_PROPS_REGEX[i]);\n\t\tif(cur != null && cur.length > 0) p[f[1]] = unescapexml(cur[1]);\n\t\tif(f[2] === 'date' && p[f[1]]) p[f[1]] = parseDate(p[f[1]]);\n\t}\n\n\treturn p;\n}\n\nfunction cp_doit(f, g, h, o, p) {\n\tif(p[f] != null || g == null || g === \"\") return;\n\tp[f] = g;\n\tg = escapexml(g);\n\to[o.length] = (h ? writextag(f,g,h) : writetag(f,g));\n}\n\nfunction write_core_props(cp, _opts) {\n\tvar opts = _opts || {};\n\tvar o = [XML_HEADER, writextag('cp:coreProperties', null, {\n\t\t//'xmlns': XMLNS.CORE_PROPS,\n\t\t'xmlns:cp': XMLNS.CORE_PROPS,\n\t\t'xmlns:dc': XMLNS.dc,\n\t\t'xmlns:dcterms': XMLNS.dcterms,\n\t\t'xmlns:dcmitype': XMLNS.dcmitype,\n\t\t'xmlns:xsi': XMLNS.xsi\n\t})], p = {};\n\tif(!cp && !opts.Props) return o.join(\"\");\n\n\tif(cp) {\n\t\tif(cp.CreatedDate != null) cp_doit(\"dcterms:created\", typeof cp.CreatedDate === \"string\" ? cp.CreatedDate : write_w3cdtf(cp.CreatedDate, opts.WTF), {\"xsi:type\":\"dcterms:W3CDTF\"}, o, p);\n\t\tif(cp.ModifiedDate != null) cp_doit(\"dcterms:modified\", typeof cp.ModifiedDate === \"string\" ? cp.ModifiedDate : write_w3cdtf(cp.ModifiedDate, opts.WTF), {\"xsi:type\":\"dcterms:W3CDTF\"}, o, p);\n\t}\n\n\tfor(var i = 0; i != CORE_PROPS.length; ++i) {\n\t\tvar f = CORE_PROPS[i];\n\t\tvar v = opts.Props && opts.Props[f[1]] != null ? opts.Props[f[1]] : cp ? cp[f[1]] : null;\n\t\tif(v === true) v = \"1\";\n\t\telse if(v === false) v = \"0\";\n\t\telse if(typeof v == \"number\") v = String(v);\n\t\tif(v != null) cp_doit(f[0], v, null, o, p);\n\t}\n\tif(o.length>2){ o[o.length] = ('</cp:coreProperties>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 15.2.12.3 Extended File Properties Part */\n/* [MS-OSHARED] 2.3.3.2.[1-2].1 (PIDSI/PIDDSI) */\nvar EXT_PROPS/*:Array<Array<string> >*/ = [\n\t[\"Application\", \"Application\", \"string\"],\n\t[\"AppVersion\", \"AppVersion\", \"string\"],\n\t[\"Company\", \"Company\", \"string\"],\n\t[\"DocSecurity\", \"DocSecurity\", \"string\"],\n\t[\"Manager\", \"Manager\", \"string\"],\n\t[\"HyperlinksChanged\", \"HyperlinksChanged\", \"bool\"],\n\t[\"SharedDoc\", \"SharedDoc\", \"bool\"],\n\t[\"LinksUpToDate\", \"LinksUpToDate\", \"bool\"],\n\t[\"ScaleCrop\", \"ScaleCrop\", \"bool\"],\n\t[\"HeadingPairs\", \"HeadingPairs\", \"raw\"],\n\t[\"TitlesOfParts\", \"TitlesOfParts\", \"raw\"]\n];\n\nvar PseudoPropsPairs = [\n\t\"Worksheets\",  \"SheetNames\",\n\t\"NamedRanges\", \"DefinedNames\",\n\t\"Chartsheets\", \"ChartNames\"\n];\nfunction load_props_pairs(HP/*:string|Array<Array<any>>*/, TOP, props, opts) {\n\tvar v = [];\n\tif(typeof HP == \"string\") v = parseVector(HP, opts);\n\telse for(var j = 0; j < HP.length; ++j) v = v.concat(HP[j].map(function(hp) { return {v:hp}; }));\n\tvar parts = (typeof TOP == \"string\") ? parseVector(TOP, opts).map(function (x) { return x.v; }) : TOP;\n\tvar idx = 0, len = 0;\n\tif(parts.length > 0) for(var i = 0; i !== v.length; i += 2) {\n\t\tlen = +(v[i+1].v);\n\t\tswitch(v[i].v) {\n\t\t\tcase \"Worksheets\":\n\t\t\tcase \"工作表\":\n\t\t\tcase \"Листы\":\n\t\t\tcase \"أوراق العمل\":\n\t\t\tcase \"ワークシート\":\n\t\t\tcase \"גליונות עבודה\":\n\t\t\tcase \"Arbeitsblätter\":\n\t\t\tcase \"Çalışma Sayfaları\":\n\t\t\tcase \"Feuilles de calcul\":\n\t\t\tcase \"Fogli di lavoro\":\n\t\t\tcase \"Folhas de cálculo\":\n\t\t\tcase \"Planilhas\":\n\t\t\tcase \"Regneark\":\n\t\t\tcase \"Hojas de cálculo\":\n\t\t\tcase \"Werkbladen\":\n\t\t\t\tprops.Worksheets = len;\n\t\t\t\tprops.SheetNames = parts.slice(idx, idx + len);\n\t\t\t\tbreak;\n\n\t\t\tcase \"Named Ranges\":\n\t\t\tcase \"Rangos con nombre\":\n\t\t\tcase \"名前付き一覧\":\n\t\t\tcase \"Benannte Bereiche\":\n\t\t\tcase \"Navngivne områder\":\n\t\t\t\tprops.NamedRanges = len;\n\t\t\t\tprops.DefinedNames = parts.slice(idx, idx + len);\n\t\t\t\tbreak;\n\n\t\t\tcase \"Charts\":\n\t\t\tcase \"Diagramme\":\n\t\t\t\tprops.Chartsheets = len;\n\t\t\t\tprops.ChartNames = parts.slice(idx, idx + len);\n\t\t\t\tbreak;\n\t\t}\n\t\tidx += len;\n\t}\n}\n\nfunction parse_ext_props(data, p, opts) {\n\tvar q = {}; if(!p) p = {};\n\tdata = utf8read(data);\n\n\tEXT_PROPS.forEach(function(f) {\n\t\tvar xml = (data.match(matchtag(f[0]))||[])[1];\n\t\tswitch(f[2]) {\n\t\t\tcase \"string\": if(xml) p[f[1]] = unescapexml(xml); break;\n\t\t\tcase \"bool\": p[f[1]] = xml === \"true\"; break;\n\t\t\tcase \"raw\":\n\t\t\t\tvar cur = data.match(new RegExp(\"<\" + f[0] + \"[^>]*>([\\\\s\\\\S]*?)<\\/\" + f[0] + \">\"));\n\t\t\t\tif(cur && cur.length > 0) q[f[1]] = cur[1];\n\t\t\t\tbreak;\n\t\t}\n\t});\n\n\tif(q.HeadingPairs && q.TitlesOfParts) load_props_pairs(q.HeadingPairs, q.TitlesOfParts, p, opts);\n\n\treturn p;\n}\n\nfunction write_ext_props(cp/*::, opts*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [], W = writextag;\n\tif(!cp) cp = {};\n\tcp.Application = \"SheetJS\";\n\to[o.length] = (XML_HEADER);\n\to[o.length] = (writextag('Properties', null, {\n\t\t'xmlns': XMLNS.EXT_PROPS,\n\t\t'xmlns:vt': XMLNS.vt\n\t}));\n\n\tEXT_PROPS.forEach(function(f) {\n\t\tif(cp[f[1]] === undefined) return;\n\t\tvar v;\n\t\tswitch(f[2]) {\n\t\t\tcase 'string': v = escapexml(String(cp[f[1]])); break;\n\t\t\tcase 'bool': v = cp[f[1]] ? 'true' : 'false'; break;\n\t\t}\n\t\tif(v !== undefined) o[o.length] = (W(f[0], v));\n\t});\n\n\t/* TODO: HeadingPairs, TitlesOfParts */\n\to[o.length] = (W('HeadingPairs', W('vt:vector', W('vt:variant', '<vt:lpstr>Worksheets</vt:lpstr>')+W('vt:variant', W('vt:i4', String(cp.Worksheets))), {size:2, baseType:\"variant\"})));\n\to[o.length] = (W('TitlesOfParts', W('vt:vector', cp.SheetNames.map(function(s) { return \"<vt:lpstr>\" + escapexml(s) + \"</vt:lpstr>\"; }).join(\"\"), {size: cp.Worksheets, baseType:\"lpstr\"})));\n\tif(o.length>2){ o[o.length] = ('</Properties>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* 15.2.12.2 Custom File Properties Part */\nvar custregex = /<[^>]+>[^<]*/g;\nfunction parse_cust_props(data/*:string*/, opts) {\n\tvar p = {}, name = \"\";\n\tvar m = data.match(custregex);\n\tif(m) for(var i = 0; i != m.length; ++i) {\n\t\tvar x = m[i], y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<Properties': break;\n\t\t\tcase '<property': name = unescapexml(y.name); break;\n\t\t\tcase '</property>': name = null; break;\n\t\t\tdefault: if (x.indexOf('<vt:') === 0) {\n\t\t\t\tvar toks = x.split('>');\n\t\t\t\tvar type = toks[0].slice(4), text = toks[1];\n\t\t\t\t/* 22.4.2.32 (CT_Variant). Omit the binary types from 22.4 (Variant Types) */\n\t\t\t\tswitch(type) {\n\t\t\t\t\tcase 'lpstr': case 'bstr': case 'lpwstr':\n\t\t\t\t\t\tp[name] = unescapexml(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'bool':\n\t\t\t\t\t\tp[name] = parsexmlbool(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'i1': case 'i2': case 'i4': case 'i8': case 'int': case 'uint':\n\t\t\t\t\t\tp[name] = parseInt(text, 10);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'r4': case 'r8': case 'decimal':\n\t\t\t\t\t\tp[name] = parseFloat(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'filetime': case 'date':\n\t\t\t\t\t\tp[name] = parseDate(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'cy': case 'error':\n\t\t\t\t\t\tp[name] = unescapexml(text);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\tif(type.slice(-1) == '/') break;\n\t\t\t\t\t\tif(opts.WTF && typeof console !== 'undefined') console.warn('Unexpected', x, type, toks);\n\t\t\t\t}\n\t\t\t} else if(x.slice(0,2) === \"</\") {/* empty */\n\t\t\t} else if(opts.WTF) throw new Error(x);\n\t\t}\n\t}\n\treturn p;\n}\n\nfunction write_cust_props(cp/*::, opts*/)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('Properties', null, {\n\t\t'xmlns': XMLNS.CUST_PROPS,\n\t\t'xmlns:vt': XMLNS.vt\n\t})];\n\tif(!cp) return o.join(\"\");\n\tvar pid = 1;\n\tkeys(cp).forEach(function custprop(k) { ++pid;\n\t\to[o.length] = (writextag('property', write_vt(cp[k], true), {\n\t\t\t'fmtid': '{D5CDD505-2E9C-101B-9397-08002B2CF9AE}',\n\t\t\t'pid': pid,\n\t\t\t'name': escapexml(k)\n\t\t}));\n\t});\n\tif(o.length>2){ o[o.length] = '</Properties>'; o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* Common Name -> XLML Name */\nvar XLMLDocPropsMap = {\n\tTitle: 'Title',\n\tSubject: 'Subject',\n\tAuthor: 'Author',\n\tKeywords: 'Keywords',\n\tComments: 'Description',\n\tLastAuthor: 'LastAuthor',\n\tRevNumber: 'Revision',\n\tApplication: 'AppName',\n\t/* TotalTime: 'TotalTime', */\n\tLastPrinted: 'LastPrinted',\n\tCreatedDate: 'Created',\n\tModifiedDate: 'LastSaved',\n\t/* Pages */\n\t/* Words */\n\t/* Characters */\n\tCategory: 'Category',\n\t/* PresentationFormat */\n\tManager: 'Manager',\n\tCompany: 'Company',\n\t/* Guid */\n\t/* HyperlinkBase */\n\t/* Bytes */\n\t/* Lines */\n\t/* Paragraphs */\n\t/* CharactersWithSpaces */\n\tAppVersion: 'Version',\n\n\tContentStatus: 'ContentStatus', /* NOTE: missing from schema */\n\tIdentifier: 'Identifier', /* NOTE: missing from schema */\n\tLanguage: 'Language' /* NOTE: missing from schema */\n};\nvar evert_XLMLDPM;\n\nfunction xlml_set_prop(Props, tag/*:string*/, val) {\n\tif(!evert_XLMLDPM) evert_XLMLDPM = evert(XLMLDocPropsMap);\n\ttag = evert_XLMLDPM[tag] || tag;\n\tProps[tag] = val;\n}\n\nfunction xlml_write_docprops(Props, opts) {\n\tvar o/*:Array<string>*/ = [];\n\tkeys(XLMLDocPropsMap).map(function(m) {\n\t\tfor(var i = 0; i < CORE_PROPS.length; ++i) if(CORE_PROPS[i][1] == m) return CORE_PROPS[i];\n\t\tfor(i = 0; i < EXT_PROPS.length; ++i) if(EXT_PROPS[i][1] == m) return EXT_PROPS[i];\n\t\tthrow m;\n\t}).forEach(function(p) {\n\t\tif(Props[p[1]] == null) return;\n\t\tvar m = opts && opts.Props && opts.Props[p[1]] != null ? opts.Props[p[1]] : Props[p[1]];\n\t\tswitch(p[2]) {\n\t\t\tcase 'date': m = new Date(m).toISOString().replace(/\\.\\d*Z/,\"Z\"); break;\n\t\t}\n\t\tif(typeof m == 'number') m = String(m);\n\t\telse if(m === true || m === false) { m = m ? \"1\" : \"0\"; }\n\t\telse if(m instanceof Date) m = new Date(m).toISOString().replace(/\\.\\d*Z/,\"\");\n\t\to.push(writetag(XLMLDocPropsMap[p[1]] || p[1], m));\n\t});\n\treturn writextag('DocumentProperties', o.join(\"\"), {xmlns:XLMLNS.o });\n}\nfunction xlml_write_custprops(Props, Custprops/*::, opts*/) {\n\tvar BLACKLIST = [\"Worksheets\",\"SheetNames\"];\n\tvar T = 'CustomDocumentProperties';\n\tvar o/*:Array<string>*/ = [];\n\tif(Props) keys(Props).forEach(function(k) {\n\t\t/*:: if(!Props) return; */\n\t\tif(!Object.prototype.hasOwnProperty.call(Props, k)) return;\n\t\tfor(var i = 0; i < CORE_PROPS.length; ++i) if(k == CORE_PROPS[i][1]) return;\n\t\tfor(i = 0; i < EXT_PROPS.length; ++i) if(k == EXT_PROPS[i][1]) return;\n\t\tfor(i = 0; i < BLACKLIST.length; ++i) if(k == BLACKLIST[i]) return;\n\n\t\tvar m = Props[k];\n\t\tvar t = \"string\";\n\t\tif(typeof m == 'number') { t = \"float\"; m = String(m); }\n\t\telse if(m === true || m === false) { t = \"boolean\"; m = m ? \"1\" : \"0\"; }\n\t\telse m = String(m);\n\t\to.push(writextag(escapexmltag(k), m, {\"dt:dt\":t}));\n\t});\n\tif(Custprops) keys(Custprops).forEach(function(k) {\n\t\t/*:: if(!Custprops) return; */\n\t\tif(!Object.prototype.hasOwnProperty.call(Custprops, k)) return;\n\t\tif(Props && Object.prototype.hasOwnProperty.call(Props, k)) return;\n\t\tvar m = Custprops[k];\n\t\tvar t = \"string\";\n\t\tif(typeof m == 'number') { t = \"float\"; m = String(m); }\n\t\telse if(m === true || m === false) { t = \"boolean\"; m = m ? \"1\" : \"0\"; }\n\t\telse if(m instanceof Date) { t = \"dateTime.tz\"; m = m.toISOString(); }\n\t\telse m = String(m);\n\t\to.push(writextag(escapexmltag(k), m, {\"dt:dt\":t}));\n\t});\n\treturn '<' + T + ' xmlns=\"' + XLMLNS.o + '\">' + o.join(\"\") + '</' + T + '>';\n}\n/* [MS-DTYP] 2.3.3 FILETIME */\n/* [MS-OLEDS] 2.1.3 FILETIME (Packet Version) */\n/* [MS-OLEPS] 2.8 FILETIME (Packet Version) */\nfunction parse_FILETIME(blob) {\n\tvar dwLowDateTime = blob.read_shift(4), dwHighDateTime = blob.read_shift(4);\n\treturn new Date(((dwHighDateTime/1e7*Math.pow(2,32) + dwLowDateTime/1e7) - 11644473600)*1000).toISOString().replace(/\\.000/,\"\");\n}\nfunction write_FILETIME(time/*:string|Date*/) {\n\tvar date = (typeof time == \"string\") ? new Date(Date.parse(time)) : time;\n\tvar t = date.getTime() / 1000 + 11644473600;\n\tvar l = t % Math.pow(2,32), h = (t - l) / Math.pow(2,32);\n\tl *= 1e7; h *= 1e7;\n\tvar w = (l / Math.pow(2,32)) | 0;\n\tif(w > 0) { l = l % Math.pow(2,32); h += w; }\n\tvar o = new_buf(8); o.write_shift(4, l); o.write_shift(4, h); return o;\n}\n\n/* [MS-OSHARED] 2.3.3.1.4 Lpstr */\nfunction parse_lpstr(blob, type, pad/*:?number*/) {\n\tvar start = blob.l;\n\tvar str = blob.read_shift(0, 'lpstr-cp');\n\tif(pad) while((blob.l - start) & 3) ++blob.l;\n\treturn str;\n}\n\n/* [MS-OSHARED] 2.3.3.1.6 Lpwstr */\nfunction parse_lpwstr(blob, type, pad) {\n\tvar str = blob.read_shift(0, 'lpwstr');\n\tif(pad) blob.l += (4 - ((str.length+1) & 3)) & 3;\n\treturn str;\n}\n\n\n/* [MS-OSHARED] 2.3.3.1.11 VtString */\n/* [MS-OSHARED] 2.3.3.1.12 VtUnalignedString */\nfunction parse_VtStringBase(blob, stringType, pad) {\n\tif(stringType === 0x1F /*VT_LPWSTR*/) return parse_lpwstr(blob);\n\treturn parse_lpstr(blob, stringType, pad);\n}\n\nfunction parse_VtString(blob, t/*:number*/, pad/*:?boolean*/) { return parse_VtStringBase(blob, t, pad === false ? 0: 4); }\nfunction parse_VtUnalignedString(blob, t/*:number*/) { if(!t) throw new Error(\"VtUnalignedString must have positive length\"); return parse_VtStringBase(blob, t, 0); }\n\n/* [MS-OSHARED] 2.3.3.1.7 VtVecLpwstrValue */\nfunction parse_VtVecLpwstrValue(blob)/*:Array<string>*/ {\n\tvar length = blob.read_shift(4);\n\tvar ret/*:Array<string>*/ = [];\n\tfor(var i = 0; i != length; ++i) {\n\t\tvar start = blob.l;\n\t\tret[i] = blob.read_shift(0, 'lpwstr').replace(chr0,'');\n\t\tif((blob.l - start) & 0x02) blob.l += 2;\n\t}\n\treturn ret;\n}\n\n/* [MS-OSHARED] 2.3.3.1.9 VtVecUnalignedLpstrValue */\nfunction parse_VtVecUnalignedLpstrValue(blob)/*:Array<string>*/ {\n\tvar length = blob.read_shift(4);\n\tvar ret/*:Array<string>*/ = [];\n\tfor(var i = 0; i != length; ++i) ret[i] = blob.read_shift(0, 'lpstr-cp').replace(chr0,'');\n\treturn ret;\n}\n\n\n/* [MS-OSHARED] 2.3.3.1.13 VtHeadingPair */\nfunction parse_VtHeadingPair(blob) {\n\tvar start = blob.l;\n\tvar headingString = parse_TypedPropertyValue(blob, VT_USTR);\n\tif(blob[blob.l] == 0x00 && blob[blob.l+1] == 0x00 && ((blob.l - start) & 0x02)) blob.l += 2;\n\tvar headerParts = parse_TypedPropertyValue(blob, VT_I4);\n\treturn [headingString, headerParts];\n}\n\n/* [MS-OSHARED] 2.3.3.1.14 VtVecHeadingPairValue */\nfunction parse_VtVecHeadingPairValue(blob) {\n\tvar cElements = blob.read_shift(4);\n\tvar out = [];\n\tfor(var i = 0; i < cElements / 2; ++i) out.push(parse_VtHeadingPair(blob));\n\treturn out;\n}\n\n/* [MS-OLEPS] 2.18.1 Dictionary (uses 2.17, 2.16) */\nfunction parse_dictionary(blob,CodePage) {\n\tvar cnt = blob.read_shift(4);\n\tvar dict/*:{[number]:string}*/ = ({}/*:any*/);\n\tfor(var j = 0; j != cnt; ++j) {\n\t\tvar pid = blob.read_shift(4);\n\t\tvar len = blob.read_shift(4);\n\t\tdict[pid] = blob.read_shift(len, (CodePage === 0x4B0 ?'utf16le':'utf8')).replace(chr0,'').replace(chr1,'!');\n\t\tif(CodePage === 0x4B0 && (len % 2)) blob.l += 2;\n\t}\n\tif(blob.l & 3) blob.l = (blob.l>>2+1)<<2;\n\treturn dict;\n}\n\n/* [MS-OLEPS] 2.9 BLOB */\nfunction parse_BLOB(blob) {\n\tvar size = blob.read_shift(4);\n\tvar bytes = blob.slice(blob.l,blob.l+size);\n\tblob.l += size;\n\tif((size & 3) > 0) blob.l += (4 - (size & 3)) & 3;\n\treturn bytes;\n}\n\n/* [MS-OLEPS] 2.11 ClipboardData */\nfunction parse_ClipboardData(blob) {\n\t// TODO\n\tvar o = {};\n\to.Size = blob.read_shift(4);\n\t//o.Format = blob.read_shift(4);\n\tblob.l += o.Size + 3 - (o.Size - 1) % 4;\n\treturn o;\n}\n\n/* [MS-OLEPS] 2.15 TypedPropertyValue */\nfunction parse_TypedPropertyValue(blob, type/*:number*/, _opts)/*:any*/ {\n\tvar t = blob.read_shift(2), ret, opts = _opts||{};\n\tblob.l += 2;\n\tif(type !== VT_VARIANT)\n\tif(t !== type && VT_CUSTOM.indexOf(type)===-1 && !((type & 0xFFFE) == 0x101E && (t & 0xFFFE) == 0x101E)) throw new Error('Expected type ' + type + ' saw ' + t);\n\tswitch(type === VT_VARIANT ? t : type) {\n\t\tcase 0x02 /*VT_I2*/: ret = blob.read_shift(2, 'i'); if(!opts.raw) blob.l += 2; return ret;\n\t\tcase 0x03 /*VT_I4*/: ret = blob.read_shift(4, 'i'); return ret;\n\t\tcase 0x0B /*VT_BOOL*/: return blob.read_shift(4) !== 0x0;\n\t\tcase 0x13 /*VT_UI4*/: ret = blob.read_shift(4); return ret;\n\t\tcase 0x1E /*VT_LPSTR*/: return parse_lpstr(blob, t, 4).replace(chr0,'');\n\t\tcase 0x1F /*VT_LPWSTR*/: return parse_lpwstr(blob);\n\t\tcase 0x40 /*VT_FILETIME*/: return parse_FILETIME(blob);\n\t\tcase 0x41 /*VT_BLOB*/: return parse_BLOB(blob);\n\t\tcase 0x47 /*VT_CF*/: return parse_ClipboardData(blob);\n\t\tcase 0x50 /*VT_STRING*/: return parse_VtString(blob, t, !opts.raw).replace(chr0,'');\n\t\tcase 0x51 /*VT_USTR*/: return parse_VtUnalignedString(blob, t/*, 4*/).replace(chr0,'');\n\t\tcase 0x100C /*VT_VECTOR|VT_VARIANT*/: return parse_VtVecHeadingPairValue(blob);\n\t\tcase 0x101E /*VT_VECTOR|VT_LPSTR*/:\n\t\tcase 0x101F /*VT_VECTOR|VT_LPWSTR*/:\n\t\t\treturn t == 0x101F ? parse_VtVecLpwstrValue(blob) : parse_VtVecUnalignedLpstrValue(blob);\n\t\tdefault: throw new Error(\"TypedPropertyValue unrecognized type \" + type + \" \" + t);\n\t}\n}\nfunction write_TypedPropertyValue(type/*:number*/, value) {\n\tvar o = new_buf(4), p = new_buf(4);\n\to.write_shift(4, type == 0x50 ? 0x1F : type);\n\tswitch(type) {\n\t\tcase 0x03 /*VT_I4*/: p.write_shift(-4, value); break;\n\t\tcase 0x05 /*VT_I4*/: p = new_buf(8); p.write_shift(8, value, 'f'); break;\n\t\tcase 0x0B /*VT_BOOL*/: p.write_shift(4, value ? 0x01 : 0x00); break;\n\t\tcase 0x40 /*VT_FILETIME*/: /*:: if(typeof value !== \"string\" && !(value instanceof Date)) throw \"unreachable\"; */ p = write_FILETIME(value); break;\n\t\tcase 0x1F /*VT_LPWSTR*/:\n\t\tcase 0x50 /*VT_STRING*/:\n\t\t\t/*:: if(typeof value !== \"string\") throw \"unreachable\"; */\n\t\t\tp = new_buf(4 + 2 * (value.length + 1) + (value.length % 2 ? 0 : 2));\n\t\t\tp.write_shift(4, value.length + 1);\n\t\t\tp.write_shift(0, value, \"dbcs\");\n\t\t\twhile(p.l != p.length) p.write_shift(1, 0);\n\t\t\tbreak;\n\t\tdefault: throw new Error(\"TypedPropertyValue unrecognized type \" + type + \" \" + value);\n\t}\n\treturn bconcat([o, p]);\n}\n\n/* [MS-OLEPS] 2.20 PropertySet */\nfunction parse_PropertySet(blob, PIDSI) {\n\tvar start_addr = blob.l;\n\tvar size = blob.read_shift(4);\n\tvar NumProps = blob.read_shift(4);\n\tvar Props = [], i = 0;\n\tvar CodePage = 0;\n\tvar Dictionary = -1, DictObj/*:{[number]:string}*/ = ({}/*:any*/);\n\tfor(i = 0; i != NumProps; ++i) {\n\t\tvar PropID = blob.read_shift(4);\n\t\tvar Offset = blob.read_shift(4);\n\t\tProps[i] = [PropID, Offset + start_addr];\n\t}\n\tProps.sort(function(x,y) { return x[1] - y[1]; });\n\tvar PropH = {};\n\tfor(i = 0; i != NumProps; ++i) {\n\t\tif(blob.l !== Props[i][1]) {\n\t\t\tvar fail = true;\n\t\t\tif(i>0 && PIDSI) switch(PIDSI[Props[i-1][0]].t) {\n\t\t\t\tcase 0x02 /*VT_I2*/: if(blob.l+2 === Props[i][1]) { blob.l+=2; fail = false; } break;\n\t\t\t\tcase 0x50 /*VT_STRING*/: if(blob.l <= Props[i][1]) { blob.l=Props[i][1]; fail = false; } break;\n\t\t\t\tcase 0x100C /*VT_VECTOR|VT_VARIANT*/: if(blob.l <= Props[i][1]) { blob.l=Props[i][1]; fail = false; } break;\n\t\t\t}\n\t\t\tif((!PIDSI||i==0) && blob.l <= Props[i][1]) { fail=false; blob.l = Props[i][1]; }\n\t\t\tif(fail) throw new Error(\"Read Error: Expected address \" + Props[i][1] + ' at ' + blob.l + ' :' + i);\n\t\t}\n\t\tif(PIDSI) {\n\t\t\tvar piddsi = PIDSI[Props[i][0]];\n\t\t\tPropH[piddsi.n] = parse_TypedPropertyValue(blob, piddsi.t, {raw:true});\n\t\t\tif(piddsi.p === 'version') PropH[piddsi.n] = String(PropH[piddsi.n] >> 16) + \".\" + (\"0000\" + String(PropH[piddsi.n] & 0xFFFF)).slice(-4);\n\t\t\tif(piddsi.n == \"CodePage\") switch(PropH[piddsi.n]) {\n\t\t\t\tcase 0: PropH[piddsi.n] = 1252;\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 874:\n\t\t\t\tcase 932:\n\t\t\t\tcase 936:\n\t\t\t\tcase 949:\n\t\t\t\tcase 950:\n\t\t\t\tcase 1250:\n\t\t\t\tcase 1251:\n\t\t\t\tcase 1253:\n\t\t\t\tcase 1254:\n\t\t\t\tcase 1255:\n\t\t\t\tcase 1256:\n\t\t\t\tcase 1257:\n\t\t\t\tcase 1258:\n\t\t\t\tcase 10000:\n\t\t\t\tcase 1200:\n\t\t\t\tcase 1201:\n\t\t\t\tcase 1252:\n\t\t\t\tcase 65000: case -536:\n\t\t\t\tcase 65001: case -535:\n\t\t\t\t\tset_cp(CodePage = (PropH[piddsi.n]>>>0) & 0xFFFF); break;\n\t\t\t\tdefault: throw new Error(\"Unsupported CodePage: \" + PropH[piddsi.n]);\n\t\t\t}\n\t\t} else {\n\t\t\tif(Props[i][0] === 0x1) {\n\t\t\t\tCodePage = PropH.CodePage = (parse_TypedPropertyValue(blob, VT_I2)/*:number*/);\n\t\t\t\tset_cp(CodePage);\n\t\t\t\tif(Dictionary !== -1) {\n\t\t\t\t\tvar oldpos = blob.l;\n\t\t\t\t\tblob.l = Props[Dictionary][1];\n\t\t\t\t\tDictObj = parse_dictionary(blob,CodePage);\n\t\t\t\t\tblob.l = oldpos;\n\t\t\t\t}\n\t\t\t} else if(Props[i][0] === 0) {\n\t\t\t\tif(CodePage === 0) { Dictionary = i; blob.l = Props[i+1][1]; continue; }\n\t\t\t\tDictObj = parse_dictionary(blob,CodePage);\n\t\t\t} else {\n\t\t\t\tvar name = DictObj[Props[i][0]];\n\t\t\t\tvar val;\n\t\t\t\t/* [MS-OSHARED] 2.3.3.2.3.1.2 + PROPVARIANT */\n\t\t\t\tswitch(blob[blob.l]) {\n\t\t\t\t\tcase 0x41 /*VT_BLOB*/: blob.l += 4; val = parse_BLOB(blob); break;\n\t\t\t\t\tcase 0x1E /*VT_LPSTR*/: blob.l += 4; val = parse_VtString(blob, blob[blob.l-4]).replace(/\\u0000+$/,\"\"); break;\n\t\t\t\t\tcase 0x1F /*VT_LPWSTR*/: blob.l += 4; val = parse_VtString(blob, blob[blob.l-4]).replace(/\\u0000+$/,\"\"); break;\n\t\t\t\t\tcase 0x03 /*VT_I4*/: blob.l += 4; val = blob.read_shift(4, 'i'); break;\n\t\t\t\t\tcase 0x13 /*VT_UI4*/: blob.l += 4; val = blob.read_shift(4); break;\n\t\t\t\t\tcase 0x05 /*VT_R8*/: blob.l += 4; val = blob.read_shift(8, 'f'); break;\n\t\t\t\t\tcase 0x0B /*VT_BOOL*/: blob.l += 4; val = parsebool(blob, 4); break;\n\t\t\t\t\tcase 0x40 /*VT_FILETIME*/: blob.l += 4; val = parseDate(parse_FILETIME(blob)); break;\n\t\t\t\t\tdefault: throw new Error(\"unparsed value: \" + blob[blob.l]);\n\t\t\t\t}\n\t\t\t\tPropH[name] = val;\n\t\t\t}\n\t\t}\n\t}\n\tblob.l = start_addr + size; /* step ahead to skip padding */\n\treturn PropH;\n}\nvar XLSPSSkip = [ \"CodePage\", \"Thumbnail\", \"_PID_LINKBASE\", \"_PID_HLINKS\", \"SystemIdentifier\", \"FMTID\" ]; //.concat(PseudoPropsPairs);\nfunction guess_property_type(val/*:any*/)/*:number*/ {\n\tswitch(typeof val) {\n\t\tcase \"boolean\": return 0x0B;\n\t\tcase \"number\": return ((val|0)==val) ? 0x03 : 0x05;\n\t\tcase \"string\": return 0x1F;\n\t\tcase \"object\": if(val instanceof Date) return 0x40; break;\n\t}\n\treturn -1;\n}\nfunction write_PropertySet(entries, RE, PIDSI) {\n\tvar hdr = new_buf(8), piao = [], prop = [];\n\tvar sz = 8, i = 0;\n\n\tvar pr = new_buf(8), pio = new_buf(8);\n\tpr.write_shift(4, 0x0002);\n\tpr.write_shift(4, 0x04B0);\n\tpio.write_shift(4, 0x0001);\n\tprop.push(pr); piao.push(pio);\n\tsz += 8 + pr.length;\n\n\tif(!RE) {\n\t\tpio = new_buf(8);\n\t\tpio.write_shift(4, 0);\n\t\tpiao.unshift(pio);\n\n\t\tvar bufs = [new_buf(4)];\n\t\tbufs[0].write_shift(4, entries.length);\n\t\tfor(i = 0; i < entries.length; ++i) {\n\t\t\tvar value = entries[i][0];\n\t\t\tpr = new_buf(4 + 4 + 2 * (value.length + 1) + (value.length % 2 ? 0 : 2));\n\t\t\tpr.write_shift(4, i+2);\n\t\t\tpr.write_shift(4, value.length + 1);\n\t\t\tpr.write_shift(0, value, \"dbcs\");\n\t\t\twhile(pr.l != pr.length) pr.write_shift(1, 0);\n\t\t\tbufs.push(pr);\n\t\t}\n\t\tpr = bconcat(bufs);\n\t\tprop.unshift(pr);\n\t\tsz += 8 + pr.length;\n\t}\n\n\tfor(i = 0; i < entries.length; ++i) {\n\t\tif(RE && !RE[entries[i][0]]) continue;\n\t\tif(XLSPSSkip.indexOf(entries[i][0]) > -1 || PseudoPropsPairs.indexOf(entries[i][0]) > -1) continue;\n\t\tif(entries[i][1] == null) continue;\n\n\t\tvar val = entries[i][1], idx = 0;\n\t\tif(RE) {\n\t\t\tidx = +RE[entries[i][0]];\n\t\t\tvar pinfo = (PIDSI/*:: || {}*/)[idx]/*:: || {} */;\n\t\t\tif(pinfo.p == \"version\" && typeof val == \"string\") {\n\t\t\t\t/*:: if(typeof val !== \"string\") throw \"unreachable\"; */\n\t\t\t\tvar arr = val.split(\".\");\n\t\t\t\tval = ((+arr[0])<<16) + ((+arr[1])||0);\n\t\t\t}\n\t\t\tpr = write_TypedPropertyValue(pinfo.t, val);\n\t\t} else {\n\t\t\tvar T = guess_property_type(val);\n\t\t\tif(T == -1) { T = 0x1F; val = String(val); }\n\t\t\tpr = write_TypedPropertyValue(T, val);\n\t\t}\n\t\tprop.push(pr);\n\n\t\tpio = new_buf(8);\n\t\tpio.write_shift(4, !RE ? 2+i : idx);\n\t\tpiao.push(pio);\n\n\t\tsz += 8 + pr.length;\n\t}\n\n\tvar w = 8 * (prop.length + 1);\n\tfor(i = 0; i < prop.length; ++i) { piao[i].write_shift(4, w); w += prop[i].length; }\n\thdr.write_shift(4, sz);\n\thdr.write_shift(4, prop.length);\n\treturn bconcat([hdr].concat(piao).concat(prop));\n}\n\n/* [MS-OLEPS] 2.21 PropertySetStream */\nfunction parse_PropertySetStream(file, PIDSI, clsid) {\n\tvar blob = file.content;\n\tif(!blob) return ({}/*:any*/);\n\tprep_blob(blob, 0);\n\n\tvar NumSets, FMTID0, FMTID1, Offset0, Offset1 = 0;\n\tblob.chk('feff', 'Byte Order: ');\n\n\t/*var vers = */blob.read_shift(2); // TODO: check version\n\tvar SystemIdentifier = blob.read_shift(4);\n\tvar CLSID = blob.read_shift(16);\n\tif(CLSID !== CFB.utils.consts.HEADER_CLSID && CLSID !== clsid) throw new Error(\"Bad PropertySet CLSID \" + CLSID);\n\tNumSets = blob.read_shift(4);\n\tif(NumSets !== 1 && NumSets !== 2) throw new Error(\"Unrecognized #Sets: \" + NumSets);\n\tFMTID0 = blob.read_shift(16); Offset0 = blob.read_shift(4);\n\n\tif(NumSets === 1 && Offset0 !== blob.l) throw new Error(\"Length mismatch: \" + Offset0 + \" !== \" + blob.l);\n\telse if(NumSets === 2) { FMTID1 = blob.read_shift(16); Offset1 = blob.read_shift(4); }\n\tvar PSet0 = parse_PropertySet(blob, PIDSI);\n\n\tvar rval = ({ SystemIdentifier: SystemIdentifier }/*:any*/);\n\tfor(var y in PSet0) rval[y] = PSet0[y];\n\t//rval.blob = blob;\n\trval.FMTID = FMTID0;\n\t//rval.PSet0 = PSet0;\n\tif(NumSets === 1) return rval;\n\tif(Offset1 - blob.l == 2) blob.l += 2;\n\tif(blob.l !== Offset1) throw new Error(\"Length mismatch 2: \" + blob.l + \" !== \" + Offset1);\n\tvar PSet1;\n\ttry { PSet1 = parse_PropertySet(blob, null); } catch(e) {/* empty */}\n\tfor(y in PSet1) rval[y] = PSet1[y];\n\trval.FMTID = [FMTID0, FMTID1]; // TODO: verify FMTID0/1\n\treturn rval;\n}\nfunction write_PropertySetStream(entries, clsid, RE, PIDSI/*:{[key:string|number]:any}*/, entries2/*:?any*/, clsid2/*:?any*/) {\n\tvar hdr = new_buf(entries2 ? 68 : 48);\n\tvar bufs = [hdr];\n\thdr.write_shift(2, 0xFFFE);\n\thdr.write_shift(2, 0x0000); /* TODO: type 1 props */\n\thdr.write_shift(4, 0x32363237);\n\thdr.write_shift(16, CFB.utils.consts.HEADER_CLSID, \"hex\");\n\thdr.write_shift(4, (entries2 ? 2 : 1));\n\thdr.write_shift(16, clsid, \"hex\");\n\thdr.write_shift(4, (entries2 ? 68 : 48));\n\tvar ps0 = write_PropertySet(entries, RE, PIDSI);\n\tbufs.push(ps0);\n\n\tif(entries2) {\n\t\tvar ps1 = write_PropertySet(entries2, null, null);\n\t\thdr.write_shift(16, clsid2, \"hex\");\n\t\thdr.write_shift(4, 68 + ps0.length);\n\t\tbufs.push(ps1);\n\t}\n\treturn bconcat(bufs);\n}\n\nfunction parsenoop2(blob, length) { blob.read_shift(length); return null; }\nfunction writezeroes(n, o) { if(!o) o=new_buf(n); for(var j=0; j<n; ++j) o.write_shift(1, 0); return o; }\n\nfunction parslurp(blob, length, cb) {\n\tvar arr = [], target = blob.l + length;\n\twhile(blob.l < target) arr.push(cb(blob, target - blob.l));\n\tif(target !== blob.l) throw new Error(\"Slurp error\");\n\treturn arr;\n}\n\nfunction parsebool(blob, length/*:number*/) { return blob.read_shift(length) === 0x1; }\nfunction writebool(v/*:any*/, o) { if(!o) o=new_buf(2); o.write_shift(2, +!!v); return o; }\n\nfunction parseuint16(blob/*::, length:?number, opts:?any*/) { return blob.read_shift(2, 'u'); }\nfunction writeuint16(v/*:number*/, o) { if(!o) o=new_buf(2); o.write_shift(2, v); return o; }\nfunction parseuint16a(blob, length/*:: :?number, opts:?any*/) { return parslurp(blob,length,parseuint16);}\n\n/* --- 2.5 Structures --- */\n\n/* [MS-XLS] 2.5.10 Bes (boolean or error) */\nfunction parse_Bes(blob/*::, length*/) {\n\tvar v = blob.read_shift(1), t = blob.read_shift(1);\n\treturn t === 0x01 ? v : v === 0x01;\n}\nfunction write_Bes(v, t/*:string*/, o) {\n\tif(!o) o = new_buf(2);\n\to.write_shift(1, ((t == 'e') ? +v : +!!v));\n\to.write_shift(1, ((t == 'e') ? 1 : 0));\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.240 ShortXLUnicodeString */\nfunction parse_ShortXLUnicodeString(blob, length, opts) {\n\tvar cch = blob.read_shift(opts && opts.biff >= 12 ? 2 : 1);\n\tvar encoding = 'sbcs-cont';\n\tvar cp = current_codepage;\n\tif(opts && opts.biff >= 8) current_codepage = 1200;\n\tif(!opts || opts.biff == 8 ) {\n\t\tvar fHighByte = blob.read_shift(1);\n\t\tif(fHighByte) { encoding = 'dbcs-cont'; }\n\t} else if(opts.biff == 12) {\n\t\tencoding = 'wstr';\n\t}\n\tif(opts.biff >= 2 && opts.biff <= 5) encoding = 'cpstr';\n\tvar o = cch ? blob.read_shift(cch, encoding) : \"\";\n\tcurrent_codepage = cp;\n\treturn o;\n}\n\n/* 2.5.293 XLUnicodeRichExtendedString */\nfunction parse_XLUnicodeRichExtendedString(blob) {\n\tvar cp = current_codepage;\n\tcurrent_codepage = 1200;\n\tvar cch = blob.read_shift(2), flags = blob.read_shift(1);\n\tvar /*fHighByte = flags & 0x1,*/ fExtSt = flags & 0x4, fRichSt = flags & 0x8;\n\tvar width = 1 + (flags & 0x1); // 0x0 -> utf8, 0x1 -> dbcs\n\tvar cRun = 0, cbExtRst;\n\tvar z = {};\n\tif(fRichSt) cRun = blob.read_shift(2);\n\tif(fExtSt) cbExtRst = blob.read_shift(4);\n\tvar encoding = width == 2 ? 'dbcs-cont' : 'sbcs-cont';\n\tvar msg = cch === 0 ? \"\" : blob.read_shift(cch, encoding);\n\tif(fRichSt) blob.l += 4 * cRun; //TODO: parse this\n\tif(fExtSt) blob.l += cbExtRst; //TODO: parse this\n\tz.t = msg;\n\tif(!fRichSt) { z.raw = \"<t>\" + z.t + \"</t>\"; z.r = z.t; }\n\tcurrent_codepage = cp;\n\treturn z;\n}\nfunction write_XLUnicodeRichExtendedString(xlstr/*:: :XLString, opts*/) {\n\tvar str = (xlstr.t||\"\"), nfmts = 1;\n\n\tvar hdr = new_buf(3 + (nfmts > 1 ? 2 : 0));\n\thdr.write_shift(2, str.length);\n\thdr.write_shift(1, (nfmts > 1 ? 0x08 : 0x00) | 0x01);\n\tif(nfmts > 1) hdr.write_shift(2, nfmts);\n\n\tvar otext = new_buf(2 * str.length);\n\totext.write_shift(2 * str.length, str, 'utf16le');\n\n\tvar out = [hdr, otext];\n\n\treturn bconcat(out);\n}\n\n/* 2.5.296 XLUnicodeStringNoCch */\nfunction parse_XLUnicodeStringNoCch(blob, cch, opts) {\n\tvar retval;\n\tif(opts) {\n\t\tif(opts.biff >= 2 && opts.biff <= 5) return blob.read_shift(cch, 'cpstr');\n\t\tif(opts.biff >= 12) return blob.read_shift(cch, 'dbcs-cont');\n\t}\n\tvar fHighByte = blob.read_shift(1);\n\tif(fHighByte===0) { retval = blob.read_shift(cch, 'sbcs-cont'); }\n\telse { retval = blob.read_shift(cch, 'dbcs-cont'); }\n\treturn retval;\n}\n\n/* 2.5.294 XLUnicodeString */\nfunction parse_XLUnicodeString(blob, length, opts) {\n\tvar cch = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn parse_XLUnicodeStringNoCch(blob, cch, opts);\n}\n/* BIFF5 override */\nfunction parse_XLUnicodeString2(blob, length, opts) {\n\tif(opts.biff > 5) return parse_XLUnicodeString(blob, length, opts);\n\tvar cch = blob.read_shift(1);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn blob.read_shift(cch, (opts.biff <= 4 || !blob.lens ) ? 'cpstr' : 'sbcs-cont');\n}\n/* TODO: BIFF5 and lower, codepage awareness */\nfunction write_XLUnicodeString(str, opts, o) {\n\tif(!o) o = new_buf(3 + 2 * str.length);\n\to.write_shift(2, str.length);\n\to.write_shift(1, 1);\n\to.write_shift(31, str, 'utf16le');\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.61 ControlInfo */\nfunction parse_ControlInfo(blob/*::, length, opts*/) {\n\tvar flags = blob.read_shift(1);\n\tblob.l++;\n\tvar accel = blob.read_shift(2);\n\tblob.l += 2;\n\treturn [flags, accel];\n}\n\n/* [MS-OSHARED] 2.3.7.6 URLMoniker TODO: flags */\nfunction parse_URLMoniker(blob/*::, length, opts*/) {\n\tvar len = blob.read_shift(4), start = blob.l;\n\tvar extra = false;\n\tif(len > 24) {\n\t\t/* look ahead */\n\t\tblob.l += len - 24;\n\t\tif(blob.read_shift(16) === \"795881f43b1d7f48af2c825dc4852763\") extra = true;\n\t\tblob.l = start;\n\t}\n\tvar url = blob.read_shift((extra?len-24:len)>>1, 'utf16le').replace(chr0,\"\");\n\tif(extra) blob.l += 24;\n\treturn url;\n}\n\n/* [MS-OSHARED] 2.3.7.8 FileMoniker TODO: all fields */\nfunction parse_FileMoniker(blob/*::, length*/) {\n\tvar cAnti = blob.read_shift(2);\n\tvar preamble = \"\"; while(cAnti-- > 0) preamble += \"../\";\n\tvar ansiPath = blob.read_shift(0, 'lpstr-ansi');\n\tblob.l += 2; //var endServer = blob.read_shift(2);\n\tif(blob.read_shift(2) != 0xDEAD) throw new Error(\"Bad FileMoniker\");\n\tvar sz = blob.read_shift(4);\n\tif(sz === 0) return preamble + ansiPath.replace(/\\\\/g,\"/\");\n\tvar bytes = blob.read_shift(4);\n\tif(blob.read_shift(2) != 3) throw new Error(\"Bad FileMoniker\");\n\tvar unicodePath = blob.read_shift(bytes>>1, 'utf16le').replace(chr0,\"\");\n\treturn preamble + unicodePath;\n}\n\n/* [MS-OSHARED] 2.3.7.2 HyperlinkMoniker TODO: all the monikers */\nfunction parse_HyperlinkMoniker(blob, length) {\n\tvar clsid = blob.read_shift(16); length -= 16;\n\tswitch(clsid) {\n\t\tcase \"e0c9ea79f9bace118c8200aa004ba90b\": return parse_URLMoniker(blob, length);\n\t\tcase \"0303000000000000c000000000000046\": return parse_FileMoniker(blob, length);\n\t\tdefault: throw new Error(\"Unsupported Moniker \" + clsid);\n\t}\n}\n\n/* [MS-OSHARED] 2.3.7.9 HyperlinkString */\nfunction parse_HyperlinkString(blob/*::, length*/) {\n\tvar len = blob.read_shift(4);\n\tvar o = len > 0 ? blob.read_shift(len, 'utf16le').replace(chr0, \"\") : \"\";\n\treturn o;\n}\nfunction write_HyperlinkString(str/*:string*/, o) {\n\tif(!o) o = new_buf(6 + str.length * 2);\n\to.write_shift(4, 1 + str.length);\n\tfor(var i = 0; i < str.length; ++i) o.write_shift(2, str.charCodeAt(i));\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-OSHARED] 2.3.7.1 Hyperlink Object */\nfunction parse_Hyperlink(blob, length)/*:Hyperlink*/ {\n\tvar end = blob.l + length;\n\tvar sVer = blob.read_shift(4);\n\tif(sVer !== 2) throw new Error(\"Unrecognized streamVersion: \" + sVer);\n\tvar flags = blob.read_shift(2);\n\tblob.l += 2;\n\tvar displayName, targetFrameName, moniker, oleMoniker, Loc=\"\", guid, fileTime;\n\tif(flags & 0x0010) displayName = parse_HyperlinkString(blob, end - blob.l);\n\tif(flags & 0x0080) targetFrameName = parse_HyperlinkString(blob, end - blob.l);\n\tif((flags & 0x0101) === 0x0101) moniker = parse_HyperlinkString(blob, end - blob.l);\n\tif((flags & 0x0101) === 0x0001) oleMoniker = parse_HyperlinkMoniker(blob, end - blob.l);\n\tif(flags & 0x0008) Loc = parse_HyperlinkString(blob, end - blob.l);\n\tif(flags & 0x0020) guid = blob.read_shift(16);\n\tif(flags & 0x0040) fileTime = parse_FILETIME(blob/*, 8*/);\n\tblob.l = end;\n\tvar target = targetFrameName||moniker||oleMoniker||\"\";\n\tif(target && Loc) target+=\"#\"+Loc;\n\tif(!target) target = \"#\" + Loc;\n\tif((flags & 0x0002) && target.charAt(0) == \"/\" && target.charAt(1) != \"/\") target = \"file://\" + target;\n\tvar out = ({Target:target}/*:any*/);\n\tif(guid) out.guid = guid;\n\tif(fileTime) out.time = fileTime;\n\tif(displayName) out.Tooltip = displayName;\n\treturn out;\n}\nfunction write_Hyperlink(hl) {\n\tvar out = new_buf(512), i = 0;\n\tvar Target = hl.Target;\n\tif(Target.slice(0,7) == \"file://\") Target = Target.slice(7);\n\tvar hashidx = Target.indexOf(\"#\");\n\tvar F = hashidx > -1 ? 0x1f : 0x17;\n\tswitch(Target.charAt(0)) { case \"#\": F=0x1c; break; case \".\": F&=~2; break; }\n\tout.write_shift(4,2); out.write_shift(4, F);\n\tvar data = [8,6815827,6619237,4849780,83]; for(i = 0; i < data.length; ++i) out.write_shift(4, data[i]);\n\tif(F == 0x1C) {\n\t\tTarget = Target.slice(1);\n\t\twrite_HyperlinkString(Target, out);\n\t} else if(F & 0x02) {\n\t\tdata = \"e0 c9 ea 79 f9 ba ce 11 8c 82 00 aa 00 4b a9 0b\".split(\" \");\n\t\tfor(i = 0; i < data.length; ++i) out.write_shift(1, parseInt(data[i], 16));\n\t\tvar Pretarget = hashidx > -1 ? Target.slice(0, hashidx) : Target;\n\t\tout.write_shift(4, 2*(Pretarget.length + 1));\n\t\tfor(i = 0; i < Pretarget.length; ++i) out.write_shift(2, Pretarget.charCodeAt(i));\n\t\tout.write_shift(2, 0);\n\t\tif(F & 0x08) write_HyperlinkString(hashidx > -1 ? Target.slice(hashidx+1): \"\", out);\n\t} else {\n\t\tdata = \"03 03 00 00 00 00 00 00 c0 00 00 00 00 00 00 46\".split(\" \");\n\t\tfor(i = 0; i < data.length; ++i) out.write_shift(1, parseInt(data[i], 16));\n\t\tvar P = 0;\n\t\twhile(Target.slice(P*3,P*3+3)==\"../\"||Target.slice(P*3,P*3+3)==\"..\\\\\") ++P;\n\t\tout.write_shift(2, P);\n\t\tout.write_shift(4, Target.length - 3 * P + 1);\n\t\tfor(i = 0; i < Target.length - 3 * P; ++i) out.write_shift(1, Target.charCodeAt(i + 3 * P) & 0xFF);\n\t\tout.write_shift(1, 0);\n\t\tout.write_shift(2, 0xFFFF);\n\t\tout.write_shift(2, 0xDEAD);\n\t\tfor(i = 0; i < 6; ++i) out.write_shift(4, 0);\n\t}\n\treturn out.slice(0, out.l);\n}\n\n/* 2.5.178 LongRGBA */\nfunction parse_LongRGBA(blob/*::, length*/) { var r = blob.read_shift(1), g = blob.read_shift(1), b = blob.read_shift(1), a = blob.read_shift(1); return [r,g,b,a]; }\n\n/* 2.5.177 LongRGB */\nfunction parse_LongRGB(blob, length) { var x = parse_LongRGBA(blob, length); x[3] = 0; return x; }\n\n\n/* [MS-XLS] 2.5.19 */\nfunction parse_XLSCell(blob/*::, length*/)/*:Cell*/ {\n\tvar rw = blob.read_shift(2); // 0-indexed\n\tvar col = blob.read_shift(2);\n\tvar ixfe = blob.read_shift(2);\n\treturn ({r:rw, c:col, ixfe:ixfe}/*:any*/);\n}\nfunction write_XLSCell(R/*:number*/, C/*:number*/, ixfe/*:?number*/, o) {\n\tif(!o) o = new_buf(6);\n\to.write_shift(2, R);\n\to.write_shift(2, C);\n\to.write_shift(2, ixfe||0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.134 */\nfunction parse_frtHeader(blob) {\n\tvar rt = blob.read_shift(2);\n\tvar flags = blob.read_shift(2); // TODO: parse these flags\n\tblob.l += 8;\n\treturn {type: rt, flags: flags};\n}\n\n\n\nfunction parse_OptXLUnicodeString(blob, length, opts) { return length === 0 ? \"\" : parse_XLUnicodeString2(blob, length, opts); }\n\n/* [MS-XLS] 2.5.344 */\nfunction parse_XTI(blob, length, opts) {\n\tvar w = opts.biff > 8 ? 4 : 2;\n\tvar iSupBook = blob.read_shift(w), itabFirst = blob.read_shift(w,'i'), itabLast = blob.read_shift(w,'i');\n\treturn [iSupBook, itabFirst, itabLast];\n}\n\n/* [MS-XLS] 2.5.218 */\nfunction parse_RkRec(blob) {\n\tvar ixfe = blob.read_shift(2);\n\tvar RK = parse_RkNumber(blob);\n\treturn [ixfe, RK];\n}\n\n/* [MS-XLS] 2.5.1 */\nfunction parse_AddinUdf(blob, length, opts) {\n\tblob.l += 4; length -= 4;\n\tvar l = blob.l + length;\n\tvar udfName = parse_ShortXLUnicodeString(blob, length, opts);\n\tvar cb = blob.read_shift(2);\n\tl -= blob.l;\n\tif(cb !== l) throw new Error(\"Malformed AddinUdf: padding = \" + l + \" != \" + cb);\n\tblob.l += cb;\n\treturn udfName;\n}\n\n/* [MS-XLS] 2.5.209 TODO: Check sizes */\nfunction parse_Ref8U(blob/*::, length*/) {\n\tvar rwFirst = blob.read_shift(2);\n\tvar rwLast = blob.read_shift(2);\n\tvar colFirst = blob.read_shift(2);\n\tvar colLast = blob.read_shift(2);\n\treturn {s:{c:colFirst, r:rwFirst}, e:{c:colLast,r:rwLast}};\n}\nfunction write_Ref8U(r/*:Range*/, o) {\n\tif(!o) o = new_buf(8);\n\to.write_shift(2, r.s.r);\n\to.write_shift(2, r.e.r);\n\to.write_shift(2, r.s.c);\n\to.write_shift(2, r.e.c);\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.211 */\nfunction parse_RefU(blob/*::, length*/) {\n\tvar rwFirst = blob.read_shift(2);\n\tvar rwLast = blob.read_shift(2);\n\tvar colFirst = blob.read_shift(1);\n\tvar colLast = blob.read_shift(1);\n\treturn {s:{c:colFirst, r:rwFirst}, e:{c:colLast,r:rwLast}};\n}\n\n/* [MS-XLS] 2.5.207 */\nvar parse_Ref = parse_RefU;\n\n/* [MS-XLS] 2.5.143 */\nfunction parse_FtCmo(blob/*::, length*/) {\n\tblob.l += 4;\n\tvar ot = blob.read_shift(2);\n\tvar id = blob.read_shift(2);\n\tvar flags = blob.read_shift(2);\n\tblob.l+=12;\n\treturn [id, ot, flags];\n}\n\n/* [MS-XLS] 2.5.149 */\nfunction parse_FtNts(blob) {\n\tvar out = {};\n\tblob.l += 4;\n\tblob.l += 16; // GUID TODO\n\tout.fSharedNote = blob.read_shift(2);\n\tblob.l += 4;\n\treturn out;\n}\n\n/* [MS-XLS] 2.5.142 */\nfunction parse_FtCf(blob) {\n\tvar out = {};\n\tblob.l += 4;\n\tblob.cf = blob.read_shift(2);\n\treturn out;\n}\n\n/* [MS-XLS] 2.5.140 - 2.5.154 and friends */\nfunction parse_FtSkip(blob) { blob.l += 2; blob.l += blob.read_shift(2); }\nvar FtTab = {\n\t/*::[*/0x00/*::]*/: parse_FtSkip,      /* FtEnd */\n\t/*::[*/0x04/*::]*/: parse_FtSkip,      /* FtMacro */\n\t/*::[*/0x05/*::]*/: parse_FtSkip,      /* FtButton */\n\t/*::[*/0x06/*::]*/: parse_FtSkip,      /* FtGmo */\n\t/*::[*/0x07/*::]*/: parse_FtCf,        /* FtCf */\n\t/*::[*/0x08/*::]*/: parse_FtSkip,      /* FtPioGrbit */\n\t/*::[*/0x09/*::]*/: parse_FtSkip,      /* FtPictFmla */\n\t/*::[*/0x0A/*::]*/: parse_FtSkip,      /* FtCbls */\n\t/*::[*/0x0B/*::]*/: parse_FtSkip,      /* FtRbo */\n\t/*::[*/0x0C/*::]*/: parse_FtSkip,      /* FtSbs */\n\t/*::[*/0x0D/*::]*/: parse_FtNts,       /* FtNts */\n\t/*::[*/0x0E/*::]*/: parse_FtSkip,      /* FtSbsFmla */\n\t/*::[*/0x0F/*::]*/: parse_FtSkip,      /* FtGboData */\n\t/*::[*/0x10/*::]*/: parse_FtSkip,      /* FtEdoData */\n\t/*::[*/0x11/*::]*/: parse_FtSkip,      /* FtRboData */\n\t/*::[*/0x12/*::]*/: parse_FtSkip,      /* FtCblsData */\n\t/*::[*/0x13/*::]*/: parse_FtSkip,      /* FtLbsData */\n\t/*::[*/0x14/*::]*/: parse_FtSkip,      /* FtCblsFmla */\n\t/*::[*/0x15/*::]*/: parse_FtCmo\n};\nfunction parse_FtArray(blob, length/*::, ot*/) {\n\tvar tgt = blob.l + length;\n\tvar fts = [];\n\twhile(blob.l < tgt) {\n\t\tvar ft = blob.read_shift(2);\n\t\tblob.l-=2;\n\t\ttry {\n\t\t\tfts.push(FtTab[ft](blob, tgt - blob.l));\n\t\t} catch(e) { blob.l = tgt; return fts; }\n\t}\n\tif(blob.l != tgt) blob.l = tgt; //throw new Error(\"bad Object Ft-sequence\");\n\treturn fts;\n}\n\n/* --- 2.4 Records --- */\n\n/* [MS-XLS] 2.4.21 */\nfunction parse_BOF(blob, length) {\n\tvar o = {BIFFVer:0, dt:0};\n\to.BIFFVer = blob.read_shift(2); length -= 2;\n\tif(length >= 2) { o.dt = blob.read_shift(2); blob.l -= 2; }\n\tswitch(o.BIFFVer) {\n\t\tcase 0x0600: /* BIFF8 */\n\t\tcase 0x0500: /* BIFF5 */\n\t\tcase 0x0400: /* BIFF4 */\n\t\tcase 0x0300: /* BIFF3 */\n\t\tcase 0x0200: /* BIFF2 */\n\t\tcase 0x0002: case 0x0007: /* BIFF2 */\n\t\t\tbreak;\n\t\tdefault: if(length > 6) throw new Error(\"Unexpected BIFF Ver \" + o.BIFFVer);\n\t}\n\n\tblob.read_shift(length);\n\treturn o;\n}\nfunction write_BOF(wb/*:Workbook*/, t/*:number*/, o) {\n\tvar h = 0x0600, w = 16;\n\tswitch(o.bookType) {\n\t\tcase 'biff8': break;\n\t\tcase 'biff5': h = 0x0500; w = 8; break;\n\t\tcase 'biff4': h = 0x0004; w = 6; break;\n\t\tcase 'biff3': h = 0x0003; w = 6; break;\n\t\tcase 'biff2': h = 0x0002; w = 4; break;\n\t\tcase 'xla': break;\n\t\tdefault: throw new Error(\"unsupported BIFF version\");\n\t}\n\tvar out = new_buf(w);\n\tout.write_shift(2, h);\n\tout.write_shift(2, t);\n\tif(w > 4) out.write_shift(2, 0x7262);\n\tif(w > 6) out.write_shift(2, 0x07CD);\n\tif(w > 8) {\n\t\tout.write_shift(2, 0xC009);\n\t\tout.write_shift(2, 0x0001);\n\t\tout.write_shift(2, 0x0706);\n\t\tout.write_shift(2, 0x0000);\n\t}\n\treturn out;\n}\n\n\n/* [MS-XLS] 2.4.146 */\nfunction parse_InterfaceHdr(blob, length) {\n\tif(length === 0) return 0x04b0;\n\tif((blob.read_shift(2))!==0x04b0){/* empty */}\n\treturn 0x04b0;\n}\n\n\n/* [MS-XLS] 2.4.349 */\nfunction parse_WriteAccess(blob, length, opts) {\n\tif(opts.enc) { blob.l += length; return \"\"; }\n\tvar l = blob.l;\n\t// TODO: make sure XLUnicodeString doesnt overrun\n\tvar UserName = parse_XLUnicodeString2(blob, 0, opts);\n\tblob.read_shift(length + l - blob.l);\n\treturn UserName;\n}\nfunction write_WriteAccess(s/*:string*/, opts) {\n\tvar b8 = !opts || opts.biff == 8;\n\tvar o = new_buf(b8 ? 112 : 54);\n\to.write_shift(opts.biff == 8 ? 2 : 1, 7);\n\tif(b8) o.write_shift(1, 0);\n\to.write_shift(4, 0x33336853);\n\to.write_shift(4, (0x00534A74 | (b8 ? 0 : 0x20000000)));\n\twhile(o.l < o.length) o.write_shift(1, (b8 ? 0 : 32));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.351 */\nfunction parse_WsBool(blob, length, opts) {\n\tvar flags = opts && opts.biff == 8 || length == 2 ? blob.read_shift(2) : (blob.l += length, 0);\n\treturn { fDialog: flags & 0x10, fBelow: flags & 0x40, fRight: flags & 0x80 };\n}\n\n/* [MS-XLS] 2.4.28 */\nfunction parse_BoundSheet8(blob, length, opts) {\n\tvar pos = blob.read_shift(4);\n\tvar hidden = blob.read_shift(1) & 0x03;\n\tvar dt = blob.read_shift(1);\n\tswitch(dt) {\n\t\tcase 0: dt = 'Worksheet'; break;\n\t\tcase 1: dt = 'Macrosheet'; break;\n\t\tcase 2: dt = 'Chartsheet'; break;\n\t\tcase 6: dt = 'VBAModule'; break;\n\t}\n\tvar name = parse_ShortXLUnicodeString(blob, 0, opts);\n\tif(name.length === 0) name = \"Sheet1\";\n\treturn { pos:pos, hs:hidden, dt:dt, name:name };\n}\nfunction write_BoundSheet8(data, opts) {\n\tvar w = (!opts || opts.biff >= 8 ? 2 : 1);\n\tvar o = new_buf(8 + w * data.name.length);\n\to.write_shift(4, data.pos);\n\to.write_shift(1, data.hs || 0);\n\to.write_shift(1, data.dt);\n\to.write_shift(1, data.name.length);\n\tif(opts.biff >= 8) o.write_shift(1, 1);\n\to.write_shift(w * data.name.length, data.name, opts.biff < 8 ? 'sbcs' : 'utf16le');\n\tvar out = o.slice(0, o.l);\n\tout.l = o.l; return out;\n}\n\n/* [MS-XLS] 2.4.265 TODO */\nfunction parse_SST(blob, length)/*:SST*/ {\n\tvar end = blob.l + length;\n\tvar cnt = blob.read_shift(4);\n\tvar ucnt = blob.read_shift(4);\n\tvar strs/*:SST*/ = ([]/*:any*/);\n\tfor(var i = 0; i != ucnt && blob.l < end; ++i) {\n\t\tstrs.push(parse_XLUnicodeRichExtendedString(blob));\n\t}\n\tstrs.Count = cnt; strs.Unique = ucnt;\n\treturn strs;\n}\nfunction write_SST(sst, opts) {\n\tvar header = new_buf(8);\n\theader.write_shift(4, sst.Count);\n\theader.write_shift(4, sst.Unique);\n\tvar strs = [];\n\tfor(var j = 0; j < sst.length; ++j) strs[j] = write_XLUnicodeRichExtendedString(sst[j], opts);\n\tvar o = bconcat([header].concat(strs));\n\t/*::(*/o/*:: :any)*/.parts = [header.length].concat(strs.map(function(str) { return str.length; }));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.107 */\nfunction parse_ExtSST(blob, length) {\n\tvar extsst = {};\n\textsst.dsst = blob.read_shift(2);\n\tblob.l += length-2;\n\treturn extsst;\n}\n\n\n/* [MS-XLS] 2.4.221 TODO: check BIFF2-4 */\nfunction parse_Row(blob) {\n\tvar z = ({}/*:any*/);\n\tz.r = blob.read_shift(2);\n\tz.c = blob.read_shift(2);\n\tz.cnt = blob.read_shift(2) - z.c;\n\tvar miyRw = blob.read_shift(2);\n\tblob.l += 4; // reserved(2), unused(2)\n\tvar flags = blob.read_shift(1); // various flags\n\tblob.l += 3; // reserved(8), ixfe(12), flags(4)\n\tif(flags & 0x07) z.level = flags & 0x07;\n\t// collapsed: flags & 0x10\n\tif(flags & 0x20) z.hidden = true;\n\tif(flags & 0x40) z.hpt = miyRw / 20;\n\treturn z;\n}\n\n\n/* [MS-XLS] 2.4.125 */\nfunction parse_ForceFullCalculation(blob) {\n\tvar header = parse_frtHeader(blob);\n\tif(header.type != 0x08A3) throw new Error(\"Invalid Future Record \" + header.type);\n\tvar fullcalc = blob.read_shift(4);\n\treturn fullcalc !== 0x0;\n}\n\n\n\n\n\n/* [MS-XLS] 2.4.215 rt */\nfunction parse_RecalcId(blob) {\n\tblob.read_shift(2);\n\treturn blob.read_shift(4);\n}\n\n/* [MS-XLS] 2.4.87 */\nfunction parse_DefaultRowHeight(blob, length, opts) {\n\tvar f = 0;\n\tif(!(opts && opts.biff == 2)) {\n\t\tf = blob.read_shift(2);\n\t}\n\tvar miyRw = blob.read_shift(2);\n\tif((opts && opts.biff == 2)) {\n\t\tf = 1 - (miyRw >> 15); miyRw &= 0x7fff;\n\t}\n\tvar fl = {Unsynced:f&1,DyZero:(f&2)>>1,ExAsc:(f&4)>>2,ExDsc:(f&8)>>3};\n\treturn [fl, miyRw];\n}\n\n/* [MS-XLS] 2.4.345 TODO */\nfunction parse_Window1(blob) {\n\tvar xWn = blob.read_shift(2), yWn = blob.read_shift(2), dxWn = blob.read_shift(2), dyWn = blob.read_shift(2);\n\tvar flags = blob.read_shift(2), iTabCur = blob.read_shift(2), iTabFirst = blob.read_shift(2);\n\tvar ctabSel = blob.read_shift(2), wTabRatio = blob.read_shift(2);\n\treturn { Pos: [xWn, yWn], Dim: [dxWn, dyWn], Flags: flags, CurTab: iTabCur,\n\t\tFirstTab: iTabFirst, Selected: ctabSel, TabRatio: wTabRatio };\n}\nfunction write_Window1(/*::opts*/) {\n\tvar o = new_buf(18);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0x7260);\n\to.write_shift(2, 0x44c0);\n\to.write_shift(2, 0x38);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 1);\n\to.write_shift(2, 0x01f4);\n\treturn o;\n}\n/* [MS-XLS] 2.4.346 TODO */\nfunction parse_Window2(blob, length, opts) {\n\tif(opts && opts.biff >= 2 && opts.biff < 5) return {};\n\tvar f = blob.read_shift(2);\n\treturn { RTL: f & 0x40 };\n}\nfunction write_Window2(view) {\n\tvar o = new_buf(18), f = 0x6b6;\n\tif(view && view.RTL) f |= 0x40;\n\to.write_shift(2, f);\n\to.write_shift(4, 0);\n\to.write_shift(4, 64);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.189 TODO */\nfunction parse_Pane(/*blob, length, opts*/) {\n}\n\n/* [MS-XLS] 2.4.122 TODO */\nfunction parse_Font(blob, length, opts) {\n\tvar o/*:any*/ = {\n\t\tdyHeight: blob.read_shift(2),\n\t\tfl: blob.read_shift(2)\n\t};\n\tswitch((opts && opts.biff) || 8) {\n\t\tcase 2: break;\n\t\tcase 3: case 4: blob.l += 2; break;\n\t\tdefault: blob.l += 10; break;\n\t}\n\to.name = parse_ShortXLUnicodeString(blob, 0, opts);\n\treturn o;\n}\nfunction write_Font(data, opts) {\n\tvar name = data.name || \"Arial\";\n\tvar b5 = (opts && (opts.biff == 5)), w = (b5 ? (15 + name.length) : (16 + 2 * name.length));\n\tvar o = new_buf(w);\n\to.write_shift(2, (data.sz || 12) * 20);\n\to.write_shift(4, 0);\n\to.write_shift(2, 400);\n\to.write_shift(4, 0);\n\to.write_shift(2, 0);\n\to.write_shift(1, name.length);\n\tif(!b5) o.write_shift(1, 1);\n\to.write_shift((b5 ? 1 : 2) * name.length, name, (b5 ? \"sbcs\" : \"utf16le\"));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.149 */\nfunction parse_LabelSst(blob) {\n\tvar cell = parse_XLSCell(blob);\n\tcell.isst = blob.read_shift(4);\n\treturn cell;\n}\nfunction write_LabelSst(R/*:number*/, C/*:number*/, v/*:number*/, os/*:number*/ /*::, opts*/) {\n\tvar o = new_buf(10);\n\twrite_XLSCell(R, C, os, o);\n\to.write_shift(4, v);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.148 */\nfunction parse_Label(blob, length, opts) {\n\tif(opts.biffguess && opts.biff == 2) opts.biff = 5;\n\tvar target = blob.l + length;\n\tvar cell = parse_XLSCell(blob, 6);\n\tif(opts.biff == 2) blob.l++;\n\tvar str = parse_XLUnicodeString(blob, target - blob.l, opts);\n\tcell.val = str;\n\treturn cell;\n}\nfunction write_Label(R/*:number*/, C/*:number*/, v/*:string*/, os/*:number*/, opts) {\n\tvar b8 = !opts || opts.biff == 8;\n\tvar o = new_buf(6 + 2 + (+b8) + (1 + b8) * v.length);\n\twrite_XLSCell(R, C, os, o);\n\to.write_shift(2, v.length);\n\tif(b8) o.write_shift(1, 1);\n\to.write_shift((1 + b8) * v.length, v, b8 ? 'utf16le' : 'sbcs');\n\treturn o;\n}\n\n\n/* [MS-XLS] 2.4.126 Number Formats */\nfunction parse_Format(blob, length, opts) {\n\tvar numFmtId = blob.read_shift(2);\n\tvar fmtstr = parse_XLUnicodeString2(blob, 0, opts);\n\treturn [numFmtId, fmtstr];\n}\nfunction write_Format(i/*:number*/, f/*:string*/, opts, o) {\n\tvar b5 = (opts && (opts.biff == 5));\n\tif(!o) o = new_buf(b5 ? (3 + f.length) : (5 + 2 * f.length));\n\to.write_shift(2, i);\n\to.write_shift((b5 ? 1 : 2), f.length);\n\tif(!b5) o.write_shift(1, 1);\n\to.write_shift((b5 ? 1 : 2) * f.length, f, (b5 ? 'sbcs' : 'utf16le'));\n\tvar out = (o.length > o.l) ? o.slice(0, o.l) : o;\n\tif(out.l == null) out.l = out.length;\n\treturn out;\n}\nvar parse_BIFF2Format = parse_XLUnicodeString2;\n\n/* [MS-XLS] 2.4.90 */\nfunction parse_Dimensions(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar w = opts.biff == 8 || !opts.biff ? 4 : 2;\n\tvar r = blob.read_shift(w), R = blob.read_shift(w);\n\tvar c = blob.read_shift(2), C = blob.read_shift(2);\n\tblob.l = end;\n\treturn {s: {r:r, c:c}, e: {r:R, c:C}};\n}\nfunction write_Dimensions(range, opts) {\n\tvar w = opts.biff == 8 || !opts.biff ? 4 : 2;\n\tvar o = new_buf(2*w + 6);\n\to.write_shift(w, range.s.r);\n\to.write_shift(w, range.e.r + 1);\n\to.write_shift(2, range.s.c);\n\to.write_shift(2, range.e.c + 1);\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.220 */\nfunction parse_RK(blob) {\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar rkrec = parse_RkRec(blob);\n\treturn {r:rw, c:col, ixfe:rkrec[0], rknum:rkrec[1]};\n}\n\n/* [MS-XLS] 2.4.175 */\nfunction parse_MulRk(blob, length) {\n\tvar target = blob.l + length - 2;\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar rkrecs = [];\n\twhile(blob.l < target) rkrecs.push(parse_RkRec(blob));\n\tif(blob.l !== target) throw new Error(\"MulRK read error\");\n\tvar lastcol = blob.read_shift(2);\n\tif(rkrecs.length != lastcol - col + 1) throw new Error(\"MulRK length mismatch\");\n\treturn {r:rw, c:col, C:lastcol, rkrec:rkrecs};\n}\n/* [MS-XLS] 2.4.174 */\nfunction parse_MulBlank(blob, length) {\n\tvar target = blob.l + length - 2;\n\tvar rw = blob.read_shift(2), col = blob.read_shift(2);\n\tvar ixfes = [];\n\twhile(blob.l < target) ixfes.push(blob.read_shift(2));\n\tif(blob.l !== target) throw new Error(\"MulBlank read error\");\n\tvar lastcol = blob.read_shift(2);\n\tif(ixfes.length != lastcol - col + 1) throw new Error(\"MulBlank length mismatch\");\n\treturn {r:rw, c:col, C:lastcol, ixfe:ixfes};\n}\n\n/* [MS-XLS] 2.5.20 2.5.249 TODO: interpret values here */\nfunction parse_CellStyleXF(blob, length, style, opts) {\n\tvar o = {};\n\tvar a = blob.read_shift(4), b = blob.read_shift(4);\n\tvar c = blob.read_shift(4), d = blob.read_shift(2);\n\to.patternType = XLSFillPattern[c >> 26];\n\n\tif(!opts.cellStyles) return o;\n\to.alc = a & 0x07;\n\to.fWrap = (a >> 3) & 0x01;\n\to.alcV = (a >> 4) & 0x07;\n\to.fJustLast = (a >> 7) & 0x01;\n\to.trot = (a >> 8) & 0xFF;\n\to.cIndent = (a >> 16) & 0x0F;\n\to.fShrinkToFit = (a >> 20) & 0x01;\n\to.iReadOrder = (a >> 22) & 0x02;\n\to.fAtrNum = (a >> 26) & 0x01;\n\to.fAtrFnt = (a >> 27) & 0x01;\n\to.fAtrAlc = (a >> 28) & 0x01;\n\to.fAtrBdr = (a >> 29) & 0x01;\n\to.fAtrPat = (a >> 30) & 0x01;\n\to.fAtrProt = (a >> 31) & 0x01;\n\n\to.dgLeft = b & 0x0F;\n\to.dgRight = (b >> 4) & 0x0F;\n\to.dgTop = (b >> 8) & 0x0F;\n\to.dgBottom = (b >> 12) & 0x0F;\n\to.icvLeft = (b >> 16) & 0x7F;\n\to.icvRight = (b >> 23) & 0x7F;\n\to.grbitDiag = (b >> 30) & 0x03;\n\n\to.icvTop = c & 0x7F;\n\to.icvBottom = (c >> 7) & 0x7F;\n\to.icvDiag = (c >> 14) & 0x7F;\n\to.dgDiag = (c >> 21) & 0x0F;\n\n\to.icvFore = d & 0x7F;\n\to.icvBack = (d >> 7) & 0x7F;\n\to.fsxButton = (d >> 14) & 0x01;\n\treturn o;\n}\n//function parse_CellXF(blob, length, opts) {return parse_CellStyleXF(blob,length,0, opts);}\n//function parse_StyleXF(blob, length, opts) {return parse_CellStyleXF(blob,length,1, opts);}\n\n/* [MS-XLS] 2.4.353 TODO: actually do this right */\nfunction parse_XF(blob, length, opts) {\n\tvar o = {};\n\to.ifnt = blob.read_shift(2); o.numFmtId = blob.read_shift(2); o.flags = blob.read_shift(2);\n\to.fStyle = (o.flags >> 2) & 0x01;\n\tlength -= 6;\n\to.data = parse_CellStyleXF(blob, length, o.fStyle, opts);\n\treturn o;\n}\nfunction write_XF(data, ixfeP, opts, o) {\n\tvar b5 = (opts && (opts.biff == 5));\n\tif(!o) o = new_buf(b5 ? 16 : 20);\n\to.write_shift(2, 0);\n\tif(data.style) {\n\t\to.write_shift(2, (data.numFmtId||0));\n\t\to.write_shift(2, 0xFFF4);\n\t} else {\n\t\to.write_shift(2, (data.numFmtId||0));\n\t\to.write_shift(2, (ixfeP<<4));\n\t}\n\tvar f = 0;\n\tif(data.numFmtId > 0 && b5) f |= 0x0400;\n\to.write_shift(4, f);\n\to.write_shift(4, 0);\n\tif(!b5) o.write_shift(4, 0);\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.134 */\nfunction parse_Guts(blob) {\n\tblob.l += 4;\n\tvar out = [blob.read_shift(2), blob.read_shift(2)];\n\tif(out[0] !== 0) out[0]--;\n\tif(out[1] !== 0) out[1]--;\n\tif(out[0] > 7 || out[1] > 7) throw new Error(\"Bad Gutters: \" + out.join(\"|\"));\n\treturn out;\n}\nfunction write_Guts(guts/*:Array<number>*/) {\n\tvar o = new_buf(8);\n\to.write_shift(4, 0);\n\to.write_shift(2, guts[0] ? guts[0] + 1 : 0);\n\to.write_shift(2, guts[1] ? guts[1] + 1 : 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.24 */\nfunction parse_BoolErr(blob, length, opts) {\n\tvar cell = parse_XLSCell(blob, 6);\n\tif(opts.biff == 2 || length == 9) ++blob.l;\n\tvar val = parse_Bes(blob, 2);\n\tcell.val = val;\n\tcell.t = (val === true || val === false) ? 'b' : 'e';\n\treturn cell;\n}\nfunction write_BoolErr(R/*:number*/, C/*:number*/, v, os/*:number*/, opts, t/*:string*/) {\n\tvar o = new_buf(8);\n\twrite_XLSCell(R, C, os, o);\n\twrite_Bes(v, t, o);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.180 Number */\nfunction parse_Number(blob, length, opts) {\n\tif(opts.biffguess && opts.biff == 2) opts.biff = 5;\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar xnum = parse_Xnum(blob, 8);\n\tcell.val = xnum;\n\treturn cell;\n}\nfunction write_Number(R/*:number*/, C/*:number*/, v, os/*:: :number, opts*/) {\n\tvar o = new_buf(14);\n\twrite_XLSCell(R, C, os, o);\n\twrite_Xnum(v, o);\n\treturn o;\n}\n\nvar parse_XLHeaderFooter = parse_OptXLUnicodeString; // TODO: parse 2.4.136\n\n/* [MS-XLS] 2.4.271 */\nfunction parse_SupBook(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar ctab = blob.read_shift(2);\n\tvar cch = blob.read_shift(2);\n\topts.sbcch = cch;\n\tif(cch == 0x0401 || cch == 0x3A01) return [cch, ctab];\n\tif(cch < 0x01 || cch >0xff) throw new Error(\"Unexpected SupBook type: \"+cch);\n\tvar virtPath = parse_XLUnicodeStringNoCch(blob, cch);\n\t/* TODO: 2.5.277 Virtual Path */\n\tvar rgst = [];\n\twhile(end > blob.l) rgst.push(parse_XLUnicodeString(blob));\n\treturn [cch, ctab, virtPath, rgst];\n}\n\n/* [MS-XLS] 2.4.105 TODO */\nfunction parse_ExternName(blob, length, opts) {\n\tvar flags = blob.read_shift(2);\n\tvar body;\n\tvar o = ({\n\t\tfBuiltIn: flags & 0x01,\n\t\tfWantAdvise: (flags >>> 1) & 0x01,\n\t\tfWantPict: (flags >>> 2) & 0x01,\n\t\tfOle: (flags >>> 3) & 0x01,\n\t\tfOleLink: (flags >>> 4) & 0x01,\n\t\tcf: (flags >>> 5) & 0x3FF,\n\t\tfIcon: flags >>> 15 & 0x01\n\t}/*:any*/);\n\tif(opts.sbcch === 0x3A01) body = parse_AddinUdf(blob, length-2, opts);\n\t//else throw new Error(\"unsupported SupBook cch: \" + opts.sbcch);\n\to.body = body || blob.read_shift(length-2);\n\tif(typeof body === \"string\") o.Name = body;\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.150 TODO */\nvar XLSLblBuiltIn = [\n\t\"_xlnm.Consolidate_Area\",\n\t\"_xlnm.Auto_Open\",\n\t\"_xlnm.Auto_Close\",\n\t\"_xlnm.Extract\",\n\t\"_xlnm.Database\",\n\t\"_xlnm.Criteria\",\n\t\"_xlnm.Print_Area\",\n\t\"_xlnm.Print_Titles\",\n\t\"_xlnm.Recorder\",\n\t\"_xlnm.Data_Form\",\n\t\"_xlnm.Auto_Activate\",\n\t\"_xlnm.Auto_Deactivate\",\n\t\"_xlnm.Sheet_Title\",\n\t\"_xlnm._FilterDatabase\"\n];\nfunction parse_Lbl(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar flags = blob.read_shift(2);\n\tvar chKey = blob.read_shift(1);\n\tvar cch = blob.read_shift(1);\n\tvar cce = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\tvar itab = 0;\n\tif(!opts || opts.biff >= 5) {\n\t\tif(opts.biff != 5) blob.l += 2;\n\t\titab = blob.read_shift(2);\n\t\tif(opts.biff == 5) blob.l += 2;\n\t\tblob.l += 4;\n\t}\n\tvar name = parse_XLUnicodeStringNoCch(blob, cch, opts);\n\tif(flags & 0x20) name = XLSLblBuiltIn[name.charCodeAt(0)];\n\tvar npflen = target - blob.l; if(opts && opts.biff == 2) --npflen;\n\t/*jshint -W018 */\n\tvar rgce = (target == blob.l || cce === 0 || !(npflen > 0)) ? [] : parse_NameParsedFormula(blob, npflen, opts, cce);\n\t/*jshint +W018 */\n\treturn {\n\t\tchKey: chKey,\n\t\tName: name,\n\t\titab: itab,\n\t\trgce: rgce\n\t};\n}\n\n/* [MS-XLS] 2.4.106 TODO: verify filename encoding */\nfunction parse_ExternSheet(blob, length, opts) {\n\tif(opts.biff < 8) return parse_BIFF5ExternSheet(blob, length, opts);\n\tvar o = [], target = blob.l + length, len = blob.read_shift(opts.biff > 8 ? 4 : 2);\n\twhile(len-- !== 0) o.push(parse_XTI(blob, opts.biff > 8 ? 12 : 6, opts));\n\t\t// [iSupBook, itabFirst, itabLast];\n\tif(blob.l != target) throw new Error(\"Bad ExternSheet: \" + blob.l + \" != \" + target);\n\treturn o;\n}\nfunction parse_BIFF5ExternSheet(blob, length, opts) {\n\tif(blob[blob.l + 1] == 0x03) blob[blob.l]++;\n\tvar o = parse_ShortXLUnicodeString(blob, length, opts);\n\treturn o.charCodeAt(0) == 0x03 ? o.slice(1) : o;\n}\n\n/* [MS-XLS] 2.4.176 TODO: check older biff */\nfunction parse_NameCmt(blob, length, opts) {\n\tif(opts.biff < 8) { blob.l += length; return; }\n\tvar cchName = blob.read_shift(2);\n\tvar cchComment = blob.read_shift(2);\n\tvar name = parse_XLUnicodeStringNoCch(blob, cchName, opts);\n\tvar comment = parse_XLUnicodeStringNoCch(blob, cchComment, opts);\n\treturn [name, comment];\n}\n\n/* [MS-XLS] 2.4.260 */\nfunction parse_ShrFmla(blob, length, opts) {\n\tvar ref = parse_RefU(blob, 6);\n\tblob.l++;\n\tvar cUse = blob.read_shift(1);\n\tlength -= 8;\n\treturn [parse_SharedParsedFormula(blob, length, opts), cUse, ref];\n}\n\n/* [MS-XLS] 2.4.4 TODO */\nfunction parse_Array(blob, length, opts) {\n\tvar ref = parse_Ref(blob, 6);\n\t/* TODO: fAlwaysCalc */\n\tswitch(opts.biff) {\n\t\tcase 2: blob.l ++; length -= 7; break;\n\t\tcase 3: case 4: blob.l += 2; length -= 8; break;\n\t\tdefault: blob.l += 6; length -= 12;\n\t}\n\treturn [ref, parse_ArrayParsedFormula(blob, length, opts, ref)];\n}\n\n/* [MS-XLS] 2.4.173 */\nfunction parse_MTRSettings(blob) {\n\tvar fMTREnabled = blob.read_shift(4) !== 0x00;\n\tvar fUserSetThreadCount = blob.read_shift(4) !== 0x00;\n\tvar cUserThreadCount = blob.read_shift(4);\n\treturn [fMTREnabled, fUserSetThreadCount, cUserThreadCount];\n}\n\n/* [MS-XLS] 2.5.186 TODO: BIFF5 */\nfunction parse_NoteSh(blob, length, opts) {\n\tif(opts.biff < 8) return;\n\tvar row = blob.read_shift(2), col = blob.read_shift(2);\n\tvar flags = blob.read_shift(2), idObj = blob.read_shift(2);\n\tvar stAuthor = parse_XLUnicodeString2(blob, 0, opts);\n\tif(opts.biff < 8) blob.read_shift(1);\n\treturn [{r:row,c:col}, stAuthor, idObj, flags];\n}\n\n/* [MS-XLS] 2.4.179 */\nfunction parse_Note(blob, length, opts) {\n\t/* TODO: Support revisions */\n\treturn parse_NoteSh(blob, length, opts);\n}\n\n/* [MS-XLS] 2.4.168 */\nfunction parse_MergeCells(blob, length)/*:Array<Range>*/ {\n\tvar merges/*:Array<Range>*/ = [];\n\tvar cmcs = blob.read_shift(2);\n\twhile (cmcs--) merges.push(parse_Ref8U(blob,length));\n\treturn merges;\n}\nfunction write_MergeCells(merges/*:Array<Range>*/) {\n\tvar o = new_buf(2 + merges.length * 8);\n\to.write_shift(2, merges.length);\n\tfor(var i = 0; i < merges.length; ++i) write_Ref8U(merges[i], o);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.181 TODO: parse all the things! */\nfunction parse_Obj(blob, length, opts) {\n\tif(opts && opts.biff < 8) return parse_BIFF5Obj(blob, length, opts);\n\tvar cmo = parse_FtCmo(blob, 22); // id, ot, flags\n\tvar fts = parse_FtArray(blob, length-22, cmo[1]);\n\treturn { cmo: cmo, ft:fts };\n}\n/* from older spec */\nvar parse_BIFF5OT = {\n0x08: function(blob, length) {\n\tvar tgt = blob.l + length;\n\tblob.l += 10; // todo\n\tvar cf = blob.read_shift(2);\n\tblob.l += 4;\n\tblob.l += 2; //var cbPictFmla = blob.read_shift(2);\n\tblob.l += 2;\n\tblob.l += 2; //var grbit = blob.read_shift(2);\n\tblob.l += 4;\n\tvar cchName = blob.read_shift(1);\n\tblob.l += cchName; // TODO: stName\n\tblob.l = tgt; // TODO: fmla\n\treturn { fmt:cf };\n}\n};\n\nfunction parse_BIFF5Obj(blob, length, opts) {\n\tblob.l += 4; //var cnt = blob.read_shift(4);\n\tvar ot = blob.read_shift(2);\n\tvar id = blob.read_shift(2);\n\tvar grbit = blob.read_shift(2);\n\tblob.l += 2; //var colL = blob.read_shift(2);\n\tblob.l += 2; //var dxL = blob.read_shift(2);\n\tblob.l += 2; //var rwT = blob.read_shift(2);\n\tblob.l += 2; //var dyT = blob.read_shift(2);\n\tblob.l += 2; //var colR = blob.read_shift(2);\n\tblob.l += 2; //var dxR = blob.read_shift(2);\n\tblob.l += 2; //var rwB = blob.read_shift(2);\n\tblob.l += 2; //var dyB = blob.read_shift(2);\n\tblob.l += 2; //var cbMacro = blob.read_shift(2);\n\tblob.l += 6;\n\tlength -= 36;\n\tvar fts = [];\n\tfts.push((parse_BIFF5OT[ot]||parsenoop)(blob, length, opts));\n\treturn { cmo: [id, ot, grbit], ft:fts };\n}\n\n/* [MS-XLS] 2.4.329 TODO: parse properly */\nfunction parse_TxO(blob, length, opts) {\n\tvar s = blob.l;\n\tvar texts = \"\";\ntry {\n\tblob.l += 4;\n\tvar ot = (opts.lastobj||{cmo:[0,0]}).cmo[1];\n\tvar controlInfo; // eslint-disable-line no-unused-vars\n\tif([0,5,7,11,12,14].indexOf(ot) == -1) blob.l += 6;\n\telse controlInfo = parse_ControlInfo(blob, 6, opts); // eslint-disable-line no-unused-vars\n\tvar cchText = blob.read_shift(2);\n\t/*var cbRuns = */blob.read_shift(2);\n\t/*var ifntEmpty = */parseuint16(blob, 2);\n\tvar len = blob.read_shift(2);\n\tblob.l += len;\n\t//var fmla = parse_ObjFmla(blob, s + length - blob.l);\n\n\tfor(var i = 1; i < blob.lens.length-1; ++i) {\n\t\tif(blob.l-s != blob.lens[i]) throw new Error(\"TxO: bad continue record\");\n\t\tvar hdr = blob[blob.l];\n\t\tvar t = parse_XLUnicodeStringNoCch(blob, blob.lens[i+1]-blob.lens[i]-1);\n\t\ttexts += t;\n\t\tif(texts.length >= (hdr ? cchText : 2*cchText)) break;\n\t}\n\tif(texts.length !== cchText && texts.length !== cchText*2) {\n\t\tthrow new Error(\"cchText: \" + cchText + \" != \" + texts.length);\n\t}\n\n\tblob.l = s + length;\n\t/* [MS-XLS] 2.5.272 TxORuns */\n//\tvar rgTxoRuns = [];\n//\tfor(var j = 0; j != cbRuns/8-1; ++j) blob.l += 8;\n//\tvar cchText2 = blob.read_shift(2);\n//\tif(cchText2 !== cchText) throw new Error(\"TxOLastRun mismatch: \" + cchText2 + \" \" + cchText);\n//\tblob.l += 6;\n//\tif(s + length != blob.l) throw new Error(\"TxO \" + (s + length) + \", at \" + blob.l);\n\treturn { t: texts };\n} catch(e) { blob.l = s + length; return { t: texts }; }\n}\n\n/* [MS-XLS] 2.4.140 */\nfunction parse_HLink(blob, length) {\n\tvar ref = parse_Ref8U(blob, 8);\n\tblob.l += 16; /* CLSID */\n\tvar hlink = parse_Hyperlink(blob, length-24);\n\treturn [ref, hlink];\n}\nfunction write_HLink(hl) {\n\tvar O = new_buf(24);\n\tvar ref = decode_cell(hl[0]);\n\tO.write_shift(2, ref.r); O.write_shift(2, ref.r);\n\tO.write_shift(2, ref.c); O.write_shift(2, ref.c);\n\tvar clsid = \"d0 c9 ea 79 f9 ba ce 11 8c 82 00 aa 00 4b a9 0b\".split(\" \");\n\tfor(var i = 0; i < 16; ++i) O.write_shift(1, parseInt(clsid[i], 16));\n\treturn bconcat([O, write_Hyperlink(hl[1])]);\n}\n\n\n/* [MS-XLS] 2.4.141 */\nfunction parse_HLinkTooltip(blob, length) {\n\tblob.read_shift(2);\n\tvar ref = parse_Ref8U(blob, 8);\n\tvar wzTooltip = blob.read_shift((length-10)/2, 'dbcs-cont');\n\twzTooltip = wzTooltip.replace(chr0,\"\");\n\treturn [ref, wzTooltip];\n}\nfunction write_HLinkTooltip(hl) {\n\tvar TT = hl[1].Tooltip;\n\tvar O = new_buf(10 + 2 * (TT.length + 1));\n\tO.write_shift(2, 0x0800);\n\tvar ref = decode_cell(hl[0]);\n\tO.write_shift(2, ref.r); O.write_shift(2, ref.r);\n\tO.write_shift(2, ref.c); O.write_shift(2, ref.c);\n\tfor(var i = 0; i < TT.length; ++i) O.write_shift(2, TT.charCodeAt(i));\n\tO.write_shift(2, 0);\n\treturn O;\n}\n\n/* [MS-XLS] 2.4.63 */\nfunction parse_Country(blob)/*:[string|number, string|number]*/ {\n\tvar o = [0,0], d;\n\td = blob.read_shift(2); o[0] = CountryEnum[d] || d;\n\td = blob.read_shift(2); o[1] = CountryEnum[d] || d;\n\treturn o;\n}\nfunction write_Country(o) {\n\tif(!o) o = new_buf(4);\n\to.write_shift(2, 0x01);\n\to.write_shift(2, 0x01);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.50 ClrtClient */\nfunction parse_ClrtClient(blob) {\n\tvar ccv = blob.read_shift(2);\n\tvar o = [];\n\twhile(ccv-->0) o.push(parse_LongRGB(blob, 8));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.188 */\nfunction parse_Palette(blob) {\n\tvar ccv = blob.read_shift(2);\n\tvar o = [];\n\twhile(ccv-->0) o.push(parse_LongRGB(blob, 8));\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.354 */\nfunction parse_XFCRC(blob) {\n\tblob.l += 2;\n\tvar o = {cxfs:0, crc:0};\n\to.cxfs = blob.read_shift(2);\n\to.crc = blob.read_shift(4);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.53 TODO: parse flags */\n/* [MS-XLSB] 2.4.323 TODO: parse flags */\nfunction parse_ColInfo(blob, length, opts) {\n\tif(!opts.cellStyles) return parsenoop(blob, length);\n\tvar w = opts && opts.biff >= 12 ? 4 : 2;\n\tvar colFirst = blob.read_shift(w);\n\tvar colLast = blob.read_shift(w);\n\tvar coldx = blob.read_shift(w);\n\tvar ixfe = blob.read_shift(w);\n\tvar flags = blob.read_shift(2);\n\tif(w == 2) blob.l += 2;\n\tvar o = ({s:colFirst, e:colLast, w:coldx, ixfe:ixfe, flags:flags}/*:any*/);\n\tif(opts.biff >= 5 || !opts.biff) o.level = (flags >> 8) & 0x7;\n\treturn o;\n}\nfunction write_ColInfo(col, idx) {\n\tvar o = new_buf(12);\n\to.write_shift(2, idx);\n\to.write_shift(2, idx);\n\to.write_shift(2, col.width * 256);\n\to.write_shift(2, 0);\n\tvar f = 0;\n\tif(col.hidden) f |= 1;\n\to.write_shift(1, f);\n\tf = col.level || 0;\n\to.write_shift(1, f);\n\to.write_shift(2, 0);\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.257 */\nfunction parse_Setup(blob, length) {\n\tvar o = {};\n\tif(length < 32) return o;\n\tblob.l += 16;\n\to.header = parse_Xnum(blob, 8);\n\to.footer = parse_Xnum(blob, 8);\n\tblob.l += 2;\n\treturn o;\n}\n\n/* [MS-XLS] 2.4.261 */\nfunction parse_ShtProps(blob, length, opts) {\n\tvar def = {area:false};\n\tif(opts.biff != 5) { blob.l += length; return def; }\n\tvar d = blob.read_shift(1); blob.l += 3;\n\tif((d & 0x10)) def.area = true;\n\treturn def;\n}\n\n/* [MS-XLS] 2.4.241 */\nfunction write_RRTabId(n/*:number*/) {\n\tvar out = new_buf(2 * n);\n\tfor(var i = 0; i < n; ++i) out.write_shift(2, i+1);\n\treturn out;\n}\n\nvar parse_Blank = parse_XLSCell; /* [MS-XLS] 2.4.20 Just the cell */\nvar parse_Scl = parseuint16a; /* [MS-XLS] 2.4.247 num, den */\nvar parse_String = parse_XLUnicodeString; /* [MS-XLS] 2.4.268 */\n\n/* --- Specific to versions before BIFF8 --- */\nfunction parse_ImData(blob) {\n\tvar cf = blob.read_shift(2);\n\tvar env = blob.read_shift(2);\n\tvar lcb = blob.read_shift(4);\n\tvar o = {fmt:cf, env:env, len:lcb, data:blob.slice(blob.l,blob.l+lcb)};\n\tblob.l += lcb;\n\treturn o;\n}\n\n/* BIFF2_??? where ??? is the name from [XLS] */\nfunction parse_BIFF2STR(blob, length, opts) {\n\tif(opts.biffguess && opts.biff == 5) opts.biff = 2;\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar str = parse_XLUnicodeString2(blob, length-7, opts);\n\tcell.t = 'str';\n\tcell.val = str;\n\treturn cell;\n}\n\nfunction parse_BIFF2NUM(blob/*::, length*/) {\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar num = parse_Xnum(blob, 8);\n\tcell.t = 'n';\n\tcell.val = num;\n\treturn cell;\n}\nfunction write_BIFF2NUM(r/*:number*/, c/*:number*/, val/*:number*/) {\n\tvar out = new_buf(15);\n\twrite_BIFF2Cell(out, r, c);\n\tout.write_shift(8, val, 'f');\n\treturn out;\n}\n\nfunction parse_BIFF2INT(blob) {\n\tvar cell = parse_XLSCell(blob, 6);\n\t++blob.l;\n\tvar num = blob.read_shift(2);\n\tcell.t = 'n';\n\tcell.val = num;\n\treturn cell;\n}\nfunction write_BIFF2INT(r/*:number*/, c/*:number*/, val/*:number*/) {\n\tvar out = new_buf(9);\n\twrite_BIFF2Cell(out, r, c);\n\tout.write_shift(2, val);\n\treturn out;\n}\n\nfunction parse_BIFF2STRING(blob) {\n\tvar cch = blob.read_shift(1);\n\tif(cch === 0) { blob.l++; return \"\"; }\n\treturn blob.read_shift(cch, 'sbcs-cont');\n}\n\n/* TODO: convert to BIFF8 font struct */\nfunction parse_BIFF2FONTXTRA(blob, length) {\n\tblob.l += 6; // unknown\n\tblob.l += 2; // font weight \"bls\"\n\tblob.l += 1; // charset\n\tblob.l += 3; // unknown\n\tblob.l += 1; // font family\n\tblob.l += length - 13;\n}\n\n/* TODO: parse rich text runs */\nfunction parse_RString(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar cell = parse_XLSCell(blob, 6);\n\tvar cch = blob.read_shift(2);\n\tvar str = parse_XLUnicodeStringNoCch(blob, cch, opts);\n\tblob.l = end;\n\tcell.t = 'str';\n\tcell.val = str;\n\treturn cell;\n}\n/* from js-harb (C) 2014-present  SheetJS */\nvar DBF_SUPPORTED_VERSIONS = [0x02, 0x03, 0x30, 0x31, 0x83, 0x8B, 0x8C, 0xF5];\nvar DBF = /*#__PURE__*/(function() {\nvar dbf_codepage_map = {\n\t/* Code Pages Supported by Visual FoxPro */\n\t/*::[*/0x01/*::]*/:   437,           /*::[*/0x02/*::]*/:   850,\n\t/*::[*/0x03/*::]*/:  1252,           /*::[*/0x04/*::]*/: 10000,\n\t/*::[*/0x64/*::]*/:   852,           /*::[*/0x65/*::]*/:   866,\n\t/*::[*/0x66/*::]*/:   865,           /*::[*/0x67/*::]*/:   861,\n\t/*::[*/0x68/*::]*/:   895,           /*::[*/0x69/*::]*/:   620,\n\t/*::[*/0x6A/*::]*/:   737,           /*::[*/0x6B/*::]*/:   857,\n\t/*::[*/0x78/*::]*/:   950,           /*::[*/0x79/*::]*/:   949,\n\t/*::[*/0x7A/*::]*/:   936,           /*::[*/0x7B/*::]*/:   932,\n\t/*::[*/0x7C/*::]*/:   874,           /*::[*/0x7D/*::]*/:  1255,\n\t/*::[*/0x7E/*::]*/:  1256,           /*::[*/0x96/*::]*/: 10007,\n\t/*::[*/0x97/*::]*/: 10029,           /*::[*/0x98/*::]*/: 10006,\n\t/*::[*/0xC8/*::]*/:  1250,           /*::[*/0xC9/*::]*/:  1251,\n\t/*::[*/0xCA/*::]*/:  1254,           /*::[*/0xCB/*::]*/:  1253,\n\n\t/* shapefile DBF extension */\n\t/*::[*/0x00/*::]*/: 20127,           /*::[*/0x08/*::]*/:   865,\n\t/*::[*/0x09/*::]*/:   437,           /*::[*/0x0A/*::]*/:   850,\n\t/*::[*/0x0B/*::]*/:   437,           /*::[*/0x0D/*::]*/:   437,\n\t/*::[*/0x0E/*::]*/:   850,           /*::[*/0x0F/*::]*/:   437,\n\t/*::[*/0x10/*::]*/:   850,           /*::[*/0x11/*::]*/:   437,\n\t/*::[*/0x12/*::]*/:   850,           /*::[*/0x13/*::]*/:   932,\n\t/*::[*/0x14/*::]*/:   850,           /*::[*/0x15/*::]*/:   437,\n\t/*::[*/0x16/*::]*/:   850,           /*::[*/0x17/*::]*/:   865,\n\t/*::[*/0x18/*::]*/:   437,           /*::[*/0x19/*::]*/:   437,\n\t/*::[*/0x1A/*::]*/:   850,           /*::[*/0x1B/*::]*/:   437,\n\t/*::[*/0x1C/*::]*/:   863,           /*::[*/0x1D/*::]*/:   850,\n\t/*::[*/0x1F/*::]*/:   852,           /*::[*/0x22/*::]*/:   852,\n\t/*::[*/0x23/*::]*/:   852,           /*::[*/0x24/*::]*/:   860,\n\t/*::[*/0x25/*::]*/:   850,           /*::[*/0x26/*::]*/:   866,\n\t/*::[*/0x37/*::]*/:   850,           /*::[*/0x40/*::]*/:   852,\n\t/*::[*/0x4D/*::]*/:   936,           /*::[*/0x4E/*::]*/:   949,\n\t/*::[*/0x4F/*::]*/:   950,           /*::[*/0x50/*::]*/:   874,\n\t/*::[*/0x57/*::]*/:  1252,           /*::[*/0x58/*::]*/:  1252,\n\t/*::[*/0x59/*::]*/:  1252,           /*::[*/0x6C/*::]*/:   863,\n\t/*::[*/0x86/*::]*/:   737,           /*::[*/0x87/*::]*/:   852,\n\t/*::[*/0x88/*::]*/:   857,           /*::[*/0xCC/*::]*/:  1257,\n\n\t/*::[*/0xFF/*::]*/: 16969\n};\nvar dbf_reverse_map = evert({\n\t/*::[*/0x01/*::]*/:   437,           /*::[*/0x02/*::]*/:   850,\n\t/*::[*/0x03/*::]*/:  1252,           /*::[*/0x04/*::]*/: 10000,\n\t/*::[*/0x64/*::]*/:   852,           /*::[*/0x65/*::]*/:   866,\n\t/*::[*/0x66/*::]*/:   865,           /*::[*/0x67/*::]*/:   861,\n\t/*::[*/0x68/*::]*/:   895,           /*::[*/0x69/*::]*/:   620,\n\t/*::[*/0x6A/*::]*/:   737,           /*::[*/0x6B/*::]*/:   857,\n\t/*::[*/0x78/*::]*/:   950,           /*::[*/0x79/*::]*/:   949,\n\t/*::[*/0x7A/*::]*/:   936,           /*::[*/0x7B/*::]*/:   932,\n\t/*::[*/0x7C/*::]*/:   874,           /*::[*/0x7D/*::]*/:  1255,\n\t/*::[*/0x7E/*::]*/:  1256,           /*::[*/0x96/*::]*/: 10007,\n\t/*::[*/0x97/*::]*/: 10029,           /*::[*/0x98/*::]*/: 10006,\n\t/*::[*/0xC8/*::]*/:  1250,           /*::[*/0xC9/*::]*/:  1251,\n\t/*::[*/0xCA/*::]*/:  1254,           /*::[*/0xCB/*::]*/:  1253,\n\t/*::[*/0x00/*::]*/: 20127\n});\n/* TODO: find an actual specification */\nfunction dbf_to_aoa(buf, opts)/*:AOA*/ {\n\tvar out/*:AOA*/ = [];\n\tvar d/*:Block*/ = (new_raw_buf(1)/*:any*/);\n\tswitch(opts.type) {\n\t\tcase 'base64': d = s2a(Base64_decode(buf)); break;\n\t\tcase 'binary': d = s2a(buf); break;\n\t\tcase 'buffer':\n\t\tcase 'array': d = buf; break;\n\t}\n\tprep_blob(d, 0);\n\n\t/* header */\n\tvar ft = d.read_shift(1);\n\tvar memo = !!(ft & 0x88);\n\tvar vfp = false, l7 = false;\n\tswitch(ft) {\n\t\tcase 0x02: break; // dBASE II\n\t\tcase 0x03: break; // dBASE III\n\t\tcase 0x30: vfp = true; memo = true; break; // VFP\n\t\tcase 0x31: vfp = true; memo = true; break; // VFP with autoincrement\n\t\t// 0x43 dBASE IV SQL table files\n\t\t// 0x63 dBASE IV SQL system files\n\t\tcase 0x83: break; // dBASE III with memo\n\t\tcase 0x8B: break; // dBASE IV with memo\n\t\tcase 0x8C: l7 = true; break; // dBASE Level 7 with memo\n\t\t// case 0xCB dBASE IV SQL table files with memo\n\t\tcase 0xF5: break; // FoxPro 2.x with memo\n\t\t// case 0xFB FoxBASE\n\t\tdefault: throw new Error(\"DBF Unsupported Version: \" + ft.toString(16));\n\t}\n\n\tvar nrow = 0, fpos = 0x0209;\n\tif(ft == 0x02) nrow = d.read_shift(2);\n\td.l += 3; // dBASE II stores DDMMYY date, others use YYMMDD\n\tif(ft != 0x02) nrow = d.read_shift(4);\n\tif(nrow > 1048576) nrow = 1e6;\n\n\tif(ft != 0x02) fpos = d.read_shift(2); // header length\n\tvar rlen = d.read_shift(2); // record length\n\n\tvar /*flags = 0,*/ current_cp = opts.codepage || 1252;\n\tif(ft != 0x02) { // 20 reserved bytes\n\t\td.l+=16;\n\t\t/*flags = */d.read_shift(1);\n\t\t//if(memo && ((flags & 0x02) === 0)) throw new Error(\"DBF Flags \" + flags.toString(16) + \" ft \" + ft.toString(16));\n\n\t\t/* codepage present in FoxPro and dBASE Level 7 */\n\t\tif(d[d.l] !== 0) current_cp = dbf_codepage_map[d[d.l]];\n\t\td.l+=1;\n\n\t\td.l+=2;\n\t}\n\tif(l7) d.l += 36; // Level 7: 32 byte \"Language driver name\", 4 byte reserved\n\n/*:: type DBFField = { name:string; len:number; type:string; } */\n\tvar fields/*:Array<DBFField>*/ = [], field/*:DBFField*/ = ({}/*:any*/);\n\tvar hend = Math.min(d.length, (ft == 0x02 ? 0x209 : (fpos - 10 - (vfp ? 264 : 0))));\n\tvar ww = l7 ? 32 : 11;\n\twhile(d.l < hend && d[d.l] != 0x0d) {\n\t\tfield = ({}/*:any*/);\n\t\tfield.name = $cptable.utils.decode(current_cp, d.slice(d.l, d.l+ww)).replace(/[\\u0000\\r\\n].*$/g,\"\");\n\t\td.l += ww;\n\t\tfield.type = String.fromCharCode(d.read_shift(1));\n\t\tif(ft != 0x02 && !l7) field.offset = d.read_shift(4);\n\t\tfield.len = d.read_shift(1);\n\t\tif(ft == 0x02) field.offset = d.read_shift(2);\n\t\tfield.dec = d.read_shift(1);\n\t\tif(field.name.length) fields.push(field);\n\t\tif(ft != 0x02) d.l += l7 ? 13 : 14;\n\t\tswitch(field.type) {\n\t\t\tcase 'B': // Double (VFP) / Binary (dBASE L7)\n\t\t\t\tif((!vfp || field.len != 8) && opts.WTF) console.log('Skipping ' + field.name + ':' + field.type);\n\t\t\t\tbreak;\n\t\t\tcase 'G': // General (FoxPro and dBASE L7)\n\t\t\tcase 'P': // Picture (FoxPro and dBASE L7)\n\t\t\t\tif(opts.WTF) console.log('Skipping ' + field.name + ':' + field.type);\n\t\t\t\tbreak;\n\t\t\tcase '+': // Autoincrement (dBASE L7 only)\n\t\t\tcase '0': // _NullFlags (VFP only)\n\t\t\tcase '@': // Timestamp (dBASE L7 only)\n\t\t\tcase 'C': // Character (dBASE II)\n\t\t\tcase 'D': // Date (dBASE III)\n\t\t\tcase 'F': // Float (dBASE IV)\n\t\t\tcase 'I': // Long (VFP and dBASE L7)\n\t\t\tcase 'L': // Logical (dBASE II)\n\t\t\tcase 'M': // Memo (dBASE III)\n\t\t\tcase 'N': // Number (dBASE II)\n\t\t\tcase 'O': // Double (dBASE L7 only)\n\t\t\tcase 'T': // Datetime (VFP only)\n\t\t\tcase 'Y': // Currency (VFP only)\n\t\t\t\tbreak;\n\t\t\tdefault: throw new Error('Unknown Field Type: ' + field.type);\n\t\t}\n\t}\n\n\tif(d[d.l] !== 0x0D) d.l = fpos-1;\n\tif(d.read_shift(1) !== 0x0D) throw new Error(\"DBF Terminator not found \" + d.l + \" \" + d[d.l]);\n\td.l = fpos;\n\n\t/* data */\n\tvar R = 0, C = 0;\n\tout[0] = [];\n\tfor(C = 0; C != fields.length; ++C) out[0][C] = fields[C].name;\n\twhile(nrow-- > 0) {\n\t\tif(d[d.l] === 0x2A) {\n\t\t\t// TODO: record marked as deleted -- create a hidden row?\n\t\t\td.l+=rlen;\n\t\t\tcontinue;\n\t\t}\n\t\t++d.l;\n\t\tout[++R] = []; C = 0;\n\t\tfor(C = 0; C != fields.length; ++C) {\n\t\t\tvar dd = d.slice(d.l, d.l+fields[C].len); d.l+=fields[C].len;\n\t\t\tprep_blob(dd, 0);\n\t\t\tvar s = $cptable.utils.decode(current_cp, dd);\n\t\t\tswitch(fields[C].type) {\n\t\t\t\tcase 'C':\n\t\t\t\t\t// NOTE: it is conventional to write '  /  /  ' for empty dates\n\t\t\t\t\tif(s.trim().length) out[R][C] = s.replace(/\\s+$/,\"\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'D':\n\t\t\t\t\tif(s.length === 8) out[R][C] = new Date(+s.slice(0,4), +s.slice(4,6)-1, +s.slice(6,8));\n\t\t\t\t\telse out[R][C] = s;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'F': out[R][C] = parseFloat(s.trim()); break;\n\t\t\t\tcase '+': case 'I': out[R][C] = l7 ? dd.read_shift(-4, 'i') ^ 0x80000000 : dd.read_shift(4, 'i'); break;\n\t\t\t\tcase 'L': switch(s.trim().toUpperCase()) {\n\t\t\t\t\tcase 'Y': case 'T': out[R][C] = true; break;\n\t\t\t\t\tcase 'N': case 'F': out[R][C] = false; break;\n\t\t\t\t\tcase '': case '?': break;\n\t\t\t\t\tdefault: throw new Error(\"DBF Unrecognized L:|\" + s + \"|\");\n\t\t\t\t\t} break;\n\t\t\t\tcase 'M': /* TODO: handle memo files */\n\t\t\t\t\tif(!memo) throw new Error(\"DBF Unexpected MEMO for type \" + ft.toString(16));\n\t\t\t\t\tout[R][C] = \"##MEMO##\" + (l7 ? parseInt(s.trim(), 10): dd.read_shift(4));\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'N':\n\t\t\t\t\ts = s.replace(/\\u0000/g,\"\").trim();\n\t\t\t\t\t// NOTE: dBASE II interprets \"  .  \" as 0\n\t\t\t\t\tif(s && s != \".\") out[R][C] = +s || 0; break;\n\t\t\t\tcase '@':\n\t\t\t\t\t// NOTE: dBASE specs appear to be incorrect\n\t\t\t\t\tout[R][C] = new Date(dd.read_shift(-8, 'f') - 0x388317533400);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'T': out[R][C] = new Date((dd.read_shift(4) - 0x253D8C) * 0x5265C00 + dd.read_shift(4)); break;\n\t\t\t\tcase 'Y': out[R][C] = dd.read_shift(4,'i')/1e4 + (dd.read_shift(4, 'i')/1e4)*Math.pow(2,32); break;\n\t\t\t\tcase 'O': out[R][C] = -dd.read_shift(-8, 'f'); break;\n\t\t\t\tcase 'B': if(vfp && fields[C].len == 8) { out[R][C] = dd.read_shift(8,'f'); break; }\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 'G': case 'P': dd.l += fields[C].len; break;\n\t\t\t\tcase '0':\n\t\t\t\t\tif(fields[C].name === '_NullFlags') break;\n\t\t\t\t\t/* falls through */\n\t\t\t\tdefault: throw new Error(\"DBF Unsupported data type \" + fields[C].type);\n\t\t\t}\n\t\t}\n\t}\n\tif(ft != 0x02) if(d.l < d.length && d[d.l++] != 0x1A) throw new Error(\"DBF EOF Marker missing \" + (d.l-1) + \" of \" + d.length + \" \" + d[d.l-1].toString(16));\n\tif(opts && opts.sheetRows) out = out.slice(0, opts.sheetRows);\n\topts.DBF = fields;\n\treturn out;\n}\n\nfunction dbf_to_sheet(buf, opts)/*:Worksheet*/ {\n\tvar o = opts || {};\n\tif(!o.dateNF) o.dateNF = \"yyyymmdd\";\n\tvar ws = aoa_to_sheet(dbf_to_aoa(buf, o), o);\n\tws[\"!cols\"] = o.DBF.map(function(field) { return {\n\t\twch: field.len,\n\t\tDBF: field\n\t};});\n\tdelete o.DBF;\n\treturn ws;\n}\n\nfunction dbf_to_workbook(buf, opts)/*:Workbook*/ {\n\ttry { return sheet_to_workbook(dbf_to_sheet(buf, opts), opts); }\n\tcatch(e) { if(opts && opts.WTF) throw e; }\n\treturn ({SheetNames:[],Sheets:{}});\n}\n\nvar _RLEN = { 'B': 8, 'C': 250, 'L': 1, 'D': 8, '?': 0, '': 0 };\nfunction sheet_to_dbf(ws/*:Worksheet*/, opts/*:WriteOpts*/) {\n\tvar o = opts || {};\n\tif(+o.codepage >= 0) set_cp(+o.codepage);\n\tif(o.type == \"string\") throw new Error(\"Cannot write DBF to JS string\");\n\tvar ba = buf_array();\n\tvar aoa/*:AOA*/ = sheet_to_json(ws, {header:1, raw:true, cellDates:true});\n\tvar headers = aoa[0], data = aoa.slice(1), cols = ws[\"!cols\"] || [];\n\tvar i = 0, j = 0, hcnt = 0, rlen = 1;\n\tfor(i = 0; i < headers.length; ++i) {\n\t\tif(((cols[i]||{}).DBF||{}).name) { headers[i] = cols[i].DBF.name; ++hcnt; continue; }\n\t\tif(headers[i] == null) continue;\n\t\t++hcnt;\n\t\tif(typeof headers[i] === 'number') headers[i] = headers[i].toString(10);\n\t\tif(typeof headers[i] !== 'string') throw new Error(\"DBF Invalid column name \" + headers[i] + \" |\" + (typeof headers[i]) + \"|\");\n\t\tif(headers.indexOf(headers[i]) !== i) for(j=0; j<1024;++j)\n\t\t\tif(headers.indexOf(headers[i] + \"_\" + j) == -1) { headers[i] += \"_\" + j; break; }\n\t}\n\tvar range = safe_decode_range(ws['!ref']);\n\tvar coltypes/*:Array<string>*/ = [];\n\tvar colwidths/*:Array<number>*/ = [];\n\tvar coldecimals/*:Array<number>*/ = [];\n\tfor(i = 0; i <= range.e.c - range.s.c; ++i) {\n\t\tvar guess = '', _guess = '', maxlen = 0;\n\t\tvar col/*:Array<any>*/ = [];\n\t\tfor(j=0; j < data.length; ++j) {\n\t\t\tif(data[j][i] != null) col.push(data[j][i]);\n\t\t}\n\t\tif(col.length == 0 || headers[i] == null) { coltypes[i] = '?'; continue; }\n\t\tfor(j = 0; j < col.length; ++j) {\n\t\t\tswitch(typeof col[j]) {\n\t\t\t\t/* TODO: check if L2 compat is desired */\n\t\t\t\tcase 'number': _guess = 'B'; break;\n\t\t\t\tcase 'string': _guess = 'C'; break;\n\t\t\t\tcase 'boolean': _guess = 'L'; break;\n\t\t\t\tcase 'object': _guess = col[j] instanceof Date ? 'D' : 'C'; break;\n\t\t\t\tdefault: _guess = 'C';\n\t\t\t}\n\t\t\tmaxlen = Math.max(maxlen, String(col[j]).length);\n\t\t\tguess = guess && guess != _guess ? 'C' : _guess;\n\t\t\t//if(guess == 'C') break;\n\t\t}\n\t\tif(maxlen > 250) maxlen = 250;\n\t\t_guess = ((cols[i]||{}).DBF||{}).type;\n\t\t/* TODO: more fine grained control over DBF type resolution */\n\t\tif(_guess == 'C') {\n\t\t\tif(cols[i].DBF.len > maxlen) maxlen = cols[i].DBF.len;\n\t\t}\n\t\tif(guess == 'B' && _guess == 'N') {\n\t\t\tguess = 'N';\n\t\t\tcoldecimals[i] = cols[i].DBF.dec;\n\t\t\tmaxlen = cols[i].DBF.len;\n\t\t}\n\t\tcolwidths[i] = guess == 'C' || _guess == 'N' ? maxlen : (_RLEN[guess] || 0);\n\t\trlen += colwidths[i];\n\t\tcoltypes[i] = guess;\n\t}\n\n\tvar h = ba.next(32);\n\th.write_shift(4, 0x13021130);\n\th.write_shift(4, data.length);\n\th.write_shift(2, 296 + 32 * hcnt);\n\th.write_shift(2, rlen);\n\tfor(i=0; i < 4; ++i) h.write_shift(4, 0);\n\th.write_shift(4, 0x00000000 | ((+dbf_reverse_map[/*::String(*/current_ansi/*::)*/] || 0x03)<<8));\n\n\tfor(i = 0, j = 0; i < headers.length; ++i) {\n\t\tif(headers[i] == null) continue;\n\t\tvar hf = ba.next(32);\n\t\tvar _f = (headers[i].slice(-10) + \"\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\").slice(0, 11);\n\t\thf.write_shift(1, _f, \"sbcs\");\n\t\thf.write_shift(1, coltypes[i] == '?' ? 'C' : coltypes[i], \"sbcs\");\n\t\thf.write_shift(4, j);\n\t\thf.write_shift(1, colwidths[i] || _RLEN[coltypes[i]] || 0);\n\t\thf.write_shift(1, coldecimals[i] || 0);\n\t\thf.write_shift(1, 0x02);\n\t\thf.write_shift(4, 0);\n\t\thf.write_shift(1, 0);\n\t\thf.write_shift(4, 0);\n\t\thf.write_shift(4, 0);\n\t\tj += (colwidths[i] || _RLEN[coltypes[i]] || 0);\n\t}\n\n\tvar hb = ba.next(264);\n\thb.write_shift(4, 0x0000000D);\n\tfor(i=0; i < 65;++i) hb.write_shift(4, 0x00000000);\n\tfor(i=0; i < data.length; ++i) {\n\t\tvar rout = ba.next(rlen);\n\t\trout.write_shift(1, 0);\n\t\tfor(j=0; j<headers.length; ++j) {\n\t\t\tif(headers[j] == null) continue;\n\t\t\tswitch(coltypes[j]) {\n\t\t\t\tcase 'L': rout.write_shift(1, data[i][j] == null ? 0x3F : data[i][j] ? 0x54 : 0x46); break;\n\t\t\t\tcase 'B': rout.write_shift(8, data[i][j]||0, 'f'); break;\n\t\t\t\tcase 'N':\n\t\t\t\t\tvar _n = \"0\";\n\t\t\t\t\tif(typeof data[i][j] == \"number\") _n = data[i][j].toFixed(coldecimals[j]||0);\n\t\t\t\t\tfor(hcnt=0; hcnt < colwidths[j]-_n.length; ++hcnt) rout.write_shift(1, 0x20);\n\t\t\t\t\trout.write_shift(1, _n, \"sbcs\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'D':\n\t\t\t\t\tif(!data[i][j]) rout.write_shift(8, \"00000000\", \"sbcs\");\n\t\t\t\t\telse {\n\t\t\t\t\t\trout.write_shift(4, (\"0000\"+data[i][j].getFullYear()).slice(-4), \"sbcs\");\n\t\t\t\t\t\trout.write_shift(2, (\"00\"+(data[i][j].getMonth()+1)).slice(-2), \"sbcs\");\n\t\t\t\t\t\trout.write_shift(2, (\"00\"+data[i][j].getDate()).slice(-2), \"sbcs\");\n\t\t\t\t\t} break;\n\t\t\t\tcase 'C':\n\t\t\t\t\tvar _s = String(data[i][j] != null ? data[i][j] : \"\").slice(0, colwidths[j]);\n\t\t\t\t\trout.write_shift(1, _s, \"sbcs\");\n\t\t\t\t\tfor(hcnt=0; hcnt < colwidths[j]-_s.length; ++hcnt) rout.write_shift(1, 0x20); break;\n\t\t\t}\n\t\t}\n\t\t// data\n\t}\n\tba.next(1).write_shift(1, 0x1A);\n\treturn ba.end();\n}\n\treturn {\n\t\tto_workbook: dbf_to_workbook,\n\t\tto_sheet: dbf_to_sheet,\n\t\tfrom_sheet: sheet_to_dbf\n\t};\n})();\n\nvar SYLK = /*#__PURE__*/(function() {\n\t/* TODO: stress test sequences */\n\tvar sylk_escapes = ({\n\t\tAA:'À', BA:'Á', CA:'Â', DA:195, HA:'Ä', JA:197,\n\t\tAE:'È', BE:'É', CE:'Ê',         HE:'Ë',\n\t\tAI:'Ì', BI:'Í', CI:'Î',         HI:'Ï',\n\t\tAO:'Ò', BO:'Ó', CO:'Ô', DO:213, HO:'Ö',\n\t\tAU:'Ù', BU:'Ú', CU:'Û',         HU:'Ü',\n\t\tAa:'à', Ba:'á', Ca:'â', Da:227, Ha:'ä', Ja:229,\n\t\tAe:'è', Be:'é', Ce:'ê',         He:'ë',\n\t\tAi:'ì', Bi:'í', Ci:'î',         Hi:'ï',\n\t\tAo:'ò', Bo:'ó', Co:'ô', Do:245, Ho:'ö',\n\t\tAu:'ù', Bu:'ú', Cu:'û',         Hu:'ü',\n\t\tKC:'Ç', Kc:'ç', q:'æ',  z:'œ',  a:'Æ',  j:'Œ',\n\t\tDN:209, Dn:241, Hy:255,\n\t\tS:169,  c:170,  R:174,  \"B \":180,\n\t\t/*::[*/0/*::]*/:176,    /*::[*/1/*::]*/:177,  /*::[*/2/*::]*/:178,\n\t\t/*::[*/3/*::]*/:179,    /*::[*/5/*::]*/:181,  /*::[*/6/*::]*/:182,\n\t\t/*::[*/7/*::]*/:183,    Q:185,  k:186,  b:208,  i:216,  l:222,  s:240,  y:248,\n\t\t\"!\":161, '\"':162, \"#\":163, \"(\":164, \"%\":165, \"'\":167, \"H \":168,\n\t\t\"+\":171, \";\":187, \"<\":188, \"=\":189, \">\":190, \"?\":191, \"{\":223\n\t}/*:any*/);\n\tvar sylk_char_regex = new RegExp(\"\\u001BN(\" + keys(sylk_escapes).join(\"|\").replace(/\\|\\|\\|/, \"|\\\\||\").replace(/([?()+])/g,\"\\\\$1\") + \"|\\\\|)\", \"gm\");\n\tvar sylk_char_fn = function(_, $1){ var o = sylk_escapes[$1]; return typeof o == \"number\" ? _getansi(o) : o; };\n\tvar decode_sylk_char = function($$, $1, $2) { var newcc = (($1.charCodeAt(0) - 0x20)<<4) | ($2.charCodeAt(0) - 0x30); return newcc == 59 ? $$ : _getansi(newcc); };\n\tsylk_escapes[\"|\"] = 254;\n\t/* TODO: find an actual specification */\n\tfunction sylk_to_aoa(d/*:RawData*/, opts)/*:[AOA, Worksheet]*/ {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return sylk_to_aoa_str(Base64_decode(d), opts);\n\t\t\tcase 'binary': return sylk_to_aoa_str(d, opts);\n\t\t\tcase 'buffer': return sylk_to_aoa_str(has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d), opts);\n\t\t\tcase 'array': return sylk_to_aoa_str(cc2str(d), opts);\n\t\t}\n\t\tthrow new Error(\"Unrecognized type \" + opts.type);\n\t}\n\tfunction sylk_to_aoa_str(str/*:string*/, opts)/*:[AOA, Worksheet]*/ {\n\t\tvar records = str.split(/[\\n\\r]+/), R = -1, C = -1, ri = 0, rj = 0, arr/*:AOA*/ = [];\n\t\tvar formats/*:Array<string>*/ = [];\n\t\tvar next_cell_format/*:string|null*/ = null;\n\t\tvar sht = {}, rowinfo/*:Array<RowInfo>*/ = [], colinfo/*:Array<ColInfo>*/ = [], cw/*:Array<string>*/ = [];\n\t\tvar Mval = 0, j;\n\t\tif(+opts.codepage >= 0) set_cp(+opts.codepage);\n\t\tfor (; ri !== records.length; ++ri) {\n\t\t\tMval = 0;\n\t\t\tvar rstr=records[ri].trim().replace(/\\x1B([\\x20-\\x2F])([\\x30-\\x3F])/g, decode_sylk_char).replace(sylk_char_regex, sylk_char_fn);\n\t\t\tvar record=rstr.replace(/;;/g, \"\\u0000\").split(\";\").map(function(x) { return x.replace(/\\u0000/g, \";\"); });\n\t\t\tvar RT=record[0], val;\n\t\t\tif(rstr.length > 0) switch(RT) {\n\t\t\tcase 'ID': break; /* header */\n\t\t\tcase 'E': break; /* EOF */\n\t\t\tcase 'B': break; /* dimensions */\n\t\t\tcase 'O': break; /* options? */\n\t\t\tcase 'W': break; /* window? */\n\t\t\tcase 'P':\n\t\t\t\tif(record[1].charAt(0) == 'P')\n\t\t\t\t\tformats.push(rstr.slice(3).replace(/;;/g, \";\"));\n\t\t\t\tbreak;\n\t\t\tcase 'C':\n\t\t\tvar C_seen_K = false, C_seen_X = false, C_seen_S = false, C_seen_E = false, _R = -1, _C = -1;\n\t\t\tfor(rj=1; rj<record.length; ++rj) switch(record[rj].charAt(0)) {\n\t\t\t\tcase 'A': break; // TODO: comment\n\t\t\t\tcase 'X': C = parseInt(record[rj].slice(1))-1; C_seen_X = true; break;\n\t\t\t\tcase 'Y':\n\t\t\t\t\tR = parseInt(record[rj].slice(1))-1; if(!C_seen_X) C = 0;\n\t\t\t\t\tfor(j = arr.length; j <= R; ++j) arr[j] = [];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'K':\n\t\t\t\t\tval = record[rj].slice(1);\n\t\t\t\t\tif(val.charAt(0) === '\"') val = val.slice(1,val.length - 1);\n\t\t\t\t\telse if(val === 'TRUE') val = true;\n\t\t\t\t\telse if(val === 'FALSE') val = false;\n\t\t\t\t\telse if(!isNaN(fuzzynum(val))) {\n\t\t\t\t\t\tval = fuzzynum(val);\n\t\t\t\t\t\tif(next_cell_format !== null && fmt_is_date(next_cell_format)) val = numdate(val);\n\t\t\t\t\t} else if(!isNaN(fuzzydate(val).getDate())) {\n\t\t\t\t\t\tval = parseDate(val);\n\t\t\t\t\t}\n\t\t\t\t\tif(typeof $cptable !== 'undefined' && typeof val == \"string\" && ((opts||{}).type != \"string\") && (opts||{}).codepage) val = $cptable.utils.decode(opts.codepage, val);\n\t\t\t\t\tC_seen_K = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'E':\n\t\t\t\t\tC_seen_E = true;\n\t\t\t\t\tvar formula = rc_to_a1(record[rj].slice(1), {r:R,c:C});\n\t\t\t\t\tarr[R][C] = [arr[R][C], formula];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'S':\n\t\t\t\t\tC_seen_S = true;\n\t\t\t\t\tarr[R][C] = [arr[R][C], \"S5S\"];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'G': break; // unknown\n\t\t\t\tcase 'R': _R = parseInt(record[rj].slice(1))-1; break;\n\t\t\t\tcase 'C': _C = parseInt(record[rj].slice(1))-1; break;\n\t\t\t\tdefault: if(opts && opts.WTF) throw new Error(\"SYLK bad record \" + rstr);\n\t\t\t}\n\t\t\tif(C_seen_K) {\n\t\t\t\tif(arr[R][C] && arr[R][C].length == 2) arr[R][C][0] = val;\n\t\t\t\telse arr[R][C] = val;\n\t\t\t\tnext_cell_format = null;\n\t\t\t}\n\t\t\tif(C_seen_S) {\n\t\t\t\tif(C_seen_E) throw new Error(\"SYLK shared formula cannot have own formula\");\n\t\t\t\tvar shrbase = _R > -1 && arr[_R][_C];\n\t\t\t\tif(!shrbase || !shrbase[1]) throw new Error(\"SYLK shared formula cannot find base\");\n\t\t\t\tarr[R][C][1] = shift_formula_str(shrbase[1], {r: R - _R, c: C - _C});\n\t\t\t}\n\t\t\tbreak;\n\t\t\tcase 'F':\n\t\t\tvar F_seen = 0;\n\t\t\tfor(rj=1; rj<record.length; ++rj) switch(record[rj].charAt(0)) {\n\t\t\t\tcase 'X': C = parseInt(record[rj].slice(1))-1; ++F_seen; break;\n\t\t\t\tcase 'Y':\n\t\t\t\t\tR = parseInt(record[rj].slice(1))-1; /*C = 0;*/\n\t\t\t\t\tfor(j = arr.length; j <= R; ++j) arr[j] = [];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'M': Mval = parseInt(record[rj].slice(1)) / 20; break;\n\t\t\t\tcase 'F': break; /* ??? */\n\t\t\t\tcase 'G': break; /* hide grid */\n\t\t\t\tcase 'P':\n\t\t\t\t\tnext_cell_format = formats[parseInt(record[rj].slice(1))];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'S': break; /* cell style */\n\t\t\t\tcase 'D': break; /* column */\n\t\t\t\tcase 'N': break; /* font */\n\t\t\t\tcase 'W':\n\t\t\t\t\tcw = record[rj].slice(1).split(\" \");\n\t\t\t\t\tfor(j = parseInt(cw[0], 10); j <= parseInt(cw[1], 10); ++j) {\n\t\t\t\t\t\tMval = parseInt(cw[2], 10);\n\t\t\t\t\t\tcolinfo[j-1] = Mval === 0 ? {hidden:true}: {wch:Mval}; process_col(colinfo[j-1]);\n\t\t\t\t\t} break;\n\t\t\t\tcase 'C': /* default column format */\n\t\t\t\t\tC = parseInt(record[rj].slice(1))-1;\n\t\t\t\t\tif(!colinfo[C]) colinfo[C] = {};\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'R': /* row properties */\n\t\t\t\t\tR = parseInt(record[rj].slice(1))-1;\n\t\t\t\t\tif(!rowinfo[R]) rowinfo[R] = {};\n\t\t\t\t\tif(Mval > 0) { rowinfo[R].hpt = Mval; rowinfo[R].hpx = pt2px(Mval); }\n\t\t\t\t\telse if(Mval === 0) rowinfo[R].hidden = true;\n\t\t\t\t\tbreak;\n\t\t\t\tdefault: if(opts && opts.WTF) throw new Error(\"SYLK bad record \" + rstr);\n\t\t\t}\n\t\t\tif(F_seen < 1) next_cell_format = null; break;\n\t\t\tdefault: if(opts && opts.WTF) throw new Error(\"SYLK bad record \" + rstr);\n\t\t\t}\n\t\t}\n\t\tif(rowinfo.length > 0) sht['!rows'] = rowinfo;\n\t\tif(colinfo.length > 0) sht['!cols'] = colinfo;\n\t\tif(opts && opts.sheetRows) arr = arr.slice(0, opts.sheetRows);\n\t\treturn [arr, sht];\n\t}\n\n\tfunction sylk_to_sheet(d/*:RawData*/, opts)/*:Worksheet*/ {\n\t\tvar aoasht = sylk_to_aoa(d, opts);\n\t\tvar aoa = aoasht[0], ws = aoasht[1];\n\t\tvar o = aoa_to_sheet(aoa, opts);\n\t\tkeys(ws).forEach(function(k) { o[k] = ws[k]; });\n\t\treturn o;\n\t}\n\n\tfunction sylk_to_workbook(d/*:RawData*/, opts)/*:Workbook*/ { return sheet_to_workbook(sylk_to_sheet(d, opts), opts); }\n\n\tfunction write_ws_cell_sylk(cell/*:Cell*/, ws/*:Worksheet*/, R/*:number*/, C/*:number*//*::, opts*/)/*:string*/ {\n\t\tvar o = \"C;Y\" + (R+1) + \";X\" + (C+1) + \";K\";\n\t\tswitch(cell.t) {\n\t\t\tcase 'n':\n\t\t\t\to += (cell.v||0);\n\t\t\t\tif(cell.f && !cell.F) o += \";E\" + a1_to_rc(cell.f, {r:R, c:C}); break;\n\t\t\tcase 'b': o += cell.v ? \"TRUE\" : \"FALSE\"; break;\n\t\t\tcase 'e': o += cell.w || cell.v; break;\n\t\t\tcase 'd': o += '\"' + (cell.w || cell.v) + '\"'; break;\n\t\t\tcase 's': o += '\"' + cell.v.replace(/\"/g,\"\").replace(/;/g, \";;\") + '\"'; break;\n\t\t}\n\t\treturn o;\n\t}\n\n\tfunction write_ws_cols_sylk(out, cols) {\n\t\tcols.forEach(function(col, i) {\n\t\t\tvar rec = \"F;W\" + (i+1) + \" \" + (i+1) + \" \";\n\t\t\tif(col.hidden) rec += \"0\";\n\t\t\telse {\n\t\t\t\tif(typeof col.width == 'number' && !col.wpx) col.wpx = width2px(col.width);\n\t\t\t\tif(typeof col.wpx == 'number' && !col.wch) col.wch = px2char(col.wpx);\n\t\t\t\tif(typeof col.wch == 'number') rec += Math.round(col.wch);\n\t\t\t}\n\t\t\tif(rec.charAt(rec.length - 1) != \" \") out.push(rec);\n\t\t});\n\t}\n\n\tfunction write_ws_rows_sylk(out/*:Array<string>*/, rows/*:Array<RowInfo>*/) {\n\t\trows.forEach(function(row, i) {\n\t\t\tvar rec = \"F;\";\n\t\t\tif(row.hidden) rec += \"M0;\";\n\t\t\telse if(row.hpt) rec += \"M\" + 20 * row.hpt + \";\";\n\t\t\telse if(row.hpx) rec += \"M\" + 20 * px2pt(row.hpx) + \";\";\n\t\t\tif(rec.length > 2) out.push(rec + \"R\" + (i+1));\n\t\t});\n\t}\n\n\tfunction sheet_to_sylk(ws/*:Worksheet*/, opts/*:?any*/)/*:string*/ {\n\t\tvar preamble/*:Array<string>*/ = [\"ID;PWXL;N;E\"], o/*:Array<string>*/ = [];\n\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\tvar dense = Array.isArray(ws);\n\t\tvar RS = \"\\r\\n\";\n\n\t\tpreamble.push(\"P;PGeneral\");\n\t\tpreamble.push(\"F;P0;DG0G8;M255\");\n\t\tif(ws['!cols']) write_ws_cols_sylk(preamble, ws['!cols']);\n\t\tif(ws['!rows']) write_ws_rows_sylk(preamble, ws['!rows']);\n\n\t\tpreamble.push(\"B;Y\" + (r.e.r - r.s.r + 1) + \";X\" + (r.e.c - r.s.c + 1) + \";D\" + [r.s.c,r.s.r,r.e.c,r.e.r].join(\" \"));\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C]: ws[coord];\n\t\t\t\tif(!cell || (cell.v == null && (!cell.f || cell.F))) continue;\n\t\t\t\to.push(write_ws_cell_sylk(cell, ws, R, C, opts));\n\t\t\t}\n\t\t}\n\t\treturn preamble.join(RS) + RS + o.join(RS) + RS + \"E\" + RS;\n\t}\n\n\treturn {\n\t\tto_workbook: sylk_to_workbook,\n\t\tto_sheet: sylk_to_sheet,\n\t\tfrom_sheet: sheet_to_sylk\n\t};\n})();\n\nvar DIF = /*#__PURE__*/(function() {\n\tfunction dif_to_aoa(d/*:RawData*/, opts)/*:AOA*/ {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return dif_to_aoa_str(Base64_decode(d), opts);\n\t\t\tcase 'binary': return dif_to_aoa_str(d, opts);\n\t\t\tcase 'buffer': return dif_to_aoa_str(has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d), opts);\n\t\t\tcase 'array': return dif_to_aoa_str(cc2str(d), opts);\n\t\t}\n\t\tthrow new Error(\"Unrecognized type \" + opts.type);\n\t}\n\tfunction dif_to_aoa_str(str/*:string*/, opts)/*:AOA*/ {\n\t\tvar records = str.split('\\n'), R = -1, C = -1, ri = 0, arr/*:AOA*/ = [];\n\t\tfor (; ri !== records.length; ++ri) {\n\t\t\tif (records[ri].trim() === 'BOT') { arr[++R] = []; C = 0; continue; }\n\t\t\tif (R < 0) continue;\n\t\t\tvar metadata = records[ri].trim().split(\",\");\n\t\t\tvar type = metadata[0], value = metadata[1];\n\t\t\t++ri;\n\t\t\tvar data = records[ri] || \"\";\n\t\t\twhile(((data.match(/[\"]/g)||[]).length & 1) && ri < records.length - 1) data += \"\\n\" + records[++ri];\n\t\t\tdata = data.trim();\n\t\t\tswitch (+type) {\n\t\t\t\tcase -1:\n\t\t\t\t\tif (data === 'BOT') { arr[++R] = []; C = 0; continue; }\n\t\t\t\t\telse if (data !== 'EOD') throw new Error(\"Unrecognized DIF special command \" + data);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0:\n\t\t\t\t\tif(data === 'TRUE') arr[R][C] = true;\n\t\t\t\t\telse if(data === 'FALSE') arr[R][C] = false;\n\t\t\t\t\telse if(!isNaN(fuzzynum(value))) arr[R][C] = fuzzynum(value);\n\t\t\t\t\telse if(!isNaN(fuzzydate(value).getDate())) arr[R][C] = parseDate(value);\n\t\t\t\t\telse arr[R][C] = value;\n\t\t\t\t\t++C; break;\n\t\t\t\tcase 1:\n\t\t\t\t\tdata = data.slice(1,data.length-1);\n\t\t\t\t\tdata = data.replace(/\"\"/g, '\"');\n\t\t\t\t\tif(DIF_XL && data && data.match(/^=\".*\"$/)) data = data.slice(2, -1);\n\t\t\t\t\tarr[R][C++] = data !== '' ? data : null;\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (data === 'EOD') break;\n\t\t}\n\t\tif(opts && opts.sheetRows) arr = arr.slice(0, opts.sheetRows);\n\t\treturn arr;\n\t}\n\n\tfunction dif_to_sheet(str/*:string*/, opts)/*:Worksheet*/ { return aoa_to_sheet(dif_to_aoa(str, opts), opts); }\n\tfunction dif_to_workbook(str/*:string*/, opts)/*:Workbook*/ { return sheet_to_workbook(dif_to_sheet(str, opts), opts); }\n\n\tvar sheet_to_dif = /*#__PURE__*/(function() {\n\t\tvar push_field = function pf(o/*:Array<string>*/, topic/*:string*/, v/*:number*/, n/*:number*/, s/*:string*/) {\n\t\t\to.push(topic);\n\t\t\to.push(v + \",\" + n);\n\t\t\to.push('\"' + s.replace(/\"/g,'\"\"') + '\"');\n\t\t};\n\t\tvar push_value = function po(o/*:Array<string>*/, type/*:number*/, v/*:any*/, s/*:string*/) {\n\t\t\to.push(type + \",\" + v);\n\t\t\to.push(type == 1 ? '\"' + s.replace(/\"/g,'\"\"') + '\"' : s);\n\t\t};\n\t\treturn function sheet_to_dif(ws/*:Worksheet*//*::, opts:?any*/)/*:string*/ {\n\t\t\tvar o/*:Array<string>*/ = [];\n\t\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\t\tvar dense = Array.isArray(ws);\n\t\t\tpush_field(o, \"TABLE\", 0, 1, \"sheetjs\");\n\t\t\tpush_field(o, \"VECTORS\", 0, r.e.r - r.s.r + 1,\"\");\n\t\t\tpush_field(o, \"TUPLES\", 0, r.e.c - r.s.c + 1,\"\");\n\t\t\tpush_field(o, \"DATA\", 0, 0,\"\");\n\t\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\t\tpush_value(o, -1, 0, \"BOT\");\n\t\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\t\tcell = dense ? (ws[R]||[])[C] : ws[coord];\n\t\t\t\t\tif(!cell) { push_value(o, 1, 0, \"\"); continue;}\n\t\t\t\t\tswitch(cell.t) {\n\t\t\t\t\t\tcase 'n':\n\t\t\t\t\t\t\tvar val = DIF_XL ? cell.w : cell.v;\n\t\t\t\t\t\t\tif(!val && cell.v != null) val = cell.v;\n\t\t\t\t\t\t\tif(val == null) {\n\t\t\t\t\t\t\t\tif(DIF_XL && cell.f && !cell.F) push_value(o, 1, 0, \"=\" + cell.f);\n\t\t\t\t\t\t\t\telse push_value(o, 1, 0, \"\");\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\telse push_value(o, 0, val, \"V\");\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 'b':\n\t\t\t\t\t\t\tpush_value(o, 0, cell.v ? 1 : 0, cell.v ? \"TRUE\" : \"FALSE\");\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 's':\n\t\t\t\t\t\t\tpush_value(o, 1, 0, (!DIF_XL || isNaN(cell.v)) ? cell.v : '=\"' + cell.v + '\"');\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tcase 'd':\n\t\t\t\t\t\t\tif(!cell.w) cell.w = SSF_format(cell.z || table_fmt[14], datenum(parseDate(cell.v)));\n\t\t\t\t\t\t\tif(DIF_XL) push_value(o, 0, cell.w, \"V\");\n\t\t\t\t\t\t\telse push_value(o, 1, 0, cell.w);\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\tdefault: push_value(o, 1, 0, \"\");\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tpush_value(o, -1, 0, \"EOD\");\n\t\t\tvar RS = \"\\r\\n\";\n\t\t\tvar oo = o.join(RS);\n\t\t\t//while((oo.length & 0x7F) != 0) oo += \"\\0\";\n\t\t\treturn oo;\n\t\t};\n\t})();\n\treturn {\n\t\tto_workbook: dif_to_workbook,\n\t\tto_sheet: dif_to_sheet,\n\t\tfrom_sheet: sheet_to_dif\n\t};\n})();\n\nvar ETH = /*#__PURE__*/(function() {\n\tfunction decode(s/*:string*/)/*:string*/ { return s.replace(/\\\\b/g,\"\\\\\").replace(/\\\\c/g,\":\").replace(/\\\\n/g,\"\\n\"); }\n\tfunction encode(s/*:string*/)/*:string*/ { return s.replace(/\\\\/g, \"\\\\b\").replace(/:/g, \"\\\\c\").replace(/\\n/g,\"\\\\n\"); }\n\n\tfunction eth_to_aoa(str/*:string*/, opts)/*:AOA*/ {\n\t\tvar records = str.split('\\n'), R = -1, C = -1, ri = 0, arr/*:AOA*/ = [];\n\t\tfor (; ri !== records.length; ++ri) {\n\t\t\tvar record = records[ri].trim().split(\":\");\n\t\t\tif(record[0] !== 'cell') continue;\n\t\t\tvar addr = decode_cell(record[1]);\n\t\t\tif(arr.length <= addr.r) for(R = arr.length; R <= addr.r; ++R) if(!arr[R]) arr[R] = [];\n\t\t\tR = addr.r; C = addr.c;\n\t\t\tswitch(record[2]) {\n\t\t\t\tcase 't': arr[R][C] = decode(record[3]); break;\n\t\t\t\tcase 'v': arr[R][C] = +record[3]; break;\n\t\t\t\tcase 'vtf': var _f = record[record.length - 1];\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 'vtc':\n\t\t\t\t\tswitch(record[3]) {\n\t\t\t\t\t\tcase 'nl': arr[R][C] = +record[4] ? true : false; break;\n\t\t\t\t\t\tdefault: arr[R][C] = +record[4]; break;\n\t\t\t\t\t}\n\t\t\t\t\tif(record[2] == 'vtf') arr[R][C] = [arr[R][C], _f];\n\t\t\t}\n\t\t}\n\t\tif(opts && opts.sheetRows) arr = arr.slice(0, opts.sheetRows);\n\t\treturn arr;\n\t}\n\n\tfunction eth_to_sheet(d/*:string*/, opts)/*:Worksheet*/ { return aoa_to_sheet(eth_to_aoa(d, opts), opts); }\n\tfunction eth_to_workbook(d/*:string*/, opts)/*:Workbook*/ { return sheet_to_workbook(eth_to_sheet(d, opts), opts); }\n\n\tvar header = [\n\t\t\"socialcalc:version:1.5\",\n\t\t\"MIME-Version: 1.0\",\n\t\t\"Content-Type: multipart/mixed; boundary=SocialCalcSpreadsheetControlSave\"\n\t].join(\"\\n\");\n\n\tvar sep = [\n\t\t\"--SocialCalcSpreadsheetControlSave\",\n\t\t\"Content-type: text/plain; charset=UTF-8\"\n\t].join(\"\\n\") + \"\\n\";\n\n\t/* TODO: the other parts */\n\tvar meta = [\n\t\t\"# SocialCalc Spreadsheet Control Save\",\n\t\t\"part:sheet\"\n\t].join(\"\\n\");\n\n\tvar end = \"--SocialCalcSpreadsheetControlSave--\";\n\n\tfunction sheet_to_eth_data(ws/*:Worksheet*/)/*:string*/ {\n\t\tif(!ws || !ws['!ref']) return \"\";\n\t\tvar o/*:Array<string>*/ = [], oo/*:Array<string>*/ = [], cell, coord = \"\";\n\t\tvar r = decode_range(ws['!ref']);\n\t\tvar dense = Array.isArray(ws);\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tcoord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C] : ws[coord];\n\t\t\t\tif(!cell || cell.v == null || cell.t === 'z') continue;\n\t\t\t\too = [\"cell\", coord, 't'];\n\t\t\t\tswitch(cell.t) {\n\t\t\t\t\tcase 's': case 'str': oo.push(encode(cell.v)); break;\n\t\t\t\t\tcase 'n':\n\t\t\t\t\t\tif(!cell.f) { oo[2]='v'; oo[3]=cell.v; }\n\t\t\t\t\t\telse { oo[2]='vtf'; oo[3]='n'; oo[4]=cell.v; oo[5]=encode(cell.f); }\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'b':\n\t\t\t\t\t\too[2] = 'vt'+(cell.f?'f':'c'); oo[3]='nl'; oo[4]=cell.v?\"1\":\"0\";\n\t\t\t\t\t\too[5] = encode(cell.f||(cell.v?'TRUE':'FALSE'));\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'd':\n\t\t\t\t\t\tvar t = datenum(parseDate(cell.v));\n\t\t\t\t\t\too[2] = 'vtc'; oo[3] = 'nd'; oo[4] = \"\"+t;\n\t\t\t\t\t\too[5] = cell.w || SSF_format(cell.z || table_fmt[14], t);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'e': continue;\n\t\t\t\t}\n\t\t\t\to.push(oo.join(\":\"));\n\t\t\t}\n\t\t}\n\t\to.push(\"sheet:c:\" + (r.e.c-r.s.c+1) + \":r:\" + (r.e.r-r.s.r+1) + \":tvf:1\");\n\t\to.push(\"valueformat:1:text-wiki\");\n\t\t//o.push(\"copiedfrom:\" + ws['!ref']); // clipboard only\n\t\treturn o.join(\"\\n\");\n\t}\n\n\tfunction sheet_to_eth(ws/*:Worksheet*//*::, opts:?any*/)/*:string*/ {\n\t\treturn [header, sep, meta, sep, sheet_to_eth_data(ws), end].join(\"\\n\");\n\t\t// return [\"version:1.5\", sheet_to_eth_data(ws)].join(\"\\n\"); // clipboard form\n\t}\n\n\treturn {\n\t\tto_workbook: eth_to_workbook,\n\t\tto_sheet: eth_to_sheet,\n\t\tfrom_sheet: sheet_to_eth\n\t};\n})();\n\nvar PRN = /*#__PURE__*/(function() {\n\tfunction set_text_arr(data/*:string*/, arr/*:AOA*/, R/*:number*/, C/*:number*/, o/*:any*/) {\n\t\tif(o.raw) arr[R][C] = data;\n\t\telse if(data === \"\"){/* empty */}\n\t\telse if(data === 'TRUE') arr[R][C] = true;\n\t\telse if(data === 'FALSE') arr[R][C] = false;\n\t\telse if(!isNaN(fuzzynum(data))) arr[R][C] = fuzzynum(data);\n\t\telse if(!isNaN(fuzzydate(data).getDate())) arr[R][C] = parseDate(data);\n\t\telse arr[R][C] = data;\n\t}\n\n\tfunction prn_to_aoa_str(f/*:string*/, opts)/*:AOA*/ {\n\t\tvar o = opts || {};\n\t\tvar arr/*:AOA*/ = ([]/*:any*/);\n\t\tif(!f || f.length === 0) return arr;\n\t\tvar lines = f.split(/[\\r\\n]/);\n\t\tvar L = lines.length - 1;\n\t\twhile(L >= 0 && lines[L].length === 0) --L;\n\t\tvar start = 10, idx = 0;\n\t\tvar R = 0;\n\t\tfor(; R <= L; ++R) {\n\t\t\tidx = lines[R].indexOf(\" \");\n\t\t\tif(idx == -1) idx = lines[R].length; else idx++;\n\t\t\tstart = Math.max(start, idx);\n\t\t}\n\t\tfor(R = 0; R <= L; ++R) {\n\t\t\tarr[R] = [];\n\t\t\t/* TODO: confirm that widths are always 10 */\n\t\t\tvar C = 0;\n\t\t\tset_text_arr(lines[R].slice(0, start).trim(), arr, R, C, o);\n\t\t\tfor(C = 1; C <= (lines[R].length - start)/10 + 1; ++C)\n\t\t\t\tset_text_arr(lines[R].slice(start+(C-1)*10,start+C*10).trim(),arr,R,C,o);\n\t\t}\n\t\tif(o.sheetRows) arr = arr.slice(0, o.sheetRows);\n\t\treturn arr;\n\t}\n\n\t// List of accepted CSV separators\n\tvar guess_seps = {\n\t\t/*::[*/0x2C/*::]*/: ',',\n\t\t/*::[*/0x09/*::]*/: \"\\t\",\n\t\t/*::[*/0x3B/*::]*/: ';',\n\t\t/*::[*/0x7C/*::]*/: '|'\n\t};\n\n\t// CSV separator weights to be used in case of equal numbers\n\tvar guess_sep_weights = {\n\t\t/*::[*/0x2C/*::]*/: 3,\n\t\t/*::[*/0x09/*::]*/: 2,\n\t\t/*::[*/0x3B/*::]*/: 1,\n\t\t/*::[*/0x7C/*::]*/: 0\n\t};\n\n\tfunction guess_sep(str) {\n\t\tvar cnt = {}, instr = false, end = 0, cc = 0;\n\t\tfor(;end < str.length;++end) {\n\t\t\tif((cc=str.charCodeAt(end)) == 0x22) instr = !instr;\n\t\t\telse if(!instr && cc in guess_seps) cnt[cc] = (cnt[cc]||0)+1;\n\t\t}\n\n\t\tcc = [];\n\t\tfor(end in cnt) if ( Object.prototype.hasOwnProperty.call(cnt, end) ) {\n\t\t\tcc.push([ cnt[end], end ]);\n\t\t}\n\n\t\tif ( !cc.length ) {\n\t\t\tcnt = guess_sep_weights;\n\t\t\tfor(end in cnt) if ( Object.prototype.hasOwnProperty.call(cnt, end) ) {\n\t\t\t\tcc.push([ cnt[end], end ]);\n\t\t\t}\n\t\t}\n\n\t\tcc.sort(function(a, b) { return a[0] - b[0] || guess_sep_weights[a[1]] - guess_sep_weights[b[1]]; });\n\n\t\treturn guess_seps[cc.pop()[1]] || 0x2C;\n\t}\n\n\tfunction dsv_to_sheet_str(str/*:string*/, opts)/*:Worksheet*/ {\n\t\tvar o = opts || {};\n\t\tvar sep = \"\";\n\t\tif(DENSE != null && o.dense == null) o.dense = DENSE;\n\t\tvar ws/*:Worksheet*/ = o.dense ? ([]/*:any*/) : ({}/*:any*/);\n\t\tvar range/*:Range*/ = ({s: {c:0, r:0}, e: {c:0, r:0}}/*:any*/);\n\n\t\tif(str.slice(0,4) == \"sep=\") {\n\t\t\t// If the line ends in \\r\\n\n\t\t\tif(str.charCodeAt(5) == 13 && str.charCodeAt(6) == 10 ) {\n\t\t\t\tsep = str.charAt(4); str = str.slice(7);\n\t\t\t}\n\t\t\t// If line ends in \\r OR \\n\n\t\t\telse if(str.charCodeAt(5) == 13 || str.charCodeAt(5) == 10 ) {\n\t\t\t\tsep = str.charAt(4); str = str.slice(6);\n\t\t\t}\n\t\t\telse sep = guess_sep(str.slice(0,1024));\n\t\t}\n\t\telse if(o && o.FS) sep = o.FS;\n\t\telse sep = guess_sep(str.slice(0,1024));\n\t\tvar R = 0, C = 0, v = 0;\n\t\tvar start = 0, end = 0, sepcc = sep.charCodeAt(0), instr = false, cc=0, startcc=str.charCodeAt(0);\n\t\tstr = str.replace(/\\r\\n/mg, \"\\n\");\n\t\tvar _re/*:?RegExp*/ = o.dateNF != null ? dateNF_regex(o.dateNF) : null;\n\t\tfunction finish_cell() {\n\t\t\tvar s = str.slice(start, end);\n\t\t\tvar cell = ({}/*:any*/);\n\t\t\tif(s.charAt(0) == '\"' && s.charAt(s.length - 1) == '\"') s = s.slice(1,-1).replace(/\"\"/g,'\"');\n\t\t\tif(s.length === 0) cell.t = 'z';\n\t\t\telse if(o.raw) { cell.t = 's'; cell.v = s; }\n\t\t\telse if(s.trim().length === 0) { cell.t = 's'; cell.v = s; }\n\t\t\telse if(s.charCodeAt(0) == 0x3D) {\n\t\t\t\tif(s.charCodeAt(1) == 0x22 && s.charCodeAt(s.length - 1) == 0x22) { cell.t = 's'; cell.v = s.slice(2,-1).replace(/\"\"/g,'\"'); }\n\t\t\t\telse if(fuzzyfmla(s)) { cell.t = 'n'; cell.f = s.slice(1); }\n\t\t\t\telse { cell.t = 's'; cell.v = s; } }\n\t\t\telse if(s == \"TRUE\") { cell.t = 'b'; cell.v = true; }\n\t\t\telse if(s == \"FALSE\") { cell.t = 'b'; cell.v = false; }\n\t\t\telse if(!isNaN(v = fuzzynum(s))) { cell.t = 'n'; if(o.cellText !== false) cell.w = s; cell.v = v; }\n\t\t\telse if(!isNaN(fuzzydate(s).getDate()) || _re && s.match(_re)) {\n\t\t\t\tcell.z = o.dateNF || table_fmt[14];\n\t\t\t\tvar k = 0;\n\t\t\t\tif(_re && s.match(_re)){ s=dateNF_fix(s, o.dateNF, (s.match(_re)||[])); k=1; }\n\t\t\t\tif(o.cellDates) { cell.t = 'd'; cell.v = parseDate(s, k); }\n\t\t\t\telse { cell.t = 'n'; cell.v = datenum(parseDate(s, k)); }\n\t\t\t\tif(o.cellText !== false) cell.w = SSF_format(cell.z, cell.v instanceof Date ? datenum(cell.v):cell.v);\n\t\t\t\tif(!o.cellNF) delete cell.z;\n\t\t\t} else {\n\t\t\t\tcell.t = 's';\n\t\t\t\tcell.v = s;\n\t\t\t}\n\t\t\tif(cell.t == 'z'){}\n\t\t\telse if(o.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = cell; }\n\t\t\telse ws[encode_cell({c:C,r:R})] = cell;\n\t\t\tstart = end+1; startcc = str.charCodeAt(start);\n\t\t\tif(range.e.c < C) range.e.c = C;\n\t\t\tif(range.e.r < R) range.e.r = R;\n\t\t\tif(cc == sepcc) ++C; else { C = 0; ++R; if(o.sheetRows && o.sheetRows <= R) return true; }\n\t\t}\n\t\touter: for(;end < str.length;++end) switch((cc=str.charCodeAt(end))) {\n\t\t\tcase 0x22: if(startcc === 0x22) instr = !instr; break;\n\t\t\tcase sepcc: case 0x0a: case 0x0d: if(!instr && finish_cell()) break outer; break;\n\t\t\tdefault: break;\n\t\t}\n\t\tif(end - start > 0) finish_cell();\n\n\t\tws['!ref'] = encode_range(range);\n\t\treturn ws;\n\t}\n\n\tfunction prn_to_sheet_str(str/*:string*/, opts)/*:Worksheet*/ {\n\t\tif(!(opts && opts.PRN)) return dsv_to_sheet_str(str, opts);\n\t\tif(opts.FS) return dsv_to_sheet_str(str, opts);\n\t\tif(str.slice(0,4) == \"sep=\") return dsv_to_sheet_str(str, opts);\n\t\tif(str.indexOf(\"\\t\") >= 0 || str.indexOf(\",\") >= 0 || str.indexOf(\";\") >= 0) return dsv_to_sheet_str(str, opts);\n\t\treturn aoa_to_sheet(prn_to_aoa_str(str, opts), opts);\n\t}\n\n\tfunction prn_to_sheet(d/*:RawData*/, opts)/*:Worksheet*/ {\n\t\tvar str = \"\", bytes = opts.type == 'string' ? [0,0,0,0] : firstbyte(d, opts);\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': str = Base64_decode(d); break;\n\t\t\tcase 'binary': str = d; break;\n\t\t\tcase 'buffer':\n\t\t\t\tif(opts.codepage == 65001) str = d.toString('utf8'); // TODO: test if buf\n\t\t\t\telse if(opts.codepage && typeof $cptable !== 'undefined') str = $cptable.utils.decode(opts.codepage, d);\n\t\t\t\telse str = has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d);\n\t\t\t\tbreak;\n\t\t\tcase 'array': str = cc2str(d); break;\n\t\t\tcase 'string': str = d; break;\n\t\t\tdefault: throw new Error(\"Unrecognized type \" + opts.type);\n\t\t}\n\t\tif(bytes[0] == 0xEF && bytes[1] == 0xBB && bytes[2] == 0xBF) str = utf8read(str.slice(3));\n\t\telse if(opts.type != 'string' && opts.type != 'buffer' && opts.codepage == 65001) str = utf8read(str);\n\t\telse if((opts.type == 'binary') && typeof $cptable !== 'undefined' && opts.codepage)  str = $cptable.utils.decode(opts.codepage, $cptable.utils.encode(28591,str));\n\t\tif(str.slice(0,19) == \"socialcalc:version:\") return ETH.to_sheet(opts.type == 'string' ? str : utf8read(str), opts);\n\t\treturn prn_to_sheet_str(str, opts);\n\t}\n\n\tfunction prn_to_workbook(d/*:RawData*/, opts)/*:Workbook*/ { return sheet_to_workbook(prn_to_sheet(d, opts), opts); }\n\n\tfunction sheet_to_prn(ws/*:Worksheet*//*::, opts:?any*/)/*:string*/ {\n\t\tvar o/*:Array<string>*/ = [];\n\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\tvar dense = Array.isArray(ws);\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\tvar oo/*:Array<string>*/ = [];\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C] : ws[coord];\n\t\t\t\tif(!cell || cell.v == null) { oo.push(\"          \"); continue; }\n\t\t\t\tvar w = (cell.w || (format_cell(cell), cell.w) || \"\").slice(0,10);\n\t\t\t\twhile(w.length < 10) w += \" \";\n\t\t\t\too.push(w + (C === 0 ? \" \" : \"\"));\n\t\t\t}\n\t\t\to.push(oo.join(\"\"));\n\t\t}\n\t\treturn o.join(\"\\n\");\n\t}\n\n\treturn {\n\t\tto_workbook: prn_to_workbook,\n\t\tto_sheet: prn_to_sheet,\n\t\tfrom_sheet: sheet_to_prn\n\t};\n})();\n\n/* Excel defaults to SYLK but warns if data is not valid */\nfunction read_wb_ID(d, opts) {\n\tvar o = opts || {}, OLD_WTF = !!o.WTF; o.WTF = true;\n\ttry {\n\t\tvar out = SYLK.to_workbook(d, o);\n\t\to.WTF = OLD_WTF;\n\t\treturn out;\n\t} catch(e) {\n\t\to.WTF = OLD_WTF;\n\t\tif(!e.message.match(/SYLK bad record ID/) && OLD_WTF) throw e;\n\t\treturn PRN.to_workbook(d, opts);\n\t}\n}\n\nvar WK_ = /*#__PURE__*/(function() {\n\tfunction lotushopper(data, cb/*:RecordHopperCB*/, opts/*:any*/) {\n\t\tif(!data) return;\n\t\tprep_blob(data, data.l || 0);\n\t\tvar Enum = opts.Enum || WK1Enum;\n\t\twhile(data.l < data.length) {\n\t\t\tvar RT = data.read_shift(2);\n\t\t\tvar R = Enum[RT] || Enum[0xFFFF];\n\t\t\tvar length = data.read_shift(2);\n\t\t\tvar tgt = data.l + length;\n\t\t\tvar d = R.f && R.f(data, length, opts);\n\t\t\tdata.l = tgt;\n\t\t\tif(cb(d, R, RT)) return;\n\t\t}\n\t}\n\n\tfunction lotus_to_workbook(d/*:RawData*/, opts) {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return lotus_to_workbook_buf(s2a(Base64_decode(d)), opts);\n\t\t\tcase 'binary': return lotus_to_workbook_buf(s2a(d), opts);\n\t\t\tcase 'buffer':\n\t\t\tcase 'array': return lotus_to_workbook_buf(d, opts);\n\t\t}\n\t\tthrow \"Unsupported type \" + opts.type;\n\t}\n\n\tfunction lotus_to_workbook_buf(d, opts)/*:Workbook*/ {\n\t\tif(!d) return d;\n\t\tvar o = opts || {};\n\t\tif(DENSE != null && o.dense == null) o.dense = DENSE;\n\t\tvar s/*:Worksheet*/ = ((o.dense ? [] : {})/*:any*/), n = \"Sheet1\", next_n = \"\", sidx = 0;\n\t\tvar sheets = {}, snames = [], realnames = [];\n\n\t\tvar refguess = {s: {r:0, c:0}, e: {r:0, c:0} };\n\t\tvar sheetRows = o.sheetRows || 0;\n\n\t\tif(d[2] == 0x00) {\n\t\t\tif(d[3] == 0x08 || d[3] == 0x09) {\n\t\t\t\tif(d.length >= 16 && d[14] == 0x05 && d[15] === 0x6c) throw new Error(\"Unsupported Works 3 for Mac file\");\n\t\t\t}\n\t\t}\n\n\t\tif(d[2] == 0x02) {\n\t\t\to.Enum = WK1Enum;\n\t\t\tlotushopper(d, function(val, R, RT) { switch(RT) {\n\t\t\t\tcase 0x00: /* BOF */\n\t\t\t\t\to.vers = val;\n\t\t\t\t\tif(val >= 0x1000) o.qpro = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x06: refguess = val; break; /* RANGE */\n\t\t\t\tcase 0xCC: if(val) next_n = val; break; /* SHEETNAMECS */\n\t\t\t\tcase 0xDE: next_n = val; break; /* SHEETNAMELP */\n\t\t\t\tcase 0x0F: /* LABEL */\n\t\t\t\tcase 0x33: /* STRING */\n\t\t\t\t\tif(!o.qpro) val[1].v = val[1].v.slice(1);\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 0x0D: /* INTEGER */\n\t\t\t\tcase 0x0E: /* NUMBER */\n\t\t\t\tcase 0x10: /* FORMULA */\n\t\t\t\t\t/* TODO: actual translation of the format code */\n\t\t\t\t\tif(RT == 0x0E && (val[2] & 0x70) == 0x70 && (val[2] & 0x0F) > 1 && (val[2] & 0x0F) < 15) {\n\t\t\t\t\t\tval[1].z = o.dateNF || table_fmt[14];\n\t\t\t\t\t\tif(o.cellDates) { val[1].t = 'd'; val[1].v = numdate(val[1].v); }\n\t\t\t\t\t}\n\n\t\t\t\t\tif(o.qpro) {\n\t\t\t\t\t\tif(val[3] > sidx) {\n\t\t\t\t\t\t\ts[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\t\t\tsheets[n] = s;\n\t\t\t\t\t\t\tsnames.push(n);\n\t\t\t\t\t\t\ts = (o.dense ? [] : {});\n\t\t\t\t\t\t\trefguess = {s: {r:0, c:0}, e: {r:0, c:0} };\n\t\t\t\t\t\t\tsidx = val[3]; n = next_n || \"Sheet\" + (sidx + 1); next_n = \"\";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tvar tmpcell = o.dense ? (s[val[0].r]||[])[val[0].c] : s[encode_cell(val[0])];\n\t\t\t\t\tif(tmpcell) {\n\t\t\t\t\t\ttmpcell.t = val[1].t; tmpcell.v = val[1].v;\n\t\t\t\t\t\tif(val[1].z != null) tmpcell.z = val[1].z;\n\t\t\t\t\t\tif(val[1].f != null) tmpcell.f = val[1].f;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tif(o.dense) {\n\t\t\t\t\t\tif(!s[val[0].r]) s[val[0].r] = [];\n\t\t\t\t\t\ts[val[0].r][val[0].c] = val[1];\n\t\t\t\t\t} else s[encode_cell(val[0])] = val[1];\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t}}, o);\n\t\t} else if(d[2] == 0x1A || d[2] == 0x0E) {\n\t\t\to.Enum = WK3Enum;\n\t\t\tif(d[2] == 0x0E) { o.qpro = true; d.l = 0; }\n\t\t\tlotushopper(d, function(val, R, RT) { switch(RT) {\n\t\t\t\tcase 0xCC: n = val; break; /* SHEETNAMECS */\n\t\t\t\tcase 0x16: /* LABEL16 */\n\t\t\t\t\tval[1].v = val[1].v.slice(1);\n\t\t\t\t\t/* falls through */\n\t\t\t\tcase 0x17: /* NUMBER17 */\n\t\t\t\tcase 0x18: /* NUMBER18 */\n\t\t\t\tcase 0x19: /* FORMULA19 */\n\t\t\t\tcase 0x25: /* NUMBER25 */\n\t\t\t\tcase 0x27: /* NUMBER27 */\n\t\t\t\tcase 0x28: /* FORMULA28 */\n\t\t\t\t\tif(val[3] > sidx) {\n\t\t\t\t\t\ts[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\t\tsheets[n] = s;\n\t\t\t\t\t\tsnames.push(n);\n\t\t\t\t\t\ts = (o.dense ? [] : {});\n\t\t\t\t\t\trefguess = {s: {r:0, c:0}, e: {r:0, c:0} };\n\t\t\t\t\t\tsidx = val[3]; n = \"Sheet\" + (sidx + 1);\n\t\t\t\t\t}\n\t\t\t\t\tif(sheetRows > 0 && val[0].r >= sheetRows) break;\n\t\t\t\t\tif(o.dense) {\n\t\t\t\t\t\tif(!s[val[0].r]) s[val[0].r] = [];\n\t\t\t\t\t\ts[val[0].r][val[0].c] = val[1];\n\t\t\t\t\t} else s[encode_cell(val[0])] = val[1];\n\t\t\t\t\tif(refguess.e.c < val[0].c) refguess.e.c = val[0].c;\n\t\t\t\t\tif(refguess.e.r < val[0].r) refguess.e.r = val[0].r;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x1B: /* XFORMAT */\n\t\t\t\t\tif(val[0x36b0]) realnames[val[0x36b0][0]] = val[0x36b0][1];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0601: /* SHEETINFOQP */\n\t\t\t\t\trealnames[val[0]] = val[1]; if(val[0] == sidx) n = val[1]; break;\n\t\t\t\tdefault: break;\n\t\t\t}}, o);\n\t\t} else throw new Error(\"Unrecognized LOTUS BOF \" + d[2]);\n\t\ts[\"!ref\"] = encode_range(refguess);\n\t\tsheets[next_n || n] = s;\n\t\tsnames.push(next_n || n);\n\t\tif(!realnames.length) return { SheetNames: snames, Sheets: sheets };\n\t\tvar osheets = {}, rnames = [];\n\t\t/* TODO: verify no collisions */\n\t\tfor(var i = 0; i < realnames.length; ++i) if(sheets[snames[i]]) {\n\t\t\trnames.push(realnames[i] || snames[i]);\n\t\t\tosheets[realnames[i]] = sheets[realnames[i]] || sheets[snames[i]];\n\t\t} else {\n\t\t\trnames.push(realnames[i]);\n\t\t\tosheets[realnames[i]] = ({ \"!ref\": \"A1\" });\n\t\t}\n\t\treturn { SheetNames: rnames, Sheets: osheets };\n\t}\n\n\tfunction sheet_to_wk1(ws/*:Worksheet*/, opts/*:WriteOpts*/) {\n\t\tvar o = opts || {};\n\t\tif(+o.codepage >= 0) set_cp(+o.codepage);\n\t\tif(o.type == \"string\") throw new Error(\"Cannot write WK1 to JS string\");\n\t\tvar ba = buf_array();\n\t\tvar range = safe_decode_range(ws[\"!ref\"]);\n\t\tvar dense = Array.isArray(ws);\n\t\tvar cols = [];\n\n\t\twrite_biff_rec(ba, 0x00, write_BOF_WK1(0x0406));\n\t\twrite_biff_rec(ba, 0x06, write_RANGE(range));\n\t\tvar max_R = Math.min(range.e.r, 8191);\n\t\tfor(var R = range.s.r; R <= max_R; ++R) {\n\t\t\tvar rr = encode_row(R);\n\t\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\t\tvar ref = cols[C] + rr;\n\t\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\t\tif(!cell || cell.t == \"z\") continue;\n\t\t\t\t/* TODO: formula records */\n\t\t\t\tif(cell.t == \"n\") {\n\t\t\t\t\tif((cell.v|0)==cell.v && cell.v >= -32768 && cell.v <= 32767) write_biff_rec(ba, 0x0d, write_INTEGER(R, C, cell.v));\n\t\t\t\t\telse write_biff_rec(ba, 0x0e, write_NUMBER(R, C, cell.v));\n\t\t\t\t} else {\n\t\t\t\t\tvar str = format_cell(cell);\n\t\t\t\t\twrite_biff_rec(ba, 0x0F, write_LABEL(R, C, str.slice(0, 239)));\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\twrite_biff_rec(ba, 0x01);\n\t\treturn ba.end();\n\t}\n\n\tfunction book_to_wk3(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\t\tvar o = opts || {};\n\t\tif(+o.codepage >= 0) set_cp(+o.codepage);\n\t\tif(o.type == \"string\") throw new Error(\"Cannot write WK3 to JS string\");\n\t\tvar ba = buf_array();\n\n\t\twrite_biff_rec(ba, 0x00, write_BOF_WK3(wb));\n\n\t\tfor(var i = 0, cnt = 0; i < wb.SheetNames.length; ++i) if((wb.Sheets[wb.SheetNames[i]] || {})[\"!ref\"]) write_biff_rec(ba, 0x1b, write_XFORMAT_SHEETNAME(wb.SheetNames[i], cnt++));\n\n\t\tvar wsidx = 0;\n\t\tfor(i = 0; i < wb.SheetNames.length; ++i) {\n\t\t\tvar ws = wb.Sheets[wb.SheetNames[i]];\n\t\t\tif(!ws || !ws[\"!ref\"]) continue;\n\t\t\tvar range = safe_decode_range(ws[\"!ref\"]);\n\t\t\tvar dense = Array.isArray(ws);\n\t\t\tvar cols = [];\n\t\t\tvar max_R = Math.min(range.e.r, 8191);\n\t\t\tfor(var R = range.s.r; R <= max_R; ++R) {\n\t\t\t\tvar rr = encode_row(R);\n\t\t\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\t\t\tvar ref = cols[C] + rr;\n\t\t\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\t\t\tif(!cell || cell.t == \"z\") continue;\n\t\t\t\t\t/* TODO: FORMULA19 NUMBER18 records */\n\t\t\t\t\tif(cell.t == \"n\") {\n\t\t\t\t\t\twrite_biff_rec(ba, 0x17, write_NUMBER_17(R, C, wsidx, cell.v));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tvar str = format_cell(cell);\n\t\t\t\t\t\t/* TODO: max len? */\n\t\t\t\t\t\twrite_biff_rec(ba, 0x16, write_LABEL_16(R, C, wsidx, str.slice(0, 239)));\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\t++wsidx;\n\t\t}\n\n\t\twrite_biff_rec(ba, 0x01);\n\t\treturn ba.end();\n\t}\n\n\n\tfunction write_BOF_WK1(v/*:number*/) {\n\t\tvar out = new_buf(2);\n\t\tout.write_shift(2, v);\n\t\treturn out;\n\t}\n\n\tfunction write_BOF_WK3(wb/*:Workbook*/) {\n\t\tvar out = new_buf(26);\n\t\tout.write_shift(2, 0x1000);\n\t\tout.write_shift(2, 0x0004);\n\t\tout.write_shift(4, 0x0000);\n\t\tvar rows = 0, cols = 0, wscnt = 0;\n\t\tfor(var i = 0; i < wb.SheetNames.length; ++i) {\n\t\t\tvar name = wb.SheetNames[i];\n\t\t\tvar ws = wb.Sheets[name];\n\t\t\tif(!ws || !ws[\"!ref\"]) continue;\n\t\t\t++wscnt;\n\t\t\tvar range = decode_range(ws[\"!ref\"]);\n\t\t\tif(rows < range.e.r) rows = range.e.r;\n\t\t\tif(cols < range.e.c) cols = range.e.c;\n\t\t}\n\t\tif(rows > 8191) rows = 8191;\n\t\tout.write_shift(2, rows);\n\t\tout.write_shift(1, wscnt);\n\t\tout.write_shift(1, cols);\n\t\tout.write_shift(2, 0x00);\n\t\tout.write_shift(2, 0x00);\n\t\tout.write_shift(1, 0x01);\n\t\tout.write_shift(1, 0x02);\n\t\tout.write_shift(4, 0);\n\t\tout.write_shift(4, 0);\n\t\treturn out;\n\t}\n\n\tfunction parse_RANGE(blob, length, opts) {\n\t\tvar o = {s:{c:0,r:0},e:{c:0,r:0}};\n\t\tif(length == 8 && opts.qpro) {\n\t\t\to.s.c = blob.read_shift(1);\n\t\t\tblob.l++;\n\t\t\to.s.r = blob.read_shift(2);\n\t\t\to.e.c = blob.read_shift(1);\n\t\t\tblob.l++;\n\t\t\to.e.r = blob.read_shift(2);\n\t\t\treturn o;\n\t\t}\n\t\to.s.c = blob.read_shift(2);\n\t\to.s.r = blob.read_shift(2);\n\t\tif(length == 12 && opts.qpro) blob.l += 2;\n\t\to.e.c = blob.read_shift(2);\n\t\to.e.r = blob.read_shift(2);\n\t\tif(length == 12 && opts.qpro) blob.l += 2;\n\t\tif(o.s.c == 0xFFFF) o.s.c = o.e.c = o.s.r = o.e.r = 0;\n\t\treturn o;\n\t}\n\tfunction write_RANGE(range) {\n\t\tvar out = new_buf(8);\n\t\tout.write_shift(2, range.s.c);\n\t\tout.write_shift(2, range.s.r);\n\t\tout.write_shift(2, range.e.c);\n\t\tout.write_shift(2, range.e.r);\n\t\treturn out;\n\t}\n\n\tfunction parse_cell(blob, length, opts) {\n\t\tvar o = [{c:0,r:0}, {t:'n',v:0}, 0, 0];\n\t\tif(opts.qpro && opts.vers != 0x5120) {\n\t\t\to[0].c = blob.read_shift(1);\n\t\t\to[3] = blob.read_shift(1);\n\t\t\to[0].r = blob.read_shift(2);\n\t\t\tblob.l+=2;\n\t\t} else {\n\t\t\to[2] = blob.read_shift(1);\n\t\t\to[0].c = blob.read_shift(2); o[0].r = blob.read_shift(2);\n\t\t}\n\t\treturn o;\n\t}\n\n\tfunction parse_LABEL(blob, length, opts) {\n\t\tvar tgt = blob.l + length;\n\t\tvar o = parse_cell(blob, length, opts);\n\t\to[1].t = 's';\n\t\tif(opts.vers == 0x5120) {\n\t\t\tblob.l++;\n\t\t\tvar len = blob.read_shift(1);\n\t\t\to[1].v = blob.read_shift(len, 'utf8');\n\t\t\treturn o;\n\t\t}\n\t\tif(opts.qpro) blob.l++;\n\t\to[1].v = blob.read_shift(tgt - blob.l, 'cstr');\n\t\treturn o;\n\t}\n\tfunction write_LABEL(R, C, s) {\n\t\t/* TODO: encoding */\n\t\tvar o = new_buf(7 + s.length);\n\t\to.write_shift(1, 0xFF);\n\t\to.write_shift(2, C);\n\t\to.write_shift(2, R);\n\t\to.write_shift(1, 0x27); // ??\n\t\tfor(var i = 0; i < o.length; ++i) {\n\t\t\tvar cc = s.charCodeAt(i);\n\t\t\to.write_shift(1, cc >= 0x80 ? 0x5F : cc);\n\t\t}\n\t\to.write_shift(1, 0);\n\t\treturn o;\n\t}\n\n\tfunction parse_INTEGER(blob, length, opts) {\n\t\tvar o = parse_cell(blob, length, opts);\n\t\to[1].v = blob.read_shift(2, 'i');\n\t\treturn o;\n\t}\n\tfunction write_INTEGER(R, C, v) {\n\t\tvar o = new_buf(7);\n\t\to.write_shift(1, 0xFF);\n\t\to.write_shift(2, C);\n\t\to.write_shift(2, R);\n\t\to.write_shift(2, v, 'i');\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER(blob, length, opts) {\n\t\tvar o = parse_cell(blob, length, opts);\n\t\to[1].v = blob.read_shift(8, 'f');\n\t\treturn o;\n\t}\n\tfunction write_NUMBER(R, C, v) {\n\t\tvar o = new_buf(13);\n\t\to.write_shift(1, 0xFF);\n\t\to.write_shift(2, C);\n\t\to.write_shift(2, R);\n\t\to.write_shift(8, v, 'f');\n\t\treturn o;\n\t}\n\n\tfunction parse_FORMULA(blob, length, opts) {\n\t\tvar tgt = blob.l + length;\n\t\tvar o = parse_cell(blob, length, opts);\n\t\t/* TODO: formula */\n\t\to[1].v = blob.read_shift(8, 'f');\n\t\tif(opts.qpro) blob.l = tgt;\n\t\telse {\n\t\t\tvar flen = blob.read_shift(2);\n\t\t\twk1_fmla_to_csf(blob.slice(blob.l, blob.l + flen), o);\n\t\t\tblob.l += flen;\n\t\t}\n\t\treturn o;\n\t}\n\n\tfunction wk1_parse_rc(B, V, col) {\n\t\tvar rel = V & 0x8000;\n\t\tV &= ~0x8000;\n\t\tV = (rel ? B : 0) + ((V >= 0x2000) ? V - 0x4000 : V);\n\t\treturn (rel ? \"\" : \"$\") + (col ? encode_col(V) : encode_row(V));\n\t}\n\t/* var oprec = [\n\t\t8, 8, 8, 8, 8, 8, 8, 8, 6, 4, 4, 5, 5, 7, 3, 3,\n\t\t3, 3, 3, 3, 1, 1, 2, 6, 8, 8, 8, 8, 8, 8, 8, 8\n\t]; */\n\t/* TODO: flesh out */\n\tvar FuncTab = {\n\t\t0x33: [\"FALSE\", 0],\n\t\t0x34: [\"TRUE\", 0],\n\t\t0x46: [\"LEN\", 1],\n\t\t0x50: [\"SUM\", 69],\n\t\t0x51: [\"AVERAGEA\", 69],\n\t\t0x52: [\"COUNTA\", 69],\n\t\t0x53: [\"MINA\", 69],\n\t\t0x54: [\"MAXA\", 69],\n\t\t0x6F: [\"T\", 1]\n\t};\n\tvar BinOpTab = [\n\t\t  \"\",   \"\",   \"\",   \"\",   \"\",   \"\",   \"\",   \"\", // eslint-disable-line no-mixed-spaces-and-tabs\n\t\t  \"\",  \"+\",  \"-\",  \"*\",  \"/\",  \"^\",  \"=\", \"<>\", // eslint-disable-line no-mixed-spaces-and-tabs\n\t\t\"<=\", \">=\",  \"<\",  \">\",   \"\",   \"\",   \"\",   \"\", // eslint-disable-line no-mixed-spaces-and-tabs\n\t\t \"&\",   \"\",   \"\",   \"\",   \"\",   \"\",   \"\",   \"\"  // eslint-disable-line no-mixed-spaces-and-tabs\n\t];\n\n\tfunction wk1_fmla_to_csf(blob, o) {\n\t\tprep_blob(blob, 0);\n\t\tvar out = [], argc = 0, R = \"\", C = \"\", argL = \"\", argR = \"\";\n\t\twhile(blob.l < blob.length) {\n\t\t\tvar cc = blob[blob.l++];\n\t\t\tswitch(cc) {\n\t\t\t\tcase 0x00: out.push(blob.read_shift(8, 'f')); break;\n\t\t\t\tcase 0x01: {\n\t\t\t\t\tC = wk1_parse_rc(o[0].c, blob.read_shift(2), true);\n\t\t\t\t\tR = wk1_parse_rc(o[0].r, blob.read_shift(2), false);\n\t\t\t\t\tout.push(C + R);\n\t\t\t\t} break;\n\t\t\t\tcase 0x02: {\n\t\t\t\t\tvar c = wk1_parse_rc(o[0].c, blob.read_shift(2), true);\n\t\t\t\t\tvar r = wk1_parse_rc(o[0].r, blob.read_shift(2), false);\n\t\t\t\t\tC = wk1_parse_rc(o[0].c, blob.read_shift(2), true);\n\t\t\t\t\tR = wk1_parse_rc(o[0].r, blob.read_shift(2), false);\n\t\t\t\t\tout.push(c + r + \":\" + C + R);\n\t\t\t\t} break;\n\t\t\t\tcase 0x03:\n\t\t\t\t\tif(blob.l < blob.length) { console.error(\"WK1 premature formula end\"); return; }\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x04: out.push(\"(\" + out.pop() + \")\"); break;\n\t\t\t\tcase 0x05: out.push(blob.read_shift(2)); break;\n\t\t\t\tcase 0x06: {\n\t\t\t\t\t/* TODO: text encoding */\n\t\t\t\t\tvar Z = \"\"; while((cc = blob[blob.l++])) Z += String.fromCharCode(cc);\n\t\t\t\t\tout.push('\"' + Z.replace(/\"/g, '\"\"') + '\"');\n\t\t\t\t} break;\n\n\t\t\t\tcase 0x08: out.push(\"-\" + out.pop()); break;\n\t\t\t\tcase 0x17: out.push(\"+\" + out.pop()); break;\n\t\t\t\tcase 0x16: out.push(\"NOT(\" + out.pop() + \")\"); break;\n\n\t\t\t\tcase 0x14: case 0x15: {\n\t\t\t\t\targR = out.pop(); argL = out.pop();\n\t\t\t\t\tout.push([\"AND\", \"OR\"][cc - 0x14] + \"(\" + argL + \",\" + argR + \")\");\n\t\t\t\t} break;\n\n\t\t\t\tdefault:\n\t\t\t\t\tif(cc < 0x20 && BinOpTab[cc]) {\n\t\t\t\t\t\targR = out.pop(); argL = out.pop();\n\t\t\t\t\t\tout.push(argL + BinOpTab[cc] + argR);\n\t\t\t\t\t} else if(FuncTab[cc]) {\n\t\t\t\t\t\targc = FuncTab[cc][1];\n\t\t\t\t\t\tif(argc == 69) argc = blob[blob.l++];\n\t\t\t\t\t\tif(argc > out.length) { console.error(\"WK1 bad formula parse 0x\" + cc.toString(16) + \":|\" + out.join(\"|\") + \"|\"); return; }\n\t\t\t\t\t\tvar args = out.slice(-argc);\n\t\t\t\t\t\tout.length -= argc;\n\t\t\t\t\t\tout.push(FuncTab[cc][0] + \"(\" + args.join(\",\") + \")\");\n\t\t\t\t\t}\n\t\t\t\t\telse if(cc <= 0x07) return console.error(\"WK1 invalid opcode \" + cc.toString(16));\n\t\t\t\t\telse if(cc <= 0x18) return console.error(\"WK1 unsupported op \" + cc.toString(16));\n\t\t\t\t\telse if(cc <= 0x1E) return console.error(\"WK1 invalid opcode \" + cc.toString(16));\n\t\t\t\t\telse if(cc <= 0x73) return console.error(\"WK1 unsupported function opcode \" + cc.toString(16));\n\t\t\t\t\t// possible future functions ??\n\t\t\t\t\telse return console.error(\"WK1 unrecognized opcode \" + cc.toString(16));\n\t\t\t}\n\t\t}\n\t\tif(out.length == 1) o[1].f = \"\" + out[0];\n\t\telse console.error(\"WK1 bad formula parse |\" + out.join(\"|\") + \"|\");\n\t}\n\n\n\tfunction parse_cell_3(blob/*::, length*/) {\n\t\tvar o = [{c:0,r:0}, {t:'n',v:0}, 0];\n\t\to[0].r = blob.read_shift(2); o[3] = blob[blob.l++]; o[0].c = blob[blob.l++];\n\t\treturn o;\n\t}\n\n\tfunction parse_LABEL_16(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\to[1].t = 's';\n\t\to[1].v = blob.read_shift(length - 4, 'cstr');\n\t\treturn o;\n\t}\n\tfunction write_LABEL_16(R, C, wsidx, s) {\n\t\t/* TODO: encoding */\n\t\tvar o = new_buf(6 + s.length);\n\t\to.write_shift(2, R);\n\t\to.write_shift(1, wsidx);\n\t\to.write_shift(1, C);\n\t\to.write_shift(1, 0x27);\n\t\tfor(var i = 0; i < s.length; ++i) {\n\t\t\tvar cc = s.charCodeAt(i);\n\t\t\to.write_shift(1, cc >= 0x80 ? 0x5F : cc);\n\t\t}\n\t\to.write_shift(1, 0);\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_18(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\to[1].v = blob.read_shift(2);\n\t\tvar v = o[1].v >> 1;\n\t\tif(o[1].v & 0x1) {\n\t\t\tswitch(v & 0x07) {\n\t\t\t\tcase 0: v = (v >> 3) * 5000; break;\n\t\t\t\tcase 1: v = (v >> 3) * 500; break;\n\t\t\t\tcase 2: v = (v >> 3) / 20; break;\n\t\t\t\tcase 3: v = (v >> 3) / 200; break;\n\t\t\t\tcase 4: v = (v >> 3) / 2000; break;\n\t\t\t\tcase 5: v = (v >> 3) / 20000; break;\n\t\t\t\tcase 6: v = (v >> 3) / 16; break;\n\t\t\t\tcase 7: v = (v >> 3) / 64; break;\n\t\t\t}\n\t\t}\n\t\to[1].v = v;\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_17(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\tvar v1 = blob.read_shift(4);\n\t\tvar v2 = blob.read_shift(4);\n\t\tvar e = blob.read_shift(2);\n\t\tif(e == 0xFFFF) {\n\t\t\tif(v1 === 0 && v2 === 0xC0000000) { o[1].t = \"e\"; o[1].v = 0x0F; } // ERR -> #VALUE!\n\t\t\telse if(v1 === 0 && v2 === 0xD0000000) { o[1].t = \"e\"; o[1].v = 0x2A; } // NA -> #N/A\n\t\t\telse o[1].v = 0;\n\t\t\treturn o;\n\t\t}\n\t\tvar s = e & 0x8000; e = (e&0x7FFF) - 16446;\n\t\to[1].v = (1 - s*2) * (v2 * Math.pow(2, e+32) + v1 * Math.pow(2, e));\n\t\treturn o;\n\t}\n\tfunction write_NUMBER_17(R, C, wsidx, v) {\n\t\tvar o = new_buf(14);\n\t\to.write_shift(2, R);\n\t\to.write_shift(1, wsidx);\n\t\to.write_shift(1, C);\n\t\tif(v == 0) {\n\t\t\to.write_shift(4, 0);\n\t\t\to.write_shift(4, 0);\n\t\t\to.write_shift(2, 0xFFFF);\n\t\t\treturn o;\n\t\t}\n\t\tvar s = 0, e = 0, v1 = 0, v2 = 0;\n\t\tif(v < 0) { s = 1; v = -v; }\n\t\te = Math.log2(v) | 0;\n\t\tv /= Math.pow(2, e-31);\n\t\tv2 = (v)>>>0;\n\t\tif((v2&0x80000000) == 0) { v/=2; ++e; v2 = v >>> 0; }\n\t\tv -= v2;\n\t\tv2 |= 0x80000000;\n\t\tv2 >>>= 0;\n\t\tv *= Math.pow(2, 32);\n\t\tv1 = v>>>0;\n\t\to.write_shift(4, v1);\n\t\to.write_shift(4, v2);\n\t\te += 0x3FFF + (s ? 0x8000 : 0);\n\t\to.write_shift(2, e);\n\t\treturn o;\n\t}\n\n\tfunction parse_FORMULA_19(blob, length) {\n\t\tvar o = parse_NUMBER_17(blob, 14);\n\t\tblob.l += length - 14; /* TODO: WK3 formula */\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_25(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\tvar v1 = blob.read_shift(4);\n\t\to[1].v = v1 >> 6;\n\t\treturn o;\n\t}\n\n\tfunction parse_NUMBER_27(blob, length) {\n\t\tvar o = parse_cell_3(blob, length);\n\t\tvar v1 = blob.read_shift(8,'f');\n\t\to[1].v = v1;\n\t\treturn o;\n\t}\n\n\tfunction parse_FORMULA_28(blob, length) {\n\t\tvar o = parse_NUMBER_27(blob, 14);\n\t\tblob.l += length - 10; /* TODO: formula */\n\t\treturn o;\n\t}\n\n\tfunction parse_SHEETNAMECS(blob, length) {\n\t\treturn blob[blob.l + length - 1] == 0 ? blob.read_shift(length, 'cstr') : \"\";\n\t}\n\n\tfunction parse_SHEETNAMELP(blob, length) {\n\t\tvar len = blob[blob.l++];\n\t\tif(len > length - 1) len = length - 1;\n\t\tvar o = \"\"; while(o.length < len) o += String.fromCharCode(blob[blob.l++]);\n\t\treturn o;\n\t}\n\n\tfunction parse_SHEETINFOQP(blob, length, opts) {\n\t\tif(!opts.qpro || length < 21) return;\n\t\tvar id = blob.read_shift(1);\n\t\tblob.l += 17;\n\t\tblob.l += 1; //var len = blob.read_shift(1);\n\t\tblob.l += 2;\n\t\tvar nm = blob.read_shift(length - 21, 'cstr');\n\t\treturn [id, nm];\n\t}\n\n\tfunction parse_XFORMAT(blob, length) {\n\t\tvar o = {}, tgt = blob.l + length;\n\t\twhile(blob.l < tgt) {\n\t\t\tvar dt = blob.read_shift(2);\n\t\t\tif(dt == 0x36b0) {\n\t\t\t\to[dt] = [0, \"\"];\n\t\t\t\to[dt][0] = blob.read_shift(2);\n\t\t\t\twhile(blob[blob.l]) { o[dt][1] += String.fromCharCode(blob[blob.l]); blob.l++; } blob.l++;\n\t\t\t}\n\t\t\t// TODO: 0x3a99 ??\n\t\t}\n\t\treturn o;\n\t}\n\tfunction write_XFORMAT_SHEETNAME(name, wsidx) {\n\t\tvar out = new_buf(5 + name.length);\n\t\tout.write_shift(2, 0x36b0);\n\t\tout.write_shift(2, wsidx);\n\t\tfor(var i = 0; i < name.length; ++i) {\n\t\t\tvar cc = name.charCodeAt(i);\n\t\t\tout[out.l++] = cc > 0x7F ? 0x5F : cc;\n\t\t}\n\t\tout[out.l++] = 0;\n\t\treturn out;\n\t}\n\n\tvar WK1Enum = {\n\t\t/*::[*/0x0000/*::]*/: { n:\"BOF\", f:parseuint16 },\n\t\t/*::[*/0x0001/*::]*/: { n:\"EOF\" },\n\t\t/*::[*/0x0002/*::]*/: { n:\"CALCMODE\" },\n\t\t/*::[*/0x0003/*::]*/: { n:\"CALCORDER\" },\n\t\t/*::[*/0x0004/*::]*/: { n:\"SPLIT\" },\n\t\t/*::[*/0x0005/*::]*/: { n:\"SYNC\" },\n\t\t/*::[*/0x0006/*::]*/: { n:\"RANGE\", f:parse_RANGE },\n\t\t/*::[*/0x0007/*::]*/: { n:\"WINDOW1\" },\n\t\t/*::[*/0x0008/*::]*/: { n:\"COLW1\" },\n\t\t/*::[*/0x0009/*::]*/: { n:\"WINTWO\" },\n\t\t/*::[*/0x000A/*::]*/: { n:\"COLW2\" },\n\t\t/*::[*/0x000B/*::]*/: { n:\"NAME\" },\n\t\t/*::[*/0x000C/*::]*/: { n:\"BLANK\" },\n\t\t/*::[*/0x000D/*::]*/: { n:\"INTEGER\", f:parse_INTEGER },\n\t\t/*::[*/0x000E/*::]*/: { n:\"NUMBER\", f:parse_NUMBER },\n\t\t/*::[*/0x000F/*::]*/: { n:\"LABEL\", f:parse_LABEL },\n\t\t/*::[*/0x0010/*::]*/: { n:\"FORMULA\", f:parse_FORMULA },\n\t\t/*::[*/0x0018/*::]*/: { n:\"TABLE\" },\n\t\t/*::[*/0x0019/*::]*/: { n:\"ORANGE\" },\n\t\t/*::[*/0x001A/*::]*/: { n:\"PRANGE\" },\n\t\t/*::[*/0x001B/*::]*/: { n:\"SRANGE\" },\n\t\t/*::[*/0x001C/*::]*/: { n:\"FRANGE\" },\n\t\t/*::[*/0x001D/*::]*/: { n:\"KRANGE1\" },\n\t\t/*::[*/0x0020/*::]*/: { n:\"HRANGE\" },\n\t\t/*::[*/0x0023/*::]*/: { n:\"KRANGE2\" },\n\t\t/*::[*/0x0024/*::]*/: { n:\"PROTEC\" },\n\t\t/*::[*/0x0025/*::]*/: { n:\"FOOTER\" },\n\t\t/*::[*/0x0026/*::]*/: { n:\"HEADER\" },\n\t\t/*::[*/0x0027/*::]*/: { n:\"SETUP\" },\n\t\t/*::[*/0x0028/*::]*/: { n:\"MARGINS\" },\n\t\t/*::[*/0x0029/*::]*/: { n:\"LABELFMT\" },\n\t\t/*::[*/0x002A/*::]*/: { n:\"TITLES\" },\n\t\t/*::[*/0x002B/*::]*/: { n:\"SHEETJS\" },\n\t\t/*::[*/0x002D/*::]*/: { n:\"GRAPH\" },\n\t\t/*::[*/0x002E/*::]*/: { n:\"NGRAPH\" },\n\t\t/*::[*/0x002F/*::]*/: { n:\"CALCCOUNT\" },\n\t\t/*::[*/0x0030/*::]*/: { n:\"UNFORMATTED\" },\n\t\t/*::[*/0x0031/*::]*/: { n:\"CURSORW12\" },\n\t\t/*::[*/0x0032/*::]*/: { n:\"WINDOW\" },\n\t\t/*::[*/0x0033/*::]*/: { n:\"STRING\", f:parse_LABEL },\n\t\t/*::[*/0x0037/*::]*/: { n:\"PASSWORD\" },\n\t\t/*::[*/0x0038/*::]*/: { n:\"LOCKED\" },\n\t\t/*::[*/0x003C/*::]*/: { n:\"QUERY\" },\n\t\t/*::[*/0x003D/*::]*/: { n:\"QUERYNAME\" },\n\t\t/*::[*/0x003E/*::]*/: { n:\"PRINT\" },\n\t\t/*::[*/0x003F/*::]*/: { n:\"PRINTNAME\" },\n\t\t/*::[*/0x0040/*::]*/: { n:\"GRAPH2\" },\n\t\t/*::[*/0x0041/*::]*/: { n:\"GRAPHNAME\" },\n\t\t/*::[*/0x0042/*::]*/: { n:\"ZOOM\" },\n\t\t/*::[*/0x0043/*::]*/: { n:\"SYMSPLIT\" },\n\t\t/*::[*/0x0044/*::]*/: { n:\"NSROWS\" },\n\t\t/*::[*/0x0045/*::]*/: { n:\"NSCOLS\" },\n\t\t/*::[*/0x0046/*::]*/: { n:\"RULER\" },\n\t\t/*::[*/0x0047/*::]*/: { n:\"NNAME\" },\n\t\t/*::[*/0x0048/*::]*/: { n:\"ACOMM\" },\n\t\t/*::[*/0x0049/*::]*/: { n:\"AMACRO\" },\n\t\t/*::[*/0x004A/*::]*/: { n:\"PARSE\" },\n\t\t/*::[*/0x0066/*::]*/: { n:\"PRANGES??\" },\n\t\t/*::[*/0x0067/*::]*/: { n:\"RRANGES??\" },\n\t\t/*::[*/0x0068/*::]*/: { n:\"FNAME??\" },\n\t\t/*::[*/0x0069/*::]*/: { n:\"MRANGES??\" },\n\t\t/*::[*/0x00CC/*::]*/: { n:\"SHEETNAMECS\", f:parse_SHEETNAMECS },\n\t\t/*::[*/0x00DE/*::]*/: { n:\"SHEETNAMELP\", f:parse_SHEETNAMELP },\n\t\t/*::[*/0xFFFF/*::]*/: { n:\"\" }\n\t};\n\n\tvar WK3Enum = {\n\t\t/*::[*/0x0000/*::]*/: { n:\"BOF\" },\n\t\t/*::[*/0x0001/*::]*/: { n:\"EOF\" },\n\t\t/*::[*/0x0002/*::]*/: { n:\"PASSWORD\" },\n\t\t/*::[*/0x0003/*::]*/: { n:\"CALCSET\" },\n\t\t/*::[*/0x0004/*::]*/: { n:\"WINDOWSET\" },\n\t\t/*::[*/0x0005/*::]*/: { n:\"SHEETCELLPTR\" },\n\t\t/*::[*/0x0006/*::]*/: { n:\"SHEETLAYOUT\" },\n\t\t/*::[*/0x0007/*::]*/: { n:\"COLUMNWIDTH\" },\n\t\t/*::[*/0x0008/*::]*/: { n:\"HIDDENCOLUMN\" },\n\t\t/*::[*/0x0009/*::]*/: { n:\"USERRANGE\" },\n\t\t/*::[*/0x000A/*::]*/: { n:\"SYSTEMRANGE\" },\n\t\t/*::[*/0x000B/*::]*/: { n:\"ZEROFORCE\" },\n\t\t/*::[*/0x000C/*::]*/: { n:\"SORTKEYDIR\" },\n\t\t/*::[*/0x000D/*::]*/: { n:\"FILESEAL\" },\n\t\t/*::[*/0x000E/*::]*/: { n:\"DATAFILLNUMS\" },\n\t\t/*::[*/0x000F/*::]*/: { n:\"PRINTMAIN\" },\n\t\t/*::[*/0x0010/*::]*/: { n:\"PRINTSTRING\" },\n\t\t/*::[*/0x0011/*::]*/: { n:\"GRAPHMAIN\" },\n\t\t/*::[*/0x0012/*::]*/: { n:\"GRAPHSTRING\" },\n\t\t/*::[*/0x0013/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0014/*::]*/: { n:\"ERRCELL\" },\n\t\t/*::[*/0x0015/*::]*/: { n:\"NACELL\" },\n\t\t/*::[*/0x0016/*::]*/: { n:\"LABEL16\", f:parse_LABEL_16},\n\t\t/*::[*/0x0017/*::]*/: { n:\"NUMBER17\", f:parse_NUMBER_17 },\n\t\t/*::[*/0x0018/*::]*/: { n:\"NUMBER18\", f:parse_NUMBER_18 },\n\t\t/*::[*/0x0019/*::]*/: { n:\"FORMULA19\", f:parse_FORMULA_19},\n\t\t/*::[*/0x001A/*::]*/: { n:\"FORMULA1A\" },\n\t\t/*::[*/0x001B/*::]*/: { n:\"XFORMAT\", f:parse_XFORMAT },\n\t\t/*::[*/0x001C/*::]*/: { n:\"DTLABELMISC\" },\n\t\t/*::[*/0x001D/*::]*/: { n:\"DTLABELCELL\" },\n\t\t/*::[*/0x001E/*::]*/: { n:\"GRAPHWINDOW\" },\n\t\t/*::[*/0x001F/*::]*/: { n:\"CPA\" },\n\t\t/*::[*/0x0020/*::]*/: { n:\"LPLAUTO\" },\n\t\t/*::[*/0x0021/*::]*/: { n:\"QUERY\" },\n\t\t/*::[*/0x0022/*::]*/: { n:\"HIDDENSHEET\" },\n\t\t/*::[*/0x0023/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0025/*::]*/: { n:\"NUMBER25\", f:parse_NUMBER_25 },\n\t\t/*::[*/0x0026/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0027/*::]*/: { n:\"NUMBER27\", f:parse_NUMBER_27 },\n\t\t/*::[*/0x0028/*::]*/: { n:\"FORMULA28\", f:parse_FORMULA_28 },\n\t\t/*::[*/0x008E/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0093/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0096/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0097/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0098/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0099/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x009A/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x009B/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x009C/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00A3/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00AE/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00AF/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B0/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B1/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B8/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00B9/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00BA/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00BB/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00BC/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00C3/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00C9/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00CC/*::]*/: { n:\"SHEETNAMECS\", f:parse_SHEETNAMECS },\n\t\t/*::[*/0x00CD/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00CE/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00CF/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x00D0/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0100/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0103/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0104/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0105/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0106/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0107/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0109/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010A/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010B/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010C/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010E/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x010F/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0180/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0185/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0186/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0189/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x018C/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0200/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0202/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0201/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0204/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0205/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0280/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0281/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0282/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0283/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0284/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0285/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0286/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0287/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0288/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0292/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0293/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0294/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0295/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0296/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0299/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x029A/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0300/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0304/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0601/*::]*/: { n:\"SHEETINFOQP\", f:parse_SHEETINFOQP },\n\t\t/*::[*/0x0640/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0642/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0701/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0702/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0703/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0704/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0780/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0800/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0801/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0804/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x0A80/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x2AF6/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x3231/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x6E49/*::]*/: { n:\"??\" },\n\t\t/*::[*/0x6F44/*::]*/: { n:\"??\" },\n\t\t/*::[*/0xFFFF/*::]*/: { n:\"\" }\n\t};\n\treturn {\n\t\tsheet_to_wk1: sheet_to_wk1,\n\t\tbook_to_wk3: book_to_wk3,\n\t\tto_workbook: lotus_to_workbook\n\t};\n})();\n/* 18.4.7 rPr CT_RPrElt */\nfunction parse_rpr(rpr) {\n\tvar font = {}, m = rpr.match(tagregex), i = 0;\n\tvar pass = false;\n\tif(m) for(;i!=m.length; ++i) {\n\t\tvar y = parsexmltag(m[i]);\n\t\tswitch(y[0].replace(/\\w*:/g,\"\")) {\n\t\t\t/* 18.8.12 condense CT_BooleanProperty */\n\t\t\t/* ** not required . */\n\t\t\tcase '<condense': break;\n\t\t\t/* 18.8.17 extend CT_BooleanProperty */\n\t\t\t/* ** not required . */\n\t\t\tcase '<extend': break;\n\t\t\t/* 18.8.36 shadow CT_BooleanProperty */\n\t\t\t/* ** not required . */\n\t\t\tcase '<shadow':\n\t\t\t\tif(!y.val) break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<shadow>':\n\t\t\tcase '<shadow/>': font.shadow = 1; break;\n\t\t\tcase '</shadow>': break;\n\n\t\t\t/* 18.4.1 charset CT_IntProperty TODO */\n\t\t\tcase '<charset':\n\t\t\t\tif(y.val == '1') break;\n\t\t\t\tfont.cp = CS2CP[parseInt(y.val, 10)];\n\t\t\t\tbreak;\n\n\t\t\t/* 18.4.2 outline CT_BooleanProperty TODO */\n\t\t\tcase '<outline':\n\t\t\t\tif(!y.val) break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<outline>':\n\t\t\tcase '<outline/>': font.outline = 1; break;\n\t\t\tcase '</outline>': break;\n\n\t\t\t/* 18.4.5 rFont CT_FontName */\n\t\t\tcase '<rFont': font.name = y.val; break;\n\n\t\t\t/* 18.4.11 sz CT_FontSize */\n\t\t\tcase '<sz': font.sz = y.val; break;\n\n\t\t\t/* 18.4.10 strike CT_BooleanProperty */\n\t\t\tcase '<strike':\n\t\t\t\tif(!y.val) break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<strike>':\n\t\t\tcase '<strike/>': font.strike = 1; break;\n\t\t\tcase '</strike>': break;\n\n\t\t\t/* 18.4.13 u CT_UnderlineProperty */\n\t\t\tcase '<u':\n\t\t\t\tif(!y.val) break;\n\t\t\t\tswitch(y.val) {\n\t\t\t\t\tcase 'double': font.uval = \"double\"; break;\n\t\t\t\t\tcase 'singleAccounting': font.uval = \"single-accounting\"; break;\n\t\t\t\t\tcase 'doubleAccounting': font.uval = \"double-accounting\"; break;\n\t\t\t\t}\n\t\t\t\t/* falls through */\n\t\t\tcase '<u>':\n\t\t\tcase '<u/>': font.u = 1; break;\n\t\t\tcase '</u>': break;\n\n\t\t\t/* 18.8.2 b */\n\t\t\tcase '<b':\n\t\t\t\tif(y.val == '0') break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<b>':\n\t\t\tcase '<b/>': font.b = 1; break;\n\t\t\tcase '</b>': break;\n\n\t\t\t/* 18.8.26 i */\n\t\t\tcase '<i':\n\t\t\t\tif(y.val == '0') break;\n\t\t\t\t/* falls through */\n\t\t\tcase '<i>':\n\t\t\tcase '<i/>': font.i = 1; break;\n\t\t\tcase '</i>': break;\n\n\t\t\t/* 18.3.1.15 color CT_Color TODO: tint, theme, auto, indexed */\n\t\t\tcase '<color':\n\t\t\t\tif(y.rgb) font.color = y.rgb.slice(2,8);\n\t\t\t\tbreak;\n\t\t\tcase '<color>': case '<color/>': case '</color>': break;\n\n\t\t\t/* 18.8.18 family ST_FontFamily */\n\t\t\tcase '<family': font.family = y.val; break;\n\t\t\tcase '<family>': case '<family/>': case '</family>': break;\n\n\t\t\t/* 18.4.14 vertAlign CT_VerticalAlignFontProperty TODO */\n\t\t\tcase '<vertAlign': font.valign = y.val; break;\n\t\t\tcase '<vertAlign>': case '<vertAlign/>': case '</vertAlign>': break;\n\n\t\t\t/* 18.8.35 scheme CT_FontScheme TODO */\n\t\t\tcase '<scheme': break;\n\t\t\tcase '<scheme>': case '<scheme/>': case '</scheme>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault:\n\t\t\t\tif(y[0].charCodeAt(1) !== 47 && !pass) throw new Error('Unrecognized rich format ' + y[0]);\n\t\t}\n\t}\n\treturn font;\n}\n\nvar parse_rs = /*#__PURE__*/(function() {\n\tvar tregex = matchtag(\"t\"), rpregex = matchtag(\"rPr\");\n\t/* 18.4.4 r CT_RElt */\n\tfunction parse_r(r) {\n\t\t/* 18.4.12 t ST_Xstring */\n\t\tvar t = r.match(tregex)/*, cp = 65001*/;\n\t\tif(!t) return {t:\"s\", v:\"\"};\n\n\t\tvar o/*:Cell*/ = ({t:'s', v:unescapexml(t[1])}/*:any*/);\n\t\tvar rpr = r.match(rpregex);\n\t\tif(rpr) o.s = parse_rpr(rpr[1]);\n\t\treturn o;\n\t}\n\tvar rregex = /<(?:\\w+:)?r>/g, rend = /<\\/(?:\\w+:)?r>/;\n\treturn function parse_rs(rs) {\n\t\treturn rs.replace(rregex,\"\").split(rend).map(parse_r).filter(function(r) { return r.v; });\n\t};\n})();\n\n\n/* Parse a list of <r> tags */\nvar rs_to_html = /*#__PURE__*/(function parse_rs_factory() {\n\tvar nlregex = /(\\r\\n|\\n)/g;\n\tfunction parse_rpr2(font, intro, outro) {\n\t\tvar style/*:Array<string>*/ = [];\n\n\t\tif(font.u) style.push(\"text-decoration: underline;\");\n\t\tif(font.uval) style.push(\"text-underline-style:\" + font.uval + \";\");\n\t\tif(font.sz) style.push(\"font-size:\" + font.sz + \"pt;\");\n\t\tif(font.outline) style.push(\"text-effect: outline;\");\n\t\tif(font.shadow) style.push(\"text-shadow: auto;\");\n\t\tintro.push('<span style=\"' + style.join(\"\") + '\">');\n\n\t\tif(font.b) { intro.push(\"<b>\"); outro.push(\"</b>\"); }\n\t\tif(font.i) { intro.push(\"<i>\"); outro.push(\"</i>\"); }\n\t\tif(font.strike) { intro.push(\"<s>\"); outro.push(\"</s>\"); }\n\n\t\tvar align = font.valign || \"\";\n\t\tif(align == \"superscript\" || align == \"super\") align = \"sup\";\n\t\telse if(align == \"subscript\") align = \"sub\";\n\t\tif(align != \"\") { intro.push(\"<\" + align + \">\"); outro.push(\"</\" + align + \">\"); }\n\n\t\toutro.push(\"</span>\");\n\t\treturn font;\n\t}\n\n\t/* 18.4.4 r CT_RElt */\n\tfunction r_to_html(r) {\n\t\tvar terms/*:[Array<string>, string, Array<string>]*/ = [[],r.v,[]];\n\t\tif(!r.v) return \"\";\n\n\t\tif(r.s) parse_rpr2(r.s, terms[0], terms[2]);\n\n\t\treturn terms[0].join(\"\") + terms[1].replace(nlregex,'<br/>') + terms[2].join(\"\");\n\t}\n\n\treturn function parse_rs(rs) {\n\t\treturn rs.map(r_to_html).join(\"\");\n\t};\n})();\n\n/* 18.4.8 si CT_Rst */\nvar sitregex = /<(?:\\w+:)?t[^>]*>([^<]*)<\\/(?:\\w+:)?t>/g, sirregex = /<(?:\\w+:)?r>/;\nvar sirphregex = /<(?:\\w+:)?rPh.*?>([\\s\\S]*?)<\\/(?:\\w+:)?rPh>/g;\nfunction parse_si(x, opts) {\n\tvar html = opts ? opts.cellHTML : true;\n\tvar z = {};\n\tif(!x) return { t: \"\" };\n\t//var y;\n\t/* 18.4.12 t ST_Xstring (Plaintext String) */\n\t// TODO: is whitespace actually valid here?\n\tif(x.match(/^\\s*<(?:\\w+:)?t[^>]*>/)) {\n\t\tz.t = unescapexml(utf8read(x.slice(x.indexOf(\">\")+1).split(/<\\/(?:\\w+:)?t>/)[0]||\"\"));\n\t\tz.r = utf8read(x);\n\t\tif(html) z.h = escapehtml(z.t);\n\t}\n\t/* 18.4.4 r CT_RElt (Rich Text Run) */\n\telse if((/*y = */x.match(sirregex))) {\n\t\tz.r = utf8read(x);\n\t\tz.t = unescapexml(utf8read((x.replace(sirphregex, '').match(sitregex)||[]).join(\"\").replace(tagregex,\"\")));\n\t\tif(html) z.h = rs_to_html(parse_rs(z.r));\n\t}\n\t/* 18.4.3 phoneticPr CT_PhoneticPr (TODO: needed for Asian support) */\n\t/* 18.4.6 rPh CT_PhoneticRun (TODO: needed for Asian support) */\n\treturn z;\n}\n\n/* 18.4 Shared String Table */\nvar sstr0 = /<(?:\\w+:)?sst([^>]*)>([\\s\\S]*)<\\/(?:\\w+:)?sst>/;\nvar sstr1 = /<(?:\\w+:)?(?:si|sstItem)>/g;\nvar sstr2 = /<\\/(?:\\w+:)?(?:si|sstItem)>/;\nfunction parse_sst_xml(data/*:string*/, opts)/*:SST*/ {\n\tvar s/*:SST*/ = ([]/*:any*/), ss = \"\";\n\tif(!data) return s;\n\t/* 18.4.9 sst CT_Sst */\n\tvar sst = data.match(sstr0);\n\tif(sst) {\n\t\tss = sst[2].replace(sstr1,\"\").split(sstr2);\n\t\tfor(var i = 0; i != ss.length; ++i) {\n\t\t\tvar o = parse_si(ss[i].trim(), opts);\n\t\t\tif(o != null) s[s.length] = o;\n\t\t}\n\t\tsst = parsexmltag(sst[1]); s.Count = sst.count; s.Unique = sst.uniqueCount;\n\t}\n\treturn s;\n}\n\nvar straywsregex = /^\\s|\\s$|[\\t\\n\\r]/;\nfunction write_sst_xml(sst/*:SST*/, opts)/*:string*/ {\n\tif(!opts.bookSST) return \"\";\n\tvar o = [XML_HEADER];\n\to[o.length] = (writextag('sst', null, {\n\t\txmlns: XMLNS_main[0],\n\t\tcount: sst.Count,\n\t\tuniqueCount: sst.Unique\n\t}));\n\tfor(var i = 0; i != sst.length; ++i) { if(sst[i] == null) continue;\n\t\tvar s/*:XLString*/ = sst[i];\n\t\tvar sitag = \"<si>\";\n\t\tif(s.r) sitag += s.r;\n\t\telse {\n\t\t\tsitag += \"<t\";\n\t\t\tif(!s.t) s.t = \"\";\n\t\t\tif(s.t.match(straywsregex)) sitag += ' xml:space=\"preserve\"';\n\t\t\tsitag += \">\" + escapexml(s.t) + \"</t>\";\n\t\t}\n\t\tsitag += \"</si>\";\n\t\to[o.length] = (sitag);\n\t}\n\tif(o.length>2){ o[o.length] = ('</sst>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.221 BrtBeginSst */\nfunction parse_BrtBeginSst(data) {\n\treturn [data.read_shift(4), data.read_shift(4)];\n}\n\n/* [MS-XLSB] 2.1.7.45 Shared Strings */\nfunction parse_sst_bin(data, opts)/*:SST*/ {\n\tvar s/*:SST*/ = ([]/*:any*/);\n\tvar pass = false;\n\trecordhopper(data, function hopper_sst(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x009F: /* BrtBeginSst */\n\t\t\t\ts.Count = val[0]; s.Unique = val[1]; break;\n\t\t\tcase 0x0013: /* BrtSSTItem */\n\t\t\t\ts.push(val); break;\n\t\t\tcase 0x00A0: /* BrtEndSst */\n\t\t\t\treturn true;\n\n\t\t\tcase 0x0023: /* BrtFRTBegin */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* BrtFRTEnd */\n\t\t\t\tpass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){}\n\t\t\t\tif(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn s;\n}\n\nfunction write_BrtBeginSst(sst, o) {\n\tif(!o) o = new_buf(8);\n\to.write_shift(4, sst.Count);\n\to.write_shift(4, sst.Unique);\n\treturn o;\n}\n\nvar write_BrtSSTItem = write_RichStr;\n\nfunction write_sst_bin(sst/*::, opts*/) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x009F /* BrtBeginSst */, write_BrtBeginSst(sst));\n\tfor(var i = 0; i < sst.length; ++i) write_record(ba, 0x0013 /* BrtSSTItem */, write_BrtSSTItem(sst[i]));\n\t/* FRTSST */\n\twrite_record(ba, 0x00A0 /* BrtEndSst */);\n\treturn ba.end();\n}\nfunction _JS2ANSI(str/*:string*/)/*:Array<number>*/ {\n\tif(typeof $cptable !== 'undefined') return $cptable.utils.encode(current_ansi, str);\n\tvar o/*:Array<number>*/ = [], oo = str.split(\"\");\n\tfor(var i = 0; i < oo.length; ++i) o[i] = oo[i].charCodeAt(0);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.4 Version */\nfunction parse_CRYPTOVersion(blob, length/*:?number*/) {\n\tvar o/*:any*/ = {};\n\to.Major = blob.read_shift(2);\n\to.Minor = blob.read_shift(2);\n\t/*:: if(length == null) return o; */\n\tif(length >= 4) blob.l += length - 4;\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.5 DataSpaceVersionInfo */\nfunction parse_DataSpaceVersionInfo(blob) {\n\tvar o = {};\n\to.id = blob.read_shift(0, 'lpp4');\n\to.R = parse_CRYPTOVersion(blob, 4);\n\to.U = parse_CRYPTOVersion(blob, 4);\n\to.W = parse_CRYPTOVersion(blob, 4);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.6.1 DataSpaceMapEntry Structure */\nfunction parse_DataSpaceMapEntry(blob) {\n\tvar len = blob.read_shift(4);\n\tvar end = blob.l + len - 4;\n\tvar o = {};\n\tvar cnt = blob.read_shift(4);\n\tvar comps/*:Array<{t:number, v:string}>*/ = [];\n\t/* [MS-OFFCRYPTO] 2.1.6.2 DataSpaceReferenceComponent Structure */\n\twhile(cnt-- > 0) comps.push({ t: blob.read_shift(4), v: blob.read_shift(0, 'lpp4') });\n\to.name = blob.read_shift(0, 'lpp4');\n\to.comps = comps;\n\tif(blob.l != end) throw new Error(\"Bad DataSpaceMapEntry: \" + blob.l + \" != \" + end);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.6 DataSpaceMap */\nfunction parse_DataSpaceMap(blob) {\n\tvar o = [];\n\tblob.l += 4; // must be 0x8\n\tvar cnt = blob.read_shift(4);\n\twhile(cnt-- > 0) o.push(parse_DataSpaceMapEntry(blob));\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.7 DataSpaceDefinition */\nfunction parse_DataSpaceDefinition(blob)/*:Array<string>*/ {\n\tvar o/*:Array<string>*/ = [];\n\tblob.l += 4; // must be 0x8\n\tvar cnt = blob.read_shift(4);\n\twhile(cnt-- > 0) o.push(blob.read_shift(0, 'lpp4'));\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.1.8 DataSpaceDefinition */\nfunction parse_TransformInfoHeader(blob) {\n\tvar o = {};\n\t/*var len = */blob.read_shift(4);\n\tblob.l += 4; // must be 0x1\n\to.id = blob.read_shift(0, 'lpp4');\n\to.name = blob.read_shift(0, 'lpp4');\n\to.R = parse_CRYPTOVersion(blob, 4);\n\to.U = parse_CRYPTOVersion(blob, 4);\n\to.W = parse_CRYPTOVersion(blob, 4);\n\treturn o;\n}\n\nfunction parse_Primary(blob) {\n\t/* [MS-OFFCRYPTO] 2.2.6 IRMDSTransformInfo */\n\tvar hdr = parse_TransformInfoHeader(blob);\n\t/* [MS-OFFCRYPTO] 2.1.9 EncryptionTransformInfo */\n\thdr.ename = blob.read_shift(0, '8lpp4');\n\thdr.blksz = blob.read_shift(4);\n\thdr.cmode = blob.read_shift(4);\n\tif(blob.read_shift(4) != 0x04) throw new Error(\"Bad !Primary record\");\n\treturn hdr;\n}\n\n/* [MS-OFFCRYPTO] 2.3.2 Encryption Header */\nfunction parse_EncryptionHeader(blob, length/*:number*/) {\n\tvar tgt = blob.l + length;\n\tvar o = {};\n\to.Flags = (blob.read_shift(4) & 0x3F);\n\tblob.l += 4;\n\to.AlgID = blob.read_shift(4);\n\tvar valid = false;\n\tswitch(o.AlgID) {\n\t\tcase 0x660E: case 0x660F: case 0x6610: valid = (o.Flags == 0x24); break;\n\t\tcase 0x6801: valid = (o.Flags == 0x04); break;\n\t\tcase 0: valid = (o.Flags == 0x10 || o.Flags == 0x04 || o.Flags == 0x24); break;\n\t\tdefault: throw 'Unrecognized encryption algorithm: ' + o.AlgID;\n\t}\n\tif(!valid) throw new Error(\"Encryption Flags/AlgID mismatch\");\n\to.AlgIDHash = blob.read_shift(4);\n\to.KeySize = blob.read_shift(4);\n\to.ProviderType = blob.read_shift(4);\n\tblob.l += 8;\n\to.CSPName = blob.read_shift((tgt-blob.l)>>1, 'utf16le');\n\tblob.l = tgt;\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.3 Encryption Verifier */\nfunction parse_EncryptionVerifier(blob, length/*:number*/) {\n\tvar o = {}, tgt = blob.l + length;\n\tblob.l += 4; // SaltSize must be 0x10\n\to.Salt = blob.slice(blob.l, blob.l+16); blob.l += 16;\n\to.Verifier = blob.slice(blob.l, blob.l+16); blob.l += 16;\n\t/*var sz = */blob.read_shift(4);\n\to.VerifierHash = blob.slice(blob.l, tgt); blob.l = tgt;\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.4.* EncryptionInfo Stream */\nfunction parse_EncryptionInfo(blob) {\n\tvar vers = parse_CRYPTOVersion(blob);\n\tswitch(vers.Minor) {\n\t\tcase 0x02: return [vers.Minor, parse_EncInfoStd(blob, vers)];\n\t\tcase 0x03: return [vers.Minor, parse_EncInfoExt(blob, vers)];\n\t\tcase 0x04: return [vers.Minor, parse_EncInfoAgl(blob, vers)];\n\t}\n\tthrow new Error(\"ECMA-376 Encrypted file unrecognized Version: \" + vers.Minor);\n}\n\n/* [MS-OFFCRYPTO] 2.3.4.5  EncryptionInfo Stream (Standard Encryption) */\nfunction parse_EncInfoStd(blob/*::, vers*/) {\n\tvar flags = blob.read_shift(4);\n\tif((flags & 0x3F) != 0x24) throw new Error(\"EncryptionInfo mismatch\");\n\tvar sz = blob.read_shift(4);\n\t//var tgt = blob.l + sz;\n\tvar hdr = parse_EncryptionHeader(blob, sz);\n\tvar verifier = parse_EncryptionVerifier(blob, blob.length - blob.l);\n\treturn { t:\"Std\", h:hdr, v:verifier };\n}\n/* [MS-OFFCRYPTO] 2.3.4.6  EncryptionInfo Stream (Extensible Encryption) */\nfunction parse_EncInfoExt(/*::blob, vers*/) { throw new Error(\"File is password-protected: ECMA-376 Extensible\"); }\n/* [MS-OFFCRYPTO] 2.3.4.10 EncryptionInfo Stream (Agile Encryption) */\nfunction parse_EncInfoAgl(blob/*::, vers*/) {\n\tvar KeyData = [\"saltSize\",\"blockSize\",\"keyBits\",\"hashSize\",\"cipherAlgorithm\",\"cipherChaining\",\"hashAlgorithm\",\"saltValue\"];\n\tblob.l+=4;\n\tvar xml = blob.read_shift(blob.length - blob.l, 'utf8');\n\tvar o = {};\n\txml.replace(tagregex, function xml_agile(x) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\t\t\tcase '<encryption': case '</encryption>': break;\n\t\t\tcase '<keyData': KeyData.forEach(function(k) { o[k] = y[k]; }); break;\n\t\t\tcase '<dataIntegrity': o.encryptedHmacKey = y.encryptedHmacKey; o.encryptedHmacValue = y.encryptedHmacValue; break;\n\t\t\tcase '<keyEncryptors>': case '<keyEncryptors': o.encs = []; break;\n\t\t\tcase '</keyEncryptors>': break;\n\n\t\t\tcase '<keyEncryptor': o.uri = y.uri; break;\n\t\t\tcase '</keyEncryptor>': break;\n\t\t\tcase '<encryptedKey': o.encs.push(y); break;\n\t\t\tdefault: throw y[0];\n\t\t}\n\t});\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.5.1 RC4 CryptoAPI Encryption Header */\nfunction parse_RC4CryptoHeader(blob, length/*:number*/) {\n\tvar o = {};\n\tvar vers = o.EncryptionVersionInfo = parse_CRYPTOVersion(blob, 4); length -= 4;\n\tif(vers.Minor != 2) throw new Error('unrecognized minor version code: ' + vers.Minor);\n\tif(vers.Major > 4 || vers.Major < 2) throw new Error('unrecognized major version code: ' + vers.Major);\n\to.Flags = blob.read_shift(4); length -= 4;\n\tvar sz = blob.read_shift(4); length -= 4;\n\to.EncryptionHeader = parse_EncryptionHeader(blob, sz); length -= sz;\n\to.EncryptionVerifier = parse_EncryptionVerifier(blob, length);\n\treturn o;\n}\n/* [MS-OFFCRYPTO] 2.3.6.1 RC4 Encryption Header */\nfunction parse_RC4Header(blob/*::, length*/) {\n\tvar o = {};\n\tvar vers = o.EncryptionVersionInfo = parse_CRYPTOVersion(blob, 4);\n\tif(vers.Major != 1 || vers.Minor != 1) throw 'unrecognized version code ' + vers.Major + ' : ' + vers.Minor;\n\to.Salt = blob.read_shift(16);\n\to.EncryptedVerifier = blob.read_shift(16);\n\to.EncryptedVerifierHash = blob.read_shift(16);\n\treturn o;\n}\n\n/* [MS-OFFCRYPTO] 2.3.7.1 Binary Document Password Verifier Derivation */\nfunction crypto_CreatePasswordVerifier_Method1(Password/*:string*/) {\n\tvar Verifier = 0x0000, PasswordArray;\n\tvar PasswordDecoded = _JS2ANSI(Password);\n\tvar len = PasswordDecoded.length + 1, i, PasswordByte;\n\tvar Intermediate1, Intermediate2, Intermediate3;\n\tPasswordArray = new_raw_buf(len);\n\tPasswordArray[0] = PasswordDecoded.length;\n\tfor(i = 1; i != len; ++i) PasswordArray[i] = PasswordDecoded[i-1];\n\tfor(i = len-1; i >= 0; --i) {\n\t\tPasswordByte = PasswordArray[i];\n\t\tIntermediate1 = ((Verifier & 0x4000) === 0x0000) ? 0 : 1;\n\t\tIntermediate2 = (Verifier << 1) & 0x7FFF;\n\t\tIntermediate3 = Intermediate1 | Intermediate2;\n\t\tVerifier = Intermediate3 ^ PasswordByte;\n\t}\n\treturn Verifier ^ 0xCE4B;\n}\n\n/* [MS-OFFCRYPTO] 2.3.7.2 Binary Document XOR Array Initialization */\nvar crypto_CreateXorArray_Method1 = /*#__PURE__*/(function() {\n\tvar PadArray = [0xBB, 0xFF, 0xFF, 0xBA, 0xFF, 0xFF, 0xB9, 0x80, 0x00, 0xBE, 0x0F, 0x00, 0xBF, 0x0F, 0x00];\n\tvar InitialCode = [0xE1F0, 0x1D0F, 0xCC9C, 0x84C0, 0x110C, 0x0E10, 0xF1CE, 0x313E, 0x1872, 0xE139, 0xD40F, 0x84F9, 0x280C, 0xA96A, 0x4EC3];\n\tvar XorMatrix = [0xAEFC, 0x4DD9, 0x9BB2, 0x2745, 0x4E8A, 0x9D14, 0x2A09, 0x7B61, 0xF6C2, 0xFDA5, 0xEB6B, 0xC6F7, 0x9DCF, 0x2BBF, 0x4563, 0x8AC6, 0x05AD, 0x0B5A, 0x16B4, 0x2D68, 0x5AD0, 0x0375, 0x06EA, 0x0DD4, 0x1BA8, 0x3750, 0x6EA0, 0xDD40, 0xD849, 0xA0B3, 0x5147, 0xA28E, 0x553D, 0xAA7A, 0x44D5, 0x6F45, 0xDE8A, 0xAD35, 0x4A4B, 0x9496, 0x390D, 0x721A, 0xEB23, 0xC667, 0x9CEF, 0x29FF, 0x53FE, 0xA7FC, 0x5FD9, 0x47D3, 0x8FA6, 0x0F6D, 0x1EDA, 0x3DB4, 0x7B68, 0xF6D0, 0xB861, 0x60E3, 0xC1C6, 0x93AD, 0x377B, 0x6EF6, 0xDDEC, 0x45A0, 0x8B40, 0x06A1, 0x0D42, 0x1A84, 0x3508, 0x6A10, 0xAA51, 0x4483, 0x8906, 0x022D, 0x045A, 0x08B4, 0x1168, 0x76B4, 0xED68, 0xCAF1, 0x85C3, 0x1BA7, 0x374E, 0x6E9C, 0x3730, 0x6E60, 0xDCC0, 0xA9A1, 0x4363, 0x86C6, 0x1DAD, 0x3331, 0x6662, 0xCCC4, 0x89A9, 0x0373, 0x06E6, 0x0DCC, 0x1021, 0x2042, 0x4084, 0x8108, 0x1231, 0x2462, 0x48C4];\n\tvar Ror = function(Byte) { return ((Byte/2) | (Byte*128)) & 0xFF; };\n\tvar XorRor = function(byte1, byte2) { return Ror(byte1 ^ byte2); };\n\tvar CreateXorKey_Method1 = function(Password) {\n\t\tvar XorKey = InitialCode[Password.length - 1];\n\t\tvar CurrentElement = 0x68;\n\t\tfor(var i = Password.length-1; i >= 0; --i) {\n\t\t\tvar Char = Password[i];\n\t\t\tfor(var j = 0; j != 7; ++j) {\n\t\t\t\tif(Char & 0x40) XorKey ^= XorMatrix[CurrentElement];\n\t\t\t\tChar *= 2; --CurrentElement;\n\t\t\t}\n\t\t}\n\t\treturn XorKey;\n\t};\n\treturn function(password/*:string*/) {\n\t\tvar Password = _JS2ANSI(password);\n\t\tvar XorKey = CreateXorKey_Method1(Password);\n\t\tvar Index = Password.length;\n\t\tvar ObfuscationArray = new_raw_buf(16);\n\t\tfor(var i = 0; i != 16; ++i) ObfuscationArray[i] = 0x00;\n\t\tvar Temp, PasswordLastChar, PadIndex;\n\t\tif((Index & 1) === 1) {\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(PadArray[0], Temp);\n\t\t\t--Index;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tPasswordLastChar = Password[Password.length - 1];\n\t\t\tObfuscationArray[Index] = XorRor(PasswordLastChar, Temp);\n\t\t}\n\t\twhile(Index > 0) {\n\t\t\t--Index;\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t\t--Index;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t}\n\t\tIndex = 15;\n\t\tPadIndex = 15 - Password.length;\n\t\twhile(PadIndex > 0) {\n\t\t\tTemp = XorKey >> 8;\n\t\t\tObfuscationArray[Index] = XorRor(PadArray[PadIndex], Temp);\n\t\t\t--Index;\n\t\t\t--PadIndex;\n\t\t\tTemp = XorKey & 0xFF;\n\t\t\tObfuscationArray[Index] = XorRor(Password[Index], Temp);\n\t\t\t--Index;\n\t\t\t--PadIndex;\n\t\t}\n\t\treturn ObfuscationArray;\n\t};\n})();\n\n/* [MS-OFFCRYPTO] 2.3.7.3 Binary Document XOR Data Transformation Method 1 */\nvar crypto_DecryptData_Method1 = function(password/*:string*/, Data, XorArrayIndex, XorArray, O) {\n\t/* If XorArray is set, use it; if O is not set, make changes in-place */\n\tif(!O) O = Data;\n\tif(!XorArray) XorArray = crypto_CreateXorArray_Method1(password);\n\tvar Index, Value;\n\tfor(Index = 0; Index != Data.length; ++Index) {\n\t\tValue = Data[Index];\n\t\tValue ^= XorArray[XorArrayIndex];\n\t\tValue = ((Value>>5) | (Value<<3)) & 0xFF;\n\t\tO[Index] = Value;\n\t\t++XorArrayIndex;\n\t}\n\treturn [O, XorArrayIndex, XorArray];\n};\n\nvar crypto_MakeXorDecryptor = function(password/*:string*/) {\n\tvar XorArrayIndex = 0, XorArray = crypto_CreateXorArray_Method1(password);\n\treturn function(Data) {\n\t\tvar O = crypto_DecryptData_Method1(\"\", Data, XorArrayIndex, XorArray);\n\t\tXorArrayIndex = O[1];\n\t\treturn O[0];\n\t};\n};\n\n/* 2.5.343 */\nfunction parse_XORObfuscation(blob, length, opts, out) {\n\tvar o = ({ key: parseuint16(blob), verificationBytes: parseuint16(blob) }/*:any*/);\n\tif(opts.password) o.verifier = crypto_CreatePasswordVerifier_Method1(opts.password);\n\tout.valid = o.verificationBytes === o.verifier;\n\tif(out.valid) out.insitu = crypto_MakeXorDecryptor(opts.password);\n\treturn o;\n}\n\n/* 2.4.117 */\nfunction parse_FilePassHeader(blob, length/*:number*/, oo) {\n\tvar o = oo || {}; o.Info = blob.read_shift(2); blob.l -= 2;\n\tif(o.Info === 1) o.Data = parse_RC4Header(blob, length);\n\telse o.Data = parse_RC4CryptoHeader(blob, length);\n\treturn o;\n}\nfunction parse_FilePass(blob, length/*:number*/, opts) {\n\tvar o = ({ Type: opts.biff >= 8 ? blob.read_shift(2) : 0 }/*:any*/); /* wEncryptionType */\n\tif(o.Type) parse_FilePassHeader(blob, length-2, o);\n\telse parse_XORObfuscation(blob, opts.biff >= 8 ? length : length - 2, opts, o);\n\treturn o;\n}\n\n\nvar RTF = /*#__PURE__*/(function() {\n\tfunction rtf_to_sheet(d/*:RawData*/, opts)/*:Worksheet*/ {\n\t\tswitch(opts.type) {\n\t\t\tcase 'base64': return rtf_to_sheet_str(Base64_decode(d), opts);\n\t\t\tcase 'binary': return rtf_to_sheet_str(d, opts);\n\t\t\tcase 'buffer': return rtf_to_sheet_str(has_buf && Buffer.isBuffer(d) ? d.toString('binary') : a2s(d), opts);\n\t\t\tcase 'array':  return rtf_to_sheet_str(cc2str(d), opts);\n\t\t}\n\t\tthrow new Error(\"Unrecognized type \" + opts.type);\n\t}\n\n\t/* TODO: this is a stub */\n\tfunction rtf_to_sheet_str(str/*:string*/, opts)/*:Worksheet*/ {\n\t\tvar o = opts || {};\n\t\tvar ws/*:Worksheet*/ = o.dense ? ([]/*:any*/) : ({}/*:any*/);\n\n\t\tvar rows = str.match(/\\\\trowd.*?\\\\row\\b/g);\n\t\tif(!rows.length) throw new Error(\"RTF missing table\");\n\t\tvar range/*:Range*/ = ({s: {c:0, r:0}, e: {c:0, r:rows.length - 1}}/*:any*/);\n\t\trows.forEach(function(rowtf, R) {\n\t\t\tif(Array.isArray(ws)) ws[R] = [];\n\t\t\tvar rtfre = /\\\\\\w+\\b/g;\n\t\t\tvar last_index = 0;\n\t\t\tvar res;\n\t\t\tvar C = -1;\n\t\t\twhile((res = rtfre.exec(rowtf))) {\n\t\t\t\tswitch(res[0]) {\n\t\t\t\t\tcase \"\\\\cell\":\n\t\t\t\t\t\tvar data = rowtf.slice(last_index, rtfre.lastIndex - res[0].length);\n\t\t\t\t\t\tif(data[0] == \" \") data = data.slice(1);\n\t\t\t\t\t\t++C;\n\t\t\t\t\t\tif(data.length) {\n\t\t\t\t\t\t\t// TODO: value parsing, including codepage adjustments\n\t\t\t\t\t\t\tvar cell = {v: data, t:\"s\"};\n\t\t\t\t\t\t\tif(Array.isArray(ws)) ws[R][C] = cell;\n\t\t\t\t\t\t\telse ws[encode_cell({r:R, c:C})] = cell;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tlast_index = rtfre.lastIndex;\n\t\t\t}\n\t\t\tif(C > range.e.c) range.e.c = C;\n\t\t});\n\t\tws['!ref'] = encode_range(range);\n\t\treturn ws;\n\t}\n\n\tfunction rtf_to_workbook(d/*:RawData*/, opts)/*:Workbook*/ { return sheet_to_workbook(rtf_to_sheet(d, opts), opts); }\n\n\t/* TODO: this is a stub */\n\tfunction sheet_to_rtf(ws/*:Worksheet*//*::, opts*/)/*:string*/ {\n\t\tvar o = [\"{\\\\rtf1\\\\ansi\"];\n\t\tvar r = safe_decode_range(ws['!ref']), cell/*:Cell*/;\n\t\tvar dense = Array.isArray(ws);\n\t\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\t\to.push(\"\\\\trowd\\\\trautofit1\");\n\t\t\tfor(var C = r.s.c; C <= r.e.c; ++C) o.push(\"\\\\cellx\" + (C+1));\n\t\t\to.push(\"\\\\pard\\\\intbl\");\n\t\t\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\t\t\tvar coord = encode_cell({r:R,c:C});\n\t\t\t\tcell = dense ? (ws[R]||[])[C]: ws[coord];\n\t\t\t\tif(!cell || cell.v == null && (!cell.f || cell.F)) continue;\n\t\t\t\to.push(\" \" + (cell.w || (format_cell(cell), cell.w)));\n\t\t\t\to.push(\"\\\\cell\");\n\t\t\t}\n\t\t\to.push(\"\\\\pard\\\\intbl\\\\row\");\n\t\t}\n\t\treturn o.join(\"\") + \"}\";\n\t}\n\n\treturn {\n\t\tto_workbook: rtf_to_workbook,\n\t\tto_sheet: rtf_to_sheet,\n\t\tfrom_sheet: sheet_to_rtf\n\t};\n})();\nfunction hex2RGB(h) {\n\tvar o = h.slice(h[0]===\"#\"?1:0).slice(0,6);\n\treturn [parseInt(o.slice(0,2),16),parseInt(o.slice(2,4),16),parseInt(o.slice(4,6),16)];\n}\nfunction rgb2Hex(rgb) {\n\tfor(var i=0,o=1; i!=3; ++i) o = o*256 + (rgb[i]>255?255:rgb[i]<0?0:rgb[i]);\n\treturn o.toString(16).toUpperCase().slice(1);\n}\n\nfunction rgb2HSL(rgb) {\n\tvar R = rgb[0]/255, G = rgb[1]/255, B=rgb[2]/255;\n\tvar M = Math.max(R, G, B), m = Math.min(R, G, B), C = M - m;\n\tif(C === 0) return [0, 0, R];\n\n\tvar H6 = 0, S = 0, L2 = (M + m);\n\tS = C / (L2 > 1 ? 2 - L2 : L2);\n\tswitch(M){\n\t\tcase R: H6 = ((G - B) / C + 6)%6; break;\n\t\tcase G: H6 = ((B - R) / C + 2); break;\n\t\tcase B: H6 = ((R - G) / C + 4); break;\n\t}\n\treturn [H6 / 6, S, L2 / 2];\n}\n\nfunction hsl2RGB(hsl){\n\tvar H = hsl[0], S = hsl[1], L = hsl[2];\n\tvar C = S * 2 * (L < 0.5 ? L : 1 - L), m = L - C/2;\n\tvar rgb = [m,m,m], h6 = 6*H;\n\n\tvar X;\n\tif(S !== 0) switch(h6|0) {\n\t\tcase 0: case 6: X = C * h6; rgb[0] += C; rgb[1] += X; break;\n\t\tcase 1: X = C * (2 - h6);   rgb[0] += X; rgb[1] += C; break;\n\t\tcase 2: X = C * (h6 - 2);   rgb[1] += C; rgb[2] += X; break;\n\t\tcase 3: X = C * (4 - h6);   rgb[1] += X; rgb[2] += C; break;\n\t\tcase 4: X = C * (h6 - 4);   rgb[2] += C; rgb[0] += X; break;\n\t\tcase 5: X = C * (6 - h6);   rgb[2] += X; rgb[0] += C; break;\n\t}\n\tfor(var i = 0; i != 3; ++i) rgb[i] = Math.round(rgb[i]*255);\n\treturn rgb;\n}\n\n/* 18.8.3 bgColor tint algorithm */\nfunction rgb_tint(hex, tint) {\n\tif(tint === 0) return hex;\n\tvar hsl = rgb2HSL(hex2RGB(hex));\n\tif (tint < 0) hsl[2] = hsl[2] * (1 + tint);\n\telse hsl[2] = 1 - (1 - hsl[2]) * (1 - tint);\n\treturn rgb2Hex(hsl2RGB(hsl));\n}\n\n/* 18.3.1.13 width calculations */\n/* [MS-OI29500] 2.1.595 Column Width & Formatting */\nvar DEF_MDW = 6, MAX_MDW = 15, MIN_MDW = 1, MDW = DEF_MDW;\nfunction width2px(width) { return Math.floor(( width + (Math.round(128/MDW))/256 )* MDW ); }\nfunction px2char(px) { return (Math.floor((px - 5)/MDW * 100 + 0.5))/100; }\nfunction char2width(chr) { return (Math.round((chr * MDW + 5)/MDW*256))/256; }\n//function px2char_(px) { return (((px - 5)/MDW * 100 + 0.5))/100; }\n//function char2width_(chr) { return (((chr * MDW + 5)/MDW*256))/256; }\nfunction cycle_width(collw) { return char2width(px2char(width2px(collw))); }\n/* XLSX/XLSB/XLS specify width in units of MDW */\nfunction find_mdw_colw(collw) {\n\tvar delta = Math.abs(collw - cycle_width(collw)), _MDW = MDW;\n\tif(delta > 0.005) for(MDW=MIN_MDW; MDW<MAX_MDW; ++MDW) if(Math.abs(collw - cycle_width(collw)) <= delta) { delta = Math.abs(collw - cycle_width(collw)); _MDW = MDW; }\n\tMDW = _MDW;\n}\n/* XLML specifies width in terms of pixels */\n/*function find_mdw_wpx(wpx) {\n\tvar delta = Infinity, guess = 0, _MDW = MIN_MDW;\n\tfor(MDW=MIN_MDW; MDW<MAX_MDW; ++MDW) {\n\t\tguess = char2width_(px2char_(wpx))*256;\n\t\tguess = (guess) % 1;\n\t\tif(guess > 0.5) guess--;\n\t\tif(Math.abs(guess) < delta) { delta = Math.abs(guess); _MDW = MDW; }\n\t}\n\tMDW = _MDW;\n}*/\n\nfunction process_col(coll/*:ColInfo*/) {\n\tif(coll.width) {\n\t\tcoll.wpx = width2px(coll.width);\n\t\tcoll.wch = px2char(coll.wpx);\n\t\tcoll.MDW = MDW;\n\t} else if(coll.wpx) {\n\t\tcoll.wch = px2char(coll.wpx);\n\t\tcoll.width = char2width(coll.wch);\n\t\tcoll.MDW = MDW;\n\t} else if(typeof coll.wch == 'number') {\n\t\tcoll.width = char2width(coll.wch);\n\t\tcoll.wpx = width2px(coll.width);\n\t\tcoll.MDW = MDW;\n\t}\n\tif(coll.customWidth) delete coll.customWidth;\n}\n\nvar DEF_PPI = 96, PPI = DEF_PPI;\nfunction px2pt(px) { return px * 96 / PPI; }\nfunction pt2px(pt) { return pt * PPI / 96; }\n\n/* [MS-EXSPXML3] 2.4.54 ST_enmPattern */\nvar XLMLPatternTypeMap = {\n\t\"None\": \"none\",\n\t\"Solid\": \"solid\",\n\t\"Gray50\": \"mediumGray\",\n\t\"Gray75\": \"darkGray\",\n\t\"Gray25\": \"lightGray\",\n\t\"HorzStripe\": \"darkHorizontal\",\n\t\"VertStripe\": \"darkVertical\",\n\t\"ReverseDiagStripe\": \"darkDown\",\n\t\"DiagStripe\": \"darkUp\",\n\t\"DiagCross\": \"darkGrid\",\n\t\"ThickDiagCross\": \"darkTrellis\",\n\t\"ThinHorzStripe\": \"lightHorizontal\",\n\t\"ThinVertStripe\": \"lightVertical\",\n\t\"ThinReverseDiagStripe\": \"lightDown\",\n\t\"ThinHorzCross\": \"lightGrid\"\n};\n\n/* 18.8.5 borders CT_Borders */\nfunction parse_borders(t, styles, themes, opts) {\n\tstyles.Borders = [];\n\tvar border = {};\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<borders': case '<borders>': case '</borders>': break;\n\n\t\t\t/* 18.8.4 border CT_Border */\n\t\t\tcase '<border': case '<border>': case '<border/>':\n\t\t\t\tborder = /*::(*/{}/*:: :any)*/;\n\t\t\t\tif(y.diagonalUp) border.diagonalUp = parsexmlbool(y.diagonalUp);\n\t\t\t\tif(y.diagonalDown) border.diagonalDown = parsexmlbool(y.diagonalDown);\n\t\t\t\tstyles.Borders.push(border);\n\t\t\t\tbreak;\n\t\t\tcase '</border>': break;\n\n\t\t\t/* note: not in spec, appears to be CT_BorderPr */\n\t\t\tcase '<left/>': break;\n\t\t\tcase '<left': case '<left>': break;\n\t\t\tcase '</left>': break;\n\n\t\t\t/* note: not in spec, appears to be CT_BorderPr */\n\t\t\tcase '<right/>': break;\n\t\t\tcase '<right': case '<right>': break;\n\t\t\tcase '</right>': break;\n\n\t\t\t/* 18.8.43 top CT_BorderPr */\n\t\t\tcase '<top/>': break;\n\t\t\tcase '<top': case '<top>': break;\n\t\t\tcase '</top>': break;\n\n\t\t\t/* 18.8.6 bottom CT_BorderPr */\n\t\t\tcase '<bottom/>': break;\n\t\t\tcase '<bottom': case '<bottom>': break;\n\t\t\tcase '</bottom>': break;\n\n\t\t\t/* 18.8.13 diagonal CT_BorderPr */\n\t\t\tcase '<diagonal': case '<diagonal>': case '<diagonal/>': break;\n\t\t\tcase '</diagonal>': break;\n\n\t\t\t/* 18.8.25 horizontal CT_BorderPr */\n\t\t\tcase '<horizontal': case '<horizontal>': case '<horizontal/>': break;\n\t\t\tcase '</horizontal>': break;\n\n\t\t\t/* 18.8.44 vertical CT_BorderPr */\n\t\t\tcase '<vertical': case '<vertical>': case '<vertical/>': break;\n\t\t\tcase '</vertical>': break;\n\n\t\t\t/* 18.8.37 start CT_BorderPr */\n\t\t\tcase '<start': case '<start>': case '<start/>': break;\n\t\t\tcase '</start>': break;\n\n\t\t\t/* 18.8.16 end CT_BorderPr */\n\t\t\tcase '<end': case '<end>': case '<end/>': break;\n\t\t\tcase '</end>': break;\n\n\t\t\t/* 18.8.? color CT_Color */\n\t\t\tcase '<color': case '<color>':\n\t\t\t\tbreak;\n\t\t\tcase '<color/>': case '</color>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in borders');\n\t\t\t}\n\t\t}\n\t});\n}\n\n/* 18.8.21 fills CT_Fills */\nfunction parse_fills(t, styles, themes, opts) {\n\tstyles.Fills = [];\n\tvar fill = {};\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<fills': case '<fills>': case '</fills>': break;\n\n\t\t\t/* 18.8.20 fill CT_Fill */\n\t\t\tcase '<fill>': case '<fill': case '<fill/>':\n\t\t\t\tfill = {}; styles.Fills.push(fill); break;\n\t\t\tcase '</fill>': break;\n\n\t\t\t/* 18.8.24 gradientFill CT_GradientFill */\n\t\t\tcase '<gradientFill>': break;\n\t\t\tcase '<gradientFill':\n\t\t\tcase '</gradientFill>': styles.Fills.push(fill); fill = {}; break;\n\n\t\t\t/* 18.8.32 patternFill CT_PatternFill */\n\t\t\tcase '<patternFill': case '<patternFill>':\n\t\t\t\tif(y.patternType) fill.patternType = y.patternType;\n\t\t\t\tbreak;\n\t\t\tcase '<patternFill/>': case '</patternFill>': break;\n\n\t\t\t/* 18.8.3 bgColor CT_Color */\n\t\t\tcase '<bgColor':\n\t\t\t\tif(!fill.bgColor) fill.bgColor = {};\n\t\t\t\tif(y.indexed) fill.bgColor.indexed = parseInt(y.indexed, 10);\n\t\t\t\tif(y.theme) fill.bgColor.theme = parseInt(y.theme, 10);\n\t\t\t\tif(y.tint) fill.bgColor.tint = parseFloat(y.tint);\n\t\t\t\t/* Excel uses ARGB strings */\n\t\t\t\tif(y.rgb) fill.bgColor.rgb = y.rgb.slice(-6);\n\t\t\t\tbreak;\n\t\t\tcase '<bgColor/>': case '</bgColor>': break;\n\n\t\t\t/* 18.8.19 fgColor CT_Color */\n\t\t\tcase '<fgColor':\n\t\t\t\tif(!fill.fgColor) fill.fgColor = {};\n\t\t\t\tif(y.theme) fill.fgColor.theme = parseInt(y.theme, 10);\n\t\t\t\tif(y.tint) fill.fgColor.tint = parseFloat(y.tint);\n\t\t\t\t/* Excel uses ARGB strings */\n\t\t\t\tif(y.rgb != null) fill.fgColor.rgb = y.rgb.slice(-6);\n\t\t\t\tbreak;\n\t\t\tcase '<fgColor/>': case '</fgColor>': break;\n\n\t\t\t/* 18.8.38 stop CT_GradientStop */\n\t\t\tcase '<stop': case '<stop/>': break;\n\t\t\tcase '</stop>': break;\n\n\t\t\t/* 18.8.? color CT_Color */\n\t\t\tcase '<color': case '<color/>': break;\n\t\t\tcase '</color>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in fills');\n\t\t\t}\n\t\t}\n\t});\n}\n\n/* 18.8.23 fonts CT_Fonts */\nfunction parse_fonts(t, styles, themes, opts) {\n\tstyles.Fonts = [];\n\tvar font = {};\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<fonts': case '<fonts>': case '</fonts>': break;\n\n\t\t\t/* 18.8.22 font CT_Font */\n\t\t\tcase '<font': case '<font>': break;\n\t\t\tcase '</font>': case '<font/>':\n\t\t\t\tstyles.Fonts.push(font);\n\t\t\t\tfont = {};\n\t\t\t\tbreak;\n\n\t\t\t/* 18.8.29 name CT_FontName */\n\t\t\tcase '<name': if(y.val) font.name = utf8read(y.val); break;\n\t\t\tcase '<name/>': case '</name>': break;\n\n\t\t\t/* 18.8.2  b CT_BooleanProperty */\n\t\t\tcase '<b': font.bold = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<b/>': font.bold = 1; break;\n\n\t\t\t/* 18.8.26 i CT_BooleanProperty */\n\t\t\tcase '<i': font.italic = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<i/>': font.italic = 1; break;\n\n\t\t\t/* 18.4.13 u CT_UnderlineProperty */\n\t\t\tcase '<u':\n\t\t\t\tswitch(y.val) {\n\t\t\t\t\tcase \"none\": font.underline = 0x00; break;\n\t\t\t\t\tcase \"single\": font.underline = 0x01; break;\n\t\t\t\t\tcase \"double\": font.underline = 0x02; break;\n\t\t\t\t\tcase \"singleAccounting\": font.underline = 0x21; break;\n\t\t\t\t\tcase \"doubleAccounting\": font.underline = 0x22; break;\n\t\t\t\t} break;\n\t\t\tcase '<u/>': font.underline = 1; break;\n\n\t\t\t/* 18.4.10 strike CT_BooleanProperty */\n\t\t\tcase '<strike': font.strike = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<strike/>': font.strike = 1; break;\n\n\t\t\t/* 18.4.2  outline CT_BooleanProperty */\n\t\t\tcase '<outline': font.outline = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<outline/>': font.outline = 1; break;\n\n\t\t\t/* 18.8.36 shadow CT_BooleanProperty */\n\t\t\tcase '<shadow': font.shadow = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<shadow/>': font.shadow = 1; break;\n\n\t\t\t/* 18.8.12 condense CT_BooleanProperty */\n\t\t\tcase '<condense': font.condense = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<condense/>': font.condense = 1; break;\n\n\t\t\t/* 18.8.17 extend CT_BooleanProperty */\n\t\t\tcase '<extend': font.extend = y.val ? parsexmlbool(y.val) : 1; break;\n\t\t\tcase '<extend/>': font.extend = 1; break;\n\n\t\t\t/* 18.4.11 sz CT_FontSize */\n\t\t\tcase '<sz': if(y.val) font.sz = +y.val; break;\n\t\t\tcase '<sz/>': case '</sz>': break;\n\n\t\t\t/* 18.4.14 vertAlign CT_VerticalAlignFontProperty */\n\t\t\tcase '<vertAlign': if(y.val) font.vertAlign = y.val; break;\n\t\t\tcase '<vertAlign/>': case '</vertAlign>': break;\n\n\t\t\t/* 18.8.18 family CT_FontFamily */\n\t\t\tcase '<family': if(y.val) font.family = parseInt(y.val,10); break;\n\t\t\tcase '<family/>': case '</family>': break;\n\n\t\t\t/* 18.8.35 scheme CT_FontScheme */\n\t\t\tcase '<scheme': if(y.val) font.scheme = y.val; break;\n\t\t\tcase '<scheme/>': case '</scheme>': break;\n\n\t\t\t/* 18.4.1 charset CT_IntProperty */\n\t\t\tcase '<charset':\n\t\t\t\tif(y.val == '1') break;\n\t\t\t\ty.codepage = CS2CP[parseInt(y.val, 10)];\n\t\t\t\tbreak;\n\n\t\t\t/* 18.?.? color CT_Color */\n\t\t\tcase '<color':\n\t\t\t\tif(!font.color) font.color = {};\n\t\t\t\tif(y.auto) font.color.auto = parsexmlbool(y.auto);\n\n\t\t\t\tif(y.rgb) font.color.rgb = y.rgb.slice(-6);\n\t\t\t\telse if(y.indexed) {\n\t\t\t\t\tfont.color.index = parseInt(y.indexed, 10);\n\t\t\t\t\tvar icv = XLSIcv[font.color.index];\n\t\t\t\t\tif(font.color.index == 81) icv = XLSIcv[1];\n\t\t\t\t\tif(!icv) icv = XLSIcv[1]; //throw new Error(x); // note: 206 is valid\n\t\t\t\t\tfont.color.rgb = icv[0].toString(16) + icv[1].toString(16) + icv[2].toString(16);\n\t\t\t\t} else if(y.theme) {\n\t\t\t\t\tfont.color.theme = parseInt(y.theme, 10);\n\t\t\t\t\tif(y.tint) font.color.tint = parseFloat(y.tint);\n\t\t\t\t\tif(y.theme && themes.themeElements && themes.themeElements.clrScheme) {\n\t\t\t\t\t\tfont.color.rgb = rgb_tint(themes.themeElements.clrScheme[font.color.theme].rgb, font.color.tint || 0);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tbreak;\n\t\t\tcase '<color/>': case '</color>': break;\n\n\t\t\t/* note: sometimes mc:AlternateContent appears bare */\n\t\t\tcase '<AlternateContent': pass = true; break;\n\t\t\tcase '</AlternateContent>': pass = false; break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in fonts');\n\t\t\t}\n\t\t}\n\t});\n}\n\n/* 18.8.31 numFmts CT_NumFmts */\nfunction parse_numFmts(t, styles, opts) {\n\tstyles.NumberFmt = [];\n\tvar k/*Array<number>*/ = (keys(table_fmt)/*:any*/);\n\tfor(var i=0; i < k.length; ++i) styles.NumberFmt[k[i]] = table_fmt[k[i]];\n\tvar m = t[0].match(tagregex);\n\tif(!m) return;\n\tfor(i=0; i < m.length; ++i) {\n\t\tvar y = parsexmltag(m[i]);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<numFmts': case '</numFmts>': case '<numFmts/>': case '<numFmts>': break;\n\t\t\tcase '<numFmt': {\n\t\t\t\tvar f=unescapexml(utf8read(y.formatCode)), j=parseInt(y.numFmtId,10);\n\t\t\t\tstyles.NumberFmt[j] = f;\n\t\t\t\tif(j>0) {\n\t\t\t\t\tif(j > 0x188) {\n\t\t\t\t\t\tfor(j = 0x188; j > 0x3c; --j) if(styles.NumberFmt[j] == null) break;\n\t\t\t\t\t\tstyles.NumberFmt[j] = f;\n\t\t\t\t\t}\n\t\t\t\t\tSSF_load(f,j);\n\t\t\t\t}\n\t\t\t} break;\n\t\t\tcase '</numFmt>': break;\n\t\t\tdefault: if(opts.WTF) throw new Error('unrecognized ' + y[0] + ' in numFmts');\n\t\t}\n\t}\n}\n\nfunction write_numFmts(NF/*:{[n:number|string]:string}*//*::, opts*/) {\n\tvar o = [\"<numFmts>\"];\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) o[o.length] = (writextag('numFmt',null,{numFmtId:i,formatCode:escapexml(NF[i])}));\n\t});\n\tif(o.length === 1) return \"\";\n\to[o.length] = (\"</numFmts>\");\n\to[0] = writextag('numFmts', null, { count:o.length-2 }).replace(\"/>\", \">\");\n\treturn o.join(\"\");\n}\n\n/* 18.8.10 cellXfs CT_CellXfs */\nvar cellXF_uint = [ \"numFmtId\", \"fillId\", \"fontId\", \"borderId\", \"xfId\" ];\nvar cellXF_bool = [ \"applyAlignment\", \"applyBorder\", \"applyFill\", \"applyFont\", \"applyNumberFormat\", \"applyProtection\", \"pivotButton\", \"quotePrefix\" ];\nfunction parse_cellXfs(t, styles, opts) {\n\tstyles.CellXf = [];\n\tvar xf;\n\tvar pass = false;\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x), i = 0;\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<cellXfs': case '<cellXfs>': case '<cellXfs/>': case '</cellXfs>': break;\n\n\t\t\t/* 18.8.45 xf CT_Xf */\n\t\t\tcase '<xf': case '<xf/>':\n\t\t\t\txf = y;\n\t\t\t\tdelete xf[0];\n\t\t\t\tfor(i = 0; i < cellXF_uint.length; ++i) if(xf[cellXF_uint[i]])\n\t\t\t\t\txf[cellXF_uint[i]] = parseInt(xf[cellXF_uint[i]], 10);\n\t\t\t\tfor(i = 0; i < cellXF_bool.length; ++i) if(xf[cellXF_bool[i]])\n\t\t\t\t\txf[cellXF_bool[i]] = parsexmlbool(xf[cellXF_bool[i]]);\n\t\t\t\tif(styles.NumberFmt && xf.numFmtId > 0x188) {\n\t\t\t\t\tfor(i = 0x188; i > 0x3c; --i) if(styles.NumberFmt[xf.numFmtId] == styles.NumberFmt[i]) { xf.numFmtId = i; break; }\n\t\t\t\t}\n\t\t\t\tstyles.CellXf.push(xf); break;\n\t\t\tcase '</xf>': break;\n\n\t\t\t/* 18.8.1 alignment CT_CellAlignment */\n\t\t\tcase '<alignment': case '<alignment/>':\n\t\t\t\tvar alignment = {};\n\t\t\t\tif(y.vertical) alignment.vertical = y.vertical;\n\t\t\t\tif(y.horizontal) alignment.horizontal = y.horizontal;\n\t\t\t\tif(y.textRotation != null) alignment.textRotation = y.textRotation;\n\t\t\t\tif(y.indent) alignment.indent = y.indent;\n\t\t\t\tif(y.wrapText) alignment.wrapText = parsexmlbool(y.wrapText);\n\t\t\t\txf.alignment = alignment;\n\t\t\t\tbreak;\n\t\t\tcase '</alignment>': break;\n\n\t\t\t/* 18.8.33 protection CT_CellProtection */\n\t\t\tcase '<protection':\n\t\t\t\tbreak;\n\t\t\tcase '</protection>': case '<protection/>': break;\n\n\t\t\t/* note: sometimes mc:AlternateContent appears bare */\n\t\t\tcase '<AlternateContent': pass = true; break;\n\t\t\tcase '</AlternateContent>': pass = false; break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': break;\n\t\t\tcase '<ext': pass = true; break;\n\t\t\tcase '</ext>': pass = false; break;\n\t\t\tdefault: if(opts && opts.WTF) {\n\t\t\t\tif(!pass) throw new Error('unrecognized ' + y[0] + ' in cellXfs');\n\t\t\t}\n\t\t}\n\t});\n}\n\nfunction write_cellXfs(cellXfs)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\to[o.length] = (writextag('cellXfs',null));\n\tcellXfs.forEach(function(c) {\n\t\to[o.length] = (writextag('xf', null, c));\n\t});\n\to[o.length] = (\"</cellXfs>\");\n\tif(o.length === 2) return \"\";\n\to[0] = writextag('cellXfs',null, {count:o.length-2}).replace(\"/>\",\">\");\n\treturn o.join(\"\");\n}\n\n/* 18.8 Styles CT_Stylesheet*/\nvar parse_sty_xml= /*#__PURE__*/(function make_pstyx() {\nvar numFmtRegex = /<(?:\\w+:)?numFmts([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?numFmts>/;\nvar cellXfRegex = /<(?:\\w+:)?cellXfs([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?cellXfs>/;\nvar fillsRegex = /<(?:\\w+:)?fills([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?fills>/;\nvar fontsRegex = /<(?:\\w+:)?fonts([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?fonts>/;\nvar bordersRegex = /<(?:\\w+:)?borders([^>]*)>[\\S\\s]*?<\\/(?:\\w+:)?borders>/;\n\nreturn function parse_sty_xml(data, themes, opts) {\n\tvar styles = {};\n\tif(!data) return styles;\n\tdata = data.replace(/<!--([\\s\\S]*?)-->/mg,\"\").replace(/<!DOCTYPE[^\\[]*\\[[^\\]]*\\]>/gm,\"\");\n\t/* 18.8.39 styleSheet CT_Stylesheet */\n\tvar t;\n\n\t/* 18.8.31 numFmts CT_NumFmts ? */\n\tif((t=data.match(numFmtRegex))) parse_numFmts(t, styles, opts);\n\n\t/* 18.8.23 fonts CT_Fonts ? */\n\tif((t=data.match(fontsRegex))) parse_fonts(t, styles, themes, opts);\n\n\t/* 18.8.21 fills CT_Fills ? */\n\tif((t=data.match(fillsRegex))) parse_fills(t, styles, themes, opts);\n\n\t/* 18.8.5  borders CT_Borders ? */\n\tif((t=data.match(bordersRegex))) parse_borders(t, styles, themes, opts);\n\n\t/* 18.8.9  cellStyleXfs CT_CellStyleXfs ? */\n\t/* 18.8.8  cellStyles CT_CellStyles ? */\n\n\t/* 18.8.10 cellXfs CT_CellXfs ? */\n\tif((t=data.match(cellXfRegex))) parse_cellXfs(t, styles, opts);\n\n\t/* 18.8.15 dxfs CT_Dxfs ? */\n\t/* 18.8.42 tableStyles CT_TableStyles ? */\n\t/* 18.8.11 colors CT_Colors ? */\n\t/* 18.2.10 extLst CT_ExtensionList ? */\n\n\treturn styles;\n};\n})();\n\nfunction write_sty_xml(wb/*:Workbook*/, opts)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('styleSheet', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t'xmlns:vt': XMLNS.vt\n\t})], w;\n\tif(wb.SSF && (w = write_numFmts(wb.SSF)) != null) o[o.length] = w;\n\to[o.length] = ('<fonts count=\"1\"><font><sz val=\"12\"/><color theme=\"1\"/><name val=\"Calibri\"/><family val=\"2\"/><scheme val=\"minor\"/></font></fonts>');\n\to[o.length] = ('<fills count=\"2\"><fill><patternFill patternType=\"none\"/></fill><fill><patternFill patternType=\"gray125\"/></fill></fills>');\n\to[o.length] = ('<borders count=\"1\"><border><left/><right/><top/><bottom/><diagonal/></border></borders>');\n\to[o.length] = ('<cellStyleXfs count=\"1\"><xf numFmtId=\"0\" fontId=\"0\" fillId=\"0\" borderId=\"0\"/></cellStyleXfs>');\n\tif((w = write_cellXfs(opts.cellXfs))) o[o.length] = (w);\n\to[o.length] = ('<cellStyles count=\"1\"><cellStyle name=\"Normal\" xfId=\"0\" builtinId=\"0\"/></cellStyles>');\n\to[o.length] = ('<dxfs count=\"0\"/>');\n\to[o.length] = ('<tableStyles count=\"0\" defaultTableStyle=\"TableStyleMedium9\" defaultPivotStyle=\"PivotStyleMedium4\"/>');\n\n\tif(o.length>2){ o[o.length] = ('</styleSheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.657 BrtFmt */\nfunction parse_BrtFmt(data, length/*:number*/) {\n\tvar numFmtId = data.read_shift(2);\n\tvar stFmtCode = parse_XLWideString(data,length-2);\n\treturn [numFmtId, stFmtCode];\n}\nfunction write_BrtFmt(i/*:number*/, f/*:string*/, o) {\n\tif(!o) o = new_buf(6 + 4 * f.length);\n\to.write_shift(2, i);\n\twrite_XLWideString(f, o);\n\tvar out = (o.length > o.l) ? o.slice(0, o.l) : o;\n\tif(o.l == null) o.l = o.length;\n\treturn out;\n}\n\n/* [MS-XLSB] 2.4.659 BrtFont TODO */\nfunction parse_BrtFont(data, length/*:number*/, opts) {\n\tvar out = ({}/*:any*/);\n\n\tout.sz = data.read_shift(2) / 20;\n\n\tvar grbit = parse_FontFlags(data, 2, opts);\n\tif(grbit.fItalic) out.italic = 1;\n\tif(grbit.fCondense) out.condense = 1;\n\tif(grbit.fExtend) out.extend = 1;\n\tif(grbit.fShadow) out.shadow = 1;\n\tif(grbit.fOutline) out.outline = 1;\n\tif(grbit.fStrikeout) out.strike = 1;\n\n\tvar bls = data.read_shift(2);\n\tif(bls === 0x02BC) out.bold = 1;\n\n\tswitch(data.read_shift(2)) {\n\t\t/* case 0: out.vertAlign = \"baseline\"; break; */\n\t\tcase 1: out.vertAlign = \"superscript\"; break;\n\t\tcase 2: out.vertAlign = \"subscript\"; break;\n\t}\n\n\tvar underline = data.read_shift(1);\n\tif(underline != 0) out.underline = underline;\n\n\tvar family = data.read_shift(1);\n\tif(family > 0) out.family = family;\n\n\tvar bCharSet = data.read_shift(1);\n\tif(bCharSet > 0) out.charset = bCharSet;\n\n\tdata.l++;\n\tout.color = parse_BrtColor(data, 8);\n\n\tswitch(data.read_shift(1)) {\n\t\t/* case 0: out.scheme = \"none\": break; */\n\t\tcase 1: out.scheme = \"major\"; break;\n\t\tcase 2: out.scheme = \"minor\"; break;\n\t}\n\n\tout.name = parse_XLWideString(data, length - 21);\n\n\treturn out;\n}\nfunction write_BrtFont(font/*:any*/, o) {\n\tif(!o) o = new_buf(25+4*32);\n\to.write_shift(2, font.sz * 20);\n\twrite_FontFlags(font, o);\n\to.write_shift(2, font.bold ? 0x02BC : 0x0190);\n\tvar sss = 0;\n\tif(font.vertAlign == \"superscript\") sss = 1;\n\telse if(font.vertAlign == \"subscript\") sss = 2;\n\to.write_shift(2, sss);\n\to.write_shift(1, font.underline || 0);\n\to.write_shift(1, font.family || 0);\n\to.write_shift(1, font.charset || 0);\n\to.write_shift(1, 0);\n\twrite_BrtColor(font.color, o);\n\tvar scheme = 0;\n\tif(font.scheme == \"major\") scheme = 1;\n\tif(font.scheme == \"minor\") scheme = 2;\n\to.write_shift(1, scheme);\n\twrite_XLWideString(font.name, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.650 BrtFill */\nvar XLSBFillPTNames = [\n\t\"none\",\n\t\"solid\",\n\t\"mediumGray\",\n\t\"darkGray\",\n\t\"lightGray\",\n\t\"darkHorizontal\",\n\t\"darkVertical\",\n\t\"darkDown\",\n\t\"darkUp\",\n\t\"darkGrid\",\n\t\"darkTrellis\",\n\t\"lightHorizontal\",\n\t\"lightVertical\",\n\t\"lightDown\",\n\t\"lightUp\",\n\t\"lightGrid\",\n\t\"lightTrellis\",\n\t\"gray125\",\n\t\"gray0625\"\n];\nvar rev_XLSBFillPTNames/*:EvertNumType*/;\n/* TODO: gradient fill representation */\nvar parse_BrtFill = parsenoop;\nfunction write_BrtFill(fill, o) {\n\tif(!o) o = new_buf(4*3 + 8*7 + 16*1);\n\tif(!rev_XLSBFillPTNames) rev_XLSBFillPTNames = (evert(XLSBFillPTNames)/*:any*/);\n\tvar fls/*:number*/ = rev_XLSBFillPTNames[fill.patternType];\n\tif(fls == null) fls = 0x28;\n\to.write_shift(4, fls);\n\tvar j = 0;\n\tif(fls != 0x28) {\n\t\t/* TODO: custom FG Color */\n\t\twrite_BrtColor({auto:1}, o);\n\t\t/* TODO: custom BG Color */\n\t\twrite_BrtColor({auto:1}, o);\n\n\t\tfor(; j < 12; ++j) o.write_shift(4, 0);\n\t} else {\n\t\tfor(; j < 4; ++j) o.write_shift(4, 0);\n\n\t\tfor(; j < 12; ++j) o.write_shift(4, 0); /* TODO */\n\t\t/* iGradientType */\n\t\t/* xnumDegree */\n\t\t/* xnumFillToLeft */\n\t\t/* xnumFillToRight */\n\t\t/* xnumFillToTop */\n\t\t/* xnumFillToBottom */\n\t\t/* cNumStop */\n\t\t/* xfillGradientStop */\n\t}\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.824 BrtXF */\nfunction parse_BrtXF(data, length/*:number*/) {\n\tvar tgt = data.l + length;\n\tvar ixfeParent = data.read_shift(2);\n\tvar ifmt = data.read_shift(2);\n\tdata.l = tgt;\n\treturn {ixfe:ixfeParent, numFmtId:ifmt };\n}\nfunction write_BrtXF(data, ixfeP, o) {\n\tif(!o) o = new_buf(16);\n\to.write_shift(2, ixfeP||0);\n\to.write_shift(2, data.numFmtId||0);\n\to.write_shift(2, 0); /* iFont */\n\to.write_shift(2, 0); /* iFill */\n\to.write_shift(2, 0); /* ixBorder */\n\to.write_shift(1, 0); /* trot */\n\to.write_shift(1, 0); /* indent */\n\tvar flow = 0;\n\to.write_shift(1, flow); /* flags */\n\to.write_shift(1, 0); /* flags */\n\to.write_shift(1, 0); /* xfGrbitAtr */\n\to.write_shift(1, 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.5.4 Blxf TODO */\nfunction write_Blxf(data, o) {\n\tif(!o) o = new_buf(10);\n\to.write_shift(1, 0); /* dg */\n\to.write_shift(1, 0);\n\to.write_shift(4, 0); /* color */\n\to.write_shift(4, 0); /* color */\n\treturn o;\n}\n/* [MS-XLSB] 2.4.302 BrtBorder TODO */\nvar parse_BrtBorder = parsenoop;\nfunction write_BrtBorder(border, o) {\n\tif(!o) o = new_buf(51);\n\to.write_shift(1, 0); /* diagonal */\n\twrite_Blxf(null, o); /* top */\n\twrite_Blxf(null, o); /* bottom */\n\twrite_Blxf(null, o); /* left */\n\twrite_Blxf(null, o); /* right */\n\twrite_Blxf(null, o); /* diag */\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.763 BrtStyle TODO */\nfunction write_BrtStyle(style, o) {\n\tif(!o) o = new_buf(12+4*10);\n\to.write_shift(4, style.xfId);\n\to.write_shift(2, 1);\n\to.write_shift(1, +style.builtinId);\n\to.write_shift(1, 0); /* iLevel */\n\twrite_XLNullableWideString(style.name || \"\", o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.272 BrtBeginTableStyles */\nfunction write_BrtBeginTableStyles(cnt, defTableStyle, defPivotStyle) {\n\tvar o = new_buf(4+256*2*4);\n\to.write_shift(4, cnt);\n\twrite_XLNullableWideString(defTableStyle, o);\n\twrite_XLNullableWideString(defPivotStyle, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.1.7.50 Styles */\nfunction parse_sty_bin(data, themes, opts) {\n\tvar styles = {};\n\tstyles.NumberFmt = ([]/*:any*/);\n\tfor(var y in table_fmt) styles.NumberFmt[y] = table_fmt[y];\n\n\tstyles.CellXf = [];\n\tstyles.Fonts = [];\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false;\n\trecordhopper(data, function hopper_sty(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x002C: /* BrtFmt */\n\t\t\t\tstyles.NumberFmt[val[0]] = val[1]; SSF_load(val[1], val[0]);\n\t\t\t\tbreak;\n\t\t\tcase 0x002B: /* BrtFont */\n\t\t\t\tstyles.Fonts.push(val);\n\t\t\t\tif(val.color.theme != null && themes && themes.themeElements && themes.themeElements.clrScheme) {\n\t\t\t\t\tval.color.rgb = rgb_tint(themes.themeElements.clrScheme[val.color.theme].rgb, val.color.tint || 0);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 0x0401: /* BrtKnownFonts */ break;\n\t\t\tcase 0x002D: /* BrtFill */\n\t\t\t\tbreak;\n\t\t\tcase 0x002E: /* BrtBorder */\n\t\t\t\tbreak;\n\t\t\tcase 0x002F: /* BrtXF */\n\t\t\t\tif(state[state.length - 1] == 0x0269 /* BrtBeginCellXFs */) {\n\t\t\t\t\tstyles.CellXf.push(val);\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase 0x0030: /* BrtStyle */\n\t\t\tcase 0x01FB: /* BrtDXF */\n\t\t\tcase 0x023C: /* BrtMRUColor */\n\t\t\tcase 0x01DB: /* BrtIndexedColor */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0493: /* BrtDXF14 */\n\t\t\tcase 0x0836: /* BrtDXF15 */\n\t\t\tcase 0x046A: /* BrtSlicerStyleElement */\n\t\t\tcase 0x0200: /* BrtTableStyleElement */\n\t\t\tcase 0x082F: /* BrtTimelineStyleElement */\n\t\t\tcase 0x0C00: /* BrtUid */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* BrtFRTBegin */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* BrtFRTEnd */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* BrtACBegin */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0026: /* BrtACEnd */\n\t\t\t\tstate.pop(); pass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T > 0) state.push(RT);\n\t\t\t\telse if(R.T < 0) state.pop();\n\t\t\t\telse if(!pass || (opts.WTF && state[state.length-1] != 0x0025 /* BrtACBegin */)) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn styles;\n}\n\nfunction write_FMTS_bin(ba, NF/*:?SSFTable*/) {\n\tif(!NF) return;\n\tvar cnt = 0;\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\t/*:: if(!NF) return; */\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) ++cnt;\n\t});\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x0267 /* BrtBeginFmts */, write_UInt32LE(cnt));\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\t/*:: if(!NF) return; */\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) write_record(ba, 0x002C /* BrtFmt */, write_BrtFmt(i, NF[i]));\n\t});\n\twrite_record(ba, 0x0268 /* BrtEndFmts */);\n}\n\nfunction write_FONTS_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x0263 /* BrtBeginFonts */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002B /* BrtFont */, write_BrtFont({\n\t\tsz:12,\n\t\tcolor: {theme:1},\n\t\tname: \"Calibri\",\n\t\tfamily: 2,\n\t\tscheme: \"minor\"\n\t}));\n\t/* 1*65491BrtFont [ACFONTS] */\n\twrite_record(ba, 0x0264 /* BrtEndFonts */);\n}\n\nfunction write_FILLS_bin(ba/*::, data*/) {\n\tvar cnt = 2;\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x025B /* BrtBeginFills */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002D /* BrtFill */, write_BrtFill({patternType:\"none\"}));\n\twrite_record(ba, 0x002D /* BrtFill */, write_BrtFill({patternType:\"gray125\"}));\n\t/* 1*65431BrtFill */\n\twrite_record(ba, 0x025C /* BrtEndFills */);\n}\n\nfunction write_BORDERS_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\n\tif(cnt == 0) return;\n\twrite_record(ba, 0x0265 /* BrtBeginBorders */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002E /* BrtBorder */, write_BrtBorder({}));\n\t/* 1*65430BrtBorder */\n\twrite_record(ba, 0x0266 /* BrtEndBorders */);\n}\n\nfunction write_CELLSTYLEXFS_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\twrite_record(ba, 0x0272 /* BrtBeginCellStyleXFs */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x002F /* BrtXF */, write_BrtXF({\n\t\tnumFmtId: 0,\n\t\tfontId:   0,\n\t\tfillId:   0,\n\t\tborderId: 0\n\t}, 0xFFFF));\n\t/* 1*65430(BrtXF *FRT) */\n\twrite_record(ba, 0x0273 /* BrtEndCellStyleXFs */);\n}\n\nfunction write_CELLXFS_bin(ba, data) {\n\twrite_record(ba, 0x0269 /* BrtBeginCellXFs */, write_UInt32LE(data.length));\n\tdata.forEach(function(c) { write_record(ba, 0x002F /* BrtXF */, write_BrtXF(c,0)); });\n\t/* 1*65430(BrtXF *FRT) */\n\twrite_record(ba, 0x026A /* BrtEndCellXFs */);\n}\n\nfunction write_STYLES_bin(ba/*::, data*/) {\n\tvar cnt = 1;\n\n\twrite_record(ba, 0x026B /* BrtBeginStyles */, write_UInt32LE(cnt));\n\twrite_record(ba, 0x0030 /* BrtStyle */, write_BrtStyle({\n\t\txfId:0,\n\t\tbuiltinId:0,\n\t\tname:\"Normal\"\n\t}));\n\t/* 1*65430(BrtStyle *FRT) */\n\twrite_record(ba, 0x026C /* BrtEndStyles */);\n}\n\nfunction write_DXFS_bin(ba/*::, data*/) {\n\tvar cnt = 0;\n\n\twrite_record(ba, 0x01F9 /* BrtBeginDXFs */, write_UInt32LE(cnt));\n\t/* *2147483647(BrtDXF *FRT) */\n\twrite_record(ba, 0x01FA /* BrtEndDXFs */);\n}\n\nfunction write_TABLESTYLES_bin(ba/*::, data*/) {\n\tvar cnt = 0;\n\n\twrite_record(ba, 0x01FC /* BrtBeginTableStyles */, write_BrtBeginTableStyles(cnt, \"TableStyleMedium9\", \"PivotStyleMedium4\"));\n\t/* *TABLESTYLE */\n\twrite_record(ba, 0x01FD /* BrtEndTableStyles */);\n}\n\nfunction write_COLORPALETTE_bin(/*::ba, data*/) {\n\treturn;\n\t/* BrtBeginColorPalette [INDEXEDCOLORS] [MRUCOLORS] BrtEndColorPalette */\n}\n\n/* [MS-XLSB] 2.1.7.50 Styles */\nfunction write_sty_bin(wb, opts) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x0116 /* BrtBeginStyleSheet */);\n\twrite_FMTS_bin(ba, wb.SSF);\n\twrite_FONTS_bin(ba, wb);\n\twrite_FILLS_bin(ba, wb);\n\twrite_BORDERS_bin(ba, wb);\n\twrite_CELLSTYLEXFS_bin(ba, wb);\n\twrite_CELLXFS_bin(ba, opts.cellXfs);\n\twrite_STYLES_bin(ba, wb);\n\twrite_DXFS_bin(ba, wb);\n\twrite_TABLESTYLES_bin(ba, wb);\n\twrite_COLORPALETTE_bin(ba, wb);\n\t/* FRTSTYLESHEET*/\n\twrite_record(ba, 0x0117 /* BrtEndStyleSheet */);\n\treturn ba.end();\n}\n/* Even though theme layout is dk1 lt1 dk2 lt2, true order is lt1 dk1 lt2 dk2 */\nvar XLSXThemeClrScheme = [\n\t'</a:lt1>', '</a:dk1>', '</a:lt2>', '</a:dk2>',\n\t'</a:accent1>', '</a:accent2>', '</a:accent3>',\n\t'</a:accent4>', '</a:accent5>', '</a:accent6>',\n\t'</a:hlink>', '</a:folHlink>'\n];\n/* 20.1.6.2 clrScheme CT_ColorScheme */\nfunction parse_clrScheme(t, themes, opts) {\n\tthemes.themeElements.clrScheme = [];\n\tvar color = {};\n\t(t[0].match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\t/* 20.1.6.2 clrScheme (Color Scheme) CT_ColorScheme */\n\t\t\tcase '<a:clrScheme': case '</a:clrScheme>': break;\n\n\t\t\t/* 20.1.2.3.32 srgbClr CT_SRgbColor */\n\t\t\tcase '<a:srgbClr':\n\t\t\t\tcolor.rgb = y.val; break;\n\n\t\t\t/* 20.1.2.3.33 sysClr CT_SystemColor */\n\t\t\tcase '<a:sysClr':\n\t\t\t\tcolor.rgb = y.lastClr; break;\n\n\t\t\t/* 20.1.4.1.1 accent1 (Accent 1) */\n\t\t\t/* 20.1.4.1.2 accent2 (Accent 2) */\n\t\t\t/* 20.1.4.1.3 accent3 (Accent 3) */\n\t\t\t/* 20.1.4.1.4 accent4 (Accent 4) */\n\t\t\t/* 20.1.4.1.5 accent5 (Accent 5) */\n\t\t\t/* 20.1.4.1.6 accent6 (Accent 6) */\n\t\t\t/* 20.1.4.1.9 dk1 (Dark 1) */\n\t\t\t/* 20.1.4.1.10 dk2 (Dark 2) */\n\t\t\t/* 20.1.4.1.15 folHlink (Followed Hyperlink) */\n\t\t\t/* 20.1.4.1.19 hlink (Hyperlink) */\n\t\t\t/* 20.1.4.1.22 lt1 (Light 1) */\n\t\t\t/* 20.1.4.1.23 lt2 (Light 2) */\n\t\t\tcase '<a:dk1>': case '</a:dk1>':\n\t\t\tcase '<a:lt1>': case '</a:lt1>':\n\t\t\tcase '<a:dk2>': case '</a:dk2>':\n\t\t\tcase '<a:lt2>': case '</a:lt2>':\n\t\t\tcase '<a:accent1>': case '</a:accent1>':\n\t\t\tcase '<a:accent2>': case '</a:accent2>':\n\t\t\tcase '<a:accent3>': case '</a:accent3>':\n\t\t\tcase '<a:accent4>': case '</a:accent4>':\n\t\t\tcase '<a:accent5>': case '</a:accent5>':\n\t\t\tcase '<a:accent6>': case '</a:accent6>':\n\t\t\tcase '<a:hlink>': case '</a:hlink>':\n\t\t\tcase '<a:folHlink>': case '</a:folHlink>':\n\t\t\t\tif (y[0].charAt(1) === '/') {\n\t\t\t\t\tthemes.themeElements.clrScheme[XLSXThemeClrScheme.indexOf(y[0])] = color;\n\t\t\t\t\tcolor = {};\n\t\t\t\t} else {\n\t\t\t\t\tcolor.name = y[0].slice(3, y[0].length - 1);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tdefault: if(opts && opts.WTF) throw new Error('Unrecognized ' + y[0] + ' in clrScheme');\n\t\t}\n\t});\n}\n\n/* 20.1.4.1.18 fontScheme CT_FontScheme */\nfunction parse_fontScheme(/*::t, themes, opts*/) { }\n\n/* 20.1.4.1.15 fmtScheme CT_StyleMatrix */\nfunction parse_fmtScheme(/*::t, themes, opts*/) { }\n\nvar clrsregex = /<a:clrScheme([^>]*)>[\\s\\S]*<\\/a:clrScheme>/;\nvar fntsregex = /<a:fontScheme([^>]*)>[\\s\\S]*<\\/a:fontScheme>/;\nvar fmtsregex = /<a:fmtScheme([^>]*)>[\\s\\S]*<\\/a:fmtScheme>/;\n\n/* 20.1.6.10 themeElements CT_BaseStyles */\nfunction parse_themeElements(data, themes, opts) {\n\tthemes.themeElements = {};\n\n\tvar t;\n\n\t[\n\t\t/* clrScheme CT_ColorScheme */\n\t\t['clrScheme', clrsregex, parse_clrScheme],\n\t\t/* fontScheme CT_FontScheme */\n\t\t['fontScheme', fntsregex, parse_fontScheme],\n\t\t/* fmtScheme CT_StyleMatrix */\n\t\t['fmtScheme', fmtsregex, parse_fmtScheme]\n\t].forEach(function(m) {\n\t\tif(!(t=data.match(m[1]))) throw new Error(m[0] + ' not found in themeElements');\n\t\tm[2](t, themes, opts);\n\t});\n}\n\nvar themeltregex = /<a:themeElements([^>]*)>[\\s\\S]*<\\/a:themeElements>/;\n\n/* 14.2.7 Theme Part */\nfunction parse_theme_xml(data/*:string*/, opts) {\n\t/* 20.1.6.9 theme CT_OfficeStyleSheet */\n\tif(!data || data.length === 0) data = write_theme();\n\n\tvar t;\n\tvar themes = {};\n\n\t/* themeElements CT_BaseStyles */\n\tif(!(t=data.match(themeltregex))) throw new Error('themeElements not found in theme');\n\tparse_themeElements(t[0], themes, opts);\n\tthemes.raw = data;\n\treturn themes;\n}\n\nfunction write_theme(Themes, opts)/*:string*/ {\n\tif(opts && opts.themeXLSX) return opts.themeXLSX;\n\tif(Themes && typeof Themes.raw == \"string\") return Themes.raw;\n\tvar o = [XML_HEADER];\n\to[o.length] = '<a:theme xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\" name=\"Office Theme\">';\n\to[o.length] =  '<a:themeElements>';\n\n\to[o.length] =   '<a:clrScheme name=\"Office\">';\n\to[o.length] =    '<a:dk1><a:sysClr val=\"windowText\" lastClr=\"000000\"/></a:dk1>';\n\to[o.length] =    '<a:lt1><a:sysClr val=\"window\" lastClr=\"FFFFFF\"/></a:lt1>';\n\to[o.length] =    '<a:dk2><a:srgbClr val=\"1F497D\"/></a:dk2>';\n\to[o.length] =    '<a:lt2><a:srgbClr val=\"EEECE1\"/></a:lt2>';\n\to[o.length] =    '<a:accent1><a:srgbClr val=\"4F81BD\"/></a:accent1>';\n\to[o.length] =    '<a:accent2><a:srgbClr val=\"C0504D\"/></a:accent2>';\n\to[o.length] =    '<a:accent3><a:srgbClr val=\"9BBB59\"/></a:accent3>';\n\to[o.length] =    '<a:accent4><a:srgbClr val=\"8064A2\"/></a:accent4>';\n\to[o.length] =    '<a:accent5><a:srgbClr val=\"4BACC6\"/></a:accent5>';\n\to[o.length] =    '<a:accent6><a:srgbClr val=\"F79646\"/></a:accent6>';\n\to[o.length] =    '<a:hlink><a:srgbClr val=\"0000FF\"/></a:hlink>';\n\to[o.length] =    '<a:folHlink><a:srgbClr val=\"800080\"/></a:folHlink>';\n\to[o.length] =   '</a:clrScheme>';\n\n\to[o.length] =   '<a:fontScheme name=\"Office\">';\n\to[o.length] =    '<a:majorFont>';\n\to[o.length] =     '<a:latin typeface=\"Cambria\"/>';\n\to[o.length] =     '<a:ea typeface=\"\"/>';\n\to[o.length] =     '<a:cs typeface=\"\"/>';\n\to[o.length] =     '<a:font script=\"Jpan\" typeface=\"ＭＳ Ｐゴシック\"/>';\n\to[o.length] =     '<a:font script=\"Hang\" typeface=\"맑은 고딕\"/>';\n\to[o.length] =     '<a:font script=\"Hans\" typeface=\"宋体\"/>';\n\to[o.length] =     '<a:font script=\"Hant\" typeface=\"新細明體\"/>';\n\to[o.length] =     '<a:font script=\"Arab\" typeface=\"Times New Roman\"/>';\n\to[o.length] =     '<a:font script=\"Hebr\" typeface=\"Times New Roman\"/>';\n\to[o.length] =     '<a:font script=\"Thai\" typeface=\"Tahoma\"/>';\n\to[o.length] =     '<a:font script=\"Ethi\" typeface=\"Nyala\"/>';\n\to[o.length] =     '<a:font script=\"Beng\" typeface=\"Vrinda\"/>';\n\to[o.length] =     '<a:font script=\"Gujr\" typeface=\"Shruti\"/>';\n\to[o.length] =     '<a:font script=\"Khmr\" typeface=\"MoolBoran\"/>';\n\to[o.length] =     '<a:font script=\"Knda\" typeface=\"Tunga\"/>';\n\to[o.length] =     '<a:font script=\"Guru\" typeface=\"Raavi\"/>';\n\to[o.length] =     '<a:font script=\"Cans\" typeface=\"Euphemia\"/>';\n\to[o.length] =     '<a:font script=\"Cher\" typeface=\"Plantagenet Cherokee\"/>';\n\to[o.length] =     '<a:font script=\"Yiii\" typeface=\"Microsoft Yi Baiti\"/>';\n\to[o.length] =     '<a:font script=\"Tibt\" typeface=\"Microsoft Himalaya\"/>';\n\to[o.length] =     '<a:font script=\"Thaa\" typeface=\"MV Boli\"/>';\n\to[o.length] =     '<a:font script=\"Deva\" typeface=\"Mangal\"/>';\n\to[o.length] =     '<a:font script=\"Telu\" typeface=\"Gautami\"/>';\n\to[o.length] =     '<a:font script=\"Taml\" typeface=\"Latha\"/>';\n\to[o.length] =     '<a:font script=\"Syrc\" typeface=\"Estrangelo Edessa\"/>';\n\to[o.length] =     '<a:font script=\"Orya\" typeface=\"Kalinga\"/>';\n\to[o.length] =     '<a:font script=\"Mlym\" typeface=\"Kartika\"/>';\n\to[o.length] =     '<a:font script=\"Laoo\" typeface=\"DokChampa\"/>';\n\to[o.length] =     '<a:font script=\"Sinh\" typeface=\"Iskoola Pota\"/>';\n\to[o.length] =     '<a:font script=\"Mong\" typeface=\"Mongolian Baiti\"/>';\n\to[o.length] =     '<a:font script=\"Viet\" typeface=\"Times New Roman\"/>';\n\to[o.length] =     '<a:font script=\"Uigh\" typeface=\"Microsoft Uighur\"/>';\n\to[o.length] =     '<a:font script=\"Geor\" typeface=\"Sylfaen\"/>';\n\to[o.length] =    '</a:majorFont>';\n\to[o.length] =    '<a:minorFont>';\n\to[o.length] =     '<a:latin typeface=\"Calibri\"/>';\n\to[o.length] =     '<a:ea typeface=\"\"/>';\n\to[o.length] =     '<a:cs typeface=\"\"/>';\n\to[o.length] =     '<a:font script=\"Jpan\" typeface=\"ＭＳ Ｐゴシック\"/>';\n\to[o.length] =     '<a:font script=\"Hang\" typeface=\"맑은 고딕\"/>';\n\to[o.length] =     '<a:font script=\"Hans\" typeface=\"宋体\"/>';\n\to[o.length] =     '<a:font script=\"Hant\" typeface=\"新細明體\"/>';\n\to[o.length] =     '<a:font script=\"Arab\" typeface=\"Arial\"/>';\n\to[o.length] =     '<a:font script=\"Hebr\" typeface=\"Arial\"/>';\n\to[o.length] =     '<a:font script=\"Thai\" typeface=\"Tahoma\"/>';\n\to[o.length] =     '<a:font script=\"Ethi\" typeface=\"Nyala\"/>';\n\to[o.length] =     '<a:font script=\"Beng\" typeface=\"Vrinda\"/>';\n\to[o.length] =     '<a:font script=\"Gujr\" typeface=\"Shruti\"/>';\n\to[o.length] =     '<a:font script=\"Khmr\" typeface=\"DaunPenh\"/>';\n\to[o.length] =     '<a:font script=\"Knda\" typeface=\"Tunga\"/>';\n\to[o.length] =     '<a:font script=\"Guru\" typeface=\"Raavi\"/>';\n\to[o.length] =     '<a:font script=\"Cans\" typeface=\"Euphemia\"/>';\n\to[o.length] =     '<a:font script=\"Cher\" typeface=\"Plantagenet Cherokee\"/>';\n\to[o.length] =     '<a:font script=\"Yiii\" typeface=\"Microsoft Yi Baiti\"/>';\n\to[o.length] =     '<a:font script=\"Tibt\" typeface=\"Microsoft Himalaya\"/>';\n\to[o.length] =     '<a:font script=\"Thaa\" typeface=\"MV Boli\"/>';\n\to[o.length] =     '<a:font script=\"Deva\" typeface=\"Mangal\"/>';\n\to[o.length] =     '<a:font script=\"Telu\" typeface=\"Gautami\"/>';\n\to[o.length] =     '<a:font script=\"Taml\" typeface=\"Latha\"/>';\n\to[o.length] =     '<a:font script=\"Syrc\" typeface=\"Estrangelo Edessa\"/>';\n\to[o.length] =     '<a:font script=\"Orya\" typeface=\"Kalinga\"/>';\n\to[o.length] =     '<a:font script=\"Mlym\" typeface=\"Kartika\"/>';\n\to[o.length] =     '<a:font script=\"Laoo\" typeface=\"DokChampa\"/>';\n\to[o.length] =     '<a:font script=\"Sinh\" typeface=\"Iskoola Pota\"/>';\n\to[o.length] =     '<a:font script=\"Mong\" typeface=\"Mongolian Baiti\"/>';\n\to[o.length] =     '<a:font script=\"Viet\" typeface=\"Arial\"/>';\n\to[o.length] =     '<a:font script=\"Uigh\" typeface=\"Microsoft Uighur\"/>';\n\to[o.length] =     '<a:font script=\"Geor\" typeface=\"Sylfaen\"/>';\n\to[o.length] =    '</a:minorFont>';\n\to[o.length] =   '</a:fontScheme>';\n\n\to[o.length] =   '<a:fmtScheme name=\"Office\">';\n\to[o.length] =    '<a:fillStyleLst>';\n\to[o.length] =     '<a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill>';\n\to[o.length] =     '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] =      '<a:gsLst>';\n\to[o.length] =       '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"50000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs>';\n\to[o.length] =       '<a:gs pos=\"35000\"><a:schemeClr val=\"phClr\"><a:tint val=\"37000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs>';\n\to[o.length] =       '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:tint val=\"15000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] =      '</a:gsLst>';\n\to[o.length] =      '<a:lin ang=\"16200000\" scaled=\"1\"/>';\n\to[o.length] =     '</a:gradFill>';\n\to[o.length] =     '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] =      '<a:gsLst>';\n\to[o.length] =       '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"100000\"/><a:shade val=\"100000\"/><a:satMod val=\"130000\"/></a:schemeClr></a:gs>';\n\to[o.length] =       '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:tint val=\"50000\"/><a:shade val=\"100000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] =      '</a:gsLst>';\n\to[o.length] =      '<a:lin ang=\"16200000\" scaled=\"0\"/>';\n\to[o.length] =     '</a:gradFill>';\n\to[o.length] =    '</a:fillStyleLst>';\n\to[o.length] =    '<a:lnStyleLst>';\n\to[o.length] =     '<a:ln w=\"9525\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"><a:shade val=\"95000\"/><a:satMod val=\"105000\"/></a:schemeClr></a:solidFill><a:prstDash val=\"solid\"/></a:ln>';\n\to[o.length] =     '<a:ln w=\"25400\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:prstDash val=\"solid\"/></a:ln>';\n\to[o.length] =     '<a:ln w=\"38100\" cap=\"flat\" cmpd=\"sng\" algn=\"ctr\"><a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill><a:prstDash val=\"solid\"/></a:ln>';\n\to[o.length] =    '</a:lnStyleLst>';\n\to[o.length] =    '<a:effectStyleLst>';\n\to[o.length] =     '<a:effectStyle>';\n\to[o.length] =      '<a:effectLst>';\n\to[o.length] =       '<a:outerShdw blurRad=\"40000\" dist=\"20000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"38000\"/></a:srgbClr></a:outerShdw>';\n\to[o.length] =      '</a:effectLst>';\n\to[o.length] =     '</a:effectStyle>';\n\to[o.length] =     '<a:effectStyle>';\n\to[o.length] =      '<a:effectLst>';\n\to[o.length] =       '<a:outerShdw blurRad=\"40000\" dist=\"23000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"35000\"/></a:srgbClr></a:outerShdw>';\n\to[o.length] =      '</a:effectLst>';\n\to[o.length] =     '</a:effectStyle>';\n\to[o.length] =     '<a:effectStyle>';\n\to[o.length] =      '<a:effectLst>';\n\to[o.length] =       '<a:outerShdw blurRad=\"40000\" dist=\"23000\" dir=\"5400000\" rotWithShape=\"0\"><a:srgbClr val=\"000000\"><a:alpha val=\"35000\"/></a:srgbClr></a:outerShdw>';\n\to[o.length] =      '</a:effectLst>';\n\to[o.length] =      '<a:scene3d><a:camera prst=\"orthographicFront\"><a:rot lat=\"0\" lon=\"0\" rev=\"0\"/></a:camera><a:lightRig rig=\"threePt\" dir=\"t\"><a:rot lat=\"0\" lon=\"0\" rev=\"1200000\"/></a:lightRig></a:scene3d>';\n\to[o.length] =      '<a:sp3d><a:bevelT w=\"63500\" h=\"25400\"/></a:sp3d>';\n\to[o.length] =     '</a:effectStyle>';\n\to[o.length] =    '</a:effectStyleLst>';\n\to[o.length] =    '<a:bgFillStyleLst>';\n\to[o.length] =     '<a:solidFill><a:schemeClr val=\"phClr\"/></a:solidFill>';\n\to[o.length] =     '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] =      '<a:gsLst>';\n\to[o.length] =       '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"40000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] =       '<a:gs pos=\"40000\"><a:schemeClr val=\"phClr\"><a:tint val=\"45000\"/><a:shade val=\"99000\"/><a:satMod val=\"350000\"/></a:schemeClr></a:gs>';\n\to[o.length] =       '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:shade val=\"20000\"/><a:satMod val=\"255000\"/></a:schemeClr></a:gs>';\n\to[o.length] =      '</a:gsLst>';\n\to[o.length] =      '<a:path path=\"circle\"><a:fillToRect l=\"50000\" t=\"-80000\" r=\"50000\" b=\"180000\"/></a:path>';\n\to[o.length] =     '</a:gradFill>';\n\to[o.length] =     '<a:gradFill rotWithShape=\"1\">';\n\to[o.length] =      '<a:gsLst>';\n\to[o.length] =       '<a:gs pos=\"0\"><a:schemeClr val=\"phClr\"><a:tint val=\"80000\"/><a:satMod val=\"300000\"/></a:schemeClr></a:gs>';\n\to[o.length] =       '<a:gs pos=\"100000\"><a:schemeClr val=\"phClr\"><a:shade val=\"30000\"/><a:satMod val=\"200000\"/></a:schemeClr></a:gs>';\n\to[o.length] =      '</a:gsLst>';\n\to[o.length] =      '<a:path path=\"circle\"><a:fillToRect l=\"50000\" t=\"50000\" r=\"50000\" b=\"50000\"/></a:path>';\n\to[o.length] =     '</a:gradFill>';\n\to[o.length] =    '</a:bgFillStyleLst>';\n\to[o.length] =   '</a:fmtScheme>';\n\to[o.length] =  '</a:themeElements>';\n\n\to[o.length] =  '<a:objectDefaults>';\n\to[o.length] =   '<a:spDef>';\n\to[o.length] =    '<a:spPr/><a:bodyPr/><a:lstStyle/><a:style><a:lnRef idx=\"1\"><a:schemeClr val=\"accent1\"/></a:lnRef><a:fillRef idx=\"3\"><a:schemeClr val=\"accent1\"/></a:fillRef><a:effectRef idx=\"2\"><a:schemeClr val=\"accent1\"/></a:effectRef><a:fontRef idx=\"minor\"><a:schemeClr val=\"lt1\"/></a:fontRef></a:style>';\n\to[o.length] =   '</a:spDef>';\n\to[o.length] =   '<a:lnDef>';\n\to[o.length] =    '<a:spPr/><a:bodyPr/><a:lstStyle/><a:style><a:lnRef idx=\"2\"><a:schemeClr val=\"accent1\"/></a:lnRef><a:fillRef idx=\"0\"><a:schemeClr val=\"accent1\"/></a:fillRef><a:effectRef idx=\"1\"><a:schemeClr val=\"accent1\"/></a:effectRef><a:fontRef idx=\"minor\"><a:schemeClr val=\"tx1\"/></a:fontRef></a:style>';\n\to[o.length] =   '</a:lnDef>';\n\to[o.length] =  '</a:objectDefaults>';\n\to[o.length] =  '<a:extraClrSchemeLst/>';\n\to[o.length] = '</a:theme>';\n\treturn o.join(\"\");\n}\n/* [MS-XLS] 2.4.326 TODO: payload is a zip file */\nfunction parse_Theme(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar dwThemeVersion = blob.read_shift(4);\n\tif(dwThemeVersion === 124226) return;\n\tif(!opts.cellStyles) { blob.l = end; return; }\n\tvar data = blob.slice(blob.l);\n\tblob.l = end;\n\tvar zip; try { zip = zip_read(data, {type: \"array\"}); } catch(e) { return; }\n\tvar themeXML = getzipstr(zip, \"theme/theme/theme1.xml\", true);\n\tif(!themeXML) return;\n\treturn parse_theme_xml(themeXML, opts);\n}\n\n/* 2.5.49 */\nfunction parse_ColorTheme(blob/*::, length*/) { return blob.read_shift(4); }\n\n/* 2.5.155 */\nfunction parse_FullColorExt(blob/*::, length*/) {\n\tvar o = {};\n\to.xclrType = blob.read_shift(2);\n\to.nTintShade = blob.read_shift(2);\n\tswitch(o.xclrType) {\n\t\tcase 0: blob.l += 4; break;\n\t\tcase 1: o.xclrValue = parse_IcvXF(blob, 4); break;\n\t\tcase 2: o.xclrValue = parse_LongRGBA(blob, 4); break;\n\t\tcase 3: o.xclrValue = parse_ColorTheme(blob, 4); break;\n\t\tcase 4: blob.l += 4; break;\n\t}\n\tblob.l += 8;\n\treturn o;\n}\n\n/* 2.5.164 TODO: read 7 bits*/\nfunction parse_IcvXF(blob, length) {\n\treturn parsenoop(blob, length);\n}\n\n/* 2.5.280 */\nfunction parse_XFExtGradient(blob, length) {\n\treturn parsenoop(blob, length);\n}\n\n/* [MS-XLS] 2.5.108 */\nfunction parse_ExtProp(blob/*::, length*/)/*:Array<any>*/ {\n\tvar extType = blob.read_shift(2);\n\tvar cb = blob.read_shift(2) - 4;\n\tvar o = [extType];\n\tswitch(extType) {\n\t\tcase 0x04: case 0x05: case 0x07: case 0x08:\n\t\tcase 0x09: case 0x0A: case 0x0B: case 0x0D:\n\t\t\to[1] = parse_FullColorExt(blob, cb); break;\n\t\tcase 0x06: o[1] = parse_XFExtGradient(blob, cb); break;\n\t\tcase 0x0E: case 0x0F: o[1] = blob.read_shift(cb === 1 ? 1 : 2); break;\n\t\tdefault: throw new Error(\"Unrecognized ExtProp type: \" + extType + \" \" + cb);\n\t}\n\treturn o;\n}\n\n/* 2.4.355 */\nfunction parse_XFExt(blob, length) {\n\tvar end = blob.l + length;\n\tblob.l += 2;\n\tvar ixfe = blob.read_shift(2);\n\tblob.l += 2;\n\tvar cexts = blob.read_shift(2);\n\tvar ext/*:AOA*/ = [];\n\twhile(cexts-- > 0) ext.push(parse_ExtProp(blob, end-blob.l));\n\treturn {ixfe:ixfe, ext:ext};\n}\n\n/* xf is an XF, see parse_XFExt for xfext */\nfunction update_xfext(xf, xfext) {\n\txfext.forEach(function(xfe) {\n\t\tswitch(xfe[0]) { /* 2.5.108 extPropData */\n\t\t\tcase 0x04: break; /* foreground color */\n\t\t\tcase 0x05: break; /* background color */\n\t\t\tcase 0x06: break; /* gradient fill */\n\t\t\tcase 0x07: break; /* top cell border color */\n\t\t\tcase 0x08: break; /* bottom cell border color */\n\t\t\tcase 0x09: break; /* left cell border color */\n\t\t\tcase 0x0a: break; /* right cell border color */\n\t\t\tcase 0x0b: break; /* diagonal cell border color */\n\t\t\tcase 0x0d: /* text color */\n\t\t\t\tbreak;\n\t\t\tcase 0x0e: break; /* font scheme */\n\t\t\tcase 0x0f: break; /* indentation level */\n\t\t}\n\t});\n}\n\nfunction parse_BrtMdtinfo(data, length) {\n  return {\n    flags: data.read_shift(4),\n    version: data.read_shift(4),\n    name: parse_XLWideString(data, length - 8)\n  };\n}\nfunction write_BrtMdtinfo(data) {\n  var o = new_buf(12 + 2 * data.name.length);\n  o.write_shift(4, data.flags);\n  o.write_shift(4, data.version);\n  write_XLWideString(data.name, o);\n  return o.slice(0, o.l);\n}\nfunction parse_BrtMdb(data) {\n  var out = [];\n  var cnt = data.read_shift(4);\n  while (cnt-- > 0)\n    out.push([data.read_shift(4), data.read_shift(4)]);\n  return out;\n}\nfunction write_BrtMdb(mdb) {\n  var o = new_buf(4 + 8 * mdb.length);\n  o.write_shift(4, mdb.length);\n  for (var i = 0; i < mdb.length; ++i) {\n    o.write_shift(4, mdb[i][0]);\n    o.write_shift(4, mdb[i][1]);\n  }\n  return o;\n}\nfunction write_BrtBeginEsfmd(cnt, name) {\n  var o = new_buf(8 + 2 * name.length);\n  o.write_shift(4, cnt);\n  write_XLWideString(name, o);\n  return o.slice(0, o.l);\n}\nfunction parse_BrtBeginEsmdb(data) {\n  data.l += 4;\n  return data.read_shift(4) != 0;\n}\nfunction write_BrtBeginEsmdb(cnt, cm) {\n  var o = new_buf(8);\n  o.write_shift(4, cnt);\n  o.write_shift(4, cm ? 1 : 0);\n  return o;\n}\nfunction parse_xlmeta_bin(data, name, _opts) {\n  var out = { Types: [], Cell: [], Value: [] };\n  var opts = _opts || {};\n  var state = [];\n  var pass = false;\n  var metatype = 2;\n  recordhopper(data, function(val, R, RT) {\n    switch (RT) {\n      case 335:\n        out.Types.push({ name: val.name });\n        break;\n      case 51:\n        val.forEach(function(r) {\n          if (metatype == 1)\n            out.Cell.push({ type: out.Types[r[0] - 1].name, index: r[1] });\n          else if (metatype == 0)\n            out.Value.push({ type: out.Types[r[0] - 1].name, index: r[1] });\n        });\n        break;\n      case 337:\n        metatype = val ? 1 : 0;\n        break;\n      case 338:\n        metatype = 2;\n        break;\n      case 35:\n        state.push(RT);\n        pass = true;\n        break;\n      case 36:\n        state.pop();\n        pass = false;\n        break;\n      default:\n        if (R.T) {\n        } else if (!pass || opts.WTF && state[state.length - 1] != 35)\n          throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n    }\n  });\n  return out;\n}\nfunction write_xlmeta_bin() {\n  var ba = buf_array();\n  write_record(ba, 332);\n  write_record(ba, 334, write_UInt32LE(1));\n  write_record(ba, 335, write_BrtMdtinfo({\n    name: \"XLDAPR\",\n    version: 12e4,\n    flags: 3496657072\n  }));\n  write_record(ba, 336);\n  write_record(ba, 339, write_BrtBeginEsfmd(1, \"XLDAPR\"));\n  write_record(ba, 52);\n  write_record(ba, 35, write_UInt32LE(514));\n  write_record(ba, 4096, write_UInt32LE(0));\n  write_record(ba, 4097, writeuint16(1));\n  write_record(ba, 36);\n  write_record(ba, 53);\n  write_record(ba, 340);\n  write_record(ba, 337, write_BrtBeginEsmdb(1, true));\n  write_record(ba, 51, write_BrtMdb([[1, 0]]));\n  write_record(ba, 338);\n  write_record(ba, 333);\n  return ba.end();\n}\nfunction parse_xlmeta_xml(data, name, opts) {\n  var out = { Types: [], Cell: [], Value: [] };\n  if (!data)\n    return out;\n  var pass = false;\n  var metatype = 2;\n  var lastmeta;\n  data.replace(tagregex, function(x) {\n    var y = parsexmltag(x);\n    switch (strip_ns(y[0])) {\n      case \"<?xml\":\n        break;\n      case \"<metadata\":\n      case \"</metadata>\":\n        break;\n      case \"<metadataTypes\":\n      case \"</metadataTypes>\":\n        break;\n      case \"<metadataType\":\n        out.Types.push({ name: y.name });\n        break;\n      case \"</metadataType>\":\n        break;\n      case \"<futureMetadata\":\n        for (var j = 0; j < out.Types.length; ++j)\n          if (out.Types[j].name == y.name)\n            lastmeta = out.Types[j];\n        break;\n      case \"</futureMetadata>\":\n        break;\n      case \"<bk>\":\n        break;\n      case \"</bk>\":\n        break;\n      case \"<rc\":\n        if (metatype == 1)\n          out.Cell.push({ type: out.Types[y.t - 1].name, index: +y.v });\n        else if (metatype == 0)\n          out.Value.push({ type: out.Types[y.t - 1].name, index: +y.v });\n        break;\n      case \"</rc>\":\n        break;\n      case \"<cellMetadata\":\n        metatype = 1;\n        break;\n      case \"</cellMetadata>\":\n        metatype = 2;\n        break;\n      case \"<valueMetadata\":\n        metatype = 0;\n        break;\n      case \"</valueMetadata>\":\n        metatype = 2;\n        break;\n      case \"<extLst\":\n      case \"<extLst>\":\n      case \"</extLst>\":\n      case \"<extLst/>\":\n        break;\n      case \"<ext\":\n        pass = true;\n        break;\n      case \"</ext>\":\n        pass = false;\n        break;\n      case \"<rvb\":\n        if (!lastmeta)\n          break;\n        if (!lastmeta.offsets)\n          lastmeta.offsets = [];\n        lastmeta.offsets.push(+y.i);\n        break;\n      default:\n        if (!pass && opts.WTF)\n          throw new Error(\"unrecognized \" + y[0] + \" in metadata\");\n    }\n    return x;\n  });\n  return out;\n}\nfunction write_xlmeta_xml() {\n  var o = [XML_HEADER];\n  o.push('<metadata xmlns=\"http://schemas.openxmlformats.org/spreadsheetml/2006/main\" xmlns:xlrd=\"http://schemas.microsoft.com/office/spreadsheetml/2017/richdata\" xmlns:xda=\"http://schemas.microsoft.com/office/spreadsheetml/2017/dynamicarray\">\\n  <metadataTypes count=\"1\">\\n    <metadataType name=\"XLDAPR\" minSupportedVersion=\"120000\" copy=\"1\" pasteAll=\"1\" pasteValues=\"1\" merge=\"1\" splitFirst=\"1\" rowColShift=\"1\" clearFormats=\"1\" clearComments=\"1\" assign=\"1\" coerce=\"1\" cellMeta=\"1\"/>\\n  </metadataTypes>\\n  <futureMetadata name=\"XLDAPR\" count=\"1\">\\n    <bk>\\n      <extLst>\\n        <ext uri=\"{bdbb8cdc-fa1e-496e-a857-3c3f30c029c3}\">\\n          <xda:dynamicArrayProperties fDynamic=\"1\" fCollapsed=\"0\"/>\\n        </ext>\\n      </extLst>\\n    </bk>\\n  </futureMetadata>\\n  <cellMetadata count=\"1\">\\n    <bk>\\n      <rc t=\"1\" v=\"0\"/>\\n    </bk>\\n  </cellMetadata>\\n</metadata>');\n  return o.join(\"\");\n}\n/* 18.6 Calculation Chain */\nfunction parse_cc_xml(data/*::, name, opts*/)/*:Array<any>*/ {\n\tvar d = [];\n\tif(!data) return d;\n\tvar i = 1;\n\t(data.match(tagregex)||[]).forEach(function(x) {\n\t\tvar y = parsexmltag(x);\n\t\tswitch(y[0]) {\n\t\t\tcase '<?xml': break;\n\t\t\t/* 18.6.2  calcChain CT_CalcChain 1 */\n\t\t\tcase '<calcChain': case '<calcChain>': case '</calcChain>': break;\n\t\t\t/* 18.6.1  c CT_CalcCell 1 */\n\t\t\tcase '<c': delete y[0]; if(y.i) i = y.i; else y.i = i; d.push(y); break;\n\t\t}\n\t});\n\treturn d;\n}\n\n//function write_cc_xml(data, opts) { }\n\n/* [MS-XLSB] 2.6.4.1 */\nfunction parse_BrtCalcChainItem$(data) {\n\tvar out = {};\n\tout.i = data.read_shift(4);\n\tvar cell = {};\n\tcell.r = data.read_shift(4);\n\tcell.c = data.read_shift(4);\n\tout.r = encode_cell(cell);\n\tvar flags = data.read_shift(1);\n\tif(flags & 0x2) out.l = '1';\n\tif(flags & 0x8) out.a = '1';\n\treturn out;\n}\n\n/* 18.6 Calculation Chain */\nfunction parse_cc_bin(data, name, opts) {\n\tvar out = [];\n\tvar pass = false;\n\trecordhopper(data, function hopper_cc(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x003F: /* 'BrtCalcChainItem$' */\n\t\t\t\tout.push(val); break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn out;\n}\n\n//function write_cc_bin(data, opts) { }\n/* 18.14 Supplementary Workbook Data */\nfunction parse_xlink_xml(/*::data, rel, name:string, _opts*/) {\n\t//var opts = _opts || {};\n\t//if(opts.WTF) throw \"XLSX External Link\";\n}\n\n/* [MS-XLSB] 2.1.7.25 External Link */\nfunction parse_xlink_bin(data, rel, name/*:string*/, _opts) {\n\tif(!data) return data;\n\tvar opts = _opts || {};\n\n\tvar pass = false, end = false;\n\n\trecordhopper(data, function xlink_parse(val, R, RT) {\n\t\tif(end) return;\n\t\tswitch(RT) {\n\t\t\tcase 0x0167: /* 'BrtSupTabs' */\n\t\t\tcase 0x016B: /* 'BrtExternTableStart' */\n\t\t\tcase 0x016C: /* 'BrtExternTableEnd' */\n\t\t\tcase 0x016E: /* 'BrtExternRowHdr' */\n\t\t\tcase 0x016F: /* 'BrtExternCellBlank' */\n\t\t\tcase 0x0170: /* 'BrtExternCellReal' */\n\t\t\tcase 0x0171: /* 'BrtExternCellBool' */\n\t\t\tcase 0x0172: /* 'BrtExternCellError' */\n\t\t\tcase 0x0173: /* 'BrtExternCellString' */\n\t\t\tcase 0x01D8: /* 'BrtExternValueMeta' */\n\t\t\tcase 0x0241: /* 'BrtSupNameStart' */\n\t\t\tcase 0x0242: /* 'BrtSupNameValueStart' */\n\t\t\tcase 0x0243: /* 'BrtSupNameValueEnd' */\n\t\t\tcase 0x0244: /* 'BrtSupNameNum' */\n\t\t\tcase 0x0245: /* 'BrtSupNameErr' */\n\t\t\tcase 0x0246: /* 'BrtSupNameSt' */\n\t\t\tcase 0x0247: /* 'BrtSupNameNil' */\n\t\t\tcase 0x0248: /* 'BrtSupNameBool' */\n\t\t\tcase 0x0249: /* 'BrtSupNameFmla' */\n\t\t\tcase 0x024A: /* 'BrtSupNameBits' */\n\t\t\tcase 0x024B: /* 'BrtSupNameEnd' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n}\n/* 20.5 DrawingML - SpreadsheetML Drawing */\n/* 20.5.2.35 wsDr CT_Drawing */\nfunction parse_drawing(data, rels/*:any*/) {\n\tif(!data) return \"??\";\n\t/*\n\t  Chartsheet Drawing:\n\t   - 20.5.2.35 wsDr CT_Drawing\n\t    - 20.5.2.1  absoluteAnchor CT_AbsoluteAnchor\n\t     - 20.5.2.16 graphicFrame CT_GraphicalObjectFrame\n\t      - 20.1.2.2.16 graphic CT_GraphicalObject\n\t       - 20.1.2.2.17 graphicData CT_GraphicalObjectData\n          - chart reference\n\t   the actual type is based on the URI of the graphicData\n\t\tTODO: handle embedded charts and other types of graphics\n\t*/\n\tvar id = (data.match(/<c:chart [^>]*r:id=\"([^\"]*)\"/)||[\"\",\"\"])[1];\n\n\treturn rels['!id'][id].Target;\n}\n\n/* L.5.5.2 SpreadsheetML Comments + VML Schema */\nvar _shapeid = 1024;\nfunction write_comments_vml(rId/*:number*/, comments) {\n\tvar csize = [21600, 21600];\n\t/* L.5.2.1.2 Path Attribute */\n\tvar bbox = [\"m0,0l0\",csize[1],csize[0],csize[1],csize[0],\"0xe\"].join(\",\");\n\tvar o = [\n\t\twritextag(\"xml\", null, { 'xmlns:v': XLMLNS.v, 'xmlns:o': XLMLNS.o, 'xmlns:x': XLMLNS.x, 'xmlns:mv': XLMLNS.mv }).replace(/\\/>/,\">\"),\n\t\twritextag(\"o:shapelayout\", writextag(\"o:idmap\", null, {'v:ext':\"edit\", 'data':rId}), {'v:ext':\"edit\"}),\n\t\twritextag(\"v:shapetype\", [\n\t\t\twritextag(\"v:stroke\", null, {joinstyle:\"miter\"}),\n\t\t\twritextag(\"v:path\", null, {gradientshapeok:\"t\", 'o:connecttype':\"rect\"})\n\t\t].join(\"\"), {id:\"_x0000_t202\", 'o:spt':202, coordsize:csize.join(\",\"),path:bbox})\n\t];\n\twhile(_shapeid < rId * 1000) _shapeid += 1000;\n\n\tcomments.forEach(function(x) {\n\tvar c = decode_cell(x[0]);\n\tvar fillopts = /*::(*/{'color2':\"#BEFF82\", 'type':\"gradient\"}/*:: :any)*/;\n\tif(fillopts.type == \"gradient\") fillopts.angle = \"-180\";\n\tvar fillparm = fillopts.type == \"gradient\" ? writextag(\"o:fill\", null, {type:\"gradientUnscaled\", 'v:ext':\"view\"}) : null;\n\tvar fillxml = writextag('v:fill', fillparm, fillopts);\n\n\tvar shadata = ({on:\"t\", 'obscured':\"t\"}/*:any*/);\n\t++_shapeid;\n\n\to = o.concat([\n\t'<v:shape' + wxt_helper({\n\t\tid:'_x0000_s' + _shapeid,\n\t\ttype:\"#_x0000_t202\",\n\t\tstyle:\"position:absolute; margin-left:80pt;margin-top:5pt;width:104pt;height:64pt;z-index:10\" + (x[1].hidden ? \";visibility:hidden\" : \"\") ,\n\t\tfillcolor:\"#ECFAD4\",\n\t\tstrokecolor:\"#edeaa1\"\n\t}) + '>',\n\t\tfillxml,\n\t\twritextag(\"v:shadow\", null, shadata),\n\t\twritextag(\"v:path\", null, {'o:connecttype':\"none\"}),\n\t\t'<v:textbox><div style=\"text-align:left\"></div></v:textbox>',\n\t\t'<x:ClientData ObjectType=\"Note\">',\n\t\t\t'<x:MoveWithCells/>',\n\t\t\t'<x:SizeWithCells/>',\n\t\t\t/* Part 4 19.4.2.3 Anchor (Anchor) */\n\t\t\twritetag('x:Anchor', [c.c+1, 0, c.r+1, 0, c.c+3, 20, c.r+5, 20].join(\",\")),\n\t\t\twritetag('x:AutoFill', \"False\"),\n\t\t\twritetag('x:Row', String(c.r)),\n\t\t\twritetag('x:Column', String(c.c)),\n\t\t\tx[1].hidden ? '' : '<x:Visible/>',\n\t\t'</x:ClientData>',\n\t'</v:shape>'\n\t]); });\n\to.push('</xml>');\n\treturn o.join(\"\");\n}\nfunction sheet_insert_comments(sheet, comments/*:Array<RawComment>*/, threaded/*:boolean*/, people/*:?Array<any>*/) {\n\tvar dense = Array.isArray(sheet);\n\tvar cell/*:Cell*/;\n\tcomments.forEach(function(comment) {\n\t\tvar r = decode_cell(comment.ref);\n\t\tif(dense) {\n\t\t\tif(!sheet[r.r]) sheet[r.r] = [];\n\t\t\tcell = sheet[r.r][r.c];\n\t\t} else cell = sheet[comment.ref];\n\t\tif (!cell) {\n\t\t\tcell = ({t:\"z\"}/*:any*/);\n\t\t\tif(dense) sheet[r.r][r.c] = cell;\n\t\t\telse sheet[comment.ref] = cell;\n\t\t\tvar range = safe_decode_range(sheet[\"!ref\"]||\"BDWGO1000001:A1\");\n\t\t\tif(range.s.r > r.r) range.s.r = r.r;\n\t\t\tif(range.e.r < r.r) range.e.r = r.r;\n\t\t\tif(range.s.c > r.c) range.s.c = r.c;\n\t\t\tif(range.e.c < r.c) range.e.c = r.c;\n\t\t\tvar encoded = encode_range(range);\n\t\t\tif (encoded !== sheet[\"!ref\"]) sheet[\"!ref\"] = encoded;\n\t\t}\n\n\t\tif (!cell.c) cell.c = [];\n\t\tvar o/*:Comment*/ = ({a: comment.author, t: comment.t, r: comment.r, T: threaded});\n\t\tif(comment.h) o.h = comment.h;\n\n\t\t/* threaded comments always override */\n\t\tfor(var i = cell.c.length - 1; i >= 0; --i) {\n\t\t\tif(!threaded && cell.c[i].T) return;\n\t\t\tif(threaded && !cell.c[i].T) cell.c.splice(i, 1);\n\t\t}\n\t\tif(threaded && people) for(i = 0; i < people.length; ++i) {\n\t\t\tif(o.a == people[i].id) { o.a = people[i].name || o.a; break; }\n\t\t}\n\t\tcell.c.push(o);\n\t});\n}\n\n/* 18.7 Comments */\nfunction parse_comments_xml(data/*:string*/, opts)/*:Array<RawComment>*/ {\n\t/* 18.7.6 CT_Comments */\n\tif(data.match(/<(?:\\w+:)?comments *\\/>/)) return [];\n\tvar authors/*:Array<string>*/ = [];\n\tvar commentList/*:Array<RawComment>*/ = [];\n\tvar authtag = data.match(/<(?:\\w+:)?authors>([\\s\\S]*)<\\/(?:\\w+:)?authors>/);\n\tif(authtag && authtag[1]) authtag[1].split(/<\\/\\w*:?author>/).forEach(function(x) {\n\t\tif(x === \"\" || x.trim() === \"\") return;\n\t\tvar a = x.match(/<(?:\\w+:)?author[^>]*>(.*)/);\n\t\tif(a) authors.push(a[1]);\n\t});\n\tvar cmnttag = data.match(/<(?:\\w+:)?commentList>([\\s\\S]*)<\\/(?:\\w+:)?commentList>/);\n\tif(cmnttag && cmnttag[1]) cmnttag[1].split(/<\\/\\w*:?comment>/).forEach(function(x) {\n\t\tif(x === \"\" || x.trim() === \"\") return;\n\t\tvar cm = x.match(/<(?:\\w+:)?comment[^>]*>/);\n\t\tif(!cm) return;\n\t\tvar y = parsexmltag(cm[0]);\n\t\tvar comment/*:RawComment*/ = ({ author: y.authorId && authors[y.authorId] || \"sheetjsghost\", ref: y.ref, guid: y.guid }/*:any*/);\n\t\tvar cell = decode_cell(y.ref);\n\t\tif(opts.sheetRows && opts.sheetRows <= cell.r) return;\n\t\tvar textMatch = x.match(/<(?:\\w+:)?text>([\\s\\S]*)<\\/(?:\\w+:)?text>/);\n\t\tvar rt = !!textMatch && !!textMatch[1] && parse_si(textMatch[1]) || {r:\"\",t:\"\",h:\"\"};\n\t\tcomment.r = rt.r;\n\t\tif(rt.r == \"<t></t>\") rt.t = rt.h = \"\";\n\t\tcomment.t = (rt.t||\"\").replace(/\\r\\n/g,\"\\n\").replace(/\\r/g,\"\\n\");\n\t\tif(opts.cellHTML) comment.h = rt.h;\n\t\tcommentList.push(comment);\n\t});\n\treturn commentList;\n}\n\nfunction write_comments_xml(data/*::, opts*/) {\n\tvar o = [XML_HEADER, writextag('comments', null, { 'xmlns': XMLNS_main[0] })];\n\n\tvar iauthor/*:Array<string>*/ = [];\n\to.push(\"<authors>\");\n\tdata.forEach(function(x) { x[1].forEach(function(w) { var a = escapexml(w.a);\n\t\tif(iauthor.indexOf(a) == -1) {\n\t\t\tiauthor.push(a);\n\t\t\to.push(\"<author>\" + a + \"</author>\");\n\t\t}\n\t\tif(w.T && w.ID && iauthor.indexOf(\"tc=\" + w.ID) == -1) {\n\t\t\tiauthor.push(\"tc=\" + w.ID);\n\t\t\to.push(\"<author>\" + \"tc=\" + w.ID + \"</author>\");\n\t\t}\n\t}); });\n\tif(iauthor.length == 0) { iauthor.push(\"SheetJ5\"); o.push(\"<author>SheetJ5</author>\"); }\n\to.push(\"</authors>\");\n\to.push(\"<commentList>\");\n\tdata.forEach(function(d) {\n\t\t/* 18.7.3 CT_Comment */\n\t\tvar lastauthor = 0, ts = [];\n\t\tif(d[1][0] && d[1][0].T && d[1][0].ID) lastauthor = iauthor.indexOf(\"tc=\" + d[1][0].ID);\n\t\telse d[1].forEach(function(c) {\n\t\t\tif(c.a) lastauthor = iauthor.indexOf(escapexml(c.a));\n\t\t\tts.push(c.t||\"\");\n\t\t});\n\t\to.push('<comment ref=\"' + d[0] + '\" authorId=\"' + lastauthor + '\"><text>');\n\t\tif(ts.length <= 1) o.push(writetag(\"t\", escapexml(ts[0]||\"\")));\n\t\telse {\n\t\t\t/* based on Threaded Comments -> Comments projection */\n\t\t\tvar t = \"Comment:\\n    \" + (ts[0]) + \"\\n\";\n\t\t\tfor(var i = 1; i < ts.length; ++i) t += \"Reply:\\n    \" + ts[i] + \"\\n\";\n\t\t\to.push(writetag(\"t\", escapexml(t)));\n\t\t}\n\t\to.push('</text></comment>');\n\t});\n\to.push(\"</commentList>\");\n\tif(o.length>2) { o[o.length] = ('</comments>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSX] 2.1.17 */\nfunction parse_tcmnt_xml(data/*:string*/, opts)/*:Array<RawComment>*/ {\n\tvar out = [];\n\tvar pass = false, comment = {}, tidx = 0;\n\tdata.replace(tagregex, function xml_tcmnt(x, idx) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\n\t\t\t/* 2.6.207 ThreadedComments CT_ThreadedComments */\n\t\t\tcase '<ThreadedComments': break;\n\t\t\tcase '</ThreadedComments>': break;\n\n\t\t\t/* 2.6.205 threadedComment CT_ThreadedComment */\n\t\t\tcase '<threadedComment': comment = {author: y.personId, guid: y.id, ref: y.ref, T: 1}; break;\n\t\t\tcase '</threadedComment>': if(comment.t != null) out.push(comment); break;\n\n\t\t\tcase '<text>': case '<text': tidx = idx + x.length; break;\n\t\t\tcase '</text>': comment.t = data.slice(tidx, idx).replace(/\\r\\n/g, \"\\n\").replace(/\\r/g, \"\\n\"); break;\n\n\t\t\t/* 2.6.206 mentions CT_ThreadedCommentMentions TODO */\n\t\t\tcase '<mentions': case '<mentions>': pass = true; break;\n\t\t\tcase '</mentions>': pass = false; break;\n\n\t\t\t/* 2.6.202 mention CT_Mention TODO */\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': case '<extLst/>': break;\n\t\t\t/* 18.2.7  ext CT_Extension + */\n\t\t\tcase '<ext': pass=true; break;\n\t\t\tcase '</ext>': pass=false; break;\n\n\t\t\tdefault: if(!pass && opts.WTF) throw new Error('unrecognized ' + y[0] + ' in threaded comments');\n\t\t}\n\t\treturn x;\n\t});\n\treturn out;\n}\n\nfunction write_tcmnt_xml(comments, people, opts) {\n\tvar o = [XML_HEADER, writextag('ThreadedComments', null, { 'xmlns': XMLNS.TCMNT }).replace(/[\\/]>/, \">\")];\n\tcomments.forEach(function(carr) {\n\t\tvar rootid = \"\";\n\t\t(carr[1] || []).forEach(function(c, idx) {\n\t\t\tif(!c.T) { delete c.ID; return; }\n\t\t\tif(c.a && people.indexOf(c.a) == -1) people.push(c.a);\n\t\t\tvar tcopts = {\n\t\t\t\tref: carr[0],\n\t\t\t\tid: \"{54EE7951-7262-4200-6969-\" + (\"000000000000\" + opts.tcid++).slice(-12) + \"}\"\n\t\t\t};\n\t\t\tif(idx == 0) rootid = tcopts.id;\n\t\t\telse tcopts.parentId = rootid;\n\t\t\tc.ID = tcopts.id;\n\t\t\tif(c.a) tcopts.personId = \"{54EE7950-7262-4200-6969-\" + (\"000000000000\" + people.indexOf(c.a)).slice(-12) + \"}\";\n\t\t\to.push(writextag('threadedComment', writetag('text', c.t||\"\"), tcopts));\n\t\t});\n\t});\n\to.push('</ThreadedComments>');\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSX] 2.1.18 */\nfunction parse_people_xml(data/*:string*/, opts) {\n\tvar out = [];\n\tvar pass = false;\n\tdata.replace(tagregex, function xml_tcmnt(x) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\n\t\t\t/* 2.4.85 personList CT_PersonList */\n\t\t\tcase '<personList': break;\n\t\t\tcase '</personList>': break;\n\n\t\t\t/* 2.6.203 person CT_Person TODO: providers */\n\t\t\tcase '<person': out.push({name: y.displayname, id: y.id }); break;\n\t\t\tcase '</person>': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': case '<extLst/>': break;\n\t\t\t/* 18.2.7  ext CT_Extension + */\n\t\t\tcase '<ext': pass=true; break;\n\t\t\tcase '</ext>': pass=false; break;\n\n\t\t\tdefault: if(!pass && opts.WTF) throw new Error('unrecognized ' + y[0] + ' in threaded comments');\n\t\t}\n\t\treturn x;\n\t});\n\treturn out;\n}\nfunction write_people_xml(people/*, opts*/) {\n\tvar o = [XML_HEADER, writextag('personList', null, {\n\t\t'xmlns': XMLNS.TCMNT,\n\t\t'xmlns:x': XMLNS_main[0]\n\t}).replace(/[\\/]>/, \">\")];\n\tpeople.forEach(function(person, idx) {\n\t\to.push(writextag('person', null, {\n\t\t\tdisplayName: person,\n\t\t\tid: \"{54EE7950-7262-4200-6969-\" + (\"000000000000\" + idx).slice(-12) + \"}\",\n\t\t\tuserId: person,\n\t\t\tproviderId: \"None\"\n\t\t}));\n\t});\n\to.push(\"</personList>\");\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.28 BrtBeginComment */\nfunction parse_BrtBeginComment(data) {\n\tvar out = {};\n\tout.iauthor = data.read_shift(4);\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tout.rfx = rfx.s;\n\tout.ref = encode_cell(rfx.s);\n\tdata.l += 16; /*var guid = parse_GUID(data); */\n\treturn out;\n}\nfunction write_BrtBeginComment(data, o) {\n\tif(o == null) o = new_buf(36);\n\to.write_shift(4, data[1].iauthor);\n\twrite_UncheckedRfX((data[0]/*:any*/), o);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\to.write_shift(4, 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.327 BrtCommentAuthor */\nvar parse_BrtCommentAuthor = parse_XLWideString;\nfunction write_BrtCommentAuthor(data) { return write_XLWideString(data.slice(0, 54)); }\n\n/* [MS-XLSB] 2.1.7.8 Comments */\nfunction parse_comments_bin(data, opts)/*:Array<RawComment>*/ {\n\tvar out/*:Array<RawComment>*/ = [];\n\tvar authors/*:Array<string>*/ = [];\n\tvar c = {};\n\tvar pass = false;\n\trecordhopper(data, function hopper_cmnt(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x0278: /* 'BrtCommentAuthor' */\n\t\t\t\tauthors.push(val); break;\n\t\t\tcase 0x027B: /* 'BrtBeginComment' */\n\t\t\t\tc = val; break;\n\t\t\tcase 0x027D: /* 'BrtCommentText' */\n\t\t\t\tc.t = val.t; c.h = val.h; c.r = val.r; break;\n\t\t\tcase 0x027C: /* 'BrtEndComment' */\n\t\t\t\tc.author = authors[c.iauthor];\n\t\t\t\tdelete (c/*:any*/).iauthor;\n\t\t\t\tif(opts.sheetRows && c.rfx && opts.sheetRows <= c.rfx.r) break;\n\t\t\t\tif(!c.t) c.t = \"\";\n\t\t\t\tdelete c.rfx; out.push(c); break;\n\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */ break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */ break;\n\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t});\n\treturn out;\n}\n\nfunction write_comments_bin(data/*::, opts*/) {\n\tvar ba = buf_array();\n\tvar iauthor/*:Array<string>*/ = [];\n\twrite_record(ba, 0x0274 /* BrtBeginComments */);\n\n\twrite_record(ba, 0x0276 /* BrtBeginCommentAuthors */);\n\tdata.forEach(function(comment) {\n\t\tcomment[1].forEach(function(c) {\n\t\t\tif(iauthor.indexOf(c.a) > -1) return;\n\t\t\tiauthor.push(c.a.slice(0,54));\n\t\t\twrite_record(ba, 0x0278 /* BrtCommentAuthor */, write_BrtCommentAuthor(c.a));\n\t\t});\n\t});\n\twrite_record(ba, 0x0277 /* BrtEndCommentAuthors */);\n\n\twrite_record(ba, 0x0279 /* BrtBeginCommentList */);\n\tdata.forEach(function(comment) {\n\t\tcomment[1].forEach(function(c) {\n\t\t\tc.iauthor = iauthor.indexOf(c.a);\n\t\t\tvar range = {s:decode_cell(comment[0]),e:decode_cell(comment[0])};\n\t\t\twrite_record(ba, 0x027B /* BrtBeginComment */, write_BrtBeginComment([range, c]));\n\t\t\tif(c.t && c.t.length > 0) write_record(ba, 0x027D /* BrtCommentText */, write_BrtCommentText(c));\n\t\t\twrite_record(ba, 0x027C /* BrtEndComment */);\n\t\t\tdelete c.iauthor;\n\t\t});\n\t});\n\twrite_record(ba, 0x027A /* BrtEndCommentList */);\n\n\twrite_record(ba, 0x0275 /* BrtEndComments */);\n\treturn ba.end();\n}\nvar CT_VBA = \"application/vnd.ms-office.vbaProject\";\nfunction make_vba_xls(cfb) {\n  var newcfb = CFB.utils.cfb_new({ root: \"R\" });\n  cfb.FullPaths.forEach(function(p, i) {\n    if (p.slice(-1) === \"/\" || !p.match(/_VBA_PROJECT_CUR/))\n      return;\n    var newpath = p.replace(/^[^\\/]*/, \"R\").replace(/\\/_VBA_PROJECT_CUR\\u0000*/, \"\");\n    CFB.utils.cfb_add(newcfb, newpath, cfb.FileIndex[i].content);\n  });\n  return CFB.write(newcfb);\n}\nfunction fill_vba_xls(cfb, vba) {\n  vba.FullPaths.forEach(function(p, i) {\n    if (i == 0)\n      return;\n    var newpath = p.replace(/[^\\/]*[\\/]/, \"/_VBA_PROJECT_CUR/\");\n    if (newpath.slice(-1) !== \"/\")\n      CFB.utils.cfb_add(cfb, newpath, vba.FileIndex[i].content);\n  });\n}\nvar VBAFMTS = [\"xlsb\", \"xlsm\", \"xlam\", \"biff8\", \"xla\"];\n/* macro and dialog sheet stubs */\nfunction parse_ds_bin(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'dialog'}; }\nfunction parse_ds_xml(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'dialog'}; }\nfunction parse_ms_bin(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'macro'}; }\nfunction parse_ms_xml(/*::data:any, opts, idx:number, rels, wb, themes, styles*/)/*:Worksheet*/ { return {'!type':'macro'}; }\n/* TODO: it will be useful to parse the function str */\nvar rc_to_a1 = /*#__PURE__*/(function(){\n\tvar rcregex = /(^|[^A-Za-z_])R(\\[?-?\\d+\\]|[1-9]\\d*|)C(\\[?-?\\d+\\]|[1-9]\\d*|)(?![A-Za-z0-9_])/g;\n\tvar rcbase/*:Cell*/ = ({r:0,c:0}/*:any*/);\n\tfunction rcfunc($$,$1,$2,$3) {\n\t\tvar cRel = false, rRel = false;\n\n\t\tif($2.length == 0) rRel = true;\n\t\telse if($2.charAt(0) == \"[\") { rRel = true; $2 = $2.slice(1, -1); }\n\n\t\tif($3.length == 0) cRel = true;\n\t\telse if($3.charAt(0) == \"[\") { cRel = true; $3 = $3.slice(1, -1); }\n\n\t\tvar R = $2.length>0?parseInt($2,10)|0:0, C = $3.length>0?parseInt($3,10)|0:0;\n\n\t\tif(cRel) C += rcbase.c; else --C;\n\t\tif(rRel) R += rcbase.r; else --R;\n\t\treturn $1 + (cRel ? \"\" : \"$\") + encode_col(C) + (rRel ? \"\" : \"$\") + encode_row(R);\n\t}\n\treturn function rc_to_a1(fstr/*:string*/, base/*:Cell*/)/*:string*/ {\n\t\trcbase = base;\n\t\treturn fstr.replace(rcregex, rcfunc);\n\t};\n})();\n\nvar crefregex = /(^|[^._A-Z0-9])([$]?)([A-Z]{1,2}|[A-W][A-Z]{2}|X[A-E][A-Z]|XF[A-D])([$]?)(10[0-3]\\d{4}|104[0-7]\\d{3}|1048[0-4]\\d{2}|10485[0-6]\\d|104857[0-6]|[1-9]\\d{0,5})(?![_.\\(A-Za-z0-9])/g;\nvar a1_to_rc = /*#__PURE__*/(function(){\n\treturn function a1_to_rc(fstr/*:string*/, base/*:CellAddress*/) {\n\t\treturn fstr.replace(crefregex, function($0, $1, $2, $3, $4, $5) {\n\t\t\tvar c = decode_col($3) - ($2 ? 0 : base.c);\n\t\t\tvar r = decode_row($5) - ($4 ? 0 : base.r);\n\t\t\tvar R = (r == 0 ? \"\" : !$4 ? \"[\" + r + \"]\" : (r+1));\n\t\t\tvar C = (c == 0 ? \"\" : !$2 ? \"[\" + c + \"]\" : (c+1));\n\t\t\treturn $1 + \"R\" + R + \"C\" + C;\n\t\t});\n\t};\n})();\n\n/* no defined name can collide with a valid cell address A1:XFD1048576 ... except LOG10! */\nfunction shift_formula_str(f/*:string*/, delta/*:Cell*/)/*:string*/ {\n\treturn f.replace(crefregex, function($0, $1, $2, $3, $4, $5) {\n\t\treturn $1+($2==\"$\" ? $2+$3 : encode_col(decode_col($3)+delta.c))+($4==\"$\" ? $4+$5 : encode_row(decode_row($5) + delta.r));\n\t});\n}\n\nfunction shift_formula_xlsx(f/*:string*/, range/*:string*/, cell/*:string*/)/*:string*/ {\n\tvar r = decode_range(range), s = r.s, c = decode_cell(cell);\n\tvar delta = {r:c.r - s.r, c:c.c - s.c};\n\treturn shift_formula_str(f, delta);\n}\n\n/* TODO: parse formula */\nfunction fuzzyfmla(f/*:string*/)/*:boolean*/ {\n\tif(f.length == 1) return false;\n\treturn true;\n}\n\nfunction _xlfn(f/*:string*/)/*:string*/ {\n\treturn f.replace(/_xlfn\\./g,\"\");\n}\nfunction parseread1(blob) { blob.l+=1; return; }\n\n/* [MS-XLS] 2.5.51 */\nfunction parse_ColRelU(blob, length) {\n\tvar c = blob.read_shift(length == 1 ? 1 : 2);\n\treturn [c & 0x3FFF, (c >> 14) & 1, (c >> 15) & 1];\n}\n\n/* [MS-XLS] 2.5.198.105 ; [MS-XLSB] 2.5.97.89 */\nfunction parse_RgceArea(blob, length, opts) {\n\tvar w = 2;\n\tif(opts) {\n\t\tif(opts.biff >= 2 && opts.biff <= 5) return parse_RgceArea_BIFF2(blob, length, opts);\n\t\telse if(opts.biff == 12) w = 4;\n\t}\n\tvar r=blob.read_shift(w), R=blob.read_shift(w);\n\tvar c=parse_ColRelU(blob, 2);\n\tvar C=parse_ColRelU(blob, 2);\n\treturn { s:{r:r, c:c[0], cRel:c[1], rRel:c[2]}, e:{r:R, c:C[0], cRel:C[1], rRel:C[2]} };\n}\n/* BIFF 2-5 encodes flags in the row field */\nfunction parse_RgceArea_BIFF2(blob/*::, length, opts*/) {\n\tvar r=parse_ColRelU(blob, 2), R=parse_ColRelU(blob, 2);\n\tvar c=blob.read_shift(1);\n\tvar C=blob.read_shift(1);\n\treturn { s:{r:r[0], c:c, cRel:r[1], rRel:r[2]}, e:{r:R[0], c:C, cRel:R[1], rRel:R[2]} };\n}\n\n/* [MS-XLS] 2.5.198.105 ; [MS-XLSB] 2.5.97.90 */\nfunction parse_RgceAreaRel(blob, length, opts) {\n\tif(opts.biff < 8) return parse_RgceArea_BIFF2(blob, length, opts);\n\tvar r=blob.read_shift(opts.biff == 12 ? 4 : 2), R=blob.read_shift(opts.biff == 12 ? 4 : 2);\n\tvar c=parse_ColRelU(blob, 2);\n\tvar C=parse_ColRelU(blob, 2);\n\treturn { s:{r:r, c:c[0], cRel:c[1], rRel:c[2]}, e:{r:R, c:C[0], cRel:C[1], rRel:C[2]} };\n}\n\n/* [MS-XLS] 2.5.198.109 ; [MS-XLSB] 2.5.97.91 */\nfunction parse_RgceLoc(blob, length, opts) {\n\tif(opts && opts.biff >= 2 && opts.biff <= 5) return parse_RgceLoc_BIFF2(blob, length, opts);\n\tvar r = blob.read_shift(opts && opts.biff == 12 ? 4 : 2);\n\tvar c = parse_ColRelU(blob, 2);\n\treturn {r:r, c:c[0], cRel:c[1], rRel:c[2]};\n}\nfunction parse_RgceLoc_BIFF2(blob/*::, length, opts*/) {\n\tvar r = parse_ColRelU(blob, 2);\n\tvar c = blob.read_shift(1);\n\treturn {r:r[0], c:c, cRel:r[1], rRel:r[2]};\n}\n\n/* [MS-XLS] 2.5.198.107, 2.5.47 */\nfunction parse_RgceElfLoc(blob/*::, length, opts*/) {\n\tvar r = blob.read_shift(2);\n\tvar c = blob.read_shift(2);\n\treturn {r:r, c:c & 0xFF, fQuoted:!!(c & 0x4000), cRel:c>>15, rRel:c>>15 };\n}\n\n/* [MS-XLS] 2.5.198.111 ; [MS-XLSB] 2.5.97.92 TODO */\nfunction parse_RgceLocRel(blob, length, opts) {\n\tvar biff = opts && opts.biff ? opts.biff : 8;\n\tif(biff >= 2 && biff <= 5) return parse_RgceLocRel_BIFF2(blob, length, opts);\n\tvar r = blob.read_shift(biff >= 12 ? 4 : 2);\n\tvar cl = blob.read_shift(2);\n\tvar cRel = (cl & 0x4000) >> 14, rRel = (cl & 0x8000) >> 15;\n\tcl &= 0x3FFF;\n\tif(rRel == 1) while(r > 0x7FFFF) r -= 0x100000;\n\tif(cRel == 1) while(cl > 0x1FFF) cl = cl - 0x4000;\n\treturn {r:r,c:cl,cRel:cRel,rRel:rRel};\n}\nfunction parse_RgceLocRel_BIFF2(blob/*::, length:number, opts*/) {\n\tvar rl = blob.read_shift(2);\n\tvar c = blob.read_shift(1);\n\tvar rRel = (rl & 0x8000) >> 15, cRel = (rl & 0x4000) >> 14;\n\trl &= 0x3FFF;\n\tif(rRel == 1 && rl >= 0x2000) rl = rl - 0x4000;\n\tif(cRel == 1 && c >= 0x80) c = c - 0x100;\n\treturn {r:rl,c:c,cRel:cRel,rRel:rRel};\n}\n\n/* [MS-XLS] 2.5.198.27 ; [MS-XLSB] 2.5.97.18 */\nfunction parse_PtgArea(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar area = parse_RgceArea(blob, opts.biff >= 2 && opts.biff <= 5 ? 6 : 8, opts);\n\treturn [type, area];\n}\n\n/* [MS-XLS] 2.5.198.28 ; [MS-XLSB] 2.5.97.19 */\nfunction parse_PtgArea3d(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2, 'i');\n\tvar w = 8;\n\tif(opts) switch(opts.biff) {\n\t\tcase 5: blob.l += 12; w = 6; break;\n\t\tcase 12: w = 12; break;\n\t}\n\tvar area = parse_RgceArea(blob, w, opts);\n\treturn [type, ixti, area];\n}\n\n/* [MS-XLS] 2.5.198.29 ; [MS-XLSB] 2.5.97.20 */\nfunction parse_PtgAreaErr(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tblob.l += opts && (opts.biff > 8) ? 12 : (opts.biff < 8 ? 6 : 8);\n\treturn [type];\n}\n/* [MS-XLS] 2.5.198.30 ; [MS-XLSB] 2.5.97.21 */\nfunction parse_PtgAreaErr3d(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2);\n\tvar w = 8;\n\tif(opts) switch(opts.biff) {\n\t\tcase 5: blob.l += 12; w = 6; break;\n\t\tcase 12: w = 12; break;\n\t}\n\tblob.l += w;\n\treturn [type, ixti];\n}\n\n/* [MS-XLS] 2.5.198.31 ; [MS-XLSB] 2.5.97.22 */\nfunction parse_PtgAreaN(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar area = parse_RgceAreaRel(blob, length - 1, opts);\n\treturn [type, area];\n}\n\n/* [MS-XLS] 2.5.198.32 ; [MS-XLSB] 2.5.97.23 */\nfunction parse_PtgArray(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tblob.l += opts.biff == 2 ? 6 : opts.biff == 12 ? 14 : 7;\n\treturn [type];\n}\n\n/* [MS-XLS] 2.5.198.33 ; [MS-XLSB] 2.5.97.24 */\nfunction parse_PtgAttrBaxcel(blob) {\n\tvar bitSemi = blob[blob.l+1] & 0x01; /* 1 = volatile */\n\tvar bitBaxcel = 1;\n\tblob.l += 4;\n\treturn [bitSemi, bitBaxcel];\n}\n\n/* [MS-XLS] 2.5.198.34 ; [MS-XLSB] 2.5.97.25 */\nfunction parse_PtgAttrChoose(blob, length, opts)/*:Array<number>*/ {\n\tblob.l +=2;\n\tvar offset = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\tvar o/*:Array<number>*/ = [];\n\t/* offset is 1 less than the number of elements */\n\tfor(var i = 0; i <= offset; ++i) o.push(blob.read_shift(opts && opts.biff == 2 ? 1 : 2));\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.198.35 ; [MS-XLSB] 2.5.97.26 */\nfunction parse_PtgAttrGoto(blob, length, opts) {\n\tvar bitGoto = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitGoto, blob.read_shift(opts && opts.biff == 2 ? 1 : 2)];\n}\n\n/* [MS-XLS] 2.5.198.36 ; [MS-XLSB] 2.5.97.27 */\nfunction parse_PtgAttrIf(blob, length, opts) {\n\tvar bitIf = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitIf, blob.read_shift(opts && opts.biff == 2 ? 1 : 2)];\n}\n\n/* [MS-XLSB] 2.5.97.28 */\nfunction parse_PtgAttrIfError(blob) {\n\tvar bitIf = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += 2;\n\treturn [bitIf, blob.read_shift(2)];\n}\n\n/* [MS-XLS] 2.5.198.37 ; [MS-XLSB] 2.5.97.29 */\nfunction parse_PtgAttrSemi(blob, length, opts) {\n\tvar bitSemi = (blob[blob.l+1] & 0xFF) ? 1 : 0;\n\tblob.l += opts && opts.biff == 2 ? 3 : 4;\n\treturn [bitSemi];\n}\n\n/* [MS-XLS] 2.5.198.40 ; [MS-XLSB] 2.5.97.32 */\nfunction parse_PtgAttrSpaceType(blob/*::, length*/) {\n\tvar type = blob.read_shift(1), cch = blob.read_shift(1);\n\treturn [type, cch];\n}\n\n/* [MS-XLS] 2.5.198.38 ; [MS-XLSB] 2.5.97.30 */\nfunction parse_PtgAttrSpace(blob) {\n\tblob.read_shift(2);\n\treturn parse_PtgAttrSpaceType(blob, 2);\n}\n\n/* [MS-XLS] 2.5.198.39 ; [MS-XLSB] 2.5.97.31 */\nfunction parse_PtgAttrSpaceSemi(blob) {\n\tblob.read_shift(2);\n\treturn parse_PtgAttrSpaceType(blob, 2);\n}\n\n/* [MS-XLS] 2.5.198.84 ; [MS-XLSB] 2.5.97.68 TODO */\nfunction parse_PtgRef(blob, length, opts) {\n\t//var ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar loc = parse_RgceLoc(blob, 0, opts);\n\treturn [type, loc];\n}\n\n/* [MS-XLS] 2.5.198.88 ; [MS-XLSB] 2.5.97.72 TODO */\nfunction parse_PtgRefN(blob, length, opts) {\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar loc = parse_RgceLocRel(blob, 0, opts);\n\treturn [type, loc];\n}\n\n/* [MS-XLS] 2.5.198.85 ; [MS-XLSB] 2.5.97.69 TODO */\nfunction parse_PtgRef3d(blob, length, opts) {\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar ixti = blob.read_shift(2); // XtiIndex\n\tif(opts && opts.biff == 5) blob.l += 12;\n\tvar loc = parse_RgceLoc(blob, 0, opts); // TODO: or RgceLocRel\n\treturn [type, ixti, loc];\n}\n\n\n/* [MS-XLS] 2.5.198.62 ; [MS-XLSB] 2.5.97.45 TODO */\nfunction parse_PtgFunc(blob, length, opts) {\n\t//var ptg = blob[blob.l] & 0x1F;\n\tvar type = (blob[blob.l] & 0x60)>>5;\n\tblob.l += 1;\n\tvar iftab = blob.read_shift(opts && opts.biff <= 3 ? 1 : 2);\n\treturn [FtabArgc[iftab], Ftab[iftab], type];\n}\n/* [MS-XLS] 2.5.198.63 ; [MS-XLSB] 2.5.97.46 TODO */\nfunction parse_PtgFuncVar(blob, length, opts) {\n\tvar type = blob[blob.l++];\n\tvar cparams = blob.read_shift(1), tab = opts && opts.biff <= 3 ? [(type == 0x58 ? -1 : 0), blob.read_shift(1)]: parsetab(blob);\n\treturn [cparams, (tab[0] === 0 ? Ftab : Cetab)[tab[1]]];\n}\n\nfunction parsetab(blob) {\n\treturn [blob[blob.l+1]>>7, blob.read_shift(2) & 0x7FFF];\n}\n\n/* [MS-XLS] 2.5.198.41 ; [MS-XLSB] 2.5.97.33 */\nfunction parse_PtgAttrSum(blob, length, opts) {\n\tblob.l += opts && opts.biff == 2 ? 3 : 4; return;\n}\n\n/* [MS-XLS] 2.5.198.58 ; [MS-XLSB] 2.5.97.40 */\nfunction parse_PtgExp(blob, length, opts) {\n\tblob.l++;\n\tif(opts && opts.biff == 12) return [blob.read_shift(4, 'i'), 0];\n\tvar row = blob.read_shift(2);\n\tvar col = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\treturn [row, col];\n}\n\n/* [MS-XLS] 2.5.198.57 ; [MS-XLSB] 2.5.97.39 */\nfunction parse_PtgErr(blob) { blob.l++; return BErr[blob.read_shift(1)]; }\n\n/* [MS-XLS] 2.5.198.66 ; [MS-XLSB] 2.5.97.49 */\nfunction parse_PtgInt(blob) { blob.l++; return blob.read_shift(2); }\n\n/* [MS-XLS] 2.5.198.42 ; [MS-XLSB] 2.5.97.34 */\nfunction parse_PtgBool(blob) { blob.l++; return blob.read_shift(1)!==0;}\n\n/* [MS-XLS] 2.5.198.79 ; [MS-XLSB] 2.5.97.63 */\nfunction parse_PtgNum(blob) { blob.l++; return parse_Xnum(blob, 8); }\n\n/* [MS-XLS] 2.5.198.89 ; [MS-XLSB] 2.5.97.74 */\nfunction parse_PtgStr(blob, length, opts) { blob.l++; return parse_ShortXLUnicodeString(blob, length-1, opts); }\n\n/* [MS-XLS] 2.5.192.112 + 2.5.192.11{3,4,5,6,7} */\n/* [MS-XLSB] 2.5.97.93 + 2.5.97.9{4,5,6,7} */\nfunction parse_SerAr(blob, biff/*:number*/) {\n\tvar val = [blob.read_shift(1)];\n\tif(biff == 12) switch(val[0]) {\n\t\tcase 0x02: val[0] = 0x04; break; /* SerBool */\n\t\tcase 0x04: val[0] = 0x10; break; /* SerErr */\n\t\tcase 0x00: val[0] = 0x01; break; /* SerNum */\n\t\tcase 0x01: val[0] = 0x02; break; /* SerStr */\n\t}\n\tswitch(val[0]) {\n\t\tcase 0x04: /* SerBool -- boolean */\n\t\t\tval[1] = parsebool(blob, 1) ? 'TRUE' : 'FALSE';\n\t\t\tif(biff != 12) blob.l += 7; break;\n\t\tcase 0x25: /* appears to be an alias */\n\t\tcase 0x10: /* SerErr -- error */\n\t\t\tval[1] = BErr[blob[blob.l]];\n\t\t\tblob.l += ((biff == 12) ? 4 : 8); break;\n\t\tcase 0x00: /* SerNil -- honestly, I'm not sure how to reproduce this */\n\t\t\tblob.l += 8; break;\n\t\tcase 0x01: /* SerNum -- Xnum */\n\t\t\tval[1] = parse_Xnum(blob, 8); break;\n\t\tcase 0x02: /* SerStr -- XLUnicodeString (<256 chars) */\n\t\t\tval[1] = parse_XLUnicodeString2(blob, 0, {biff:biff > 0 && biff < 8 ? 2 : biff}); break;\n\t\tdefault: throw new Error(\"Bad SerAr: \" + val[0]); /* Unreachable */\n\t}\n\treturn val;\n}\n\n/* [MS-XLS] 2.5.198.61 ; [MS-XLSB] 2.5.97.44 */\nfunction parse_PtgExtraMem(blob, cce, opts) {\n\tvar count = blob.read_shift((opts.biff == 12) ? 4 : 2);\n\tvar out/*:Array<Range>*/ = [];\n\tfor(var i = 0; i != count; ++i) out.push(((opts.biff == 12) ? parse_UncheckedRfX : parse_Ref8U)(blob, 8));\n\treturn out;\n}\n\n/* [MS-XLS] 2.5.198.59 ; [MS-XLSB] 2.5.97.41 */\nfunction parse_PtgExtraArray(blob, length, opts) {\n\tvar rows = 0, cols = 0;\n\tif(opts.biff == 12) {\n\t\trows = blob.read_shift(4); // DRw\n\t\tcols = blob.read_shift(4); // DCol\n\t} else {\n\t\tcols = 1 + blob.read_shift(1); //DColByteU\n\t\trows = 1 + blob.read_shift(2); //DRw\n\t}\n\tif(opts.biff >= 2 && opts.biff < 8) { --rows; if(--cols == 0) cols = 0x100; }\n\t// $FlowIgnore\n\tfor(var i = 0, o/*:Array<Array<any>>*/ = []; i != rows && (o[i] = []); ++i)\n\t\tfor(var j = 0; j != cols; ++j) o[i][j] = parse_SerAr(blob, opts.biff);\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.198.76 ; [MS-XLSB] 2.5.97.60 */\nfunction parse_PtgName(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar w = (!opts || (opts.biff >= 8)) ? 4 : 2;\n\tvar nameindex = blob.read_shift(w);\n\tswitch(opts.biff) {\n\t\tcase 2: blob.l += 5; break;\n\t\tcase 3: case 4: blob.l += 8; break;\n\t\tcase 5: blob.l += 12; break;\n\t}\n\treturn [type, 0, nameindex];\n}\n\n/* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 */\nfunction parse_PtgNameX(blob, length, opts) {\n\tif(opts.biff == 5) return parse_PtgNameX_BIFF5(blob, length, opts);\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar ixti = blob.read_shift(2); // XtiIndex\n\tvar nameindex = blob.read_shift(4);\n\treturn [type, ixti, nameindex];\n}\nfunction parse_PtgNameX_BIFF5(blob/*::, length, opts*/) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar ixti = blob.read_shift(2, 'i'); // XtiIndex\n\tblob.l += 8;\n\tvar nameindex = blob.read_shift(2);\n\tblob.l += 12;\n\treturn [type, ixti, nameindex];\n}\n\n/* [MS-XLS] 2.5.198.70 ; [MS-XLSB] 2.5.97.54 */\nfunction parse_PtgMemArea(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tblob.l += (opts && opts.biff == 2 ? 3 : 4);\n\tvar cce = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\treturn [type, cce];\n}\n\n/* [MS-XLS] 2.5.198.72 ; [MS-XLSB] 2.5.97.56 */\nfunction parse_PtgMemFunc(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar cce = blob.read_shift(opts && opts.biff == 2 ? 1 : 2);\n\treturn [type, cce];\n}\n\n\n/* [MS-XLS] 2.5.198.86 ; [MS-XLSB] 2.5.97.69 */\nfunction parse_PtgRefErr(blob, length, opts) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tblob.l += 4;\n\tif(opts.biff < 8) blob.l--;\n\tif(opts.biff == 12) blob.l += 2;\n\treturn [type];\n}\n\n/* [MS-XLS] 2.5.198.87 ; [MS-XLSB] 2.5.97.71 */\nfunction parse_PtgRefErr3d(blob, length, opts) {\n\tvar type = (blob[blob.l++] & 0x60) >> 5;\n\tvar ixti = blob.read_shift(2);\n\tvar w = 4;\n\tif(opts) switch(opts.biff) {\n\t\tcase 5: w = 15; break;\n\t\tcase 12: w = 6; break;\n\t}\n\tblob.l += w;\n\treturn [type, ixti];\n}\n\n/* [MS-XLS] 2.5.198.71 ; [MS-XLSB] 2.5.97.55 */\nvar parse_PtgMemErr = parsenoop;\n/* [MS-XLS] 2.5.198.73  ; [MS-XLSB] 2.5.97.57 */\nvar parse_PtgMemNoMem = parsenoop;\n/* [MS-XLS] 2.5.198.92 */\nvar parse_PtgTbl = parsenoop;\n\nfunction parse_PtgElfLoc(blob, length, opts) {\n\tblob.l += 2;\n\treturn [parse_RgceElfLoc(blob, 4, opts)];\n}\nfunction parse_PtgElfNoop(blob/*::, length, opts*/) {\n\tblob.l += 6;\n\treturn [];\n}\n/* [MS-XLS] 2.5.198.46 */\nvar parse_PtgElfCol = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.47 */\nvar parse_PtgElfColS = parse_PtgElfNoop;\n/* [MS-XLS] 2.5.198.48 */\nvar parse_PtgElfColSV = parse_PtgElfNoop;\n/* [MS-XLS] 2.5.198.49 */\nvar parse_PtgElfColV = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.50 */\nfunction parse_PtgElfLel(blob/*::, length, opts*/) {\n\tblob.l += 2;\n\treturn [parseuint16(blob), blob.read_shift(2) & 0x01];\n}\n/* [MS-XLS] 2.5.198.51 */\nvar parse_PtgElfRadical = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.52 */\nvar parse_PtgElfRadicalLel = parse_PtgElfLel;\n/* [MS-XLS] 2.5.198.53 */\nvar parse_PtgElfRadicalS = parse_PtgElfNoop;\n/* [MS-XLS] 2.5.198.54 */\nvar parse_PtgElfRw = parse_PtgElfLoc;\n/* [MS-XLS] 2.5.198.55 */\nvar parse_PtgElfRwV = parse_PtgElfLoc;\n\n/* [MS-XLSB] 2.5.97.52 TODO */\nvar PtgListRT = [\n\t\"Data\",\n\t\"All\",\n\t\"Headers\",\n\t\"??\",\n\t\"?Data2\",\n\t\"??\",\n\t\"?DataHeaders\",\n\t\"??\",\n\t\"Totals\",\n\t\"??\",\n\t\"??\",\n\t\"??\",\n\t\"?DataTotals\",\n\t\"??\",\n\t\"??\",\n\t\"??\",\n\t\"?Current\"\n];\nfunction parse_PtgList(blob/*::, length, opts*/) {\n\tblob.l += 2;\n\tvar ixti = blob.read_shift(2);\n\tvar flags = blob.read_shift(2);\n\tvar idx = blob.read_shift(4);\n\tvar c = blob.read_shift(2);\n\tvar C = blob.read_shift(2);\n\tvar rt = PtgListRT[(flags >> 2) & 0x1F];\n\treturn {ixti: ixti, coltype:(flags&0x3), rt:rt, idx:idx, c:c, C:C};\n}\n/* [MS-XLS] 2.5.198.91 ; [MS-XLSB] 2.5.97.76 */\nfunction parse_PtgSxName(blob/*::, length, opts*/) {\n\tblob.l += 2;\n\treturn [blob.read_shift(4)];\n}\n\n/* [XLS] old spec */\nfunction parse_PtgSheet(blob, length, opts) {\n\tblob.l += 5;\n\tblob.l += 2;\n\tblob.l += (opts.biff == 2 ? 1 : 4);\n\treturn [\"PTGSHEET\"];\n}\nfunction parse_PtgEndSheet(blob, length, opts) {\n\tblob.l += (opts.biff == 2 ? 4 : 5);\n\treturn [\"PTGENDSHEET\"];\n}\nfunction parse_PtgMemAreaN(blob/*::, length, opts*/) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar cce = blob.read_shift(2);\n\treturn [type, cce];\n}\nfunction parse_PtgMemNoMemN(blob/*::, length, opts*/) {\n\tvar type = (blob.read_shift(1) >>> 5) & 0x03;\n\tvar cce = blob.read_shift(2);\n\treturn [type, cce];\n}\nfunction parse_PtgAttrNoop(blob/*::, length, opts*/) {\n\tblob.l += 4;\n\treturn [0, 0];\n}\n\n/* [MS-XLS] 2.5.198.25 ; [MS-XLSB] 2.5.97.16 */\nvar PtgTypes = {\n\t/*::[*/0x01/*::]*/: { n:'PtgExp', f:parse_PtgExp },\n\t/*::[*/0x02/*::]*/: { n:'PtgTbl', f:parse_PtgTbl },\n\t/*::[*/0x03/*::]*/: { n:'PtgAdd', f:parseread1 },\n\t/*::[*/0x04/*::]*/: { n:'PtgSub', f:parseread1 },\n\t/*::[*/0x05/*::]*/: { n:'PtgMul', f:parseread1 },\n\t/*::[*/0x06/*::]*/: { n:'PtgDiv', f:parseread1 },\n\t/*::[*/0x07/*::]*/: { n:'PtgPower', f:parseread1 },\n\t/*::[*/0x08/*::]*/: { n:'PtgConcat', f:parseread1 },\n\t/*::[*/0x09/*::]*/: { n:'PtgLt', f:parseread1 },\n\t/*::[*/0x0A/*::]*/: { n:'PtgLe', f:parseread1 },\n\t/*::[*/0x0B/*::]*/: { n:'PtgEq', f:parseread1 },\n\t/*::[*/0x0C/*::]*/: { n:'PtgGe', f:parseread1 },\n\t/*::[*/0x0D/*::]*/: { n:'PtgGt', f:parseread1 },\n\t/*::[*/0x0E/*::]*/: { n:'PtgNe', f:parseread1 },\n\t/*::[*/0x0F/*::]*/: { n:'PtgIsect', f:parseread1 },\n\t/*::[*/0x10/*::]*/: { n:'PtgUnion', f:parseread1 },\n\t/*::[*/0x11/*::]*/: { n:'PtgRange', f:parseread1 },\n\t/*::[*/0x12/*::]*/: { n:'PtgUplus', f:parseread1 },\n\t/*::[*/0x13/*::]*/: { n:'PtgUminus', f:parseread1 },\n\t/*::[*/0x14/*::]*/: { n:'PtgPercent', f:parseread1 },\n\t/*::[*/0x15/*::]*/: { n:'PtgParen', f:parseread1 },\n\t/*::[*/0x16/*::]*/: { n:'PtgMissArg', f:parseread1 },\n\t/*::[*/0x17/*::]*/: { n:'PtgStr', f:parse_PtgStr },\n\t/*::[*/0x1A/*::]*/: { n:'PtgSheet', f:parse_PtgSheet },\n\t/*::[*/0x1B/*::]*/: { n:'PtgEndSheet', f:parse_PtgEndSheet },\n\t/*::[*/0x1C/*::]*/: { n:'PtgErr', f:parse_PtgErr },\n\t/*::[*/0x1D/*::]*/: { n:'PtgBool', f:parse_PtgBool },\n\t/*::[*/0x1E/*::]*/: { n:'PtgInt', f:parse_PtgInt },\n\t/*::[*/0x1F/*::]*/: { n:'PtgNum', f:parse_PtgNum },\n\t/*::[*/0x20/*::]*/: { n:'PtgArray', f:parse_PtgArray },\n\t/*::[*/0x21/*::]*/: { n:'PtgFunc', f:parse_PtgFunc },\n\t/*::[*/0x22/*::]*/: { n:'PtgFuncVar', f:parse_PtgFuncVar },\n\t/*::[*/0x23/*::]*/: { n:'PtgName', f:parse_PtgName },\n\t/*::[*/0x24/*::]*/: { n:'PtgRef', f:parse_PtgRef },\n\t/*::[*/0x25/*::]*/: { n:'PtgArea', f:parse_PtgArea },\n\t/*::[*/0x26/*::]*/: { n:'PtgMemArea', f:parse_PtgMemArea },\n\t/*::[*/0x27/*::]*/: { n:'PtgMemErr', f:parse_PtgMemErr },\n\t/*::[*/0x28/*::]*/: { n:'PtgMemNoMem', f:parse_PtgMemNoMem },\n\t/*::[*/0x29/*::]*/: { n:'PtgMemFunc', f:parse_PtgMemFunc },\n\t/*::[*/0x2A/*::]*/: { n:'PtgRefErr', f:parse_PtgRefErr },\n\t/*::[*/0x2B/*::]*/: { n:'PtgAreaErr', f:parse_PtgAreaErr },\n\t/*::[*/0x2C/*::]*/: { n:'PtgRefN', f:parse_PtgRefN },\n\t/*::[*/0x2D/*::]*/: { n:'PtgAreaN', f:parse_PtgAreaN },\n\t/*::[*/0x2E/*::]*/: { n:'PtgMemAreaN', f:parse_PtgMemAreaN },\n\t/*::[*/0x2F/*::]*/: { n:'PtgMemNoMemN', f:parse_PtgMemNoMemN },\n\t/*::[*/0x39/*::]*/: { n:'PtgNameX', f:parse_PtgNameX },\n\t/*::[*/0x3A/*::]*/: { n:'PtgRef3d', f:parse_PtgRef3d },\n\t/*::[*/0x3B/*::]*/: { n:'PtgArea3d', f:parse_PtgArea3d },\n\t/*::[*/0x3C/*::]*/: { n:'PtgRefErr3d', f:parse_PtgRefErr3d },\n\t/*::[*/0x3D/*::]*/: { n:'PtgAreaErr3d', f:parse_PtgAreaErr3d },\n\t/*::[*/0xFF/*::]*/: {}\n};\n/* These are duplicated in the PtgTypes table */\nvar PtgDupes = {\n\t/*::[*/0x40/*::]*/: 0x20, /*::[*/0x60/*::]*/: 0x20,\n\t/*::[*/0x41/*::]*/: 0x21, /*::[*/0x61/*::]*/: 0x21,\n\t/*::[*/0x42/*::]*/: 0x22, /*::[*/0x62/*::]*/: 0x22,\n\t/*::[*/0x43/*::]*/: 0x23, /*::[*/0x63/*::]*/: 0x23,\n\t/*::[*/0x44/*::]*/: 0x24, /*::[*/0x64/*::]*/: 0x24,\n\t/*::[*/0x45/*::]*/: 0x25, /*::[*/0x65/*::]*/: 0x25,\n\t/*::[*/0x46/*::]*/: 0x26, /*::[*/0x66/*::]*/: 0x26,\n\t/*::[*/0x47/*::]*/: 0x27, /*::[*/0x67/*::]*/: 0x27,\n\t/*::[*/0x48/*::]*/: 0x28, /*::[*/0x68/*::]*/: 0x28,\n\t/*::[*/0x49/*::]*/: 0x29, /*::[*/0x69/*::]*/: 0x29,\n\t/*::[*/0x4A/*::]*/: 0x2A, /*::[*/0x6A/*::]*/: 0x2A,\n\t/*::[*/0x4B/*::]*/: 0x2B, /*::[*/0x6B/*::]*/: 0x2B,\n\t/*::[*/0x4C/*::]*/: 0x2C, /*::[*/0x6C/*::]*/: 0x2C,\n\t/*::[*/0x4D/*::]*/: 0x2D, /*::[*/0x6D/*::]*/: 0x2D,\n\t/*::[*/0x4E/*::]*/: 0x2E, /*::[*/0x6E/*::]*/: 0x2E,\n\t/*::[*/0x4F/*::]*/: 0x2F, /*::[*/0x6F/*::]*/: 0x2F,\n\t/*::[*/0x58/*::]*/: 0x22, /*::[*/0x78/*::]*/: 0x22,\n\t/*::[*/0x59/*::]*/: 0x39, /*::[*/0x79/*::]*/: 0x39,\n\t/*::[*/0x5A/*::]*/: 0x3A, /*::[*/0x7A/*::]*/: 0x3A,\n\t/*::[*/0x5B/*::]*/: 0x3B, /*::[*/0x7B/*::]*/: 0x3B,\n\t/*::[*/0x5C/*::]*/: 0x3C, /*::[*/0x7C/*::]*/: 0x3C,\n\t/*::[*/0x5D/*::]*/: 0x3D, /*::[*/0x7D/*::]*/: 0x3D\n};\n\nvar Ptg18 = {\n\t/*::[*/0x01/*::]*/: { n:'PtgElfLel', f:parse_PtgElfLel },\n\t/*::[*/0x02/*::]*/: { n:'PtgElfRw', f:parse_PtgElfRw },\n\t/*::[*/0x03/*::]*/: { n:'PtgElfCol', f:parse_PtgElfCol },\n\t/*::[*/0x06/*::]*/: { n:'PtgElfRwV', f:parse_PtgElfRwV },\n\t/*::[*/0x07/*::]*/: { n:'PtgElfColV', f:parse_PtgElfColV },\n\t/*::[*/0x0A/*::]*/: { n:'PtgElfRadical', f:parse_PtgElfRadical },\n\t/*::[*/0x0B/*::]*/: { n:'PtgElfRadicalS', f:parse_PtgElfRadicalS },\n\t/*::[*/0x0D/*::]*/: { n:'PtgElfColS', f:parse_PtgElfColS },\n\t/*::[*/0x0F/*::]*/: { n:'PtgElfColSV', f:parse_PtgElfColSV },\n\t/*::[*/0x10/*::]*/: { n:'PtgElfRadicalLel', f:parse_PtgElfRadicalLel },\n\t/*::[*/0x19/*::]*/: { n:'PtgList', f:parse_PtgList },\n\t/*::[*/0x1D/*::]*/: { n:'PtgSxName', f:parse_PtgSxName },\n\t/*::[*/0xFF/*::]*/: {}\n};\nvar Ptg19 = {\n\t/*::[*/0x00/*::]*/: { n:'PtgAttrNoop', f:parse_PtgAttrNoop },\n\t/*::[*/0x01/*::]*/: { n:'PtgAttrSemi', f:parse_PtgAttrSemi },\n\t/*::[*/0x02/*::]*/: { n:'PtgAttrIf', f:parse_PtgAttrIf },\n\t/*::[*/0x04/*::]*/: { n:'PtgAttrChoose', f:parse_PtgAttrChoose },\n\t/*::[*/0x08/*::]*/: { n:'PtgAttrGoto', f:parse_PtgAttrGoto },\n\t/*::[*/0x10/*::]*/: { n:'PtgAttrSum', f:parse_PtgAttrSum },\n\t/*::[*/0x20/*::]*/: { n:'PtgAttrBaxcel', f:parse_PtgAttrBaxcel },\n\t/*::[*/0x21/*::]*/: { n:'PtgAttrBaxcel', f:parse_PtgAttrBaxcel },\n\t/*::[*/0x40/*::]*/: { n:'PtgAttrSpace', f:parse_PtgAttrSpace },\n\t/*::[*/0x41/*::]*/: { n:'PtgAttrSpaceSemi', f:parse_PtgAttrSpaceSemi },\n\t/*::[*/0x80/*::]*/: { n:'PtgAttrIfError', f:parse_PtgAttrIfError },\n\t/*::[*/0xFF/*::]*/: {}\n};\n\n/* [MS-XLS] 2.5.198.103 ; [MS-XLSB] 2.5.97.87 */\nfunction parse_RgbExtra(blob, length, rgce, opts) {\n\tif(opts.biff < 8) return parsenoop(blob, length);\n\tvar target = blob.l + length;\n\tvar o = [];\n\tfor(var i = 0; i !== rgce.length; ++i) {\n\t\tswitch(rgce[i][0]) {\n\t\t\tcase 'PtgArray': /* PtgArray -> PtgExtraArray */\n\t\t\t\trgce[i][1] = parse_PtgExtraArray(blob, 0, opts);\n\t\t\t\to.push(rgce[i][1]);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgMemArea': /* PtgMemArea -> PtgExtraMem */\n\t\t\t\trgce[i][2] = parse_PtgExtraMem(blob, rgce[i][1], opts);\n\t\t\t\to.push(rgce[i][2]);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgExp': /* PtgExp -> PtgExtraCol */\n\t\t\t\tif(opts && opts.biff == 12) {\n\t\t\t\t\trgce[i][1][1] = blob.read_shift(4);\n\t\t\t\t\to.push(rgce[i][1]);\n\t\t\t\t} break;\n\t\t\tcase 'PtgList': /* TODO: PtgList -> PtgExtraList */\n\t\t\tcase 'PtgElfRadicalS': /* TODO: PtgElfRadicalS -> PtgExtraElf */\n\t\t\tcase 'PtgElfColS': /* TODO: PtgElfColS -> PtgExtraElf */\n\t\t\tcase 'PtgElfColSV': /* TODO: PtgElfColSV -> PtgExtraElf */\n\t\t\t\tthrow \"Unsupported \" + rgce[i][0];\n\t\t\tdefault: break;\n\t\t}\n\t}\n\tlength = target - blob.l;\n\t/* note: this is technically an error but Excel disregards */\n\t//if(target !== blob.l && blob.l !== target - length) throw new Error(target + \" != \" + blob.l);\n\tif(length !== 0) o.push(parsenoop(blob, length));\n\treturn o;\n}\n\n/* [MS-XLS] 2.5.198.104 ; [MS-XLSB] 2.5.97.88 */\nfunction parse_Rgce(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar R, id, ptgs = [];\n\twhile(target != blob.l) {\n\t\tlength = target - blob.l;\n\t\tid = blob[blob.l];\n\t\tR = PtgTypes[id] || PtgTypes[PtgDupes[id]];\n\t\tif(id === 0x18 || id === 0x19) R = (id === 0x18 ? Ptg18 : Ptg19)[blob[blob.l + 1]];\n\t\tif(!R || !R.f) { /*ptgs.push*/(parsenoop(blob, length)); }\n\t\telse { ptgs.push([R.n, R.f(blob, length, opts)]); }\n\t}\n\treturn ptgs;\n}\n\nfunction stringify_array(f/*:Array<Array<string>>*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tfor(var i = 0; i < f.length; ++i) {\n\t\tvar x = f[i], r/*:Array<string>*/ = [];\n\t\tfor(var j = 0; j < x.length; ++j) {\n\t\t\tvar y = x[j];\n\t\t\tif(y) switch(y[0]) {\n\t\t\t\t// TODO: handle embedded quotes\n\t\t\t\tcase 0x02:\n\t\t\t\t\t/*:: if(typeof y[1] != 'string') throw \"unreachable\"; */\n\t\t\t\t\tr.push('\"' + y[1].replace(/\"/g,'\"\"') + '\"'); break;\n\t\t\t\tdefault: r.push(y[1]);\n\t\t\t} else r.push(\"\");\n\t\t}\n\t\to.push(r.join(\",\"));\n\t}\n\treturn o.join(\";\");\n}\n\n/* [MS-XLS] 2.2.2 ; [MS-XLSB] 2.2.2 TODO */\nvar PtgBinOp = {\n\tPtgAdd: \"+\",\n\tPtgConcat: \"&\",\n\tPtgDiv: \"/\",\n\tPtgEq: \"=\",\n\tPtgGe: \">=\",\n\tPtgGt: \">\",\n\tPtgLe: \"<=\",\n\tPtgLt: \"<\",\n\tPtgMul: \"*\",\n\tPtgNe: \"<>\",\n\tPtgPower: \"^\",\n\tPtgSub: \"-\"\n};\n\n// List of invalid characters needs to be tested further\nfunction formula_quote_sheet_name(sname/*:string*/, opts)/*:string*/ {\n\tif(!sname && !(opts && opts.biff <= 5 && opts.biff >= 2)) throw new Error(\"empty sheet name\");\n\tif (/[^\\w\\u4E00-\\u9FFF\\u3040-\\u30FF]/.test(sname)) return \"'\" + sname + \"'\";\n\treturn sname;\n}\nfunction get_ixti_raw(supbooks, ixti/*:number*/, opts)/*:string*/ {\n\tif(!supbooks) return \"SH33TJSERR0\";\n\tif(opts.biff > 8 && (!supbooks.XTI || !supbooks.XTI[ixti])) return supbooks.SheetNames[ixti];\n\tif(!supbooks.XTI) return \"SH33TJSERR6\";\n\tvar XTI = supbooks.XTI[ixti];\n\tif(opts.biff < 8) {\n\t\tif(ixti > 10000) ixti-= 65536;\n\t\tif(ixti < 0) ixti = -ixti;\n\t\treturn ixti == 0 ? \"\" : supbooks.XTI[ixti - 1];\n\t}\n\tif(!XTI) return \"SH33TJSERR1\";\n\tvar o = \"\";\n\tif(opts.biff > 8) switch(supbooks[XTI[0]][0]) {\n\t\tcase 0x0165: /* 'BrtSupSelf' */\n\t\t\to = XTI[1] == -1 ? \"#REF\" : supbooks.SheetNames[XTI[1]];\n\t\t\treturn XTI[1] == XTI[2] ? o : o + \":\" + supbooks.SheetNames[XTI[2]];\n\t\tcase 0x0166: /* 'BrtSupSame' */\n\t\t\tif(opts.SID != null) return supbooks.SheetNames[opts.SID];\n\t\t\treturn \"SH33TJSSAME\" + supbooks[XTI[0]][0];\n\t\tcase 0x0163: /* 'BrtSupBookSrc' */\n\t\t\t/* falls through */\n\t\tdefault: return \"SH33TJSSRC\" + supbooks[XTI[0]][0];\n\t}\n\tswitch(supbooks[XTI[0]][0][0]) {\n\t\tcase 0x0401:\n\t\t\to = XTI[1] == -1 ? \"#REF\" : (supbooks.SheetNames[XTI[1]] || \"SH33TJSERR3\");\n\t\t\treturn XTI[1] == XTI[2] ? o : o + \":\" + supbooks.SheetNames[XTI[2]];\n\t\tcase 0x3A01: return supbooks[XTI[0]].slice(1).map(function(name) { return name.Name; }).join(\";;\"); //return \"SH33TJSERR8\";\n\t\tdefault:\n\t\t\tif(!supbooks[XTI[0]][0][3]) return \"SH33TJSERR2\";\n\t\t\to = XTI[1] == -1 ? \"#REF\" : (supbooks[XTI[0]][0][3][XTI[1]] || \"SH33TJSERR4\");\n\t\t\treturn XTI[1] == XTI[2] ? o : o + \":\" + supbooks[XTI[0]][0][3][XTI[2]];\n\t}\n}\nfunction get_ixti(supbooks, ixti/*:number*/, opts)/*:string*/ {\n\tvar ixtiraw = get_ixti_raw(supbooks, ixti, opts);\n\treturn ixtiraw == \"#REF\" ? ixtiraw : formula_quote_sheet_name(ixtiraw, opts);\n}\nfunction stringify_formula(formula/*Array<any>*/, range, cell/*:any*/, supbooks, opts)/*:string*/ {\n\tvar biff = (opts && opts.biff) || 8;\n\tvar _range = /*range != null ? range :*/ {s:{c:0, r:0},e:{c:0, r:0}};\n\tvar stack/*:Array<string>*/ = [], e1, e2, /*::type,*/ c/*:CellAddress*/, ixti=0, nameidx=0, r, sname=\"\";\n\tif(!formula[0] || !formula[0][0]) return \"\";\n\tvar last_sp = -1, sp = \"\";\n\tfor(var ff = 0, fflen = formula[0].length; ff < fflen; ++ff) {\n\t\tvar f = formula[0][ff];\n\t\tswitch(f[0]) {\n\t\t\tcase 'PtgUminus': /* [MS-XLS] 2.5.198.93 */\n\t\t\t\tstack.push(\"-\" + stack.pop()); break;\n\t\t\tcase 'PtgUplus': /* [MS-XLS] 2.5.198.95 */\n\t\t\t\tstack.push(\"+\" + stack.pop()); break;\n\t\t\tcase 'PtgPercent': /* [MS-XLS] 2.5.198.81 */\n\t\t\t\tstack.push(stack.pop() + \"%\"); break;\n\n\t\t\tcase 'PtgAdd':    /* [MS-XLS] 2.5.198.26 */\n\t\t\tcase 'PtgConcat': /* [MS-XLS] 2.5.198.43 */\n\t\t\tcase 'PtgDiv':    /* [MS-XLS] 2.5.198.45 */\n\t\t\tcase 'PtgEq':     /* [MS-XLS] 2.5.198.56 */\n\t\t\tcase 'PtgGe':     /* [MS-XLS] 2.5.198.64 */\n\t\t\tcase 'PtgGt':     /* [MS-XLS] 2.5.198.65 */\n\t\t\tcase 'PtgLe':     /* [MS-XLS] 2.5.198.68 */\n\t\t\tcase 'PtgLt':     /* [MS-XLS] 2.5.198.69 */\n\t\t\tcase 'PtgMul':    /* [MS-XLS] 2.5.198.75 */\n\t\t\tcase 'PtgNe':     /* [MS-XLS] 2.5.198.78 */\n\t\t\tcase 'PtgPower':  /* [MS-XLS] 2.5.198.82 */\n\t\t\tcase 'PtgSub':    /* [MS-XLS] 2.5.198.90 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tif(last_sp >= 0) {\n\t\t\t\t\tswitch(formula[0][last_sp][1][0]) {\n\t\t\t\t\t\tcase 0:\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tsp = fill(\" \", formula[0][last_sp][1][1]); break;\n\t\t\t\t\t\tcase 1:\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tsp = fill(\"\\r\", formula[0][last_sp][1][1]); break;\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tsp = \"\";\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tif(opts.WTF) throw new Error(\"Unexpected PtgAttrSpaceType \" + formula[0][last_sp][1][0]);\n\t\t\t\t\t}\n\t\t\t\t\te2 = e2 + sp;\n\t\t\t\t\tlast_sp = -1;\n\t\t\t\t}\n\t\t\t\tstack.push(e2+PtgBinOp[f[0]]+e1);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgIsect': /* [MS-XLS] 2.5.198.67 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\" \"+e1);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgUnion': /* [MS-XLS] 2.5.198.94 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\",\"+e1);\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRange': /* [MS-XLS] 2.5.198.83 */\n\t\t\t\te1 = stack.pop(); e2 = stack.pop();\n\t\t\t\tstack.push(e2+\":\"+e1);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAttrChoose': /* [MS-XLS] 2.5.198.34 */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrGoto': /* [MS-XLS] 2.5.198.35 */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrIf': /* [MS-XLS] 2.5.198.36 */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrIfError': /* [MS-XLSB] 2.5.97.28 */\n\t\t\t\tbreak;\n\n\n\t\t\tcase 'PtgRef': /* [MS-XLS] 2.5.198.84 */\n\t\t\t\t/*::type = f[1][0]; */c = shift_cell_xls((f[1][1]/*:any*/), _range, opts);\n\t\t\t\tstack.push(encode_cell_xls(c, biff));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRefN': /* [MS-XLS] 2.5.198.88 */\n\t\t\t\t/*::type = f[1][0]; */c = cell ? shift_cell_xls((f[1][1]/*:any*/), cell, opts) : (f[1][1]/*:any*/);\n\t\t\t\tstack.push(encode_cell_xls(c, biff));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgRef3d': /* [MS-XLS] 2.5.198.85 */\n\t\t\t\t/*::type = f[1][0]; */ixti = /*::Number(*/f[1][1]/*::)*/; c = shift_cell_xls((f[1][2]/*:any*/), _range, opts);\n\t\t\t\tsname = get_ixti(supbooks, ixti, opts);\n\t\t\t\tvar w = sname; /* IE9 fails on defined names */ // eslint-disable-line no-unused-vars\n\t\t\t\tstack.push(sname + \"!\" + encode_cell_xls(c, biff));\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgFunc': /* [MS-XLS] 2.5.198.62 */\n\t\t\tcase 'PtgFuncVar': /* [MS-XLS] 2.5.198.63 */\n\t\t\t\t/* f[1] = [argc, func, type] */\n\t\t\t\tvar argc/*:number*/ = (f[1][0]/*:any*/), func/*:string*/ = (f[1][1]/*:any*/);\n\t\t\t\tif(!argc) argc = 0;\n\t\t\t\targc &= 0x7F;\n\t\t\t\tvar args = argc == 0 ? [] : stack.slice(-argc);\n\t\t\t\tstack.length -= argc;\n\t\t\t\tif(func === 'User') func = args.shift();\n\t\t\t\tstack.push(func + \"(\" + args.join(\",\") + \")\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgBool': /* [MS-XLS] 2.5.198.42 */\n\t\t\t\tstack.push(f[1] ? \"TRUE\" : \"FALSE\"); break;\n\t\t\tcase 'PtgInt': /* [MS-XLS] 2.5.198.66 */\n\t\t\t\tstack.push(/*::String(*/f[1]/*::)*/); break;\n\t\t\tcase 'PtgNum': /* [MS-XLS] 2.5.198.79 TODO: precision? */\n\t\t\t\tstack.push(String(f[1])); break;\n\t\t\tcase 'PtgStr': /* [MS-XLS] 2.5.198.89 */\n\t\t\t\t// $FlowIgnore\n\t\t\t\tstack.push('\"' + f[1].replace(/\"/g, '\"\"') + '\"'); break;\n\t\t\tcase 'PtgErr': /* [MS-XLS] 2.5.198.57 */\n\t\t\t\tstack.push(/*::String(*/f[1]/*::)*/); break;\n\t\t\tcase 'PtgAreaN': /* [MS-XLS] 2.5.198.31 TODO */\n\t\t\t\t/*::type = f[1][0]; */r = shift_range_xls(f[1][1], cell ? {s:cell} : _range, opts);\n\t\t\t\tstack.push(encode_range_xls((r/*:any*/), opts));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgArea': /* [MS-XLS] 2.5.198.27 TODO: fixed points */\n\t\t\t\t/*::type = f[1][0]; */r = shift_range_xls(f[1][1], _range, opts);\n\t\t\t\tstack.push(encode_range_xls((r/*:any*/), opts));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgArea3d': /* [MS-XLS] 2.5.198.28 TODO */\n\t\t\t\t/*::type = f[1][0]; */ixti = /*::Number(*/f[1][1]/*::)*/; r = f[1][2];\n\t\t\t\tsname = get_ixti(supbooks, ixti, opts);\n\t\t\t\tstack.push(sname + \"!\" + encode_range_xls((r/*:any*/), opts));\n\t\t\t\tbreak;\n\t\t\tcase 'PtgAttrSum': /* [MS-XLS] 2.5.198.41 */\n\t\t\t\tstack.push(\"SUM(\" + stack.pop() + \")\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAttrBaxcel': /* [MS-XLS] 2.5.198.33 */\n\t\t\tcase 'PtgAttrSemi': /* [MS-XLS] 2.5.198.37 */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgName': /* [MS-XLS] 2.5.198.76 ; [MS-XLSB] 2.5.97.60 TODO: revisions */\n\t\t\t\t/* f[1] = type, 0, nameindex */\n\t\t\t\tnameidx = (f[1][2]/*:any*/);\n\t\t\t\tvar lbl = (supbooks.names||[])[nameidx-1] || (supbooks[0]||[])[nameidx];\n\t\t\t\tvar name = lbl ? lbl.Name : \"SH33TJSNAME\" + String(nameidx);\n\t\t\t\t/* [MS-XLSB] 2.5.97.10 Ftab -- last verified 20220204 */\n\t\t\t\tif(name && name.slice(0,6) == \"_xlfn.\" && !opts.xlfn) name = name.slice(6);\n\t\t\t\tstack.push(name);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgNameX': /* [MS-XLS] 2.5.198.77 ; [MS-XLSB] 2.5.97.61 TODO: revisions */\n\t\t\t\t/* f[1] = type, ixti, nameindex */\n\t\t\t\tvar bookidx/*:number*/ = (f[1][1]/*:any*/); nameidx = (f[1][2]/*:any*/); var externbook;\n\t\t\t\t/* TODO: Properly handle missing values -- this should be using get_ixti_raw primarily */\n\t\t\t\tif(opts.biff <= 5) {\n\t\t\t\t\tif(bookidx < 0) bookidx = -bookidx;\n\t\t\t\t\tif(supbooks[bookidx]) externbook = supbooks[bookidx][nameidx];\n\t\t\t\t} else {\n\t\t\t\t\tvar o = \"\";\n\t\t\t\t\tif(((supbooks[bookidx]||[])[0]||[])[0] == 0x3A01){/* empty */}\n\t\t\t\t\telse if(((supbooks[bookidx]||[])[0]||[])[0] == 0x0401){\n\t\t\t\t\t\tif(supbooks[bookidx][nameidx] && supbooks[bookidx][nameidx].itab > 0) {\n\t\t\t\t\t\t\to = supbooks.SheetNames[supbooks[bookidx][nameidx].itab-1] + \"!\";\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\telse o = supbooks.SheetNames[nameidx-1]+ \"!\";\n\t\t\t\t\tif(supbooks[bookidx] && supbooks[bookidx][nameidx]) o += supbooks[bookidx][nameidx].Name;\n\t\t\t\t\telse if(supbooks[0] && supbooks[0][nameidx]) o += supbooks[0][nameidx].Name;\n\t\t\t\t\telse {\n\t\t\t\t\t\tvar ixtidata = (get_ixti_raw(supbooks, bookidx, opts)||\"\").split(\";;\");\n\t\t\t\t\t\tif(ixtidata[nameidx - 1]) o = ixtidata[nameidx - 1]; // TODO: confirm this is correct\n\t\t\t\t\t\telse o += \"SH33TJSERRX\";\n\t\t\t\t\t}\n\t\t\t\t\tstack.push(o);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tif(!externbook) externbook = {Name: \"SH33TJSERRY\"};\n\t\t\t\tstack.push(externbook.Name);\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgParen': /* [MS-XLS] 2.5.198.80 */\n\t\t\t\tvar lp = '(', rp = ')';\n\t\t\t\tif(last_sp >= 0) {\n\t\t\t\t\tsp = \"\";\n\t\t\t\t\tswitch(formula[0][last_sp][1][0]) {\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 2: lp = fill(\" \", formula[0][last_sp][1][1]) + lp; break;\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 3: lp = fill(\"\\r\", formula[0][last_sp][1][1]) + lp; break;\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 4: rp = fill(\" \", formula[0][last_sp][1][1]) + rp; break;\n\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\tcase 5: rp = fill(\"\\r\", formula[0][last_sp][1][1]) + rp; break;\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\t\t\tif(opts.WTF) throw new Error(\"Unexpected PtgAttrSpaceType \" + formula[0][last_sp][1][0]);\n\t\t\t\t\t}\n\t\t\t\t\tlast_sp = -1;\n\t\t\t\t}\n\t\t\t\tstack.push(lp + stack.pop() + rp); break;\n\n\t\t\tcase 'PtgRefErr': /* [MS-XLS] 2.5.198.86 */\n\t\t\t\tstack.push('#REF!'); break;\n\n\t\t\tcase 'PtgRefErr3d': /* [MS-XLS] 2.5.198.87 */\n\t\t\t\tstack.push('#REF!'); break;\n\n\t\t\tcase 'PtgExp': /* [MS-XLS] 2.5.198.58 TODO */\n\t\t\t\tc = {c:(f[1][1]/*:any*/),r:(f[1][0]/*:any*/)};\n\t\t\t\tvar q = ({c: cell.c, r:cell.r}/*:any*/);\n\t\t\t\tif(supbooks.sharedf[encode_cell(c)]) {\n\t\t\t\t\tvar parsedf = (supbooks.sharedf[encode_cell(c)]);\n\t\t\t\t\tstack.push(stringify_formula(parsedf, _range, q, supbooks, opts));\n\t\t\t\t} else {\n\t\t\t\t\tvar fnd = false;\n\t\t\t\t\tfor(e1=0;e1!=supbooks.arrayf.length; ++e1) {\n\t\t\t\t\t\t/* TODO: should be something like range_has */\n\t\t\t\t\t\te2 = supbooks.arrayf[e1];\n\t\t\t\t\t\tif(c.c < e2[0].s.c || c.c > e2[0].e.c) continue;\n\t\t\t\t\t\tif(c.r < e2[0].s.r || c.r > e2[0].e.r) continue;\n\t\t\t\t\t\tstack.push(stringify_formula(e2[1], _range, q, supbooks, opts));\n\t\t\t\t\t\tfnd = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tif(!fnd) stack.push(/*::String(*/f[1]/*::)*/);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgArray': /* [MS-XLS] 2.5.198.32 TODO */\n\t\t\t\tstack.push(\"{\" + stringify_array(/*::(*/f[1]/*:: :any)*/) + \"}\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemArea': /* [MS-XLS] 2.5.198.70 TODO: confirm this is a non-display */\n\t\t\t\t//stack.push(\"(\" + f[2].map(encode_range).join(\",\") + \")\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAttrSpace': /* [MS-XLS] 2.5.198.38 */\n\t\t\tcase 'PtgAttrSpaceSemi': /* [MS-XLS] 2.5.198.39 */\n\t\t\t\tlast_sp = ff;\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgTbl': /* [MS-XLS] 2.5.198.92 TODO */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemErr': /* [MS-XLS] 2.5.198.71 */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMissArg': /* [MS-XLS] 2.5.198.74 */\n\t\t\t\tstack.push(\"\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgAreaErr': /* [MS-XLS] 2.5.198.29 */\n\t\t\t\tstack.push(\"#REF!\"); break;\n\n\t\t\tcase 'PtgAreaErr3d': /* [MS-XLS] 2.5.198.30 */\n\t\t\t\tstack.push(\"#REF!\"); break;\n\n\t\t\tcase 'PtgList': /* [MS-XLSB] 2.5.97.52 */\n\t\t\t\t// $FlowIgnore\n\t\t\t\tstack.push(\"Table\" + f[1].idx + \"[#\" + f[1].rt + \"]\");\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemAreaN':\n\t\t\tcase 'PtgMemNoMemN':\n\t\t\tcase 'PtgAttrNoop':\n\t\t\tcase 'PtgSheet':\n\t\t\tcase 'PtgEndSheet':\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgMemFunc': /* [MS-XLS] 2.5.198.72 TODO */\n\t\t\t\tbreak;\n\t\t\tcase 'PtgMemNoMem': /* [MS-XLS] 2.5.198.73 TODO */\n\t\t\t\tbreak;\n\n\t\t\tcase 'PtgElfCol': /* [MS-XLS] 2.5.198.46 */\n\t\t\tcase 'PtgElfColS': /* [MS-XLS] 2.5.198.47 */\n\t\t\tcase 'PtgElfColSV': /* [MS-XLS] 2.5.198.48 */\n\t\t\tcase 'PtgElfColV': /* [MS-XLS] 2.5.198.49 */\n\t\t\tcase 'PtgElfLel': /* [MS-XLS] 2.5.198.50 */\n\t\t\tcase 'PtgElfRadical': /* [MS-XLS] 2.5.198.51 */\n\t\t\tcase 'PtgElfRadicalLel': /* [MS-XLS] 2.5.198.52 */\n\t\t\tcase 'PtgElfRadicalS': /* [MS-XLS] 2.5.198.53 */\n\t\t\tcase 'PtgElfRw': /* [MS-XLS] 2.5.198.54 */\n\t\t\tcase 'PtgElfRwV': /* [MS-XLS] 2.5.198.55 */\n\t\t\t\tthrow new Error(\"Unsupported ELFs\");\n\n\t\t\tcase 'PtgSxName': /* [MS-XLS] 2.5.198.91 TODO -- find a test case */\n\t\t\t\tthrow new Error('Unrecognized Formula Token: ' + String(f));\n\t\t\tdefault: throw new Error('Unrecognized Formula Token: ' + String(f));\n\t\t}\n\t\tvar PtgNonDisp = ['PtgAttrSpace', 'PtgAttrSpaceSemi', 'PtgAttrGoto'];\n\t\tif(opts.biff != 3) if(last_sp >= 0 && PtgNonDisp.indexOf(formula[0][ff][0]) == -1) {\n\t\t\tf = formula[0][last_sp];\n\t\t\tvar _left = true;\n\t\t\tswitch(f[1][0]) {\n\t\t\t\t/* note: some bad XLSB files omit the PtgParen */\n\t\t\t\tcase 4: _left = false;\n\t\t\t\t/* falls through */\n\t\t\t\tcase 0:\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tsp = fill(\" \", f[1][1]); break;\n\t\t\t\tcase 5: _left = false;\n\t\t\t\t/* falls through */\n\t\t\t\tcase 1:\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tsp = fill(\"\\r\", f[1][1]); break;\n\t\t\t\tdefault:\n\t\t\t\t\tsp = \"\";\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tif(opts.WTF) throw new Error(\"Unexpected PtgAttrSpaceType \" + f[1][0]);\n\t\t\t}\n\t\t\tstack.push((_left ? sp : \"\") + stack.pop() + (_left ? \"\" : sp));\n\t\t\tlast_sp = -1;\n\t\t}\n\t}\n\tif(stack.length > 1 && opts.WTF) throw new Error(\"bad formula stack\");\n\treturn stack[0];\n}\n\n/* [MS-XLS] 2.5.198.1 TODO */\nfunction parse_ArrayParsedFormula(blob, length, opts/*::, ref*/) {\n\tvar target = blob.l + length, len = opts.biff == 2 ? 1 : 2;\n\tvar rgcb, cce = blob.read_shift(len); // length of rgce\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tif(length !== cce + len) rgcb = parse_RgbExtra(blob, length - cce - len, rgce, opts);\n\tblob.l = target;\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.198.3 TODO */\nfunction parse_XLSCellParsedFormula(blob, length, opts) {\n\tvar target = blob.l + length, len = opts.biff == 2 ? 1 : 2;\n\tvar rgcb, cce = blob.read_shift(len); // length of rgce\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tif(length !== cce + len) rgcb = parse_RgbExtra(blob, length - cce - len, rgce, opts);\n\tblob.l = target;\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.198.21 */\nfunction parse_NameParsedFormula(blob, length, opts, cce) {\n\tvar target = blob.l + length;\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tvar rgcb;\n\tif(target !== blob.l) rgcb = parse_RgbExtra(blob, target - blob.l, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.198.118 TODO */\nfunction parse_SharedParsedFormula(blob, length, opts) {\n\tvar target = blob.l + length;\n\tvar rgcb, cce = blob.read_shift(2); // length of rgce\n\tvar rgce = parse_Rgce(blob, cce, opts);\n\tif(cce == 0xFFFF) return [[],parsenoop(blob, length-2)];\n\tif(length !== cce + 2) rgcb = parse_RgbExtra(blob, target - cce - 2, rgce, opts);\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLS] 2.5.133 TODO: how to emit empty strings? */\nfunction parse_FormulaValue(blob/*::, length*/) {\n\tvar b;\n\tif(__readUInt16LE(blob,blob.l + 6) !== 0xFFFF) return [parse_Xnum(blob),'n'];\n\tswitch(blob[blob.l]) {\n\t\tcase 0x00: blob.l += 8; return [\"String\", 's'];\n\t\tcase 0x01: b = blob[blob.l+2] === 0x1; blob.l += 8; return [b,'b'];\n\t\tcase 0x02: b = blob[blob.l+2]; blob.l += 8; return [b,'e'];\n\t\tcase 0x03: blob.l += 8; return [\"\",'s'];\n\t}\n\treturn [];\n}\nfunction write_FormulaValue(value) {\n\tif(value == null) {\n\t\t// Blank String Value\n\t\tvar o = new_buf(8);\n\t\to.write_shift(1, 0x03);\n\t\to.write_shift(1, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0);\n\t\to.write_shift(2, 0xFFFF);\n\t\treturn o;\n\t} else if(typeof value == \"number\") return write_Xnum(value);\n\treturn write_Xnum(0);\n}\n\n/* [MS-XLS] 2.4.127 TODO */\nfunction parse_Formula(blob, length, opts) {\n\tvar end = blob.l + length;\n\tvar cell = parse_XLSCell(blob, 6);\n\tif(opts.biff == 2) ++blob.l;\n\tvar val = parse_FormulaValue(blob,8);\n\tvar flags = blob.read_shift(1);\n\tif(opts.biff != 2) {\n\t\tblob.read_shift(1);\n\t\tif(opts.biff >= 5) {\n\t\t\t/*var chn = */blob.read_shift(4);\n\t\t}\n\t}\n\tvar cbf = parse_XLSCellParsedFormula(blob, end - blob.l, opts);\n\treturn {cell:cell, val:val[0], formula:cbf, shared: (flags >> 3) & 1, tt:val[1]};\n}\nfunction write_Formula(cell/*:Cell*/, R/*:number*/, C/*:number*/, opts, os/*:number*/) {\n\t// Cell\n\tvar o1 = write_XLSCell(R, C, os);\n\n\t// FormulaValue\n\tvar o2 = write_FormulaValue(cell.v);\n\n\t// flags + cache\n\tvar o3 = new_buf(6);\n\tvar flags = 0x01 | 0x20;\n\to3.write_shift(2, flags);\n\to3.write_shift(4, 0);\n\n\t// CellParsedFormula\n\tvar bf = new_buf(cell.bf.length);\n\tfor(var i = 0; i < cell.bf.length; ++i) bf[i] = cell.bf[i];\n\n\tvar out = bconcat([o1, o2, o3, bf]);\n\treturn out;\n}\n\n\n/* XLSB Parsed Formula records have the same shape */\nfunction parse_XLSBParsedFormula(data, length, opts) {\n\tvar cce = data.read_shift(4);\n\tvar rgce = parse_Rgce(data, cce, opts);\n\tvar cb = data.read_shift(4);\n\tvar rgcb = cb > 0 ? parse_RgbExtra(data, cb, rgce, opts) : null;\n\treturn [rgce, rgcb];\n}\n\n/* [MS-XLSB] 2.5.97.1 ArrayParsedFormula */\nvar parse_XLSBArrayParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.4 CellParsedFormula */\nvar parse_XLSBCellParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.8 DVParsedFormula */\n//var parse_XLSBDVParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.9 FRTParsedFormula */\n//var parse_XLSBFRTParsedFormula = parse_XLSBParsedFormula2;\n/* [MS-XLSB] 2.5.97.12 NameParsedFormula */\nvar parse_XLSBNameParsedFormula = parse_XLSBParsedFormula;\n/* [MS-XLSB] 2.5.97.98 SharedParsedFormula */\nvar parse_XLSBSharedParsedFormula = parse_XLSBParsedFormula;\nvar Cetab = {\n  0: \"BEEP\",\n  1: \"OPEN\",\n  2: \"OPEN.LINKS\",\n  3: \"CLOSE.ALL\",\n  4: \"SAVE\",\n  5: \"SAVE.AS\",\n  6: \"FILE.DELETE\",\n  7: \"PAGE.SETUP\",\n  8: \"PRINT\",\n  9: \"PRINTER.SETUP\",\n  10: \"QUIT\",\n  11: \"NEW.WINDOW\",\n  12: \"ARRANGE.ALL\",\n  13: \"WINDOW.SIZE\",\n  14: \"WINDOW.MOVE\",\n  15: \"FULL\",\n  16: \"CLOSE\",\n  17: \"RUN\",\n  22: \"SET.PRINT.AREA\",\n  23: \"SET.PRINT.TITLES\",\n  24: \"SET.PAGE.BREAK\",\n  25: \"REMOVE.PAGE.BREAK\",\n  26: \"FONT\",\n  27: \"DISPLAY\",\n  28: \"PROTECT.DOCUMENT\",\n  29: \"PRECISION\",\n  30: \"A1.R1C1\",\n  31: \"CALCULATE.NOW\",\n  32: \"CALCULATION\",\n  34: \"DATA.FIND\",\n  35: \"EXTRACT\",\n  36: \"DATA.DELETE\",\n  37: \"SET.DATABASE\",\n  38: \"SET.CRITERIA\",\n  39: \"SORT\",\n  40: \"DATA.SERIES\",\n  41: \"TABLE\",\n  42: \"FORMAT.NUMBER\",\n  43: \"ALIGNMENT\",\n  44: \"STYLE\",\n  45: \"BORDER\",\n  46: \"CELL.PROTECTION\",\n  47: \"COLUMN.WIDTH\",\n  48: \"UNDO\",\n  49: \"CUT\",\n  50: \"COPY\",\n  51: \"PASTE\",\n  52: \"CLEAR\",\n  53: \"PASTE.SPECIAL\",\n  54: \"EDIT.DELETE\",\n  55: \"INSERT\",\n  56: \"FILL.RIGHT\",\n  57: \"FILL.DOWN\",\n  61: \"DEFINE.NAME\",\n  62: \"CREATE.NAMES\",\n  63: \"FORMULA.GOTO\",\n  64: \"FORMULA.FIND\",\n  65: \"SELECT.LAST.CELL\",\n  66: \"SHOW.ACTIVE.CELL\",\n  67: \"GALLERY.AREA\",\n  68: \"GALLERY.BAR\",\n  69: \"GALLERY.COLUMN\",\n  70: \"GALLERY.LINE\",\n  71: \"GALLERY.PIE\",\n  72: \"GALLERY.SCATTER\",\n  73: \"COMBINATION\",\n  74: \"PREFERRED\",\n  75: \"ADD.OVERLAY\",\n  76: \"GRIDLINES\",\n  77: \"SET.PREFERRED\",\n  78: \"AXES\",\n  79: \"LEGEND\",\n  80: \"ATTACH.TEXT\",\n  81: \"ADD.ARROW\",\n  82: \"SELECT.CHART\",\n  83: \"SELECT.PLOT.AREA\",\n  84: \"PATTERNS\",\n  85: \"MAIN.CHART\",\n  86: \"OVERLAY\",\n  87: \"SCALE\",\n  88: \"FORMAT.LEGEND\",\n  89: \"FORMAT.TEXT\",\n  90: \"EDIT.REPEAT\",\n  91: \"PARSE\",\n  92: \"JUSTIFY\",\n  93: \"HIDE\",\n  94: \"UNHIDE\",\n  95: \"WORKSPACE\",\n  96: \"FORMULA\",\n  97: \"FORMULA.FILL\",\n  98: \"FORMULA.ARRAY\",\n  99: \"DATA.FIND.NEXT\",\n  100: \"DATA.FIND.PREV\",\n  101: \"FORMULA.FIND.NEXT\",\n  102: \"FORMULA.FIND.PREV\",\n  103: \"ACTIVATE\",\n  104: \"ACTIVATE.NEXT\",\n  105: \"ACTIVATE.PREV\",\n  106: \"UNLOCKED.NEXT\",\n  107: \"UNLOCKED.PREV\",\n  108: \"COPY.PICTURE\",\n  109: \"SELECT\",\n  110: \"DELETE.NAME\",\n  111: \"DELETE.FORMAT\",\n  112: \"VLINE\",\n  113: \"HLINE\",\n  114: \"VPAGE\",\n  115: \"HPAGE\",\n  116: \"VSCROLL\",\n  117: \"HSCROLL\",\n  118: \"ALERT\",\n  119: \"NEW\",\n  120: \"CANCEL.COPY\",\n  121: \"SHOW.CLIPBOARD\",\n  122: \"MESSAGE\",\n  124: \"PASTE.LINK\",\n  125: \"APP.ACTIVATE\",\n  126: \"DELETE.ARROW\",\n  127: \"ROW.HEIGHT\",\n  128: \"FORMAT.MOVE\",\n  129: \"FORMAT.SIZE\",\n  130: \"FORMULA.REPLACE\",\n  131: \"SEND.KEYS\",\n  132: \"SELECT.SPECIAL\",\n  133: \"APPLY.NAMES\",\n  134: \"REPLACE.FONT\",\n  135: \"FREEZE.PANES\",\n  136: \"SHOW.INFO\",\n  137: \"SPLIT\",\n  138: \"ON.WINDOW\",\n  139: \"ON.DATA\",\n  140: \"DISABLE.INPUT\",\n  142: \"OUTLINE\",\n  143: \"LIST.NAMES\",\n  144: \"FILE.CLOSE\",\n  145: \"SAVE.WORKBOOK\",\n  146: \"DATA.FORM\",\n  147: \"COPY.CHART\",\n  148: \"ON.TIME\",\n  149: \"WAIT\",\n  150: \"FORMAT.FONT\",\n  151: \"FILL.UP\",\n  152: \"FILL.LEFT\",\n  153: \"DELETE.OVERLAY\",\n  155: \"SHORT.MENUS\",\n  159: \"SET.UPDATE.STATUS\",\n  161: \"COLOR.PALETTE\",\n  162: \"DELETE.STYLE\",\n  163: \"WINDOW.RESTORE\",\n  164: \"WINDOW.MAXIMIZE\",\n  166: \"CHANGE.LINK\",\n  167: \"CALCULATE.DOCUMENT\",\n  168: \"ON.KEY\",\n  169: \"APP.RESTORE\",\n  170: \"APP.MOVE\",\n  171: \"APP.SIZE\",\n  172: \"APP.MINIMIZE\",\n  173: \"APP.MAXIMIZE\",\n  174: \"BRING.TO.FRONT\",\n  175: \"SEND.TO.BACK\",\n  185: \"MAIN.CHART.TYPE\",\n  186: \"OVERLAY.CHART.TYPE\",\n  187: \"SELECT.END\",\n  188: \"OPEN.MAIL\",\n  189: \"SEND.MAIL\",\n  190: \"STANDARD.FONT\",\n  191: \"CONSOLIDATE\",\n  192: \"SORT.SPECIAL\",\n  193: \"GALLERY.3D.AREA\",\n  194: \"GALLERY.3D.COLUMN\",\n  195: \"GALLERY.3D.LINE\",\n  196: \"GALLERY.3D.PIE\",\n  197: \"VIEW.3D\",\n  198: \"GOAL.SEEK\",\n  199: \"WORKGROUP\",\n  200: \"FILL.GROUP\",\n  201: \"UPDATE.LINK\",\n  202: \"PROMOTE\",\n  203: \"DEMOTE\",\n  204: \"SHOW.DETAIL\",\n  206: \"UNGROUP\",\n  207: \"OBJECT.PROPERTIES\",\n  208: \"SAVE.NEW.OBJECT\",\n  209: \"SHARE\",\n  210: \"SHARE.NAME\",\n  211: \"DUPLICATE\",\n  212: \"APPLY.STYLE\",\n  213: \"ASSIGN.TO.OBJECT\",\n  214: \"OBJECT.PROTECTION\",\n  215: \"HIDE.OBJECT\",\n  216: \"SET.EXTRACT\",\n  217: \"CREATE.PUBLISHER\",\n  218: \"SUBSCRIBE.TO\",\n  219: \"ATTRIBUTES\",\n  220: \"SHOW.TOOLBAR\",\n  222: \"PRINT.PREVIEW\",\n  223: \"EDIT.COLOR\",\n  224: \"SHOW.LEVELS\",\n  225: \"FORMAT.MAIN\",\n  226: \"FORMAT.OVERLAY\",\n  227: \"ON.RECALC\",\n  228: \"EDIT.SERIES\",\n  229: \"DEFINE.STYLE\",\n  240: \"LINE.PRINT\",\n  243: \"ENTER.DATA\",\n  249: \"GALLERY.RADAR\",\n  250: \"MERGE.STYLES\",\n  251: \"EDITION.OPTIONS\",\n  252: \"PASTE.PICTURE\",\n  253: \"PASTE.PICTURE.LINK\",\n  254: \"SPELLING\",\n  256: \"ZOOM\",\n  259: \"INSERT.OBJECT\",\n  260: \"WINDOW.MINIMIZE\",\n  265: \"SOUND.NOTE\",\n  266: \"SOUND.PLAY\",\n  267: \"FORMAT.SHAPE\",\n  268: \"EXTEND.POLYGON\",\n  269: \"FORMAT.AUTO\",\n  272: \"GALLERY.3D.BAR\",\n  273: \"GALLERY.3D.SURFACE\",\n  274: \"FILL.AUTO\",\n  276: \"CUSTOMIZE.TOOLBAR\",\n  277: \"ADD.TOOL\",\n  278: \"EDIT.OBJECT\",\n  279: \"ON.DOUBLECLICK\",\n  280: \"ON.ENTRY\",\n  281: \"WORKBOOK.ADD\",\n  282: \"WORKBOOK.MOVE\",\n  283: \"WORKBOOK.COPY\",\n  284: \"WORKBOOK.OPTIONS\",\n  285: \"SAVE.WORKSPACE\",\n  288: \"CHART.WIZARD\",\n  289: \"DELETE.TOOL\",\n  290: \"MOVE.TOOL\",\n  291: \"WORKBOOK.SELECT\",\n  292: \"WORKBOOK.ACTIVATE\",\n  293: \"ASSIGN.TO.TOOL\",\n  295: \"COPY.TOOL\",\n  296: \"RESET.TOOL\",\n  297: \"CONSTRAIN.NUMERIC\",\n  298: \"PASTE.TOOL\",\n  302: \"WORKBOOK.NEW\",\n  305: \"SCENARIO.CELLS\",\n  306: \"SCENARIO.DELETE\",\n  307: \"SCENARIO.ADD\",\n  308: \"SCENARIO.EDIT\",\n  309: \"SCENARIO.SHOW\",\n  310: \"SCENARIO.SHOW.NEXT\",\n  311: \"SCENARIO.SUMMARY\",\n  312: \"PIVOT.TABLE.WIZARD\",\n  313: \"PIVOT.FIELD.PROPERTIES\",\n  314: \"PIVOT.FIELD\",\n  315: \"PIVOT.ITEM\",\n  316: \"PIVOT.ADD.FIELDS\",\n  318: \"OPTIONS.CALCULATION\",\n  319: \"OPTIONS.EDIT\",\n  320: \"OPTIONS.VIEW\",\n  321: \"ADDIN.MANAGER\",\n  322: \"MENU.EDITOR\",\n  323: \"ATTACH.TOOLBARS\",\n  324: \"VBAActivate\",\n  325: \"OPTIONS.CHART\",\n  328: \"VBA.INSERT.FILE\",\n  330: \"VBA.PROCEDURE.DEFINITION\",\n  336: \"ROUTING.SLIP\",\n  338: \"ROUTE.DOCUMENT\",\n  339: \"MAIL.LOGON\",\n  342: \"INSERT.PICTURE\",\n  343: \"EDIT.TOOL\",\n  344: \"GALLERY.DOUGHNUT\",\n  350: \"CHART.TREND\",\n  352: \"PIVOT.ITEM.PROPERTIES\",\n  354: \"WORKBOOK.INSERT\",\n  355: \"OPTIONS.TRANSITION\",\n  356: \"OPTIONS.GENERAL\",\n  370: \"FILTER.ADVANCED\",\n  373: \"MAIL.ADD.MAILER\",\n  374: \"MAIL.DELETE.MAILER\",\n  375: \"MAIL.REPLY\",\n  376: \"MAIL.REPLY.ALL\",\n  377: \"MAIL.FORWARD\",\n  378: \"MAIL.NEXT.LETTER\",\n  379: \"DATA.LABEL\",\n  380: \"INSERT.TITLE\",\n  381: \"FONT.PROPERTIES\",\n  382: \"MACRO.OPTIONS\",\n  383: \"WORKBOOK.HIDE\",\n  384: \"WORKBOOK.UNHIDE\",\n  385: \"WORKBOOK.DELETE\",\n  386: \"WORKBOOK.NAME\",\n  388: \"GALLERY.CUSTOM\",\n  390: \"ADD.CHART.AUTOFORMAT\",\n  391: \"DELETE.CHART.AUTOFORMAT\",\n  392: \"CHART.ADD.DATA\",\n  393: \"AUTO.OUTLINE\",\n  394: \"TAB.ORDER\",\n  395: \"SHOW.DIALOG\",\n  396: \"SELECT.ALL\",\n  397: \"UNGROUP.SHEETS\",\n  398: \"SUBTOTAL.CREATE\",\n  399: \"SUBTOTAL.REMOVE\",\n  400: \"RENAME.OBJECT\",\n  412: \"WORKBOOK.SCROLL\",\n  413: \"WORKBOOK.NEXT\",\n  414: \"WORKBOOK.PREV\",\n  415: \"WORKBOOK.TAB.SPLIT\",\n  416: \"FULL.SCREEN\",\n  417: \"WORKBOOK.PROTECT\",\n  420: \"SCROLLBAR.PROPERTIES\",\n  421: \"PIVOT.SHOW.PAGES\",\n  422: \"TEXT.TO.COLUMNS\",\n  423: \"FORMAT.CHARTTYPE\",\n  424: \"LINK.FORMAT\",\n  425: \"TRACER.DISPLAY\",\n  430: \"TRACER.NAVIGATE\",\n  431: \"TRACER.CLEAR\",\n  432: \"TRACER.ERROR\",\n  433: \"PIVOT.FIELD.GROUP\",\n  434: \"PIVOT.FIELD.UNGROUP\",\n  435: \"CHECKBOX.PROPERTIES\",\n  436: \"LABEL.PROPERTIES\",\n  437: \"LISTBOX.PROPERTIES\",\n  438: \"EDITBOX.PROPERTIES\",\n  439: \"PIVOT.REFRESH\",\n  440: \"LINK.COMBO\",\n  441: \"OPEN.TEXT\",\n  442: \"HIDE.DIALOG\",\n  443: \"SET.DIALOG.FOCUS\",\n  444: \"ENABLE.OBJECT\",\n  445: \"PUSHBUTTON.PROPERTIES\",\n  446: \"SET.DIALOG.DEFAULT\",\n  447: \"FILTER\",\n  448: \"FILTER.SHOW.ALL\",\n  449: \"CLEAR.OUTLINE\",\n  450: \"FUNCTION.WIZARD\",\n  451: \"ADD.LIST.ITEM\",\n  452: \"SET.LIST.ITEM\",\n  453: \"REMOVE.LIST.ITEM\",\n  454: \"SELECT.LIST.ITEM\",\n  455: \"SET.CONTROL.VALUE\",\n  456: \"SAVE.COPY.AS\",\n  458: \"OPTIONS.LISTS.ADD\",\n  459: \"OPTIONS.LISTS.DELETE\",\n  460: \"SERIES.AXES\",\n  461: \"SERIES.X\",\n  462: \"SERIES.Y\",\n  463: \"ERRORBAR.X\",\n  464: \"ERRORBAR.Y\",\n  465: \"FORMAT.CHART\",\n  466: \"SERIES.ORDER\",\n  467: \"MAIL.LOGOFF\",\n  468: \"CLEAR.ROUTING.SLIP\",\n  469: \"APP.ACTIVATE.MICROSOFT\",\n  470: \"MAIL.EDIT.MAILER\",\n  471: \"ON.SHEET\",\n  472: \"STANDARD.WIDTH\",\n  473: \"SCENARIO.MERGE\",\n  474: \"SUMMARY.INFO\",\n  475: \"FIND.FILE\",\n  476: \"ACTIVE.CELL.FONT\",\n  477: \"ENABLE.TIPWIZARD\",\n  478: \"VBA.MAKE.ADDIN\",\n  480: \"INSERTDATATABLE\",\n  481: \"WORKGROUP.OPTIONS\",\n  482: \"MAIL.SEND.MAILER\",\n  485: \"AUTOCORRECT\",\n  489: \"POST.DOCUMENT\",\n  491: \"PICKLIST\",\n  493: \"VIEW.SHOW\",\n  494: \"VIEW.DEFINE\",\n  495: \"VIEW.DELETE\",\n  509: \"SHEET.BACKGROUND\",\n  510: \"INSERT.MAP.OBJECT\",\n  511: \"OPTIONS.MENONO\",\n  517: \"MSOCHECKS\",\n  518: \"NORMAL\",\n  519: \"LAYOUT\",\n  520: \"RM.PRINT.AREA\",\n  521: \"CLEAR.PRINT.AREA\",\n  522: \"ADD.PRINT.AREA\",\n  523: \"MOVE.BRK\",\n  545: \"HIDECURR.NOTE\",\n  546: \"HIDEALL.NOTES\",\n  547: \"DELETE.NOTE\",\n  548: \"TRAVERSE.NOTES\",\n  549: \"ACTIVATE.NOTES\",\n  620: \"PROTECT.REVISIONS\",\n  621: \"UNPROTECT.REVISIONS\",\n  647: \"OPTIONS.ME\",\n  653: \"WEB.PUBLISH\",\n  667: \"NEWWEBQUERY\",\n  673: \"PIVOT.TABLE.CHART\",\n  753: \"OPTIONS.SAVE\",\n  755: \"OPTIONS.SPELL\",\n  808: \"HIDEALL.INKANNOTS\"\n};\nvar Ftab = {\n  0: \"COUNT\",\n  1: \"IF\",\n  2: \"ISNA\",\n  3: \"ISERROR\",\n  4: \"SUM\",\n  5: \"AVERAGE\",\n  6: \"MIN\",\n  7: \"MAX\",\n  8: \"ROW\",\n  9: \"COLUMN\",\n  10: \"NA\",\n  11: \"NPV\",\n  12: \"STDEV\",\n  13: \"DOLLAR\",\n  14: \"FIXED\",\n  15: \"SIN\",\n  16: \"COS\",\n  17: \"TAN\",\n  18: \"ATAN\",\n  19: \"PI\",\n  20: \"SQRT\",\n  21: \"EXP\",\n  22: \"LN\",\n  23: \"LOG10\",\n  24: \"ABS\",\n  25: \"INT\",\n  26: \"SIGN\",\n  27: \"ROUND\",\n  28: \"LOOKUP\",\n  29: \"INDEX\",\n  30: \"REPT\",\n  31: \"MID\",\n  32: \"LEN\",\n  33: \"VALUE\",\n  34: \"TRUE\",\n  35: \"FALSE\",\n  36: \"AND\",\n  37: \"OR\",\n  38: \"NOT\",\n  39: \"MOD\",\n  40: \"DCOUNT\",\n  41: \"DSUM\",\n  42: \"DAVERAGE\",\n  43: \"DMIN\",\n  44: \"DMAX\",\n  45: \"DSTDEV\",\n  46: \"VAR\",\n  47: \"DVAR\",\n  48: \"TEXT\",\n  49: \"LINEST\",\n  50: \"TREND\",\n  51: \"LOGEST\",\n  52: \"GROWTH\",\n  53: \"GOTO\",\n  54: \"HALT\",\n  55: \"RETURN\",\n  56: \"PV\",\n  57: \"FV\",\n  58: \"NPER\",\n  59: \"PMT\",\n  60: \"RATE\",\n  61: \"MIRR\",\n  62: \"IRR\",\n  63: \"RAND\",\n  64: \"MATCH\",\n  65: \"DATE\",\n  66: \"TIME\",\n  67: \"DAY\",\n  68: \"MONTH\",\n  69: \"YEAR\",\n  70: \"WEEKDAY\",\n  71: \"HOUR\",\n  72: \"MINUTE\",\n  73: \"SECOND\",\n  74: \"NOW\",\n  75: \"AREAS\",\n  76: \"ROWS\",\n  77: \"COLUMNS\",\n  78: \"OFFSET\",\n  79: \"ABSREF\",\n  80: \"RELREF\",\n  81: \"ARGUMENT\",\n  82: \"SEARCH\",\n  83: \"TRANSPOSE\",\n  84: \"ERROR\",\n  85: \"STEP\",\n  86: \"TYPE\",\n  87: \"ECHO\",\n  88: \"SET.NAME\",\n  89: \"CALLER\",\n  90: \"DEREF\",\n  91: \"WINDOWS\",\n  92: \"SERIES\",\n  93: \"DOCUMENTS\",\n  94: \"ACTIVE.CELL\",\n  95: \"SELECTION\",\n  96: \"RESULT\",\n  97: \"ATAN2\",\n  98: \"ASIN\",\n  99: \"ACOS\",\n  100: \"CHOOSE\",\n  101: \"HLOOKUP\",\n  102: \"VLOOKUP\",\n  103: \"LINKS\",\n  104: \"INPUT\",\n  105: \"ISREF\",\n  106: \"GET.FORMULA\",\n  107: \"GET.NAME\",\n  108: \"SET.VALUE\",\n  109: \"LOG\",\n  110: \"EXEC\",\n  111: \"CHAR\",\n  112: \"LOWER\",\n  113: \"UPPER\",\n  114: \"PROPER\",\n  115: \"LEFT\",\n  116: \"RIGHT\",\n  117: \"EXACT\",\n  118: \"TRIM\",\n  119: \"REPLACE\",\n  120: \"SUBSTITUTE\",\n  121: \"CODE\",\n  122: \"NAMES\",\n  123: \"DIRECTORY\",\n  124: \"FIND\",\n  125: \"CELL\",\n  126: \"ISERR\",\n  127: \"ISTEXT\",\n  128: \"ISNUMBER\",\n  129: \"ISBLANK\",\n  130: \"T\",\n  131: \"N\",\n  132: \"FOPEN\",\n  133: \"FCLOSE\",\n  134: \"FSIZE\",\n  135: \"FREADLN\",\n  136: \"FREAD\",\n  137: \"FWRITELN\",\n  138: \"FWRITE\",\n  139: \"FPOS\",\n  140: \"DATEVALUE\",\n  141: \"TIMEVALUE\",\n  142: \"SLN\",\n  143: \"SYD\",\n  144: \"DDB\",\n  145: \"GET.DEF\",\n  146: \"REFTEXT\",\n  147: \"TEXTREF\",\n  148: \"INDIRECT\",\n  149: \"REGISTER\",\n  150: \"CALL\",\n  151: \"ADD.BAR\",\n  152: \"ADD.MENU\",\n  153: \"ADD.COMMAND\",\n  154: \"ENABLE.COMMAND\",\n  155: \"CHECK.COMMAND\",\n  156: \"RENAME.COMMAND\",\n  157: \"SHOW.BAR\",\n  158: \"DELETE.MENU\",\n  159: \"DELETE.COMMAND\",\n  160: \"GET.CHART.ITEM\",\n  161: \"DIALOG.BOX\",\n  162: \"CLEAN\",\n  163: \"MDETERM\",\n  164: \"MINVERSE\",\n  165: \"MMULT\",\n  166: \"FILES\",\n  167: \"IPMT\",\n  168: \"PPMT\",\n  169: \"COUNTA\",\n  170: \"CANCEL.KEY\",\n  171: \"FOR\",\n  172: \"WHILE\",\n  173: \"BREAK\",\n  174: \"NEXT\",\n  175: \"INITIATE\",\n  176: \"REQUEST\",\n  177: \"POKE\",\n  178: \"EXECUTE\",\n  179: \"TERMINATE\",\n  180: \"RESTART\",\n  181: \"HELP\",\n  182: \"GET.BAR\",\n  183: \"PRODUCT\",\n  184: \"FACT\",\n  185: \"GET.CELL\",\n  186: \"GET.WORKSPACE\",\n  187: \"GET.WINDOW\",\n  188: \"GET.DOCUMENT\",\n  189: \"DPRODUCT\",\n  190: \"ISNONTEXT\",\n  191: \"GET.NOTE\",\n  192: \"NOTE\",\n  193: \"STDEVP\",\n  194: \"VARP\",\n  195: \"DSTDEVP\",\n  196: \"DVARP\",\n  197: \"TRUNC\",\n  198: \"ISLOGICAL\",\n  199: \"DCOUNTA\",\n  200: \"DELETE.BAR\",\n  201: \"UNREGISTER\",\n  204: \"USDOLLAR\",\n  205: \"FINDB\",\n  206: \"SEARCHB\",\n  207: \"REPLACEB\",\n  208: \"LEFTB\",\n  209: \"RIGHTB\",\n  210: \"MIDB\",\n  211: \"LENB\",\n  212: \"ROUNDUP\",\n  213: \"ROUNDDOWN\",\n  214: \"ASC\",\n  215: \"DBCS\",\n  216: \"RANK\",\n  219: \"ADDRESS\",\n  220: \"DAYS360\",\n  221: \"TODAY\",\n  222: \"VDB\",\n  223: \"ELSE\",\n  224: \"ELSE.IF\",\n  225: \"END.IF\",\n  226: \"FOR.CELL\",\n  227: \"MEDIAN\",\n  228: \"SUMPRODUCT\",\n  229: \"SINH\",\n  230: \"COSH\",\n  231: \"TANH\",\n  232: \"ASINH\",\n  233: \"ACOSH\",\n  234: \"ATANH\",\n  235: \"DGET\",\n  236: \"CREATE.OBJECT\",\n  237: \"VOLATILE\",\n  238: \"LAST.ERROR\",\n  239: \"CUSTOM.UNDO\",\n  240: \"CUSTOM.REPEAT\",\n  241: \"FORMULA.CONVERT\",\n  242: \"GET.LINK.INFO\",\n  243: \"TEXT.BOX\",\n  244: \"INFO\",\n  245: \"GROUP\",\n  246: \"GET.OBJECT\",\n  247: \"DB\",\n  248: \"PAUSE\",\n  251: \"RESUME\",\n  252: \"FREQUENCY\",\n  253: \"ADD.TOOLBAR\",\n  254: \"DELETE.TOOLBAR\",\n  255: \"User\",\n  256: \"RESET.TOOLBAR\",\n  257: \"EVALUATE\",\n  258: \"GET.TOOLBAR\",\n  259: \"GET.TOOL\",\n  260: \"SPELLING.CHECK\",\n  261: \"ERROR.TYPE\",\n  262: \"APP.TITLE\",\n  263: \"WINDOW.TITLE\",\n  264: \"SAVE.TOOLBAR\",\n  265: \"ENABLE.TOOL\",\n  266: \"PRESS.TOOL\",\n  267: \"REGISTER.ID\",\n  268: \"GET.WORKBOOK\",\n  269: \"AVEDEV\",\n  270: \"BETADIST\",\n  271: \"GAMMALN\",\n  272: \"BETAINV\",\n  273: \"BINOMDIST\",\n  274: \"CHIDIST\",\n  275: \"CHIINV\",\n  276: \"COMBIN\",\n  277: \"CONFIDENCE\",\n  278: \"CRITBINOM\",\n  279: \"EVEN\",\n  280: \"EXPONDIST\",\n  281: \"FDIST\",\n  282: \"FINV\",\n  283: \"FISHER\",\n  284: \"FISHERINV\",\n  285: \"FLOOR\",\n  286: \"GAMMADIST\",\n  287: \"GAMMAINV\",\n  288: \"CEILING\",\n  289: \"HYPGEOMDIST\",\n  290: \"LOGNORMDIST\",\n  291: \"LOGINV\",\n  292: \"NEGBINOMDIST\",\n  293: \"NORMDIST\",\n  294: \"NORMSDIST\",\n  295: \"NORMINV\",\n  296: \"NORMSINV\",\n  297: \"STANDARDIZE\",\n  298: \"ODD\",\n  299: \"PERMUT\",\n  300: \"POISSON\",\n  301: \"TDIST\",\n  302: \"WEIBULL\",\n  303: \"SUMXMY2\",\n  304: \"SUMX2MY2\",\n  305: \"SUMX2PY2\",\n  306: \"CHITEST\",\n  307: \"CORREL\",\n  308: \"COVAR\",\n  309: \"FORECAST\",\n  310: \"FTEST\",\n  311: \"INTERCEPT\",\n  312: \"PEARSON\",\n  313: \"RSQ\",\n  314: \"STEYX\",\n  315: \"SLOPE\",\n  316: \"TTEST\",\n  317: \"PROB\",\n  318: \"DEVSQ\",\n  319: \"GEOMEAN\",\n  320: \"HARMEAN\",\n  321: \"SUMSQ\",\n  322: \"KURT\",\n  323: \"SKEW\",\n  324: \"ZTEST\",\n  325: \"LARGE\",\n  326: \"SMALL\",\n  327: \"QUARTILE\",\n  328: \"PERCENTILE\",\n  329: \"PERCENTRANK\",\n  330: \"MODE\",\n  331: \"TRIMMEAN\",\n  332: \"TINV\",\n  334: \"MOVIE.COMMAND\",\n  335: \"GET.MOVIE\",\n  336: \"CONCATENATE\",\n  337: \"POWER\",\n  338: \"PIVOT.ADD.DATA\",\n  339: \"GET.PIVOT.TABLE\",\n  340: \"GET.PIVOT.FIELD\",\n  341: \"GET.PIVOT.ITEM\",\n  342: \"RADIANS\",\n  343: \"DEGREES\",\n  344: \"SUBTOTAL\",\n  345: \"SUMIF\",\n  346: \"COUNTIF\",\n  347: \"COUNTBLANK\",\n  348: \"SCENARIO.GET\",\n  349: \"OPTIONS.LISTS.GET\",\n  350: \"ISPMT\",\n  351: \"DATEDIF\",\n  352: \"DATESTRING\",\n  353: \"NUMBERSTRING\",\n  354: \"ROMAN\",\n  355: \"OPEN.DIALOG\",\n  356: \"SAVE.DIALOG\",\n  357: \"VIEW.GET\",\n  358: \"GETPIVOTDATA\",\n  359: \"HYPERLINK\",\n  360: \"PHONETIC\",\n  361: \"AVERAGEA\",\n  362: \"MAXA\",\n  363: \"MINA\",\n  364: \"STDEVPA\",\n  365: \"VARPA\",\n  366: \"STDEVA\",\n  367: \"VARA\",\n  368: \"BAHTTEXT\",\n  369: \"THAIDAYOFWEEK\",\n  370: \"THAIDIGIT\",\n  371: \"THAIMONTHOFYEAR\",\n  372: \"THAINUMSOUND\",\n  373: \"THAINUMSTRING\",\n  374: \"THAISTRINGLENGTH\",\n  375: \"ISTHAIDIGIT\",\n  376: \"ROUNDBAHTDOWN\",\n  377: \"ROUNDBAHTUP\",\n  378: \"THAIYEAR\",\n  379: \"RTD\",\n  380: \"CUBEVALUE\",\n  381: \"CUBEMEMBER\",\n  382: \"CUBEMEMBERPROPERTY\",\n  383: \"CUBERANKEDMEMBER\",\n  384: \"HEX2BIN\",\n  385: \"HEX2DEC\",\n  386: \"HEX2OCT\",\n  387: \"DEC2BIN\",\n  388: \"DEC2HEX\",\n  389: \"DEC2OCT\",\n  390: \"OCT2BIN\",\n  391: \"OCT2HEX\",\n  392: \"OCT2DEC\",\n  393: \"BIN2DEC\",\n  394: \"BIN2OCT\",\n  395: \"BIN2HEX\",\n  396: \"IMSUB\",\n  397: \"IMDIV\",\n  398: \"IMPOWER\",\n  399: \"IMABS\",\n  400: \"IMSQRT\",\n  401: \"IMLN\",\n  402: \"IMLOG2\",\n  403: \"IMLOG10\",\n  404: \"IMSIN\",\n  405: \"IMCOS\",\n  406: \"IMEXP\",\n  407: \"IMARGUMENT\",\n  408: \"IMCONJUGATE\",\n  409: \"IMAGINARY\",\n  410: \"IMREAL\",\n  411: \"COMPLEX\",\n  412: \"IMSUM\",\n  413: \"IMPRODUCT\",\n  414: \"SERIESSUM\",\n  415: \"FACTDOUBLE\",\n  416: \"SQRTPI\",\n  417: \"QUOTIENT\",\n  418: \"DELTA\",\n  419: \"GESTEP\",\n  420: \"ISEVEN\",\n  421: \"ISODD\",\n  422: \"MROUND\",\n  423: \"ERF\",\n  424: \"ERFC\",\n  425: \"BESSELJ\",\n  426: \"BESSELK\",\n  427: \"BESSELY\",\n  428: \"BESSELI\",\n  429: \"XIRR\",\n  430: \"XNPV\",\n  431: \"PRICEMAT\",\n  432: \"YIELDMAT\",\n  433: \"INTRATE\",\n  434: \"RECEIVED\",\n  435: \"DISC\",\n  436: \"PRICEDISC\",\n  437: \"YIELDDISC\",\n  438: \"TBILLEQ\",\n  439: \"TBILLPRICE\",\n  440: \"TBILLYIELD\",\n  441: \"PRICE\",\n  442: \"YIELD\",\n  443: \"DOLLARDE\",\n  444: \"DOLLARFR\",\n  445: \"NOMINAL\",\n  446: \"EFFECT\",\n  447: \"CUMPRINC\",\n  448: \"CUMIPMT\",\n  449: \"EDATE\",\n  450: \"EOMONTH\",\n  451: \"YEARFRAC\",\n  452: \"COUPDAYBS\",\n  453: \"COUPDAYS\",\n  454: \"COUPDAYSNC\",\n  455: \"COUPNCD\",\n  456: \"COUPNUM\",\n  457: \"COUPPCD\",\n  458: \"DURATION\",\n  459: \"MDURATION\",\n  460: \"ODDLPRICE\",\n  461: \"ODDLYIELD\",\n  462: \"ODDFPRICE\",\n  463: \"ODDFYIELD\",\n  464: \"RANDBETWEEN\",\n  465: \"WEEKNUM\",\n  466: \"AMORDEGRC\",\n  467: \"AMORLINC\",\n  468: \"CONVERT\",\n  724: \"SHEETJS\",\n  469: \"ACCRINT\",\n  470: \"ACCRINTM\",\n  471: \"WORKDAY\",\n  472: \"NETWORKDAYS\",\n  473: \"GCD\",\n  474: \"MULTINOMIAL\",\n  475: \"LCM\",\n  476: \"FVSCHEDULE\",\n  477: \"CUBEKPIMEMBER\",\n  478: \"CUBESET\",\n  479: \"CUBESETCOUNT\",\n  480: \"IFERROR\",\n  481: \"COUNTIFS\",\n  482: \"SUMIFS\",\n  483: \"AVERAGEIF\",\n  484: \"AVERAGEIFS\"\n};\nvar FtabArgc = {\n  2: 1,\n  3: 1,\n  10: 0,\n  15: 1,\n  16: 1,\n  17: 1,\n  18: 1,\n  19: 0,\n  20: 1,\n  21: 1,\n  22: 1,\n  23: 1,\n  24: 1,\n  25: 1,\n  26: 1,\n  27: 2,\n  30: 2,\n  31: 3,\n  32: 1,\n  33: 1,\n  34: 0,\n  35: 0,\n  38: 1,\n  39: 2,\n  40: 3,\n  41: 3,\n  42: 3,\n  43: 3,\n  44: 3,\n  45: 3,\n  47: 3,\n  48: 2,\n  53: 1,\n  61: 3,\n  63: 0,\n  65: 3,\n  66: 3,\n  67: 1,\n  68: 1,\n  69: 1,\n  70: 1,\n  71: 1,\n  72: 1,\n  73: 1,\n  74: 0,\n  75: 1,\n  76: 1,\n  77: 1,\n  79: 2,\n  80: 2,\n  83: 1,\n  85: 0,\n  86: 1,\n  89: 0,\n  90: 1,\n  94: 0,\n  95: 0,\n  97: 2,\n  98: 1,\n  99: 1,\n  101: 3,\n  102: 3,\n  105: 1,\n  106: 1,\n  108: 2,\n  111: 1,\n  112: 1,\n  113: 1,\n  114: 1,\n  117: 2,\n  118: 1,\n  119: 4,\n  121: 1,\n  126: 1,\n  127: 1,\n  128: 1,\n  129: 1,\n  130: 1,\n  131: 1,\n  133: 1,\n  134: 1,\n  135: 1,\n  136: 2,\n  137: 2,\n  138: 2,\n  140: 1,\n  141: 1,\n  142: 3,\n  143: 4,\n  144: 4,\n  161: 1,\n  162: 1,\n  163: 1,\n  164: 1,\n  165: 2,\n  172: 1,\n  175: 2,\n  176: 2,\n  177: 3,\n  178: 2,\n  179: 1,\n  184: 1,\n  186: 1,\n  189: 3,\n  190: 1,\n  195: 3,\n  196: 3,\n  197: 1,\n  198: 1,\n  199: 3,\n  201: 1,\n  207: 4,\n  210: 3,\n  211: 1,\n  212: 2,\n  213: 2,\n  214: 1,\n  215: 1,\n  225: 0,\n  229: 1,\n  230: 1,\n  231: 1,\n  232: 1,\n  233: 1,\n  234: 1,\n  235: 3,\n  244: 1,\n  247: 4,\n  252: 2,\n  257: 1,\n  261: 1,\n  271: 1,\n  273: 4,\n  274: 2,\n  275: 2,\n  276: 2,\n  277: 3,\n  278: 3,\n  279: 1,\n  280: 3,\n  281: 3,\n  282: 3,\n  283: 1,\n  284: 1,\n  285: 2,\n  286: 4,\n  287: 3,\n  288: 2,\n  289: 4,\n  290: 3,\n  291: 3,\n  292: 3,\n  293: 4,\n  294: 1,\n  295: 3,\n  296: 1,\n  297: 3,\n  298: 1,\n  299: 2,\n  300: 3,\n  301: 3,\n  302: 4,\n  303: 2,\n  304: 2,\n  305: 2,\n  306: 2,\n  307: 2,\n  308: 2,\n  309: 3,\n  310: 2,\n  311: 2,\n  312: 2,\n  313: 2,\n  314: 2,\n  315: 2,\n  316: 4,\n  325: 2,\n  326: 2,\n  327: 2,\n  328: 2,\n  331: 2,\n  332: 2,\n  337: 2,\n  342: 1,\n  343: 1,\n  346: 2,\n  347: 1,\n  350: 4,\n  351: 3,\n  352: 1,\n  353: 2,\n  360: 1,\n  368: 1,\n  369: 1,\n  370: 1,\n  371: 1,\n  372: 1,\n  373: 1,\n  374: 1,\n  375: 1,\n  376: 1,\n  377: 1,\n  378: 1,\n  382: 3,\n  385: 1,\n  392: 1,\n  393: 1,\n  396: 2,\n  397: 2,\n  398: 2,\n  399: 1,\n  400: 1,\n  401: 1,\n  402: 1,\n  403: 1,\n  404: 1,\n  405: 1,\n  406: 1,\n  407: 1,\n  408: 1,\n  409: 1,\n  410: 1,\n  414: 4,\n  415: 1,\n  416: 1,\n  417: 2,\n  420: 1,\n  421: 1,\n  422: 2,\n  424: 1,\n  425: 2,\n  426: 2,\n  427: 2,\n  428: 2,\n  430: 3,\n  438: 3,\n  439: 3,\n  440: 3,\n  443: 2,\n  444: 2,\n  445: 2,\n  446: 2,\n  447: 6,\n  448: 6,\n  449: 2,\n  450: 2,\n  464: 2,\n  468: 3,\n  476: 2,\n  479: 1,\n  480: 2,\n  65535: 0\n};\n/* Part 3 TODO: actually parse formulae */\nfunction ods_to_csf_formula(f/*:string*/)/*:string*/ {\n\tif(f.slice(0,3) == \"of:\") f = f.slice(3);\n\t/* 5.2 Basic Expressions */\n\tif(f.charCodeAt(0) == 61) {\n\t\tf = f.slice(1);\n\t\tif(f.charCodeAt(0) == 61) f = f.slice(1);\n\t}\n\tf = f.replace(/COM\\.MICROSOFT\\./g, \"\");\n\t/* Part 3 Section 5.8 References */\n\tf = f.replace(/\\[((?:\\.[A-Z]+[0-9]+)(?::\\.[A-Z]+[0-9]+)?)\\]/g, function($$, $1) { return $1.replace(/\\./g,\"\"); });\n\t/* TODO: something other than this */\n\tf = f.replace(/\\[.(#[A-Z]*[?!])\\]/g, \"$1\");\n\treturn f.replace(/[;~]/g,\",\").replace(/\\|/g,\";\");\n}\n\nfunction csf_to_ods_formula(f/*:string*/)/*:string*/ {\n\tvar o = \"of:=\" + f.replace(crefregex, \"$1[.$2$3$4$5]\").replace(/\\]:\\[/g,\":\");\n\t/* TODO: something other than this */\n\treturn o.replace(/;/g, \"|\").replace(/,/g,\";\");\n}\n\nfunction ods_to_csf_3D(r/*:string*/)/*:[string, string]*/ {\n\tvar a = r.split(\":\");\n\tvar s = a[0].split(\".\")[0];\n\treturn [s, a[0].split(\".\")[1] + (a.length > 1 ? (\":\" + (a[1].split(\".\")[1] || a[1].split(\".\")[0])) : \"\")];\n}\n\nfunction csf_to_ods_3D(r/*:string*/)/*:string*/ {\n\treturn r.replace(/\\./,\"!\");\n}\n\nvar strs = {}; // shared strings\nvar _ssfopts = {}; // spreadsheet formatting options\n\n\n/*global Map */\nvar browser_has_Map = typeof Map !== 'undefined';\n\nfunction get_sst_id(sst/*:SST*/, str/*:string*/, rev)/*:number*/ {\n\tvar i = 0, len = sst.length;\n\tif(rev) {\n\t\tif(browser_has_Map ? rev.has(str) : Object.prototype.hasOwnProperty.call(rev, str)) {\n\t\t\tvar revarr = browser_has_Map ? rev.get(str) : rev[str];\n\t\t\tfor(; i < revarr.length; ++i) {\n\t\t\t\tif(sst[revarr[i]].t === str) { sst.Count ++; return revarr[i]; }\n\t\t\t}\n\t\t}\n\t} else for(; i < len; ++i) {\n\t\tif(sst[i].t === str) { sst.Count ++; return i; }\n\t}\n\tsst[len] = ({t:str}/*:any*/); sst.Count ++; sst.Unique ++;\n\tif(rev) {\n\t\tif(browser_has_Map) {\n\t\t\tif(!rev.has(str)) rev.set(str, []);\n\t\t\trev.get(str).push(len);\n\t\t} else {\n\t\t\tif(!Object.prototype.hasOwnProperty.call(rev, str)) rev[str] = [];\n\t\t\trev[str].push(len);\n\t\t}\n\t}\n\treturn len;\n}\n\nfunction col_obj_w(C/*:number*/, col) {\n\tvar p = ({min:C+1,max:C+1}/*:any*/);\n\t/* wch (chars), wpx (pixels) */\n\tvar wch = -1;\n\tif(col.MDW) MDW = col.MDW;\n\tif(col.width != null) p.customWidth = 1;\n\telse if(col.wpx != null) wch = px2char(col.wpx);\n\telse if(col.wch != null) wch = col.wch;\n\tif(wch > -1) { p.width = char2width(wch); p.customWidth = 1; }\n\telse if(col.width != null) p.width = col.width;\n\tif(col.hidden) p.hidden = true;\n\tif(col.level != null) { p.outlineLevel = p.level = col.level; }\n\treturn p;\n}\n\nfunction default_margins(margins/*:Margins*/, mode/*:?string*/) {\n\tif(!margins) return;\n\tvar defs = [0.7, 0.7, 0.75, 0.75, 0.3, 0.3];\n\tif(mode == 'xlml') defs = [1, 1, 1, 1, 0.5, 0.5];\n\tif(margins.left   == null) margins.left   = defs[0];\n\tif(margins.right  == null) margins.right  = defs[1];\n\tif(margins.top    == null) margins.top    = defs[2];\n\tif(margins.bottom == null) margins.bottom = defs[3];\n\tif(margins.header == null) margins.header = defs[4];\n\tif(margins.footer == null) margins.footer = defs[5];\n}\n\nfunction get_cell_style(styles/*:Array<any>*/, cell/*:Cell*/, opts) {\n\tvar z = opts.revssf[cell.z != null ? cell.z : \"General\"];\n\tvar i = 0x3c, len = styles.length;\n\tif(z == null && opts.ssf) {\n\t\tfor(; i < 0x188; ++i) if(opts.ssf[i] == null) {\n\t\t\tSSF_load(cell.z, i);\n\t\t\t// $FlowIgnore\n\t\t\topts.ssf[i] = cell.z;\n\t\t\topts.revssf[cell.z] = z = i;\n\t\t\tbreak;\n\t\t}\n\t}\n\tfor(i = 0; i != len; ++i) if(styles[i].numFmtId === z) return i;\n\tstyles[len] = {\n\t\tnumFmtId:z,\n\t\tfontId:0,\n\t\tfillId:0,\n\t\tborderId:0,\n\t\txfId:0,\n\t\tapplyNumberFormat:1\n\t};\n\treturn len;\n}\n\nfunction safe_format(p/*:Cell*/, fmtid/*:number*/, fillid/*:?number*/, opts, themes, styles) {\n\ttry {\n\t\tif(opts.cellNF) p.z = table_fmt[fmtid];\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(p.t === 'z' && !opts.cellStyles) return;\n\tif(p.t === 'd' && typeof p.v === 'string') p.v = parseDate(p.v);\n\tif((!opts || opts.cellText !== false) && p.t !== 'z') try {\n\t\tif(table_fmt[fmtid] == null) SSF_load(SSFImplicit[fmtid] || \"General\", fmtid);\n\t\tif(p.t === 'e') p.w = p.w || BErr[p.v];\n\t\telse if(fmtid === 0) {\n\t\t\tif(p.t === 'n') {\n\t\t\t\tif((p.v|0) === p.v) p.w = p.v.toString(10);\n\t\t\t\telse p.w = SSF_general_num(p.v);\n\t\t\t}\n\t\t\telse if(p.t === 'd') {\n\t\t\t\tvar dd = datenum(p.v);\n\t\t\t\tif((dd|0) === dd) p.w = dd.toString(10);\n\t\t\t\telse p.w = SSF_general_num(dd);\n\t\t\t}\n\t\t\telse if(p.v === undefined) return \"\";\n\t\t\telse p.w = SSF_general(p.v,_ssfopts);\n\t\t}\n\t\telse if(p.t === 'd') p.w = SSF_format(fmtid,datenum(p.v),_ssfopts);\n\t\telse p.w = SSF_format(fmtid,p.v,_ssfopts);\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(!opts.cellStyles) return;\n\tif(fillid != null) try {\n\t\tp.s = styles.Fills[fillid];\n\t\tif (p.s.fgColor && p.s.fgColor.theme && !p.s.fgColor.rgb) {\n\t\t\tp.s.fgColor.rgb = rgb_tint(themes.themeElements.clrScheme[p.s.fgColor.theme].rgb, p.s.fgColor.tint || 0);\n\t\t\tif(opts.WTF) p.s.fgColor.raw_rgb = themes.themeElements.clrScheme[p.s.fgColor.theme].rgb;\n\t\t}\n\t\tif (p.s.bgColor && p.s.bgColor.theme) {\n\t\t\tp.s.bgColor.rgb = rgb_tint(themes.themeElements.clrScheme[p.s.bgColor.theme].rgb, p.s.bgColor.tint || 0);\n\t\t\tif(opts.WTF) p.s.bgColor.raw_rgb = themes.themeElements.clrScheme[p.s.bgColor.theme].rgb;\n\t\t}\n\t} catch(e) { if(opts.WTF && styles.Fills) throw e; }\n}\n\nfunction check_ws(ws/*:Worksheet*/, sname/*:string*/, i/*:number*/) {\n\tif(ws && ws['!ref']) {\n\t\tvar range = safe_decode_range(ws['!ref']);\n\t\tif(range.e.c < range.s.c || range.e.r < range.s.r) throw new Error(\"Bad range (\" + i + \"): \" + ws['!ref']);\n\t}\n}\nfunction parse_ws_xml_dim(ws/*:Worksheet*/, s/*:string*/) {\n\tvar d = safe_decode_range(s);\n\tif(d.s.r<=d.e.r && d.s.c<=d.e.c && d.s.r>=0 && d.s.c>=0) ws[\"!ref\"] = encode_range(d);\n}\nvar mergecregex = /<(?:\\w:)?mergeCell ref=\"[A-Z0-9:]+\"\\s*[\\/]?>/g;\nvar sheetdataregex = /<(?:\\w+:)?sheetData[^>]*>([\\s\\S]*)<\\/(?:\\w+:)?sheetData>/;\nvar hlinkregex = /<(?:\\w:)?hyperlink [^>]*>/mg;\nvar dimregex = /\"(\\w*:\\w*)\"/;\nvar colregex = /<(?:\\w:)?col\\b[^>]*[\\/]?>/g;\nvar afregex = /<(?:\\w:)?autoFilter[^>]*([\\/]|>([\\s\\S]*)<\\/(?:\\w:)?autoFilter)>/g;\nvar marginregex= /<(?:\\w:)?pageMargins[^>]*\\/>/g;\nvar sheetprregex = /<(?:\\w:)?sheetPr\\b(?:[^>a-z][^>]*)?\\/>/;\nvar sheetprregex2= /<(?:\\w:)?sheetPr[^>]*(?:[\\/]|>([\\s\\S]*)<\\/(?:\\w:)?sheetPr)>/;\nvar svsregex = /<(?:\\w:)?sheetViews[^>]*(?:[\\/]|>([\\s\\S]*)<\\/(?:\\w:)?sheetViews)>/;\n\n/* 18.3 Worksheets */\nfunction parse_ws_xml(data/*:?string*/, opts, idx/*:number*/, rels, wb/*:WBWBProps*/, themes, styles)/*:Worksheet*/ {\n\tif(!data) return data;\n\tif(!rels) rels = {'!id':{}};\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\n\t/* 18.3.1.99 worksheet CT_Worksheet */\n\tvar s = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\tvar refguess/*:Range*/ = ({s: {r:2000000, c:2000000}, e: {r:0, c:0} }/*:any*/);\n\n\tvar data1 = \"\", data2 = \"\";\n\tvar mtch/*:?any*/ = data.match(sheetdataregex);\n\tif(mtch) {\n\t\tdata1 = data.slice(0, mtch.index);\n\t\tdata2 = data.slice(mtch.index + mtch[0].length);\n\t} else data1 = data2 = data;\n\n\t/* 18.3.1.82 sheetPr CT_SheetPr */\n\tvar sheetPr = data1.match(sheetprregex);\n\tif(sheetPr) parse_ws_xml_sheetpr(sheetPr[0], s, wb, idx);\n\telse if((sheetPr = data1.match(sheetprregex2))) parse_ws_xml_sheetpr2(sheetPr[0], sheetPr[1]||\"\", s, wb, idx, styles, themes);\n\n\t/* 18.3.1.35 dimension CT_SheetDimension */\n\tvar ridx = (data1.match(/<(?:\\w*:)?dimension/)||{index:-1}).index;\n\tif(ridx > 0) {\n\t\tvar ref = data1.slice(ridx,ridx+50).match(dimregex);\n\t\tif(ref) parse_ws_xml_dim(s, ref[1]);\n\t}\n\n\t/* 18.3.1.88 sheetViews CT_SheetViews */\n\tvar svs = data1.match(svsregex);\n\tif(svs && svs[1]) parse_ws_xml_sheetviews(svs[1], wb);\n\n\t/* 18.3.1.17 cols CT_Cols */\n\tvar columns/*:Array<ColInfo>*/ = [];\n\tif(opts.cellStyles) {\n\t\t/* 18.3.1.13 col CT_Col */\n\t\tvar cols = data1.match(colregex);\n\t\tif(cols) parse_ws_xml_cols(columns, cols);\n\t}\n\n\t/* 18.3.1.80 sheetData CT_SheetData ? */\n\tif(mtch) parse_ws_xml_data(mtch[1], s, opts, refguess, themes, styles);\n\n\t/* 18.3.1.2  autoFilter CT_AutoFilter */\n\tvar afilter = data2.match(afregex);\n\tif(afilter) s['!autofilter'] = parse_ws_xml_autofilter(afilter[0]);\n\n\t/* 18.3.1.55 mergeCells CT_MergeCells */\n\tvar merges/*:Array<Range>*/ = [];\n\tvar _merge = data2.match(mergecregex);\n\tif(_merge) for(ridx = 0; ridx != _merge.length; ++ridx)\n\t\tmerges[ridx] = safe_decode_range(_merge[ridx].slice(_merge[ridx].indexOf(\"\\\"\")+1));\n\n\t/* 18.3.1.48 hyperlinks CT_Hyperlinks */\n\tvar hlink = data2.match(hlinkregex);\n\tif(hlink) parse_ws_xml_hlinks(s, hlink, rels);\n\n\t/* 18.3.1.62 pageMargins CT_PageMargins */\n\tvar margins = data2.match(marginregex);\n\tif(margins) s['!margins'] = parse_ws_xml_margins(parsexmltag(margins[0]));\n\n\tif(!s[\"!ref\"] && refguess.e.c >= refguess.s.c && refguess.e.r >= refguess.s.r) s[\"!ref\"] = encode_range(refguess);\n\tif(opts.sheetRows > 0 && s[\"!ref\"]) {\n\t\tvar tmpref = safe_decode_range(s[\"!ref\"]);\n\t\tif(opts.sheetRows <= +tmpref.e.r) {\n\t\t\ttmpref.e.r = opts.sheetRows - 1;\n\t\t\tif(tmpref.e.r > refguess.e.r) tmpref.e.r = refguess.e.r;\n\t\t\tif(tmpref.e.r < tmpref.s.r) tmpref.s.r = tmpref.e.r;\n\t\t\tif(tmpref.e.c > refguess.e.c) tmpref.e.c = refguess.e.c;\n\t\t\tif(tmpref.e.c < tmpref.s.c) tmpref.s.c = tmpref.e.c;\n\t\t\ts[\"!fullref\"] = s[\"!ref\"];\n\t\t\ts[\"!ref\"] = encode_range(tmpref);\n\t\t}\n\t}\n\tif(columns.length > 0) s[\"!cols\"] = columns;\n\tif(merges.length > 0) s[\"!merges\"] = merges;\n\treturn s;\n}\n\nfunction write_ws_xml_merges(merges/*:Array<Range>*/)/*:string*/ {\n\tif(merges.length === 0) return \"\";\n\tvar o = '<mergeCells count=\"' + merges.length + '\">';\n\tfor(var i = 0; i != merges.length; ++i) o += '<mergeCell ref=\"' + encode_range(merges[i]) + '\"/>';\n\treturn o + '</mergeCells>';\n}\n\n/* 18.3.1.82-3 sheetPr CT_ChartsheetPr / CT_SheetPr */\nfunction parse_ws_xml_sheetpr(sheetPr/*:string*/, s, wb/*:WBWBProps*/, idx/*:number*/) {\n\tvar data = parsexmltag(sheetPr);\n\tif(!wb.Sheets[idx]) wb.Sheets[idx] = {};\n\tif(data.codeName) wb.Sheets[idx].CodeName = unescapexml(utf8read(data.codeName));\n}\nfunction parse_ws_xml_sheetpr2(sheetPr/*:string*/, body/*:string*/, s, wb/*:WBWBProps*/, idx/*:number*/) {\n\tparse_ws_xml_sheetpr(sheetPr.slice(0, sheetPr.indexOf(\">\")), s, wb, idx);\n}\nfunction write_ws_xml_sheetpr(ws, wb, idx, opts, o) {\n\tvar needed = false;\n\tvar props = {}, payload = null;\n\tif(opts.bookType !== 'xlsx' && wb.vbaraw) {\n\t\tvar cname = wb.SheetNames[idx];\n\t\ttry { if(wb.Workbook) cname = wb.Workbook.Sheets[idx].CodeName || cname; } catch(e) {}\n\t\tneeded = true;\n\t\tprops.codeName = utf8write(escapexml(cname));\n\t}\n\n\tif(ws && ws[\"!outline\"]) {\n\t\tvar outlineprops = {summaryBelow:1, summaryRight:1};\n\t\tif(ws[\"!outline\"].above) outlineprops.summaryBelow = 0;\n\t\tif(ws[\"!outline\"].left) outlineprops.summaryRight = 0;\n\t\tpayload = (payload||\"\") + writextag('outlinePr', null, outlineprops);\n\t}\n\n\tif(!needed && !payload) return;\n\to[o.length] = (writextag('sheetPr', payload, props));\n}\n\n/* 18.3.1.85 sheetProtection CT_SheetProtection */\nvar sheetprot_deffalse = [\"objects\", \"scenarios\", \"selectLockedCells\", \"selectUnlockedCells\"];\nvar sheetprot_deftrue = [\n\t\"formatColumns\", \"formatRows\", \"formatCells\",\n\t\"insertColumns\", \"insertRows\", \"insertHyperlinks\",\n\t\"deleteColumns\", \"deleteRows\",\n\t\"sort\", \"autoFilter\", \"pivotTables\"\n];\nfunction write_ws_xml_protection(sp)/*:string*/ {\n\t// algorithmName, hashValue, saltValue, spinCount\n\tvar o = ({sheet:1}/*:any*/);\n\tsheetprot_deffalse.forEach(function(n) { if(sp[n] != null && sp[n]) o[n] = \"1\"; });\n\tsheetprot_deftrue.forEach(function(n) { if(sp[n] != null && !sp[n]) o[n] = \"0\"; });\n\t/* TODO: algorithm */\n\tif(sp.password) o.password = crypto_CreatePasswordVerifier_Method1(sp.password).toString(16).toUpperCase();\n\treturn writextag('sheetProtection', null, o);\n}\n\nfunction parse_ws_xml_hlinks(s, data/*:Array<string>*/, rels) {\n\tvar dense = Array.isArray(s);\n\tfor(var i = 0; i != data.length; ++i) {\n\t\tvar val = parsexmltag(utf8read(data[i]), true);\n\t\tif(!val.ref) return;\n\t\tvar rel = ((rels || {})['!id']||[])[val.id];\n\t\tif(rel) {\n\t\t\tval.Target = rel.Target;\n\t\t\tif(val.location) val.Target += \"#\"+unescapexml(val.location);\n\t\t} else {\n\t\t\tval.Target = \"#\" + unescapexml(val.location);\n\t\t\trel = {Target: val.Target, TargetMode: 'Internal'};\n\t\t}\n\t\tval.Rel = rel;\n\t\tif(val.tooltip) { val.Tooltip = val.tooltip; delete val.tooltip; }\n\t\tvar rng = safe_decode_range(val.ref);\n\t\tfor(var R=rng.s.r;R<=rng.e.r;++R) for(var C=rng.s.c;C<=rng.e.c;++C) {\n\t\t\tvar addr = encode_cell({c:C,r:R});\n\t\t\tif(dense) {\n\t\t\t\tif(!s[R]) s[R] = [];\n\t\t\t\tif(!s[R][C]) s[R][C] = {t:\"z\",v:undefined};\n\t\t\t\ts[R][C].l = val;\n\t\t\t} else {\n\t\t\t\tif(!s[addr]) s[addr] = {t:\"z\",v:undefined};\n\t\t\t\ts[addr].l = val;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction parse_ws_xml_margins(margin) {\n\tvar o = {};\n\t[\"left\", \"right\", \"top\", \"bottom\", \"header\", \"footer\"].forEach(function(k) {\n\t\tif(margin[k]) o[k] = parseFloat(margin[k]);\n\t});\n\treturn o;\n}\nfunction write_ws_xml_margins(margin)/*:string*/ {\n\tdefault_margins(margin);\n\treturn writextag('pageMargins', null, margin);\n}\n\nfunction parse_ws_xml_cols(columns, cols) {\n\tvar seencol = false;\n\tfor(var coli = 0; coli != cols.length; ++coli) {\n\t\tvar coll = parsexmltag(cols[coli], true);\n\t\tif(coll.hidden) coll.hidden = parsexmlbool(coll.hidden);\n\t\tvar colm=parseInt(coll.min, 10)-1, colM=parseInt(coll.max,10)-1;\n\t\tif(coll.outlineLevel) coll.level = (+coll.outlineLevel || 0);\n\t\tdelete coll.min; delete coll.max; coll.width = +coll.width;\n\t\tif(!seencol && coll.width) { seencol = true; find_mdw_colw(coll.width); }\n\t\tprocess_col(coll);\n\t\twhile(colm <= colM) columns[colm++] = dup(coll);\n\t}\n}\nfunction write_ws_xml_cols(ws, cols)/*:string*/ {\n\tvar o = [\"<cols>\"], col;\n\tfor(var i = 0; i != cols.length; ++i) {\n\t\tif(!(col = cols[i])) continue;\n\t\to[o.length] = (writextag('col', null, col_obj_w(i, col)));\n\t}\n\to[o.length] = \"</cols>\";\n\treturn o.join(\"\");\n}\n\nfunction parse_ws_xml_autofilter(data/*:string*/) {\n\tvar o = { ref: (data.match(/ref=\"([^\"]*)\"/)||[])[1]};\n\treturn o;\n}\nfunction write_ws_xml_autofilter(data, ws, wb, idx)/*:string*/ {\n\tvar ref = typeof data.ref == \"string\" ? data.ref : encode_range(data.ref);\n\tif(!wb.Workbook) wb.Workbook = ({Sheets:[]}/*:any*/);\n\tif(!wb.Workbook.Names) wb.Workbook.Names = [];\n\tvar names/*: Array<any> */ = wb.Workbook.Names;\n\tvar range = decode_range(ref);\n\tif(range.s.r == range.e.r) { range.e.r = decode_range(ws[\"!ref\"]).e.r; ref = encode_range(range); }\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar name = names[i];\n\t\tif(name.Name != '_xlnm._FilterDatabase') continue;\n\t\tif(name.Sheet != idx) continue;\n\t\tname.Ref = \"'\" + wb.SheetNames[idx] + \"'!\" + ref; break;\n\t}\n\tif(i == names.length) names.push({ Name: '_xlnm._FilterDatabase', Sheet: idx, Ref: \"'\" + wb.SheetNames[idx] + \"'!\" + ref  });\n\treturn writextag(\"autoFilter\", null, {ref:ref});\n}\n\n/* 18.3.1.88 sheetViews CT_SheetViews */\n/* 18.3.1.87 sheetView CT_SheetView */\nvar sviewregex = /<(?:\\w:)?sheetView(?:[^>a-z][^>]*)?\\/?>/;\nfunction parse_ws_xml_sheetviews(data, wb/*:WBWBProps*/) {\n\tif(!wb.Views) wb.Views = [{}];\n\t(data.match(sviewregex)||[]).forEach(function(r/*:string*/, i/*:number*/) {\n\t\tvar tag = parsexmltag(r);\n\t\t// $FlowIgnore\n\t\tif(!wb.Views[i]) wb.Views[i] = {};\n\t\t// $FlowIgnore\n\t\tif(+tag.zoomScale) wb.Views[i].zoom = +tag.zoomScale;\n\t\t// $FlowIgnore\n\t\tif(parsexmlbool(tag.rightToLeft)) wb.Views[i].RTL = true;\n\t});\n}\nfunction write_ws_xml_sheetviews(ws, opts, idx, wb)/*:string*/ {\n\tvar sview = ({workbookViewId:\"0\"}/*:any*/);\n\t// $FlowIgnore\n\tif((((wb||{}).Workbook||{}).Views||[])[0]) sview.rightToLeft = wb.Workbook.Views[0].RTL ? \"1\" : \"0\";\n\treturn writextag(\"sheetViews\", writextag(\"sheetView\", null, sview), {});\n}\n\nfunction write_ws_xml_cell(cell/*:Cell*/, ref, ws, opts/*::, idx, wb*/)/*:string*/ {\n\tif(cell.c) ws['!comments'].push([ref, cell.c]);\n\tif(cell.v === undefined && typeof cell.f !== \"string\" || cell.t === 'z' && !cell.f) return \"\";\n\tvar vv = \"\";\n\tvar oldt = cell.t, oldv = cell.v;\n\tif(cell.t !== \"z\") switch(cell.t) {\n\t\tcase 'b': vv = cell.v ? \"1\" : \"0\"; break;\n\t\tcase 'n': vv = ''+cell.v; break;\n\t\tcase 'e': vv = BErr[cell.v]; break;\n\t\tcase 'd':\n\t\t\tif(opts && opts.cellDates) vv = parseDate(cell.v, -1).toISOString();\n\t\t\telse {\n\t\t\t\tcell = dup(cell);\n\t\t\t\tcell.t = 'n';\n\t\t\t\tvv = ''+(cell.v = datenum(parseDate(cell.v)));\n\t\t\t}\n\t\t\tif(typeof cell.z === 'undefined') cell.z = table_fmt[14];\n\t\t\tbreak;\n\t\tdefault: vv = cell.v; break;\n\t}\n\tvar v = writetag('v', escapexml(vv)), o = ({r:ref}/*:any*/);\n\t/* TODO: cell style */\n\tvar os = get_cell_style(opts.cellXfs, cell, opts);\n\tif(os !== 0) o.s = os;\n\tswitch(cell.t) {\n\t\tcase 'n': break;\n\t\tcase 'd': o.t = \"d\"; break;\n\t\tcase 'b': o.t = \"b\"; break;\n\t\tcase 'e': o.t = \"e\"; break;\n\t\tcase 'z': break;\n\t\tdefault: if(cell.v == null) { delete cell.t; break; }\n\t\t\tif(cell.v.length > 32767) throw new Error(\"Text length must not exceed 32767 characters\");\n\t\t\tif(opts && opts.bookSST) {\n\t\t\t\tv = writetag('v', ''+get_sst_id(opts.Strings, cell.v, opts.revStrings));\n\t\t\t\to.t = \"s\"; break;\n\t\t\t}\n\t\t\to.t = \"str\"; break;\n\t}\n\tif(cell.t != oldt) { cell.t = oldt; cell.v = oldv; }\n\tif(typeof cell.f == \"string\" && cell.f) {\n\t\tvar ff = cell.F && cell.F.slice(0, ref.length) == ref ? {t:\"array\", ref:cell.F} : null;\n\t\tv = writextag('f', escapexml(cell.f), ff) + (cell.v != null ? v : \"\");\n\t}\n\tif(cell.l) ws['!links'].push([ref, cell.l]);\n\tif(cell.D) o.cm = 1;\n\treturn writextag('c', v, o);\n}\n\nvar parse_ws_xml_data = /*#__PURE__*/(function() {\n\tvar cellregex = /<(?:\\w+:)?c[ \\/>]/, rowregex = /<\\/(?:\\w+:)?row>/;\n\tvar rregex = /r=[\"']([^\"']*)[\"']/, isregex = /<(?:\\w+:)?is>([\\S\\s]*?)<\\/(?:\\w+:)?is>/;\n\tvar refregex = /ref=[\"']([^\"']*)[\"']/;\n\tvar match_v = matchtag(\"v\"), match_f = matchtag(\"f\");\n\nreturn function parse_ws_xml_data(sdata/*:string*/, s, opts, guess/*:Range*/, themes, styles) {\n\tvar ri = 0, x = \"\", cells/*:Array<string>*/ = [], cref/*:?Array<string>*/ = [], idx=0, i=0, cc=0, d=\"\", p/*:any*/;\n\tvar tag, tagr = 0, tagc = 0;\n\tvar sstr, ftag;\n\tvar fmtid = 0, fillid = 0;\n\tvar do_format = Array.isArray(styles.CellXf), cf;\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar sharedf = [];\n\tvar dense = Array.isArray(s);\n\tvar rows/*:Array<RowInfo>*/ = [], rowobj = {}, rowrite = false;\n\tvar sheetStubs = !!opts.sheetStubs;\n\tfor(var marr = sdata.split(rowregex), mt = 0, marrlen = marr.length; mt != marrlen; ++mt) {\n\t\tx = marr[mt].trim();\n\t\tvar xlen = x.length;\n\t\tif(xlen === 0) continue;\n\n\t\t/* 18.3.1.73 row CT_Row */\n\t\tvar rstarti = 0;\n\t\touta: for(ri = 0; ri < xlen; ++ri) switch(/*x.charCodeAt(ri)*/x[ri]) {\n\t\t\tcase \">\" /*62*/:\n\t\t\t\tif(/*x.charCodeAt(ri-1) != 47*/x[ri-1] != \"/\") { ++ri; break outa; }\n\t\t\t\tif(opts && opts.cellStyles) {\n\t\t\t\t\t// TODO: avoid duplication\n\t\t\t\t\ttag = parsexmltag(x.slice(rstarti,ri), true);\n\t\t\t\t\ttagr = tag.r != null ? parseInt(tag.r, 10) : tagr+1; tagc = -1;\n\t\t\t\t\tif(opts.sheetRows && opts.sheetRows < tagr) continue;\n\t\t\t\t\trowobj = {}; rowrite = false;\n\t\t\t\t\tif(tag.ht) { rowrite = true; rowobj.hpt = parseFloat(tag.ht); rowobj.hpx = pt2px(rowobj.hpt); }\n\t\t\t\t\tif(tag.hidden == \"1\") { rowrite = true; rowobj.hidden = true; }\n\t\t\t\t\tif(tag.outlineLevel != null) { rowrite = true; rowobj.level = +tag.outlineLevel; }\n\t\t\t\t\tif(rowrite) rows[tagr-1] = rowobj;\n\t\t\t\t}\n\t\t\t\tbreak;\n\t\t\tcase \"<\" /*60*/: rstarti = ri; break;\n\t\t}\n\t\tif(rstarti >= ri) break;\n\t\ttag = parsexmltag(x.slice(rstarti,ri), true);\n\t\ttagr = tag.r != null ? parseInt(tag.r, 10) : tagr+1; tagc = -1;\n\t\tif(opts.sheetRows && opts.sheetRows < tagr) continue;\n\t\tif(guess.s.r > tagr - 1) guess.s.r = tagr - 1;\n\t\tif(guess.e.r < tagr - 1) guess.e.r = tagr - 1;\n\n\t\tif(opts && opts.cellStyles) {\n\t\t\trowobj = {}; rowrite = false;\n\t\t\tif(tag.ht) { rowrite = true; rowobj.hpt = parseFloat(tag.ht); rowobj.hpx = pt2px(rowobj.hpt); }\n\t\t\tif(tag.hidden == \"1\") { rowrite = true; rowobj.hidden = true; }\n\t\t\tif(tag.outlineLevel != null) { rowrite = true; rowobj.level = +tag.outlineLevel; }\n\t\t\tif(rowrite) rows[tagr-1] = rowobj;\n\t\t}\n\n\t\t/* 18.3.1.4 c CT_Cell */\n\t\tcells = x.slice(ri).split(cellregex);\n\t\tfor(var rslice = 0; rslice != cells.length; ++rslice) if(cells[rslice].trim().charAt(0) != \"<\") break;\n\t\tcells = cells.slice(rslice);\n\t\tfor(ri = 0; ri != cells.length; ++ri) {\n\t\t\tx = cells[ri].trim();\n\t\t\tif(x.length === 0) continue;\n\t\t\tcref = x.match(rregex); idx = ri; i=0; cc=0;\n\t\t\tx = \"<c \" + (x.slice(0,1)==\"<\"?\">\":\"\") + x;\n\t\t\tif(cref != null && cref.length === 2) {\n\t\t\t\tidx = 0; d=cref[1];\n\t\t\t\tfor(i=0; i != d.length; ++i) {\n\t\t\t\t\tif((cc=d.charCodeAt(i)-64) < 1 || cc > 26) break;\n\t\t\t\t\tidx = 26*idx + cc;\n\t\t\t\t}\n\t\t\t\t--idx;\n\t\t\t\ttagc = idx;\n\t\t\t} else ++tagc;\n\t\t\tfor(i = 0; i != x.length; ++i) if(x.charCodeAt(i) === 62) break; ++i;\n\t\t\ttag = parsexmltag(x.slice(0,i), true);\n\t\t\tif(!tag.r) tag.r = encode_cell({r:tagr-1, c:tagc});\n\t\t\td = x.slice(i);\n\t\t\tp = ({t:\"\"}/*:any*/);\n\n\t\t\tif((cref=d.match(match_v))!= null && /*::cref != null && */cref[1] !== '') p.v=unescapexml(cref[1]);\n\t\t\tif(opts.cellFormula) {\n\t\t\t\tif((cref=d.match(match_f))!= null && /*::cref != null && */cref[1] !== '') {\n\t\t\t\t\t/* TODO: match against XLSXFutureFunctions */\n\t\t\t\t\tp.f=unescapexml(utf8read(cref[1])).replace(/\\r\\n/g, \"\\n\");\n\t\t\t\t\tif(!opts.xlfn) p.f = _xlfn(p.f);\n\t\t\t\t\tif(/*::cref != null && cref[0] != null && */cref[0].indexOf('t=\"array\"') > -1) {\n\t\t\t\t\t\tp.F = (d.match(refregex)||[])[1];\n\t\t\t\t\t\tif(p.F.indexOf(\":\") > -1) arrayf.push([safe_decode_range(p.F), p.F]);\n\t\t\t\t\t} else if(/*::cref != null && cref[0] != null && */cref[0].indexOf('t=\"shared\"') > -1) {\n\t\t\t\t\t\t// TODO: parse formula\n\t\t\t\t\t\tftag = parsexmltag(cref[0]);\n\t\t\t\t\t\tvar ___f = unescapexml(utf8read(cref[1]));\n\t\t\t\t\t\tif(!opts.xlfn) ___f = _xlfn(___f);\n\t\t\t\t\t\tsharedf[parseInt(ftag.si, 10)] = [ftag, ___f, tag.r];\n\t\t\t\t\t}\n\t\t\t\t} else if((cref=d.match(/<f[^>]*\\/>/))) {\n\t\t\t\t\tftag = parsexmltag(cref[0]);\n\t\t\t\t\tif(sharedf[ftag.si]) p.f = shift_formula_xlsx(sharedf[ftag.si][1], sharedf[ftag.si][2]/*[0].ref*/, tag.r);\n\t\t\t\t}\n\t\t\t\t/* TODO: factor out contains logic */\n\t\t\t\tvar _tag = decode_cell(tag.r);\n\t\t\t\tfor(i = 0; i < arrayf.length; ++i)\n\t\t\t\t\tif(_tag.r >= arrayf[i][0].s.r && _tag.r <= arrayf[i][0].e.r)\n\t\t\t\t\t\tif(_tag.c >= arrayf[i][0].s.c && _tag.c <= arrayf[i][0].e.c)\n\t\t\t\t\t\t\tp.F = arrayf[i][1];\n\t\t\t}\n\n\t\t\tif(tag.t == null && p.v === undefined) {\n\t\t\t\tif(p.f || p.F) {\n\t\t\t\t\tp.v = 0; p.t = \"n\";\n\t\t\t\t} else if(!sheetStubs) continue;\n\t\t\t\telse p.t = \"z\";\n\t\t\t}\n\t\t\telse p.t = tag.t || \"n\";\n\t\t\tif(guess.s.c > tagc) guess.s.c = tagc;\n\t\t\tif(guess.e.c < tagc) guess.e.c = tagc;\n\t\t\t/* 18.18.11 t ST_CellType */\n\t\t\tswitch(p.t) {\n\t\t\t\tcase 'n':\n\t\t\t\t\tif(p.v == \"\" || p.v == null) {\n\t\t\t\t\t\tif(!sheetStubs) continue;\n\t\t\t\t\t\tp.t = 'z';\n\t\t\t\t\t} else p.v = parseFloat(p.v);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 's':\n\t\t\t\t\tif(typeof p.v == 'undefined') {\n\t\t\t\t\t\tif(!sheetStubs) continue;\n\t\t\t\t\t\tp.t = 'z';\n\t\t\t\t\t} else {\n\t\t\t\t\t\tsstr = strs[parseInt(p.v, 10)];\n\t\t\t\t\t\tp.v = sstr.t;\n\t\t\t\t\t\tp.r = sstr.r;\n\t\t\t\t\t\tif(opts.cellHTML) p.h = sstr.h;\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'str':\n\t\t\t\t\tp.t = \"s\";\n\t\t\t\t\tp.v = (p.v!=null) ? utf8read(p.v) : '';\n\t\t\t\t\tif(opts.cellHTML) p.h = escapehtml(p.v);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'inlineStr':\n\t\t\t\t\tcref = d.match(isregex);\n\t\t\t\t\tp.t = 's';\n\t\t\t\t\tif(cref != null && (sstr = parse_si(cref[1]))) {\n\t\t\t\t\t\tp.v = sstr.t;\n\t\t\t\t\t\tif(opts.cellHTML) p.h = sstr.h;\n\t\t\t\t\t} else p.v = \"\";\n\t\t\t\t\tbreak;\n\t\t\t\tcase 'b': p.v = parsexmlbool(p.v); break;\n\t\t\t\tcase 'd':\n\t\t\t\t\tif(opts.cellDates) p.v = parseDate(p.v, 1);\n\t\t\t\t\telse { p.v = datenum(parseDate(p.v, 1)); p.t = 'n'; }\n\t\t\t\t\tbreak;\n\t\t\t\t/* error string in .w, number in .v */\n\t\t\t\tcase 'e':\n\t\t\t\t\tif(!opts || opts.cellText !== false) p.w = p.v;\n\t\t\t\t\tp.v = RBErr[p.v]; break;\n\t\t\t}\n\t\t\t/* formatting */\n\t\t\tfmtid = fillid = 0;\n\t\t\tcf = null;\n\t\t\tif(do_format && tag.s !== undefined) {\n\t\t\t\tcf = styles.CellXf[tag.s];\n\t\t\t\tif(cf != null) {\n\t\t\t\t\tif(cf.numFmtId != null) fmtid = cf.numFmtId;\n\t\t\t\t\tif(opts.cellStyles) {\n\t\t\t\t\t\tif(cf.fillId != null) fillid = cf.fillId;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tsafe_format(p, fmtid, fillid, opts, themes, styles);\n\t\t\tif(opts.cellDates && do_format && p.t == 'n' && fmt_is_date(table_fmt[fmtid])) { p.t = 'd'; p.v = numdate(p.v); }\n\t\t\tif(tag.cm && opts.xlmeta) {\n\t\t\t\tvar cm = (opts.xlmeta.Cell||[])[+tag.cm-1];\n\t\t\t\tif(cm && cm.type == 'XLDAPR') p.D = true;\n\t\t\t}\n\t\t\tif(dense) {\n\t\t\t\tvar _r = decode_cell(tag.r);\n\t\t\t\tif(!s[_r.r]) s[_r.r] = [];\n\t\t\t\ts[_r.r][_r.c] = p;\n\t\t\t} else s[tag.r] = p;\n\t\t}\n\t}\n\tif(rows.length > 0) s['!rows'] = rows;\n}; })();\n\nfunction write_ws_xml_data(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*//*::, rels*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [], r/*:Array<string>*/ = [], range = safe_decode_range(ws['!ref']), cell=\"\", ref, rr = \"\", cols/*:Array<string>*/ = [], R=0, C=0, rows = ws['!rows'];\n\tvar dense = Array.isArray(ws);\n\tvar params = ({r:rr}/*:any*/), row/*:RowInfo*/, height = -1;\n\tfor(C = range.s.c; C <= range.e.c; ++C) cols[C] = encode_col(C);\n\tfor(R = range.s.r; R <= range.e.r; ++R) {\n\t\tr = [];\n\t\trr = encode_row(R);\n\t\tfor(C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tref = cols[C] + rr;\n\t\t\tvar _cell = dense ? (ws[R]||[])[C]: ws[ref];\n\t\t\tif(_cell === undefined) continue;\n\t\t\tif((cell = write_ws_xml_cell(_cell, ref, ws, opts, idx, wb)) != null) r.push(cell);\n\t\t}\n\t\tif(r.length > 0 || (rows && rows[R])) {\n\t\t\tparams = ({r:rr}/*:any*/);\n\t\t\tif(rows && rows[R]) {\n\t\t\t\trow = rows[R];\n\t\t\t\tif(row.hidden) params.hidden = 1;\n\t\t\t\theight = -1;\n\t\t\t\tif(row.hpx) height = px2pt(row.hpx);\n\t\t\t\telse if(row.hpt) height = row.hpt;\n\t\t\t\tif(height > -1) { params.ht = height; params.customHeight = 1; }\n\t\t\t\tif(row.level) { params.outlineLevel = row.level; }\n\t\t\t}\n\t\t\to[o.length] = (writextag('row', r.join(\"\"), params));\n\t\t}\n\t}\n\tif(rows) for(; R < rows.length; ++R) {\n\t\tif(rows && rows[R]) {\n\t\t\tparams = ({r:R+1}/*:any*/);\n\t\t\trow = rows[R];\n\t\t\tif(row.hidden) params.hidden = 1;\n\t\t\theight = -1;\n\t\t\tif (row.hpx) height = px2pt(row.hpx);\n\t\t\telse if (row.hpt) height = row.hpt;\n\t\t\tif (height > -1) { params.ht = height; params.customHeight = 1; }\n\t\t\tif (row.level) { params.outlineLevel = row.level; }\n\t\t\to[o.length] = (writextag('row', \"\", params));\n\t\t}\n\t}\n\treturn o.join(\"\");\n}\n\nfunction write_ws_xml(idx/*:number*/, opts, wb/*:Workbook*/, rels)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('worksheet', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t'xmlns:r': XMLNS.r\n\t})];\n\tvar s = wb.SheetNames[idx], sidx = 0, rdata = \"\";\n\tvar ws = wb.Sheets[s];\n\tif(ws == null) ws = {};\n\tvar ref = ws['!ref'] || 'A1';\n\tvar range = safe_decode_range(ref);\n\tif(range.e.c > 0x3FFF || range.e.r > 0xFFFFF) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + ref + \" exceeds format limit A1:XFD1048576\");\n\t\trange.e.c = Math.min(range.e.c, 0x3FFF);\n\t\trange.e.r = Math.min(range.e.c, 0xFFFFF);\n\t\tref = encode_range(range);\n\t}\n\tif(!rels) rels = {};\n\tws['!comments'] = [];\n\tvar _drawing = [];\n\n\twrite_ws_xml_sheetpr(ws, wb, idx, opts, o);\n\n\to[o.length] = (writextag('dimension', null, {'ref': ref}));\n\n\to[o.length] = write_ws_xml_sheetviews(ws, opts, idx, wb);\n\n\t/* TODO: store in WB, process styles */\n\tif(opts.sheetFormat) o[o.length] = (writextag('sheetFormatPr', null, {\n\t\tdefaultRowHeight:opts.sheetFormat.defaultRowHeight||'16',\n\t\tbaseColWidth:opts.sheetFormat.baseColWidth||'10',\n\t\toutlineLevelRow:opts.sheetFormat.outlineLevelRow||'7'\n\t}));\n\n\tif(ws['!cols'] != null && ws['!cols'].length > 0) o[o.length] = (write_ws_xml_cols(ws, ws['!cols']));\n\n\to[sidx = o.length] = '<sheetData/>';\n\tws['!links'] = [];\n\tif(ws['!ref'] != null) {\n\t\trdata = write_ws_xml_data(ws, opts, idx, wb, rels);\n\t\tif(rdata.length > 0) o[o.length] = (rdata);\n\t}\n\tif(o.length>sidx+1) { o[o.length] = ('</sheetData>'); o[sidx]=o[sidx].replace(\"/>\",\">\"); }\n\n\t/* sheetCalcPr */\n\n\tif(ws['!protect']) o[o.length] = write_ws_xml_protection(ws['!protect']);\n\n\t/* protectedRanges */\n\t/* scenarios */\n\n\tif(ws['!autofilter'] != null) o[o.length] = write_ws_xml_autofilter(ws['!autofilter'], ws, wb, idx);\n\n\t/* sortState */\n\t/* dataConsolidate */\n\t/* customSheetViews */\n\n\tif(ws['!merges'] != null && ws['!merges'].length > 0) o[o.length] = (write_ws_xml_merges(ws['!merges']));\n\n\t/* phoneticPr */\n\t/* conditionalFormatting */\n\t/* dataValidations */\n\n\tvar relc = -1, rel, rId = -1;\n\tif(/*::(*/ws['!links']/*::||[])*/.length > 0) {\n\t\to[o.length] = \"<hyperlinks>\";\n\t\t/*::(*/ws['!links']/*::||[])*/.forEach(function(l) {\n\t\t\tif(!l[1].Target) return;\n\t\t\trel = ({\"ref\":l[0]}/*:any*/);\n\t\t\tif(l[1].Target.charAt(0) != \"#\") {\n\t\t\t\trId = add_rels(rels, -1, escapexml(l[1].Target).replace(/#.*$/, \"\"), RELS.HLINK);\n\t\t\t\trel[\"r:id\"] = \"rId\"+rId;\n\t\t\t}\n\t\t\tif((relc = l[1].Target.indexOf(\"#\")) > -1) rel.location = escapexml(l[1].Target.slice(relc+1));\n\t\t\tif(l[1].Tooltip) rel.tooltip = escapexml(l[1].Tooltip);\n\t\t\to[o.length] = writextag(\"hyperlink\",null,rel);\n\t\t});\n\t\to[o.length] = \"</hyperlinks>\";\n\t}\n\tdelete ws['!links'];\n\n\t/* printOptions */\n\n\tif(ws['!margins'] != null) o[o.length] =  write_ws_xml_margins(ws['!margins']);\n\n\t/* pageSetup */\n\t/* headerFooter */\n\t/* rowBreaks */\n\t/* colBreaks */\n\t/* customProperties */\n\t/* cellWatches */\n\n\tif(!opts || opts.ignoreEC || (opts.ignoreEC == (void 0))) o[o.length] = writetag(\"ignoredErrors\", writextag(\"ignoredError\", null, {numberStoredAsText:1, sqref:ref}));\n\n\t/* smartTags */\n\n\tif(_drawing.length > 0) {\n\t\trId = add_rels(rels, -1, \"../drawings/drawing\" + (idx+1) + \".xml\", RELS.DRAW);\n\t\to[o.length] = writextag(\"drawing\", null, {\"r:id\":\"rId\" + rId});\n\t\tws['!drawing'] = _drawing;\n\t}\n\n\tif(ws['!comments'].length > 0) {\n\t\trId = add_rels(rels, -1, \"../drawings/vmlDrawing\" + (idx+1) + \".vml\", RELS.VML);\n\t\to[o.length] = writextag(\"legacyDrawing\", null, {\"r:id\":\"rId\" + rId});\n\t\tws['!legacy'] = rId;\n\t}\n\n\t/* legacyDrawingHF */\n\t/* picture */\n\t/* oleObjects */\n\t/* controls */\n\t/* webPublishItems */\n\t/* tableParts */\n\t/* extLst */\n\n\tif(o.length>1) { o[o.length] = ('</worksheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSB] 2.4.726 BrtRowHdr */\nfunction parse_BrtRowHdr(data, length) {\n\tvar z = ({}/*:any*/);\n\tvar tgt = data.l + length;\n\tz.r = data.read_shift(4);\n\tdata.l += 4; // TODO: ixfe\n\tvar miyRw = data.read_shift(2);\n\tdata.l += 1; // TODO: top/bot padding\n\tvar flags = data.read_shift(1);\n\tdata.l = tgt;\n\tif(flags & 0x07) z.level = flags & 0x07;\n\tif(flags & 0x10) z.hidden = true;\n\tif(flags & 0x20) z.hpt = miyRw / 20;\n\treturn z;\n}\nfunction write_BrtRowHdr(R/*:number*/, range, ws) {\n\tvar o = new_buf(17+8*16);\n\tvar row = (ws['!rows']||[])[R]||{};\n\to.write_shift(4, R);\n\n\to.write_shift(4, 0); /* TODO: ixfe */\n\n\tvar miyRw = 0x0140;\n\tif(row.hpx) miyRw = px2pt(row.hpx) * 20;\n\telse if(row.hpt) miyRw = row.hpt * 20;\n\to.write_shift(2, miyRw);\n\n\to.write_shift(1, 0); /* top/bot padding */\n\n\tvar flags = 0x0;\n\tif(row.level) flags |= row.level;\n\tif(row.hidden) flags |= 0x10;\n\tif(row.hpx || row.hpt) flags |= 0x20;\n\to.write_shift(1, flags);\n\n\to.write_shift(1, 0); /* phonetic guide */\n\n\t/* [MS-XLSB] 2.5.8 BrtColSpan explains the mechanism */\n\tvar ncolspan = 0, lcs = o.l;\n\to.l += 4;\n\n\tvar caddr = {r:R, c:0};\n\tfor(var i = 0; i < 16; ++i) {\n\t\tif((range.s.c > ((i+1) << 10)) || (range.e.c < (i << 10))) continue;\n\t\tvar first = -1, last = -1;\n\t\tfor(var j = (i<<10); j < ((i+1)<<10); ++j) {\n\t\t\tcaddr.c = j;\n\t\t\tvar cell = Array.isArray(ws) ? (ws[caddr.r]||[])[caddr.c] : ws[encode_cell(caddr)];\n\t\t\tif(cell) { if(first < 0) first = j; last = j; }\n\t\t}\n\t\tif(first < 0) continue;\n\t\t++ncolspan;\n\t\to.write_shift(4, first);\n\t\to.write_shift(4, last);\n\t}\n\n\tvar l = o.l;\n\to.l = lcs;\n\to.write_shift(4, ncolspan);\n\to.l = l;\n\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\nfunction write_row_header(ba, ws, range, R) {\n\tvar o = write_BrtRowHdr(R, range, ws);\n\tif((o.length > 17) || (ws['!rows']||[])[R]) write_record(ba, 0x0000 /* BrtRowHdr */, o);\n}\n\n/* [MS-XLSB] 2.4.820 BrtWsDim */\nvar parse_BrtWsDim = parse_UncheckedRfX;\nvar write_BrtWsDim = write_UncheckedRfX;\n\n/* [MS-XLSB] 2.4.821 BrtWsFmtInfo */\nfunction parse_BrtWsFmtInfo(/*::data, length*/) {\n}\n//function write_BrtWsFmtInfo(ws, o) { }\n\n/* [MS-XLSB] 2.4.823 BrtWsProp */\nfunction parse_BrtWsProp(data, length) {\n\tvar z = {};\n\tvar f = data[data.l]; ++data.l;\n\tz.above = !(f & 0x40);\n\tz.left  = !(f & 0x80);\n\t/* TODO: pull flags */\n\tdata.l += 18;\n\tz.name = parse_XLSBCodeName(data, length - 19);\n\treturn z;\n}\nfunction write_BrtWsProp(str, outl, o) {\n\tif(o == null) o = new_buf(84+4*str.length);\n\tvar f = 0xC0;\n\tif(outl) {\n\t\tif(outl.above) f &= ~0x40;\n\t\tif(outl.left)  f &= ~0x80;\n\t}\n\to.write_shift(1, f);\n\tfor(var i = 1; i < 3; ++i) o.write_shift(1,0);\n\twrite_BrtColor({auto:1}, o);\n\to.write_shift(-4,-1);\n\to.write_shift(-4,-1);\n\twrite_XLSBCodeName(str, o);\n\treturn o.slice(0, o.l);\n}\n\n/* [MS-XLSB] 2.4.306 BrtCellBlank */\nfunction parse_BrtCellBlank(data) {\n\tvar cell = parse_XLSBCell(data);\n\treturn [cell];\n}\nfunction write_BrtCellBlank(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\treturn write_XLSBCell(ncell, o);\n}\nfunction parse_BrtShortBlank(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\treturn [cell];\n}\nfunction write_BrtShortBlank(cell, ncell, o) {\n\tif(o == null) o = new_buf(4);\n\treturn write_XLSBShortCell(ncell, o);\n}\n\n/* [MS-XLSB] 2.4.307 BrtCellBool */\nfunction parse_BrtCellBool(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar fBool = data.read_shift(1);\n\treturn [cell, fBool, 'b'];\n}\nfunction write_BrtCellBool(cell, ncell, o) {\n\tif(o == null) o = new_buf(9);\n\twrite_XLSBCell(ncell, o);\n\to.write_shift(1, cell.v ? 1 : 0);\n\treturn o;\n}\nfunction parse_BrtShortBool(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar fBool = data.read_shift(1);\n\treturn [cell, fBool, 'b'];\n}\nfunction write_BrtShortBool(cell, ncell, o) {\n\tif(o == null) o = new_buf(5);\n\twrite_XLSBShortCell(ncell, o);\n\to.write_shift(1, cell.v ? 1 : 0);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.308 BrtCellError */\nfunction parse_BrtCellError(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar bError = data.read_shift(1);\n\treturn [cell, bError, 'e'];\n}\nfunction write_BrtCellError(cell, ncell, o) {\n\tif(o == null) o = new_buf(9);\n\twrite_XLSBCell(ncell, o);\n\to.write_shift(1, cell.v);\n\treturn o;\n}\nfunction parse_BrtShortError(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar bError = data.read_shift(1);\n\treturn [cell, bError, 'e'];\n}\nfunction write_BrtShortError(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\twrite_XLSBShortCell(ncell, o);\n\to.write_shift(1, cell.v);\n\to.write_shift(2, 0);\n\to.write_shift(1, 0);\n\treturn o;\n}\n\n\n/* [MS-XLSB] 2.4.311 BrtCellIsst */\nfunction parse_BrtCellIsst(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar isst = data.read_shift(4);\n\treturn [cell, isst, 's'];\n}\nfunction write_BrtCellIsst(cell, ncell, o) {\n\tif(o == null) o = new_buf(12);\n\twrite_XLSBCell(ncell, o);\n\to.write_shift(4, ncell.v);\n\treturn o;\n}\nfunction parse_BrtShortIsst(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar isst = data.read_shift(4);\n\treturn [cell, isst, 's'];\n}\nfunction write_BrtShortIsst(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\twrite_XLSBShortCell(ncell, o);\n\to.write_shift(4, ncell.v);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.313 BrtCellReal */\nfunction parse_BrtCellReal(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_Xnum(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtCellReal(cell, ncell, o) {\n\tif(o == null) o = new_buf(16);\n\twrite_XLSBCell(ncell, o);\n\twrite_Xnum(cell.v, o);\n\treturn o;\n}\nfunction parse_BrtShortReal(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar value = parse_Xnum(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtShortReal(cell, ncell, o) {\n\tif(o == null) o = new_buf(12);\n\twrite_XLSBShortCell(ncell, o);\n\twrite_Xnum(cell.v, o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.314 BrtCellRk */\nfunction parse_BrtCellRk(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_RkNumber(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtCellRk(cell, ncell, o) {\n\tif(o == null) o = new_buf(12);\n\twrite_XLSBCell(ncell, o);\n\twrite_RkNumber(cell.v, o);\n\treturn o;\n}\nfunction parse_BrtShortRk(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar value = parse_RkNumber(data);\n\treturn [cell, value, 'n'];\n}\nfunction write_BrtShortRk(cell, ncell, o) {\n\tif(o == null) o = new_buf(8);\n\twrite_XLSBShortCell(ncell, o);\n\twrite_RkNumber(cell.v, o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.323 BrtCellRString */\nfunction parse_BrtCellRString(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_RichStr(data);\n\treturn [cell, value, 'is'];\n}\n\n/* [MS-XLSB] 2.4.317 BrtCellSt */\nfunction parse_BrtCellSt(data) {\n\tvar cell = parse_XLSBCell(data);\n\tvar value = parse_XLWideString(data);\n\treturn [cell, value, 'str'];\n}\nfunction write_BrtCellSt(cell, ncell, o) {\n\tif(o == null) o = new_buf(12 + 4 * cell.v.length);\n\twrite_XLSBCell(ncell, o);\n\twrite_XLWideString(cell.v, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\nfunction parse_BrtShortSt(data) {\n\tvar cell = parse_XLSBShortCell(data);\n\tvar value = parse_XLWideString(data);\n\treturn [cell, value, 'str'];\n}\nfunction write_BrtShortSt(cell, ncell, o) {\n\tif(o == null) o = new_buf(8 + 4 * cell.v.length);\n\twrite_XLSBShortCell(ncell, o);\n\twrite_XLWideString(cell.v, o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.653 BrtFmlaBool */\nfunction parse_BrtFmlaBool(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = data.read_shift(1);\n\tvar o = [cell, value, 'b'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.654 BrtFmlaError */\nfunction parse_BrtFmlaError(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = data.read_shift(1);\n\tvar o = [cell, value, 'e'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.655 BrtFmlaNum */\nfunction parse_BrtFmlaNum(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = parse_Xnum(data);\n\tvar o = [cell, value, 'n'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.656 BrtFmlaString */\nfunction parse_BrtFmlaString(data, length, opts) {\n\tvar end = data.l + length;\n\tvar cell = parse_XLSBCell(data);\n\tcell.r = opts['!row'];\n\tvar value = parse_XLWideString(data);\n\tvar o = [cell, value, 'str'];\n\tif(opts.cellFormula) {\n\t\tdata.l += 2;\n\t\tvar formula = parse_XLSBCellParsedFormula(data, end - data.l, opts);\n\t\to[3] = stringify_formula(formula, null/*range*/, cell, opts.supbooks, opts);/* TODO */\n\t}\n\telse data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.682 BrtMergeCell */\nvar parse_BrtMergeCell = parse_UncheckedRfX;\nvar write_BrtMergeCell = write_UncheckedRfX;\n/* [MS-XLSB] 2.4.107 BrtBeginMergeCells */\nfunction write_BrtBeginMergeCells(cnt, o) {\n\tif(o == null) o = new_buf(4);\n\to.write_shift(4, cnt);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.662 BrtHLink */\nfunction parse_BrtHLink(data, length/*::, opts*/) {\n\tvar end = data.l + length;\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tvar relId = parse_XLNullableWideString(data);\n\tvar loc = parse_XLWideString(data);\n\tvar tooltip = parse_XLWideString(data);\n\tvar display = parse_XLWideString(data);\n\tdata.l = end;\n\tvar o = ({rfx:rfx, relId:relId, loc:loc, display:display}/*:any*/);\n\tif(tooltip) o.Tooltip = tooltip;\n\treturn o;\n}\nfunction write_BrtHLink(l, rId) {\n\tvar o = new_buf(50+4*(l[1].Target.length + (l[1].Tooltip || \"\").length));\n\twrite_UncheckedRfX({s:decode_cell(l[0]), e:decode_cell(l[0])}, o);\n\twrite_RelID(\"rId\" + rId, o);\n\tvar locidx = l[1].Target.indexOf(\"#\");\n\tvar loc = locidx == -1 ? \"\" : l[1].Target.slice(locidx+1);\n\twrite_XLWideString(loc || \"\", o);\n\twrite_XLWideString(l[1].Tooltip || \"\", o);\n\twrite_XLWideString(\"\", o);\n\treturn o.slice(0, o.l);\n}\n\n/* [MS-XLSB] 2.4.692 BrtPane */\nfunction parse_BrtPane(/*data, length, opts*/) {\n}\n\n/* [MS-XLSB] 2.4.6 BrtArrFmla */\nfunction parse_BrtArrFmla(data, length, opts) {\n\tvar end = data.l + length;\n\tvar rfx = parse_RfX(data, 16);\n\tvar fAlwaysCalc = data.read_shift(1);\n\tvar o = [rfx]; o[2] = fAlwaysCalc;\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBArrayParsedFormula(data, end - data.l, opts);\n\t\to[1] = formula;\n\t} else data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.750 BrtShrFmla */\nfunction parse_BrtShrFmla(data, length, opts) {\n\tvar end = data.l + length;\n\tvar rfx = parse_UncheckedRfX(data, 16);\n\tvar o = [rfx];\n\tif(opts.cellFormula) {\n\t\tvar formula = parse_XLSBSharedParsedFormula(data, end - data.l, opts);\n\t\to[1] = formula;\n\t\tdata.l = end;\n\t} else data.l = end;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.323 BrtColInfo */\n/* TODO: once XLS ColInfo is set, combine the functions */\nfunction write_BrtColInfo(C/*:number*/, col, o) {\n\tif(o == null) o = new_buf(18);\n\tvar p = col_obj_w(C, col);\n\to.write_shift(-4, C);\n\to.write_shift(-4, C);\n\to.write_shift(4, (p.width || 10) * 256);\n\to.write_shift(4, 0/*ixfe*/); // style\n\tvar flags = 0;\n\tif(col.hidden) flags |= 0x01;\n\tif(typeof p.width == 'number') flags |= 0x02;\n\tif(col.level) flags |= (col.level << 8);\n\to.write_shift(2, flags); // bit flag\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.678 BrtMargins */\nvar BrtMarginKeys = [\"left\",\"right\",\"top\",\"bottom\",\"header\",\"footer\"];\nfunction parse_BrtMargins(data/*::, length, opts*/)/*:Margins*/ {\n\tvar margins = ({}/*:any*/);\n\tBrtMarginKeys.forEach(function(k) { margins[k] = parse_Xnum(data, 8); });\n\treturn margins;\n}\nfunction write_BrtMargins(margins/*:Margins*/, o) {\n\tif(o == null) o = new_buf(6*8);\n\tdefault_margins(margins);\n\tBrtMarginKeys.forEach(function(k) { write_Xnum((margins/*:any*/)[k], o); });\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.299 BrtBeginWsView */\nfunction parse_BrtBeginWsView(data/*::, length, opts*/) {\n\tvar f = data.read_shift(2);\n\tdata.l += 28;\n\treturn { RTL: f & 0x20 };\n}\nfunction write_BrtBeginWsView(ws, Workbook, o) {\n\tif(o == null) o = new_buf(30);\n\tvar f = 0x39c;\n\tif((((Workbook||{}).Views||[])[0]||{}).RTL) f |= 0x20;\n\to.write_shift(2, f); // bit flag\n\to.write_shift(4, 0);\n\to.write_shift(4, 0); // view first row\n\to.write_shift(4, 0); // view first col\n\to.write_shift(1, 0); // gridline color ICV\n\to.write_shift(1, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 100); // zoom scale\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(2, 0);\n\to.write_shift(4, 0); // workbook view id\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.309 BrtCellIgnoreEC */\nfunction write_BrtCellIgnoreEC(ref) {\n\tvar o = new_buf(24);\n\to.write_shift(4, 4);\n\to.write_shift(4, 1);\n\twrite_UncheckedRfX(ref, o);\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.748 BrtSheetProtection */\nfunction write_BrtSheetProtection(sp, o) {\n\tif(o == null) o = new_buf(16*4+2);\n\to.write_shift(2, sp.password ? crypto_CreatePasswordVerifier_Method1(sp.password) : 0);\n\to.write_shift(4, 1); // this record should not be written if no protection\n\t[\n\t\t[\"objects\",             false], // fObjects\n\t\t[\"scenarios\",           false], // fScenarios\n\t\t[\"formatCells\",          true], // fFormatCells\n\t\t[\"formatColumns\",        true], // fFormatColumns\n\t\t[\"formatRows\",           true], // fFormatRows\n\t\t[\"insertColumns\",        true], // fInsertColumns\n\t\t[\"insertRows\",           true], // fInsertRows\n\t\t[\"insertHyperlinks\",     true], // fInsertHyperlinks\n\t\t[\"deleteColumns\",        true], // fDeleteColumns\n\t\t[\"deleteRows\",           true], // fDeleteRows\n\t\t[\"selectLockedCells\",   false], // fSelLockedCells\n\t\t[\"sort\",                 true], // fSort\n\t\t[\"autoFilter\",           true], // fAutoFilter\n\t\t[\"pivotTables\",          true], // fPivotTables\n\t\t[\"selectUnlockedCells\", false]  // fSelUnlockedCells\n\t].forEach(function(n) {\n\t\t/*:: if(o == null) throw \"unreachable\"; */\n\t\tif(n[1]) o.write_shift(4, sp[n[0]] != null && !sp[n[0]] ? 1 : 0);\n\t\telse      o.write_shift(4, sp[n[0]] != null && sp[n[0]] ? 0 : 1);\n\t});\n\treturn o;\n}\n\nfunction parse_BrtDVal(/*data, length, opts*/) {\n}\nfunction parse_BrtDVal14(/*data, length, opts*/) {\n}\n/* [MS-XLSB] 2.1.7.61 Worksheet */\nfunction parse_ws_bin(data, _opts, idx, rels, wb/*:WBWBProps*/, themes, styles)/*:Worksheet*/ {\n\tif(!data) return data;\n\tvar opts = _opts || {};\n\tif(!rels) rels = {'!id':{}};\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\tvar s/*:Worksheet*/ = (opts.dense ? [] : {});\n\n\tvar ref;\n\tvar refguess = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false, end = false;\n\tvar row, p, cf, R, C, addr, sstr, rr, cell/*:Cell*/;\n\tvar merges/*:Array<Range>*/ = [];\n\topts.biff = 12;\n\topts['!row'] = 0;\n\n\tvar ai = 0, af = false;\n\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar sharedf = {};\n\tvar supbooks = opts.supbooks || /*::(*/wb/*:: :any)*/.supbooks || ([[]]/*:any*/);\n\tsupbooks.sharedf = sharedf;\n\tsupbooks.arrayf = arrayf;\n\tsupbooks.SheetNames = wb.SheetNames || wb.Sheets.map(function(x) { return x.name; });\n\tif(!opts.supbooks) {\n\t\topts.supbooks = supbooks;\n\t\tif(wb.Names) for(var i = 0; i < wb.Names.length; ++i) supbooks[0][i+1] = wb.Names[i];\n\t}\n\n\tvar colinfo/*:Array<ColInfo>*/ = [], rowinfo/*:Array<RowInfo>*/ = [];\n\tvar seencol = false;\n\n\tXLSBRecordEnum[0x0010] = { n:\"BrtShortReal\", f:parse_BrtShortReal };\n\n\tvar cm, vm;\n\n\trecordhopper(data, function ws_parse(val, RR, RT) {\n\t\tif(end) return;\n\t\tswitch(RT) {\n\t\t\tcase 0x0094: /* 'BrtWsDim' */\n\t\t\t\tref = val; break;\n\t\t\tcase 0x0000: /* 'BrtRowHdr' */\n\t\t\t\trow = val;\n\t\t\t\tif(opts.sheetRows && opts.sheetRows <= row.r) end=true;\n\t\t\t\trr = encode_row(R = row.r);\n\t\t\t\topts['!row'] = row.r;\n\t\t\t\tif(val.hidden || val.hpt || val.level != null) {\n\t\t\t\t\tif(val.hpt) val.hpx = pt2px(val.hpt);\n\t\t\t\t\trowinfo[val.r] = val;\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0002: /* 'BrtCellRk' */\n\t\t\tcase 0x0003: /* 'BrtCellError' */\n\t\t\tcase 0x0004: /* 'BrtCellBool' */\n\t\t\tcase 0x0005: /* 'BrtCellReal' */\n\t\t\tcase 0x0006: /* 'BrtCellSt' */\n\t\t\tcase 0x0007: /* 'BrtCellIsst' */\n\t\t\tcase 0x0008: /* 'BrtFmlaString' */\n\t\t\tcase 0x0009: /* 'BrtFmlaNum' */\n\t\t\tcase 0x000A: /* 'BrtFmlaBool' */\n\t\t\tcase 0x000B: /* 'BrtFmlaError' */\n\t\t\tcase 0x000D: /* 'BrtShortRk' */\n\t\t\tcase 0x000E: /* 'BrtShortError' */\n\t\t\tcase 0x000F: /* 'BrtShortBool' */\n\t\t\tcase 0x0010: /* 'BrtShortReal' */\n\t\t\tcase 0x0011: /* 'BrtShortSt' */\n\t\t\tcase 0x0012: /* 'BrtShortIsst' */\n\t\t\tcase 0x003E: /* 'BrtCellRString' */\n\t\t\t\tp = ({t:val[2]}/*:any*/);\n\t\t\t\tswitch(val[2]) {\n\t\t\t\t\tcase 'n': p.v = val[1]; break;\n\t\t\t\t\tcase 's': sstr = strs[val[1]]; p.v = sstr.t; p.r = sstr.r; break;\n\t\t\t\t\tcase 'b': p.v = val[1] ? true : false; break;\n\t\t\t\t\tcase 'e': p.v = val[1]; if(opts.cellText !== false) p.w = BErr[p.v]; break;\n\t\t\t\t\tcase 'str': p.t = 's'; p.v = val[1]; break;\n\t\t\t\t\tcase 'is': p.t = 's'; p.v = val[1].t; break;\n\t\t\t\t}\n\t\t\t\tif((cf = styles.CellXf[val[0].iStyleRef])) safe_format(p,cf.numFmtId,null,opts, themes, styles);\n\t\t\t\tC = val[0].c == -1 ? C + 1 : val[0].c;\n\t\t\t\tif(opts.dense) { if(!s[R]) s[R] = []; s[R][C] = p; }\n\t\t\t\telse s[encode_col(C) + rr] = p;\n\t\t\t\tif(opts.cellFormula) {\n\t\t\t\t\taf = false;\n\t\t\t\t\tfor(ai = 0; ai < arrayf.length; ++ai) {\n\t\t\t\t\t\tvar aii = arrayf[ai];\n\t\t\t\t\t\tif(row.r >= aii[0].s.r && row.r <= aii[0].e.r)\n\t\t\t\t\t\t\tif(C >= aii[0].s.c && C <= aii[0].e.c) {\n\t\t\t\t\t\t\t\tp.F = encode_range(aii[0]); af = true;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tif(!af && val.length > 3) p.f = val[3];\n\t\t\t\t}\n\n\t\t\t\tif(refguess.s.r > row.r) refguess.s.r = row.r;\n\t\t\t\tif(refguess.s.c > C) refguess.s.c = C;\n\t\t\t\tif(refguess.e.r < row.r) refguess.e.r = row.r;\n\t\t\t\tif(refguess.e.c < C) refguess.e.c = C;\n\t\t\t\tif(opts.cellDates && cf && p.t == 'n' && fmt_is_date(table_fmt[cf.numFmtId])) {\n\t\t\t\t\tvar _d = SSF_parse_date_code(p.v); if(_d) { p.t = 'd'; p.v = new Date(_d.y, _d.m-1,_d.d,_d.H,_d.M,_d.S,_d.u); }\n\t\t\t\t}\n\t\t\t\tif(cm) {\n\t\t\t\t\tif(cm.type == 'XLDAPR') p.D = true;\n\t\t\t\t\tcm = void 0;\n\t\t\t\t}\n\t\t\t\tif(vm) vm = void 0;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0001: /* 'BrtCellBlank' */\n\t\t\tcase 0x000C: /* 'BrtShortBlank' */\n\t\t\t\tif(!opts.sheetStubs || pass) break;\n\t\t\t\tp = ({t:'z',v:void 0}/*:any*/);\n\t\t\t\tC = val[0].c == -1 ? C + 1 : val[0].c;\n\t\t\t\tif(opts.dense) { if(!s[R]) s[R] = []; s[R][C] = p; }\n\t\t\t\telse s[encode_col(C) + rr] = p;\n\t\t\t\tif(refguess.s.r > row.r) refguess.s.r = row.r;\n\t\t\t\tif(refguess.s.c > C) refguess.s.c = C;\n\t\t\t\tif(refguess.e.r < row.r) refguess.e.r = row.r;\n\t\t\t\tif(refguess.e.c < C) refguess.e.c = C;\n\t\t\t\tif(cm) {\n\t\t\t\t\tif(cm.type == 'XLDAPR') p.D = true;\n\t\t\t\t\tcm = void 0;\n\t\t\t\t}\n\t\t\t\tif(vm) vm = void 0;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x00B0: /* 'BrtMergeCell' */\n\t\t\t\tmerges.push(val); break;\n\n\t\t\tcase 0x0031: { /* 'BrtCellMeta' */\n\t\t\t\tcm = ((opts.xlmeta||{}).Cell||[])[val-1];\n\t\t\t} break;\n\n\t\t\tcase 0x01EE: /* 'BrtHLink' */\n\t\t\t\tvar rel = rels['!id'][val.relId];\n\t\t\t\tif(rel) {\n\t\t\t\t\tval.Target = rel.Target;\n\t\t\t\t\tif(val.loc) val.Target += \"#\"+val.loc;\n\t\t\t\t\tval.Rel = rel;\n\t\t\t\t} else if(val.relId == '') {\n\t\t\t\t\tval.Target = \"#\" + val.loc;\n\t\t\t\t}\n\t\t\t\tfor(R=val.rfx.s.r;R<=val.rfx.e.r;++R) for(C=val.rfx.s.c;C<=val.rfx.e.c;++C) {\n\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\tif(!s[R]) s[R] = [];\n\t\t\t\t\t\tif(!s[R][C]) s[R][C] = {t:'z',v:undefined};\n\t\t\t\t\t\ts[R][C].l = val;\n\t\t\t\t\t} else {\n\t\t\t\t\t\taddr = encode_cell({c:C,r:R});\n\t\t\t\t\t\tif(!s[addr]) s[addr] = {t:'z',v:undefined};\n\t\t\t\t\t\ts[addr].l = val;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 0x01AA: /* 'BrtArrFmla' */\n\t\t\t\tif(!opts.cellFormula) break;\n\t\t\t\tarrayf.push(val);\n\t\t\t\tcell = ((opts.dense ? s[R][C] : s[encode_col(C) + rr])/*:any*/);\n\t\t\t\tcell.f = stringify_formula(val[1], refguess, {r:row.r, c:C}, supbooks, opts);\n\t\t\t\tcell.F = encode_range(val[0]);\n\t\t\t\tbreak;\n\t\t\tcase 0x01AB: /* 'BrtShrFmla' */\n\t\t\t\tif(!opts.cellFormula) break;\n\t\t\t\tsharedf[encode_cell(val[0].s)] = val[1];\n\t\t\t\tcell = (opts.dense ? s[R][C] : s[encode_col(C) + rr]);\n\t\t\t\tcell.f = stringify_formula(val[1], refguess, {r:row.r, c:C}, supbooks, opts);\n\t\t\t\tbreak;\n\n\t\t\t/* identical to 'ColInfo' in XLS */\n\t\t\tcase 0x003C: /* 'BrtColInfo' */\n\t\t\t\tif(!opts.cellStyles) break;\n\t\t\t\twhile(val.e >= val.s) {\n\t\t\t\t\tcolinfo[val.e--] = { width: val.w/256, hidden: !!(val.flags & 0x01), level: val.level };\n\t\t\t\t\tif(!seencol) { seencol = true; find_mdw_colw(val.w/256); }\n\t\t\t\t\tprocess_col(colinfo[val.e+1]);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 0x00A1: /* 'BrtBeginAFilter' */\n\t\t\t\ts['!autofilter'] = { ref:encode_range(val) };\n\t\t\t\tbreak;\n\n\t\t\tcase 0x01DC: /* 'BrtMargins' */\n\t\t\t\ts['!margins'] = val;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0093: /* 'BrtWsProp' */\n\t\t\t\tif(!wb.Sheets[idx]) wb.Sheets[idx] = {};\n\t\t\t\tif(val.name) wb.Sheets[idx].CodeName = val.name;\n\t\t\t\tif(val.above || val.left) s['!outline'] = { above: val.above, left: val.left };\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0089: /* 'BrtBeginWsView' */\n\t\t\t\tif(!wb.Views) wb.Views = [{}];\n\t\t\t\tif(!wb.Views[0]) wb.Views[0] = {};\n\t\t\t\tif(val.RTL) wb.Views[0].RTL = true;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x01E5: /* 'BrtWsFmtInfo' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0040: /* 'BrtDVal' */\n\t\t\tcase 0x041D: /* 'BrtDVal14' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0097: /* 'BrtPane' */\n\t\t\t\tbreak;\n\t\t\tcase 0x0098: /* 'BrtSel' */\n\t\t\tcase 0x00AF: /* 'BrtAFilterDateGroupItem' */\n\t\t\tcase 0x0284: /* 'BrtActiveX' */\n\t\t\tcase 0x0271: /* 'BrtBigName' */\n\t\t\tcase 0x0232: /* 'BrtBkHim' */\n\t\t\tcase 0x018C: /* 'BrtBrk' */\n\t\t\tcase 0x0458: /* 'BrtCFIcon' */\n\t\t\tcase 0x047A: /* 'BrtCFRuleExt' */\n\t\t\tcase 0x01D7: /* 'BrtCFVO' */\n\t\t\tcase 0x041A: /* 'BrtCFVO14' */\n\t\t\tcase 0x0289: /* 'BrtCellIgnoreEC' */\n\t\t\tcase 0x0451: /* 'BrtCellIgnoreEC14' */\n\t\t\tcase 0x024D: /* 'BrtCellSmartTagProperty' */\n\t\t\tcase 0x025F: /* 'BrtCellWatch' */\n\t\t\tcase 0x0234: /* 'BrtColor' */\n\t\t\tcase 0x041F: /* 'BrtColor14' */\n\t\t\tcase 0x00A8: /* 'BrtColorFilter' */\n\t\t\tcase 0x00AE: /* 'BrtCustomFilter' */\n\t\t\tcase 0x049C: /* 'BrtCustomFilter14' */\n\t\t\tcase 0x01F3: /* 'BrtDRef' */\n\t\t\tcase 0x01FB: /* 'BrtDXF' */\n\t\t\tcase 0x0226: /* 'BrtDrawing' */\n\t\t\tcase 0x00AB: /* 'BrtDynamicFilter' */\n\t\t\tcase 0x00A7: /* 'BrtFilter' */\n\t\t\tcase 0x0499: /* 'BrtFilter14' */\n\t\t\tcase 0x00A9: /* 'BrtIconFilter' */\n\t\t\tcase 0x049D: /* 'BrtIconFilter14' */\n\t\t\tcase 0x0227: /* 'BrtLegacyDrawing' */\n\t\t\tcase 0x0228: /* 'BrtLegacyDrawingHF' */\n\t\t\tcase 0x0295: /* 'BrtListPart' */\n\t\t\tcase 0x027F: /* 'BrtOleObject' */\n\t\t\tcase 0x01DE: /* 'BrtPageSetup' */\n\t\t\tcase 0x0219: /* 'BrtPhoneticInfo' */\n\t\t\tcase 0x01DD: /* 'BrtPrintOptions' */\n\t\t\tcase 0x0218: /* 'BrtRangeProtection' */\n\t\t\tcase 0x044F: /* 'BrtRangeProtection14' */\n\t\t\tcase 0x02A8: /* 'BrtRangeProtectionIso' */\n\t\t\tcase 0x0450: /* 'BrtRangeProtectionIso14' */\n\t\t\tcase 0x0400: /* 'BrtRwDescent' */\n\t\t\tcase 0x0297: /* 'BrtSheetCalcProp' */\n\t\t\tcase 0x0217: /* 'BrtSheetProtection' */\n\t\t\tcase 0x02A6: /* 'BrtSheetProtectionIso' */\n\t\t\tcase 0x01F8: /* 'BrtSlc' */\n\t\t\tcase 0x0413: /* 'BrtSparkline' */\n\t\t\tcase 0x01AC: /* 'BrtTable' */\n\t\t\tcase 0x00AA: /* 'BrtTop10Filter' */\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\tcase 0x0032: /* 'BrtValueMeta' */\n\t\t\tcase 0x0816: /* 'BrtWebExtension' */\n\t\t\tcase 0x0415: /* 'BrtWsFmtInfoEx14' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */\n\t\t\t\tstate.pop(); pass = false; break;\n\n\t\t\tdefault:\n\t\t\t\tif(RR.T){/* empty */}\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n\n\tdelete opts.supbooks;\n\tdelete opts['!row'];\n\n\tif(!s[\"!ref\"] && (refguess.s.r < 2000000 || ref && (ref.e.r > 0 || ref.e.c > 0 || ref.s.r > 0 || ref.s.c > 0))) s[\"!ref\"] = encode_range(ref || refguess);\n\tif(opts.sheetRows && s[\"!ref\"]) {\n\t\tvar tmpref = safe_decode_range(s[\"!ref\"]);\n\t\tif(opts.sheetRows <= +tmpref.e.r) {\n\t\t\ttmpref.e.r = opts.sheetRows - 1;\n\t\t\tif(tmpref.e.r > refguess.e.r) tmpref.e.r = refguess.e.r;\n\t\t\tif(tmpref.e.r < tmpref.s.r) tmpref.s.r = tmpref.e.r;\n\t\t\tif(tmpref.e.c > refguess.e.c) tmpref.e.c = refguess.e.c;\n\t\t\tif(tmpref.e.c < tmpref.s.c) tmpref.s.c = tmpref.e.c;\n\t\t\ts[\"!fullref\"] = s[\"!ref\"];\n\t\t\ts[\"!ref\"] = encode_range(tmpref);\n\t\t}\n\t}\n\tif(merges.length > 0) s[\"!merges\"] = merges;\n\tif(colinfo.length > 0) s[\"!cols\"] = colinfo;\n\tif(rowinfo.length > 0) s[\"!rows\"] = rowinfo;\n\treturn s;\n}\n\n/* TODO: something useful -- this is a stub */\nfunction write_ws_bin_cell(ba/*:BufArray*/, cell/*:Cell*/, R/*:number*/, C/*:number*/, opts, ws/*:Worksheet*/, last_seen/*:boolean*/)/*:boolean*/ {\n\tif(cell.v === undefined) return false;\n\tvar vv = \"\";\n\tswitch(cell.t) {\n\t\tcase 'b': vv = cell.v ? \"1\" : \"0\"; break;\n\t\tcase 'd': // no BrtCellDate :(\n\t\t\tcell = dup(cell);\n\t\t\tcell.z = cell.z || table_fmt[14];\n\t\t\tcell.v = datenum(parseDate(cell.v)); cell.t = 'n';\n\t\t\tbreak;\n\t\t/* falls through */\n\t\tcase 'n': case 'e': vv = ''+cell.v; break;\n\t\tdefault: vv = cell.v; break;\n\t}\n\tvar o/*:any*/ = ({r:R, c:C}/*:any*/);\n\t/* TODO: cell style */\n\to.s = get_cell_style(opts.cellXfs, cell, opts);\n\tif(cell.l) ws['!links'].push([encode_cell(o), cell.l]);\n\tif(cell.c) ws['!comments'].push([encode_cell(o), cell.c]);\n\tswitch(cell.t) {\n\t\tcase 's': case 'str':\n\t\t\tif(opts.bookSST) {\n\t\t\t\tvv = get_sst_id(opts.Strings, (cell.v/*:any*/), opts.revStrings);\n\t\t\t\to.t = \"s\"; o.v = vv;\n\t\t\t\tif(last_seen) write_record(ba, 0x0012 /* BrtShortIsst */, write_BrtShortIsst(cell, o));\n\t\t\t\telse write_record(ba, 0x0007 /* BrtCellIsst */, write_BrtCellIsst(cell, o));\n\t\t\t} else {\n\t\t\t\to.t = \"str\";\n\t\t\t\tif(last_seen) write_record(ba, 0x0011 /* BrtShortSt */, write_BrtShortSt(cell, o));\n\t\t\t\telse write_record(ba, 0x0006 /* BrtCellSt */, write_BrtCellSt(cell, o));\n\t\t\t}\n\t\t\treturn true;\n\t\tcase 'n':\n\t\t\t/* TODO: determine threshold for Real vs RK */\n\t\t\tif(cell.v == (cell.v | 0) && cell.v > -1000 && cell.v < 1000) {\n\t\t\t\tif(last_seen) write_record(ba, 0x000D /* BrtShortRk */, write_BrtShortRk(cell, o));\n\t\t\t\telse write_record(ba, 0x0002 /* BrtCellRk */, write_BrtCellRk(cell, o));\n\t\t\t} else {\n\t\t\t\tif(last_seen) write_record(ba, 0x0010 /* BrtShortReal */, write_BrtShortReal(cell, o));\n\t\t\t\telse write_record(ba, 0x0005 /* BrtCellReal */, write_BrtCellReal(cell, o));\n\t\t\t} return true;\n\t\tcase 'b':\n\t\t\to.t = \"b\";\n\t\t\tif(last_seen) write_record(ba, 0x000F /* BrtShortBool */, write_BrtShortBool(cell, o));\n\t\t\telse write_record(ba, 0x0004 /* BrtCellBool */, write_BrtCellBool(cell, o));\n\t\t\treturn true;\n\t\tcase 'e':\n\t\t\to.t = \"e\";\n\t\t\tif(last_seen) write_record(ba, 0x000E /* BrtShortError */, write_BrtShortError(cell, o));\n\t\t\telse write_record(ba, 0x0003 /* BrtCellError */, write_BrtCellError(cell, o));\n\t\t\treturn true;\n\t}\n\tif(last_seen) write_record(ba, 0x000C /* BrtShortBlank */, write_BrtShortBlank(cell, o));\n\telse write_record(ba, 0x0001 /* BrtCellBlank */, write_BrtCellBlank(cell, o));\n\treturn true;\n}\n\nfunction write_CELLTABLE(ba, ws/*:Worksheet*/, idx/*:number*/, opts/*::, wb:Workbook*/) {\n\tvar range = safe_decode_range(ws['!ref'] || \"A1\"), ref, rr = \"\", cols/*:Array<string>*/ = [];\n\twrite_record(ba, 0x0091 /* BrtBeginSheetData */);\n\tvar dense = Array.isArray(ws);\n\tvar cap = range.e.r;\n\tif(ws['!rows']) cap = Math.max(range.e.r, ws['!rows'].length - 1);\n\tfor(var R = range.s.r; R <= cap; ++R) {\n\t\trr = encode_row(R);\n\t\t/* [ACCELLTABLE] */\n\t\t/* BrtRowHdr */\n\t\twrite_row_header(ba, ws, range, R);\n\t\tvar last_seen = false;\n\t\tif(R <= range.e.r) for(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\t/* *16384CELL */\n\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\tref = cols[C] + rr;\n\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\tif(!cell) { last_seen = false; continue; }\n\t\t\t/* write cell */\n\t\t\tlast_seen = write_ws_bin_cell(ba, cell, R, C, opts, ws, last_seen);\n\t\t}\n\t}\n\twrite_record(ba, 0x0092 /* BrtEndSheetData */);\n}\n\nfunction write_MERGECELLS(ba, ws/*:Worksheet*/) {\n\tif(!ws || !ws['!merges']) return;\n\twrite_record(ba, 0x00B1 /* BrtBeginMergeCells */, write_BrtBeginMergeCells(ws['!merges'].length));\n\tws['!merges'].forEach(function(m) { write_record(ba, 0x00B0 /* BrtMergeCell */, write_BrtMergeCell(m)); });\n\twrite_record(ba, 0x00B2 /* BrtEndMergeCells */);\n}\n\nfunction write_COLINFOS(ba, ws/*:Worksheet*//*::, idx:number, opts, wb:Workbook*/) {\n\tif(!ws || !ws['!cols']) return;\n\twrite_record(ba, 0x0186 /* BrtBeginColInfos */);\n\tws['!cols'].forEach(function(m, i) { if(m) write_record(ba, 0x003C /* 'BrtColInfo' */, write_BrtColInfo(i, m)); });\n\twrite_record(ba, 0x0187 /* BrtEndColInfos */);\n}\n\nfunction write_IGNOREECS(ba, ws/*:Worksheet*/) {\n\tif(!ws || !ws['!ref']) return;\n\twrite_record(ba, 0x0288 /* BrtBeginCellIgnoreECs */);\n\twrite_record(ba, 0x0289 /* BrtCellIgnoreEC */, write_BrtCellIgnoreEC(safe_decode_range(ws['!ref'])));\n\twrite_record(ba, 0x028A /* BrtEndCellIgnoreECs */);\n}\n\nfunction write_HLINKS(ba, ws/*:Worksheet*/, rels) {\n\t/* *BrtHLink */\n\tws['!links'].forEach(function(l) {\n\t\tif(!l[1].Target) return;\n\t\tvar rId = add_rels(rels, -1, l[1].Target.replace(/#.*$/, \"\"), RELS.HLINK);\n\t\twrite_record(ba, 0x01EE /* BrtHLink */, write_BrtHLink(l, rId));\n\t});\n\tdelete ws['!links'];\n}\nfunction write_LEGACYDRAWING(ba, ws/*:Worksheet*/, idx/*:number*/, rels) {\n\t/* [BrtLegacyDrawing] */\n\tif(ws['!comments'].length > 0) {\n\t\tvar rId = add_rels(rels, -1, \"../drawings/vmlDrawing\" + (idx+1) + \".vml\", RELS.VML);\n\t\twrite_record(ba, 0x0227 /* BrtLegacyDrawing */, write_RelID(\"rId\" + rId));\n\t\tws['!legacy'] = rId;\n\t}\n}\n\nfunction write_AUTOFILTER(ba, ws, wb, idx) {\n\tif(!ws['!autofilter']) return;\n\tvar data = ws['!autofilter'];\n\tvar ref = typeof data.ref === \"string\" ? data.ref : encode_range(data.ref);\n\n\t/* Update FilterDatabase defined name for the worksheet */\n\tif(!wb.Workbook) wb.Workbook = ({Sheets:[]}/*:any*/);\n\tif(!wb.Workbook.Names) wb.Workbook.Names = [];\n\tvar names/*: Array<any> */ = wb.Workbook.Names;\n\tvar range = decode_range(ref);\n\tif(range.s.r == range.e.r) { range.e.r = decode_range(ws[\"!ref\"]).e.r; ref = encode_range(range); }\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar name = names[i];\n\t\tif(name.Name != '_xlnm._FilterDatabase') continue;\n\t\tif(name.Sheet != idx) continue;\n\t\tname.Ref = \"'\" + wb.SheetNames[idx] + \"'!\" + ref; break;\n\t}\n\tif(i == names.length) names.push({ Name: '_xlnm._FilterDatabase', Sheet: idx, Ref: \"'\" + wb.SheetNames[idx] + \"'!\" + ref  });\n\n\twrite_record(ba, 0x00A1 /* BrtBeginAFilter */, write_UncheckedRfX(safe_decode_range(ref)));\n\t/* *FILTERCOLUMN */\n\t/* [SORTSTATE] */\n\t/* BrtEndAFilter */\n\twrite_record(ba, 0x00A2 /* BrtEndAFilter */);\n}\n\nfunction write_WSVIEWS2(ba, ws, Workbook) {\n\twrite_record(ba, 0x0085 /* BrtBeginWsViews */);\n\t{ /* 1*WSVIEW2 */\n\t\t/* [ACUID] */\n\t\twrite_record(ba, 0x0089 /* BrtBeginWsView */, write_BrtBeginWsView(ws, Workbook));\n\t\t/* [BrtPane] */\n\t\t/* *4BrtSel */\n\t\t/* *4SXSELECT */\n\t\t/* *FRT */\n\t\twrite_record(ba, 0x008A /* BrtEndWsView */);\n\t}\n\t/* *FRT */\n\twrite_record(ba, 0x0086 /* BrtEndWsViews */);\n}\n\nfunction write_WSFMTINFO(/*::ba, ws*/) {\n\t/* [ACWSFMTINFO] */\n\t// write_record(ba, 0x01E5 /* BrtWsFmtInfo */, write_BrtWsFmtInfo(ws));\n}\n\nfunction write_SHEETPROTECT(ba, ws) {\n\tif(!ws['!protect']) return;\n\t/* [BrtSheetProtectionIso] */\n\twrite_record(ba, 0x0217 /* BrtSheetProtection */, write_BrtSheetProtection(ws['!protect']));\n}\n\nfunction write_ws_bin(idx/*:number*/, opts, wb/*:Workbook*/, rels) {\n\tvar ba = buf_array();\n\tvar s = wb.SheetNames[idx], ws = wb.Sheets[s] || {};\n\tvar c/*:string*/ = s; try { if(wb && wb.Workbook) c = wb.Workbook.Sheets[idx].CodeName || c; } catch(e) {}\n\tvar r = safe_decode_range(ws['!ref'] || \"A1\");\n\tif(r.e.c > 0x3FFF || r.e.r > 0xFFFFF) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + (ws['!ref'] || \"A1\") + \" exceeds format limit A1:XFD1048576\");\n\t\tr.e.c = Math.min(r.e.c, 0x3FFF);\n\t\tr.e.r = Math.min(r.e.c, 0xFFFFF);\n\t}\n\tws['!links'] = [];\n\t/* passed back to write_zip and removed there */\n\tws['!comments'] = [];\n\twrite_record(ba, 0x0081 /* BrtBeginSheet */);\n\tif(wb.vbaraw || ws['!outline']) write_record(ba, 0x0093 /* BrtWsProp */, write_BrtWsProp(c, ws['!outline']));\n\twrite_record(ba, 0x0094 /* BrtWsDim */, write_BrtWsDim(r));\n\twrite_WSVIEWS2(ba, ws, wb.Workbook);\n\twrite_WSFMTINFO(ba, ws);\n\twrite_COLINFOS(ba, ws, idx, opts, wb);\n\twrite_CELLTABLE(ba, ws, idx, opts, wb);\n\t/* [BrtSheetCalcProp] */\n\twrite_SHEETPROTECT(ba, ws);\n\t/* *([BrtRangeProtectionIso] BrtRangeProtection) */\n\t/* [SCENMAN] */\n\twrite_AUTOFILTER(ba, ws, wb, idx);\n\t/* [SORTSTATE] */\n\t/* [DCON] */\n\t/* [USERSHVIEWS] */\n\twrite_MERGECELLS(ba, ws);\n\t/* [BrtPhoneticInfo] */\n\t/* *CONDITIONALFORMATTING */\n\t/* [DVALS] */\n\twrite_HLINKS(ba, ws, rels);\n\t/* [BrtPrintOptions] */\n\tif(ws['!margins']) write_record(ba, 0x01DC /* BrtMargins */, write_BrtMargins(ws['!margins']));\n\t/* [BrtPageSetup] */\n\t/* [HEADERFOOTER] */\n\t/* [RWBRK] */\n\t/* [COLBRK] */\n\t/* *BrtBigName */\n\t/* [CELLWATCHES] */\n\tif(!opts || opts.ignoreEC || (opts.ignoreEC == (void 0))) write_IGNOREECS(ba, ws);\n\t/* [SMARTTAGS] */\n\t/* [BrtDrawing] */\n\twrite_LEGACYDRAWING(ba, ws, idx, rels);\n\t/* [BrtLegacyDrawingHF] */\n\t/* [BrtBkHim] */\n\t/* [OLEOBJECTS] */\n\t/* [ACTIVEXCONTROLS] */\n\t/* [WEBPUBITEMS] */\n\t/* [LISTPARTS] */\n\t/* FRTWORKSHEET */\n\twrite_record(ba, 0x0082 /* BrtEndSheet */);\n\treturn ba.end();\n}\nfunction parse_Cache(data/*:string*/)/*:[Array<number|string>, string, ?string]*/ {\n\tvar col/*:Array<number|string>*/ = [];\n\tvar num = data.match(/^<c:numCache>/);\n\tvar f;\n\n\t/* 21.2.2.150 pt CT_NumVal */\n\t(data.match(/<c:pt idx=\"(\\d*)\">(.*?)<\\/c:pt>/mg)||[]).forEach(function(pt) {\n\t\tvar q = pt.match(/<c:pt idx=\"(\\d*?)\"><c:v>(.*)<\\/c:v><\\/c:pt>/);\n\t\tif(!q) return;\n\t\tcol[+q[1]] = num ? +q[2] : q[2];\n\t});\n\n\t/* 21.2.2.71 formatCode CT_Xstring */\n\tvar nf = unescapexml((data.match(/<c:formatCode>([\\s\\S]*?)<\\/c:formatCode>/) || [\"\",\"General\"])[1]);\n\n\t(data.match(/<c:f>(.*?)<\\/c:f>/mg)||[]).forEach(function(F) { f = F.replace(/<.*?>/g,\"\"); });\n\n\treturn [col, nf, f];\n}\n\n/* 21.2 DrawingML - Charts */\nfunction parse_chart(data/*:?string*/, name/*:string*/, opts, rels, wb, csheet) {\n\tvar cs/*:Worksheet*/ = ((csheet || {\"!type\":\"chart\"})/*:any*/);\n\tif(!data) return csheet;\n\t/* 21.2.2.27 chart CT_Chart */\n\n\tvar C = 0, R = 0, col = \"A\";\n\tvar refguess = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\n\t/* 21.2.2.120 numCache CT_NumData */\n\t(data.match(/<c:numCache>[\\s\\S]*?<\\/c:numCache>/gm)||[]).forEach(function(nc) {\n\t\tvar cache = parse_Cache(nc);\n\t\trefguess.s.r = refguess.s.c = 0;\n\t\trefguess.e.c = C;\n\t\tcol = encode_col(C);\n\t\tcache[0].forEach(function(n,i) {\n\t\t\tcs[col + encode_row(i)] = {t:'n', v:n, z:cache[1] };\n\t\t\tR = i;\n\t\t});\n\t\tif(refguess.e.r < R) refguess.e.r = R;\n\t\t++C;\n\t});\n\tif(C > 0) cs[\"!ref\"] = encode_range(refguess);\n\treturn cs;\n}\n/* 18.3 Worksheets also covers Chartsheets */\nfunction parse_cs_xml(data/*:?string*/, opts, idx/*:number*/, rels, wb/*::, themes, styles*/)/*:Worksheet*/ {\n\tif(!data) return data;\n\t/* 18.3.1.12 chartsheet CT_ChartSheet */\n\tif(!rels) rels = {'!id':{}};\n\tvar s = ({'!type':\"chart\", '!drawel':null, '!rel':\"\"}/*:any*/);\n\tvar m;\n\n\t/* 18.3.1.83 sheetPr CT_ChartsheetPr */\n\tvar sheetPr = data.match(sheetprregex);\n\tif(sheetPr) parse_ws_xml_sheetpr(sheetPr[0], s, wb, idx);\n\n\t/* 18.3.1.36 drawing CT_Drawing */\n\tif((m = data.match(/drawing r:id=\"(.*?)\"/))) s['!rel'] = m[1];\n\n\tif(rels['!id'][s['!rel']]) s['!drawel'] = rels['!id'][s['!rel']];\n\treturn s;\n}\nfunction write_cs_xml(idx/*:number*/, opts, wb/*:Workbook*/, rels)/*:string*/ {\n\tvar o = [XML_HEADER, writextag('chartsheet', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t'xmlns:r': XMLNS.r\n\t})];\n\to[o.length] = writextag(\"drawing\", null, {\"r:id\": \"rId1\"});\n\tadd_rels(rels, -1, \"../drawings/drawing\" + (idx+1) + \".xml\", RELS.DRAW);\n\tif(o.length>2) { o[o.length] = ('</chartsheet>'); o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n\n/* [MS-XLSB] 2.4.331 BrtCsProp */\nfunction parse_BrtCsProp(data, length/*:number*/) {\n\tdata.l += 10;\n\tvar name = parse_XLWideString(data, length - 10);\n\treturn { name: name };\n}\n\n/* [MS-XLSB] 2.1.7.7 Chart Sheet */\nfunction parse_cs_bin(data, opts, idx/*:number*/, rels, wb/*::, themes, styles*/)/*:Worksheet*/ {\n\tif(!data) return data;\n\tif(!rels) rels = {'!id':{}};\n\tvar s = {'!type':\"chart\", '!drawel':null, '!rel':\"\"};\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false;\n\trecordhopper(data, function cs_parse(val, R, RT) {\n\t\tswitch(RT) {\n\n\t\t\tcase 0x0226: /* 'BrtDrawing' */\n\t\t\t\ts['!rel'] = val; break;\n\n\t\t\tcase 0x028B: /* 'BrtCsProp' */\n\t\t\t\tif(!wb.Sheets[idx]) wb.Sheets[idx] = {};\n\t\t\t\tif(val.name) wb.Sheets[idx].CodeName = val.name;\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0232: /* 'BrtBkHim' */\n\t\t\tcase 0x028C: /* 'BrtCsPageSetup' */\n\t\t\tcase 0x029D: /* 'BrtCsProtection' */\n\t\t\tcase 0x02A7: /* 'BrtCsProtectionIso' */\n\t\t\tcase 0x0227: /* 'BrtLegacyDrawing' */\n\t\t\tcase 0x0228: /* 'BrtLegacyDrawingHF' */\n\t\t\tcase 0x01DC: /* 'BrtMargins' */\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tpass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tpass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */\n\t\t\t\tstate.push(RT); break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */\n\t\t\t\tstate.pop(); break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T > 0) state.push(RT);\n\t\t\t\telse if(R.T < 0) state.pop();\n\t\t\t\telse if(!pass || opts.WTF) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n\n\tif(rels['!id'][s['!rel']]) s['!drawel'] = rels['!id'][s['!rel']];\n\treturn s;\n}\nfunction write_cs_bin(/*::idx:number, opts, wb:Workbook, rels*/) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x0081 /* BrtBeginSheet */);\n\t/* [BrtCsProp] */\n\t/* CSVIEWS */\n\t/* [[BrtCsProtectionIso] BrtCsProtection] */\n\t/* [USERCSVIEWS] */\n\t/* [BrtMargins] */\n\t/* [BrtCsPageSetup] */\n\t/* [HEADERFOOTER] */\n\t/* BrtDrawing */\n\t/* [BrtLegacyDrawing] */\n\t/* [BrtLegacyDrawingHF] */\n\t/* [BrtBkHim] */\n\t/* [WEBPUBITEMS] */\n\t/* FRTCHARTSHEET */\n\twrite_record(ba, 0x0082 /* BrtEndSheet */);\n\treturn ba.end();\n}\n/* 18.2.28 (CT_WorkbookProtection) Defaults */\nvar WBPropsDef = [\n\t['allowRefreshQuery',           false, \"bool\"],\n\t['autoCompressPictures',        true,  \"bool\"],\n\t['backupFile',                  false, \"bool\"],\n\t['checkCompatibility',          false, \"bool\"],\n\t['CodeName',                    ''],\n\t['date1904',                    false, \"bool\"],\n\t['defaultThemeVersion',         0,      \"int\"],\n\t['filterPrivacy',               false, \"bool\"],\n\t['hidePivotFieldList',          false, \"bool\"],\n\t['promptedSolutions',           false, \"bool\"],\n\t['publishItems',                false, \"bool\"],\n\t['refreshAllConnections',       false, \"bool\"],\n\t['saveExternalLinkValues',      true,  \"bool\"],\n\t['showBorderUnselectedTables',  true,  \"bool\"],\n\t['showInkAnnotation',           true,  \"bool\"],\n\t['showObjects',                 'all'],\n\t['showPivotChartFilter',        false, \"bool\"],\n\t['updateLinks', 'userSet']\n];\n\n/* 18.2.30 (CT_BookView) Defaults */\nvar WBViewDef = [\n\t['activeTab',                   0,      \"int\"],\n\t['autoFilterDateGrouping',      true,  \"bool\"],\n\t['firstSheet',                  0,      \"int\"],\n\t['minimized',                   false, \"bool\"],\n\t['showHorizontalScroll',        true,  \"bool\"],\n\t['showSheetTabs',               true,  \"bool\"],\n\t['showVerticalScroll',          true,  \"bool\"],\n\t['tabRatio',                    600,    \"int\"],\n\t['visibility',                  'visible']\n\t//window{Height,Width}, {x,y}Window\n];\n\n/* 18.2.19 (CT_Sheet) Defaults */\nvar SheetDef = [\n\t//['state', 'visible']\n];\n\n/* 18.2.2  (CT_CalcPr) Defaults */\nvar CalcPrDef = [\n\t['calcCompleted', 'true'],\n\t['calcMode', 'auto'],\n\t['calcOnSave', 'true'],\n\t['concurrentCalc', 'true'],\n\t['fullCalcOnLoad', 'false'],\n\t['fullPrecision', 'true'],\n\t['iterate', 'false'],\n\t['iterateCount', '100'],\n\t['iterateDelta', '0.001'],\n\t['refMode', 'A1']\n];\n\n/* 18.2.3 (CT_CustomWorkbookView) Defaults */\n/*var CustomWBViewDef = [\n\t['autoUpdate', 'false'],\n\t['changesSavedWin', 'false'],\n\t['includeHiddenRowCol', 'true'],\n\t['includePrintSettings', 'true'],\n\t['maximized', 'false'],\n\t['minimized', 'false'],\n\t['onlySync', 'false'],\n\t['personalView', 'false'],\n\t['showComments', 'commIndicator'],\n\t['showFormulaBar', 'true'],\n\t['showHorizontalScroll', 'true'],\n\t['showObjects', 'all'],\n\t['showSheetTabs', 'true'],\n\t['showStatusbar', 'true'],\n\t['showVerticalScroll', 'true'],\n\t['tabRatio', '600'],\n\t['xWindow', '0'],\n\t['yWindow', '0']\n];*/\n\nfunction push_defaults_array(target, defaults) {\n\tfor(var j = 0; j != target.length; ++j) { var w = target[j];\n\t\tfor(var i=0; i != defaults.length; ++i) { var z = defaults[i];\n\t\t\tif(w[z[0]] == null) w[z[0]] = z[1];\n\t\t\telse switch(z[2]) {\n\t\t\tcase \"bool\": if(typeof w[z[0]] == \"string\") w[z[0]] = parsexmlbool(w[z[0]]); break;\n\t\t\tcase \"int\": if(typeof w[z[0]] == \"string\") w[z[0]] = parseInt(w[z[0]], 10); break;\n\t\t\t}\n\t\t}\n\t}\n}\nfunction push_defaults(target, defaults) {\n\tfor(var i = 0; i != defaults.length; ++i) { var z = defaults[i];\n\t\tif(target[z[0]] == null) target[z[0]] = z[1];\n\t\telse switch(z[2]) {\n\t\t\tcase \"bool\": if(typeof target[z[0]] == \"string\") target[z[0]] = parsexmlbool(target[z[0]]); break;\n\t\t\tcase \"int\": if(typeof target[z[0]] == \"string\") target[z[0]] = parseInt(target[z[0]], 10); break;\n\t\t}\n\t}\n}\n\nfunction parse_wb_defaults(wb) {\n\tpush_defaults(wb.WBProps, WBPropsDef);\n\tpush_defaults(wb.CalcPr, CalcPrDef);\n\n\tpush_defaults_array(wb.WBView, WBViewDef);\n\tpush_defaults_array(wb.Sheets, SheetDef);\n\n\t_ssfopts.date1904 = parsexmlbool(wb.WBProps.date1904);\n}\n\nfunction safe1904(wb/*:Workbook*/)/*:string*/ {\n\t/* TODO: store date1904 somewhere else */\n\tif(!wb.Workbook) return \"false\";\n\tif(!wb.Workbook.WBProps) return \"false\";\n\treturn parsexmlbool(wb.Workbook.WBProps.date1904) ? \"true\" : \"false\";\n}\n\nvar badchars = /*#__PURE__*/\"][*?\\/\\\\\".split(\"\");\nfunction check_ws_name(n/*:string*/, safe/*:?boolean*/)/*:boolean*/ {\n\tif(n.length > 31) { if(safe) return false; throw new Error(\"Sheet names cannot exceed 31 chars\"); }\n\tvar _good = true;\n\tbadchars.forEach(function(c) {\n\t\tif(n.indexOf(c) == -1) return;\n\t\tif(!safe) throw new Error(\"Sheet name cannot contain : \\\\ / ? * [ ]\");\n\t\t_good = false;\n\t});\n\treturn _good;\n}\nfunction check_wb_names(N, S, codes) {\n\tN.forEach(function(n,i) {\n\t\tcheck_ws_name(n);\n\t\tfor(var j = 0; j < i; ++j) if(n == N[j]) throw new Error(\"Duplicate Sheet Name: \" + n);\n\t\tif(codes) {\n\t\t\tvar cn = (S && S[i] && S[i].CodeName) || n;\n\t\t\tif(cn.charCodeAt(0) == 95 && cn.length > 22) throw new Error(\"Bad Code Name: Worksheet\" + cn);\n\t\t}\n\t});\n}\nfunction check_wb(wb) {\n\tif(!wb || !wb.SheetNames || !wb.Sheets) throw new Error(\"Invalid Workbook\");\n\tif(!wb.SheetNames.length) throw new Error(\"Workbook is empty\");\n\tvar Sheets = (wb.Workbook && wb.Workbook.Sheets) || [];\n\tcheck_wb_names(wb.SheetNames, Sheets, !!wb.vbaraw);\n\tfor(var i = 0; i < wb.SheetNames.length; ++i) check_ws(wb.Sheets[wb.SheetNames[i]], wb.SheetNames[i], i);\n\t/* TODO: validate workbook */\n}\n/* 18.2 Workbook */\nvar wbnsregex = /<\\w+:workbook/;\nfunction parse_wb_xml(data, opts)/*:WorkbookFile*/ {\n\tif(!data) throw new Error(\"Could not find file\");\n\tvar wb = /*::(*/{ AppVersion:{}, WBProps:{}, WBView:[], Sheets:[], CalcPr:{}, Names:[], xmlns: \"\" }/*::)*/;\n\tvar pass = false, xmlns = \"xmlns\";\n\tvar dname = {}, dnstart = 0;\n\tdata.replace(tagregex, function xml_wb(x, idx) {\n\t\tvar y/*:any*/ = parsexmltag(x);\n\t\tswitch(strip_ns(y[0])) {\n\t\t\tcase '<?xml': break;\n\n\t\t\t/* 18.2.27 workbook CT_Workbook 1 */\n\t\t\tcase '<workbook':\n\t\t\t\tif(x.match(wbnsregex)) xmlns = \"xmlns\" + x.match(/<(\\w+):/)[1];\n\t\t\t\twb.xmlns = y[xmlns];\n\t\t\t\tbreak;\n\t\t\tcase '</workbook>': break;\n\n\t\t\t/* 18.2.13 fileVersion CT_FileVersion ? */\n\t\t\tcase '<fileVersion': delete y[0]; wb.AppVersion = y; break;\n\t\t\tcase '<fileVersion/>': case '</fileVersion>': break;\n\n\t\t\t/* 18.2.12 fileSharing CT_FileSharing ? */\n\t\t\tcase '<fileSharing':\n\t\t\t\tbreak;\n\t\t\tcase '<fileSharing/>': break;\n\n\t\t\t/* 18.2.28 workbookPr CT_WorkbookPr ? */\n\t\t\tcase '<workbookPr':\n\t\t\tcase '<workbookPr/>':\n\t\t\t\tWBPropsDef.forEach(function(w) {\n\t\t\t\t\tif(y[w[0]] == null) return;\n\t\t\t\t\tswitch(w[2]) {\n\t\t\t\t\t\tcase \"bool\": wb.WBProps[w[0]] = parsexmlbool(y[w[0]]); break;\n\t\t\t\t\t\tcase \"int\": wb.WBProps[w[0]] = parseInt(y[w[0]], 10); break;\n\t\t\t\t\t\tdefault: wb.WBProps[w[0]] = y[w[0]];\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tif(y.codeName) wb.WBProps.CodeName = utf8read(y.codeName);\n\t\t\t\tbreak;\n\t\t\tcase '</workbookPr>': break;\n\n\t\t\t/* 18.2.29 workbookProtection CT_WorkbookProtection ? */\n\t\t\tcase '<workbookProtection':\n\t\t\t\tbreak;\n\t\t\tcase '<workbookProtection/>': break;\n\n\t\t\t/* 18.2.1  bookViews CT_BookViews ? */\n\t\t\tcase '<bookViews': case '<bookViews>': case '</bookViews>': break;\n\t\t\t/* 18.2.30   workbookView CT_BookView + */\n\t\t\tcase '<workbookView': case '<workbookView/>': delete y[0]; wb.WBView.push(y); break;\n\t\t\tcase '</workbookView>': break;\n\n\t\t\t/* 18.2.20 sheets CT_Sheets 1 */\n\t\t\tcase '<sheets': case '<sheets>': case '</sheets>': break; // aggregate sheet\n\t\t\t/* 18.2.19   sheet CT_Sheet + */\n\t\t\tcase '<sheet':\n\t\t\t\tswitch(y.state) {\n\t\t\t\t\tcase \"hidden\": y.Hidden = 1; break;\n\t\t\t\t\tcase \"veryHidden\": y.Hidden = 2; break;\n\t\t\t\t\tdefault: y.Hidden = 0;\n\t\t\t\t}\n\t\t\t\tdelete y.state;\n\t\t\t\ty.name = unescapexml(utf8read(y.name));\n\t\t\t\tdelete y[0]; wb.Sheets.push(y); break;\n\t\t\tcase '</sheet>': break;\n\n\t\t\t/* 18.2.15 functionGroups CT_FunctionGroups ? */\n\t\t\tcase '<functionGroups': case '<functionGroups/>': break;\n\t\t\t/* 18.2.14   functionGroup CT_FunctionGroup + */\n\t\t\tcase '<functionGroup': break;\n\n\t\t\t/* 18.2.9  externalReferences CT_ExternalReferences ? */\n\t\t\tcase '<externalReferences': case '</externalReferences>': case '<externalReferences>': break;\n\t\t\t/* 18.2.8    externalReference CT_ExternalReference + */\n\t\t\tcase '<externalReference': break;\n\n\t\t\t/* 18.2.6  definedNames CT_DefinedNames ? */\n\t\t\tcase '<definedNames/>': break;\n\t\t\tcase '<definedNames>': case '<definedNames': pass=true; break;\n\t\t\tcase '</definedNames>': pass=false; break;\n\t\t\t/* 18.2.5    definedName CT_DefinedName + */\n\t\t\tcase '<definedName': {\n\t\t\t\tdname = {};\n\t\t\t\tdname.Name = utf8read(y.name);\n\t\t\t\tif(y.comment) dname.Comment = y.comment;\n\t\t\t\tif(y.localSheetId) dname.Sheet = +y.localSheetId;\n\t\t\t\tif(parsexmlbool(y.hidden||\"0\")) dname.Hidden = true;\n\t\t\t\tdnstart = idx + x.length;\n\t\t\t}\tbreak;\n\t\t\tcase '</definedName>': {\n\t\t\t\tdname.Ref = unescapexml(utf8read(data.slice(dnstart, idx)));\n\t\t\t\twb.Names.push(dname);\n\t\t\t} break;\n\t\t\tcase '<definedName/>': break;\n\n\t\t\t/* 18.2.2  calcPr CT_CalcPr ? */\n\t\t\tcase '<calcPr': delete y[0]; wb.CalcPr = y; break;\n\t\t\tcase '<calcPr/>': delete y[0]; wb.CalcPr = y; break;\n\t\t\tcase '</calcPr>': break;\n\n\t\t\t/* 18.2.16 oleSize CT_OleSize ? (ref required) */\n\t\t\tcase '<oleSize': break;\n\n\t\t\t/* 18.2.4  customWorkbookViews CT_CustomWorkbookViews ? */\n\t\t\tcase '<customWorkbookViews>': case '</customWorkbookViews>': case '<customWorkbookViews': break;\n\t\t\t/* 18.2.3  customWorkbookView CT_CustomWorkbookView + */\n\t\t\tcase '<customWorkbookView': case '</customWorkbookView>': break;\n\n\t\t\t/* 18.2.18 pivotCaches CT_PivotCaches ? */\n\t\t\tcase '<pivotCaches>': case '</pivotCaches>': case '<pivotCaches': break;\n\t\t\t/* 18.2.17 pivotCache CT_PivotCache ? */\n\t\t\tcase '<pivotCache': break;\n\n\t\t\t/* 18.2.21 smartTagPr CT_SmartTagPr ? */\n\t\t\tcase '<smartTagPr': case '<smartTagPr/>': break;\n\n\t\t\t/* 18.2.23 smartTagTypes CT_SmartTagTypes ? */\n\t\t\tcase '<smartTagTypes': case '<smartTagTypes>': case '</smartTagTypes>': break;\n\t\t\t/* 18.2.22 smartTagType CT_SmartTagType ? */\n\t\t\tcase '<smartTagType': break;\n\n\t\t\t/* 18.2.24 webPublishing CT_WebPublishing ? */\n\t\t\tcase '<webPublishing': case '<webPublishing/>': break;\n\n\t\t\t/* 18.2.11 fileRecoveryPr CT_FileRecoveryPr ? */\n\t\t\tcase '<fileRecoveryPr': case '<fileRecoveryPr/>': break;\n\n\t\t\t/* 18.2.26 webPublishObjects CT_WebPublishObjects ? */\n\t\t\tcase '<webPublishObjects>': case '<webPublishObjects': case '</webPublishObjects>': break;\n\t\t\t/* 18.2.25 webPublishObject CT_WebPublishObject ? */\n\t\t\tcase '<webPublishObject': break;\n\n\t\t\t/* 18.2.10 extLst CT_ExtensionList ? */\n\t\t\tcase '<extLst': case '<extLst>': case '</extLst>': case '<extLst/>': break;\n\t\t\t/* 18.2.7  ext CT_Extension + */\n\t\t\tcase '<ext': pass=true; break; //TODO: check with versions of excel\n\t\t\tcase '</ext>': pass=false; break;\n\n\t\t\t/* Others */\n\t\t\tcase '<ArchID': break;\n\t\t\tcase '<AlternateContent':\n\t\t\tcase '<AlternateContent>': pass=true; break;\n\t\t\tcase '</AlternateContent>': pass=false; break;\n\n\t\t\t/* TODO */\n\t\t\tcase '<revisionPtr': break;\n\n\t\t\tdefault: if(!pass && opts.WTF) throw new Error('unrecognized ' + y[0] + ' in workbook');\n\t\t}\n\t\treturn x;\n\t});\n\tif(XMLNS_main.indexOf(wb.xmlns) === -1) throw new Error(\"Unknown Namespace: \" + wb.xmlns);\n\n\tparse_wb_defaults(wb);\n\n\treturn wb;\n}\n\nfunction write_wb_xml(wb/*:Workbook*//*::, opts:?WriteOpts*/)/*:string*/ {\n\tvar o = [XML_HEADER];\n\to[o.length] = writextag('workbook', null, {\n\t\t'xmlns': XMLNS_main[0],\n\t\t//'xmlns:mx': XMLNS.mx,\n\t\t//'xmlns:s': XMLNS_main[0],\n\t\t'xmlns:r': XMLNS.r\n\t});\n\n\tvar write_names = (wb.Workbook && (wb.Workbook.Names||[]).length > 0);\n\n\t/* fileVersion */\n\t/* fileSharing */\n\n\tvar workbookPr/*:any*/ = ({codeName:\"ThisWorkbook\"}/*:any*/);\n\tif(wb.Workbook && wb.Workbook.WBProps) {\n\t\tWBPropsDef.forEach(function(x) {\n\t\t\t/*:: if(!wb.Workbook || !wb.Workbook.WBProps) throw \"unreachable\"; */\n\t\t\tif((wb.Workbook.WBProps[x[0]]/*:any*/) == null) return;\n\t\t\tif((wb.Workbook.WBProps[x[0]]/*:any*/) == x[1]) return;\n\t\t\tworkbookPr[x[0]] = (wb.Workbook.WBProps[x[0]]/*:any*/);\n\t\t});\n\t\t/*:: if(!wb.Workbook || !wb.Workbook.WBProps) throw \"unreachable\"; */\n\t\tif(wb.Workbook.WBProps.CodeName) { workbookPr.codeName = wb.Workbook.WBProps.CodeName; delete workbookPr.CodeName; }\n\t}\n\to[o.length] = (writextag('workbookPr', null, workbookPr));\n\n\t/* workbookProtection */\n\n\tvar sheets = wb.Workbook && wb.Workbook.Sheets || [];\n\tvar i = 0;\n\n\t/* bookViews only written if first worksheet is hidden */\n\tif(sheets && sheets[0] && !!sheets[0].Hidden) {\n\t\to[o.length] = \"<bookViews>\";\n\t\tfor(i = 0; i != wb.SheetNames.length; ++i) {\n\t\t\tif(!sheets[i]) break;\n\t\t\tif(!sheets[i].Hidden) break;\n\t\t}\n\t\tif(i == wb.SheetNames.length) i = 0;\n\t\to[o.length] = '<workbookView firstSheet=\"' + i + '\" activeTab=\"' + i + '\"/>';\n\t\to[o.length] = \"</bookViews>\";\n\t}\n\n\to[o.length] = \"<sheets>\";\n\tfor(i = 0; i != wb.SheetNames.length; ++i) {\n\t\tvar sht = ({name:escapexml(wb.SheetNames[i].slice(0,31))}/*:any*/);\n\t\tsht.sheetId = \"\"+(i+1);\n\t\tsht[\"r:id\"] = \"rId\"+(i+1);\n\t\tif(sheets[i]) switch(sheets[i].Hidden) {\n\t\t\tcase 1: sht.state = \"hidden\"; break;\n\t\t\tcase 2: sht.state = \"veryHidden\"; break;\n\t\t}\n\t\to[o.length] = (writextag('sheet',null,sht));\n\t}\n\to[o.length] = \"</sheets>\";\n\n\t/* functionGroups */\n\t/* externalReferences */\n\n\tif(write_names) {\n\t\to[o.length] = \"<definedNames>\";\n\t\tif(wb.Workbook && wb.Workbook.Names) wb.Workbook.Names.forEach(function(n) {\n\t\t\tvar d/*:any*/ = {name:n.Name};\n\t\t\tif(n.Comment) d.comment = n.Comment;\n\t\t\tif(n.Sheet != null) d.localSheetId = \"\"+n.Sheet;\n\t\t\tif(n.Hidden) d.hidden = \"1\";\n\t\t\tif(!n.Ref) return;\n\t\t\to[o.length] = writextag('definedName', escapexml(n.Ref), d);\n\t\t});\n\t\to[o.length] = \"</definedNames>\";\n\t}\n\n\t/* calcPr */\n\t/* oleSize */\n\t/* customWorkbookViews */\n\t/* pivotCaches */\n\t/* smartTagPr */\n\t/* smartTagTypes */\n\t/* webPublishing */\n\t/* fileRecoveryPr */\n\t/* webPublishObjects */\n\t/* extLst */\n\n\tif(o.length>2){ o[o.length] = '</workbook>'; o[1]=o[1].replace(\"/>\",\">\"); }\n\treturn o.join(\"\");\n}\n/* [MS-XLSB] 2.4.304 BrtBundleSh */\nfunction parse_BrtBundleSh(data, length/*:number*/) {\n\tvar z = {};\n\tz.Hidden = data.read_shift(4); //hsState ST_SheetState\n\tz.iTabID = data.read_shift(4);\n\tz.strRelID = parse_RelID(data,length-8);\n\tz.name = parse_XLWideString(data);\n\treturn z;\n}\nfunction write_BrtBundleSh(data, o) {\n\tif(!o) o = new_buf(127);\n\to.write_shift(4, data.Hidden);\n\to.write_shift(4, data.iTabID);\n\twrite_RelID(data.strRelID, o);\n\twrite_XLWideString(data.name.slice(0,31), o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.815 BrtWbProp */\nfunction parse_BrtWbProp(data, length)/*:WBProps*/ {\n\tvar o/*:WBProps*/ = ({}/*:any*/);\n\tvar flags = data.read_shift(4);\n\to.defaultThemeVersion = data.read_shift(4);\n\tvar strName = (length > 8) ? parse_XLWideString(data) : \"\";\n\tif(strName.length > 0) o.CodeName = strName;\n\to.autoCompressPictures = !!(flags & 0x10000);\n\to.backupFile = !!(flags & 0x40);\n\to.checkCompatibility = !!(flags & 0x1000);\n\to.date1904 = !!(flags & 0x01);\n\to.filterPrivacy = !!(flags & 0x08);\n\to.hidePivotFieldList = !!(flags & 0x400);\n\to.promptedSolutions = !!(flags & 0x10);\n\to.publishItems = !!(flags & 0x800);\n\to.refreshAllConnections = !!(flags & 0x40000);\n\to.saveExternalLinkValues = !!(flags & 0x80);\n\to.showBorderUnselectedTables = !!(flags & 0x04);\n\to.showInkAnnotation = !!(flags & 0x20);\n\to.showObjects = [\"all\", \"placeholders\", \"none\"][(flags >> 13) & 0x03];\n\to.showPivotChartFilter = !!(flags & 0x8000);\n\to.updateLinks = [\"userSet\", \"never\", \"always\"][(flags >> 8) & 0x03];\n\treturn o;\n}\nfunction write_BrtWbProp(data/*:?WBProps*/, o) {\n\tif(!o) o = new_buf(72);\n\tvar flags = 0;\n\tif(data) {\n\t\t/* TODO: mirror parse_BrtWbProp fields */\n\t\tif(data.filterPrivacy) flags |= 0x08;\n\t}\n\to.write_shift(4, flags);\n\to.write_shift(4, 0);\n\twrite_XLSBCodeName(data && data.CodeName || \"ThisWorkbook\", o);\n\treturn o.slice(0, o.l);\n}\n\nfunction parse_BrtFRTArchID$(data, length) {\n\tvar o = {};\n\tdata.read_shift(4);\n\to.ArchID = data.read_shift(4);\n\tdata.l += length - 8;\n\treturn o;\n}\n\n/* [MS-XLSB] 2.4.687 BrtName */\nfunction parse_BrtName(data, length, opts) {\n\tvar end = data.l + length;\n\tdata.l += 4; //var flags = data.read_shift(4);\n\tdata.l += 1; //var chKey = data.read_shift(1);\n\tvar itab = data.read_shift(4);\n\tvar name = parse_XLNameWideString(data);\n\tvar formula = parse_XLSBNameParsedFormula(data, 0, opts);\n\tvar comment = parse_XLNullableWideString(data);\n\t//if(0 /* fProc */) {\n\t\t// unusedstring1: XLNullableWideString\n\t\t// description: XLNullableWideString\n\t\t// helpTopic: XLNullableWideString\n\t\t// unusedstring2: XLNullableWideString\n\t//}\n\tdata.l = end;\n\tvar out = ({Name:name, Ptg:formula}/*:any*/);\n\tif(itab < 0xFFFFFFF) out.Sheet = itab;\n\tif(comment) out.Comment = comment;\n\treturn out;\n}\n\n/* [MS-XLSB] 2.1.7.61 Workbook */\nfunction parse_wb_bin(data, opts)/*:WorkbookFile*/ {\n\tvar wb = { AppVersion:{}, WBProps:{}, WBView:[], Sheets:[], CalcPr:{}, xmlns: \"\" };\n\tvar state/*:Array<string>*/ = [];\n\tvar pass = false;\n\n\tif(!opts) opts = {};\n\topts.biff = 12;\n\n\tvar Names = [];\n\tvar supbooks = ([[]]/*:any*/);\n\tsupbooks.SheetNames = [];\n\tsupbooks.XTI = [];\n\n\tXLSBRecordEnum[0x0010] = { n:\"BrtFRTArchID$\", f:parse_BrtFRTArchID$ };\n\n\trecordhopper(data, function hopper_wb(val, R, RT) {\n\t\tswitch(RT) {\n\t\t\tcase 0x009C: /* 'BrtBundleSh' */\n\t\t\t\tsupbooks.SheetNames.push(val.name);\n\t\t\t\twb.Sheets.push(val); break;\n\n\t\t\tcase 0x0099: /* 'BrtWbProp' */\n\t\t\t\twb.WBProps = val; break;\n\n\t\t\tcase 0x0027: /* 'BrtName' */\n\t\t\t\tif(val.Sheet != null) opts.SID = val.Sheet;\n\t\t\t\tval.Ref = stringify_formula(val.Ptg, null, null, supbooks, opts);\n\t\t\t\tdelete opts.SID;\n\t\t\t\tdelete val.Ptg;\n\t\t\t\tNames.push(val);\n\t\t\t\tbreak;\n\t\t\tcase 0x040C: /* 'BrtNameExt' */ break;\n\n\t\t\tcase 0x0165: /* 'BrtSupSelf' */\n\t\t\tcase 0x0166: /* 'BrtSupSame' */\n\t\t\tcase 0x0163: /* 'BrtSupBookSrc' */\n\t\t\tcase 0x029B: /* 'BrtSupAddin' */\n\t\t\t\tif(!supbooks[0].length) supbooks[0] = [RT, val];\n\t\t\t\telse supbooks.push([RT, val]);\n\t\t\t\tsupbooks[supbooks.length - 1].XTI = [];\n\t\t\t\tbreak;\n\t\t\tcase 0x016A: /* 'BrtExternSheet' */\n\t\t\t\tif(supbooks.length === 0) { supbooks[0] = []; supbooks[0].XTI = []; }\n\t\t\t\tsupbooks[supbooks.length - 1].XTI = supbooks[supbooks.length - 1].XTI.concat(val);\n\t\t\t\tsupbooks.XTI = supbooks.XTI.concat(val);\n\t\t\t\tbreak;\n\t\t\tcase 0x0169: /* 'BrtPlaceholderName' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0817: /* 'BrtAbsPath15' */\n\t\t\tcase 0x009E: /* 'BrtBookView' */\n\t\t\tcase 0x008F: /* 'BrtBeginBundleShs' */\n\t\t\tcase 0x0298: /* 'BrtBeginFnGroup' */\n\t\t\tcase 0x0161: /* 'BrtBeginExternals' */\n\t\t\t\tbreak;\n\n\t\t\t/* case 'BrtModelTimeGroupingCalcCol' */\n\t\t\tcase 0x0C00: /* 'BrtUid' */\n\t\t\tcase 0x0C01: /* 'BrtRevisionPtr' */\n\t\t\tcase 0x0216: /* 'BrtBookProtection' */\n\t\t\tcase 0x02A5: /* 'BrtBookProtectionIso' */\n\t\t\tcase 0x009D: /* 'BrtCalcProp' */\n\t\t\tcase 0x0262: /* 'BrtCrashRecErr' */\n\t\t\tcase 0x0802: /* 'BrtDecoupledPivotCacheID' */\n\t\t\tcase 0x009B: /* 'BrtFileRecover' */\n\t\t\tcase 0x0224: /* 'BrtFileSharing' */\n\t\t\tcase 0x02A4: /* 'BrtFileSharingIso' */\n\t\t\tcase 0x0080: /* 'BrtFileVersion' */\n\t\t\tcase 0x0299: /* 'BrtFnGroup' */\n\t\t\tcase 0x0850: /* 'BrtModelRelationship' */\n\t\t\tcase 0x084D: /* 'BrtModelTable' */\n\t\t\tcase 0x0225: /* 'BrtOleSize' */\n\t\t\tcase 0x0805: /* 'BrtPivotTableRef' */\n\t\t\tcase 0x0254: /* 'BrtSmartTagType' */\n\t\t\tcase 0x081C: /* 'BrtTableSlicerCacheID' */\n\t\t\tcase 0x081B: /* 'BrtTableSlicerCacheIDs' */\n\t\t\tcase 0x0822: /* 'BrtTimelineCachePivotCacheID' */\n\t\t\tcase 0x018D: /* 'BrtUserBookView' */\n\t\t\tcase 0x009A: /* 'BrtWbFactoid' */\n\t\t\tcase 0x045D: /* 'BrtWbProp14' */\n\t\t\tcase 0x0229: /* 'BrtWebOpt' */\n\t\t\tcase 0x082B: /* 'BrtWorkBookPr15' */\n\t\t\t\tbreak;\n\n\t\t\tcase 0x0023: /* 'BrtFRTBegin' */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0024: /* 'BrtFRTEnd' */\n\t\t\t\tstate.pop(); pass = false; break;\n\t\t\tcase 0x0025: /* 'BrtACBegin' */\n\t\t\t\tstate.push(RT); pass = true; break;\n\t\t\tcase 0x0026: /* 'BrtACEnd' */\n\t\t\t\tstate.pop(); pass = false; break;\n\n\t\t\tcase 0x0010: /* 'BrtFRTArchID$' */ break;\n\n\t\t\tdefault:\n\t\t\t\tif(R.T){/* empty */}\n\t\t\t\telse if(!pass || (opts.WTF && state[state.length-1] != 0x0025 /* BrtACBegin */ && state[state.length-1] != 0x0023 /* BrtFRTBegin */)) throw new Error(\"Unexpected record 0x\" + RT.toString(16));\n\t\t}\n\t}, opts);\n\n\tparse_wb_defaults(wb);\n\n\t// $FlowIgnore\n\twb.Names = Names;\n\n\t(wb/*:any*/).supbooks = supbooks;\n\treturn wb;\n}\n\nfunction write_BUNDLESHS(ba, wb/*::, opts*/) {\n\twrite_record(ba, 0x008F /* BrtBeginBundleShs */);\n\tfor(var idx = 0; idx != wb.SheetNames.length; ++idx) {\n\t\tvar viz = wb.Workbook && wb.Workbook.Sheets && wb.Workbook.Sheets[idx] && wb.Workbook.Sheets[idx].Hidden || 0;\n\t\tvar d = { Hidden: viz, iTabID: idx+1, strRelID: 'rId' + (idx+1), name: wb.SheetNames[idx] };\n\t\twrite_record(ba, 0x009C /* BrtBundleSh */, write_BrtBundleSh(d));\n\t}\n\twrite_record(ba, 0x0090 /* BrtEndBundleShs */);\n}\n\n/* [MS-XLSB] 2.4.649 BrtFileVersion */\nfunction write_BrtFileVersion(data, o) {\n\tif(!o) o = new_buf(127);\n\tfor(var i = 0; i != 4; ++i) o.write_shift(4, 0);\n\twrite_XLWideString(\"SheetJS\", o);\n\twrite_XLWideString(XLSX.version, o);\n\twrite_XLWideString(XLSX.version, o);\n\twrite_XLWideString(\"7262\", o);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\n/* [MS-XLSB] 2.4.301 BrtBookView */\nfunction write_BrtBookView(idx, o) {\n\tif(!o) o = new_buf(29);\n\to.write_shift(-4, 0);\n\to.write_shift(-4, 460);\n\to.write_shift(4,  28800);\n\to.write_shift(4,  17600);\n\to.write_shift(4,  500);\n\to.write_shift(4,  idx);\n\to.write_shift(4,  idx);\n\tvar flags = 0x78;\n\to.write_shift(1,  flags);\n\treturn o.length > o.l ? o.slice(0, o.l) : o;\n}\n\nfunction write_BOOKVIEWS(ba, wb/*::, opts*/) {\n\t/* required if hidden tab appears before visible tab */\n\tif(!wb.Workbook || !wb.Workbook.Sheets) return;\n\tvar sheets = wb.Workbook.Sheets;\n\tvar i = 0, vistab = -1, hidden = -1;\n\tfor(; i < sheets.length; ++i) {\n\t\tif(!sheets[i] || !sheets[i].Hidden && vistab == -1) vistab = i;\n\t\telse if(sheets[i].Hidden == 1 && hidden == -1) hidden = i;\n\t}\n\tif(hidden > vistab) return;\n\twrite_record(ba, 0x0087 /* BrtBeginBookViews */);\n\twrite_record(ba, 0x009E /* BrtBookView */, write_BrtBookView(vistab));\n\t/* 1*(BrtBookView *FRT) */\n\twrite_record(ba, 0x0088 /* BrtEndBookViews */);\n}\n\n/* [MS-XLSB] 2.4.305 BrtCalcProp */\n/*function write_BrtCalcProp(data, o) {\n\tif(!o) o = new_buf(26);\n\to.write_shift(4,0); // force recalc\n\to.write_shift(4,1);\n\to.write_shift(4,0);\n\twrite_Xnum(0, o);\n\to.write_shift(-4, 1023);\n\to.write_shift(1, 0x33);\n\to.write_shift(1, 0x00);\n\treturn o;\n}*/\n\n/* [MS-XLSB] 2.4.646 BrtFileRecover */\n/*function write_BrtFileRecover(data, o) {\n\tif(!o) o = new_buf(1);\n\to.write_shift(1,0);\n\treturn o;\n}*/\n\n/* [MS-XLSB] 2.1.7.61 Workbook */\nfunction write_wb_bin(wb, opts) {\n\tvar ba = buf_array();\n\twrite_record(ba, 0x0083 /* BrtBeginBook */);\n\twrite_record(ba, 0x0080 /* BrtFileVersion */, write_BrtFileVersion());\n\t/* [[BrtFileSharingIso] BrtFileSharing] */\n\twrite_record(ba, 0x0099 /* BrtWbProp */, write_BrtWbProp(wb.Workbook && wb.Workbook.WBProps || null));\n\t/* [ACABSPATH] */\n\t/* [[BrtBookProtectionIso] BrtBookProtection] */\n\twrite_BOOKVIEWS(ba, wb, opts);\n\twrite_BUNDLESHS(ba, wb, opts);\n\t/* [FNGROUP] */\n\t/* [EXTERNALS] */\n\t/* *BrtName */\n\t/* write_record(ba, 0x009D BrtCalcProp, write_BrtCalcProp()); */\n\t/* [BrtOleSize] */\n\t/* *(BrtUserBookView *FRT) */\n\t/* [PIVOTCACHEIDS] */\n\t/* [BrtWbFactoid] */\n\t/* [SMARTTAGTYPES] */\n\t/* [BrtWebOpt] */\n\t/* write_record(ba, 0x009B BrtFileRecover, write_BrtFileRecover()); */\n\t/* [WEBPUBITEMS] */\n\t/* [CRERRS] */\n\t/* FRTWORKBOOK */\n\twrite_record(ba, 0x0084 /* BrtEndBook */);\n\n\treturn ba.end();\n}\nfunction parse_wb(data, name/*:string*/, opts)/*:WorkbookFile*/ {\n\tif(name.slice(-4)===\".bin\") return parse_wb_bin((data/*:any*/), opts);\n\treturn parse_wb_xml((data/*:any*/), opts);\n}\n\nfunction parse_ws(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_ws_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_ws_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_cs(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_cs_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_cs_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_ms(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_ms_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_ms_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_ds(data, name/*:string*/, idx/*:number*/, opts, rels, wb, themes, styles)/*:Worksheet*/ {\n\tif(name.slice(-4)===\".bin\") return parse_ds_bin((data/*:any*/), opts, idx, rels, wb, themes, styles);\n\treturn parse_ds_xml((data/*:any*/), opts, idx, rels, wb, themes, styles);\n}\n\nfunction parse_sty(data, name/*:string*/, themes, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_sty_bin((data/*:any*/), themes, opts);\n\treturn parse_sty_xml((data/*:any*/), themes, opts);\n}\n\nfunction parse_theme(data/*:string*/, name/*:string*/, opts) {\n\treturn parse_theme_xml(data, opts);\n}\n\nfunction parse_sst(data, name/*:string*/, opts)/*:SST*/ {\n\tif(name.slice(-4)===\".bin\") return parse_sst_bin((data/*:any*/), opts);\n\treturn parse_sst_xml((data/*:any*/), opts);\n}\n\nfunction parse_cmnt(data, name/*:string*/, opts)/*:Array<RawComment>*/ {\n\tif(name.slice(-4)===\".bin\") return parse_comments_bin((data/*:any*/), opts);\n\treturn parse_comments_xml((data/*:any*/), opts);\n}\n\nfunction parse_cc(data, name/*:string*/, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_cc_bin((data/*:any*/), name, opts);\n\treturn parse_cc_xml((data/*:any*/), name, opts);\n}\n\nfunction parse_xlink(data, rel, name/*:string*/, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_xlink_bin((data/*:any*/), rel, name, opts);\n\treturn parse_xlink_xml((data/*:any*/), rel, name, opts);\n}\n\nfunction parse_xlmeta(data, name/*:string*/, opts) {\n\tif(name.slice(-4)===\".bin\") return parse_xlmeta_bin((data/*:any*/), name, opts);\n\treturn parse_xlmeta_xml((data/*:any*/), name, opts);\n}\n\nfunction write_wb(wb, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_wb_bin : write_wb_xml)(wb, opts);\n}\n\nfunction write_ws(data/*:number*/, name/*:string*/, opts, wb/*:Workbook*/, rels) {\n\treturn (name.slice(-4)===\".bin\" ? write_ws_bin : write_ws_xml)(data, opts, wb, rels);\n}\n\n// eslint-disable-next-line no-unused-vars\nfunction write_cs(data/*:number*/, name/*:string*/, opts, wb/*:Workbook*/, rels) {\n\treturn (name.slice(-4)===\".bin\" ? write_cs_bin : write_cs_xml)(data, opts, wb, rels);\n}\n\nfunction write_sty(data, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_sty_bin : write_sty_xml)(data, opts);\n}\n\nfunction write_sst(data/*:SST*/, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_sst_bin : write_sst_xml)(data, opts);\n}\n\nfunction write_cmnt(data/*:Array<any>*/, name/*:string*/, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_comments_bin : write_comments_xml)(data, opts);\n}\n/*\nfunction write_cc(data, name:string, opts) {\n\treturn (name.slice(-4)===\".bin\" ? write_cc_bin : write_cc_xml)(data, opts);\n}\n*/\n\nfunction write_xlmeta(name/*:string*/) {\n\treturn (name.slice(-4)===\".bin\" ? write_xlmeta_bin : write_xlmeta_xml)();\n}\nvar attregexg2=/([\\w:]+)=((?:\")([^\"]*)(?:\")|(?:')([^']*)(?:'))/g;\nvar attregex2=/([\\w:]+)=((?:\")(?:[^\"]*)(?:\")|(?:')(?:[^']*)(?:'))/;\nfunction xlml_parsexmltag(tag/*:string*/, skip_root/*:?boolean*/) {\n\tvar words = tag.split(/\\s+/);\n\tvar z/*:any*/ = ([]/*:any*/); if(!skip_root) z[0] = words[0];\n\tif(words.length === 1) return z;\n\tvar m = tag.match(attregexg2), y, j, w, i;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\ty = m[i].match(attregex2);\n/*:: if(!y || !y[2]) continue; */\n\t\tif((j=y[1].indexOf(\":\")) === -1) z[y[1]] = y[2].slice(1,y[2].length-1);\n\t\telse {\n\t\t\tif(y[1].slice(0,6) === \"xmlns:\") w = \"xmlns\"+y[1].slice(6);\n\t\t\telse w = y[1].slice(j+1);\n\t\t\tz[w] = y[2].slice(1,y[2].length-1);\n\t\t}\n\t}\n\treturn z;\n}\nfunction xlml_parsexmltagobj(tag/*:string*/) {\n\tvar words = tag.split(/\\s+/);\n\tvar z = {};\n\tif(words.length === 1) return z;\n\tvar m = tag.match(attregexg2), y, j, w, i;\n\tif(m) for(i = 0; i != m.length; ++i) {\n\t\ty = m[i].match(attregex2);\n/*:: if(!y || !y[2]) continue; */\n\t\tif((j=y[1].indexOf(\":\")) === -1) z[y[1]] = y[2].slice(1,y[2].length-1);\n\t\telse {\n\t\t\tif(y[1].slice(0,6) === \"xmlns:\") w = \"xmlns\"+y[1].slice(6);\n\t\t\telse w = y[1].slice(j+1);\n\t\t\tz[w] = y[2].slice(1,y[2].length-1);\n\t\t}\n\t}\n\treturn z;\n}\n\n// ----\n\n/* map from xlml named formats to SSF TODO: localize */\nvar XLMLFormatMap/*: {[string]:string}*/;\n\nfunction xlml_format(format, value)/*:string*/ {\n\tvar fmt = XLMLFormatMap[format] || unescapexml(format);\n\tif(fmt === \"General\") return SSF_general(value);\n\treturn SSF_format(fmt, value);\n}\n\nfunction xlml_set_custprop(Custprops, key, cp, val/*:string*/) {\n\tvar oval/*:any*/ = val;\n\tswitch((cp[0].match(/dt:dt=\"([\\w.]+)\"/)||[\"\",\"\"])[1]) {\n\t\tcase \"boolean\": oval = parsexmlbool(val); break;\n\t\tcase \"i2\": case \"int\": oval = parseInt(val, 10); break;\n\t\tcase \"r4\": case \"float\": oval = parseFloat(val); break;\n\t\tcase \"date\": case \"dateTime.tz\": oval = parseDate(val); break;\n\t\tcase \"i8\": case \"string\": case \"fixed\": case \"uuid\": case \"bin.base64\": break;\n\t\tdefault: throw new Error(\"bad custprop:\" + cp[0]);\n\t}\n\tCustprops[unescapexml(key)] = oval;\n}\n\nfunction safe_format_xlml(cell/*:Cell*/, nf, o) {\n\tif(cell.t === 'z') return;\n\tif(!o || o.cellText !== false) try {\n\t\tif(cell.t === 'e') { cell.w = cell.w || BErr[cell.v]; }\n\t\telse if(nf === \"General\") {\n\t\t\tif(cell.t === 'n') {\n\t\t\t\tif((cell.v|0) === cell.v) cell.w = cell.v.toString(10);\n\t\t\t\telse cell.w = SSF_general_num(cell.v);\n\t\t\t}\n\t\t\telse cell.w = SSF_general(cell.v);\n\t\t}\n\t\telse cell.w = xlml_format(nf||\"General\", cell.v);\n\t} catch(e) { if(o.WTF) throw e; }\n\ttry {\n\t\tvar z = XLMLFormatMap[nf]||nf||\"General\";\n\t\tif(o.cellNF) cell.z = z;\n\t\tif(o.cellDates && cell.t == 'n' && fmt_is_date(z)) {\n\t\t\tvar _d = SSF_parse_date_code(cell.v); if(_d) { cell.t = 'd'; cell.v = new Date(_d.y, _d.m-1,_d.d,_d.H,_d.M,_d.S,_d.u); }\n\t\t}\n\t} catch(e) { if(o.WTF) throw e; }\n}\n\nfunction process_style_xlml(styles, stag, opts) {\n\tif(opts.cellStyles) {\n\t\tif(stag.Interior) {\n\t\t\tvar I = stag.Interior;\n\t\t\tif(I.Pattern) I.patternType = XLMLPatternTypeMap[I.Pattern] || I.Pattern;\n\t\t}\n\t}\n\tstyles[stag.ID] = stag;\n}\n\n/* TODO: there must exist some form of OSP-blessed spec */\nfunction parse_xlml_data(xml, ss, data, cell/*:any*/, base, styles, csty, row, arrayf, o) {\n\tvar nf = \"General\", sid = cell.StyleID, S = {}; o = o || {};\n\tvar interiors = [];\n\tvar i = 0;\n\tif(sid === undefined && row) sid = row.StyleID;\n\tif(sid === undefined && csty) sid = csty.StyleID;\n\twhile(styles[sid] !== undefined) {\n\t\tif(styles[sid].nf) nf = styles[sid].nf;\n\t\tif(styles[sid].Interior) interiors.push(styles[sid].Interior);\n\t\tif(!styles[sid].Parent) break;\n\t\tsid = styles[sid].Parent;\n\t}\n\tswitch(data.Type) {\n\t\tcase 'Boolean':\n\t\t\tcell.t = 'b';\n\t\t\tcell.v = parsexmlbool(xml);\n\t\t\tbreak;\n\t\tcase 'String':\n\t\t\tcell.t = 's'; cell.r = xlml_fixstr(unescapexml(xml));\n\t\t\tcell.v = (xml.indexOf(\"<\") > -1 ? unescapexml(ss||xml).replace(/<.*?>/g, \"\") : cell.r); // todo: BR etc\n\t\t\tbreak;\n\t\tcase 'DateTime':\n\t\t\tif(xml.slice(-1) != \"Z\") xml += \"Z\";\n\t\t\tcell.v = (parseDate(xml) - new Date(Date.UTC(1899, 11, 30))) / (24 * 60 * 60 * 1000);\n\t\t\tif(cell.v !== cell.v) cell.v = unescapexml(xml);\n\t\t\telse if(cell.v<60) cell.v = cell.v -1;\n\t\t\tif(!nf || nf == \"General\") nf = \"yyyy-mm-dd\";\n\t\t\t/* falls through */\n\t\tcase 'Number':\n\t\t\tif(cell.v === undefined) cell.v=+xml;\n\t\t\tif(!cell.t) cell.t = 'n';\n\t\t\tbreak;\n\t\tcase 'Error': cell.t = 'e'; cell.v = RBErr[xml]; if(o.cellText !== false) cell.w = xml; break;\n\t\tdefault:\n\t\t\tif(xml == \"\" && ss == \"\") { cell.t = 'z'; }\n\t\t\telse { cell.t = 's'; cell.v = xlml_fixstr(ss||xml); }\n\t\t\tbreak;\n\t}\n\tsafe_format_xlml(cell, nf, o);\n\tif(o.cellFormula !== false) {\n\t\tif(cell.Formula) {\n\t\t\tvar fstr = unescapexml(cell.Formula);\n\t\t\t/* strictly speaking, the leading = is required but some writers omit */\n\t\t\tif(fstr.charCodeAt(0) == 61 /* = */) fstr = fstr.slice(1);\n\t\t\tcell.f = rc_to_a1(fstr, base);\n\t\t\tdelete cell.Formula;\n\t\t\tif(cell.ArrayRange == \"RC\") cell.F = rc_to_a1(\"RC:RC\", base);\n\t\t\telse if(cell.ArrayRange) {\n\t\t\t\tcell.F = rc_to_a1(cell.ArrayRange, base);\n\t\t\t\tarrayf.push([safe_decode_range(cell.F), cell.F]);\n\t\t\t}\n\t\t} else {\n\t\t\tfor(i = 0; i < arrayf.length; ++i)\n\t\t\t\tif(base.r >= arrayf[i][0].s.r && base.r <= arrayf[i][0].e.r)\n\t\t\t\t\tif(base.c >= arrayf[i][0].s.c && base.c <= arrayf[i][0].e.c)\n\t\t\t\t\t\tcell.F = arrayf[i][1];\n\t\t}\n\t}\n\tif(o.cellStyles) {\n\t\tinteriors.forEach(function(x) {\n\t\t\tif(!S.patternType && x.patternType) S.patternType = x.patternType;\n\t\t});\n\t\tcell.s = S;\n\t}\n\tif(cell.StyleID !== undefined) cell.ixfe = cell.StyleID;\n}\n\nfunction xlml_clean_comment(comment/*:any*/) {\n\tcomment.t = comment.v || \"\";\n\tcomment.t = comment.t.replace(/\\r\\n/g,\"\\n\").replace(/\\r/g,\"\\n\");\n\tcomment.v = comment.w = comment.ixfe = undefined;\n}\n\n/* TODO: Everything */\nfunction parse_xlml_xml(d, _opts)/*:Workbook*/ {\n\tvar opts = _opts || {};\n\tmake_ssf();\n\tvar str = debom(xlml_normalize(d));\n\tif(opts.type == 'binary' || opts.type == 'array' || opts.type == 'base64') {\n\t\tif(typeof $cptable !== 'undefined') str = $cptable.utils.decode(65001, char_codes(str));\n\t\telse str = utf8read(str);\n\t}\n\tvar opening = str.slice(0, 1024).toLowerCase(), ishtml = false;\n\topening = opening.replace(/\".*?\"/g, \"\");\n\tif((opening.indexOf(\">\") & 1023) > Math.min((opening.indexOf(\",\") & 1023), (opening.indexOf(\";\")&1023))) { var _o = dup(opts); _o.type = \"string\"; return PRN.to_workbook(str, _o); }\n\tif(opening.indexOf(\"<?xml\") == -1) [\"html\", \"table\", \"head\", \"meta\", \"script\", \"style\", \"div\"].forEach(function(tag) { if(opening.indexOf(\"<\" + tag) >= 0) ishtml = true; });\n\tif(ishtml) return html_to_workbook(str, opts);\n\n\tXLMLFormatMap = ({\n\t\t\"General Number\": \"General\",\n\t\t\"General Date\": table_fmt[22],\n\t\t\"Long Date\": \"dddd, mmmm dd, yyyy\",\n\t\t\"Medium Date\": table_fmt[15],\n\t\t\"Short Date\": table_fmt[14],\n\t\t\"Long Time\": table_fmt[19],\n\t\t\"Medium Time\": table_fmt[18],\n\t\t\"Short Time\": table_fmt[20],\n\t\t\"Currency\": '\"$\"#,##0.00_);[Red]\\\\(\"$\"#,##0.00\\\\)',\n\t\t\"Fixed\": table_fmt[2],\n\t\t\"Standard\": table_fmt[4],\n\t\t\"Percent\": table_fmt[10],\n\t\t\"Scientific\": table_fmt[11],\n\t\t\"Yes/No\": '\"Yes\";\"Yes\";\"No\";@',\n\t\t\"True/False\": '\"True\";\"True\";\"False\";@',\n\t\t\"On/Off\": '\"Yes\";\"Yes\";\"No\";@'\n\t}/*:any*/);\n\n\n\tvar Rn;\n\tvar state = [], tmp;\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\tvar sheets = {}, sheetnames/*:Array<string>*/ = [], cursheet/*:Worksheet*/ = (opts.dense ? [] : {}), sheetname = \"\";\n\tvar cell = ({}/*:any*/), row = {};// eslint-disable-line no-unused-vars\n\tvar dtag = xlml_parsexmltag('<Data ss:Type=\"String\">'), didx = 0;\n\tvar c = 0, r = 0;\n\tvar refguess/*:Range*/ = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\tvar styles = {}, stag = {};\n\tvar ss = \"\", fidx = 0;\n\tvar merges/*:Array<Range>*/ = [];\n\tvar Props = {}, Custprops = {}, pidx = 0, cp = [];\n\tvar comments/*:Array<Comment>*/ = [], comment/*:Comment*/ = ({}/*:any*/);\n\tvar cstys = [], csty, seencol = false;\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar rowinfo/*:Array<RowInfo>*/ = [], rowobj = {}, cc = 0, rr = 0;\n\tvar Workbook/*:WBWBProps*/ = ({ Sheets:[], WBProps:{date1904:false} }/*:any*/), wsprops = {};\n\txlmlregex.lastIndex = 0;\n\tstr = str.replace(/<!--([\\s\\S]*?)-->/mg,\"\");\n\tvar raw_Rn3 = \"\";\n\twhile((Rn = xlmlregex.exec(str))) switch((Rn[3] = (raw_Rn3 = Rn[3]).toLowerCase())) {\n\t\tcase 'data' /*case 'Data'*/:\n\t\t\tif(raw_Rn3 == \"data\") {\n\t\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif(state[state.length-1][1]) break;\n\t\t\tif(Rn[1]==='/') parse_xlml_data(str.slice(didx, Rn.index), ss, dtag, state[state.length-1][0]==/*\"Comment\"*/\"comment\"?comment:cell, {c:c,r:r}, styles, cstys[c], row, arrayf, opts);\n\t\t\telse { ss = \"\"; dtag = xlml_parsexmltag(Rn[0]); didx = Rn.index + Rn[0].length; }\n\t\t\tbreak;\n\t\tcase 'cell' /*case 'Cell'*/:\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif(comments.length > 0) cell.c = comments;\n\t\t\t\tif((!opts.sheetRows || opts.sheetRows > r) && cell.v !== undefined) {\n\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\tif(!cursheet[r]) cursheet[r] = [];\n\t\t\t\t\t\tcursheet[r][c] = cell;\n\t\t\t\t\t} else cursheet[encode_col(c) + encode_row(r)] = cell;\n\t\t\t\t}\n\t\t\t\tif(cell.HRef) {\n\t\t\t\t\tcell.l = ({Target:unescapexml(cell.HRef)}/*:any*/);\n\t\t\t\t\tif(cell.HRefScreenTip) cell.l.Tooltip = cell.HRefScreenTip;\n\t\t\t\t\tdelete cell.HRef; delete cell.HRefScreenTip;\n\t\t\t\t}\n\t\t\t\tif(cell.MergeAcross || cell.MergeDown) {\n\t\t\t\t\tcc = c + (parseInt(cell.MergeAcross,10)|0);\n\t\t\t\t\trr = r + (parseInt(cell.MergeDown,10)|0);\n\t\t\t\t\tmerges.push({s:{c:c,r:r},e:{c:cc,r:rr}});\n\t\t\t\t}\n\t\t\t\tif(!opts.sheetStubs) { if(cell.MergeAcross) c = cc + 1; else ++c; }\n\t\t\t\telse if(cell.MergeAcross || cell.MergeDown) {\n\t\t\t\t\t/*:: if(!cc) cc = 0; if(!rr) rr = 0; */\n\t\t\t\t\tfor(var cma = c; cma <= cc; ++cma) {\n\t\t\t\t\t\tfor(var cmd = r; cmd <= rr; ++cmd) {\n\t\t\t\t\t\t\tif(cma > c || cmd > r) {\n\t\t\t\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\t\t\t\tif(!cursheet[cmd]) cursheet[cmd] = [];\n\t\t\t\t\t\t\t\t\tcursheet[cmd][cma] = {t:'z'};\n\t\t\t\t\t\t\t\t} else cursheet[encode_col(cma) + encode_row(cmd)] = {t:'z'};\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tc = cc + 1;\n\t\t\t\t}\n\t\t\t\telse ++c;\n\t\t\t} else {\n\t\t\t\tcell = xlml_parsexmltagobj(Rn[0]);\n\t\t\t\tif(cell.Index) c = +cell.Index - 1;\n\t\t\t\tif(c < refguess.s.c) refguess.s.c = c;\n\t\t\t\tif(c > refguess.e.c) refguess.e.c = c;\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") ++c;\n\t\t\t\tcomments = [];\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'row' /*case 'Row'*/:\n\t\t\tif(Rn[1]==='/' || Rn[0].slice(-2) === \"/>\") {\n\t\t\t\tif(r < refguess.s.r) refguess.s.r = r;\n\t\t\t\tif(r > refguess.e.r) refguess.e.r = r;\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") {\n\t\t\t\t\trow = xlml_parsexmltag(Rn[0]);\n\t\t\t\t\tif(row.Index) r = +row.Index - 1;\n\t\t\t\t}\n\t\t\t\tc = 0; ++r;\n\t\t\t} else {\n\t\t\t\trow = xlml_parsexmltag(Rn[0]);\n\t\t\t\tif(row.Index) r = +row.Index - 1;\n\t\t\t\trowobj = {};\n\t\t\t\tif(row.AutoFitHeight == \"0\" || row.Height) {\n\t\t\t\t\trowobj.hpx = parseInt(row.Height, 10); rowobj.hpt = px2pt(rowobj.hpx);\n\t\t\t\t\trowinfo[r] = rowobj;\n\t\t\t\t}\n\t\t\t\tif(row.Hidden == \"1\") { rowobj.hidden = true; rowinfo[r] = rowobj; }\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'worksheet' /*case 'Worksheet'*/: /* TODO: read range from FullRows/FullColumns */\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));\n\t\t\t\tsheetnames.push(sheetname);\n\t\t\t\tif(refguess.s.r <= refguess.e.r && refguess.s.c <= refguess.e.c) {\n\t\t\t\t\tcursheet[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\tif(opts.sheetRows && opts.sheetRows <= refguess.e.r) {\n\t\t\t\t\t\tcursheet[\"!fullref\"] = cursheet[\"!ref\"];\n\t\t\t\t\t\trefguess.e.r = opts.sheetRows - 1;\n\t\t\t\t\t\tcursheet[\"!ref\"] = encode_range(refguess);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif(merges.length) cursheet[\"!merges\"] = merges;\n\t\t\t\tif(cstys.length > 0) cursheet[\"!cols\"] = cstys;\n\t\t\t\tif(rowinfo.length > 0) cursheet[\"!rows\"] = rowinfo;\n\t\t\t\tsheets[sheetname] = cursheet;\n\t\t\t} else {\n\t\t\t\trefguess = {s: {r:2000000, c:2000000}, e: {r:0, c:0} };\n\t\t\t\tr = c = 0;\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\ttmp = xlml_parsexmltag(Rn[0]);\n\t\t\t\tsheetname = unescapexml(tmp.Name);\n\t\t\t\tcursheet = (opts.dense ? [] : {});\n\t\t\t\tmerges = [];\n\t\t\t\tarrayf = [];\n\t\t\t\trowinfo = [];\n\t\t\t\twsprops = {name:sheetname, Hidden:0};\n\t\t\t\tWorkbook.Sheets.push(wsprops);\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 'table' /*case 'Table'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse if(Rn[0].slice(-2) == \"/>\") break;\n\t\t\telse {\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\tcstys = []; seencol = false;\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'style' /*case 'Style'*/:\n\t\t\tif(Rn[1]==='/') process_style_xlml(styles, stag, opts);\n\t\t\telse stag = xlml_parsexmltag(Rn[0]);\n\t\t\tbreak;\n\n\t\tcase 'numberformat' /*case 'NumberFormat'*/:\n\t\t\tstag.nf = unescapexml(xlml_parsexmltag(Rn[0]).Format || \"General\");\n\t\t\tif(XLMLFormatMap[stag.nf]) stag.nf = XLMLFormatMap[stag.nf];\n\t\t\tfor(var ssfidx = 0; ssfidx != 0x188; ++ssfidx) if(table_fmt[ssfidx] == stag.nf) break;\n\t\t\tif(ssfidx == 0x188) for(ssfidx = 0x39; ssfidx != 0x188; ++ssfidx) if(table_fmt[ssfidx] == null) { SSF_load(stag.nf, ssfidx); break; }\n\t\t\tbreak;\n\n\t\tcase 'column' /*case 'Column'*/:\n\t\t\tif(state[state.length-1][0] !== /*'Table'*/'table') break;\n\t\t\tcsty = xlml_parsexmltag(Rn[0]);\n\t\t\tif(csty.Hidden) { csty.hidden = true; delete csty.Hidden; }\n\t\t\tif(csty.Width) csty.wpx = parseInt(csty.Width, 10);\n\t\t\tif(!seencol && csty.wpx > 10) {\n\t\t\t\tseencol = true; MDW = DEF_MDW; //find_mdw_wpx(csty.wpx);\n\t\t\t\tfor(var _col = 0; _col < cstys.length; ++_col) if(cstys[_col]) process_col(cstys[_col]);\n\t\t\t}\n\t\t\tif(seencol) process_col(csty);\n\t\t\tcstys[(csty.Index-1||cstys.length)] = csty;\n\t\t\tfor(var i = 0; i < +csty.Span; ++i) cstys[cstys.length] = dup(csty);\n\t\t\tbreak;\n\n\t\tcase 'namedrange' /*case 'NamedRange'*/:\n\t\t\tif(Rn[1]==='/') break;\n\t\t\tif(!Workbook.Names) Workbook.Names = [];\n\t\t\tvar _NamedRange = parsexmltag(Rn[0]);\n\t\t\tvar _DefinedName/*:DefinedName*/ = ({\n\t\t\t\tName: _NamedRange.Name,\n\t\t\t\tRef: rc_to_a1(_NamedRange.RefersTo.slice(1), {r:0, c:0})\n\t\t\t}/*:any*/);\n\t\t\tif(Workbook.Sheets.length>0) _DefinedName.Sheet=Workbook.Sheets.length-1;\n\t\t\t/*:: if(Workbook.Names) */Workbook.Names.push(_DefinedName);\n\t\t\tbreak;\n\n\t\tcase 'namedcell' /*case 'NamedCell'*/: break;\n\t\tcase 'b' /*case 'B'*/: break;\n\t\tcase 'i' /*case 'I'*/: break;\n\t\tcase 'u' /*case 'U'*/: break;\n\t\tcase 's' /*case 'S'*/: break;\n\t\tcase 'em' /*case 'EM'*/: break;\n\t\tcase 'h2' /*case 'H2'*/: break;\n\t\tcase 'h3' /*case 'H3'*/: break;\n\t\tcase 'sub' /*case 'Sub'*/: break;\n\t\tcase 'sup' /*case 'Sup'*/: break;\n\t\tcase 'span' /*case 'Span'*/: break;\n\t\tcase 'alignment' /*case 'Alignment'*/:\n\t\t\tbreak;\n\t\tcase 'borders' /*case 'Borders'*/: break;\n\t\tcase 'border' /*case 'Border'*/: break;\n\t\tcase 'font' /*case 'Font'*/:\n\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\telse if(Rn[1]===\"/\") ss += str.slice(fidx, Rn.index);\n\t\t\telse fidx = Rn.index + Rn[0].length;\n\t\t\tbreak;\n\t\tcase 'interior' /*case 'Interior'*/:\n\t\t\tif(!opts.cellStyles) break;\n\t\t\tstag.Interior = xlml_parsexmltag(Rn[0]);\n\t\t\tbreak;\n\t\tcase 'protection' /*case 'Protection'*/: break;\n\n\t\tcase 'author' /*case 'Author'*/:\n\t\tcase 'title' /*case 'Title'*/:\n\t\tcase 'description' /*case 'Description'*/:\n\t\tcase 'created' /*case 'Created'*/:\n\t\tcase 'keywords' /*case 'Keywords'*/:\n\t\tcase 'subject' /*case 'Subject'*/:\n\t\tcase 'category' /*case 'Category'*/:\n\t\tcase 'company' /*case 'Company'*/:\n\t\tcase 'lastauthor' /*case 'LastAuthor'*/:\n\t\tcase 'lastsaved' /*case 'LastSaved'*/:\n\t\tcase 'lastprinted' /*case 'LastPrinted'*/:\n\t\tcase 'version' /*case 'Version'*/:\n\t\tcase 'revision' /*case 'Revision'*/:\n\t\tcase 'totaltime' /*case 'TotalTime'*/:\n\t\tcase 'hyperlinkbase' /*case 'HyperlinkBase'*/:\n\t\tcase 'manager' /*case 'Manager'*/:\n\t\tcase 'contentstatus' /*case 'ContentStatus'*/:\n\t\tcase 'identifier' /*case 'Identifier'*/:\n\t\tcase 'language' /*case 'Language'*/:\n\t\tcase 'appname' /*case 'AppName'*/:\n\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\telse if(Rn[1]===\"/\") xlml_set_prop(Props, raw_Rn3, str.slice(pidx, Rn.index));\n\t\t\telse pidx = Rn.index + Rn[0].length;\n\t\t\tbreak;\n\t\tcase 'paragraphs' /*case 'Paragraphs'*/: break;\n\n\t\tcase 'styles' /*case 'Styles'*/:\n\t\tcase 'workbook' /*case 'Workbook'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse state.push([Rn[3], false]);\n\t\t\tbreak;\n\n\t\tcase 'comment' /*case 'Comment'*/:\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));\n\t\t\t\txlml_clean_comment(comment);\n\t\t\t\tcomments.push(comment);\n\t\t\t} else {\n\t\t\t\tstate.push([Rn[3], false]);\n\t\t\t\ttmp = xlml_parsexmltag(Rn[0]);\n\t\t\t\tcomment = ({a:tmp.Author}/*:any*/);\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'autofilter' /*case 'AutoFilter'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') {\n\t\t\t\tvar AutoFilter = xlml_parsexmltag(Rn[0]);\n\t\t\t\tcursheet['!autofilter'] = { ref:rc_to_a1(AutoFilter.Range).replace(/\\$/g,\"\") };\n\t\t\t\tstate.push([Rn[3], true]);\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'name' /*case 'Name'*/: break;\n\n\t\tcase 'datavalidation' /*case 'DataValidation'*/:\n\t\t\tif(Rn[1]==='/'){\n\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));\n\t\t\t} else {\n\t\t\t\tif(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\t}\n\t\t\tbreak;\n\n\t\tcase 'pixelsperinch' /*case 'PixelsPerInch'*/:\n\t\t\tbreak;\n\t\tcase 'componentoptions' /*case 'ComponentOptions'*/:\n\t\tcase 'documentproperties' /*case 'DocumentProperties'*/:\n\t\tcase 'customdocumentproperties' /*case 'CustomDocumentProperties'*/:\n\t\tcase 'officedocumentsettings' /*case 'OfficeDocumentSettings'*/:\n\t\tcase 'pivottable' /*case 'PivotTable'*/:\n\t\tcase 'pivotcache' /*case 'PivotCache'*/:\n\t\tcase 'names' /*case 'Names'*/:\n\t\tcase 'mapinfo' /*case 'MapInfo'*/:\n\t\tcase 'pagebreaks' /*case 'PageBreaks'*/:\n\t\tcase 'querytable' /*case 'QueryTable'*/:\n\t\tcase 'sorting' /*case 'Sorting'*/:\n\t\tcase 'schema' /*case 'Schema'*/: //case 'data' /*case 'data'*/:\n\t\tcase 'conditionalformatting' /*case 'ConditionalFormatting'*/:\n\t\tcase 'smarttagtype' /*case 'SmartTagType'*/:\n\t\tcase 'smarttags' /*case 'SmartTags'*/:\n\t\tcase 'excelworkbook' /*case 'ExcelWorkbook'*/:\n\t\tcase 'workbookoptions' /*case 'WorkbookOptions'*/:\n\t\tcase 'worksheetoptions' /*case 'WorksheetOptions'*/:\n\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw new Error(\"Bad state: \"+tmp.join(\"|\"));}\n\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\tbreak;\n\n\t\tcase 'null' /*case 'Null'*/: break;\n\n\t\tdefault:\n\t\t\t/* FODS file root is <office:document> */\n\t\t\tif(state.length == 0 && Rn[3] == \"document\") return parse_fods(str, opts);\n\t\t\t/* UOS file root is <uof:UOF> */\n\t\t\tif(state.length == 0 && Rn[3] == \"uof\"/*\"UOF\"*/) return parse_fods(str, opts);\n\n\t\t\tvar seen = true;\n\t\t\tswitch(state[state.length-1][0]) {\n\t\t\t\t/* OfficeDocumentSettings */\n\t\t\t\tcase 'officedocumentsettings' /*case 'OfficeDocumentSettings'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'allowpng' /*case 'AllowPNG'*/: break;\n\t\t\t\t\tcase 'removepersonalinformation' /*case 'RemovePersonalInformation'*/: break;\n\t\t\t\t\tcase 'downloadcomponents' /*case 'DownloadComponents'*/: break;\n\t\t\t\t\tcase 'locationofcomponents' /*case 'LocationOfComponents'*/: break;\n\t\t\t\t\tcase 'colors' /*case 'Colors'*/: break;\n\t\t\t\t\tcase 'color' /*case 'Color'*/: break;\n\t\t\t\t\tcase 'index' /*case 'Index'*/: break;\n\t\t\t\t\tcase 'rgb' /*case 'RGB'*/: break;\n\t\t\t\t\tcase 'targetscreensize' /*case 'TargetScreenSize'*/: break;\n\t\t\t\t\tcase 'readonlyrecommended' /*case 'ReadOnlyRecommended'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* ComponentOptions */\n\t\t\t\tcase 'componentoptions' /*case 'ComponentOptions'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'toolbar' /*case 'Toolbar'*/: break;\n\t\t\t\t\tcase 'hideofficelogo' /*case 'HideOfficeLogo'*/: break;\n\t\t\t\t\tcase 'spreadsheetautofit' /*case 'SpreadsheetAutoFit'*/: break;\n\t\t\t\t\tcase 'label' /*case 'Label'*/: break;\n\t\t\t\t\tcase 'caption' /*case 'Caption'*/: break;\n\t\t\t\t\tcase 'maxheight' /*case 'MaxHeight'*/: break;\n\t\t\t\t\tcase 'maxwidth' /*case 'MaxWidth'*/: break;\n\t\t\t\t\tcase 'nextsheetnumber' /*case 'NextSheetNumber'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* ExcelWorkbook */\n\t\t\t\tcase 'excelworkbook' /*case 'ExcelWorkbook'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'date1904' /*case 'Date1904'*/:\n\t\t\t\t\t\t/*:: if(!Workbook.WBProps) Workbook.WBProps = {}; */\n\t\t\t\t\t\tWorkbook.WBProps.date1904 = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'windowheight' /*case 'WindowHeight'*/: break;\n\t\t\t\t\tcase 'windowwidth' /*case 'WindowWidth'*/: break;\n\t\t\t\t\tcase 'windowtopx' /*case 'WindowTopX'*/: break;\n\t\t\t\t\tcase 'windowtopy' /*case 'WindowTopY'*/: break;\n\t\t\t\t\tcase 'tabratio' /*case 'TabRatio'*/: break;\n\t\t\t\t\tcase 'protectstructure' /*case 'ProtectStructure'*/: break;\n\t\t\t\t\tcase 'protectwindow' /*case 'ProtectWindow'*/: break;\n\t\t\t\t\tcase 'protectwindows' /*case 'ProtectWindows'*/: break;\n\t\t\t\t\tcase 'activesheet' /*case 'ActiveSheet'*/: break;\n\t\t\t\t\tcase 'displayinknotes' /*case 'DisplayInkNotes'*/: break;\n\t\t\t\t\tcase 'firstvisiblesheet' /*case 'FirstVisibleSheet'*/: break;\n\t\t\t\t\tcase 'supbook' /*case 'SupBook'*/: break;\n\t\t\t\t\tcase 'sheetname' /*case 'SheetName'*/: break;\n\t\t\t\t\tcase 'sheetindex' /*case 'SheetIndex'*/: break;\n\t\t\t\t\tcase 'sheetindexfirst' /*case 'SheetIndexFirst'*/: break;\n\t\t\t\t\tcase 'sheetindexlast' /*case 'SheetIndexLast'*/: break;\n\t\t\t\t\tcase 'dll' /*case 'Dll'*/: break;\n\t\t\t\t\tcase 'acceptlabelsinformulas' /*case 'AcceptLabelsInFormulas'*/: break;\n\t\t\t\t\tcase 'donotsavelinkvalues' /*case 'DoNotSaveLinkValues'*/: break;\n\t\t\t\t\tcase 'iteration' /*case 'Iteration'*/: break;\n\t\t\t\t\tcase 'maxiterations' /*case 'MaxIterations'*/: break;\n\t\t\t\t\tcase 'maxchange' /*case 'MaxChange'*/: break;\n\t\t\t\t\tcase 'path' /*case 'Path'*/: break;\n\t\t\t\t\tcase 'xct' /*case 'Xct'*/: break;\n\t\t\t\t\tcase 'count' /*case 'Count'*/: break;\n\t\t\t\t\tcase 'selectedsheets' /*case 'SelectedSheets'*/: break;\n\t\t\t\t\tcase 'calculation' /*case 'Calculation'*/: break;\n\t\t\t\t\tcase 'uncalced' /*case 'Uncalced'*/: break;\n\t\t\t\t\tcase 'startupprompt' /*case 'StartupPrompt'*/: break;\n\t\t\t\t\tcase 'crn' /*case 'Crn'*/: break;\n\t\t\t\t\tcase 'externname' /*case 'ExternName'*/: break;\n\t\t\t\t\tcase 'formula' /*case 'Formula'*/: break;\n\t\t\t\t\tcase 'colfirst' /*case 'ColFirst'*/: break;\n\t\t\t\t\tcase 'collast' /*case 'ColLast'*/: break;\n\t\t\t\t\tcase 'wantadvise' /*case 'WantAdvise'*/: break;\n\t\t\t\t\tcase 'boolean' /*case 'Boolean'*/: break;\n\t\t\t\t\tcase 'error' /*case 'Error'*/: break;\n\t\t\t\t\tcase 'text' /*case 'Text'*/: break;\n\t\t\t\t\tcase 'ole' /*case 'OLE'*/: break;\n\t\t\t\t\tcase 'noautorecover' /*case 'NoAutoRecover'*/: break;\n\t\t\t\t\tcase 'publishobjects' /*case 'PublishObjects'*/: break;\n\t\t\t\t\tcase 'donotcalculatebeforesave' /*case 'DoNotCalculateBeforeSave'*/: break;\n\t\t\t\t\tcase 'number' /*case 'Number'*/: break;\n\t\t\t\t\tcase 'refmoder1c1' /*case 'RefModeR1C1'*/: break;\n\t\t\t\t\tcase 'embedsavesmarttags' /*case 'EmbedSaveSmartTags'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* WorkbookOptions */\n\t\t\t\tcase 'workbookoptions' /*case 'WorkbookOptions'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'owcversion' /*case 'OWCVersion'*/: break;\n\t\t\t\t\tcase 'height' /*case 'Height'*/: break;\n\t\t\t\t\tcase 'width' /*case 'Width'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* WorksheetOptions */\n\t\t\t\tcase 'worksheetoptions' /*case 'WorksheetOptions'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'visible' /*case 'Visible'*/:\n\t\t\t\t\t\tif(Rn[0].slice(-2) === \"/>\"){/* empty */}\n\t\t\t\t\t\telse if(Rn[1]===\"/\") switch(str.slice(pidx, Rn.index)) {\n\t\t\t\t\t\t\tcase \"SheetHidden\": wsprops.Hidden = 1; break;\n\t\t\t\t\t\t\tcase \"SheetVeryHidden\": wsprops.Hidden = 2; break;\n\t\t\t\t\t\t}\n\t\t\t\t\t\telse pidx = Rn.index + Rn[0].length;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'header' /*case 'Header'*/:\n\t\t\t\t\t\tif(!cursheet['!margins']) default_margins(cursheet['!margins']={}, 'xlml');\n\t\t\t\t\t\tif(!isNaN(+parsexmltag(Rn[0]).Margin)) cursheet['!margins'].header = +parsexmltag(Rn[0]).Margin;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'footer' /*case 'Footer'*/:\n\t\t\t\t\t\tif(!cursheet['!margins']) default_margins(cursheet['!margins']={}, 'xlml');\n\t\t\t\t\t\tif(!isNaN(+parsexmltag(Rn[0]).Margin)) cursheet['!margins'].footer = +parsexmltag(Rn[0]).Margin;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'pagemargins' /*case 'PageMargins'*/:\n\t\t\t\t\t\tvar pagemargins = parsexmltag(Rn[0]);\n\t\t\t\t\t\tif(!cursheet['!margins']) default_margins(cursheet['!margins']={},'xlml');\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Top)) cursheet['!margins'].top = +pagemargins.Top;\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Left)) cursheet['!margins'].left = +pagemargins.Left;\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Right)) cursheet['!margins'].right = +pagemargins.Right;\n\t\t\t\t\t\tif(!isNaN(+pagemargins.Bottom)) cursheet['!margins'].bottom = +pagemargins.Bottom;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'displayrighttoleft' /*case 'DisplayRightToLeft'*/:\n\t\t\t\t\t\tif(!Workbook.Views) Workbook.Views = [];\n\t\t\t\t\t\tif(!Workbook.Views[0]) Workbook.Views[0] = {};\n\t\t\t\t\t\tWorkbook.Views[0].RTL = true;\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'freezepanes' /*case 'FreezePanes'*/: break;\n\t\t\t\t\tcase 'frozennosplit' /*case 'FrozenNoSplit'*/: break;\n\n\t\t\t\t\tcase 'splithorizontal' /*case 'SplitHorizontal'*/:\n\t\t\t\t\tcase 'splitvertical' /*case 'SplitVertical'*/:\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'donotdisplaygridlines' /*case 'DoNotDisplayGridlines'*/:\n\t\t\t\t\t\tbreak;\n\n\t\t\t\t\tcase 'activerow' /*case 'ActiveRow'*/: break;\n\t\t\t\t\tcase 'activecol' /*case 'ActiveCol'*/: break;\n\t\t\t\t\tcase 'toprowbottompane' /*case 'TopRowBottomPane'*/: break;\n\t\t\t\t\tcase 'leftcolumnrightpane' /*case 'LeftColumnRightPane'*/: break;\n\n\t\t\t\t\tcase 'unsynced' /*case 'Unsynced'*/: break;\n\t\t\t\t\tcase 'print' /*case 'Print'*/: break;\n\t\t\t\t\tcase 'printerrors' /*case 'PrintErrors'*/: break;\n\t\t\t\t\tcase 'panes' /*case 'Panes'*/: break;\n\t\t\t\t\tcase 'scale' /*case 'Scale'*/: break;\n\t\t\t\t\tcase 'pane' /*case 'Pane'*/: break;\n\t\t\t\t\tcase 'number' /*case 'Number'*/: break;\n\t\t\t\t\tcase 'layout' /*case 'Layout'*/: break;\n\t\t\t\t\tcase 'pagesetup' /*case 'PageSetup'*/: break;\n\t\t\t\t\tcase 'selected' /*case 'Selected'*/: break;\n\t\t\t\t\tcase 'protectobjects' /*case 'ProtectObjects'*/: break;\n\t\t\t\t\tcase 'enableselection' /*case 'EnableSelection'*/: break;\n\t\t\t\t\tcase 'protectscenarios' /*case 'ProtectScenarios'*/: break;\n\t\t\t\t\tcase 'validprinterinfo' /*case 'ValidPrinterInfo'*/: break;\n\t\t\t\t\tcase 'horizontalresolution' /*case 'HorizontalResolution'*/: break;\n\t\t\t\t\tcase 'verticalresolution' /*case 'VerticalResolution'*/: break;\n\t\t\t\t\tcase 'numberofcopies' /*case 'NumberofCopies'*/: break;\n\t\t\t\t\tcase 'activepane' /*case 'ActivePane'*/: break;\n\t\t\t\t\tcase 'toprowvisible' /*case 'TopRowVisible'*/: break;\n\t\t\t\t\tcase 'leftcolumnvisible' /*case 'LeftColumnVisible'*/: break;\n\t\t\t\t\tcase 'fittopage' /*case 'FitToPage'*/: break;\n\t\t\t\t\tcase 'rangeselection' /*case 'RangeSelection'*/: break;\n\t\t\t\t\tcase 'papersizeindex' /*case 'PaperSizeIndex'*/: break;\n\t\t\t\t\tcase 'pagelayoutzoom' /*case 'PageLayoutZoom'*/: break;\n\t\t\t\t\tcase 'pagebreakzoom' /*case 'PageBreakZoom'*/: break;\n\t\t\t\t\tcase 'filteron' /*case 'FilterOn'*/: break;\n\t\t\t\t\tcase 'fitwidth' /*case 'FitWidth'*/: break;\n\t\t\t\t\tcase 'fitheight' /*case 'FitHeight'*/: break;\n\t\t\t\t\tcase 'commentslayout' /*case 'CommentsLayout'*/: break;\n\t\t\t\t\tcase 'zoom' /*case 'Zoom'*/: break;\n\t\t\t\t\tcase 'lefttoright' /*case 'LeftToRight'*/: break;\n\t\t\t\t\tcase 'gridlines' /*case 'Gridlines'*/: break;\n\t\t\t\t\tcase 'allowsort' /*case 'AllowSort'*/: break;\n\t\t\t\t\tcase 'allowfilter' /*case 'AllowFilter'*/: break;\n\t\t\t\t\tcase 'allowinsertrows' /*case 'AllowInsertRows'*/: break;\n\t\t\t\t\tcase 'allowdeleterows' /*case 'AllowDeleteRows'*/: break;\n\t\t\t\t\tcase 'allowinsertcols' /*case 'AllowInsertCols'*/: break;\n\t\t\t\t\tcase 'allowdeletecols' /*case 'AllowDeleteCols'*/: break;\n\t\t\t\t\tcase 'allowinserthyperlinks' /*case 'AllowInsertHyperlinks'*/: break;\n\t\t\t\t\tcase 'allowformatcells' /*case 'AllowFormatCells'*/: break;\n\t\t\t\t\tcase 'allowsizecols' /*case 'AllowSizeCols'*/: break;\n\t\t\t\t\tcase 'allowsizerows' /*case 'AllowSizeRows'*/: break;\n\t\t\t\t\tcase 'nosummaryrowsbelowdetail' /*case 'NoSummaryRowsBelowDetail'*/:\n\t\t\t\t\t\tif(!cursheet[\"!outline\"]) cursheet[\"!outline\"] = {};\n\t\t\t\t\t\tcursheet[\"!outline\"].above = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'tabcolorindex' /*case 'TabColorIndex'*/: break;\n\t\t\t\t\tcase 'donotdisplayheadings' /*case 'DoNotDisplayHeadings'*/: break;\n\t\t\t\t\tcase 'showpagelayoutzoom' /*case 'ShowPageLayoutZoom'*/: break;\n\t\t\t\t\tcase 'nosummarycolumnsrightdetail' /*case 'NoSummaryColumnsRightDetail'*/:\n\t\t\t\t\t\tif(!cursheet[\"!outline\"]) cursheet[\"!outline\"] = {};\n\t\t\t\t\t\tcursheet[\"!outline\"].left = true;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'blackandwhite' /*case 'BlackAndWhite'*/: break;\n\t\t\t\t\tcase 'donotdisplayzeros' /*case 'DoNotDisplayZeros'*/: break;\n\t\t\t\t\tcase 'displaypagebreak' /*case 'DisplayPageBreak'*/: break;\n\t\t\t\t\tcase 'rowcolheadings' /*case 'RowColHeadings'*/: break;\n\t\t\t\t\tcase 'donotdisplayoutline' /*case 'DoNotDisplayOutline'*/: break;\n\t\t\t\t\tcase 'noorientation' /*case 'NoOrientation'*/: break;\n\t\t\t\t\tcase 'allowusepivottables' /*case 'AllowUsePivotTables'*/: break;\n\t\t\t\t\tcase 'zeroheight' /*case 'ZeroHeight'*/: break;\n\t\t\t\t\tcase 'viewablerange' /*case 'ViewableRange'*/: break;\n\t\t\t\t\tcase 'selection' /*case 'Selection'*/: break;\n\t\t\t\t\tcase 'protectcontents' /*case 'ProtectContents'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* PivotTable */\n\t\t\t\tcase 'pivottable' /*case 'PivotTable'*/: case 'pivotcache' /*case 'PivotCache'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'immediateitemsondrop' /*case 'ImmediateItemsOnDrop'*/: break;\n\t\t\t\t\tcase 'showpagemultipleitemlabel' /*case 'ShowPageMultipleItemLabel'*/: break;\n\t\t\t\t\tcase 'compactrowindent' /*case 'CompactRowIndent'*/: break;\n\t\t\t\t\tcase 'location' /*case 'Location'*/: break;\n\t\t\t\t\tcase 'pivotfield' /*case 'PivotField'*/: break;\n\t\t\t\t\tcase 'orientation' /*case 'Orientation'*/: break;\n\t\t\t\t\tcase 'layoutform' /*case 'LayoutForm'*/: break;\n\t\t\t\t\tcase 'layoutsubtotallocation' /*case 'LayoutSubtotalLocation'*/: break;\n\t\t\t\t\tcase 'layoutcompactrow' /*case 'LayoutCompactRow'*/: break;\n\t\t\t\t\tcase 'position' /*case 'Position'*/: break;\n\t\t\t\t\tcase 'pivotitem' /*case 'PivotItem'*/: break;\n\t\t\t\t\tcase 'datatype' /*case 'DataType'*/: break;\n\t\t\t\t\tcase 'datafield' /*case 'DataField'*/: break;\n\t\t\t\t\tcase 'sourcename' /*case 'SourceName'*/: break;\n\t\t\t\t\tcase 'parentfield' /*case 'ParentField'*/: break;\n\t\t\t\t\tcase 'ptlineitems' /*case 'PTLineItems'*/: break;\n\t\t\t\t\tcase 'ptlineitem' /*case 'PTLineItem'*/: break;\n\t\t\t\t\tcase 'countofsameitems' /*case 'CountOfSameItems'*/: break;\n\t\t\t\t\tcase 'item' /*case 'Item'*/: break;\n\t\t\t\t\tcase 'itemtype' /*case 'ItemType'*/: break;\n\t\t\t\t\tcase 'ptsource' /*case 'PTSource'*/: break;\n\t\t\t\t\tcase 'cacheindex' /*case 'CacheIndex'*/: break;\n\t\t\t\t\tcase 'consolidationreference' /*case 'ConsolidationReference'*/: break;\n\t\t\t\t\tcase 'filename' /*case 'FileName'*/: break;\n\t\t\t\t\tcase 'reference' /*case 'Reference'*/: break;\n\t\t\t\t\tcase 'nocolumngrand' /*case 'NoColumnGrand'*/: break;\n\t\t\t\t\tcase 'norowgrand' /*case 'NoRowGrand'*/: break;\n\t\t\t\t\tcase 'blanklineafteritems' /*case 'BlankLineAfterItems'*/: break;\n\t\t\t\t\tcase 'hidden' /*case 'Hidden'*/: break;\n\t\t\t\t\tcase 'subtotal' /*case 'Subtotal'*/: break;\n\t\t\t\t\tcase 'basefield' /*case 'BaseField'*/: break;\n\t\t\t\t\tcase 'mapchilditems' /*case 'MapChildItems'*/: break;\n\t\t\t\t\tcase 'function' /*case 'Function'*/: break;\n\t\t\t\t\tcase 'refreshonfileopen' /*case 'RefreshOnFileOpen'*/: break;\n\t\t\t\t\tcase 'printsettitles' /*case 'PrintSetTitles'*/: break;\n\t\t\t\t\tcase 'mergelabels' /*case 'MergeLabels'*/: break;\n\t\t\t\t\tcase 'defaultversion' /*case 'DefaultVersion'*/: break;\n\t\t\t\t\tcase 'refreshname' /*case 'RefreshName'*/: break;\n\t\t\t\t\tcase 'refreshdate' /*case 'RefreshDate'*/: break;\n\t\t\t\t\tcase 'refreshdatecopy' /*case 'RefreshDateCopy'*/: break;\n\t\t\t\t\tcase 'versionlastrefresh' /*case 'VersionLastRefresh'*/: break;\n\t\t\t\t\tcase 'versionlastupdate' /*case 'VersionLastUpdate'*/: break;\n\t\t\t\t\tcase 'versionupdateablemin' /*case 'VersionUpdateableMin'*/: break;\n\t\t\t\t\tcase 'versionrefreshablemin' /*case 'VersionRefreshableMin'*/: break;\n\t\t\t\t\tcase 'calculation' /*case 'Calculation'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* PageBreaks */\n\t\t\t\tcase 'pagebreaks' /*case 'PageBreaks'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'colbreaks' /*case 'ColBreaks'*/: break;\n\t\t\t\t\tcase 'colbreak' /*case 'ColBreak'*/: break;\n\t\t\t\t\tcase 'rowbreaks' /*case 'RowBreaks'*/: break;\n\t\t\t\t\tcase 'rowbreak' /*case 'RowBreak'*/: break;\n\t\t\t\t\tcase 'colstart' /*case 'ColStart'*/: break;\n\t\t\t\t\tcase 'colend' /*case 'ColEnd'*/: break;\n\t\t\t\t\tcase 'rowend' /*case 'RowEnd'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* AutoFilter */\n\t\t\t\tcase 'autofilter' /*case 'AutoFilter'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'autofiltercolumn' /*case 'AutoFilterColumn'*/: break;\n\t\t\t\t\tcase 'autofiltercondition' /*case 'AutoFilterCondition'*/: break;\n\t\t\t\t\tcase 'autofilterand' /*case 'AutoFilterAnd'*/: break;\n\t\t\t\t\tcase 'autofilteror' /*case 'AutoFilterOr'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* QueryTable */\n\t\t\t\tcase 'querytable' /*case 'QueryTable'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'id' /*case 'Id'*/: break;\n\t\t\t\t\tcase 'autoformatfont' /*case 'AutoFormatFont'*/: break;\n\t\t\t\t\tcase 'autoformatpattern' /*case 'AutoFormatPattern'*/: break;\n\t\t\t\t\tcase 'querysource' /*case 'QuerySource'*/: break;\n\t\t\t\t\tcase 'querytype' /*case 'QueryType'*/: break;\n\t\t\t\t\tcase 'enableredirections' /*case 'EnableRedirections'*/: break;\n\t\t\t\t\tcase 'refreshedinxl9' /*case 'RefreshedInXl9'*/: break;\n\t\t\t\t\tcase 'urlstring' /*case 'URLString'*/: break;\n\t\t\t\t\tcase 'htmltables' /*case 'HTMLTables'*/: break;\n\t\t\t\t\tcase 'connection' /*case 'Connection'*/: break;\n\t\t\t\t\tcase 'commandtext' /*case 'CommandText'*/: break;\n\t\t\t\t\tcase 'refreshinfo' /*case 'RefreshInfo'*/: break;\n\t\t\t\t\tcase 'notitles' /*case 'NoTitles'*/: break;\n\t\t\t\t\tcase 'nextid' /*case 'NextId'*/: break;\n\t\t\t\t\tcase 'columninfo' /*case 'ColumnInfo'*/: break;\n\t\t\t\t\tcase 'overwritecells' /*case 'OverwriteCells'*/: break;\n\t\t\t\t\tcase 'donotpromptforfile' /*case 'DoNotPromptForFile'*/: break;\n\t\t\t\t\tcase 'textwizardsettings' /*case 'TextWizardSettings'*/: break;\n\t\t\t\t\tcase 'source' /*case 'Source'*/: break;\n\t\t\t\t\tcase 'number' /*case 'Number'*/: break;\n\t\t\t\t\tcase 'decimal' /*case 'Decimal'*/: break;\n\t\t\t\t\tcase 'thousandseparator' /*case 'ThousandSeparator'*/: break;\n\t\t\t\t\tcase 'trailingminusnumbers' /*case 'TrailingMinusNumbers'*/: break;\n\t\t\t\t\tcase 'formatsettings' /*case 'FormatSettings'*/: break;\n\t\t\t\t\tcase 'fieldtype' /*case 'FieldType'*/: break;\n\t\t\t\t\tcase 'delimiters' /*case 'Delimiters'*/: break;\n\t\t\t\t\tcase 'tab' /*case 'Tab'*/: break;\n\t\t\t\t\tcase 'comma' /*case 'Comma'*/: break;\n\t\t\t\t\tcase 'autoformatname' /*case 'AutoFormatName'*/: break;\n\t\t\t\t\tcase 'versionlastedit' /*case 'VersionLastEdit'*/: break;\n\t\t\t\t\tcase 'versionlastrefresh' /*case 'VersionLastRefresh'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\tcase 'datavalidation' /*case 'DataValidation'*/:\n\t\t\t\tswitch(Rn[3]) {\n\t\t\t\t\tcase 'range' /*case 'Range'*/: break;\n\n\t\t\t\t\tcase 'type' /*case 'Type'*/: break;\n\t\t\t\t\tcase 'min' /*case 'Min'*/: break;\n\t\t\t\t\tcase 'max' /*case 'Max'*/: break;\n\t\t\t\t\tcase 'sort' /*case 'Sort'*/: break;\n\t\t\t\t\tcase 'descending' /*case 'Descending'*/: break;\n\t\t\t\t\tcase 'order' /*case 'Order'*/: break;\n\t\t\t\t\tcase 'casesensitive' /*case 'CaseSensitive'*/: break;\n\t\t\t\t\tcase 'value' /*case 'Value'*/: break;\n\t\t\t\t\tcase 'errorstyle' /*case 'ErrorStyle'*/: break;\n\t\t\t\t\tcase 'errormessage' /*case 'ErrorMessage'*/: break;\n\t\t\t\t\tcase 'errortitle' /*case 'ErrorTitle'*/: break;\n\t\t\t\t\tcase 'inputmessage' /*case 'InputMessage'*/: break;\n\t\t\t\t\tcase 'inputtitle' /*case 'InputTitle'*/: break;\n\t\t\t\t\tcase 'combohide' /*case 'ComboHide'*/: break;\n\t\t\t\t\tcase 'inputhide' /*case 'InputHide'*/: break;\n\t\t\t\t\tcase 'condition' /*case 'Condition'*/: break;\n\t\t\t\t\tcase 'qualifier' /*case 'Qualifier'*/: break;\n\t\t\t\t\tcase 'useblank' /*case 'UseBlank'*/: break;\n\t\t\t\t\tcase 'value1' /*case 'Value1'*/: break;\n\t\t\t\t\tcase 'value2' /*case 'Value2'*/: break;\n\t\t\t\t\tcase 'format' /*case 'Format'*/: break;\n\n\t\t\t\t\tcase 'cellrangelist' /*case 'CellRangeList'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\tcase 'sorting' /*case 'Sorting'*/:\n\t\t\t\tcase 'conditionalformatting' /*case 'ConditionalFormatting'*/:\n\t\t\t\tswitch(Rn[3]) {\n\t\t\t\t\tcase 'range' /*case 'Range'*/: break;\n\t\t\t\t\tcase 'type' /*case 'Type'*/: break;\n\t\t\t\t\tcase 'min' /*case 'Min'*/: break;\n\t\t\t\t\tcase 'max' /*case 'Max'*/: break;\n\t\t\t\t\tcase 'sort' /*case 'Sort'*/: break;\n\t\t\t\t\tcase 'descending' /*case 'Descending'*/: break;\n\t\t\t\t\tcase 'order' /*case 'Order'*/: break;\n\t\t\t\t\tcase 'casesensitive' /*case 'CaseSensitive'*/: break;\n\t\t\t\t\tcase 'value' /*case 'Value'*/: break;\n\t\t\t\t\tcase 'errorstyle' /*case 'ErrorStyle'*/: break;\n\t\t\t\t\tcase 'errormessage' /*case 'ErrorMessage'*/: break;\n\t\t\t\t\tcase 'errortitle' /*case 'ErrorTitle'*/: break;\n\t\t\t\t\tcase 'cellrangelist' /*case 'CellRangeList'*/: break;\n\t\t\t\t\tcase 'inputmessage' /*case 'InputMessage'*/: break;\n\t\t\t\t\tcase 'inputtitle' /*case 'InputTitle'*/: break;\n\t\t\t\t\tcase 'combohide' /*case 'ComboHide'*/: break;\n\t\t\t\t\tcase 'inputhide' /*case 'InputHide'*/: break;\n\t\t\t\t\tcase 'condition' /*case 'Condition'*/: break;\n\t\t\t\t\tcase 'qualifier' /*case 'Qualifier'*/: break;\n\t\t\t\t\tcase 'useblank' /*case 'UseBlank'*/: break;\n\t\t\t\t\tcase 'value1' /*case 'Value1'*/: break;\n\t\t\t\t\tcase 'value2' /*case 'Value2'*/: break;\n\t\t\t\t\tcase 'format' /*case 'Format'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* MapInfo (schema) */\n\t\t\t\tcase 'mapinfo' /*case 'MapInfo'*/: case 'schema' /*case 'Schema'*/: case 'data' /*case 'data'*/: switch(Rn[3]) {\n\t\t\t\t\tcase 'map' /*case 'Map'*/: break;\n\t\t\t\t\tcase 'entry' /*case 'Entry'*/: break;\n\t\t\t\t\tcase 'range' /*case 'Range'*/: break;\n\t\t\t\t\tcase 'xpath' /*case 'XPath'*/: break;\n\t\t\t\t\tcase 'field' /*case 'Field'*/: break;\n\t\t\t\t\tcase 'xsdtype' /*case 'XSDType'*/: break;\n\t\t\t\t\tcase 'filteron' /*case 'FilterOn'*/: break;\n\t\t\t\t\tcase 'aggregate' /*case 'Aggregate'*/: break;\n\t\t\t\t\tcase 'elementtype' /*case 'ElementType'*/: break;\n\t\t\t\t\tcase 'attributetype' /*case 'AttributeType'*/: break;\n\t\t\t\t/* These are from xsd (XML Schema Definition) */\n\t\t\t\t\tcase 'schema' /*case 'schema'*/:\n\t\t\t\t\tcase 'element' /*case 'element'*/:\n\t\t\t\t\tcase 'complextype' /*case 'complexType'*/:\n\t\t\t\t\tcase 'datatype' /*case 'datatype'*/:\n\t\t\t\t\tcase 'all' /*case 'all'*/:\n\t\t\t\t\tcase 'attribute' /*case 'attribute'*/:\n\t\t\t\t\tcase 'extends' /*case 'extends'*/: break;\n\n\t\t\t\t\tcase 'row' /*case 'row'*/: break;\n\t\t\t\t\tdefault: seen = false;\n\t\t\t\t} break;\n\n\t\t\t\t/* SmartTags (can be anything) */\n\t\t\t\tcase 'smarttags' /*case 'SmartTags'*/: break;\n\n\t\t\t\tdefault: seen = false; break;\n\t\t\t}\n\t\t\tif(seen) break;\n\t\t\t/* CustomDocumentProperties */\n\t\t\tif(Rn[3].match(/!\\[CDATA/)) break;\n\t\t\tif(!state[state.length-1][1]) throw 'Unrecognized tag: ' + Rn[3] + \"|\" + state.join(\"|\");\n\t\t\tif(state[state.length-1][0]===/*'CustomDocumentProperties'*/'customdocumentproperties') {\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\t\telse if(Rn[1]===\"/\") xlml_set_custprop(Custprops, raw_Rn3, cp, str.slice(pidx, Rn.index));\n\t\t\t\telse { cp = Rn; pidx = Rn.index + Rn[0].length; }\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif(opts.WTF) throw 'Unrecognized tag: ' + Rn[3] + \"|\" + state.join(\"|\");\n\t}\n\tvar out = ({}/*:any*/);\n\tif(!opts.bookSheets && !opts.bookProps) out.Sheets = sheets;\n\tout.SheetNames = sheetnames;\n\tout.Workbook = Workbook;\n\tout.SSF = dup(table_fmt);\n\tout.Props = Props;\n\tout.Custprops = Custprops;\n\treturn out;\n}\n\nfunction parse_xlml(data/*:RawBytes|string*/, opts)/*:Workbook*/ {\n\tfix_read_opts(opts=opts||{});\n\tswitch(opts.type||\"base64\") {\n\t\tcase \"base64\": return parse_xlml_xml(Base64_decode(data), opts);\n\t\tcase \"binary\": case \"buffer\": case \"file\": return parse_xlml_xml(data, opts);\n\t\tcase \"array\": return parse_xlml_xml(a2s(data), opts);\n\t}\n\t/*:: throw new Error(\"unsupported type \" + opts.type); */\n}\n\n/* TODO */\nfunction write_props_xlml(wb/*:Workbook*/, opts)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\t/* DocumentProperties */\n\tif(wb.Props) o.push(xlml_write_docprops(wb.Props, opts));\n\t/* CustomDocumentProperties */\n\tif(wb.Custprops) o.push(xlml_write_custprops(wb.Props, wb.Custprops, opts));\n\treturn o.join(\"\");\n}\n/* TODO */\nfunction write_wb_xlml(/*::wb, opts*/)/*:string*/ {\n\t/* OfficeDocumentSettings */\n\t/* ExcelWorkbook */\n\treturn \"\";\n}\n/* TODO */\nfunction write_sty_xlml(wb, opts)/*:string*/ {\n\t/* Styles */\n\tvar styles/*:Array<string>*/ = ['<Style ss:ID=\"Default\" ss:Name=\"Normal\"><NumberFormat/></Style>'];\n\topts.cellXfs.forEach(function(xf, id) {\n\t\tvar payload/*:Array<string>*/ = [];\n\t\tpayload.push(writextag('NumberFormat', null, {\"ss:Format\": escapexml(table_fmt[xf.numFmtId])}));\n\n\t\tvar o = /*::(*/{\"ss:ID\": \"s\" + (21+id)}/*:: :any)*/;\n\t\tstyles.push(writextag('Style', payload.join(\"\"), o));\n\t});\n\treturn writextag(\"Styles\", styles.join(\"\"));\n}\nfunction write_name_xlml(n) { return writextag(\"NamedRange\", null, {\"ss:Name\": n.Name, \"ss:RefersTo\":\"=\" + a1_to_rc(n.Ref, {r:0,c:0})}); }\nfunction write_names_xlml(wb/*::, opts*/)/*:string*/ {\n\tif(!((wb||{}).Workbook||{}).Names) return \"\";\n\t/*:: if(!wb || !wb.Workbook || !wb.Workbook.Names) throw new Error(\"unreachable\"); */\n\tvar names/*:Array<any>*/ = wb.Workbook.Names;\n\tvar out/*:Array<string>*/ = [];\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar n = names[i];\n\t\tif(n.Sheet != null) continue;\n\t\tif(n.Name.match(/^_xlfn\\./)) continue;\n\t\tout.push(write_name_xlml(n));\n\t}\n\treturn writextag(\"Names\", out.join(\"\"));\n}\nfunction write_ws_xlml_names(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*/)/*:string*/ {\n\tif(!ws) return \"\";\n\tif(!((wb||{}).Workbook||{}).Names) return \"\";\n\t/*:: if(!wb || !wb.Workbook || !wb.Workbook.Names) throw new Error(\"unreachable\"); */\n\tvar names/*:Array<any>*/ = wb.Workbook.Names;\n\tvar out/*:Array<string>*/ = [];\n\tfor(var i = 0; i < names.length; ++i) {\n\t\tvar n = names[i];\n\t\tif(n.Sheet != idx) continue;\n\t\t/*switch(n.Name) {\n\t\t\tcase \"_\": continue;\n\t\t}*/\n\t\tif(n.Name.match(/^_xlfn\\./)) continue;\n\t\tout.push(write_name_xlml(n));\n\t}\n\treturn out.join(\"\");\n}\n/* WorksheetOptions */\nfunction write_ws_xlml_wsopts(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*/)/*:string*/ {\n\tif(!ws) return \"\";\n\tvar o/*:Array<string>*/ = [];\n\t/* NOTE: spec technically allows any order, but stick with implied order */\n\n\t/* FitToPage */\n\t/* DoNotDisplayColHeaders */\n\t/* DoNotDisplayRowHeaders */\n\t/* ViewableRange */\n\t/* Selection */\n\t/* GridlineColor */\n\t/* Name */\n\t/* ExcelWorksheetType */\n\t/* IntlMacro */\n\t/* Unsynced */\n\t/* Selected */\n\t/* CodeName */\n\n\tif(ws['!margins']) {\n\t\to.push(\"<PageSetup>\");\n\t\tif(ws['!margins'].header) o.push(writextag(\"Header\", null, {'x:Margin':ws['!margins'].header}));\n\t\tif(ws['!margins'].footer) o.push(writextag(\"Footer\", null, {'x:Margin':ws['!margins'].footer}));\n\t\to.push(writextag(\"PageMargins\", null, {\n\t\t\t'x:Bottom': ws['!margins'].bottom || \"0.75\",\n\t\t\t'x:Left': ws['!margins'].left || \"0.7\",\n\t\t\t'x:Right': ws['!margins'].right || \"0.7\",\n\t\t\t'x:Top': ws['!margins'].top || \"0.75\"\n\t\t}));\n\t\to.push(\"</PageSetup>\");\n\t}\n\n\t/* PageSetup */\n\t/* DisplayPageBreak */\n\t/* TransitionExpressionEvaluation */\n\t/* TransitionFormulaEntry */\n\t/* Print */\n\t/* Zoom */\n\t/* PageLayoutZoom */\n\t/* PageBreakZoom */\n\t/* ShowPageBreakZoom */\n\t/* DefaultRowHeight */\n\t/* DefaultColumnWidth */\n\t/* StandardWidth */\n\n\tif(wb && wb.Workbook && wb.Workbook.Sheets && wb.Workbook.Sheets[idx]) {\n\t\t/* Visible */\n\t\tif(wb.Workbook.Sheets[idx].Hidden) o.push(writextag(\"Visible\", (wb.Workbook.Sheets[idx].Hidden == 1 ? \"SheetHidden\" : \"SheetVeryHidden\"), {}));\n\t\telse {\n\t\t\t/* Selected */\n\t\t\tfor(var i = 0; i < idx; ++i) if(wb.Workbook.Sheets[i] && !wb.Workbook.Sheets[i].Hidden) break;\n\t\t\tif(i == idx) o.push(\"<Selected/>\");\n\t\t}\n\t}\n\n\t/* LeftColumnVisible */\n\n\tif(((((wb||{}).Workbook||{}).Views||[])[0]||{}).RTL) o.push(\"<DisplayRightToLeft/>\");\n\n\t/* GridlineColorIndex */\n\t/* DisplayFormulas */\n\t/* DoNotDisplayGridlines */\n\t/* DoNotDisplayHeadings */\n\t/* DoNotDisplayOutline */\n\t/* ApplyAutomaticOutlineStyles */\n\t/* NoSummaryRowsBelowDetail */\n\t/* NoSummaryColumnsRightDetail */\n\t/* DoNotDisplayZeros */\n\t/* ActiveRow */\n\t/* ActiveColumn */\n\t/* FilterOn */\n\t/* RangeSelection */\n\t/* TopRowVisible */\n\t/* TopRowBottomPane */\n\t/* LeftColumnRightPane */\n\t/* ActivePane */\n\t/* SplitHorizontal */\n\t/* SplitVertical */\n\t/* FreezePanes */\n\t/* FrozenNoSplit */\n\t/* TabColorIndex */\n\t/* Panes */\n\n\t/* NOTE: Password not supported in XLML Format */\n\tif(ws['!protect']) {\n\t\to.push(writetag(\"ProtectContents\", \"True\"));\n\t\tif(ws['!protect'].objects) o.push(writetag(\"ProtectObjects\", \"True\"));\n\t\tif(ws['!protect'].scenarios) o.push(writetag(\"ProtectScenarios\", \"True\"));\n\t\tif(ws['!protect'].selectLockedCells != null && !ws['!protect'].selectLockedCells) o.push(writetag(\"EnableSelection\", \"NoSelection\"));\n\t\telse if(ws['!protect'].selectUnlockedCells != null && !ws['!protect'].selectUnlockedCells) o.push(writetag(\"EnableSelection\", \"UnlockedCells\"));\n\t[\n\t\t[ \"formatCells\", \"AllowFormatCells\" ],\n\t\t[ \"formatColumns\", \"AllowSizeCols\" ],\n\t\t[ \"formatRows\", \"AllowSizeRows\" ],\n\t\t[ \"insertColumns\", \"AllowInsertCols\" ],\n\t\t[ \"insertRows\", \"AllowInsertRows\" ],\n\t\t[ \"insertHyperlinks\", \"AllowInsertHyperlinks\" ],\n\t\t[ \"deleteColumns\", \"AllowDeleteCols\" ],\n\t\t[ \"deleteRows\", \"AllowDeleteRows\" ],\n\t\t[ \"sort\", \"AllowSort\" ],\n\t\t[ \"autoFilter\", \"AllowFilter\" ],\n\t\t[ \"pivotTables\", \"AllowUsePivotTables\" ]\n\t].forEach(function(x) { if(ws['!protect'][x[0]]) o.push(\"<\"+x[1]+\"/>\"); });\n\t}\n\n\tif(o.length == 0) return \"\";\n\treturn writextag(\"WorksheetOptions\", o.join(\"\"), {xmlns:XLMLNS.x});\n}\nfunction write_ws_xlml_comment(comments/*:Array<any>*/)/*:string*/ {\n\treturn comments.map(function(c) {\n\t\t// TODO: formatted text\n\t\tvar t = xlml_unfixstr(c.t||\"\");\n\t\tvar d =writextag(\"ss:Data\", t, {\"xmlns\":\"http://www.w3.org/TR/REC-html40\"});\n\t\treturn writextag(\"Comment\", d, {\"ss:Author\":c.a});\n\t}).join(\"\");\n}\nfunction write_ws_xlml_cell(cell, ref/*:string*/, ws, opts, idx/*:number*/, wb, addr)/*:string*/{\n\tif(!cell || (cell.v == undefined && cell.f == undefined)) return \"\";\n\n\tvar attr = {};\n\tif(cell.f) attr[\"ss:Formula\"] = \"=\" + escapexml(a1_to_rc(cell.f, addr));\n\tif(cell.F && cell.F.slice(0, ref.length) == ref) {\n\t\tvar end = decode_cell(cell.F.slice(ref.length + 1));\n\t\tattr[\"ss:ArrayRange\"] = \"RC:R\" + (end.r == addr.r ? \"\" : \"[\" + (end.r - addr.r) + \"]\") + \"C\" + (end.c == addr.c ? \"\" : \"[\" + (end.c - addr.c) + \"]\");\n\t}\n\n\tif(cell.l && cell.l.Target) {\n\t\tattr[\"ss:HRef\"] = escapexml(cell.l.Target);\n\t\tif(cell.l.Tooltip) attr[\"x:HRefScreenTip\"] = escapexml(cell.l.Tooltip);\n\t}\n\n\tif(ws['!merges']) {\n\t\tvar marr = ws['!merges'];\n\t\tfor(var mi = 0; mi != marr.length; ++mi) {\n\t\t\tif(marr[mi].s.c != addr.c || marr[mi].s.r != addr.r) continue;\n\t\t\tif(marr[mi].e.c > marr[mi].s.c) attr['ss:MergeAcross'] = marr[mi].e.c - marr[mi].s.c;\n\t\t\tif(marr[mi].e.r > marr[mi].s.r) attr['ss:MergeDown'] = marr[mi].e.r - marr[mi].s.r;\n\t\t}\n\t}\n\n\tvar t = \"\", p = \"\";\n\tswitch(cell.t) {\n\t\tcase 'z': if(!opts.sheetStubs) return \"\"; break;\n\t\tcase 'n': t = 'Number'; p = String(cell.v); break;\n\t\tcase 'b': t = 'Boolean'; p = (cell.v ? \"1\" : \"0\"); break;\n\t\tcase 'e': t = 'Error'; p = BErr[cell.v]; break;\n\t\tcase 'd': t = 'DateTime'; p = new Date(cell.v).toISOString(); if(cell.z == null) cell.z = cell.z || table_fmt[14]; break;\n\t\tcase 's': t = 'String'; p = escapexlml(cell.v||\"\"); break;\n\t}\n\t/* TODO: cell style */\n\tvar os = get_cell_style(opts.cellXfs, cell, opts);\n\tattr[\"ss:StyleID\"] = \"s\" + (21+os);\n\tattr[\"ss:Index\"] = addr.c + 1;\n\tvar _v = (cell.v != null ? p : \"\");\n\tvar m = cell.t == 'z' ? \"\" : ('<Data ss:Type=\"' + t + '\">' + _v + '</Data>');\n\n\tif((cell.c||[]).length > 0) m += write_ws_xlml_comment(cell.c);\n\n\treturn writextag(\"Cell\", m, attr);\n}\nfunction write_ws_xlml_row(R/*:number*/, row)/*:string*/ {\n\tvar o = '<Row ss:Index=\"' + (R+1) + '\"';\n\tif(row) {\n\t\tif(row.hpt && !row.hpx) row.hpx = pt2px(row.hpt);\n\t\tif(row.hpx) o += ' ss:AutoFitHeight=\"0\" ss:Height=\"' + row.hpx + '\"';\n\t\tif(row.hidden) o += ' ss:Hidden=\"1\"';\n\t}\n\treturn o + '>';\n}\n/* TODO */\nfunction write_ws_xlml_table(ws/*:Worksheet*/, opts, idx/*:number*/, wb/*:Workbook*/)/*:string*/ {\n\tif(!ws['!ref']) return \"\";\n\tvar range/*:Range*/ = safe_decode_range(ws['!ref']);\n\tvar marr/*:Array<Range>*/ = ws['!merges'] || [], mi = 0;\n\tvar o/*:Array<string>*/ = [];\n\tif(ws['!cols']) ws['!cols'].forEach(function(n, i) {\n\t\tprocess_col(n);\n\t\tvar w = !!n.width;\n\t\tvar p = col_obj_w(i, n);\n\t\tvar k/*:any*/ = {\"ss:Index\":i+1};\n\t\tif(w) k['ss:Width'] = width2px(p.width);\n\t\tif(n.hidden) k['ss:Hidden']=\"1\";\n\t\to.push(writextag(\"Column\",null,k));\n\t});\n\tvar dense = Array.isArray(ws);\n\tfor(var R = range.s.r; R <= range.e.r; ++R) {\n\t\tvar row = [write_ws_xlml_row(R, (ws['!rows']||[])[R])];\n\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tvar skip = false;\n\t\t\tfor(mi = 0; mi != marr.length; ++mi) {\n\t\t\t\tif(marr[mi].s.c > C) continue;\n\t\t\t\tif(marr[mi].s.r > R) continue;\n\t\t\t\tif(marr[mi].e.c < C) continue;\n\t\t\t\tif(marr[mi].e.r < R) continue;\n\t\t\t\tif(marr[mi].s.c != C || marr[mi].s.r != R) skip = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif(skip) continue;\n\t\t\tvar addr = {r:R,c:C};\n\t\t\tvar ref = encode_cell(addr), cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\trow.push(write_ws_xlml_cell(cell, ref, ws, opts, idx, wb, addr));\n\t\t}\n\t\trow.push(\"</Row>\");\n\t\tif(row.length > 2) o.push(row.join(\"\"));\n\t}\n\treturn o.join(\"\");\n}\nfunction write_ws_xlml(idx/*:number*/, opts, wb/*:Workbook*/)/*:string*/ {\n\tvar o/*:Array<string>*/ = [];\n\tvar s = wb.SheetNames[idx];\n\tvar ws = wb.Sheets[s];\n\n\tvar t/*:string*/ = ws ? write_ws_xlml_names(ws, opts, idx, wb) : \"\";\n\tif(t.length > 0) o.push(\"<Names>\" + t + \"</Names>\");\n\n\t/* Table */\n\tt = ws ? write_ws_xlml_table(ws, opts, idx, wb) : \"\";\n\tif(t.length > 0) o.push(\"<Table>\" + t + \"</Table>\");\n\n\t/* WorksheetOptions */\n\to.push(write_ws_xlml_wsopts(ws, opts, idx, wb));\n\n\treturn o.join(\"\");\n}\nfunction write_xlml(wb, opts)/*:string*/ {\n\tif(!opts) opts = {};\n\tif(!wb.SSF) wb.SSF = dup(table_fmt);\n\tif(wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\topts.revssf = evert_num(wb.SSF); opts.revssf[wb.SSF[65535]] = 0;\n\t\topts.ssf = wb.SSF;\n\t\topts.cellXfs = [];\n\t\tget_cell_style(opts.cellXfs, {}, {revssf:{\"General\":0}});\n\t}\n\tvar d/*:Array<string>*/ = [];\n\td.push(write_props_xlml(wb, opts));\n\td.push(write_wb_xlml(wb, opts));\n\td.push(\"\");\n\td.push(\"\");\n\tfor(var i = 0; i < wb.SheetNames.length; ++i)\n\t\td.push(writextag(\"Worksheet\", write_ws_xlml(i, opts, wb), {\"ss:Name\":escapexml(wb.SheetNames[i])}));\n\td[2] = write_sty_xlml(wb, opts);\n\td[3] = write_names_xlml(wb, opts);\n\treturn XML_HEADER + writextag(\"Workbook\", d.join(\"\"), {\n\t\t'xmlns':      XLMLNS.ss,\n\t\t'xmlns:o':    XLMLNS.o,\n\t\t'xmlns:x':    XLMLNS.x,\n\t\t'xmlns:ss':   XLMLNS.ss,\n\t\t'xmlns:dt':   XLMLNS.dt,\n\t\t'xmlns:html': XLMLNS.html\n\t});\n}\n/* [MS-OLEDS] 2.3.8 CompObjStream */\nfunction parse_compobj(obj/*:CFBEntry*/) {\n\tvar v = {};\n\tvar o = obj.content;\n\t/*:: if(o == null) return; */\n\n\t/* [MS-OLEDS] 2.3.7 CompObjHeader -- All fields MUST be ignored */\n\to.l = 28;\n\n\tv.AnsiUserType = o.read_shift(0, \"lpstr-ansi\");\n\tv.AnsiClipboardFormat = parse_ClipboardFormatOrAnsiString(o);\n\n\tif(o.length - o.l <= 4) return v;\n\n\tvar m/*:number*/ = o.read_shift(4);\n\tif(m == 0 || m > 40) return v;\n\to.l-=4; v.Reserved1 = o.read_shift(0, \"lpstr-ansi\");\n\n\tif(o.length - o.l <= 4) return v;\n\tm = o.read_shift(4);\n\tif(m !== 0x71b239f4) return v;\n\tv.UnicodeClipboardFormat = parse_ClipboardFormatOrUnicodeString(o);\n\n\tm = o.read_shift(4);\n\tif(m == 0 || m > 40) return v;\n\to.l-=4; v.Reserved2 = o.read_shift(0, \"lpwstr\");\n}\n\n/*\n\tContinue logic for:\n\t- 2.4.58 Continue          0x003c\n\t- 2.4.59 ContinueBigName   0x043c\n\t- 2.4.60 ContinueFrt       0x0812\n\t- 2.4.61 ContinueFrt11     0x0875\n\t- 2.4.62 ContinueFrt12     0x087f\n*/\nvar CONTINUE_RT = [ 0x003c, 0x043c, 0x0812, 0x0875, 0x087f ];\nfunction slurp(RecordType, R, blob, length/*:number*/, opts)/*:any*/ {\n\tvar l = length;\n\tvar bufs = [];\n\tvar d = blob.slice(blob.l,blob.l+l);\n\tif(opts && opts.enc && opts.enc.insitu && d.length > 0) switch(RecordType) {\n\tcase 0x0009: case 0x0209: case 0x0409: case 0x0809/* BOF */: case 0x002f /* FilePass */: case 0x0195 /* FileLock */: case 0x00e1 /* InterfaceHdr */: case 0x0196 /* RRDInfo */: case 0x0138 /* RRDHead */: case 0x0194 /* UsrExcl */: case 0x000a /* EOF */:\n\t\tbreak;\n\tcase 0x0085 /* BoundSheet8 */:\n\t\tbreak;\n\tdefault:\n\t\topts.enc.insitu(d);\n\t}\n\tbufs.push(d);\n\tblob.l += l;\n\tvar nextrt = __readUInt16LE(blob,blob.l), next = XLSRecordEnum[nextrt];\n\tvar start = 0;\n\twhile(next != null && CONTINUE_RT.indexOf(nextrt) > -1) {\n\t\tl = __readUInt16LE(blob,blob.l+2);\n\t\tstart = blob.l + 4;\n\t\tif(nextrt == 0x0812 /* ContinueFrt */) start += 4;\n\t\telse if(nextrt == 0x0875 || nextrt == 0x087f) {\n\t\t\tstart += 12;\n\t\t}\n\t\td = blob.slice(start,blob.l+4+l);\n\t\tbufs.push(d);\n\t\tblob.l += 4+l;\n\t\tnext = (XLSRecordEnum[nextrt = __readUInt16LE(blob, blob.l)]);\n\t}\n\tvar b = (bconcat(bufs)/*:any*/);\n\tprep_blob(b, 0);\n\tvar ll = 0; b.lens = [];\n\tfor(var j = 0; j < bufs.length; ++j) { b.lens.push(ll); ll += bufs[j].length; }\n\tif(b.length < length) throw \"XLS Record 0x\" + RecordType.toString(16) + \" Truncated: \" + b.length + \" < \" + length;\n\treturn R.f(b, b.length, opts);\n}\n\nfunction safe_format_xf(p/*:any*/, opts/*:ParseOpts*/, date1904/*:?boolean*/) {\n\tif(p.t === 'z') return;\n\tif(!p.XF) return;\n\tvar fmtid = 0;\n\ttry {\n\t\tfmtid = p.z || p.XF.numFmtId || 0;\n\t\tif(opts.cellNF) p.z = table_fmt[fmtid];\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(!opts || opts.cellText !== false) try {\n\t\tif(p.t === 'e') { p.w = p.w || BErr[p.v]; }\n\t\telse if(fmtid === 0 || fmtid == \"General\") {\n\t\t\tif(p.t === 'n') {\n\t\t\t\tif((p.v|0) === p.v) p.w = p.v.toString(10);\n\t\t\t\telse p.w = SSF_general_num(p.v);\n\t\t\t}\n\t\t\telse p.w = SSF_general(p.v);\n\t\t}\n\t\telse p.w = SSF_format(fmtid,p.v, {date1904:!!date1904, dateNF: opts && opts.dateNF});\n\t} catch(e) { if(opts.WTF) throw e; }\n\tif(opts.cellDates && fmtid && p.t == 'n' && fmt_is_date(table_fmt[fmtid] || String(fmtid))) {\n\t\tvar _d = SSF_parse_date_code(p.v); if(_d) { p.t = 'd'; p.v = new Date(_d.y, _d.m-1,_d.d,_d.H,_d.M,_d.S,_d.u); }\n\t}\n}\n\nfunction make_cell(val, ixfe, t)/*:Cell*/ {\n\treturn ({v:val, ixfe:ixfe, t:t}/*:any*/);\n}\n\n// 2.3.2\nfunction parse_workbook(blob, options/*:ParseOpts*/)/*:Workbook*/ {\n\tvar wb = ({opts:{}}/*:any*/);\n\tvar Sheets = {};\n\tif(DENSE != null && options.dense == null) options.dense = DENSE;\n\tvar out/*:Worksheet*/ = ((options.dense ? [] : {})/*:any*/);\n\tvar Directory = {};\n\tvar range/*:Range*/ = ({}/*:any*/);\n\tvar last_formula = null;\n\tvar sst/*:SST*/ = ([]/*:any*/);\n\tvar cur_sheet = \"\";\n\tvar Preamble = {};\n\tvar lastcell, last_cell = \"\", cc/*:Cell*/, cmnt, rngC, rngR;\n\tvar sharedf = {};\n\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\tvar temp_val/*:Cell*/;\n\tvar country;\n\tvar XFs = []; /* XF records */\n\tvar palette/*:Array<[number, number, number]>*/ = [];\n\tvar Workbook/*:WBWBProps*/ = ({ Sheets:[], WBProps:{date1904:false}, Views:[{}] }/*:any*/), wsprops = {};\n\tvar get_rgb = function getrgb(icv/*:number*/)/*:[number, number, number]*/ {\n\t\tif(icv < 8) return XLSIcv[icv];\n\t\tif(icv < 64) return palette[icv-8] || XLSIcv[icv];\n\t\treturn XLSIcv[icv];\n\t};\n\tvar process_cell_style = function pcs(cell, line/*:any*/, options) {\n\t\tvar xfd = line.XF.data;\n\t\tif(!xfd || !xfd.patternType || !options || !options.cellStyles) return;\n\t\tline.s = ({}/*:any*/);\n\t\tline.s.patternType = xfd.patternType;\n\t\tvar t;\n\t\tif((t = rgb2Hex(get_rgb(xfd.icvFore)))) { line.s.fgColor = {rgb:t}; }\n\t\tif((t = rgb2Hex(get_rgb(xfd.icvBack)))) { line.s.bgColor = {rgb:t}; }\n\t};\n\tvar addcell = function addcell(cell/*:any*/, line/*:any*/, options/*:any*/) {\n\t\tif(file_depth > 1) return;\n\t\tif(options.sheetRows && cell.r >= options.sheetRows) return;\n\t\tif(options.cellStyles && line.XF && line.XF.data) process_cell_style(cell, line, options);\n\t\tdelete line.ixfe; delete line.XF;\n\t\tlastcell = cell;\n\t\tlast_cell = encode_cell(cell);\n\t\tif(!range || !range.s || !range.e) range = {s:{r:0,c:0},e:{r:0,c:0}};\n\t\tif(cell.r < range.s.r) range.s.r = cell.r;\n\t\tif(cell.c < range.s.c) range.s.c = cell.c;\n\t\tif(cell.r + 1 > range.e.r) range.e.r = cell.r + 1;\n\t\tif(cell.c + 1 > range.e.c) range.e.c = cell.c + 1;\n\t\tif(options.cellFormula && line.f) {\n\t\t\tfor(var afi = 0; afi < arrayf.length; ++afi) {\n\t\t\t\tif(arrayf[afi][0].s.c > cell.c || arrayf[afi][0].s.r > cell.r) continue;\n\t\t\t\tif(arrayf[afi][0].e.c < cell.c || arrayf[afi][0].e.r < cell.r) continue;\n\t\t\t\tline.F = encode_range(arrayf[afi][0]);\n\t\t\t\tif(arrayf[afi][0].s.c != cell.c || arrayf[afi][0].s.r != cell.r) delete line.f;\n\t\t\t\tif(line.f) line.f = \"\" + stringify_formula(arrayf[afi][1], range, cell, supbooks, opts);\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\t{\n\t\t\tif(options.dense) {\n\t\t\t\tif(!out[cell.r]) out[cell.r] = [];\n\t\t\t\tout[cell.r][cell.c] = line;\n\t\t\t} else out[last_cell] = line;\n\t\t}\n\t};\n\tvar opts = ({\n\t\tenc: false, // encrypted\n\t\tsbcch: 0, // cch in the preceding SupBook\n\t\tsnames: [], // sheetnames\n\t\tsharedf: sharedf, // shared formulae by address\n\t\tarrayf: arrayf, // array formulae array\n\t\trrtabid: [], // RRTabId\n\t\tlastuser: \"\", // Last User from WriteAccess\n\t\tbiff: 8, // BIFF version\n\t\tcodepage: 0, // CP from CodePage record\n\t\twinlocked: 0, // fLockWn from WinProtect\n\t\tcellStyles: !!options && !!options.cellStyles,\n\t\tWTF: !!options && !!options.wtf\n\t}/*:any*/);\n\tif(options.password) opts.password = options.password;\n\tvar themes;\n\tvar merges/*:Array<Range>*/ = [];\n\tvar objects = [];\n\tvar colinfo/*:Array<ColInfo>*/ = [], rowinfo/*:Array<RowInfo>*/ = [];\n\tvar seencol = false;\n\tvar supbooks = ([]/*:any*/); // 1-indexed, will hold extern names\n\tsupbooks.SheetNames = opts.snames;\n\tsupbooks.sharedf = opts.sharedf;\n\tsupbooks.arrayf = opts.arrayf;\n\tsupbooks.names = [];\n\tsupbooks.XTI = [];\n\tvar last_RT = 0;\n\tvar file_depth = 0; /* TODO: make a real stack */\n\tvar BIFF2Fmt = 0, BIFF2FmtTable/*:Array<string>*/ = [];\n\tvar FilterDatabases = []; /* TODO: sort out supbooks and process elsewhere */\n\tvar last_lbl/*:?DefinedName*/;\n\n\t/* explicit override for some broken writers */\n\topts.codepage = 1200;\n\tset_cp(1200);\n\tvar seen_codepage = false;\n\twhile(blob.l < blob.length - 1) {\n\t\tvar s = blob.l;\n\t\tvar RecordType = blob.read_shift(2);\n\t\tif(RecordType === 0 && last_RT === 0x000a /* EOF */) break;\n\t\tvar length = (blob.l === blob.length ? 0 : blob.read_shift(2));\n\t\tvar R = XLSRecordEnum[RecordType];\n\t\t//console.log(RecordType.toString(16), RecordType, R, blob.l, length, blob.length);\n\t\t//if(!R) console.log(blob.slice(blob.l, blob.l + length));\n\t\tif(R && R.f) {\n\t\t\tif(options.bookSheets) {\n\t\t\t\tif(last_RT === 0x0085 /* BoundSheet8 */ && RecordType !== 0x0085 /* R.n !== 'BoundSheet8' */) break;\n\t\t\t}\n\t\t\tlast_RT = RecordType;\n\t\t\tif(R.r === 2 || R.r == 12) {\n\t\t\t\tvar rt = blob.read_shift(2); length -= 2;\n\t\t\t\tif(!opts.enc && rt !== RecordType && (((rt&0xFF)<<8)|(rt>>8)) !== RecordType) throw new Error(\"rt mismatch: \" + rt + \"!=\" + RecordType);\n\t\t\t\tif(R.r == 12){\n\t\t\t\t\tblob.l += 10; length -= 10;\n\t\t\t\t} // skip FRT\n\t\t\t}\n\t\t\t//console.error(R,blob.l,length,blob.length);\n\t\t\tvar val/*:any*/ = ({}/*:any*/);\n\t\t\tif(RecordType === 0x000a /* EOF */) val = /*::(*/R.f(blob, length, opts)/*:: :any)*/;\n\t\t\telse val = /*::(*/slurp(RecordType, R, blob, length, opts)/*:: :any)*/;\n\t\t\t/*:: val = (val:any); */\n\t\t\tif(file_depth == 0 && [0x0009, 0x0209, 0x0409, 0x0809].indexOf(last_RT) === -1 /* 'BOF' */) continue;\n\t\t\tswitch(RecordType) {\n\t\t\t\tcase 0x0022 /* Date1904 */:\n\t\t\t\t\t/*:: if(!Workbook.WBProps) Workbook.WBProps = {}; */\n\t\t\t\t\twb.opts.Date1904 = Workbook.WBProps.date1904 = val; break;\n\t\t\t\tcase 0x0086 /* WriteProtect */: wb.opts.WriteProtect = true; break;\n\t\t\t\tcase 0x002f /* FilePass */:\n\t\t\t\t\tif(!opts.enc) blob.l = 0;\n\t\t\t\t\topts.enc = val;\n\t\t\t\t\tif(!options.password) throw new Error(\"File is password-protected\");\n\t\t\t\t\tif(val.valid == null) throw new Error(\"Encryption scheme unsupported\");\n\t\t\t\t\tif(!val.valid) throw new Error(\"Password is incorrect\");\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x005c /* WriteAccess */: opts.lastuser = val; break;\n\t\t\t\tcase 0x0042 /* CodePage */:\n\t\t\t\t\tvar cpval = Number(val);\n\t\t\t\t\t/* overrides based on test cases */\n\t\t\t\t\tswitch(cpval) {\n\t\t\t\t\t\tcase 0x5212: cpval =  1200; break;\n\t\t\t\t\t\tcase 0x8000: cpval = 10000; break;\n\t\t\t\t\t\tcase 0x8001: cpval =  1252; break;\n\t\t\t\t\t}\n\t\t\t\t\tset_cp(opts.codepage = cpval);\n\t\t\t\t\tseen_codepage = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x013d /* RRTabId */: opts.rrtabid = val; break;\n\t\t\t\tcase 0x0019 /* WinProtect */: opts.winlocked = val; break;\n\t\t\t\tcase 0x01b7 /* RefreshAll */: wb.opts[\"RefreshAll\"] = val; break;\n\t\t\t\tcase 0x000c /* CalcCount */: wb.opts[\"CalcCount\"] = val; break;\n\t\t\t\tcase 0x0010 /* CalcDelta */: wb.opts[\"CalcDelta\"] = val; break;\n\t\t\t\tcase 0x0011 /* CalcIter */: wb.opts[\"CalcIter\"] = val; break;\n\t\t\t\tcase 0x000d /* CalcMode */: wb.opts[\"CalcMode\"] = val; break;\n\t\t\t\tcase 0x000e /* CalcPrecision */: wb.opts[\"CalcPrecision\"] = val; break;\n\t\t\t\tcase 0x005f /* CalcSaveRecalc */: wb.opts[\"CalcSaveRecalc\"] = val; break;\n\t\t\t\tcase 0x000f /* CalcRefMode */: opts.CalcRefMode = val; break; // TODO: implement R1C1\n\t\t\t\tcase 0x08a3 /* ForceFullCalculation */: wb.opts.FullCalc = val; break;\n\t\t\t\tcase 0x0081 /* WsBool */:\n\t\t\t\t\tif(val.fDialog) out[\"!type\"] = \"dialog\";\n\t\t\t\t\tif(!val.fBelow) (out[\"!outline\"] || (out[\"!outline\"] = {})).above = true;\n\t\t\t\t\tif(!val.fRight) (out[\"!outline\"] || (out[\"!outline\"] = {})).left = true;\n\t\t\t\t\tbreak; // TODO\n\t\t\t\tcase 0x00e0 /* XF */:\n\t\t\t\t\tXFs.push(val); break;\n\t\t\t\tcase 0x01ae /* SupBook */:\n\t\t\t\t\tsupbooks.push([val]);\n\t\t\t\t\tsupbooks[supbooks.length-1].XTI = [];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0023: case 0x0223 /* ExternName */:\n\t\t\t\t\tsupbooks[supbooks.length-1].push(val);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0018: case 0x0218 /* Lbl */:\n\t\t\t\t\tlast_lbl = ({\n\t\t\t\t\t\tName: val.Name,\n\t\t\t\t\t\tRef: stringify_formula(val.rgce,range,null,supbooks,opts)\n\t\t\t\t\t}/*:DefinedName*/);\n\t\t\t\t\tif(val.itab > 0) last_lbl.Sheet = val.itab - 1;\n\t\t\t\t\tsupbooks.names.push(last_lbl);\n\t\t\t\t\tif(!supbooks[0]) { supbooks[0] = []; supbooks[0].XTI = []; }\n\t\t\t\t\tsupbooks[supbooks.length-1].push(val);\n\t\t\t\t\tif(val.Name == \"_xlnm._FilterDatabase\" && val.itab > 0)\n\t\t\t\t\t\tif(val.rgce && val.rgce[0] && val.rgce[0][0] && val.rgce[0][0][0] == 'PtgArea3d')\n\t\t\t\t\t\t\tFilterDatabases[val.itab - 1] = { ref: encode_range(val.rgce[0][0][1][2]) };\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0016 /* ExternCount */: opts.ExternCount = val; break;\n\t\t\t\tcase 0x0017 /* ExternSheet */:\n\t\t\t\t\tif(supbooks.length == 0) { supbooks[0] = []; supbooks[0].XTI = []; }\n\t\t\t\t\tsupbooks[supbooks.length - 1].XTI = supbooks[supbooks.length - 1].XTI.concat(val); supbooks.XTI = supbooks.XTI.concat(val); break;\n\t\t\t\tcase 0x0894 /* NameCmt */:\n\t\t\t\t\t/* TODO: search for correct name */\n\t\t\t\t\tif(opts.biff < 8) break;\n\t\t\t\t\tif(last_lbl != null) last_lbl.Comment = val[1];\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0012 /* Protect */: out[\"!protect\"] = val; break; /* for sheet or book */\n\t\t\t\tcase 0x0013 /* Password */: if(val !== 0 && opts.WTF) console.error(\"Password verifier: \" + val); break;\n\t\t\t\tcase 0x0085 /* BoundSheet8 */: {\n\t\t\t\t\tDirectory[val.pos] = val;\n\t\t\t\t\topts.snames.push(val.name);\n\t\t\t\t} break;\n\t\t\t\tcase 0x000a /* EOF */: {\n\t\t\t\t\tif(--file_depth) break;\n\t\t\t\t\tif(range.e) {\n\t\t\t\t\t\tif(range.e.r > 0 && range.e.c > 0) {\n\t\t\t\t\t\t\trange.e.r--; range.e.c--;\n\t\t\t\t\t\t\tout[\"!ref\"] = encode_range(range);\n\t\t\t\t\t\t\tif(options.sheetRows && options.sheetRows <= range.e.r) {\n\t\t\t\t\t\t\t\tvar tmpri = range.e.r;\n\t\t\t\t\t\t\t\trange.e.r = options.sheetRows - 1;\n\t\t\t\t\t\t\t\tout[\"!fullref\"] = out[\"!ref\"];\n\t\t\t\t\t\t\t\tout[\"!ref\"] = encode_range(range);\n\t\t\t\t\t\t\t\trange.e.r = tmpri;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\trange.e.r++; range.e.c++;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(merges.length > 0) out[\"!merges\"] = merges;\n\t\t\t\t\t\tif(objects.length > 0) out[\"!objects\"] = objects;\n\t\t\t\t\t\tif(colinfo.length > 0) out[\"!cols\"] = colinfo;\n\t\t\t\t\t\tif(rowinfo.length > 0) out[\"!rows\"] = rowinfo;\n\t\t\t\t\t\tWorkbook.Sheets.push(wsprops);\n\t\t\t\t\t}\n\t\t\t\t\tif(cur_sheet === \"\") Preamble = out; else Sheets[cur_sheet] = out;\n\t\t\t\t\tout = ((options.dense ? [] : {})/*:any*/);\n\t\t\t\t} break;\n\t\t\t\tcase 0x0009: case 0x0209: case 0x0409: case 0x0809 /* BOF */: {\n\t\t\t\t\tif(opts.biff === 8) opts.biff = {\n\t\t\t\t\t\t/*::[*/0x0009/*::]*/:2,\n\t\t\t\t\t\t/*::[*/0x0209/*::]*/:3,\n\t\t\t\t\t\t/*::[*/0x0409/*::]*/:4\n\t\t\t\t\t}[RecordType] || {\n\t\t\t\t\t\t/*::[*/0x0200/*::]*/:2,\n\t\t\t\t\t\t/*::[*/0x0300/*::]*/:3,\n\t\t\t\t\t\t/*::[*/0x0400/*::]*/:4,\n\t\t\t\t\t\t/*::[*/0x0500/*::]*/:5,\n\t\t\t\t\t\t/*::[*/0x0600/*::]*/:8,\n\t\t\t\t\t\t/*::[*/0x0002/*::]*/:2,\n\t\t\t\t\t\t/*::[*/0x0007/*::]*/:2\n\t\t\t\t\t}[val.BIFFVer] || 8;\n\t\t\t\t\topts.biffguess = val.BIFFVer == 0;\n\t\t\t\t\tif(val.BIFFVer == 0 && val.dt == 0x1000) { opts.biff = 5; seen_codepage = true; set_cp(opts.codepage = 28591); }\n\t\t\t\t\tif(opts.biff == 8 && val.BIFFVer == 0 && val.dt == 16) opts.biff = 2;\n\t\t\t\t\tif(file_depth++) break;\n\t\t\t\t\tout = ((options.dense ? [] : {})/*:any*/);\n\n\t\t\t\t\tif(opts.biff < 8 && !seen_codepage) { seen_codepage = true; set_cp(opts.codepage = options.codepage || 1252); }\n\n\t\t\t\t\tif(opts.biff < 5 || val.BIFFVer == 0 && val.dt == 0x1000) {\n\t\t\t\t\t\tif(cur_sheet === \"\") cur_sheet = \"Sheet1\";\n\t\t\t\t\t\trange = {s:{r:0,c:0},e:{r:0,c:0}};\n\t\t\t\t\t\t/* fake BoundSheet8 */\n\t\t\t\t\t\tvar fakebs8 = {pos: blob.l - length, name:cur_sheet};\n\t\t\t\t\t\tDirectory[fakebs8.pos] = fakebs8;\n\t\t\t\t\t\topts.snames.push(cur_sheet);\n\t\t\t\t\t}\n\t\t\t\t\telse cur_sheet = (Directory[s] || {name:\"\"}).name;\n\t\t\t\t\tif(val.dt == 0x20) out[\"!type\"] = \"chart\";\n\t\t\t\t\tif(val.dt == 0x40) out[\"!type\"] = \"macro\";\n\t\t\t\t\tmerges = [];\n\t\t\t\t\tobjects = [];\n\t\t\t\t\topts.arrayf = arrayf = [];\n\t\t\t\t\tcolinfo = []; rowinfo = [];\n\t\t\t\t\tseencol = false;\n\t\t\t\t\twsprops = {Hidden:(Directory[s]||{hs:0}).hs, name:cur_sheet };\n\t\t\t\t} break;\n\t\t\t\tcase 0x0203 /* Number */: case 0x0003 /* BIFF2NUM */: case 0x0002 /* BIFF2INT */: {\n\t\t\t\t\tif(out[\"!type\"] == \"chart\") if(options.dense ? (out[val.r]||[])[val.c]: out[encode_cell({c:val.c, r:val.r})]) ++val.c;\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe]||{}, v:val.val, t:'n'}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x0005: case 0x0205 /* BoolErr */: {\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe], v:val.val, t:val.t}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x027e /* RK */: {\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe], v:val.rknum, t:'n'}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x00bd /* MulRk */: {\n\t\t\t\t\tfor(var j = val.c; j <= val.C; ++j) {\n\t\t\t\t\t\tvar ixfe = val.rkrec[j-val.c][0];\n\t\t\t\t\t\ttemp_val= ({ixfe:ixfe, XF:XFs[ixfe], v:val.rkrec[j-val.c][1], t:'n'}/*:any*/);\n\t\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell({c:j, r:val.r}, temp_val, options);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0006: case 0x0206: case 0x0406 /* Formula */: {\n\t\t\t\t\tif(val.val == 'String') { last_formula = val; break; }\n\t\t\t\t\ttemp_val = make_cell(val.val, val.cell.ixfe, val.tt);\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(options.cellFormula) {\n\t\t\t\t\t\tvar _f = val.formula;\n\t\t\t\t\t\tif(_f && _f[0] && _f[0][0] && _f[0][0][0] == 'PtgExp') {\n\t\t\t\t\t\t\tvar _fr = _f[0][0][1][0], _fc = _f[0][0][1][1];\n\t\t\t\t\t\t\tvar _fe = encode_cell({r:_fr, c:_fc});\n\t\t\t\t\t\t\tif(sharedf[_fe]) temp_val.f = \"\"+stringify_formula(val.formula,range,val.cell,supbooks, opts);\n\t\t\t\t\t\t\telse temp_val.F = ((options.dense ? (out[_fr]||[])[_fc]: out[_fe]) || {}).F;\n\t\t\t\t\t\t} else temp_val.f = \"\"+stringify_formula(val.formula,range,val.cell,supbooks, opts);\n\t\t\t\t\t}\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell(val.cell, temp_val, options);\n\t\t\t\t\tlast_formula = val;\n\t\t\t\t} break;\n\t\t\t\tcase 0x0007: case 0x0207 /* String */: {\n\t\t\t\t\tif(last_formula) { /* technically always true */\n\t\t\t\t\t\tlast_formula.val = val;\n\t\t\t\t\t\ttemp_val = make_cell(val, last_formula.cell.ixfe, 's');\n\t\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\t\tif(options.cellFormula) {\n\t\t\t\t\t\t\ttemp_val.f = \"\"+stringify_formula(last_formula.formula, range, last_formula.cell, supbooks, opts);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell(last_formula.cell, temp_val, options);\n\t\t\t\t\t\tlast_formula = null;\n\t\t\t\t\t} else throw new Error(\"String record expects Formula\");\n\t\t\t\t} break;\n\t\t\t\tcase 0x0021: case 0x0221 /* Array */: {\n\t\t\t\t\tarrayf.push(val);\n\t\t\t\t\tvar _arraystart = encode_cell(val[0].s);\n\t\t\t\t\tcc = options.dense ? (out[val[0].s.r]||[])[val[0].s.c] : out[_arraystart];\n\t\t\t\t\tif(options.cellFormula && cc) {\n\t\t\t\t\t\tif(!last_formula) break; /* technically unreachable */\n\t\t\t\t\t\tif(!_arraystart || !cc) break;\n\t\t\t\t\t\tcc.f = \"\"+stringify_formula(val[1], range, val[0], supbooks, opts);\n\t\t\t\t\t\tcc.F = encode_range(val[0]);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x04bc /* ShrFmla */: {\n\t\t\t\t\tif(!options.cellFormula) break;\n\t\t\t\t\tif(last_cell) {\n\t\t\t\t\t\t/* TODO: capture range */\n\t\t\t\t\t\tif(!last_formula) break; /* technically unreachable */\n\t\t\t\t\t\tsharedf[encode_cell(last_formula.cell)]= val[0];\n\t\t\t\t\t\tcc = options.dense ? (out[last_formula.cell.r]||[])[last_formula.cell.c] : out[encode_cell(last_formula.cell)];\n\t\t\t\t\t\t(cc||{}).f = \"\"+stringify_formula(val[0], range, lastcell, supbooks, opts);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x00fd /* LabelSst */:\n\t\t\t\t\ttemp_val=make_cell(sst[val.isst].t, val.ixfe, 's');\n\t\t\t\t\tif(sst[val.isst].h) temp_val.h = sst[val.isst].h;\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0201 /* Blank */: if(options.sheetStubs) {\n\t\t\t\t\ttemp_val = ({ixfe: val.ixfe, XF: XFs[val.ixfe], t:'z'}/*:any*/);\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t} break;\n\t\t\t\tcase 0x00be /* MulBlank */: if(options.sheetStubs) {\n\t\t\t\t\tfor(var _j = val.c; _j <= val.C; ++_j) {\n\t\t\t\t\t\tvar _ixfe = val.ixfe[_j-val.c];\n\t\t\t\t\t\ttemp_val= ({ixfe:_ixfe, XF:XFs[_ixfe], t:'z'}/*:any*/);\n\t\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\t\taddcell({c:_j, r:val.r}, temp_val, options);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x00d6 /* RString */:\n\t\t\t\tcase 0x0204 /* Label */: case 0x0004 /* BIFF2STR */:\n\t\t\t\t\ttemp_val=make_cell(val.val, val.ixfe, 's');\n\t\t\t\t\ttemp_val.XF = XFs[temp_val.ixfe];\n\t\t\t\t\tif(BIFF2Fmt > 0) temp_val.z = BIFF2FmtTable[(temp_val.ixfe>>8) & 0x3F];\n\t\t\t\t\tsafe_format_xf(temp_val, options, wb.opts.Date1904);\n\t\t\t\t\taddcell({c:val.c, r:val.r}, temp_val, options);\n\t\t\t\t\tbreak;\n\n\t\t\t\tcase 0x0000: case 0x0200 /* Dimensions */: {\n\t\t\t\t\tif(file_depth === 1) range = val; /* TODO: stack */\n\t\t\t\t} break;\n\t\t\t\tcase 0x00fc /* SST */: {\n\t\t\t\t\tsst = val;\n\t\t\t\t} break;\n\t\t\t\tcase 0x041e /* Format */: { /* val = [id, fmt] */\n\t\t\t\t\tif(opts.biff == 4) {\n\t\t\t\t\t\tBIFF2FmtTable[BIFF2Fmt++] = val[1];\n\t\t\t\t\t\tfor(var b4idx = 0; b4idx < BIFF2Fmt + 163; ++b4idx) if(table_fmt[b4idx] == val[1]) break;\n\t\t\t\t\t\tif(b4idx >= 163) SSF_load(val[1], BIFF2Fmt + 163);\n\t\t\t\t\t}\n\t\t\t\t\telse SSF_load(val[1], val[0]);\n\t\t\t\t} break;\n\t\t\t\tcase 0x001e /* BIFF2FORMAT */: {\n\t\t\t\t\tBIFF2FmtTable[BIFF2Fmt++] = val;\n\t\t\t\t\tfor(var b2idx = 0; b2idx < BIFF2Fmt + 163; ++b2idx) if(table_fmt[b2idx] == val) break;\n\t\t\t\t\tif(b2idx >= 163) SSF_load(val, BIFF2Fmt + 163);\n\t\t\t\t} break;\n\n\t\t\t\tcase 0x00e5 /* MergeCells */: merges = merges.concat(val); break;\n\n\t\t\t\tcase 0x005d /* Obj */: objects[val.cmo[0]] = opts.lastobj = val; break;\n\t\t\t\tcase 0x01b6 /* TxO */: opts.lastobj.TxO = val; break;\n\t\t\t\tcase 0x007f /* ImData */: opts.lastobj.ImData = val; break;\n\n\t\t\t\tcase 0x01b8 /* HLink */: {\n\t\t\t\t\tfor(rngR = val[0].s.r; rngR <= val[0].e.r; ++rngR)\n\t\t\t\t\t\tfor(rngC = val[0].s.c; rngC <= val[0].e.c; ++rngC) {\n\t\t\t\t\t\t\tcc = options.dense ? (out[rngR]||[])[rngC] : out[encode_cell({c:rngC,r:rngR})];\n\t\t\t\t\t\t\tif(cc) cc.l = val[1];\n\t\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0800 /* HLinkTooltip */: {\n\t\t\t\t\tfor(rngR = val[0].s.r; rngR <= val[0].e.r; ++rngR)\n\t\t\t\t\t\tfor(rngC = val[0].s.c; rngC <= val[0].e.c; ++rngC) {\n\t\t\t\t\t\t\tcc = options.dense ? (out[rngR]||[])[rngC] : out[encode_cell({c:rngC,r:rngR})];\n\t\t\t\t\t\t\tif(cc && cc.l) cc.l.Tooltip = val[1];\n\t\t\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x001c /* Note */: {\n\t\t\t\t\tif(opts.biff <= 5 && opts.biff >= 2) break; /* TODO: BIFF5 */\n\t\t\t\t\tcc = options.dense ? (out[val[0].r]||[])[val[0].c] : out[encode_cell(val[0])];\n\t\t\t\t\tvar noteobj = objects[val[2]];\n\t\t\t\t\tif(!cc) {\n\t\t\t\t\t\tif(options.dense) {\n\t\t\t\t\t\t\tif(!out[val[0].r]) out[val[0].r] = [];\n\t\t\t\t\t\t\tcc = out[val[0].r][val[0].c] = ({t:\"z\"}/*:any*/);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tcc = out[encode_cell(val[0])] = ({t:\"z\"}/*:any*/);\n\t\t\t\t\t\t}\n\t\t\t\t\t\trange.e.r = Math.max(range.e.r, val[0].r);\n\t\t\t\t\t\trange.s.r = Math.min(range.s.r, val[0].r);\n\t\t\t\t\t\trange.e.c = Math.max(range.e.c, val[0].c);\n\t\t\t\t\t\trange.s.c = Math.min(range.s.c, val[0].c);\n\t\t\t\t\t}\n\t\t\t\t\tif(!cc.c) cc.c = [];\n\t\t\t\t\tcmnt = {a:val[1],t:noteobj.TxO.t};\n\t\t\t\t\tcc.c.push(cmnt);\n\t\t\t\t} break;\n\t\t\t\tcase 0x087d /* XFExt */: update_xfext(XFs[val.ixfe], val.ext); break;\n\t\t\t\tcase 0x007d /* ColInfo */: {\n\t\t\t\t\tif(!opts.cellStyles) break;\n\t\t\t\t\twhile(val.e >= val.s) {\n\t\t\t\t\t\tcolinfo[val.e--] = { width: val.w/256, level: (val.level || 0), hidden: !!(val.flags & 1) };\n\t\t\t\t\t\tif(!seencol) { seencol = true; find_mdw_colw(val.w/256); }\n\t\t\t\t\t\tprocess_col(colinfo[val.e+1]);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0208 /* Row */: {\n\t\t\t\t\tvar rowobj = {};\n\t\t\t\t\tif(val.level != null) { rowinfo[val.r] = rowobj; rowobj.level = val.level; }\n\t\t\t\t\tif(val.hidden) { rowinfo[val.r] = rowobj; rowobj.hidden = true; }\n\t\t\t\t\tif(val.hpt) {\n\t\t\t\t\t\trowinfo[val.r] = rowobj;\n\t\t\t\t\t\trowobj.hpt = val.hpt; rowobj.hpx = pt2px(val.hpt);\n\t\t\t\t\t}\n\t\t\t\t} break;\n\t\t\t\tcase 0x0026 /* LeftMargin */:\n\t\t\t\tcase 0x0027 /* RightMargin */:\n\t\t\t\tcase 0x0028 /* TopMargin */:\n\t\t\t\tcase 0x0029 /* BottomMargin */:\n\t\t\t\t\tif(!out['!margins']) default_margins(out['!margins'] = {});\n\t\t\t\t\tout['!margins'][({0x26: \"left\", 0x27:\"right\", 0x28:\"top\", 0x29:\"bottom\"})[RecordType]] = val;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x00a1 /* Setup */: // TODO\n\t\t\t\t\tif(!out['!margins']) default_margins(out['!margins'] = {});\n\t\t\t\t\tout['!margins'].header = val.header;\n\t\t\t\t\tout['!margins'].footer = val.footer;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x023e /* Window2 */: // TODO\n\t\t\t\t\t// $FlowIgnore\n\t\t\t\t\tif(val.RTL) Workbook.Views[0].RTL = true;\n\t\t\t\t\tbreak;\n\t\t\t\tcase 0x0092 /* Palette */: palette = val; break;\n\t\t\t\tcase 0x0896 /* Theme */: themes = val; break;\n\t\t\t\tcase 0x008c /* Country */: country = val; break;\n\t\t\t\tcase 0x01ba /* CodeName */: {\n\t\t\t\t\t/*:: if(!Workbook.WBProps) Workbook.WBProps = {}; */\n\t\t\t\t\tif(!cur_sheet) Workbook.WBProps.CodeName = val || \"ThisWorkbook\";\n\t\t\t\t\telse wsprops.CodeName = val || wsprops.name;\n\t\t\t\t} break;\n\t\t\t}\n\t\t} else {\n\t\t\tif(!R) console.error(\"Missing Info for XLS Record 0x\" + RecordType.toString(16));\n\t\t\tblob.l += length;\n\t\t}\n\t}\n\twb.SheetNames=keys(Directory).sort(function(a,b) { return Number(a) - Number(b); }).map(function(x){return Directory[x].name;});\n\tif(!options.bookSheets) wb.Sheets=Sheets;\n\tif(!wb.SheetNames.length && Preamble[\"!ref\"]) {\n\t\twb.SheetNames.push(\"Sheet1\");\n\t\t/*jshint -W069 */\n\t\tif(wb.Sheets) wb.Sheets[\"Sheet1\"] = Preamble;\n\t\t/*jshint +W069 */\n\t} else wb.Preamble=Preamble;\n\tif(wb.Sheets) FilterDatabases.forEach(function(r,i) { wb.Sheets[wb.SheetNames[i]]['!autofilter'] = r; });\n\twb.Strings = sst;\n\twb.SSF = dup(table_fmt);\n\tif(opts.enc) wb.Encryption = opts.enc;\n\tif(themes) wb.Themes = themes;\n\twb.Metadata = {};\n\tif(country !== undefined) wb.Metadata.Country = country;\n\tif(supbooks.names.length > 0) Workbook.Names = supbooks.names;\n\twb.Workbook = Workbook;\n\treturn wb;\n}\n\n/* TODO: split props*/\nvar PSCLSID = {\n\tSI: \"e0859ff2f94f6810ab9108002b27b3d9\",\n\tDSI: \"02d5cdd59c2e1b10939708002b2cf9ae\",\n\tUDI: \"05d5cdd59c2e1b10939708002b2cf9ae\"\n};\nfunction parse_xls_props(cfb/*:CFBContainer*/, props, o) {\n\t/* [MS-OSHARED] 2.3.3.2.2 Document Summary Information Property Set */\n\tvar DSI = CFB.find(cfb, '/!DocumentSummaryInformation');\n\tif(DSI && DSI.size > 0) try {\n\t\tvar DocSummary = parse_PropertySetStream(DSI, DocSummaryPIDDSI, PSCLSID.DSI);\n\t\tfor(var d in DocSummary) props[d] = DocSummary[d];\n\t} catch(e) {if(o.WTF) throw e;/* empty */}\n\n\t/* [MS-OSHARED] 2.3.3.2.1 Summary Information Property Set*/\n\tvar SI = CFB.find(cfb, '/!SummaryInformation');\n\tif(SI && SI.size > 0) try {\n\t\tvar Summary = parse_PropertySetStream(SI, SummaryPIDSI, PSCLSID.SI);\n\t\tfor(var s in Summary) if(props[s] == null) props[s] = Summary[s];\n\t} catch(e) {if(o.WTF) throw e;/* empty */}\n\n\tif(props.HeadingPairs && props.TitlesOfParts) {\n\t\tload_props_pairs(props.HeadingPairs, props.TitlesOfParts, props, o);\n\t\tdelete props.HeadingPairs; delete props.TitlesOfParts;\n\t}\n}\nfunction write_xls_props(wb/*:Workbook*/, cfb/*:CFBContainer*/) {\n\tvar DSEntries = [], SEntries = [], CEntries = [];\n\tvar i = 0, Keys;\n\tvar DocSummaryRE/*:{[key:string]:string}*/ = evert_key(DocSummaryPIDDSI, \"n\");\n\tvar SummaryRE/*:{[key:string]:string}*/ = evert_key(SummaryPIDSI, \"n\");\n\tif(wb.Props) {\n\t\tKeys = keys(wb.Props);\n\t\t// $FlowIgnore\n\t\tfor(i = 0; i < Keys.length; ++i) (Object.prototype.hasOwnProperty.call(DocSummaryRE, Keys[i]) ? DSEntries : Object.prototype.hasOwnProperty.call(SummaryRE, Keys[i]) ? SEntries : CEntries).push([Keys[i], wb.Props[Keys[i]]]);\n\t}\n\tif(wb.Custprops) {\n\t\tKeys = keys(wb.Custprops);\n\t\t// $FlowIgnore\n\t\tfor(i = 0; i < Keys.length; ++i) if(!Object.prototype.hasOwnProperty.call((wb.Props||{}), Keys[i])) (Object.prototype.hasOwnProperty.call(DocSummaryRE, Keys[i]) ? DSEntries : Object.prototype.hasOwnProperty.call(SummaryRE, Keys[i]) ? SEntries : CEntries).push([Keys[i], wb.Custprops[Keys[i]]]);\n\t}\n\tvar CEntries2 = [];\n\tfor(i = 0; i < CEntries.length; ++i) {\n\t\tif(XLSPSSkip.indexOf(CEntries[i][0]) > -1 || PseudoPropsPairs.indexOf(CEntries[i][0]) > -1) continue;\n\t\tif(CEntries[i][1] == null) continue;\n\t\tCEntries2.push(CEntries[i]);\n\t}\n\tif(SEntries.length) CFB.utils.cfb_add(cfb, \"/\\u0005SummaryInformation\", write_PropertySetStream(SEntries, PSCLSID.SI, SummaryRE, SummaryPIDSI));\n\tif(DSEntries.length || CEntries2.length) CFB.utils.cfb_add(cfb, \"/\\u0005DocumentSummaryInformation\", write_PropertySetStream(DSEntries, PSCLSID.DSI, DocSummaryRE, DocSummaryPIDDSI, CEntries2.length ? CEntries2 : null, PSCLSID.UDI));\n}\n\nfunction parse_xlscfb(cfb/*:any*/, options/*:?ParseOpts*/)/*:Workbook*/ {\nif(!options) options = {};\nfix_read_opts(options);\nreset_cp();\nif(options.codepage) set_ansi(options.codepage);\nvar CompObj/*:?CFBEntry*/, WB/*:?any*/;\nif(cfb.FullPaths) {\n\tif(CFB.find(cfb, '/encryption')) throw new Error(\"File is password-protected\");\n\tCompObj = CFB.find(cfb, '!CompObj');\n\tWB = CFB.find(cfb, '/Workbook') || CFB.find(cfb, '/Book');\n} else {\n\tswitch(options.type) {\n\t\tcase 'base64': cfb = s2a(Base64_decode(cfb)); break;\n\t\tcase 'binary': cfb = s2a(cfb); break;\n\t\tcase 'buffer': break;\n\t\tcase 'array': if(!Array.isArray(cfb)) cfb = Array.prototype.slice.call(cfb); break;\n\t}\n\tprep_blob(cfb, 0);\n\tWB = ({content: cfb}/*:any*/);\n}\nvar /*::CompObjP, */WorkbookP/*:: :Workbook = XLSX.utils.book_new(); */;\n\nvar _data/*:?any*/;\nif(CompObj) /*::CompObjP = */parse_compobj(CompObj);\nif(options.bookProps && !options.bookSheets) WorkbookP = ({}/*:any*/);\nelse/*:: if(cfb instanceof CFBContainer) */ {\n\tvar T = has_buf ? 'buffer' : 'array';\n\tif(WB && WB.content) WorkbookP = parse_workbook(WB.content, options);\n\t/* Quattro Pro 7-8 */\n\telse if((_data=CFB.find(cfb, 'PerfectOffice_MAIN')) && _data.content) WorkbookP = WK_.to_workbook(_data.content, (options.type = T, options));\n\t/* Quattro Pro 9 */\n\telse if((_data=CFB.find(cfb, 'NativeContent_MAIN')) && _data.content) WorkbookP = WK_.to_workbook(_data.content, (options.type = T, options));\n\t/* Works 4 for Mac */\n\telse if((_data=CFB.find(cfb, 'MN0')) && _data.content) throw new Error(\"Unsupported Works 4 for Mac file\");\n\telse throw new Error(\"Cannot find Workbook stream\");\n\tif(options.bookVBA && cfb.FullPaths && CFB.find(cfb, '/_VBA_PROJECT_CUR/VBA/dir')) WorkbookP.vbaraw = make_vba_xls(cfb);\n}\n\nvar props = {};\nif(cfb.FullPaths) parse_xls_props(/*::((*/cfb/*:: :any):CFBContainer)*/, props, options);\n\nWorkbookP.Props = WorkbookP.Custprops = props; /* TODO: split up properties */\nif(options.bookFiles) WorkbookP.cfb = cfb;\n/*WorkbookP.CompObjP = CompObjP; // TODO: storage? */\nreturn WorkbookP;\n}\n\n\nfunction write_xlscfb(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:CFBContainer*/ {\n\tvar o = opts || {};\n\tvar cfb = CFB.utils.cfb_new({root:\"R\"});\n\tvar wbpath = \"/Workbook\";\n\tswitch(o.bookType || \"xls\") {\n\t\tcase \"xls\": o.bookType = \"biff8\";\n\t\t/* falls through */\n\t\tcase \"xla\": if(!o.bookType) o.bookType = \"xla\";\n\t\t/* falls through */\n\t\tcase \"biff8\": wbpath = \"/Workbook\"; o.biff = 8; break;\n\t\tcase \"biff5\": wbpath = \"/Book\"; o.biff = 5; break;\n\t\tdefault: throw new Error(\"invalid type \" + o.bookType + \" for XLS CFB\");\n\t}\n\tCFB.utils.cfb_add(cfb, wbpath, write_biff_buf(wb, o));\n\tif(o.biff == 8 && (wb.Props || wb.Custprops)) write_xls_props(wb, cfb);\n\t// TODO: SI, DSI, CO\n\tif(o.biff == 8 && wb.vbaraw) fill_vba_xls(cfb, CFB.read(wb.vbaraw, {type: typeof wb.vbaraw == \"string\" ? \"binary\" : \"buffer\"}));\n\treturn cfb;\n}\n/* [MS-XLSB] 2.3 Record Enumeration */\nvar XLSBRecordEnum = {\n\t/*::[*/0x0000/*::]*/: { /* n:\"BrtRowHdr\", */ f:parse_BrtRowHdr },\n\t/*::[*/0x0001/*::]*/: { /* n:\"BrtCellBlank\", */ f:parse_BrtCellBlank },\n\t/*::[*/0x0002/*::]*/: { /* n:\"BrtCellRk\", */ f:parse_BrtCellRk },\n\t/*::[*/0x0003/*::]*/: { /* n:\"BrtCellError\", */ f:parse_BrtCellError },\n\t/*::[*/0x0004/*::]*/: { /* n:\"BrtCellBool\", */ f:parse_BrtCellBool },\n\t/*::[*/0x0005/*::]*/: { /* n:\"BrtCellReal\", */ f:parse_BrtCellReal },\n\t/*::[*/0x0006/*::]*/: { /* n:\"BrtCellSt\", */ f:parse_BrtCellSt },\n\t/*::[*/0x0007/*::]*/: { /* n:\"BrtCellIsst\", */ f:parse_BrtCellIsst },\n\t/*::[*/0x0008/*::]*/: { /* n:\"BrtFmlaString\", */ f:parse_BrtFmlaString },\n\t/*::[*/0x0009/*::]*/: { /* n:\"BrtFmlaNum\", */ f:parse_BrtFmlaNum },\n\t/*::[*/0x000A/*::]*/: { /* n:\"BrtFmlaBool\", */ f:parse_BrtFmlaBool },\n\t/*::[*/0x000B/*::]*/: { /* n:\"BrtFmlaError\", */ f:parse_BrtFmlaError },\n\t/*::[*/0x000C/*::]*/: { /* n:\"BrtShortBlank\", */ f:parse_BrtShortBlank },\n\t/*::[*/0x000D/*::]*/: { /* n:\"BrtShortRk\", */ f:parse_BrtShortRk },\n\t/*::[*/0x000E/*::]*/: { /* n:\"BrtShortError\", */ f:parse_BrtShortError },\n\t/*::[*/0x000F/*::]*/: { /* n:\"BrtShortBool\", */ f:parse_BrtShortBool },\n\t/*::[*/0x0010/*::]*/: { /* n:\"BrtShortReal\", */ f:parse_BrtShortReal },\n\t/*::[*/0x0011/*::]*/: { /* n:\"BrtShortSt\", */ f:parse_BrtShortSt },\n\t/*::[*/0x0012/*::]*/: { /* n:\"BrtShortIsst\", */ f:parse_BrtShortIsst },\n\t/*::[*/0x0013/*::]*/: { /* n:\"BrtSSTItem\", */ f:parse_RichStr },\n\t/*::[*/0x0014/*::]*/: { /* n:\"BrtPCDIMissing\" */ },\n\t/*::[*/0x0015/*::]*/: { /* n:\"BrtPCDINumber\" */ },\n\t/*::[*/0x0016/*::]*/: { /* n:\"BrtPCDIBoolean\" */ },\n\t/*::[*/0x0017/*::]*/: { /* n:\"BrtPCDIError\" */ },\n\t/*::[*/0x0018/*::]*/: { /* n:\"BrtPCDIString\" */ },\n\t/*::[*/0x0019/*::]*/: { /* n:\"BrtPCDIDatetime\" */ },\n\t/*::[*/0x001A/*::]*/: { /* n:\"BrtPCDIIndex\" */ },\n\t/*::[*/0x001B/*::]*/: { /* n:\"BrtPCDIAMissing\" */ },\n\t/*::[*/0x001C/*::]*/: { /* n:\"BrtPCDIANumber\" */ },\n\t/*::[*/0x001D/*::]*/: { /* n:\"BrtPCDIABoolean\" */ },\n\t/*::[*/0x001E/*::]*/: { /* n:\"BrtPCDIAError\" */ },\n\t/*::[*/0x001F/*::]*/: { /* n:\"BrtPCDIAString\" */ },\n\t/*::[*/0x0020/*::]*/: { /* n:\"BrtPCDIADatetime\" */ },\n\t/*::[*/0x0021/*::]*/: { /* n:\"BrtPCRRecord\" */ },\n\t/*::[*/0x0022/*::]*/: { /* n:\"BrtPCRRecordDt\" */ },\n\t/*::[*/0x0023/*::]*/: { /* n:\"BrtFRTBegin\", */ T:1 },\n\t/*::[*/0x0024/*::]*/: { /* n:\"BrtFRTEnd\", */ T:-1 },\n\t/*::[*/0x0025/*::]*/: { /* n:\"BrtACBegin\", */ T:1 },\n\t/*::[*/0x0026/*::]*/: { /* n:\"BrtACEnd\", */ T:-1 },\n\t/*::[*/0x0027/*::]*/: { /* n:\"BrtName\", */ f:parse_BrtName },\n\t/*::[*/0x0028/*::]*/: { /* n:\"BrtIndexRowBlock\" */ },\n\t/*::[*/0x002A/*::]*/: { /* n:\"BrtIndexBlock\" */ },\n\t/*::[*/0x002B/*::]*/: { /* n:\"BrtFont\", */ f:parse_BrtFont },\n\t/*::[*/0x002C/*::]*/: { /* n:\"BrtFmt\", */ f:parse_BrtFmt },\n\t/*::[*/0x002D/*::]*/: { /* n:\"BrtFill\", */ f:parse_BrtFill },\n\t/*::[*/0x002E/*::]*/: { /* n:\"BrtBorder\", */ f:parse_BrtBorder },\n\t/*::[*/0x002F/*::]*/: { /* n:\"BrtXF\", */ f:parse_BrtXF },\n\t/*::[*/0x0030/*::]*/: { /* n:\"BrtStyle\" */ },\n\t/*::[*/0x0031/*::]*/: { /* n:\"BrtCellMeta\", */ f:parse_Int32LE },\n\t/*::[*/0x0032/*::]*/: { /* n:\"BrtValueMeta\" */ },\n\t/*::[*/0x0033/*::]*/: { /* n:\"BrtMdb\" */ f:parse_BrtMdb },\n\t/*::[*/0x0034/*::]*/: { /* n:\"BrtBeginFmd\", */ T:1 },\n\t/*::[*/0x0035/*::]*/: { /* n:\"BrtEndFmd\", */ T:-1 },\n\t/*::[*/0x0036/*::]*/: { /* n:\"BrtBeginMdx\", */ T:1 },\n\t/*::[*/0x0037/*::]*/: { /* n:\"BrtEndMdx\", */ T:-1 },\n\t/*::[*/0x0038/*::]*/: { /* n:\"BrtBeginMdxTuple\", */ T:1 },\n\t/*::[*/0x0039/*::]*/: { /* n:\"BrtEndMdxTuple\", */ T:-1 },\n\t/*::[*/0x003A/*::]*/: { /* n:\"BrtMdxMbrIstr\" */ },\n\t/*::[*/0x003B/*::]*/: { /* n:\"BrtStr\" */ },\n\t/*::[*/0x003C/*::]*/: { /* n:\"BrtColInfo\", */ f:parse_ColInfo },\n\t/*::[*/0x003E/*::]*/: { /* n:\"BrtCellRString\", */ f:parse_BrtCellRString },\n\t/*::[*/0x003F/*::]*/: { /* n:\"BrtCalcChainItem$\", */ f:parse_BrtCalcChainItem$ },\n\t/*::[*/0x0040/*::]*/: { /* n:\"BrtDVal\", */ f:parse_BrtDVal },\n\t/*::[*/0x0041/*::]*/: { /* n:\"BrtSxvcellNum\" */ },\n\t/*::[*/0x0042/*::]*/: { /* n:\"BrtSxvcellStr\" */ },\n\t/*::[*/0x0043/*::]*/: { /* n:\"BrtSxvcellBool\" */ },\n\t/*::[*/0x0044/*::]*/: { /* n:\"BrtSxvcellErr\" */ },\n\t/*::[*/0x0045/*::]*/: { /* n:\"BrtSxvcellDate\" */ },\n\t/*::[*/0x0046/*::]*/: { /* n:\"BrtSxvcellNil\" */ },\n\t/*::[*/0x0080/*::]*/: { /* n:\"BrtFileVersion\" */ },\n\t/*::[*/0x0081/*::]*/: { /* n:\"BrtBeginSheet\", */ T:1 },\n\t/*::[*/0x0082/*::]*/: { /* n:\"BrtEndSheet\", */ T:-1 },\n\t/*::[*/0x0083/*::]*/: { /* n:\"BrtBeginBook\", */ T:1, f:parsenoop, p:0 },\n\t/*::[*/0x0084/*::]*/: { /* n:\"BrtEndBook\", */ T:-1 },\n\t/*::[*/0x0085/*::]*/: { /* n:\"BrtBeginWsViews\", */ T:1 },\n\t/*::[*/0x0086/*::]*/: { /* n:\"BrtEndWsViews\", */ T:-1 },\n\t/*::[*/0x0087/*::]*/: { /* n:\"BrtBeginBookViews\", */ T:1 },\n\t/*::[*/0x0088/*::]*/: { /* n:\"BrtEndBookViews\", */ T:-1 },\n\t/*::[*/0x0089/*::]*/: { /* n:\"BrtBeginWsView\", */ T:1, f:parse_BrtBeginWsView },\n\t/*::[*/0x008A/*::]*/: { /* n:\"BrtEndWsView\", */ T:-1 },\n\t/*::[*/0x008B/*::]*/: { /* n:\"BrtBeginCsViews\", */ T:1 },\n\t/*::[*/0x008C/*::]*/: { /* n:\"BrtEndCsViews\", */ T:-1 },\n\t/*::[*/0x008D/*::]*/: { /* n:\"BrtBeginCsView\", */ T:1 },\n\t/*::[*/0x008E/*::]*/: { /* n:\"BrtEndCsView\", */ T:-1 },\n\t/*::[*/0x008F/*::]*/: { /* n:\"BrtBeginBundleShs\", */ T:1 },\n\t/*::[*/0x0090/*::]*/: { /* n:\"BrtEndBundleShs\", */ T:-1 },\n\t/*::[*/0x0091/*::]*/: { /* n:\"BrtBeginSheetData\", */ T:1 },\n\t/*::[*/0x0092/*::]*/: { /* n:\"BrtEndSheetData\", */ T:-1 },\n\t/*::[*/0x0093/*::]*/: { /* n:\"BrtWsProp\", */ f:parse_BrtWsProp },\n\t/*::[*/0x0094/*::]*/: { /* n:\"BrtWsDim\", */ f:parse_BrtWsDim, p:16 },\n\t/*::[*/0x0097/*::]*/: { /* n:\"BrtPane\", */ f:parse_BrtPane },\n\t/*::[*/0x0098/*::]*/: { /* n:\"BrtSel\" */ },\n\t/*::[*/0x0099/*::]*/: { /* n:\"BrtWbProp\", */ f:parse_BrtWbProp },\n\t/*::[*/0x009A/*::]*/: { /* n:\"BrtWbFactoid\" */ },\n\t/*::[*/0x009B/*::]*/: { /* n:\"BrtFileRecover\" */ },\n\t/*::[*/0x009C/*::]*/: { /* n:\"BrtBundleSh\", */ f:parse_BrtBundleSh },\n\t/*::[*/0x009D/*::]*/: { /* n:\"BrtCalcProp\" */ },\n\t/*::[*/0x009E/*::]*/: { /* n:\"BrtBookView\" */ },\n\t/*::[*/0x009F/*::]*/: { /* n:\"BrtBeginSst\", */ T:1, f:parse_BrtBeginSst },\n\t/*::[*/0x00A0/*::]*/: { /* n:\"BrtEndSst\", */ T:-1 },\n\t/*::[*/0x00A1/*::]*/: { /* n:\"BrtBeginAFilter\", */ T:1, f:parse_UncheckedRfX },\n\t/*::[*/0x00A2/*::]*/: { /* n:\"BrtEndAFilter\", */ T:-1 },\n\t/*::[*/0x00A3/*::]*/: { /* n:\"BrtBeginFilterColumn\", */ T:1 },\n\t/*::[*/0x00A4/*::]*/: { /* n:\"BrtEndFilterColumn\", */ T:-1 },\n\t/*::[*/0x00A5/*::]*/: { /* n:\"BrtBeginFilters\", */ T:1 },\n\t/*::[*/0x00A6/*::]*/: { /* n:\"BrtEndFilters\", */ T:-1 },\n\t/*::[*/0x00A7/*::]*/: { /* n:\"BrtFilter\" */ },\n\t/*::[*/0x00A8/*::]*/: { /* n:\"BrtColorFilter\" */ },\n\t/*::[*/0x00A9/*::]*/: { /* n:\"BrtIconFilter\" */ },\n\t/*::[*/0x00AA/*::]*/: { /* n:\"BrtTop10Filter\" */ },\n\t/*::[*/0x00AB/*::]*/: { /* n:\"BrtDynamicFilter\" */ },\n\t/*::[*/0x00AC/*::]*/: { /* n:\"BrtBeginCustomFilters\", */ T:1 },\n\t/*::[*/0x00AD/*::]*/: { /* n:\"BrtEndCustomFilters\", */ T:-1 },\n\t/*::[*/0x00AE/*::]*/: { /* n:\"BrtCustomFilter\" */ },\n\t/*::[*/0x00AF/*::]*/: { /* n:\"BrtAFilterDateGroupItem\" */ },\n\t/*::[*/0x00B0/*::]*/: { /* n:\"BrtMergeCell\", */ f:parse_BrtMergeCell },\n\t/*::[*/0x00B1/*::]*/: { /* n:\"BrtBeginMergeCells\", */ T:1 },\n\t/*::[*/0x00B2/*::]*/: { /* n:\"BrtEndMergeCells\", */ T:-1 },\n\t/*::[*/0x00B3/*::]*/: { /* n:\"BrtBeginPivotCacheDef\", */ T:1 },\n\t/*::[*/0x00B4/*::]*/: { /* n:\"BrtEndPivotCacheDef\", */ T:-1 },\n\t/*::[*/0x00B5/*::]*/: { /* n:\"BrtBeginPCDFields\", */ T:1 },\n\t/*::[*/0x00B6/*::]*/: { /* n:\"BrtEndPCDFields\", */ T:-1 },\n\t/*::[*/0x00B7/*::]*/: { /* n:\"BrtBeginPCDField\", */ T:1 },\n\t/*::[*/0x00B8/*::]*/: { /* n:\"BrtEndPCDField\", */ T:-1 },\n\t/*::[*/0x00B9/*::]*/: { /* n:\"BrtBeginPCDSource\", */ T:1 },\n\t/*::[*/0x00BA/*::]*/: { /* n:\"BrtEndPCDSource\", */ T:-1 },\n\t/*::[*/0x00BB/*::]*/: { /* n:\"BrtBeginPCDSRange\", */ T:1 },\n\t/*::[*/0x00BC/*::]*/: { /* n:\"BrtEndPCDSRange\", */ T:-1 },\n\t/*::[*/0x00BD/*::]*/: { /* n:\"BrtBeginPCDFAtbl\", */ T:1 },\n\t/*::[*/0x00BE/*::]*/: { /* n:\"BrtEndPCDFAtbl\", */ T:-1 },\n\t/*::[*/0x00BF/*::]*/: { /* n:\"BrtBeginPCDIRun\", */ T:1 },\n\t/*::[*/0x00C0/*::]*/: { /* n:\"BrtEndPCDIRun\", */ T:-1 },\n\t/*::[*/0x00C1/*::]*/: { /* n:\"BrtBeginPivotCacheRecords\", */ T:1 },\n\t/*::[*/0x00C2/*::]*/: { /* n:\"BrtEndPivotCacheRecords\", */ T:-1 },\n\t/*::[*/0x00C3/*::]*/: { /* n:\"BrtBeginPCDHierarchies\", */ T:1 },\n\t/*::[*/0x00C4/*::]*/: { /* n:\"BrtEndPCDHierarchies\", */ T:-1 },\n\t/*::[*/0x00C5/*::]*/: { /* n:\"BrtBeginPCDHierarchy\", */ T:1 },\n\t/*::[*/0x00C6/*::]*/: { /* n:\"BrtEndPCDHierarchy\", */ T:-1 },\n\t/*::[*/0x00C7/*::]*/: { /* n:\"BrtBeginPCDHFieldsUsage\", */ T:1 },\n\t/*::[*/0x00C8/*::]*/: { /* n:\"BrtEndPCDHFieldsUsage\", */ T:-1 },\n\t/*::[*/0x00C9/*::]*/: { /* n:\"BrtBeginExtConnection\", */ T:1 },\n\t/*::[*/0x00CA/*::]*/: { /* n:\"BrtEndExtConnection\", */ T:-1 },\n\t/*::[*/0x00CB/*::]*/: { /* n:\"BrtBeginECDbProps\", */ T:1 },\n\t/*::[*/0x00CC/*::]*/: { /* n:\"BrtEndECDbProps\", */ T:-1 },\n\t/*::[*/0x00CD/*::]*/: { /* n:\"BrtBeginECOlapProps\", */ T:1 },\n\t/*::[*/0x00CE/*::]*/: { /* n:\"BrtEndECOlapProps\", */ T:-1 },\n\t/*::[*/0x00CF/*::]*/: { /* n:\"BrtBeginPCDSConsol\", */ T:1 },\n\t/*::[*/0x00D0/*::]*/: { /* n:\"BrtEndPCDSConsol\", */ T:-1 },\n\t/*::[*/0x00D1/*::]*/: { /* n:\"BrtBeginPCDSCPages\", */ T:1 },\n\t/*::[*/0x00D2/*::]*/: { /* n:\"BrtEndPCDSCPages\", */ T:-1 },\n\t/*::[*/0x00D3/*::]*/: { /* n:\"BrtBeginPCDSCPage\", */ T:1 },\n\t/*::[*/0x00D4/*::]*/: { /* n:\"BrtEndPCDSCPage\", */ T:-1 },\n\t/*::[*/0x00D5/*::]*/: { /* n:\"BrtBeginPCDSCPItem\", */ T:1 },\n\t/*::[*/0x00D6/*::]*/: { /* n:\"BrtEndPCDSCPItem\", */ T:-1 },\n\t/*::[*/0x00D7/*::]*/: { /* n:\"BrtBeginPCDSCSets\", */ T:1 },\n\t/*::[*/0x00D8/*::]*/: { /* n:\"BrtEndPCDSCSets\", */ T:-1 },\n\t/*::[*/0x00D9/*::]*/: { /* n:\"BrtBeginPCDSCSet\", */ T:1 },\n\t/*::[*/0x00DA/*::]*/: { /* n:\"BrtEndPCDSCSet\", */ T:-1 },\n\t/*::[*/0x00DB/*::]*/: { /* n:\"BrtBeginPCDFGroup\", */ T:1 },\n\t/*::[*/0x00DC/*::]*/: { /* n:\"BrtEndPCDFGroup\", */ T:-1 },\n\t/*::[*/0x00DD/*::]*/: { /* n:\"BrtBeginPCDFGItems\", */ T:1 },\n\t/*::[*/0x00DE/*::]*/: { /* n:\"BrtEndPCDFGItems\", */ T:-1 },\n\t/*::[*/0x00DF/*::]*/: { /* n:\"BrtBeginPCDFGRange\", */ T:1 },\n\t/*::[*/0x00E0/*::]*/: { /* n:\"BrtEndPCDFGRange\", */ T:-1 },\n\t/*::[*/0x00E1/*::]*/: { /* n:\"BrtBeginPCDFGDiscrete\", */ T:1 },\n\t/*::[*/0x00E2/*::]*/: { /* n:\"BrtEndPCDFGDiscrete\", */ T:-1 },\n\t/*::[*/0x00E3/*::]*/: { /* n:\"BrtBeginPCDSDTupleCache\", */ T:1 },\n\t/*::[*/0x00E4/*::]*/: { /* n:\"BrtEndPCDSDTupleCache\", */ T:-1 },\n\t/*::[*/0x00E5/*::]*/: { /* n:\"BrtBeginPCDSDTCEntries\", */ T:1 },\n\t/*::[*/0x00E6/*::]*/: { /* n:\"BrtEndPCDSDTCEntries\", */ T:-1 },\n\t/*::[*/0x00E7/*::]*/: { /* n:\"BrtBeginPCDSDTCEMembers\", */ T:1 },\n\t/*::[*/0x00E8/*::]*/: { /* n:\"BrtEndPCDSDTCEMembers\", */ T:-1 },\n\t/*::[*/0x00E9/*::]*/: { /* n:\"BrtBeginPCDSDTCEMember\", */ T:1 },\n\t/*::[*/0x00EA/*::]*/: { /* n:\"BrtEndPCDSDTCEMember\", */ T:-1 },\n\t/*::[*/0x00EB/*::]*/: { /* n:\"BrtBeginPCDSDTCQueries\", */ T:1 },\n\t/*::[*/0x00EC/*::]*/: { /* n:\"BrtEndPCDSDTCQueries\", */ T:-1 },\n\t/*::[*/0x00ED/*::]*/: { /* n:\"BrtBeginPCDSDTCQuery\", */ T:1 },\n\t/*::[*/0x00EE/*::]*/: { /* n:\"BrtEndPCDSDTCQuery\", */ T:-1 },\n\t/*::[*/0x00EF/*::]*/: { /* n:\"BrtBeginPCDSDTCSets\", */ T:1 },\n\t/*::[*/0x00F0/*::]*/: { /* n:\"BrtEndPCDSDTCSets\", */ T:-1 },\n\t/*::[*/0x00F1/*::]*/: { /* n:\"BrtBeginPCDSDTCSet\", */ T:1 },\n\t/*::[*/0x00F2/*::]*/: { /* n:\"BrtEndPCDSDTCSet\", */ T:-1 },\n\t/*::[*/0x00F3/*::]*/: { /* n:\"BrtBeginPCDCalcItems\", */ T:1 },\n\t/*::[*/0x00F4/*::]*/: { /* n:\"BrtEndPCDCalcItems\", */ T:-1 },\n\t/*::[*/0x00F5/*::]*/: { /* n:\"BrtBeginPCDCalcItem\", */ T:1 },\n\t/*::[*/0x00F6/*::]*/: { /* n:\"BrtEndPCDCalcItem\", */ T:-1 },\n\t/*::[*/0x00F7/*::]*/: { /* n:\"BrtBeginPRule\", */ T:1 },\n\t/*::[*/0x00F8/*::]*/: { /* n:\"BrtEndPRule\", */ T:-1 },\n\t/*::[*/0x00F9/*::]*/: { /* n:\"BrtBeginPRFilters\", */ T:1 },\n\t/*::[*/0x00FA/*::]*/: { /* n:\"BrtEndPRFilters\", */ T:-1 },\n\t/*::[*/0x00FB/*::]*/: { /* n:\"BrtBeginPRFilter\", */ T:1 },\n\t/*::[*/0x00FC/*::]*/: { /* n:\"BrtEndPRFilter\", */ T:-1 },\n\t/*::[*/0x00FD/*::]*/: { /* n:\"BrtBeginPNames\", */ T:1 },\n\t/*::[*/0x00FE/*::]*/: { /* n:\"BrtEndPNames\", */ T:-1 },\n\t/*::[*/0x00FF/*::]*/: { /* n:\"BrtBeginPName\", */ T:1 },\n\t/*::[*/0x0100/*::]*/: { /* n:\"BrtEndPName\", */ T:-1 },\n\t/*::[*/0x0101/*::]*/: { /* n:\"BrtBeginPNPairs\", */ T:1 },\n\t/*::[*/0x0102/*::]*/: { /* n:\"BrtEndPNPairs\", */ T:-1 },\n\t/*::[*/0x0103/*::]*/: { /* n:\"BrtBeginPNPair\", */ T:1 },\n\t/*::[*/0x0104/*::]*/: { /* n:\"BrtEndPNPair\", */ T:-1 },\n\t/*::[*/0x0105/*::]*/: { /* n:\"BrtBeginECWebProps\", */ T:1 },\n\t/*::[*/0x0106/*::]*/: { /* n:\"BrtEndECWebProps\", */ T:-1 },\n\t/*::[*/0x0107/*::]*/: { /* n:\"BrtBeginEcWpTables\", */ T:1 },\n\t/*::[*/0x0108/*::]*/: { /* n:\"BrtEndECWPTables\", */ T:-1 },\n\t/*::[*/0x0109/*::]*/: { /* n:\"BrtBeginECParams\", */ T:1 },\n\t/*::[*/0x010A/*::]*/: { /* n:\"BrtEndECParams\", */ T:-1 },\n\t/*::[*/0x010B/*::]*/: { /* n:\"BrtBeginECParam\", */ T:1 },\n\t/*::[*/0x010C/*::]*/: { /* n:\"BrtEndECParam\", */ T:-1 },\n\t/*::[*/0x010D/*::]*/: { /* n:\"BrtBeginPCDKPIs\", */ T:1 },\n\t/*::[*/0x010E/*::]*/: { /* n:\"BrtEndPCDKPIs\", */ T:-1 },\n\t/*::[*/0x010F/*::]*/: { /* n:\"BrtBeginPCDKPI\", */ T:1 },\n\t/*::[*/0x0110/*::]*/: { /* n:\"BrtEndPCDKPI\", */ T:-1 },\n\t/*::[*/0x0111/*::]*/: { /* n:\"BrtBeginDims\", */ T:1 },\n\t/*::[*/0x0112/*::]*/: { /* n:\"BrtEndDims\", */ T:-1 },\n\t/*::[*/0x0113/*::]*/: { /* n:\"BrtBeginDim\", */ T:1 },\n\t/*::[*/0x0114/*::]*/: { /* n:\"BrtEndDim\", */ T:-1 },\n\t/*::[*/0x0115/*::]*/: { /* n:\"BrtIndexPartEnd\" */ },\n\t/*::[*/0x0116/*::]*/: { /* n:\"BrtBeginStyleSheet\", */ T:1 },\n\t/*::[*/0x0117/*::]*/: { /* n:\"BrtEndStyleSheet\", */ T:-1 },\n\t/*::[*/0x0118/*::]*/: { /* n:\"BrtBeginSXView\", */ T:1 },\n\t/*::[*/0x0119/*::]*/: { /* n:\"BrtEndSXVI\", */ T:-1 },\n\t/*::[*/0x011A/*::]*/: { /* n:\"BrtBeginSXVI\", */ T:1 },\n\t/*::[*/0x011B/*::]*/: { /* n:\"BrtBeginSXVIs\", */ T:1 },\n\t/*::[*/0x011C/*::]*/: { /* n:\"BrtEndSXVIs\", */ T:-1 },\n\t/*::[*/0x011D/*::]*/: { /* n:\"BrtBeginSXVD\", */ T:1 },\n\t/*::[*/0x011E/*::]*/: { /* n:\"BrtEndSXVD\", */ T:-1 },\n\t/*::[*/0x011F/*::]*/: { /* n:\"BrtBeginSXVDs\", */ T:1 },\n\t/*::[*/0x0120/*::]*/: { /* n:\"BrtEndSXVDs\", */ T:-1 },\n\t/*::[*/0x0121/*::]*/: { /* n:\"BrtBeginSXPI\", */ T:1 },\n\t/*::[*/0x0122/*::]*/: { /* n:\"BrtEndSXPI\", */ T:-1 },\n\t/*::[*/0x0123/*::]*/: { /* n:\"BrtBeginSXPIs\", */ T:1 },\n\t/*::[*/0x0124/*::]*/: { /* n:\"BrtEndSXPIs\", */ T:-1 },\n\t/*::[*/0x0125/*::]*/: { /* n:\"BrtBeginSXDI\", */ T:1 },\n\t/*::[*/0x0126/*::]*/: { /* n:\"BrtEndSXDI\", */ T:-1 },\n\t/*::[*/0x0127/*::]*/: { /* n:\"BrtBeginSXDIs\", */ T:1 },\n\t/*::[*/0x0128/*::]*/: { /* n:\"BrtEndSXDIs\", */ T:-1 },\n\t/*::[*/0x0129/*::]*/: { /* n:\"BrtBeginSXLI\", */ T:1 },\n\t/*::[*/0x012A/*::]*/: { /* n:\"BrtEndSXLI\", */ T:-1 },\n\t/*::[*/0x012B/*::]*/: { /* n:\"BrtBeginSXLIRws\", */ T:1 },\n\t/*::[*/0x012C/*::]*/: { /* n:\"BrtEndSXLIRws\", */ T:-1 },\n\t/*::[*/0x012D/*::]*/: { /* n:\"BrtBeginSXLICols\", */ T:1 },\n\t/*::[*/0x012E/*::]*/: { /* n:\"BrtEndSXLICols\", */ T:-1 },\n\t/*::[*/0x012F/*::]*/: { /* n:\"BrtBeginSXFormat\", */ T:1 },\n\t/*::[*/0x0130/*::]*/: { /* n:\"BrtEndSXFormat\", */ T:-1 },\n\t/*::[*/0x0131/*::]*/: { /* n:\"BrtBeginSXFormats\", */ T:1 },\n\t/*::[*/0x0132/*::]*/: { /* n:\"BrtEndSxFormats\", */ T:-1 },\n\t/*::[*/0x0133/*::]*/: { /* n:\"BrtBeginSxSelect\", */ T:1 },\n\t/*::[*/0x0134/*::]*/: { /* n:\"BrtEndSxSelect\", */ T:-1 },\n\t/*::[*/0x0135/*::]*/: { /* n:\"BrtBeginISXVDRws\", */ T:1 },\n\t/*::[*/0x0136/*::]*/: { /* n:\"BrtEndISXVDRws\", */ T:-1 },\n\t/*::[*/0x0137/*::]*/: { /* n:\"BrtBeginISXVDCols\", */ T:1 },\n\t/*::[*/0x0138/*::]*/: { /* n:\"BrtEndISXVDCols\", */ T:-1 },\n\t/*::[*/0x0139/*::]*/: { /* n:\"BrtEndSXLocation\", */ T:-1 },\n\t/*::[*/0x013A/*::]*/: { /* n:\"BrtBeginSXLocation\", */ T:1 },\n\t/*::[*/0x013B/*::]*/: { /* n:\"BrtEndSXView\", */ T:-1 },\n\t/*::[*/0x013C/*::]*/: { /* n:\"BrtBeginSXTHs\", */ T:1 },\n\t/*::[*/0x013D/*::]*/: { /* n:\"BrtEndSXTHs\", */ T:-1 },\n\t/*::[*/0x013E/*::]*/: { /* n:\"BrtBeginSXTH\", */ T:1 },\n\t/*::[*/0x013F/*::]*/: { /* n:\"BrtEndSXTH\", */ T:-1 },\n\t/*::[*/0x0140/*::]*/: { /* n:\"BrtBeginISXTHRws\", */ T:1 },\n\t/*::[*/0x0141/*::]*/: { /* n:\"BrtEndISXTHRws\", */ T:-1 },\n\t/*::[*/0x0142/*::]*/: { /* n:\"BrtBeginISXTHCols\", */ T:1 },\n\t/*::[*/0x0143/*::]*/: { /* n:\"BrtEndISXTHCols\", */ T:-1 },\n\t/*::[*/0x0144/*::]*/: { /* n:\"BrtBeginSXTDMPS\", */ T:1 },\n\t/*::[*/0x0145/*::]*/: { /* n:\"BrtEndSXTDMPs\", */ T:-1 },\n\t/*::[*/0x0146/*::]*/: { /* n:\"BrtBeginSXTDMP\", */ T:1 },\n\t/*::[*/0x0147/*::]*/: { /* n:\"BrtEndSXTDMP\", */ T:-1 },\n\t/*::[*/0x0148/*::]*/: { /* n:\"BrtBeginSXTHItems\", */ T:1 },\n\t/*::[*/0x0149/*::]*/: { /* n:\"BrtEndSXTHItems\", */ T:-1 },\n\t/*::[*/0x014A/*::]*/: { /* n:\"BrtBeginSXTHItem\", */ T:1 },\n\t/*::[*/0x014B/*::]*/: { /* n:\"BrtEndSXTHItem\", */ T:-1 },\n\t/*::[*/0x014C/*::]*/: { /* n:\"BrtBeginMetadata\", */ T:1 },\n\t/*::[*/0x014D/*::]*/: { /* n:\"BrtEndMetadata\", */ T:-1 },\n\t/*::[*/0x014E/*::]*/: { /* n:\"BrtBeginEsmdtinfo\", */ T:1 },\n\t/*::[*/0x014F/*::]*/: { /* n:\"BrtMdtinfo\", */ f:parse_BrtMdtinfo },\n\t/*::[*/0x0150/*::]*/: { /* n:\"BrtEndEsmdtinfo\", */ T:-1 },\n\t/*::[*/0x0151/*::]*/: { /* n:\"BrtBeginEsmdb\", */ f:parse_BrtBeginEsmdb, T:1 },\n\t/*::[*/0x0152/*::]*/: { /* n:\"BrtEndEsmdb\", */ T:-1 },\n\t/*::[*/0x0153/*::]*/: { /* n:\"BrtBeginEsfmd\", */ T:1 },\n\t/*::[*/0x0154/*::]*/: { /* n:\"BrtEndEsfmd\", */ T:-1 },\n\t/*::[*/0x0155/*::]*/: { /* n:\"BrtBeginSingleCells\", */ T:1 },\n\t/*::[*/0x0156/*::]*/: { /* n:\"BrtEndSingleCells\", */ T:-1 },\n\t/*::[*/0x0157/*::]*/: { /* n:\"BrtBeginList\", */ T:1 },\n\t/*::[*/0x0158/*::]*/: { /* n:\"BrtEndList\", */ T:-1 },\n\t/*::[*/0x0159/*::]*/: { /* n:\"BrtBeginListCols\", */ T:1 },\n\t/*::[*/0x015A/*::]*/: { /* n:\"BrtEndListCols\", */ T:-1 },\n\t/*::[*/0x015B/*::]*/: { /* n:\"BrtBeginListCol\", */ T:1 },\n\t/*::[*/0x015C/*::]*/: { /* n:\"BrtEndListCol\", */ T:-1 },\n\t/*::[*/0x015D/*::]*/: { /* n:\"BrtBeginListXmlCPr\", */ T:1 },\n\t/*::[*/0x015E/*::]*/: { /* n:\"BrtEndListXmlCPr\", */ T:-1 },\n\t/*::[*/0x015F/*::]*/: { /* n:\"BrtListCCFmla\" */ },\n\t/*::[*/0x0160/*::]*/: { /* n:\"BrtListTrFmla\" */ },\n\t/*::[*/0x0161/*::]*/: { /* n:\"BrtBeginExternals\", */ T:1 },\n\t/*::[*/0x0162/*::]*/: { /* n:\"BrtEndExternals\", */ T:-1 },\n\t/*::[*/0x0163/*::]*/: { /* n:\"BrtSupBookSrc\", */ f:parse_RelID},\n\t/*::[*/0x0165/*::]*/: { /* n:\"BrtSupSelf\" */ },\n\t/*::[*/0x0166/*::]*/: { /* n:\"BrtSupSame\" */ },\n\t/*::[*/0x0167/*::]*/: { /* n:\"BrtSupTabs\" */ },\n\t/*::[*/0x0168/*::]*/: { /* n:\"BrtBeginSupBook\", */ T:1 },\n\t/*::[*/0x0169/*::]*/: { /* n:\"BrtPlaceholderName\" */ },\n\t/*::[*/0x016A/*::]*/: { /* n:\"BrtExternSheet\", */ f:parse_ExternSheet },\n\t/*::[*/0x016B/*::]*/: { /* n:\"BrtExternTableStart\" */ },\n\t/*::[*/0x016C/*::]*/: { /* n:\"BrtExternTableEnd\" */ },\n\t/*::[*/0x016E/*::]*/: { /* n:\"BrtExternRowHdr\" */ },\n\t/*::[*/0x016F/*::]*/: { /* n:\"BrtExternCellBlank\" */ },\n\t/*::[*/0x0170/*::]*/: { /* n:\"BrtExternCellReal\" */ },\n\t/*::[*/0x0171/*::]*/: { /* n:\"BrtExternCellBool\" */ },\n\t/*::[*/0x0172/*::]*/: { /* n:\"BrtExternCellError\" */ },\n\t/*::[*/0x0173/*::]*/: { /* n:\"BrtExternCellString\" */ },\n\t/*::[*/0x0174/*::]*/: { /* n:\"BrtBeginEsmdx\", */ T:1 },\n\t/*::[*/0x0175/*::]*/: { /* n:\"BrtEndEsmdx\", */ T:-1 },\n\t/*::[*/0x0176/*::]*/: { /* n:\"BrtBeginMdxSet\", */ T:1 },\n\t/*::[*/0x0177/*::]*/: { /* n:\"BrtEndMdxSet\", */ T:-1 },\n\t/*::[*/0x0178/*::]*/: { /* n:\"BrtBeginMdxMbrProp\", */ T:1 },\n\t/*::[*/0x0179/*::]*/: { /* n:\"BrtEndMdxMbrProp\", */ T:-1 },\n\t/*::[*/0x017A/*::]*/: { /* n:\"BrtBeginMdxKPI\", */ T:1 },\n\t/*::[*/0x017B/*::]*/: { /* n:\"BrtEndMdxKPI\", */ T:-1 },\n\t/*::[*/0x017C/*::]*/: { /* n:\"BrtBeginEsstr\", */ T:1 },\n\t/*::[*/0x017D/*::]*/: { /* n:\"BrtEndEsstr\", */ T:-1 },\n\t/*::[*/0x017E/*::]*/: { /* n:\"BrtBeginPRFItem\", */ T:1 },\n\t/*::[*/0x017F/*::]*/: { /* n:\"BrtEndPRFItem\", */ T:-1 },\n\t/*::[*/0x0180/*::]*/: { /* n:\"BrtBeginPivotCacheIDs\", */ T:1 },\n\t/*::[*/0x0181/*::]*/: { /* n:\"BrtEndPivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x0182/*::]*/: { /* n:\"BrtBeginPivotCacheID\", */ T:1 },\n\t/*::[*/0x0183/*::]*/: { /* n:\"BrtEndPivotCacheID\", */ T:-1 },\n\t/*::[*/0x0184/*::]*/: { /* n:\"BrtBeginISXVIs\", */ T:1 },\n\t/*::[*/0x0185/*::]*/: { /* n:\"BrtEndISXVIs\", */ T:-1 },\n\t/*::[*/0x0186/*::]*/: { /* n:\"BrtBeginColInfos\", */ T:1 },\n\t/*::[*/0x0187/*::]*/: { /* n:\"BrtEndColInfos\", */ T:-1 },\n\t/*::[*/0x0188/*::]*/: { /* n:\"BrtBeginRwBrk\", */ T:1 },\n\t/*::[*/0x0189/*::]*/: { /* n:\"BrtEndRwBrk\", */ T:-1 },\n\t/*::[*/0x018A/*::]*/: { /* n:\"BrtBeginColBrk\", */ T:1 },\n\t/*::[*/0x018B/*::]*/: { /* n:\"BrtEndColBrk\", */ T:-1 },\n\t/*::[*/0x018C/*::]*/: { /* n:\"BrtBrk\" */ },\n\t/*::[*/0x018D/*::]*/: { /* n:\"BrtUserBookView\" */ },\n\t/*::[*/0x018E/*::]*/: { /* n:\"BrtInfo\" */ },\n\t/*::[*/0x018F/*::]*/: { /* n:\"BrtCUsr\" */ },\n\t/*::[*/0x0190/*::]*/: { /* n:\"BrtUsr\" */ },\n\t/*::[*/0x0191/*::]*/: { /* n:\"BrtBeginUsers\", */ T:1 },\n\t/*::[*/0x0193/*::]*/: { /* n:\"BrtEOF\" */ },\n\t/*::[*/0x0194/*::]*/: { /* n:\"BrtUCR\" */ },\n\t/*::[*/0x0195/*::]*/: { /* n:\"BrtRRInsDel\" */ },\n\t/*::[*/0x0196/*::]*/: { /* n:\"BrtRREndInsDel\" */ },\n\t/*::[*/0x0197/*::]*/: { /* n:\"BrtRRMove\" */ },\n\t/*::[*/0x0198/*::]*/: { /* n:\"BrtRREndMove\" */ },\n\t/*::[*/0x0199/*::]*/: { /* n:\"BrtRRChgCell\" */ },\n\t/*::[*/0x019A/*::]*/: { /* n:\"BrtRREndChgCell\" */ },\n\t/*::[*/0x019B/*::]*/: { /* n:\"BrtRRHeader\" */ },\n\t/*::[*/0x019C/*::]*/: { /* n:\"BrtRRUserView\" */ },\n\t/*::[*/0x019D/*::]*/: { /* n:\"BrtRRRenSheet\" */ },\n\t/*::[*/0x019E/*::]*/: { /* n:\"BrtRRInsertSh\" */ },\n\t/*::[*/0x019F/*::]*/: { /* n:\"BrtRRDefName\" */ },\n\t/*::[*/0x01A0/*::]*/: { /* n:\"BrtRRNote\" */ },\n\t/*::[*/0x01A1/*::]*/: { /* n:\"BrtRRConflict\" */ },\n\t/*::[*/0x01A2/*::]*/: { /* n:\"BrtRRTQSIF\" */ },\n\t/*::[*/0x01A3/*::]*/: { /* n:\"BrtRRFormat\" */ },\n\t/*::[*/0x01A4/*::]*/: { /* n:\"BrtRREndFormat\" */ },\n\t/*::[*/0x01A5/*::]*/: { /* n:\"BrtRRAutoFmt\" */ },\n\t/*::[*/0x01A6/*::]*/: { /* n:\"BrtBeginUserShViews\", */ T:1 },\n\t/*::[*/0x01A7/*::]*/: { /* n:\"BrtBeginUserShView\", */ T:1 },\n\t/*::[*/0x01A8/*::]*/: { /* n:\"BrtEndUserShView\", */ T:-1 },\n\t/*::[*/0x01A9/*::]*/: { /* n:\"BrtEndUserShViews\", */ T:-1 },\n\t/*::[*/0x01AA/*::]*/: { /* n:\"BrtArrFmla\", */ f:parse_BrtArrFmla },\n\t/*::[*/0x01AB/*::]*/: { /* n:\"BrtShrFmla\", */ f:parse_BrtShrFmla },\n\t/*::[*/0x01AC/*::]*/: { /* n:\"BrtTable\" */ },\n\t/*::[*/0x01AD/*::]*/: { /* n:\"BrtBeginExtConnections\", */ T:1 },\n\t/*::[*/0x01AE/*::]*/: { /* n:\"BrtEndExtConnections\", */ T:-1 },\n\t/*::[*/0x01AF/*::]*/: { /* n:\"BrtBeginPCDCalcMems\", */ T:1 },\n\t/*::[*/0x01B0/*::]*/: { /* n:\"BrtEndPCDCalcMems\", */ T:-1 },\n\t/*::[*/0x01B1/*::]*/: { /* n:\"BrtBeginPCDCalcMem\", */ T:1 },\n\t/*::[*/0x01B2/*::]*/: { /* n:\"BrtEndPCDCalcMem\", */ T:-1 },\n\t/*::[*/0x01B3/*::]*/: { /* n:\"BrtBeginPCDHGLevels\", */ T:1 },\n\t/*::[*/0x01B4/*::]*/: { /* n:\"BrtEndPCDHGLevels\", */ T:-1 },\n\t/*::[*/0x01B5/*::]*/: { /* n:\"BrtBeginPCDHGLevel\", */ T:1 },\n\t/*::[*/0x01B6/*::]*/: { /* n:\"BrtEndPCDHGLevel\", */ T:-1 },\n\t/*::[*/0x01B7/*::]*/: { /* n:\"BrtBeginPCDHGLGroups\", */ T:1 },\n\t/*::[*/0x01B8/*::]*/: { /* n:\"BrtEndPCDHGLGroups\", */ T:-1 },\n\t/*::[*/0x01B9/*::]*/: { /* n:\"BrtBeginPCDHGLGroup\", */ T:1 },\n\t/*::[*/0x01BA/*::]*/: { /* n:\"BrtEndPCDHGLGroup\", */ T:-1 },\n\t/*::[*/0x01BB/*::]*/: { /* n:\"BrtBeginPCDHGLGMembers\", */ T:1 },\n\t/*::[*/0x01BC/*::]*/: { /* n:\"BrtEndPCDHGLGMembers\", */ T:-1 },\n\t/*::[*/0x01BD/*::]*/: { /* n:\"BrtBeginPCDHGLGMember\", */ T:1 },\n\t/*::[*/0x01BE/*::]*/: { /* n:\"BrtEndPCDHGLGMember\", */ T:-1 },\n\t/*::[*/0x01BF/*::]*/: { /* n:\"BrtBeginQSI\", */ T:1 },\n\t/*::[*/0x01C0/*::]*/: { /* n:\"BrtEndQSI\", */ T:-1 },\n\t/*::[*/0x01C1/*::]*/: { /* n:\"BrtBeginQSIR\", */ T:1 },\n\t/*::[*/0x01C2/*::]*/: { /* n:\"BrtEndQSIR\", */ T:-1 },\n\t/*::[*/0x01C3/*::]*/: { /* n:\"BrtBeginDeletedNames\", */ T:1 },\n\t/*::[*/0x01C4/*::]*/: { /* n:\"BrtEndDeletedNames\", */ T:-1 },\n\t/*::[*/0x01C5/*::]*/: { /* n:\"BrtBeginDeletedName\", */ T:1 },\n\t/*::[*/0x01C6/*::]*/: { /* n:\"BrtEndDeletedName\", */ T:-1 },\n\t/*::[*/0x01C7/*::]*/: { /* n:\"BrtBeginQSIFs\", */ T:1 },\n\t/*::[*/0x01C8/*::]*/: { /* n:\"BrtEndQSIFs\", */ T:-1 },\n\t/*::[*/0x01C9/*::]*/: { /* n:\"BrtBeginQSIF\", */ T:1 },\n\t/*::[*/0x01CA/*::]*/: { /* n:\"BrtEndQSIF\", */ T:-1 },\n\t/*::[*/0x01CB/*::]*/: { /* n:\"BrtBeginAutoSortScope\", */ T:1 },\n\t/*::[*/0x01CC/*::]*/: { /* n:\"BrtEndAutoSortScope\", */ T:-1 },\n\t/*::[*/0x01CD/*::]*/: { /* n:\"BrtBeginConditionalFormatting\", */ T:1 },\n\t/*::[*/0x01CE/*::]*/: { /* n:\"BrtEndConditionalFormatting\", */ T:-1 },\n\t/*::[*/0x01CF/*::]*/: { /* n:\"BrtBeginCFRule\", */ T:1 },\n\t/*::[*/0x01D0/*::]*/: { /* n:\"BrtEndCFRule\", */ T:-1 },\n\t/*::[*/0x01D1/*::]*/: { /* n:\"BrtBeginIconSet\", */ T:1 },\n\t/*::[*/0x01D2/*::]*/: { /* n:\"BrtEndIconSet\", */ T:-1 },\n\t/*::[*/0x01D3/*::]*/: { /* n:\"BrtBeginDatabar\", */ T:1 },\n\t/*::[*/0x01D4/*::]*/: { /* n:\"BrtEndDatabar\", */ T:-1 },\n\t/*::[*/0x01D5/*::]*/: { /* n:\"BrtBeginColorScale\", */ T:1 },\n\t/*::[*/0x01D6/*::]*/: { /* n:\"BrtEndColorScale\", */ T:-1 },\n\t/*::[*/0x01D7/*::]*/: { /* n:\"BrtCFVO\" */ },\n\t/*::[*/0x01D8/*::]*/: { /* n:\"BrtExternValueMeta\" */ },\n\t/*::[*/0x01D9/*::]*/: { /* n:\"BrtBeginColorPalette\", */ T:1 },\n\t/*::[*/0x01DA/*::]*/: { /* n:\"BrtEndColorPalette\", */ T:-1 },\n\t/*::[*/0x01DB/*::]*/: { /* n:\"BrtIndexedColor\" */ },\n\t/*::[*/0x01DC/*::]*/: { /* n:\"BrtMargins\", */ f:parse_BrtMargins },\n\t/*::[*/0x01DD/*::]*/: { /* n:\"BrtPrintOptions\" */ },\n\t/*::[*/0x01DE/*::]*/: { /* n:\"BrtPageSetup\" */ },\n\t/*::[*/0x01DF/*::]*/: { /* n:\"BrtBeginHeaderFooter\", */ T:1 },\n\t/*::[*/0x01E0/*::]*/: { /* n:\"BrtEndHeaderFooter\", */ T:-1 },\n\t/*::[*/0x01E1/*::]*/: { /* n:\"BrtBeginSXCrtFormat\", */ T:1 },\n\t/*::[*/0x01E2/*::]*/: { /* n:\"BrtEndSXCrtFormat\", */ T:-1 },\n\t/*::[*/0x01E3/*::]*/: { /* n:\"BrtBeginSXCrtFormats\", */ T:1 },\n\t/*::[*/0x01E4/*::]*/: { /* n:\"BrtEndSXCrtFormats\", */ T:-1 },\n\t/*::[*/0x01E5/*::]*/: { /* n:\"BrtWsFmtInfo\", */ f:parse_BrtWsFmtInfo },\n\t/*::[*/0x01E6/*::]*/: { /* n:\"BrtBeginMgs\", */ T:1 },\n\t/*::[*/0x01E7/*::]*/: { /* n:\"BrtEndMGs\", */ T:-1 },\n\t/*::[*/0x01E8/*::]*/: { /* n:\"BrtBeginMGMaps\", */ T:1 },\n\t/*::[*/0x01E9/*::]*/: { /* n:\"BrtEndMGMaps\", */ T:-1 },\n\t/*::[*/0x01EA/*::]*/: { /* n:\"BrtBeginMG\", */ T:1 },\n\t/*::[*/0x01EB/*::]*/: { /* n:\"BrtEndMG\", */ T:-1 },\n\t/*::[*/0x01EC/*::]*/: { /* n:\"BrtBeginMap\", */ T:1 },\n\t/*::[*/0x01ED/*::]*/: { /* n:\"BrtEndMap\", */ T:-1 },\n\t/*::[*/0x01EE/*::]*/: { /* n:\"BrtHLink\", */ f:parse_BrtHLink },\n\t/*::[*/0x01EF/*::]*/: { /* n:\"BrtBeginDCon\", */ T:1 },\n\t/*::[*/0x01F0/*::]*/: { /* n:\"BrtEndDCon\", */ T:-1 },\n\t/*::[*/0x01F1/*::]*/: { /* n:\"BrtBeginDRefs\", */ T:1 },\n\t/*::[*/0x01F2/*::]*/: { /* n:\"BrtEndDRefs\", */ T:-1 },\n\t/*::[*/0x01F3/*::]*/: { /* n:\"BrtDRef\" */ },\n\t/*::[*/0x01F4/*::]*/: { /* n:\"BrtBeginScenMan\", */ T:1 },\n\t/*::[*/0x01F5/*::]*/: { /* n:\"BrtEndScenMan\", */ T:-1 },\n\t/*::[*/0x01F6/*::]*/: { /* n:\"BrtBeginSct\", */ T:1 },\n\t/*::[*/0x01F7/*::]*/: { /* n:\"BrtEndSct\", */ T:-1 },\n\t/*::[*/0x01F8/*::]*/: { /* n:\"BrtSlc\" */ },\n\t/*::[*/0x01F9/*::]*/: { /* n:\"BrtBeginDXFs\", */ T:1 },\n\t/*::[*/0x01FA/*::]*/: { /* n:\"BrtEndDXFs\", */ T:-1 },\n\t/*::[*/0x01FB/*::]*/: { /* n:\"BrtDXF\" */ },\n\t/*::[*/0x01FC/*::]*/: { /* n:\"BrtBeginTableStyles\", */ T:1 },\n\t/*::[*/0x01FD/*::]*/: { /* n:\"BrtEndTableStyles\", */ T:-1 },\n\t/*::[*/0x01FE/*::]*/: { /* n:\"BrtBeginTableStyle\", */ T:1 },\n\t/*::[*/0x01FF/*::]*/: { /* n:\"BrtEndTableStyle\", */ T:-1 },\n\t/*::[*/0x0200/*::]*/: { /* n:\"BrtTableStyleElement\" */ },\n\t/*::[*/0x0201/*::]*/: { /* n:\"BrtTableStyleClient\" */ },\n\t/*::[*/0x0202/*::]*/: { /* n:\"BrtBeginVolDeps\", */ T:1 },\n\t/*::[*/0x0203/*::]*/: { /* n:\"BrtEndVolDeps\", */ T:-1 },\n\t/*::[*/0x0204/*::]*/: { /* n:\"BrtBeginVolType\", */ T:1 },\n\t/*::[*/0x0205/*::]*/: { /* n:\"BrtEndVolType\", */ T:-1 },\n\t/*::[*/0x0206/*::]*/: { /* n:\"BrtBeginVolMain\", */ T:1 },\n\t/*::[*/0x0207/*::]*/: { /* n:\"BrtEndVolMain\", */ T:-1 },\n\t/*::[*/0x0208/*::]*/: { /* n:\"BrtBeginVolTopic\", */ T:1 },\n\t/*::[*/0x0209/*::]*/: { /* n:\"BrtEndVolTopic\", */ T:-1 },\n\t/*::[*/0x020A/*::]*/: { /* n:\"BrtVolSubtopic\" */ },\n\t/*::[*/0x020B/*::]*/: { /* n:\"BrtVolRef\" */ },\n\t/*::[*/0x020C/*::]*/: { /* n:\"BrtVolNum\" */ },\n\t/*::[*/0x020D/*::]*/: { /* n:\"BrtVolErr\" */ },\n\t/*::[*/0x020E/*::]*/: { /* n:\"BrtVolStr\" */ },\n\t/*::[*/0x020F/*::]*/: { /* n:\"BrtVolBool\" */ },\n\t/*::[*/0x0210/*::]*/: { /* n:\"BrtBeginCalcChain$\", */ T:1 },\n\t/*::[*/0x0211/*::]*/: { /* n:\"BrtEndCalcChain$\", */ T:-1 },\n\t/*::[*/0x0212/*::]*/: { /* n:\"BrtBeginSortState\", */ T:1 },\n\t/*::[*/0x0213/*::]*/: { /* n:\"BrtEndSortState\", */ T:-1 },\n\t/*::[*/0x0214/*::]*/: { /* n:\"BrtBeginSortCond\", */ T:1 },\n\t/*::[*/0x0215/*::]*/: { /* n:\"BrtEndSortCond\", */ T:-1 },\n\t/*::[*/0x0216/*::]*/: { /* n:\"BrtBookProtection\" */ },\n\t/*::[*/0x0217/*::]*/: { /* n:\"BrtSheetProtection\" */ },\n\t/*::[*/0x0218/*::]*/: { /* n:\"BrtRangeProtection\" */ },\n\t/*::[*/0x0219/*::]*/: { /* n:\"BrtPhoneticInfo\" */ },\n\t/*::[*/0x021A/*::]*/: { /* n:\"BrtBeginECTxtWiz\", */ T:1 },\n\t/*::[*/0x021B/*::]*/: { /* n:\"BrtEndECTxtWiz\", */ T:-1 },\n\t/*::[*/0x021C/*::]*/: { /* n:\"BrtBeginECTWFldInfoLst\", */ T:1 },\n\t/*::[*/0x021D/*::]*/: { /* n:\"BrtEndECTWFldInfoLst\", */ T:-1 },\n\t/*::[*/0x021E/*::]*/: { /* n:\"BrtBeginECTwFldInfo\", */ T:1 },\n\t/*::[*/0x0224/*::]*/: { /* n:\"BrtFileSharing\" */ },\n\t/*::[*/0x0225/*::]*/: { /* n:\"BrtOleSize\" */ },\n\t/*::[*/0x0226/*::]*/: { /* n:\"BrtDrawing\", */ f:parse_RelID },\n\t/*::[*/0x0227/*::]*/: { /* n:\"BrtLegacyDrawing\" */ },\n\t/*::[*/0x0228/*::]*/: { /* n:\"BrtLegacyDrawingHF\" */ },\n\t/*::[*/0x0229/*::]*/: { /* n:\"BrtWebOpt\" */ },\n\t/*::[*/0x022A/*::]*/: { /* n:\"BrtBeginWebPubItems\", */ T:1 },\n\t/*::[*/0x022B/*::]*/: { /* n:\"BrtEndWebPubItems\", */ T:-1 },\n\t/*::[*/0x022C/*::]*/: { /* n:\"BrtBeginWebPubItem\", */ T:1 },\n\t/*::[*/0x022D/*::]*/: { /* n:\"BrtEndWebPubItem\", */ T:-1 },\n\t/*::[*/0x022E/*::]*/: { /* n:\"BrtBeginSXCondFmt\", */ T:1 },\n\t/*::[*/0x022F/*::]*/: { /* n:\"BrtEndSXCondFmt\", */ T:-1 },\n\t/*::[*/0x0230/*::]*/: { /* n:\"BrtBeginSXCondFmts\", */ T:1 },\n\t/*::[*/0x0231/*::]*/: { /* n:\"BrtEndSXCondFmts\", */ T:-1 },\n\t/*::[*/0x0232/*::]*/: { /* n:\"BrtBkHim\" */ },\n\t/*::[*/0x0234/*::]*/: { /* n:\"BrtColor\" */ },\n\t/*::[*/0x0235/*::]*/: { /* n:\"BrtBeginIndexedColors\", */ T:1 },\n\t/*::[*/0x0236/*::]*/: { /* n:\"BrtEndIndexedColors\", */ T:-1 },\n\t/*::[*/0x0239/*::]*/: { /* n:\"BrtBeginMRUColors\", */ T:1 },\n\t/*::[*/0x023A/*::]*/: { /* n:\"BrtEndMRUColors\", */ T:-1 },\n\t/*::[*/0x023C/*::]*/: { /* n:\"BrtMRUColor\" */ },\n\t/*::[*/0x023D/*::]*/: { /* n:\"BrtBeginDVals\", */ T:1 },\n\t/*::[*/0x023E/*::]*/: { /* n:\"BrtEndDVals\", */ T:-1 },\n\t/*::[*/0x0241/*::]*/: { /* n:\"BrtSupNameStart\" */ },\n\t/*::[*/0x0242/*::]*/: { /* n:\"BrtSupNameValueStart\" */ },\n\t/*::[*/0x0243/*::]*/: { /* n:\"BrtSupNameValueEnd\" */ },\n\t/*::[*/0x0244/*::]*/: { /* n:\"BrtSupNameNum\" */ },\n\t/*::[*/0x0245/*::]*/: { /* n:\"BrtSupNameErr\" */ },\n\t/*::[*/0x0246/*::]*/: { /* n:\"BrtSupNameSt\" */ },\n\t/*::[*/0x0247/*::]*/: { /* n:\"BrtSupNameNil\" */ },\n\t/*::[*/0x0248/*::]*/: { /* n:\"BrtSupNameBool\" */ },\n\t/*::[*/0x0249/*::]*/: { /* n:\"BrtSupNameFmla\" */ },\n\t/*::[*/0x024A/*::]*/: { /* n:\"BrtSupNameBits\" */ },\n\t/*::[*/0x024B/*::]*/: { /* n:\"BrtSupNameEnd\" */ },\n\t/*::[*/0x024C/*::]*/: { /* n:\"BrtEndSupBook\", */ T:-1 },\n\t/*::[*/0x024D/*::]*/: { /* n:\"BrtCellSmartTagProperty\" */ },\n\t/*::[*/0x024E/*::]*/: { /* n:\"BrtBeginCellSmartTag\", */ T:1 },\n\t/*::[*/0x024F/*::]*/: { /* n:\"BrtEndCellSmartTag\", */ T:-1 },\n\t/*::[*/0x0250/*::]*/: { /* n:\"BrtBeginCellSmartTags\", */ T:1 },\n\t/*::[*/0x0251/*::]*/: { /* n:\"BrtEndCellSmartTags\", */ T:-1 },\n\t/*::[*/0x0252/*::]*/: { /* n:\"BrtBeginSmartTags\", */ T:1 },\n\t/*::[*/0x0253/*::]*/: { /* n:\"BrtEndSmartTags\", */ T:-1 },\n\t/*::[*/0x0254/*::]*/: { /* n:\"BrtSmartTagType\" */ },\n\t/*::[*/0x0255/*::]*/: { /* n:\"BrtBeginSmartTagTypes\", */ T:1 },\n\t/*::[*/0x0256/*::]*/: { /* n:\"BrtEndSmartTagTypes\", */ T:-1 },\n\t/*::[*/0x0257/*::]*/: { /* n:\"BrtBeginSXFilters\", */ T:1 },\n\t/*::[*/0x0258/*::]*/: { /* n:\"BrtEndSXFilters\", */ T:-1 },\n\t/*::[*/0x0259/*::]*/: { /* n:\"BrtBeginSXFILTER\", */ T:1 },\n\t/*::[*/0x025A/*::]*/: { /* n:\"BrtEndSXFilter\", */ T:-1 },\n\t/*::[*/0x025B/*::]*/: { /* n:\"BrtBeginFills\", */ T:1 },\n\t/*::[*/0x025C/*::]*/: { /* n:\"BrtEndFills\", */ T:-1 },\n\t/*::[*/0x025D/*::]*/: { /* n:\"BrtBeginCellWatches\", */ T:1 },\n\t/*::[*/0x025E/*::]*/: { /* n:\"BrtEndCellWatches\", */ T:-1 },\n\t/*::[*/0x025F/*::]*/: { /* n:\"BrtCellWatch\" */ },\n\t/*::[*/0x0260/*::]*/: { /* n:\"BrtBeginCRErrs\", */ T:1 },\n\t/*::[*/0x0261/*::]*/: { /* n:\"BrtEndCRErrs\", */ T:-1 },\n\t/*::[*/0x0262/*::]*/: { /* n:\"BrtCrashRecErr\" */ },\n\t/*::[*/0x0263/*::]*/: { /* n:\"BrtBeginFonts\", */ T:1 },\n\t/*::[*/0x0264/*::]*/: { /* n:\"BrtEndFonts\", */ T:-1 },\n\t/*::[*/0x0265/*::]*/: { /* n:\"BrtBeginBorders\", */ T:1 },\n\t/*::[*/0x0266/*::]*/: { /* n:\"BrtEndBorders\", */ T:-1 },\n\t/*::[*/0x0267/*::]*/: { /* n:\"BrtBeginFmts\", */ T:1 },\n\t/*::[*/0x0268/*::]*/: { /* n:\"BrtEndFmts\", */ T:-1 },\n\t/*::[*/0x0269/*::]*/: { /* n:\"BrtBeginCellXFs\", */ T:1 },\n\t/*::[*/0x026A/*::]*/: { /* n:\"BrtEndCellXFs\", */ T:-1 },\n\t/*::[*/0x026B/*::]*/: { /* n:\"BrtBeginStyles\", */ T:1 },\n\t/*::[*/0x026C/*::]*/: { /* n:\"BrtEndStyles\", */ T:-1 },\n\t/*::[*/0x0271/*::]*/: { /* n:\"BrtBigName\" */ },\n\t/*::[*/0x0272/*::]*/: { /* n:\"BrtBeginCellStyleXFs\", */ T:1 },\n\t/*::[*/0x0273/*::]*/: { /* n:\"BrtEndCellStyleXFs\", */ T:-1 },\n\t/*::[*/0x0274/*::]*/: { /* n:\"BrtBeginComments\", */ T:1 },\n\t/*::[*/0x0275/*::]*/: { /* n:\"BrtEndComments\", */ T:-1 },\n\t/*::[*/0x0276/*::]*/: { /* n:\"BrtBeginCommentAuthors\", */ T:1 },\n\t/*::[*/0x0277/*::]*/: { /* n:\"BrtEndCommentAuthors\", */ T:-1 },\n\t/*::[*/0x0278/*::]*/: { /* n:\"BrtCommentAuthor\", */ f:parse_BrtCommentAuthor },\n\t/*::[*/0x0279/*::]*/: { /* n:\"BrtBeginCommentList\", */ T:1 },\n\t/*::[*/0x027A/*::]*/: { /* n:\"BrtEndCommentList\", */ T:-1 },\n\t/*::[*/0x027B/*::]*/: { /* n:\"BrtBeginComment\", */ T:1, f:parse_BrtBeginComment},\n\t/*::[*/0x027C/*::]*/: { /* n:\"BrtEndComment\", */ T:-1 },\n\t/*::[*/0x027D/*::]*/: { /* n:\"BrtCommentText\", */ f:parse_BrtCommentText },\n\t/*::[*/0x027E/*::]*/: { /* n:\"BrtBeginOleObjects\", */ T:1 },\n\t/*::[*/0x027F/*::]*/: { /* n:\"BrtOleObject\" */ },\n\t/*::[*/0x0280/*::]*/: { /* n:\"BrtEndOleObjects\", */ T:-1 },\n\t/*::[*/0x0281/*::]*/: { /* n:\"BrtBeginSxrules\", */ T:1 },\n\t/*::[*/0x0282/*::]*/: { /* n:\"BrtEndSxRules\", */ T:-1 },\n\t/*::[*/0x0283/*::]*/: { /* n:\"BrtBeginActiveXControls\", */ T:1 },\n\t/*::[*/0x0284/*::]*/: { /* n:\"BrtActiveX\" */ },\n\t/*::[*/0x0285/*::]*/: { /* n:\"BrtEndActiveXControls\", */ T:-1 },\n\t/*::[*/0x0286/*::]*/: { /* n:\"BrtBeginPCDSDTCEMembersSortBy\", */ T:1 },\n\t/*::[*/0x0288/*::]*/: { /* n:\"BrtBeginCellIgnoreECs\", */ T:1 },\n\t/*::[*/0x0289/*::]*/: { /* n:\"BrtCellIgnoreEC\" */ },\n\t/*::[*/0x028A/*::]*/: { /* n:\"BrtEndCellIgnoreECs\", */ T:-1 },\n\t/*::[*/0x028B/*::]*/: { /* n:\"BrtCsProp\", */ f:parse_BrtCsProp },\n\t/*::[*/0x028C/*::]*/: { /* n:\"BrtCsPageSetup\" */ },\n\t/*::[*/0x028D/*::]*/: { /* n:\"BrtBeginUserCsViews\", */ T:1 },\n\t/*::[*/0x028E/*::]*/: { /* n:\"BrtEndUserCsViews\", */ T:-1 },\n\t/*::[*/0x028F/*::]*/: { /* n:\"BrtBeginUserCsView\", */ T:1 },\n\t/*::[*/0x0290/*::]*/: { /* n:\"BrtEndUserCsView\", */ T:-1 },\n\t/*::[*/0x0291/*::]*/: { /* n:\"BrtBeginPcdSFCIEntries\", */ T:1 },\n\t/*::[*/0x0292/*::]*/: { /* n:\"BrtEndPCDSFCIEntries\", */ T:-1 },\n\t/*::[*/0x0293/*::]*/: { /* n:\"BrtPCDSFCIEntry\" */ },\n\t/*::[*/0x0294/*::]*/: { /* n:\"BrtBeginListParts\", */ T:1 },\n\t/*::[*/0x0295/*::]*/: { /* n:\"BrtListPart\" */ },\n\t/*::[*/0x0296/*::]*/: { /* n:\"BrtEndListParts\", */ T:-1 },\n\t/*::[*/0x0297/*::]*/: { /* n:\"BrtSheetCalcProp\" */ },\n\t/*::[*/0x0298/*::]*/: { /* n:\"BrtBeginFnGroup\", */ T:1 },\n\t/*::[*/0x0299/*::]*/: { /* n:\"BrtFnGroup\" */ },\n\t/*::[*/0x029A/*::]*/: { /* n:\"BrtEndFnGroup\", */ T:-1 },\n\t/*::[*/0x029B/*::]*/: { /* n:\"BrtSupAddin\" */ },\n\t/*::[*/0x029C/*::]*/: { /* n:\"BrtSXTDMPOrder\" */ },\n\t/*::[*/0x029D/*::]*/: { /* n:\"BrtCsProtection\" */ },\n\t/*::[*/0x029F/*::]*/: { /* n:\"BrtBeginWsSortMap\", */ T:1 },\n\t/*::[*/0x02A0/*::]*/: { /* n:\"BrtEndWsSortMap\", */ T:-1 },\n\t/*::[*/0x02A1/*::]*/: { /* n:\"BrtBeginRRSort\", */ T:1 },\n\t/*::[*/0x02A2/*::]*/: { /* n:\"BrtEndRRSort\", */ T:-1 },\n\t/*::[*/0x02A3/*::]*/: { /* n:\"BrtRRSortItem\" */ },\n\t/*::[*/0x02A4/*::]*/: { /* n:\"BrtFileSharingIso\" */ },\n\t/*::[*/0x02A5/*::]*/: { /* n:\"BrtBookProtectionIso\" */ },\n\t/*::[*/0x02A6/*::]*/: { /* n:\"BrtSheetProtectionIso\" */ },\n\t/*::[*/0x02A7/*::]*/: { /* n:\"BrtCsProtectionIso\" */ },\n\t/*::[*/0x02A8/*::]*/: { /* n:\"BrtRangeProtectionIso\" */ },\n\t/*::[*/0x02A9/*::]*/: { /* n:\"BrtDValList\" */ },\n\t/*::[*/0x0400/*::]*/: { /* n:\"BrtRwDescent\" */ },\n\t/*::[*/0x0401/*::]*/: { /* n:\"BrtKnownFonts\" */ },\n\t/*::[*/0x0402/*::]*/: { /* n:\"BrtBeginSXTupleSet\", */ T:1 },\n\t/*::[*/0x0403/*::]*/: { /* n:\"BrtEndSXTupleSet\", */ T:-1 },\n\t/*::[*/0x0404/*::]*/: { /* n:\"BrtBeginSXTupleSetHeader\", */ T:1 },\n\t/*::[*/0x0405/*::]*/: { /* n:\"BrtEndSXTupleSetHeader\", */ T:-1 },\n\t/*::[*/0x0406/*::]*/: { /* n:\"BrtSXTupleSetHeaderItem\" */ },\n\t/*::[*/0x0407/*::]*/: { /* n:\"BrtBeginSXTupleSetData\", */ T:1 },\n\t/*::[*/0x0408/*::]*/: { /* n:\"BrtEndSXTupleSetData\", */ T:-1 },\n\t/*::[*/0x0409/*::]*/: { /* n:\"BrtBeginSXTupleSetRow\", */ T:1 },\n\t/*::[*/0x040A/*::]*/: { /* n:\"BrtEndSXTupleSetRow\", */ T:-1 },\n\t/*::[*/0x040B/*::]*/: { /* n:\"BrtSXTupleSetRowItem\" */ },\n\t/*::[*/0x040C/*::]*/: { /* n:\"BrtNameExt\" */ },\n\t/*::[*/0x040D/*::]*/: { /* n:\"BrtPCDH14\" */ },\n\t/*::[*/0x040E/*::]*/: { /* n:\"BrtBeginPCDCalcMem14\", */ T:1 },\n\t/*::[*/0x040F/*::]*/: { /* n:\"BrtEndPCDCalcMem14\", */ T:-1 },\n\t/*::[*/0x0410/*::]*/: { /* n:\"BrtSXTH14\" */ },\n\t/*::[*/0x0411/*::]*/: { /* n:\"BrtBeginSparklineGroup\", */ T:1 },\n\t/*::[*/0x0412/*::]*/: { /* n:\"BrtEndSparklineGroup\", */ T:-1 },\n\t/*::[*/0x0413/*::]*/: { /* n:\"BrtSparkline\" */ },\n\t/*::[*/0x0414/*::]*/: { /* n:\"BrtSXDI14\" */ },\n\t/*::[*/0x0415/*::]*/: { /* n:\"BrtWsFmtInfoEx14\" */ },\n\t/*::[*/0x0416/*::]*/: { /* n:\"BrtBeginConditionalFormatting14\", */ T:1 },\n\t/*::[*/0x0417/*::]*/: { /* n:\"BrtEndConditionalFormatting14\", */ T:-1 },\n\t/*::[*/0x0418/*::]*/: { /* n:\"BrtBeginCFRule14\", */ T:1 },\n\t/*::[*/0x0419/*::]*/: { /* n:\"BrtEndCFRule14\", */ T:-1 },\n\t/*::[*/0x041A/*::]*/: { /* n:\"BrtCFVO14\" */ },\n\t/*::[*/0x041B/*::]*/: { /* n:\"BrtBeginDatabar14\", */ T:1 },\n\t/*::[*/0x041C/*::]*/: { /* n:\"BrtBeginIconSet14\", */ T:1 },\n\t/*::[*/0x041D/*::]*/: { /* n:\"BrtDVal14\", */ f: parse_BrtDVal14 },\n\t/*::[*/0x041E/*::]*/: { /* n:\"BrtBeginDVals14\", */ T:1 },\n\t/*::[*/0x041F/*::]*/: { /* n:\"BrtColor14\" */ },\n\t/*::[*/0x0420/*::]*/: { /* n:\"BrtBeginSparklines\", */ T:1 },\n\t/*::[*/0x0421/*::]*/: { /* n:\"BrtEndSparklines\", */ T:-1 },\n\t/*::[*/0x0422/*::]*/: { /* n:\"BrtBeginSparklineGroups\", */ T:1 },\n\t/*::[*/0x0423/*::]*/: { /* n:\"BrtEndSparklineGroups\", */ T:-1 },\n\t/*::[*/0x0425/*::]*/: { /* n:\"BrtSXVD14\" */ },\n\t/*::[*/0x0426/*::]*/: { /* n:\"BrtBeginSXView14\", */ T:1 },\n\t/*::[*/0x0427/*::]*/: { /* n:\"BrtEndSXView14\", */ T:-1 },\n\t/*::[*/0x0428/*::]*/: { /* n:\"BrtBeginSXView16\", */ T:1 },\n\t/*::[*/0x0429/*::]*/: { /* n:\"BrtEndSXView16\", */ T:-1 },\n\t/*::[*/0x042A/*::]*/: { /* n:\"BrtBeginPCD14\", */ T:1 },\n\t/*::[*/0x042B/*::]*/: { /* n:\"BrtEndPCD14\", */ T:-1 },\n\t/*::[*/0x042C/*::]*/: { /* n:\"BrtBeginExtConn14\", */ T:1 },\n\t/*::[*/0x042D/*::]*/: { /* n:\"BrtEndExtConn14\", */ T:-1 },\n\t/*::[*/0x042E/*::]*/: { /* n:\"BrtBeginSlicerCacheIDs\", */ T:1 },\n\t/*::[*/0x042F/*::]*/: { /* n:\"BrtEndSlicerCacheIDs\", */ T:-1 },\n\t/*::[*/0x0430/*::]*/: { /* n:\"BrtBeginSlicerCacheID\", */ T:1 },\n\t/*::[*/0x0431/*::]*/: { /* n:\"BrtEndSlicerCacheID\", */ T:-1 },\n\t/*::[*/0x0433/*::]*/: { /* n:\"BrtBeginSlicerCache\", */ T:1 },\n\t/*::[*/0x0434/*::]*/: { /* n:\"BrtEndSlicerCache\", */ T:-1 },\n\t/*::[*/0x0435/*::]*/: { /* n:\"BrtBeginSlicerCacheDef\", */ T:1 },\n\t/*::[*/0x0436/*::]*/: { /* n:\"BrtEndSlicerCacheDef\", */ T:-1 },\n\t/*::[*/0x0437/*::]*/: { /* n:\"BrtBeginSlicersEx\", */ T:1 },\n\t/*::[*/0x0438/*::]*/: { /* n:\"BrtEndSlicersEx\", */ T:-1 },\n\t/*::[*/0x0439/*::]*/: { /* n:\"BrtBeginSlicerEx\", */ T:1 },\n\t/*::[*/0x043A/*::]*/: { /* n:\"BrtEndSlicerEx\", */ T:-1 },\n\t/*::[*/0x043B/*::]*/: { /* n:\"BrtBeginSlicer\", */ T:1 },\n\t/*::[*/0x043C/*::]*/: { /* n:\"BrtEndSlicer\", */ T:-1 },\n\t/*::[*/0x043D/*::]*/: { /* n:\"BrtSlicerCachePivotTables\" */ },\n\t/*::[*/0x043E/*::]*/: { /* n:\"BrtBeginSlicerCacheOlapImpl\", */ T:1 },\n\t/*::[*/0x043F/*::]*/: { /* n:\"BrtEndSlicerCacheOlapImpl\", */ T:-1 },\n\t/*::[*/0x0440/*::]*/: { /* n:\"BrtBeginSlicerCacheLevelsData\", */ T:1 },\n\t/*::[*/0x0441/*::]*/: { /* n:\"BrtEndSlicerCacheLevelsData\", */ T:-1 },\n\t/*::[*/0x0442/*::]*/: { /* n:\"BrtBeginSlicerCacheLevelData\", */ T:1 },\n\t/*::[*/0x0443/*::]*/: { /* n:\"BrtEndSlicerCacheLevelData\", */ T:-1 },\n\t/*::[*/0x0444/*::]*/: { /* n:\"BrtBeginSlicerCacheSiRanges\", */ T:1 },\n\t/*::[*/0x0445/*::]*/: { /* n:\"BrtEndSlicerCacheSiRanges\", */ T:-1 },\n\t/*::[*/0x0446/*::]*/: { /* n:\"BrtBeginSlicerCacheSiRange\", */ T:1 },\n\t/*::[*/0x0447/*::]*/: { /* n:\"BrtEndSlicerCacheSiRange\", */ T:-1 },\n\t/*::[*/0x0448/*::]*/: { /* n:\"BrtSlicerCacheOlapItem\" */ },\n\t/*::[*/0x0449/*::]*/: { /* n:\"BrtBeginSlicerCacheSelections\", */ T:1 },\n\t/*::[*/0x044A/*::]*/: { /* n:\"BrtSlicerCacheSelection\" */ },\n\t/*::[*/0x044B/*::]*/: { /* n:\"BrtEndSlicerCacheSelections\", */ T:-1 },\n\t/*::[*/0x044C/*::]*/: { /* n:\"BrtBeginSlicerCacheNative\", */ T:1 },\n\t/*::[*/0x044D/*::]*/: { /* n:\"BrtEndSlicerCacheNative\", */ T:-1 },\n\t/*::[*/0x044E/*::]*/: { /* n:\"BrtSlicerCacheNativeItem\" */ },\n\t/*::[*/0x044F/*::]*/: { /* n:\"BrtRangeProtection14\" */ },\n\t/*::[*/0x0450/*::]*/: { /* n:\"BrtRangeProtectionIso14\" */ },\n\t/*::[*/0x0451/*::]*/: { /* n:\"BrtCellIgnoreEC14\" */ },\n\t/*::[*/0x0457/*::]*/: { /* n:\"BrtList14\" */ },\n\t/*::[*/0x0458/*::]*/: { /* n:\"BrtCFIcon\" */ },\n\t/*::[*/0x0459/*::]*/: { /* n:\"BrtBeginSlicerCachesPivotCacheIDs\", */ T:1 },\n\t/*::[*/0x045A/*::]*/: { /* n:\"BrtEndSlicerCachesPivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x045B/*::]*/: { /* n:\"BrtBeginSlicers\", */ T:1 },\n\t/*::[*/0x045C/*::]*/: { /* n:\"BrtEndSlicers\", */ T:-1 },\n\t/*::[*/0x045D/*::]*/: { /* n:\"BrtWbProp14\" */ },\n\t/*::[*/0x045E/*::]*/: { /* n:\"BrtBeginSXEdit\", */ T:1 },\n\t/*::[*/0x045F/*::]*/: { /* n:\"BrtEndSXEdit\", */ T:-1 },\n\t/*::[*/0x0460/*::]*/: { /* n:\"BrtBeginSXEdits\", */ T:1 },\n\t/*::[*/0x0461/*::]*/: { /* n:\"BrtEndSXEdits\", */ T:-1 },\n\t/*::[*/0x0462/*::]*/: { /* n:\"BrtBeginSXChange\", */ T:1 },\n\t/*::[*/0x0463/*::]*/: { /* n:\"BrtEndSXChange\", */ T:-1 },\n\t/*::[*/0x0464/*::]*/: { /* n:\"BrtBeginSXChanges\", */ T:1 },\n\t/*::[*/0x0465/*::]*/: { /* n:\"BrtEndSXChanges\", */ T:-1 },\n\t/*::[*/0x0466/*::]*/: { /* n:\"BrtSXTupleItems\" */ },\n\t/*::[*/0x0468/*::]*/: { /* n:\"BrtBeginSlicerStyle\", */ T:1 },\n\t/*::[*/0x0469/*::]*/: { /* n:\"BrtEndSlicerStyle\", */ T:-1 },\n\t/*::[*/0x046A/*::]*/: { /* n:\"BrtSlicerStyleElement\" */ },\n\t/*::[*/0x046B/*::]*/: { /* n:\"BrtBeginStyleSheetExt14\", */ T:1 },\n\t/*::[*/0x046C/*::]*/: { /* n:\"BrtEndStyleSheetExt14\", */ T:-1 },\n\t/*::[*/0x046D/*::]*/: { /* n:\"BrtBeginSlicerCachesPivotCacheID\", */ T:1 },\n\t/*::[*/0x046E/*::]*/: { /* n:\"BrtEndSlicerCachesPivotCacheID\", */ T:-1 },\n\t/*::[*/0x046F/*::]*/: { /* n:\"BrtBeginConditionalFormattings\", */ T:1 },\n\t/*::[*/0x0470/*::]*/: { /* n:\"BrtEndConditionalFormattings\", */ T:-1 },\n\t/*::[*/0x0471/*::]*/: { /* n:\"BrtBeginPCDCalcMemExt\", */ T:1 },\n\t/*::[*/0x0472/*::]*/: { /* n:\"BrtEndPCDCalcMemExt\", */ T:-1 },\n\t/*::[*/0x0473/*::]*/: { /* n:\"BrtBeginPCDCalcMemsExt\", */ T:1 },\n\t/*::[*/0x0474/*::]*/: { /* n:\"BrtEndPCDCalcMemsExt\", */ T:-1 },\n\t/*::[*/0x0475/*::]*/: { /* n:\"BrtPCDField14\" */ },\n\t/*::[*/0x0476/*::]*/: { /* n:\"BrtBeginSlicerStyles\", */ T:1 },\n\t/*::[*/0x0477/*::]*/: { /* n:\"BrtEndSlicerStyles\", */ T:-1 },\n\t/*::[*/0x0478/*::]*/: { /* n:\"BrtBeginSlicerStyleElements\", */ T:1 },\n\t/*::[*/0x0479/*::]*/: { /* n:\"BrtEndSlicerStyleElements\", */ T:-1 },\n\t/*::[*/0x047A/*::]*/: { /* n:\"BrtCFRuleExt\" */ },\n\t/*::[*/0x047B/*::]*/: { /* n:\"BrtBeginSXCondFmt14\", */ T:1 },\n\t/*::[*/0x047C/*::]*/: { /* n:\"BrtEndSXCondFmt14\", */ T:-1 },\n\t/*::[*/0x047D/*::]*/: { /* n:\"BrtBeginSXCondFmts14\", */ T:1 },\n\t/*::[*/0x047E/*::]*/: { /* n:\"BrtEndSXCondFmts14\", */ T:-1 },\n\t/*::[*/0x0480/*::]*/: { /* n:\"BrtBeginSortCond14\", */ T:1 },\n\t/*::[*/0x0481/*::]*/: { /* n:\"BrtEndSortCond14\", */ T:-1 },\n\t/*::[*/0x0482/*::]*/: { /* n:\"BrtEndDVals14\", */ T:-1 },\n\t/*::[*/0x0483/*::]*/: { /* n:\"BrtEndIconSet14\", */ T:-1 },\n\t/*::[*/0x0484/*::]*/: { /* n:\"BrtEndDatabar14\", */ T:-1 },\n\t/*::[*/0x0485/*::]*/: { /* n:\"BrtBeginColorScale14\", */ T:1 },\n\t/*::[*/0x0486/*::]*/: { /* n:\"BrtEndColorScale14\", */ T:-1 },\n\t/*::[*/0x0487/*::]*/: { /* n:\"BrtBeginSxrules14\", */ T:1 },\n\t/*::[*/0x0488/*::]*/: { /* n:\"BrtEndSxrules14\", */ T:-1 },\n\t/*::[*/0x0489/*::]*/: { /* n:\"BrtBeginPRule14\", */ T:1 },\n\t/*::[*/0x048A/*::]*/: { /* n:\"BrtEndPRule14\", */ T:-1 },\n\t/*::[*/0x048B/*::]*/: { /* n:\"BrtBeginPRFilters14\", */ T:1 },\n\t/*::[*/0x048C/*::]*/: { /* n:\"BrtEndPRFilters14\", */ T:-1 },\n\t/*::[*/0x048D/*::]*/: { /* n:\"BrtBeginPRFilter14\", */ T:1 },\n\t/*::[*/0x048E/*::]*/: { /* n:\"BrtEndPRFilter14\", */ T:-1 },\n\t/*::[*/0x048F/*::]*/: { /* n:\"BrtBeginPRFItem14\", */ T:1 },\n\t/*::[*/0x0490/*::]*/: { /* n:\"BrtEndPRFItem14\", */ T:-1 },\n\t/*::[*/0x0491/*::]*/: { /* n:\"BrtBeginCellIgnoreECs14\", */ T:1 },\n\t/*::[*/0x0492/*::]*/: { /* n:\"BrtEndCellIgnoreECs14\", */ T:-1 },\n\t/*::[*/0x0493/*::]*/: { /* n:\"BrtDxf14\" */ },\n\t/*::[*/0x0494/*::]*/: { /* n:\"BrtBeginDxF14s\", */ T:1 },\n\t/*::[*/0x0495/*::]*/: { /* n:\"BrtEndDxf14s\", */ T:-1 },\n\t/*::[*/0x0499/*::]*/: { /* n:\"BrtFilter14\" */ },\n\t/*::[*/0x049A/*::]*/: { /* n:\"BrtBeginCustomFilters14\", */ T:1 },\n\t/*::[*/0x049C/*::]*/: { /* n:\"BrtCustomFilter14\" */ },\n\t/*::[*/0x049D/*::]*/: { /* n:\"BrtIconFilter14\" */ },\n\t/*::[*/0x049E/*::]*/: { /* n:\"BrtPivotCacheConnectionName\" */ },\n\t/*::[*/0x0800/*::]*/: { /* n:\"BrtBeginDecoupledPivotCacheIDs\", */ T:1 },\n\t/*::[*/0x0801/*::]*/: { /* n:\"BrtEndDecoupledPivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x0802/*::]*/: { /* n:\"BrtDecoupledPivotCacheID\" */ },\n\t/*::[*/0x0803/*::]*/: { /* n:\"BrtBeginPivotTableRefs\", */ T:1 },\n\t/*::[*/0x0804/*::]*/: { /* n:\"BrtEndPivotTableRefs\", */ T:-1 },\n\t/*::[*/0x0805/*::]*/: { /* n:\"BrtPivotTableRef\" */ },\n\t/*::[*/0x0806/*::]*/: { /* n:\"BrtSlicerCacheBookPivotTables\" */ },\n\t/*::[*/0x0807/*::]*/: { /* n:\"BrtBeginSxvcells\", */ T:1 },\n\t/*::[*/0x0808/*::]*/: { /* n:\"BrtEndSxvcells\", */ T:-1 },\n\t/*::[*/0x0809/*::]*/: { /* n:\"BrtBeginSxRow\", */ T:1 },\n\t/*::[*/0x080A/*::]*/: { /* n:\"BrtEndSxRow\", */ T:-1 },\n\t/*::[*/0x080C/*::]*/: { /* n:\"BrtPcdCalcMem15\" */ },\n\t/*::[*/0x0813/*::]*/: { /* n:\"BrtQsi15\" */ },\n\t/*::[*/0x0814/*::]*/: { /* n:\"BrtBeginWebExtensions\", */ T:1 },\n\t/*::[*/0x0815/*::]*/: { /* n:\"BrtEndWebExtensions\", */ T:-1 },\n\t/*::[*/0x0816/*::]*/: { /* n:\"BrtWebExtension\" */ },\n\t/*::[*/0x0817/*::]*/: { /* n:\"BrtAbsPath15\" */ },\n\t/*::[*/0x0818/*::]*/: { /* n:\"BrtBeginPivotTableUISettings\", */ T:1 },\n\t/*::[*/0x0819/*::]*/: { /* n:\"BrtEndPivotTableUISettings\", */ T:-1 },\n\t/*::[*/0x081B/*::]*/: { /* n:\"BrtTableSlicerCacheIDs\" */ },\n\t/*::[*/0x081C/*::]*/: { /* n:\"BrtTableSlicerCacheID\" */ },\n\t/*::[*/0x081D/*::]*/: { /* n:\"BrtBeginTableSlicerCache\", */ T:1 },\n\t/*::[*/0x081E/*::]*/: { /* n:\"BrtEndTableSlicerCache\", */ T:-1 },\n\t/*::[*/0x081F/*::]*/: { /* n:\"BrtSxFilter15\" */ },\n\t/*::[*/0x0820/*::]*/: { /* n:\"BrtBeginTimelineCachePivotCacheIDs\", */ T:1 },\n\t/*::[*/0x0821/*::]*/: { /* n:\"BrtEndTimelineCachePivotCacheIDs\", */ T:-1 },\n\t/*::[*/0x0822/*::]*/: { /* n:\"BrtTimelineCachePivotCacheID\" */ },\n\t/*::[*/0x0823/*::]*/: { /* n:\"BrtBeginTimelineCacheIDs\", */ T:1 },\n\t/*::[*/0x0824/*::]*/: { /* n:\"BrtEndTimelineCacheIDs\", */ T:-1 },\n\t/*::[*/0x0825/*::]*/: { /* n:\"BrtBeginTimelineCacheID\", */ T:1 },\n\t/*::[*/0x0826/*::]*/: { /* n:\"BrtEndTimelineCacheID\", */ T:-1 },\n\t/*::[*/0x0827/*::]*/: { /* n:\"BrtBeginTimelinesEx\", */ T:1 },\n\t/*::[*/0x0828/*::]*/: { /* n:\"BrtEndTimelinesEx\", */ T:-1 },\n\t/*::[*/0x0829/*::]*/: { /* n:\"BrtBeginTimelineEx\", */ T:1 },\n\t/*::[*/0x082A/*::]*/: { /* n:\"BrtEndTimelineEx\", */ T:-1 },\n\t/*::[*/0x082B/*::]*/: { /* n:\"BrtWorkBookPr15\" */ },\n\t/*::[*/0x082C/*::]*/: { /* n:\"BrtPCDH15\" */ },\n\t/*::[*/0x082D/*::]*/: { /* n:\"BrtBeginTimelineStyle\", */ T:1 },\n\t/*::[*/0x082E/*::]*/: { /* n:\"BrtEndTimelineStyle\", */ T:-1 },\n\t/*::[*/0x082F/*::]*/: { /* n:\"BrtTimelineStyleElement\" */ },\n\t/*::[*/0x0830/*::]*/: { /* n:\"BrtBeginTimelineStylesheetExt15\", */ T:1 },\n\t/*::[*/0x0831/*::]*/: { /* n:\"BrtEndTimelineStylesheetExt15\", */ T:-1 },\n\t/*::[*/0x0832/*::]*/: { /* n:\"BrtBeginTimelineStyles\", */ T:1 },\n\t/*::[*/0x0833/*::]*/: { /* n:\"BrtEndTimelineStyles\", */ T:-1 },\n\t/*::[*/0x0834/*::]*/: { /* n:\"BrtBeginTimelineStyleElements\", */ T:1 },\n\t/*::[*/0x0835/*::]*/: { /* n:\"BrtEndTimelineStyleElements\", */ T:-1 },\n\t/*::[*/0x0836/*::]*/: { /* n:\"BrtDxf15\" */ },\n\t/*::[*/0x0837/*::]*/: { /* n:\"BrtBeginDxfs15\", */ T:1 },\n\t/*::[*/0x0838/*::]*/: { /* n:\"BrtEndDxfs15\", */ T:-1 },\n\t/*::[*/0x0839/*::]*/: { /* n:\"BrtSlicerCacheHideItemsWithNoData\" */ },\n\t/*::[*/0x083A/*::]*/: { /* n:\"BrtBeginItemUniqueNames\", */ T:1 },\n\t/*::[*/0x083B/*::]*/: { /* n:\"BrtEndItemUniqueNames\", */ T:-1 },\n\t/*::[*/0x083C/*::]*/: { /* n:\"BrtItemUniqueName\" */ },\n\t/*::[*/0x083D/*::]*/: { /* n:\"BrtBeginExtConn15\", */ T:1 },\n\t/*::[*/0x083E/*::]*/: { /* n:\"BrtEndExtConn15\", */ T:-1 },\n\t/*::[*/0x083F/*::]*/: { /* n:\"BrtBeginOledbPr15\", */ T:1 },\n\t/*::[*/0x0840/*::]*/: { /* n:\"BrtEndOledbPr15\", */ T:-1 },\n\t/*::[*/0x0841/*::]*/: { /* n:\"BrtBeginDataFeedPr15\", */ T:1 },\n\t/*::[*/0x0842/*::]*/: { /* n:\"BrtEndDataFeedPr15\", */ T:-1 },\n\t/*::[*/0x0843/*::]*/: { /* n:\"BrtTextPr15\" */ },\n\t/*::[*/0x0844/*::]*/: { /* n:\"BrtRangePr15\" */ },\n\t/*::[*/0x0845/*::]*/: { /* n:\"BrtDbCommand15\" */ },\n\t/*::[*/0x0846/*::]*/: { /* n:\"BrtBeginDbTables15\", */ T:1 },\n\t/*::[*/0x0847/*::]*/: { /* n:\"BrtEndDbTables15\", */ T:-1 },\n\t/*::[*/0x0848/*::]*/: { /* n:\"BrtDbTable15\" */ },\n\t/*::[*/0x0849/*::]*/: { /* n:\"BrtBeginDataModel\", */ T:1 },\n\t/*::[*/0x084A/*::]*/: { /* n:\"BrtEndDataModel\", */ T:-1 },\n\t/*::[*/0x084B/*::]*/: { /* n:\"BrtBeginModelTables\", */ T:1 },\n\t/*::[*/0x084C/*::]*/: { /* n:\"BrtEndModelTables\", */ T:-1 },\n\t/*::[*/0x084D/*::]*/: { /* n:\"BrtModelTable\" */ },\n\t/*::[*/0x084E/*::]*/: { /* n:\"BrtBeginModelRelationships\", */ T:1 },\n\t/*::[*/0x084F/*::]*/: { /* n:\"BrtEndModelRelationships\", */ T:-1 },\n\t/*::[*/0x0850/*::]*/: { /* n:\"BrtModelRelationship\" */ },\n\t/*::[*/0x0851/*::]*/: { /* n:\"BrtBeginECTxtWiz15\", */ T:1 },\n\t/*::[*/0x0852/*::]*/: { /* n:\"BrtEndECTxtWiz15\", */ T:-1 },\n\t/*::[*/0x0853/*::]*/: { /* n:\"BrtBeginECTWFldInfoLst15\", */ T:1 },\n\t/*::[*/0x0854/*::]*/: { /* n:\"BrtEndECTWFldInfoLst15\", */ T:-1 },\n\t/*::[*/0x0855/*::]*/: { /* n:\"BrtBeginECTWFldInfo15\", */ T:1 },\n\t/*::[*/0x0856/*::]*/: { /* n:\"BrtFieldListActiveItem\" */ },\n\t/*::[*/0x0857/*::]*/: { /* n:\"BrtPivotCacheIdVersion\" */ },\n\t/*::[*/0x0858/*::]*/: { /* n:\"BrtSXDI15\" */ },\n\t/*::[*/0x0859/*::]*/: { /* n:\"BrtBeginModelTimeGroupings\", */ T:1 },\n\t/*::[*/0x085A/*::]*/: { /* n:\"BrtEndModelTimeGroupings\", */ T:-1 },\n\t/*::[*/0x085B/*::]*/: { /* n:\"BrtBeginModelTimeGrouping\", */ T:1 },\n\t/*::[*/0x085C/*::]*/: { /* n:\"BrtEndModelTimeGrouping\", */ T:-1 },\n\t/*::[*/0x085D/*::]*/: { /* n:\"BrtModelTimeGroupingCalcCol\" */ },\n\t/*::[*/0x0C00/*::]*/: { /* n:\"BrtUid\" */ },\n\t/*::[*/0x0C01/*::]*/: { /* n:\"BrtRevisionPtr\" */ },\n\t/*::[*/0x1000/*::]*/: { /* n:\"BrtBeginDynamicArrayPr\", */ T:1 },\n\t/*::[*/0x1001/*::]*/: { /* n:\"BrtEndDynamicArrayPr\", */ T:-1 },\n\t/*::[*/0x138A/*::]*/: { /* n:\"BrtBeginRichValueBlock\", */ T:1 },\n\t/*::[*/0x138B/*::]*/: { /* n:\"BrtEndRichValueBlock\", */ T:-1 },\n\t/*::[*/0x13D9/*::]*/: { /* n:\"BrtBeginRichFilters\", */ T:1 },\n\t/*::[*/0x13DA/*::]*/: { /* n:\"BrtEndRichFilters\", */ T:-1 },\n\t/*::[*/0x13DB/*::]*/: { /* n:\"BrtRichFilter\" */ },\n\t/*::[*/0x13DC/*::]*/: { /* n:\"BrtBeginRichFilterColumn\", */ T:1 },\n\t/*::[*/0x13DD/*::]*/: { /* n:\"BrtEndRichFilterColumn\", */ T:-1 },\n\t/*::[*/0x13DE/*::]*/: { /* n:\"BrtBeginCustomRichFilters\", */ T:1 },\n\t/*::[*/0x13DF/*::]*/: { /* n:\"BrtEndCustomRichFilters\", */ T:-1 },\n\t/*::[*/0x13E0/*::]*/: { /* n:\"BrtCustomRichFilter\" */ },\n\t/*::[*/0x13E1/*::]*/: { /* n:\"BrtTop10RichFilter\" */ },\n\t/*::[*/0x13E2/*::]*/: { /* n:\"BrtDynamicRichFilter\" */ },\n\t/*::[*/0x13E4/*::]*/: { /* n:\"BrtBeginRichSortCondition\", */ T:1 },\n\t/*::[*/0x13E5/*::]*/: { /* n:\"BrtEndRichSortCondition\", */ T:-1 },\n\t/*::[*/0x13E6/*::]*/: { /* n:\"BrtRichFilterDateGroupItem\" */ },\n\t/*::[*/0x13E7/*::]*/: { /* n:\"BrtBeginCalcFeatures\", */ T:1 },\n\t/*::[*/0x13E8/*::]*/: { /* n:\"BrtEndCalcFeatures\", */ T:-1 },\n\t/*::[*/0x13E9/*::]*/: { /* n:\"BrtCalcFeature\" */ },\n\t/*::[*/0x13EB/*::]*/: { /* n:\"BrtExternalLinksPr\" */ },\n\t/*::[*/0xFFFF/*::]*/: { n:\"\" }\n};\n\n/* [MS-XLS] 2.3 Record Enumeration (and other sources) */\nvar XLSRecordEnum = {\n\t/* [MS-XLS] 2.3 Record Enumeration 2021-08-17 */\n\t/*::[*/0x0006/*::]*/: { /* n:\"Formula\", */ f:parse_Formula },\n\t/*::[*/0x000a/*::]*/: { /* n:\"EOF\", */ f:parsenoop2 },\n\t/*::[*/0x000c/*::]*/: { /* n:\"CalcCount\", */ f:parseuint16 }, //\n\t/*::[*/0x000d/*::]*/: { /* n:\"CalcMode\", */ f:parseuint16 }, //\n\t/*::[*/0x000e/*::]*/: { /* n:\"CalcPrecision\", */ f:parsebool }, //\n\t/*::[*/0x000f/*::]*/: { /* n:\"CalcRefMode\", */ f:parsebool }, //\n\t/*::[*/0x0010/*::]*/: { /* n:\"CalcDelta\", */ f:parse_Xnum }, //\n\t/*::[*/0x0011/*::]*/: { /* n:\"CalcIter\", */ f:parsebool }, //\n\t/*::[*/0x0012/*::]*/: { /* n:\"Protect\", */ f:parsebool },\n\t/*::[*/0x0013/*::]*/: { /* n:\"Password\", */ f:parseuint16 },\n\t/*::[*/0x0014/*::]*/: { /* n:\"Header\", */ f:parse_XLHeaderFooter },\n\t/*::[*/0x0015/*::]*/: { /* n:\"Footer\", */ f:parse_XLHeaderFooter },\n\t/*::[*/0x0017/*::]*/: { /* n:\"ExternSheet\", */ f:parse_ExternSheet },\n\t/*::[*/0x0018/*::]*/: { /* n:\"Lbl\", */ f:parse_Lbl },\n\t/*::[*/0x0019/*::]*/: { /* n:\"WinProtect\", */ f:parsebool },\n\t/*::[*/0x001a/*::]*/: { /* n:\"VerticalPageBreaks\", */ },\n\t/*::[*/0x001b/*::]*/: { /* n:\"HorizontalPageBreaks\", */ },\n\t/*::[*/0x001c/*::]*/: { /* n:\"Note\", */ f:parse_Note },\n\t/*::[*/0x001d/*::]*/: { /* n:\"Selection\", */ },\n\t/*::[*/0x0022/*::]*/: { /* n:\"Date1904\", */ f:parsebool },\n\t/*::[*/0x0023/*::]*/: { /* n:\"ExternName\", */ f:parse_ExternName },\n\t/*::[*/0x0026/*::]*/: { /* n:\"LeftMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x0027/*::]*/: { /* n:\"RightMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x0028/*::]*/: { /* n:\"TopMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x0029/*::]*/: { /* n:\"BottomMargin\", */ f:parse_Xnum }, // *\n\t/*::[*/0x002a/*::]*/: { /* n:\"PrintRowCol\", */ f:parsebool },\n\t/*::[*/0x002b/*::]*/: { /* n:\"PrintGrid\", */ f:parsebool },\n\t/*::[*/0x002f/*::]*/: { /* n:\"FilePass\", */ f:parse_FilePass },\n\t/*::[*/0x0031/*::]*/: { /* n:\"Font\", */ f:parse_Font },\n\t/*::[*/0x0033/*::]*/: { /* n:\"PrintSize\", */ f:parseuint16 },\n\t/*::[*/0x003c/*::]*/: { /* n:\"Continue\", */ },\n\t/*::[*/0x003d/*::]*/: { /* n:\"Window1\", */ f:parse_Window1 },\n\t/*::[*/0x0040/*::]*/: { /* n:\"Backup\", */ f:parsebool },\n\t/*::[*/0x0041/*::]*/: { /* n:\"Pane\", */ f:parse_Pane },\n\t/*::[*/0x0042/*::]*/: { /* n:\"CodePage\", */ f:parseuint16 },\n\t/*::[*/0x004d/*::]*/: { /* n:\"Pls\", */ },\n\t/*::[*/0x0050/*::]*/: { /* n:\"DCon\", */ },\n\t/*::[*/0x0051/*::]*/: { /* n:\"DConRef\", */ },\n\t/*::[*/0x0052/*::]*/: { /* n:\"DConName\", */ },\n\t/*::[*/0x0055/*::]*/: { /* n:\"DefColWidth\", */ f:parseuint16 },\n\t/*::[*/0x0059/*::]*/: { /* n:\"XCT\", */ },\n\t/*::[*/0x005a/*::]*/: { /* n:\"CRN\", */ },\n\t/*::[*/0x005b/*::]*/: { /* n:\"FileSharing\", */ },\n\t/*::[*/0x005c/*::]*/: { /* n:\"WriteAccess\", */ f:parse_WriteAccess },\n\t/*::[*/0x005d/*::]*/: { /* n:\"Obj\", */ f:parse_Obj },\n\t/*::[*/0x005e/*::]*/: { /* n:\"Uncalced\", */ },\n\t/*::[*/0x005f/*::]*/: { /* n:\"CalcSaveRecalc\", */ f:parsebool }, //\n\t/*::[*/0x0060/*::]*/: { /* n:\"Template\", */ },\n\t/*::[*/0x0061/*::]*/: { /* n:\"Intl\", */ },\n\t/*::[*/0x0063/*::]*/: { /* n:\"ObjProtect\", */ f:parsebool },\n\t/*::[*/0x007d/*::]*/: { /* n:\"ColInfo\", */ f:parse_ColInfo },\n\t/*::[*/0x0080/*::]*/: { /* n:\"Guts\", */ f:parse_Guts },\n\t/*::[*/0x0081/*::]*/: { /* n:\"WsBool\", */ f:parse_WsBool },\n\t/*::[*/0x0082/*::]*/: { /* n:\"GridSet\", */ f:parseuint16 },\n\t/*::[*/0x0083/*::]*/: { /* n:\"HCenter\", */ f:parsebool },\n\t/*::[*/0x0084/*::]*/: { /* n:\"VCenter\", */ f:parsebool },\n\t/*::[*/0x0085/*::]*/: { /* n:\"BoundSheet8\", */ f:parse_BoundSheet8 },\n\t/*::[*/0x0086/*::]*/: { /* n:\"WriteProtect\", */ },\n\t/*::[*/0x008c/*::]*/: { /* n:\"Country\", */ f:parse_Country },\n\t/*::[*/0x008d/*::]*/: { /* n:\"HideObj\", */ f:parseuint16 },\n\t/*::[*/0x0090/*::]*/: { /* n:\"Sort\", */ },\n\t/*::[*/0x0092/*::]*/: { /* n:\"Palette\", */ f:parse_Palette },\n\t/*::[*/0x0097/*::]*/: { /* n:\"Sync\", */ },\n\t/*::[*/0x0098/*::]*/: { /* n:\"LPr\", */ },\n\t/*::[*/0x0099/*::]*/: { /* n:\"DxGCol\", */ },\n\t/*::[*/0x009a/*::]*/: { /* n:\"FnGroupName\", */ },\n\t/*::[*/0x009b/*::]*/: { /* n:\"FilterMode\", */ },\n\t/*::[*/0x009c/*::]*/: { /* n:\"BuiltInFnGroupCount\", */ f:parseuint16 },\n\t/*::[*/0x009d/*::]*/: { /* n:\"AutoFilterInfo\", */ },\n\t/*::[*/0x009e/*::]*/: { /* n:\"AutoFilter\", */ },\n\t/*::[*/0x00a0/*::]*/: { /* n:\"Scl\", */ f:parse_Scl },\n\t/*::[*/0x00a1/*::]*/: { /* n:\"Setup\", */ f:parse_Setup },\n\t/*::[*/0x00ae/*::]*/: { /* n:\"ScenMan\", */ },\n\t/*::[*/0x00af/*::]*/: { /* n:\"SCENARIO\", */ },\n\t/*::[*/0x00b0/*::]*/: { /* n:\"SxView\", */ },\n\t/*::[*/0x00b1/*::]*/: { /* n:\"Sxvd\", */ },\n\t/*::[*/0x00b2/*::]*/: { /* n:\"SXVI\", */ },\n\t/*::[*/0x00b4/*::]*/: { /* n:\"SxIvd\", */ },\n\t/*::[*/0x00b5/*::]*/: { /* n:\"SXLI\", */ },\n\t/*::[*/0x00b6/*::]*/: { /* n:\"SXPI\", */ },\n\t/*::[*/0x00b8/*::]*/: { /* n:\"DocRoute\", */ },\n\t/*::[*/0x00b9/*::]*/: { /* n:\"RecipName\", */ },\n\t/*::[*/0x00bd/*::]*/: { /* n:\"MulRk\", */ f:parse_MulRk },\n\t/*::[*/0x00be/*::]*/: { /* n:\"MulBlank\", */ f:parse_MulBlank },\n\t/*::[*/0x00c1/*::]*/: { /* n:\"Mms\", */ f:parsenoop2 },\n\t/*::[*/0x00c5/*::]*/: { /* n:\"SXDI\", */ },\n\t/*::[*/0x00c6/*::]*/: { /* n:\"SXDB\", */ },\n\t/*::[*/0x00c7/*::]*/: { /* n:\"SXFDB\", */ },\n\t/*::[*/0x00c8/*::]*/: { /* n:\"SXDBB\", */ },\n\t/*::[*/0x00c9/*::]*/: { /* n:\"SXNum\", */ },\n\t/*::[*/0x00ca/*::]*/: { /* n:\"SxBool\", */ f:parsebool },\n\t/*::[*/0x00cb/*::]*/: { /* n:\"SxErr\", */ },\n\t/*::[*/0x00cc/*::]*/: { /* n:\"SXInt\", */ },\n\t/*::[*/0x00cd/*::]*/: { /* n:\"SXString\", */ },\n\t/*::[*/0x00ce/*::]*/: { /* n:\"SXDtr\", */ },\n\t/*::[*/0x00cf/*::]*/: { /* n:\"SxNil\", */ },\n\t/*::[*/0x00d0/*::]*/: { /* n:\"SXTbl\", */ },\n\t/*::[*/0x00d1/*::]*/: { /* n:\"SXTBRGIITM\", */ },\n\t/*::[*/0x00d2/*::]*/: { /* n:\"SxTbpg\", */ },\n\t/*::[*/0x00d3/*::]*/: { /* n:\"ObProj\", */ },\n\t/*::[*/0x00d5/*::]*/: { /* n:\"SXStreamID\", */ },\n\t/*::[*/0x00d7/*::]*/: { /* n:\"DBCell\", */ },\n\t/*::[*/0x00d8/*::]*/: { /* n:\"SXRng\", */ },\n\t/*::[*/0x00d9/*::]*/: { /* n:\"SxIsxoper\", */ },\n\t/*::[*/0x00da/*::]*/: { /* n:\"BookBool\", */ f:parseuint16 },\n\t/*::[*/0x00dc/*::]*/: { /* n:\"DbOrParamQry\", */ },\n\t/*::[*/0x00dd/*::]*/: { /* n:\"ScenarioProtect\", */ f:parsebool },\n\t/*::[*/0x00de/*::]*/: { /* n:\"OleObjectSize\", */ },\n\t/*::[*/0x00e0/*::]*/: { /* n:\"XF\", */ f:parse_XF },\n\t/*::[*/0x00e1/*::]*/: { /* n:\"InterfaceHdr\", */ f:parse_InterfaceHdr },\n\t/*::[*/0x00e2/*::]*/: { /* n:\"InterfaceEnd\", */ f:parsenoop2 },\n\t/*::[*/0x00e3/*::]*/: { /* n:\"SXVS\", */ },\n\t/*::[*/0x00e5/*::]*/: { /* n:\"MergeCells\", */ f:parse_MergeCells },\n\t/*::[*/0x00e9/*::]*/: { /* n:\"BkHim\", */ },\n\t/*::[*/0x00eb/*::]*/: { /* n:\"MsoDrawingGroup\", */ },\n\t/*::[*/0x00ec/*::]*/: { /* n:\"MsoDrawing\", */ },\n\t/*::[*/0x00ed/*::]*/: { /* n:\"MsoDrawingSelection\", */ },\n\t/*::[*/0x00ef/*::]*/: { /* n:\"PhoneticInfo\", */ },\n\t/*::[*/0x00f0/*::]*/: { /* n:\"SxRule\", */ },\n\t/*::[*/0x00f1/*::]*/: { /* n:\"SXEx\", */ },\n\t/*::[*/0x00f2/*::]*/: { /* n:\"SxFilt\", */ },\n\t/*::[*/0x00f4/*::]*/: { /* n:\"SxDXF\", */ },\n\t/*::[*/0x00f5/*::]*/: { /* n:\"SxItm\", */ },\n\t/*::[*/0x00f6/*::]*/: { /* n:\"SxName\", */ },\n\t/*::[*/0x00f7/*::]*/: { /* n:\"SxSelect\", */ },\n\t/*::[*/0x00f8/*::]*/: { /* n:\"SXPair\", */ },\n\t/*::[*/0x00f9/*::]*/: { /* n:\"SxFmla\", */ },\n\t/*::[*/0x00fb/*::]*/: { /* n:\"SxFormat\", */ },\n\t/*::[*/0x00fc/*::]*/: { /* n:\"SST\", */ f:parse_SST },\n\t/*::[*/0x00fd/*::]*/: { /* n:\"LabelSst\", */ f:parse_LabelSst },\n\t/*::[*/0x00ff/*::]*/: { /* n:\"ExtSST\", */ f:parse_ExtSST },\n\t/*::[*/0x0100/*::]*/: { /* n:\"SXVDEx\", */ },\n\t/*::[*/0x0103/*::]*/: { /* n:\"SXFormula\", */ },\n\t/*::[*/0x0122/*::]*/: { /* n:\"SXDBEx\", */ },\n\t/*::[*/0x0137/*::]*/: { /* n:\"RRDInsDel\", */ },\n\t/*::[*/0x0138/*::]*/: { /* n:\"RRDHead\", */ },\n\t/*::[*/0x013b/*::]*/: { /* n:\"RRDChgCell\", */ },\n\t/*::[*/0x013d/*::]*/: { /* n:\"RRTabId\", */ f:parseuint16a },\n\t/*::[*/0x013e/*::]*/: { /* n:\"RRDRenSheet\", */ },\n\t/*::[*/0x013f/*::]*/: { /* n:\"RRSort\", */ },\n\t/*::[*/0x0140/*::]*/: { /* n:\"RRDMove\", */ },\n\t/*::[*/0x014a/*::]*/: { /* n:\"RRFormat\", */ },\n\t/*::[*/0x014b/*::]*/: { /* n:\"RRAutoFmt\", */ },\n\t/*::[*/0x014d/*::]*/: { /* n:\"RRInsertSh\", */ },\n\t/*::[*/0x014e/*::]*/: { /* n:\"RRDMoveBegin\", */ },\n\t/*::[*/0x014f/*::]*/: { /* n:\"RRDMoveEnd\", */ },\n\t/*::[*/0x0150/*::]*/: { /* n:\"RRDInsDelBegin\", */ },\n\t/*::[*/0x0151/*::]*/: { /* n:\"RRDInsDelEnd\", */ },\n\t/*::[*/0x0152/*::]*/: { /* n:\"RRDConflict\", */ },\n\t/*::[*/0x0153/*::]*/: { /* n:\"RRDDefName\", */ },\n\t/*::[*/0x0154/*::]*/: { /* n:\"RRDRstEtxp\", */ },\n\t/*::[*/0x015f/*::]*/: { /* n:\"LRng\", */ },\n\t/*::[*/0x0160/*::]*/: { /* n:\"UsesELFs\", */ f:parsebool },\n\t/*::[*/0x0161/*::]*/: { /* n:\"DSF\", */ f:parsenoop2 },\n\t/*::[*/0x0191/*::]*/: { /* n:\"CUsr\", */ },\n\t/*::[*/0x0192/*::]*/: { /* n:\"CbUsr\", */ },\n\t/*::[*/0x0193/*::]*/: { /* n:\"UsrInfo\", */ },\n\t/*::[*/0x0194/*::]*/: { /* n:\"UsrExcl\", */ },\n\t/*::[*/0x0195/*::]*/: { /* n:\"FileLock\", */ },\n\t/*::[*/0x0196/*::]*/: { /* n:\"RRDInfo\", */ },\n\t/*::[*/0x0197/*::]*/: { /* n:\"BCUsrs\", */ },\n\t/*::[*/0x0198/*::]*/: { /* n:\"UsrChk\", */ },\n\t/*::[*/0x01a9/*::]*/: { /* n:\"UserBView\", */ },\n\t/*::[*/0x01aa/*::]*/: { /* n:\"UserSViewBegin\", */ },\n\t/*::[*/0x01ab/*::]*/: { /* n:\"UserSViewEnd\", */ },\n\t/*::[*/0x01ac/*::]*/: { /* n:\"RRDUserView\", */ },\n\t/*::[*/0x01ad/*::]*/: { /* n:\"Qsi\", */ },\n\t/*::[*/0x01ae/*::]*/: { /* n:\"SupBook\", */ f:parse_SupBook },\n\t/*::[*/0x01af/*::]*/: { /* n:\"Prot4Rev\", */ f:parsebool },\n\t/*::[*/0x01b0/*::]*/: { /* n:\"CondFmt\", */ },\n\t/*::[*/0x01b1/*::]*/: { /* n:\"CF\", */ },\n\t/*::[*/0x01b2/*::]*/: { /* n:\"DVal\", */ },\n\t/*::[*/0x01b5/*::]*/: { /* n:\"DConBin\", */ },\n\t/*::[*/0x01b6/*::]*/: { /* n:\"TxO\", */ f:parse_TxO },\n\t/*::[*/0x01b7/*::]*/: { /* n:\"RefreshAll\", */ f:parsebool }, //\n\t/*::[*/0x01b8/*::]*/: { /* n:\"HLink\", */ f:parse_HLink },\n\t/*::[*/0x01b9/*::]*/: { /* n:\"Lel\", */ },\n\t/*::[*/0x01ba/*::]*/: { /* n:\"CodeName\", */ f:parse_XLUnicodeString },\n\t/*::[*/0x01bb/*::]*/: { /* n:\"SXFDBType\", */ },\n\t/*::[*/0x01bc/*::]*/: { /* n:\"Prot4RevPass\", */ f:parseuint16 },\n\t/*::[*/0x01bd/*::]*/: { /* n:\"ObNoMacros\", */ },\n\t/*::[*/0x01be/*::]*/: { /* n:\"Dv\", */ },\n\t/*::[*/0x01c0/*::]*/: { /* n:\"Excel9File\", */ f:parsenoop2 },\n\t/*::[*/0x01c1/*::]*/: { /* n:\"RecalcId\", */ f:parse_RecalcId, r:2},\n\t/*::[*/0x01c2/*::]*/: { /* n:\"EntExU2\", */ f:parsenoop2 },\n\t/*::[*/0x0200/*::]*/: { /* n:\"Dimensions\", */ f:parse_Dimensions },\n\t/*::[*/0x0201/*::]*/: { /* n:\"Blank\", */ f:parse_Blank },\n\t/*::[*/0x0203/*::]*/: { /* n:\"Number\", */ f:parse_Number },\n\t/*::[*/0x0204/*::]*/: { /* n:\"Label\", */ f:parse_Label },\n\t/*::[*/0x0205/*::]*/: { /* n:\"BoolErr\", */ f:parse_BoolErr },\n\t/*::[*/0x0207/*::]*/: { /* n:\"String\", */ f:parse_String },\n\t/*::[*/0x0208/*::]*/: { /* n:\"Row\", */ f:parse_Row },\n\t/*::[*/0x020b/*::]*/: { /* n:\"Index\", */ },\n\t/*::[*/0x0221/*::]*/: { /* n:\"Array\", */ f:parse_Array },\n\t/*::[*/0x0225/*::]*/: { /* n:\"DefaultRowHeight\", */ f:parse_DefaultRowHeight },\n\t/*::[*/0x0236/*::]*/: { /* n:\"Table\", */ },\n\t/*::[*/0x023e/*::]*/: { /* n:\"Window2\", */ f:parse_Window2 },\n\t/*::[*/0x027e/*::]*/: { /* n:\"RK\", */ f:parse_RK },\n\t/*::[*/0x0293/*::]*/: { /* n:\"Style\", */ },\n\t/*::[*/0x0418/*::]*/: { /* n:\"BigName\", */ },\n\t/*::[*/0x041e/*::]*/: { /* n:\"Format\", */ f:parse_Format },\n\t/*::[*/0x043c/*::]*/: { /* n:\"ContinueBigName\", */ },\n\t/*::[*/0x04bc/*::]*/: { /* n:\"ShrFmla\", */ f:parse_ShrFmla },\n\t/*::[*/0x0800/*::]*/: { /* n:\"HLinkTooltip\", */ f:parse_HLinkTooltip },\n\t/*::[*/0x0801/*::]*/: { /* n:\"WebPub\", */ },\n\t/*::[*/0x0802/*::]*/: { /* n:\"QsiSXTag\", */ },\n\t/*::[*/0x0803/*::]*/: { /* n:\"DBQueryExt\", */ },\n\t/*::[*/0x0804/*::]*/: { /* n:\"ExtString\", */ },\n\t/*::[*/0x0805/*::]*/: { /* n:\"TxtQry\", */ },\n\t/*::[*/0x0806/*::]*/: { /* n:\"Qsir\", */ },\n\t/*::[*/0x0807/*::]*/: { /* n:\"Qsif\", */ },\n\t/*::[*/0x0808/*::]*/: { /* n:\"RRDTQSIF\", */ },\n\t/*::[*/0x0809/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x080a/*::]*/: { /* n:\"OleDbConn\", */ },\n\t/*::[*/0x080b/*::]*/: { /* n:\"WOpt\", */ },\n\t/*::[*/0x080c/*::]*/: { /* n:\"SXViewEx\", */ },\n\t/*::[*/0x080d/*::]*/: { /* n:\"SXTH\", */ },\n\t/*::[*/0x080e/*::]*/: { /* n:\"SXPIEx\", */ },\n\t/*::[*/0x080f/*::]*/: { /* n:\"SXVDTEx\", */ },\n\t/*::[*/0x0810/*::]*/: { /* n:\"SXViewEx9\", */ },\n\t/*::[*/0x0812/*::]*/: { /* n:\"ContinueFrt\", */ },\n\t/*::[*/0x0813/*::]*/: { /* n:\"RealTimeData\", */ },\n\t/*::[*/0x0850/*::]*/: { /* n:\"ChartFrtInfo\", */ },\n\t/*::[*/0x0851/*::]*/: { /* n:\"FrtWrapper\", */ },\n\t/*::[*/0x0852/*::]*/: { /* n:\"StartBlock\", */ },\n\t/*::[*/0x0853/*::]*/: { /* n:\"EndBlock\", */ },\n\t/*::[*/0x0854/*::]*/: { /* n:\"StartObject\", */ },\n\t/*::[*/0x0855/*::]*/: { /* n:\"EndObject\", */ },\n\t/*::[*/0x0856/*::]*/: { /* n:\"CatLab\", */ },\n\t/*::[*/0x0857/*::]*/: { /* n:\"YMult\", */ },\n\t/*::[*/0x0858/*::]*/: { /* n:\"SXViewLink\", */ },\n\t/*::[*/0x0859/*::]*/: { /* n:\"PivotChartBits\", */ },\n\t/*::[*/0x085a/*::]*/: { /* n:\"FrtFontList\", */ },\n\t/*::[*/0x0862/*::]*/: { /* n:\"SheetExt\", */ },\n\t/*::[*/0x0863/*::]*/: { /* n:\"BookExt\", */ r:12},\n\t/*::[*/0x0864/*::]*/: { /* n:\"SXAddl\", */ },\n\t/*::[*/0x0865/*::]*/: { /* n:\"CrErr\", */ },\n\t/*::[*/0x0866/*::]*/: { /* n:\"HFPicture\", */ },\n\t/*::[*/0x0867/*::]*/: { /* n:\"FeatHdr\", */ f:parsenoop2 },\n\t/*::[*/0x0868/*::]*/: { /* n:\"Feat\", */ },\n\t/*::[*/0x086a/*::]*/: { /* n:\"DataLabExt\", */ },\n\t/*::[*/0x086b/*::]*/: { /* n:\"DataLabExtContents\", */ },\n\t/*::[*/0x086c/*::]*/: { /* n:\"CellWatch\", */ },\n\t/*::[*/0x0871/*::]*/: { /* n:\"FeatHdr11\", */ },\n\t/*::[*/0x0872/*::]*/: { /* n:\"Feature11\", */ },\n\t/*::[*/0x0874/*::]*/: { /* n:\"DropDownObjIds\", */ },\n\t/*::[*/0x0875/*::]*/: { /* n:\"ContinueFrt11\", */ },\n\t/*::[*/0x0876/*::]*/: { /* n:\"DConn\", */ },\n\t/*::[*/0x0877/*::]*/: { /* n:\"List12\", */ },\n\t/*::[*/0x0878/*::]*/: { /* n:\"Feature12\", */ },\n\t/*::[*/0x0879/*::]*/: { /* n:\"CondFmt12\", */ },\n\t/*::[*/0x087a/*::]*/: { /* n:\"CF12\", */ },\n\t/*::[*/0x087b/*::]*/: { /* n:\"CFEx\", */ },\n\t/*::[*/0x087c/*::]*/: { /* n:\"XFCRC\", */ f:parse_XFCRC, r:12 },\n\t/*::[*/0x087d/*::]*/: { /* n:\"XFExt\", */ f:parse_XFExt, r:12 },\n\t/*::[*/0x087e/*::]*/: { /* n:\"AutoFilter12\", */ },\n\t/*::[*/0x087f/*::]*/: { /* n:\"ContinueFrt12\", */ },\n\t/*::[*/0x0884/*::]*/: { /* n:\"MDTInfo\", */ },\n\t/*::[*/0x0885/*::]*/: { /* n:\"MDXStr\", */ },\n\t/*::[*/0x0886/*::]*/: { /* n:\"MDXTuple\", */ },\n\t/*::[*/0x0887/*::]*/: { /* n:\"MDXSet\", */ },\n\t/*::[*/0x0888/*::]*/: { /* n:\"MDXProp\", */ },\n\t/*::[*/0x0889/*::]*/: { /* n:\"MDXKPI\", */ },\n\t/*::[*/0x088a/*::]*/: { /* n:\"MDB\", */ },\n\t/*::[*/0x088b/*::]*/: { /* n:\"PLV\", */ },\n\t/*::[*/0x088c/*::]*/: { /* n:\"Compat12\", */ f:parsebool, r:12 },\n\t/*::[*/0x088d/*::]*/: { /* n:\"DXF\", */ },\n\t/*::[*/0x088e/*::]*/: { /* n:\"TableStyles\", */ r:12 },\n\t/*::[*/0x088f/*::]*/: { /* n:\"TableStyle\", */ },\n\t/*::[*/0x0890/*::]*/: { /* n:\"TableStyleElement\", */ },\n\t/*::[*/0x0892/*::]*/: { /* n:\"StyleExt\", */ },\n\t/*::[*/0x0893/*::]*/: { /* n:\"NamePublish\", */ },\n\t/*::[*/0x0894/*::]*/: { /* n:\"NameCmt\", */ f:parse_NameCmt, r:12 },\n\t/*::[*/0x0895/*::]*/: { /* n:\"SortData\", */ },\n\t/*::[*/0x0896/*::]*/: { /* n:\"Theme\", */ f:parse_Theme, r:12 },\n\t/*::[*/0x0897/*::]*/: { /* n:\"GUIDTypeLib\", */ },\n\t/*::[*/0x0898/*::]*/: { /* n:\"FnGrp12\", */ },\n\t/*::[*/0x0899/*::]*/: { /* n:\"NameFnGrp12\", */ },\n\t/*::[*/0x089a/*::]*/: { /* n:\"MTRSettings\", */ f:parse_MTRSettings, r:12 },\n\t/*::[*/0x089b/*::]*/: { /* n:\"CompressPictures\", */ f:parsenoop2 },\n\t/*::[*/0x089c/*::]*/: { /* n:\"HeaderFooter\", */ },\n\t/*::[*/0x089d/*::]*/: { /* n:\"CrtLayout12\", */ },\n\t/*::[*/0x089e/*::]*/: { /* n:\"CrtMlFrt\", */ },\n\t/*::[*/0x089f/*::]*/: { /* n:\"CrtMlFrtContinue\", */ },\n\t/*::[*/0x08a3/*::]*/: { /* n:\"ForceFullCalculation\", */ f:parse_ForceFullCalculation },\n\t/*::[*/0x08a4/*::]*/: { /* n:\"ShapePropsStream\", */ },\n\t/*::[*/0x08a5/*::]*/: { /* n:\"TextPropsStream\", */ },\n\t/*::[*/0x08a6/*::]*/: { /* n:\"RichTextStream\", */ },\n\t/*::[*/0x08a7/*::]*/: { /* n:\"CrtLayout12A\", */ },\n\t/*::[*/0x1001/*::]*/: { /* n:\"Units\", */ },\n\t/*::[*/0x1002/*::]*/: { /* n:\"Chart\", */ },\n\t/*::[*/0x1003/*::]*/: { /* n:\"Series\", */ },\n\t/*::[*/0x1006/*::]*/: { /* n:\"DataFormat\", */ },\n\t/*::[*/0x1007/*::]*/: { /* n:\"LineFormat\", */ },\n\t/*::[*/0x1009/*::]*/: { /* n:\"MarkerFormat\", */ },\n\t/*::[*/0x100a/*::]*/: { /* n:\"AreaFormat\", */ },\n\t/*::[*/0x100b/*::]*/: { /* n:\"PieFormat\", */ },\n\t/*::[*/0x100c/*::]*/: { /* n:\"AttachedLabel\", */ },\n\t/*::[*/0x100d/*::]*/: { /* n:\"SeriesText\", */ },\n\t/*::[*/0x1014/*::]*/: { /* n:\"ChartFormat\", */ },\n\t/*::[*/0x1015/*::]*/: { /* n:\"Legend\", */ },\n\t/*::[*/0x1016/*::]*/: { /* n:\"SeriesList\", */ },\n\t/*::[*/0x1017/*::]*/: { /* n:\"Bar\", */ },\n\t/*::[*/0x1018/*::]*/: { /* n:\"Line\", */ },\n\t/*::[*/0x1019/*::]*/: { /* n:\"Pie\", */ },\n\t/*::[*/0x101a/*::]*/: { /* n:\"Area\", */ },\n\t/*::[*/0x101b/*::]*/: { /* n:\"Scatter\", */ },\n\t/*::[*/0x101c/*::]*/: { /* n:\"CrtLine\", */ },\n\t/*::[*/0x101d/*::]*/: { /* n:\"Axis\", */ },\n\t/*::[*/0x101e/*::]*/: { /* n:\"Tick\", */ },\n\t/*::[*/0x101f/*::]*/: { /* n:\"ValueRange\", */ },\n\t/*::[*/0x1020/*::]*/: { /* n:\"CatSerRange\", */ },\n\t/*::[*/0x1021/*::]*/: { /* n:\"AxisLine\", */ },\n\t/*::[*/0x1022/*::]*/: { /* n:\"CrtLink\", */ },\n\t/*::[*/0x1024/*::]*/: { /* n:\"DefaultText\", */ },\n\t/*::[*/0x1025/*::]*/: { /* n:\"Text\", */ },\n\t/*::[*/0x1026/*::]*/: { /* n:\"FontX\", */ f:parseuint16 },\n\t/*::[*/0x1027/*::]*/: { /* n:\"ObjectLink\", */ },\n\t/*::[*/0x1032/*::]*/: { /* n:\"Frame\", */ },\n\t/*::[*/0x1033/*::]*/: { /* n:\"Begin\", */ },\n\t/*::[*/0x1034/*::]*/: { /* n:\"End\", */ },\n\t/*::[*/0x1035/*::]*/: { /* n:\"PlotArea\", */ },\n\t/*::[*/0x103a/*::]*/: { /* n:\"Chart3d\", */ },\n\t/*::[*/0x103c/*::]*/: { /* n:\"PicF\", */ },\n\t/*::[*/0x103d/*::]*/: { /* n:\"DropBar\", */ },\n\t/*::[*/0x103e/*::]*/: { /* n:\"Radar\", */ },\n\t/*::[*/0x103f/*::]*/: { /* n:\"Surf\", */ },\n\t/*::[*/0x1040/*::]*/: { /* n:\"RadarArea\", */ },\n\t/*::[*/0x1041/*::]*/: { /* n:\"AxisParent\", */ },\n\t/*::[*/0x1043/*::]*/: { /* n:\"LegendException\", */ },\n\t/*::[*/0x1044/*::]*/: { /* n:\"ShtProps\", */ f:parse_ShtProps },\n\t/*::[*/0x1045/*::]*/: { /* n:\"SerToCrt\", */ },\n\t/*::[*/0x1046/*::]*/: { /* n:\"AxesUsed\", */ },\n\t/*::[*/0x1048/*::]*/: { /* n:\"SBaseRef\", */ },\n\t/*::[*/0x104a/*::]*/: { /* n:\"SerParent\", */ },\n\t/*::[*/0x104b/*::]*/: { /* n:\"SerAuxTrend\", */ },\n\t/*::[*/0x104e/*::]*/: { /* n:\"IFmtRecord\", */ },\n\t/*::[*/0x104f/*::]*/: { /* n:\"Pos\", */ },\n\t/*::[*/0x1050/*::]*/: { /* n:\"AlRuns\", */ },\n\t/*::[*/0x1051/*::]*/: { /* n:\"BRAI\", */ },\n\t/*::[*/0x105b/*::]*/: { /* n:\"SerAuxErrBar\", */ },\n\t/*::[*/0x105c/*::]*/: { /* n:\"ClrtClient\", */ f:parse_ClrtClient },\n\t/*::[*/0x105d/*::]*/: { /* n:\"SerFmt\", */ },\n\t/*::[*/0x105f/*::]*/: { /* n:\"Chart3DBarShape\", */ },\n\t/*::[*/0x1060/*::]*/: { /* n:\"Fbi\", */ },\n\t/*::[*/0x1061/*::]*/: { /* n:\"BopPop\", */ },\n\t/*::[*/0x1062/*::]*/: { /* n:\"AxcExt\", */ },\n\t/*::[*/0x1063/*::]*/: { /* n:\"Dat\", */ },\n\t/*::[*/0x1064/*::]*/: { /* n:\"PlotGrowth\", */ },\n\t/*::[*/0x1065/*::]*/: { /* n:\"SIIndex\", */ },\n\t/*::[*/0x1066/*::]*/: { /* n:\"GelFrame\", */ },\n\t/*::[*/0x1067/*::]*/: { /* n:\"BopPopCustom\", */ },\n\t/*::[*/0x1068/*::]*/: { /* n:\"Fbi2\", */ },\n\n\t/*::[*/0x0000/*::]*/: { /* n:\"Dimensions\", */ f:parse_Dimensions },\n\t/*::[*/0x0001/*::]*/: { /* n:\"BIFF2BLANK\", */ },\n\t/*::[*/0x0002/*::]*/: { /* n:\"BIFF2INT\", */ f:parse_BIFF2INT },\n\t/*::[*/0x0003/*::]*/: { /* n:\"BIFF2NUM\", */ f:parse_BIFF2NUM },\n\t/*::[*/0x0004/*::]*/: { /* n:\"BIFF2STR\", */ f:parse_BIFF2STR },\n\t/*::[*/0x0005/*::]*/: { /* n:\"BoolErr\", */ f:parse_BoolErr },\n\t/*::[*/0x0007/*::]*/: { /* n:\"String\", */ f:parse_BIFF2STRING },\n\t/*::[*/0x0008/*::]*/: { /* n:\"BIFF2ROW\", */ },\n\t/*::[*/0x0009/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x000b/*::]*/: { /* n:\"Index\", */ },\n\t/*::[*/0x0016/*::]*/: { /* n:\"ExternCount\", */ f:parseuint16 },\n\t/*::[*/0x001e/*::]*/: { /* n:\"BIFF2FORMAT\", */ f:parse_BIFF2Format },\n\t/*::[*/0x001f/*::]*/: { /* n:\"BIFF2FMTCNT\", */ }, /* 16-bit cnt of BIFF2FORMAT records */\n\t/*::[*/0x0020/*::]*/: { /* n:\"BIFF2COLINFO\", */ },\n\t/*::[*/0x0021/*::]*/: { /* n:\"Array\", */ f:parse_Array },\n\t/*::[*/0x0024/*::]*/: { /* n:\"COLWIDTH\", */ },\n\t/*::[*/0x0025/*::]*/: { /* n:\"DefaultRowHeight\", */ f:parse_DefaultRowHeight },\n\t// 0x2c ??\n\t// 0x2d ??\n\t// 0x2e ??\n\t// 0x30 FONTCOUNT: number of fonts\n\t/*::[*/0x0032/*::]*/: { /* n:\"BIFF2FONTXTRA\", */ f:parse_BIFF2FONTXTRA },\n\t// 0x35: INFOOPTS\n\t// 0x36: TABLE (BIFF2 only)\n\t// 0x37: TABLE2 (BIFF2 only)\n\t// 0x38: WNDESK\n\t// 0x39 ??\n\t// 0x3a: BEGINPREF\n\t// 0x3b: ENDPREF\n\t/*::[*/0x003e/*::]*/: { /* n:\"BIFF2WINDOW2\", */ },\n\t// 0x3f ??\n\t// 0x46: SHOWSCROLL\n\t// 0x47: SHOWFORMULA\n\t// 0x48: STATUSBAR\n\t// 0x49: SHORTMENUS\n\t// 0x4A:\n\t// 0x4B:\n\t// 0x4C:\n\t// 0x4E:\n\t// 0x4F:\n\t// 0x58: TOOLBAR (BIFF3)\n\n\t/* - - - */\n\t/*::[*/0x0034/*::]*/: { /* n:\"DDEObjName\", */ },\n\t/*::[*/0x0043/*::]*/: { /* n:\"BIFF2XF\", */ },\n\t/*::[*/0x0044/*::]*/: { /* n:\"BIFF2XFINDEX\", */ f:parseuint16 },\n\t/*::[*/0x0045/*::]*/: { /* n:\"BIFF2FONTCLR\", */ },\n\t/*::[*/0x0056/*::]*/: { /* n:\"BIFF4FMTCNT\", */ }, /* 16-bit cnt, similar to BIFF2 */\n\t/*::[*/0x007e/*::]*/: { /* n:\"RK\", */ }, /* Not necessarily same as 0x027e */\n\t/*::[*/0x007f/*::]*/: { /* n:\"ImData\", */ f:parse_ImData },\n\t/*::[*/0x0087/*::]*/: { /* n:\"Addin\", */ },\n\t/*::[*/0x0088/*::]*/: { /* n:\"Edg\", */ },\n\t/*::[*/0x0089/*::]*/: { /* n:\"Pub\", */ },\n\t// 0x8A\n\t// 0x8B LH: alternate menu key flag (BIFF3/4)\n\t// 0x8E\n\t// 0x8F\n\t/*::[*/0x0091/*::]*/: { /* n:\"Sub\", */ },\n\t// 0x93 STYLE\n\t/*::[*/0x0094/*::]*/: { /* n:\"LHRecord\", */ },\n\t/*::[*/0x0095/*::]*/: { /* n:\"LHNGraph\", */ },\n\t/*::[*/0x0096/*::]*/: { /* n:\"Sound\", */ },\n\t// 0xA2 FNPROTO: function prototypes (BIFF4)\n\t// 0xA3\n\t// 0xA8\n\t/*::[*/0x00a9/*::]*/: { /* n:\"CoordList\", */ },\n\t/*::[*/0x00ab/*::]*/: { /* n:\"GCW\", */ },\n\t/*::[*/0x00bc/*::]*/: { /* n:\"ShrFmla\", */ }, /* Not necessarily same as 0x04bc */\n\t/*::[*/0x00bf/*::]*/: { /* n:\"ToolbarHdr\", */ },\n\t/*::[*/0x00c0/*::]*/: { /* n:\"ToolbarEnd\", */ },\n\t/*::[*/0x00c2/*::]*/: { /* n:\"AddMenu\", */ },\n\t/*::[*/0x00c3/*::]*/: { /* n:\"DelMenu\", */ },\n\t/*::[*/0x00d6/*::]*/: { /* n:\"RString\", */ f:parse_RString },\n\t/*::[*/0x00df/*::]*/: { /* n:\"UDDesc\", */ },\n\t/*::[*/0x00ea/*::]*/: { /* n:\"TabIdConf\", */ },\n\t/*::[*/0x0162/*::]*/: { /* n:\"XL5Modify\", */ },\n\t/*::[*/0x01a5/*::]*/: { /* n:\"FileSharing2\", */ },\n\t/*::[*/0x0206/*::]*/: { /* n:\"Formula\", */ f:parse_Formula },\n\t/*::[*/0x0209/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x0218/*::]*/: { /* n:\"Lbl\", */ f:parse_Lbl },\n\t/*::[*/0x0223/*::]*/: { /* n:\"ExternName\", */ f:parse_ExternName },\n\t/*::[*/0x0231/*::]*/: { /* n:\"Font\", */ },\n\t/*::[*/0x0243/*::]*/: { /* n:\"BIFF3XF\", */ },\n\t/*::[*/0x0406/*::]*/: { /* n:\"Formula\", */ f:parse_Formula },\n\t/*::[*/0x0409/*::]*/: { /* n:\"BOF\", */ f:parse_BOF },\n\t/*::[*/0x0443/*::]*/: { /* n:\"BIFF4XF\", */ },\n\t/*::[*/0x086d/*::]*/: { /* n:\"FeatInfo\", */ },\n\t/*::[*/0x0873/*::]*/: { /* n:\"FeatInfo11\", */ },\n\t/*::[*/0x0881/*::]*/: { /* n:\"SXAddl12\", */ },\n\t/*::[*/0x08c0/*::]*/: { /* n:\"AutoWebPub\", */ },\n\t/*::[*/0x08c1/*::]*/: { /* n:\"ListObj\", */ },\n\t/*::[*/0x08c2/*::]*/: { /* n:\"ListField\", */ },\n\t/*::[*/0x08c3/*::]*/: { /* n:\"ListDV\", */ },\n\t/*::[*/0x08c4/*::]*/: { /* n:\"ListCondFmt\", */ },\n\t/*::[*/0x08c5/*::]*/: { /* n:\"ListCF\", */ },\n\t/*::[*/0x08c6/*::]*/: { /* n:\"FMQry\", */ },\n\t/*::[*/0x08c7/*::]*/: { /* n:\"FMSQry\", */ },\n\t/*::[*/0x08c8/*::]*/: { /* n:\"PLV\", */ },\n\t/*::[*/0x08c9/*::]*/: { /* n:\"LnExt\", */ },\n\t/*::[*/0x08ca/*::]*/: { /* n:\"MkrExt\", */ },\n\t/*::[*/0x08cb/*::]*/: { /* n:\"CrtCoopt\", */ },\n\t/*::[*/0x08d6/*::]*/: { /* n:\"FRTArchId$\", */ r:12 },\n\n\t/*::[*/0x7262/*::]*/: {}\n};\n\nfunction write_biff_rec(ba/*:BufArray*/, type/*:number*/, payload, length/*:?number*/)/*:void*/ {\n\tvar t/*:number*/ = type;\n\tif(isNaN(t)) return;\n\tvar len = length || (payload||[]).length || 0;\n\tvar o = ba.next(4);\n\to.write_shift(2, t);\n\to.write_shift(2, len);\n\tif(/*:: len != null &&*/len > 0 && is_buf(payload)) ba.push(payload);\n}\n\nfunction write_biff_continue(ba/*:BufArray*/, type/*:number*/, payload, length/*:?number*/)/*:void*/ {\n\tvar len = length || (payload||[]).length || 0;\n\tif(len <= 8224) return write_biff_rec(ba, type, payload, len);\n\tvar t = type;\n\tif(isNaN(t)) return;\n\tvar parts = payload.parts || [], sidx = 0;\n\tvar i = 0, w = 0;\n\twhile(w + (parts[sidx] || 8224) <= 8224) { w+= (parts[sidx] || 8224); sidx++; }\n\tvar o = ba.next(4);\n\to.write_shift(2, t);\n\to.write_shift(2, w);\n\tba.push(payload.slice(i, i + w));\n\ti += w;\n\twhile(i < len) {\n\t\to = ba.next(4);\n\t\to.write_shift(2, 0x3c); // TODO: figure out correct continue type\n\t\tw = 0;\n\t\twhile(w + (parts[sidx] || 8224) <= 8224) { w+= (parts[sidx] || 8224); sidx++; }\n\t\to.write_shift(2, w);\n\t\tba.push(payload.slice(i, i+w)); i+= w;\n\t}\n}\n\nfunction write_BIFF2Cell(out, r/*:number*/, c/*:number*/) {\n\tif(!out) out = new_buf(7);\n\tout.write_shift(2, r);\n\tout.write_shift(2, c);\n\tout.write_shift(2, 0);\n\tout.write_shift(1, 0);\n\treturn out;\n}\n\nfunction write_BIFF2BERR(r/*:number*/, c/*:number*/, val, t/*:?string*/) {\n\tvar out = new_buf(9);\n\twrite_BIFF2Cell(out, r, c);\n\twrite_Bes(val, t || 'b', out);\n\treturn out;\n}\n\n/* TODO: codepage, large strings */\nfunction write_BIFF2LABEL(r/*:number*/, c/*:number*/, val) {\n\tvar out = new_buf(8 + 2*val.length);\n\twrite_BIFF2Cell(out, r, c);\n\tout.write_shift(1, val.length);\n\tout.write_shift(val.length, val, 'sbcs');\n\treturn out.l < out.length ? out.slice(0, out.l) : out;\n}\n\nfunction write_ws_biff2_cell(ba/*:BufArray*/, cell/*:Cell*/, R/*:number*/, C/*:number*//*::, opts*/) {\n\tif(cell.v != null) switch(cell.t) {\n\t\tcase 'd': case 'n':\n\t\t\tvar v = cell.t == 'd' ? datenum(parseDate(cell.v)) : cell.v;\n\t\t\tif((v == (v|0)) && (v >= 0) && (v < 65536))\n\t\t\t\twrite_biff_rec(ba, 0x0002, write_BIFF2INT(R, C, v));\n\t\t\telse\n\t\t\t\twrite_biff_rec(ba, 0x0003, write_BIFF2NUM(R,C, v));\n\t\t\treturn;\n\t\tcase 'b': case 'e': write_biff_rec(ba, 0x0005, write_BIFF2BERR(R, C, cell.v, cell.t)); return;\n\t\t/* TODO: codepage, sst */\n\t\tcase 's': case 'str':\n\t\t\twrite_biff_rec(ba, 0x0004, write_BIFF2LABEL(R, C, (cell.v||\"\").slice(0,255)));\n\t\t\treturn;\n\t}\n\twrite_biff_rec(ba, 0x0001, write_BIFF2Cell(null, R, C));\n}\n\nfunction write_ws_biff2(ba/*:BufArray*/, ws/*:Worksheet*/, idx/*:number*/, opts/*::, wb:Workbook*/) {\n\tvar dense = Array.isArray(ws);\n\tvar range = safe_decode_range(ws['!ref'] || \"A1\"), ref/*:string*/, rr = \"\", cols/*:Array<string>*/ = [];\n\tif(range.e.c > 0xFF || range.e.r > 0x3FFF) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + (ws['!ref'] || \"A1\") + \" exceeds format limit A1:IV16384\");\n\t\trange.e.c = Math.min(range.e.c, 0xFF);\n\t\trange.e.r = Math.min(range.e.c, 0x3FFF);\n\t\tref = encode_range(range);\n\t}\n\tfor(var R = range.s.r; R <= range.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\tref = cols[C] + rr;\n\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\tif(!cell) continue;\n\t\t\t/* write cell */\n\t\t\twrite_ws_biff2_cell(ba, cell, R, C, opts);\n\t\t}\n\t}\n}\n\n/* Based on test files */\nfunction write_biff2_buf(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\tvar o = opts || {};\n\tif(DENSE != null && o.dense == null) o.dense = DENSE;\n\tvar ba = buf_array();\n\tvar idx = 0;\n\tfor(var i=0;i<wb.SheetNames.length;++i) if(wb.SheetNames[i] == o.sheet) idx=i;\n\tif(idx == 0 && !!o.sheet && wb.SheetNames[0] != o.sheet) throw new Error(\"Sheet not found: \" + o.sheet);\n\twrite_biff_rec(ba, (o.biff == 4 ? 0x0409 : (o.biff == 3 ? 0x0209 : 0x0009)), write_BOF(wb, 0x10, o));\n\t/* ... */\n\twrite_ws_biff2(ba, wb.Sheets[wb.SheetNames[idx]], idx, o, wb);\n\t/* ... */\n\twrite_biff_rec(ba, 0x000A);\n\treturn ba.end();\n}\n\nfunction write_FONTS_biff8(ba, data, opts) {\n\twrite_biff_rec(ba, 0x0031 /* Font */, write_Font({\n\t\tsz:12,\n\t\tcolor: {theme:1},\n\t\tname: \"Arial\",\n\t\tfamily: 2,\n\t\tscheme: \"minor\"\n\t}, opts));\n}\n\n\nfunction write_FMTS_biff8(ba, NF/*:?SSFTable*/, opts) {\n\tif(!NF) return;\n\t[[5,8],[23,26],[41,44],[/*63*/50,/*66],[164,*/392]].forEach(function(r) {\n\t\t/*:: if(!NF) return; */\n\t\tfor(var i = r[0]; i <= r[1]; ++i) if(NF[i] != null) write_biff_rec(ba, 0x041E /* Format */, write_Format(i, NF[i], opts));\n\t});\n}\n\nfunction write_FEAT(ba, ws) {\n\t/* [MS-XLS] 2.4.112 */\n\tvar o = new_buf(19);\n\to.write_shift(4, 0x867); o.write_shift(4, 0); o.write_shift(4, 0);\n\to.write_shift(2, 3); o.write_shift(1, 1); o.write_shift(4, 0);\n\twrite_biff_rec(ba, 0x0867 /* FeatHdr */, o);\n\t/* [MS-XLS] 2.4.111 */\n\to = new_buf(39);\n\to.write_shift(4, 0x868); o.write_shift(4, 0); o.write_shift(4, 0);\n\to.write_shift(2, 3); o.write_shift(1, 0); o.write_shift(4, 0);\n\to.write_shift(2, 1); o.write_shift(4, 4); o.write_shift(2, 0);\n\twrite_Ref8U(safe_decode_range(ws['!ref']||\"A1\"), o);\n\to.write_shift(4, 4);\n\twrite_biff_rec(ba, 0x0868 /* Feat */, o);\n}\n\nfunction write_CELLXFS_biff8(ba, opts) {\n\tfor(var i = 0; i < 16; ++i) write_biff_rec(ba, 0x00e0 /* XF */, write_XF({numFmtId:0, style:true}, 0, opts));\n\topts.cellXfs.forEach(function(c) {\n\t\twrite_biff_rec(ba, 0x00e0 /* XF */, write_XF(c, 0, opts));\n\t});\n}\n\nfunction write_ws_biff8_hlinks(ba/*:BufArray*/, ws) {\n\tfor(var R=0; R<ws['!links'].length; ++R) {\n\t\tvar HL = ws['!links'][R];\n\t\twrite_biff_rec(ba, 0x01b8 /* HLink */, write_HLink(HL));\n\t\tif(HL[1].Tooltip) write_biff_rec(ba, 0x0800 /* HLinkTooltip */, write_HLinkTooltip(HL));\n\t}\n\tdelete ws['!links'];\n}\n\nfunction write_ws_cols_biff8(ba, cols) {\n\tif(!cols) return;\n\tvar cnt = 0;\n\tcols.forEach(function(col, idx) {\n\t\tif(++cnt <= 256 && col) {\n\t\t\twrite_biff_rec(ba, 0x007d /* ColInfo */, write_ColInfo(col_obj_w(idx, col), idx));\n\t\t}\n\t});\n}\n\nfunction write_ws_biff8_cell(ba/*:BufArray*/, cell/*:Cell*/, R/*:number*/, C/*:number*/, opts) {\n\tvar os = 16 + get_cell_style(opts.cellXfs, cell, opts);\n\tif(cell.v == null && !cell.bf) {\n\t\twrite_biff_rec(ba, 0x0201 /* Blank */, write_XLSCell(R, C, os));\n\t\treturn;\n\t}\n\tif(cell.bf) write_biff_rec(ba, 0x0006 /* Formula */, write_Formula(cell, R, C, opts, os));\n\telse switch(cell.t) {\n\t\tcase 'd': case 'n':\n\t\t\tvar v = cell.t == 'd' ? datenum(parseDate(cell.v)) : cell.v;\n\t\t\t/* TODO: emit RK as appropriate */\n\t\t\twrite_biff_rec(ba, 0x0203 /* Number */, write_Number(R, C, v, os, opts));\n\t\t\tbreak;\n\t\tcase 'b': case 'e':\n\t\t\twrite_biff_rec(ba, 0x0205 /* BoolErr */, write_BoolErr(R, C, cell.v, os, opts, cell.t));\n\t\t\tbreak;\n\t\t/* TODO: codepage, sst */\n\t\tcase 's': case 'str':\n\t\t\tif(opts.bookSST) {\n\t\t\t\tvar isst = get_sst_id(opts.Strings, cell.v, opts.revStrings);\n\t\t\t\twrite_biff_rec(ba, 0x00fd /* LabelSst */, write_LabelSst(R, C, isst, os, opts));\n\t\t\t} else write_biff_rec(ba, 0x0204 /* Label */, write_Label(R, C, (cell.v||\"\").slice(0,255), os, opts));\n\t\t\tbreak;\n\t\tdefault:\n\t\t\twrite_biff_rec(ba, 0x0201 /* Blank */, write_XLSCell(R, C, os));\n\t}\n}\n\n/* [MS-XLS] 2.1.7.20.5 */\nfunction write_ws_biff8(idx/*:number*/, opts, wb/*:Workbook*/) {\n\tvar ba = buf_array();\n\tvar s = wb.SheetNames[idx], ws = wb.Sheets[s] || {};\n\tvar _WB/*:WBWBProps*/ = ((wb||{}).Workbook||{}/*:any*/);\n\tvar _sheet/*:WBWSProp*/ = ((_WB.Sheets||[])[idx]||{}/*:any*/);\n\tvar dense = Array.isArray(ws);\n\tvar b8 = opts.biff == 8;\n\tvar ref/*:string*/, rr = \"\", cols/*:Array<string>*/ = [];\n\tvar range = safe_decode_range(ws['!ref'] || \"A1\");\n\tvar MAX_ROWS = b8 ? 65536 : 16384;\n\tif(range.e.c > 0xFF || range.e.r >= MAX_ROWS) {\n\t\tif(opts.WTF) throw new Error(\"Range \" + (ws['!ref'] || \"A1\") + \" exceeds format limit A1:IV16384\");\n\t\trange.e.c = Math.min(range.e.c, 0xFF);\n\t\trange.e.r = Math.min(range.e.c, MAX_ROWS-1);\n\t}\n\n\twrite_biff_rec(ba, 0x0809, write_BOF(wb, 0x10, opts));\n\t/* [Uncalced] Index */\n\twrite_biff_rec(ba, 0x000d /* CalcMode */, writeuint16(1));\n\twrite_biff_rec(ba, 0x000c /* CalcCount */, writeuint16(100));\n\twrite_biff_rec(ba, 0x000f /* CalcRefMode */, writebool(true));\n\twrite_biff_rec(ba, 0x0011 /* CalcIter */, writebool(false));\n\twrite_biff_rec(ba, 0x0010 /* CalcDelta */, write_Xnum(0.001));\n\twrite_biff_rec(ba, 0x005f /* CalcSaveRecalc */, writebool(true));\n\twrite_biff_rec(ba, 0x002a /* PrintRowCol */, writebool(false));\n\twrite_biff_rec(ba, 0x002b /* PrintGrid */, writebool(false));\n\twrite_biff_rec(ba, 0x0082 /* GridSet */, writeuint16(1));\n\twrite_biff_rec(ba, 0x0080 /* Guts */, write_Guts([0,0]));\n\t/* DefaultRowHeight WsBool [Sync] [LPr] [HorizontalPageBreaks] [VerticalPageBreaks] */\n\t/* Header (string) */\n\t/* Footer (string) */\n\twrite_biff_rec(ba, 0x0083 /* HCenter */, writebool(false));\n\twrite_biff_rec(ba, 0x0084 /* VCenter */, writebool(false));\n\t/* ... */\n\tif(b8) write_ws_cols_biff8(ba, ws[\"!cols\"]);\n\t/* ... */\n\twrite_biff_rec(ba, 0x200, write_Dimensions(range, opts));\n\t/* ... */\n\n\tif(b8) ws['!links'] = [];\n\tfor(var R = range.s.r; R <= range.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tfor(var C = range.s.c; C <= range.e.c; ++C) {\n\t\t\tif(R === range.s.r) cols[C] = encode_col(C);\n\t\t\tref = cols[C] + rr;\n\t\t\tvar cell = dense ? (ws[R]||[])[C] : ws[ref];\n\t\t\tif(!cell) continue;\n\t\t\t/* write cell */\n\t\t\twrite_ws_biff8_cell(ba, cell, R, C, opts);\n\t\t\tif(b8 && cell.l) ws['!links'].push([ref, cell.l]);\n\t\t}\n\t}\n\tvar cname/*:string*/ = _sheet.CodeName || _sheet.name || s;\n\t/* ... */\n\tif(b8) write_biff_rec(ba, 0x023e /* Window2 */, write_Window2((_WB.Views||[])[0]));\n\t/* ... */\n\tif(b8 && (ws['!merges']||[]).length) write_biff_rec(ba, 0x00e5 /* MergeCells */, write_MergeCells(ws['!merges']));\n\t/* [LRng] *QUERYTABLE [PHONETICINFO] CONDFMTS */\n\tif(b8) write_ws_biff8_hlinks(ba, ws);\n\t/* [DVAL] */\n\twrite_biff_rec(ba, 0x01ba /* CodeName */, write_XLUnicodeString(cname, opts));\n\t/* *WebPub *CellWatch [SheetExt] */\n\tif(b8) write_FEAT(ba, ws);\n\t/* *FEAT11 *RECORD12 */\n\twrite_biff_rec(ba, 0x000a /* EOF */);\n\treturn ba.end();\n}\n\n/* [MS-XLS] 2.1.7.20.3 */\nfunction write_biff8_global(wb/*:Workbook*/, bufs, opts/*:WriteOpts*/) {\n\tvar A = buf_array();\n\tvar _WB/*:WBWBProps*/ = ((wb||{}).Workbook||{}/*:any*/);\n\tvar _sheets/*:Array<WBWSProp>*/ = (_WB.Sheets||[]);\n\tvar _wb/*:WBProps*/ = /*::((*/_WB.WBProps||{/*::CodeName:\"ThisWorkbook\"*/}/*:: ):any)*/;\n\tvar b8 = opts.biff == 8, b5 = opts.biff == 5;\n\twrite_biff_rec(A, 0x0809, write_BOF(wb, 0x05, opts));\n\tif(opts.bookType == \"xla\") write_biff_rec(A, 0x0087 /* Addin */);\n\twrite_biff_rec(A, 0x00e1 /* InterfaceHdr */, b8 ? writeuint16(0x04b0) : null);\n\twrite_biff_rec(A, 0x00c1 /* Mms */, writezeroes(2));\n\tif(b5) write_biff_rec(A, 0x00bf /* ToolbarHdr */);\n\tif(b5) write_biff_rec(A, 0x00c0 /* ToolbarEnd */);\n\twrite_biff_rec(A, 0x00e2 /* InterfaceEnd */);\n\twrite_biff_rec(A, 0x005c /* WriteAccess */, write_WriteAccess(\"SheetJS\", opts));\n\t/* [FileSharing] */\n\twrite_biff_rec(A, 0x0042 /* CodePage */, writeuint16(b8 ? 0x04b0 : 0x04E4));\n\t/* *2047 Lel */\n\tif(b8) write_biff_rec(A, 0x0161 /* DSF */, writeuint16(0));\n\tif(b8) write_biff_rec(A, 0x01c0 /* Excel9File */);\n\twrite_biff_rec(A, 0x013d /* RRTabId */, write_RRTabId(wb.SheetNames.length));\n\tif(b8 && wb.vbaraw) write_biff_rec(A, 0x00d3 /* ObProj */);\n\t/* [ObNoMacros] */\n\tif(b8 && wb.vbaraw) {\n\t\tvar cname/*:string*/ = _wb.CodeName || \"ThisWorkbook\";\n\t\twrite_biff_rec(A, 0x01ba /* CodeName */, write_XLUnicodeString(cname, opts));\n\t}\n\twrite_biff_rec(A, 0x009c /* BuiltInFnGroupCount */, writeuint16(0x11));\n\t/* *FnGroupName *FnGrp12 */\n\t/* *Lbl */\n\t/* [OleObjectSize] */\n\twrite_biff_rec(A, 0x0019 /* WinProtect */, writebool(false));\n\twrite_biff_rec(A, 0x0012 /* Protect */, writebool(false));\n\twrite_biff_rec(A, 0x0013 /* Password */, writeuint16(0));\n\tif(b8) write_biff_rec(A, 0x01af /* Prot4Rev */, writebool(false));\n\tif(b8) write_biff_rec(A, 0x01bc /* Prot4RevPass */, writeuint16(0));\n\twrite_biff_rec(A, 0x003d /* Window1 */, write_Window1(opts));\n\twrite_biff_rec(A, 0x0040 /* Backup */, writebool(false));\n\twrite_biff_rec(A, 0x008d /* HideObj */, writeuint16(0));\n\twrite_biff_rec(A, 0x0022 /* Date1904 */, writebool(safe1904(wb)==\"true\"));\n\twrite_biff_rec(A, 0x000e /* CalcPrecision */, writebool(true));\n\tif(b8) write_biff_rec(A, 0x01b7 /* RefreshAll */, writebool(false));\n\twrite_biff_rec(A, 0x00DA /* BookBool */, writeuint16(0));\n\t/* ... */\n\twrite_FONTS_biff8(A, wb, opts);\n\twrite_FMTS_biff8(A, wb.SSF, opts);\n\twrite_CELLXFS_biff8(A, opts);\n\t/* ... */\n\tif(b8) write_biff_rec(A, 0x0160 /* UsesELFs */, writebool(false));\n\tvar a = A.end();\n\n\tvar C = buf_array();\n\t/* METADATA [MTRSettings] [ForceFullCalculation] */\n\tif(b8) write_biff_rec(C, 0x008C, write_Country());\n\t/* *SUPBOOK *LBL *RTD [RecalcId] *HFPicture *MSODRAWINGGROUP */\n\n\t/* BIFF8: [SST *Continue] ExtSST */\n\tif(b8 && opts.Strings) write_biff_continue(C, 0x00FC, write_SST(opts.Strings, opts));\n\n\t/* *WebPub [WOpt] [CrErr] [BookExt] *FeatHdr *DConn [THEME] [CompressPictures] [Compat12] [GUIDTypeLib] */\n\twrite_biff_rec(C, 0x000A /* EOF */);\n\tvar c = C.end();\n\n\tvar B = buf_array();\n\tvar blen = 0, j = 0;\n\tfor(j = 0; j < wb.SheetNames.length; ++j) blen += (b8 ? 12 : 11) + (b8 ? 2 : 1) * wb.SheetNames[j].length;\n\tvar start = a.length + blen + c.length;\n\tfor(j = 0; j < wb.SheetNames.length; ++j) {\n\t\tvar _sheet/*:WBWSProp*/ = _sheets[j] || ({}/*:any*/);\n\t\twrite_biff_rec(B, 0x0085 /* BoundSheet8 */, write_BoundSheet8({pos:start, hs:_sheet.Hidden||0, dt:0, name:wb.SheetNames[j]}, opts));\n\t\tstart += bufs[j].length;\n\t}\n\t/* 1*BoundSheet8 */\n\tvar b = B.end();\n\tif(blen != b.length) throw new Error(\"BS8 \" + blen + \" != \" + b.length);\n\n\tvar out = [];\n\tif(a.length) out.push(a);\n\tif(b.length) out.push(b);\n\tif(c.length) out.push(c);\n\treturn bconcat(out);\n}\n\n/* [MS-XLS] 2.1.7.20 Workbook Stream */\nfunction write_biff8_buf(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\tvar o = opts || {};\n\tvar bufs = [];\n\n\tif(wb && !wb.SSF) {\n\t\twb.SSF = dup(table_fmt);\n\t}\n\tif(wb && wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\to.revssf = evert_num(wb.SSF); o.revssf[wb.SSF[65535]] = 0;\n\t\to.ssf = wb.SSF;\n\t}\n\n\to.Strings = /*::((*/[]/*:: :any):SST)*/; o.Strings.Count = 0; o.Strings.Unique = 0;\n\tfix_write_opts(o);\n\n\to.cellXfs = [];\n\tget_cell_style(o.cellXfs, {}, {revssf:{\"General\":0}});\n\n\tif(!wb.Props) wb.Props = {};\n\n\tfor(var i = 0; i < wb.SheetNames.length; ++i) bufs[bufs.length] = write_ws_biff8(i, o, wb);\n\tbufs.unshift(write_biff8_global(wb, bufs, o));\n\treturn bconcat(bufs);\n}\n\nfunction write_biff_buf(wb/*:Workbook*/, opts/*:WriteOpts*/) {\n\tfor(var i = 0; i <= wb.SheetNames.length; ++i) {\n\t\tvar ws = wb.Sheets[wb.SheetNames[i]];\n\t\tif(!ws || !ws[\"!ref\"]) continue;\n\t\tvar range = decode_range(ws[\"!ref\"]);\n\t\tif(range.e.c > 255) { // note: 255 is IV\n\t\tif(typeof console != \"undefined\" && console.error) console.error(\"Worksheet '\" + wb.SheetNames[i] + \"' extends beyond column IV (255).  Data may be lost.\");\n\t\t}\n\t}\n\n\tvar o = opts || {};\n\tswitch(o.biff || 2) {\n\t\tcase 8: case 5: return write_biff8_buf(wb, opts);\n\t\tcase 4: case 3: case 2: return write_biff2_buf(wb, opts);\n\t}\n\tthrow new Error(\"invalid type \" + o.bookType + \" for BIFF\");\n}\n/* note: browser DOM element cannot see mso- style attrs, must parse */\nfunction html_to_sheet(str/*:string*/, _opts)/*:Workbook*/ {\n\tvar opts = _opts || {};\n\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\tvar ws/*:Worksheet*/ = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\tstr = str.replace(/<!--.*?-->/g, \"\");\n\tvar mtch/*:any*/ = str.match(/<table/i);\n\tif(!mtch) throw new Error(\"Invalid HTML: could not find <table>\");\n\tvar mtch2/*:any*/ = str.match(/<\\/table/i);\n\tvar i/*:number*/ = mtch.index, j/*:number*/ = mtch2 && mtch2.index || str.length;\n\tvar rows = split_regex(str.slice(i, j), /(:?<tr[^>]*>)/i, \"<tr>\");\n\tvar R = -1, C = 0, RS = 0, CS = 0;\n\tvar range/*:Range*/ = {s:{r:10000000, c:10000000},e:{r:0,c:0}};\n\tvar merges/*:Array<Range>*/ = [];\n\tfor(i = 0; i < rows.length; ++i) {\n\t\tvar row = rows[i].trim();\n\t\tvar hd = row.slice(0,3).toLowerCase();\n\t\tif(hd == \"<tr\") { ++R; if(opts.sheetRows && opts.sheetRows <= R) { --R; break; } C = 0; continue; }\n\t\tif(hd != \"<td\" && hd != \"<th\") continue;\n\t\tvar cells = row.split(/<\\/t[dh]>/i);\n\t\tfor(j = 0; j < cells.length; ++j) {\n\t\t\tvar cell = cells[j].trim();\n\t\t\tif(!cell.match(/<t[dh]/i)) continue;\n\t\t\tvar m = cell, cc = 0;\n\t\t\t/* TODO: parse styles etc */\n\t\t\twhile(m.charAt(0) == \"<\" && (cc = m.indexOf(\">\")) > -1) m = m.slice(cc+1);\n\t\t\tfor(var midx = 0; midx < merges.length; ++midx) {\n\t\t\t\tvar _merge/*:Range*/ = merges[midx];\n\t\t\t\tif(_merge.s.c == C && _merge.s.r < R && R <= _merge.e.r) { C = _merge.e.c + 1; midx = -1; }\n\t\t\t}\n\t\t\tvar tag = parsexmltag(cell.slice(0, cell.indexOf(\">\")));\n\t\t\tCS = tag.colspan ? +tag.colspan : 1;\n\t\t\tif((RS = +tag.rowspan)>1 || CS>1) merges.push({s:{r:R,c:C},e:{r:R + (RS||1) - 1, c:C + CS - 1}});\n\t\t\tvar _t/*:string*/ = tag.t || tag[\"data-t\"] || \"\";\n\t\t\t/* TODO: generate stub cells */\n\t\t\tif(!m.length) { C += CS; continue; }\n\t\t\tm = htmldecode(m);\n\t\t\tif(range.s.r > R) range.s.r = R; if(range.e.r < R) range.e.r = R;\n\t\t\tif(range.s.c > C) range.s.c = C; if(range.e.c < C) range.e.c = C;\n\t\t\tif(!m.length) { C += CS; continue; }\n\t\t\tvar o/*:Cell*/ = {t:'s', v:m};\n\t\t\tif(opts.raw || !m.trim().length || _t == 's'){}\n\t\t\telse if(m === 'TRUE') o = {t:'b', v:true};\n\t\t\telse if(m === 'FALSE') o = {t:'b', v:false};\n\t\t\telse if(!isNaN(fuzzynum(m))) o = {t:'n', v:fuzzynum(m)};\n\t\t\telse if(!isNaN(fuzzydate(m).getDate())) {\n\t\t\t\to = ({t:'d', v:parseDate(m)}/*:any*/);\n\t\t\t\tif(!opts.cellDates) o = ({t:'n', v:datenum(o.v)}/*:any*/);\n\t\t\t\to.z = opts.dateNF || table_fmt[14];\n\t\t\t}\n\t\t\tif(opts.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = o; }\n\t\t\telse ws[encode_cell({r:R, c:C})] = o;\n\t\t\tC += CS;\n\t\t}\n\t}\n\tws['!ref'] = encode_range(range);\n\tif(merges.length) ws[\"!merges\"] = merges;\n\treturn ws;\n}\nfunction make_html_row(ws/*:Worksheet*/, r/*:Range*/, R/*:number*/, o/*:Sheet2HTMLOpts*/)/*:string*/ {\n\tvar M/*:Array<Range>*/ = (ws['!merges'] ||[]);\n\tvar oo/*:Array<string>*/ = [];\n\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\tvar RS = 0, CS = 0;\n\t\tfor(var j = 0; j < M.length; ++j) {\n\t\t\tif(M[j].s.r > R || M[j].s.c > C) continue;\n\t\t\tif(M[j].e.r < R || M[j].e.c < C) continue;\n\t\t\tif(M[j].s.r < R || M[j].s.c < C) { RS = -1; break; }\n\t\t\tRS = M[j].e.r - M[j].s.r + 1; CS = M[j].e.c - M[j].s.c + 1; break;\n\t\t}\n\t\tif(RS < 0) continue;\n\t\tvar coord = encode_cell({r:R,c:C});\n\t\tvar cell = o.dense ? (ws[R]||[])[C] : ws[coord];\n\t\t/* TODO: html entities */\n\t\tvar w = (cell && cell.v != null) && (cell.h || escapehtml(cell.w || (format_cell(cell), cell.w) || \"\")) || \"\";\n\t\tvar sp = ({}/*:any*/);\n\t\tif(RS > 1) sp.rowspan = RS;\n\t\tif(CS > 1) sp.colspan = CS;\n\t\tif(o.editable) w = '<span contenteditable=\"true\">' + w + '</span>';\n\t\telse if(cell) {\n\t\t\tsp[\"data-t\"] = cell && cell.t || 'z';\n\t\t\tif(cell.v != null) sp[\"data-v\"] = cell.v;\n\t\t\tif(cell.z != null) sp[\"data-z\"] = cell.z;\n\t\t\tif(cell.l && (cell.l.Target || \"#\").charAt(0) != \"#\") w = '<a href=\"' + cell.l.Target +'\">' + w + '</a>';\n\t\t}\n\t\tsp.id = (o.id || \"sjs\") + \"-\" + coord;\n\t\too.push(writextag('td', w, sp));\n\t}\n\tvar preamble = \"<tr>\";\n\treturn preamble + oo.join(\"\") + \"</tr>\";\n}\n\nvar HTML_BEGIN = '<html><head><meta charset=\"utf-8\"/><title>SheetJS Table Export</title></head><body>';\nvar HTML_END = '</body></html>';\n\nfunction html_to_workbook(str/*:string*/, opts)/*:Workbook*/ {\n\tvar mtch = str.match(/<table[\\s\\S]*?>[\\s\\S]*?<\\/table>/gi);\n\tif(!mtch || mtch.length == 0) throw new Error(\"Invalid HTML: could not find <table>\");\n\tif(mtch.length == 1) return sheet_to_workbook(html_to_sheet(mtch[0], opts), opts);\n\tvar wb = book_new();\n\tmtch.forEach(function(s, idx) { book_append_sheet(wb, html_to_sheet(s, opts), \"Sheet\" + (idx+1)); });\n\treturn wb;\n}\n\nfunction make_html_preamble(ws/*:Worksheet*/, R/*:Range*/, o/*:Sheet2HTMLOpts*/)/*:string*/ {\n\tvar out/*:Array<string>*/ = [];\n\treturn out.join(\"\") + '<table' + (o && o.id ? ' id=\"' + o.id + '\"' : \"\") + '>';\n}\n\nfunction sheet_to_html(ws/*:Worksheet*/, opts/*:?Sheet2HTMLOpts*//*, wb:?Workbook*/)/*:string*/ {\n\tvar o = opts || {};\n\tvar header = o.header != null ? o.header : HTML_BEGIN;\n\tvar footer = o.footer != null ? o.footer : HTML_END;\n\tvar out/*:Array<string>*/ = [header];\n\tvar r = decode_range(ws['!ref']);\n\to.dense = Array.isArray(ws);\n\tout.push(make_html_preamble(ws, r, o));\n\tfor(var R = r.s.r; R <= r.e.r; ++R) out.push(make_html_row(ws, r, R, o));\n\tout.push(\"</table>\" + footer);\n\treturn out.join(\"\");\n}\n\nfunction sheet_add_dom(ws/*:Worksheet*/, table/*:HTMLElement*/, _opts/*:?any*/)/*:Worksheet*/ {\n\tvar opts = _opts || {};\n\tif(DENSE != null) opts.dense = DENSE;\n\tvar or_R = 0, or_C = 0;\n\tif(opts.origin != null) {\n\t\tif(typeof opts.origin == 'number') or_R = opts.origin;\n\t\telse {\n\t\t\tvar _origin/*:CellAddress*/ = typeof opts.origin == \"string\" ? decode_cell(opts.origin) : opts.origin;\n\t\t\tor_R = _origin.r; or_C = _origin.c;\n\t\t}\n\t}\n\n\tvar rows/*:HTMLCollection<HTMLTableRowElement>*/ = table.getElementsByTagName('tr');\n\tvar sheetRows = Math.min(opts.sheetRows||10000000, rows.length);\n\tvar range/*:Range*/ = {s:{r:0,c:0},e:{r:or_R,c:or_C}};\n\tif(ws[\"!ref\"]) {\n\t\tvar _range/*:Range*/ = decode_range(ws[\"!ref\"]);\n\t\trange.s.r = Math.min(range.s.r, _range.s.r);\n\t\trange.s.c = Math.min(range.s.c, _range.s.c);\n\t\trange.e.r = Math.max(range.e.r, _range.e.r);\n\t\trange.e.c = Math.max(range.e.c, _range.e.c);\n\t\tif(or_R == -1) range.e.r = or_R = _range.e.r + 1;\n\t}\n\tvar merges/*:Array<Range>*/ = [], midx = 0;\n\tvar rowinfo/*:Array<RowInfo>*/ = ws[\"!rows\"] || (ws[\"!rows\"] = []);\n\tvar _R = 0, R = 0, _C = 0, C = 0, RS = 0, CS = 0;\n\tif(!ws[\"!cols\"]) ws['!cols'] = [];\n\tfor(; _R < rows.length && R < sheetRows; ++_R) {\n\t\tvar row/*:HTMLTableRowElement*/ = rows[_R];\n\t\tif (is_dom_element_hidden(row)) {\n\t\t\tif (opts.display) continue;\n\t\t\trowinfo[R] = {hidden: true};\n\t\t}\n\t\tvar elts/*:HTMLCollection<HTMLTableCellElement>*/ = (row.children/*:any*/);\n\t\tfor(_C = C = 0; _C < elts.length; ++_C) {\n\t\t\tvar elt/*:HTMLTableCellElement*/ = elts[_C];\n\t\t\tif (opts.display && is_dom_element_hidden(elt)) continue;\n\t\t\tvar v/*:?string*/ = elt.hasAttribute('data-v') ? elt.getAttribute('data-v') : elt.hasAttribute('v') ? elt.getAttribute('v') : htmldecode(elt.innerHTML);\n\t\t\tvar z/*:?string*/ = elt.getAttribute('data-z') || elt.getAttribute('z');\n\t\t\tfor(midx = 0; midx < merges.length; ++midx) {\n\t\t\t\tvar m/*:Range*/ = merges[midx];\n\t\t\t\tif(m.s.c == C + or_C && m.s.r < R + or_R && R + or_R <= m.e.r) { C = m.e.c+1 - or_C; midx = -1; }\n\t\t\t}\n\t\t\t/* TODO: figure out how to extract nonstandard mso- style */\n\t\t\tCS = +elt.getAttribute(\"colspan\") || 1;\n\t\t\tif( ((RS = (+elt.getAttribute(\"rowspan\") || 1)))>1 || CS>1) merges.push({s:{r:R + or_R,c:C + or_C},e:{r:R + or_R + (RS||1) - 1, c:C + or_C + (CS||1) - 1}});\n\t\t\tvar o/*:Cell*/ = {t:'s', v:v};\n\t\t\tvar _t/*:string*/ = elt.getAttribute(\"data-t\") || elt.getAttribute(\"t\") || \"\";\n\t\t\tif(v != null) {\n\t\t\t\tif(v.length == 0) o.t = _t || 'z';\n\t\t\t\telse if(opts.raw || v.trim().length == 0 || _t == \"s\"){}\n\t\t\t\telse if(v === 'TRUE') o = {t:'b', v:true};\n\t\t\t\telse if(v === 'FALSE') o = {t:'b', v:false};\n\t\t\t\telse if(!isNaN(fuzzynum(v))) o = {t:'n', v:fuzzynum(v)};\n\t\t\t\telse if(!isNaN(fuzzydate(v).getDate())) {\n\t\t\t\t\to = ({t:'d', v:parseDate(v)}/*:any*/);\n\t\t\t\t\tif(!opts.cellDates) o = ({t:'n', v:datenum(o.v)}/*:any*/);\n\t\t\t\t\to.z = opts.dateNF || table_fmt[14];\n\t\t\t\t}\n\t\t\t}\n\t\t\tif(o.z === undefined && z != null) o.z = z;\n\t\t\t/* The first link is used.  Links are assumed to be fully specified.\n\t\t\t * TODO: The right way to process relative links is to make a new <a> */\n\t\t\tvar l = \"\", Aelts = elt.getElementsByTagName(\"A\");\n\t\t\tif(Aelts && Aelts.length) for(var Aelti = 0; Aelti < Aelts.length; ++Aelti)\tif(Aelts[Aelti].hasAttribute(\"href\")) {\n\t\t\t\tl = Aelts[Aelti].getAttribute(\"href\"); if(l.charAt(0) != \"#\") break;\n\t\t\t}\n\t\t\tif(l && l.charAt(0) != \"#\") o.l = ({ Target: l });\n\t\t\tif(opts.dense) { if(!ws[R + or_R]) ws[R + or_R] = []; ws[R + or_R][C + or_C] = o; }\n\t\t\telse ws[encode_cell({c:C + or_C, r:R + or_R})] = o;\n\t\t\tif(range.e.c < C + or_C) range.e.c = C + or_C;\n\t\t\tC += CS;\n\t\t}\n\t\t++R;\n\t}\n\tif(merges.length) ws['!merges'] = (ws[\"!merges\"] || []).concat(merges);\n\trange.e.r = Math.max(range.e.r, R - 1 + or_R);\n\tws['!ref'] = encode_range(range);\n\tif(R >= sheetRows) ws['!fullref'] = encode_range((range.e.r = rows.length-_R+R-1 + or_R,range)); // We can count the real number of rows to parse but we don't to improve the performance\n\treturn ws;\n}\n\nfunction parse_dom_table(table/*:HTMLElement*/, _opts/*:?any*/)/*:Worksheet*/ {\n\tvar opts = _opts || {};\n\tvar ws/*:Worksheet*/ = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\treturn sheet_add_dom(ws, table, _opts);\n}\n\nfunction table_to_book(table/*:HTMLElement*/, opts/*:?any*/)/*:Workbook*/ {\n\treturn sheet_to_workbook(parse_dom_table(table, opts), opts);\n}\n\nfunction is_dom_element_hidden(element/*:HTMLElement*/)/*:boolean*/ {\n\tvar display/*:string*/ = '';\n\tvar get_computed_style/*:?function*/ = get_get_computed_style_function(element);\n\tif(get_computed_style) display = get_computed_style(element).getPropertyValue('display');\n\tif(!display) display = element.style && element.style.display;\n\treturn display === 'none';\n}\n\n/* global getComputedStyle */\nfunction get_get_computed_style_function(element/*:HTMLElement*/)/*:?function*/ {\n\t// The proper getComputedStyle implementation is the one defined in the element window\n\tif(element.ownerDocument.defaultView && typeof element.ownerDocument.defaultView.getComputedStyle === 'function') return element.ownerDocument.defaultView.getComputedStyle;\n\t// If it is not available, try to get one from the global namespace\n\tif(typeof getComputedStyle === 'function') return getComputedStyle;\n\treturn null;\n}\n/* OpenDocument */\nfunction parse_text_p(text/*:string*//*::, tag*/)/*:Array<any>*/ {\n\t/* 6.1.2 White Space Characters */\n\tvar fixed = text\n\t\t.replace(/[\\t\\r\\n]/g, \" \").trim().replace(/ +/g, \" \")\n\t\t.replace(/<text:s\\/>/g,\" \")\n\t\t.replace(/<text:s text:c=\"(\\d+)\"\\/>/g, function($$,$1) { return Array(parseInt($1,10)+1).join(\" \"); })\n\t\t.replace(/<text:tab[^>]*\\/>/g,\"\\t\")\n\t\t.replace(/<text:line-break\\/>/g,\"\\n\");\n\tvar v = unescapexml(fixed.replace(/<[^>]*>/g,\"\"));\n\n\treturn [v];\n}\n\nvar number_formats_ods = {\n\t/* ods name: [short ssf fmt, long ssf fmt] */\n\tday:           [\"d\",   \"dd\"],\n\tmonth:         [\"m\",   \"mm\"],\n\tyear:          [\"y\",   \"yy\"],\n\thours:         [\"h\",   \"hh\"],\n\tminutes:       [\"m\",   \"mm\"],\n\tseconds:       [\"s\",   \"ss\"],\n\t\"am-pm\":       [\"A/P\", \"AM/PM\"],\n\t\"day-of-week\": [\"ddd\", \"dddd\"],\n\tera:           [\"e\",   \"ee\"],\n\t/* there is no native representation of LO \"Q\" format */\n\tquarter:       [\"\\\\Qm\", \"m\\\\\\\"th quarter\\\"\"]\n};\n\n\nfunction parse_content_xml(d/*:string*/, _opts)/*:Workbook*/ {\n\t\tvar opts = _opts || {};\n\t\tif(DENSE != null && opts.dense == null) opts.dense = DENSE;\n\t\tvar str = xlml_normalize(d);\n\t\tvar state/*:Array<any>*/ = [], tmp;\n\t\tvar tag/*:: = {}*/;\n\t\tvar NFtag = {name:\"\"}, NF = \"\", pidx = 0;\n\t\tvar sheetag/*:: = {name:\"\", '名称':\"\"}*/;\n\t\tvar rowtag/*:: = {'行号':\"\"}*/;\n\t\tvar Sheets = {}, SheetNames/*:Array<string>*/ = [];\n\t\tvar ws = opts.dense ? ([]/*:any*/) : ({}/*:any*/);\n\t\tvar Rn, q/*:: :any = ({t:\"\", v:null, z:null, w:\"\",c:[],}:any)*/;\n\t\tvar ctag = ({value:\"\"}/*:any*/);\n\t\tvar textp = \"\", textpidx = 0, textptag/*:: = {}*/;\n\t\tvar textR = [];\n\t\tvar R = -1, C = -1, range = {s: {r:1000000,c:10000000}, e: {r:0, c:0}};\n\t\tvar row_ol = 0;\n\t\tvar number_format_map = {};\n\t\tvar merges/*:Array<Range>*/ = [], mrange = {}, mR = 0, mC = 0;\n\t\tvar rowinfo/*:Array<RowInfo>*/ = [], rowpeat = 1, colpeat = 1;\n\t\tvar arrayf/*:Array<[Range, string]>*/ = [];\n\t\tvar WB = {Names:[]};\n\t\tvar atag = ({}/*:any*/);\n\t\tvar _Ref/*:[string, string]*/ = [\"\", \"\"];\n\t\tvar comments/*:Array<Comment>*/ = [], comment/*:Comment*/ = ({}/*:any*/);\n\t\tvar creator = \"\", creatoridx = 0;\n\t\tvar isstub = false, intable = false;\n\t\tvar i = 0;\n\t\txlmlregex.lastIndex = 0;\n\t\tstr = str.replace(/<!--([\\s\\S]*?)-->/mg,\"\").replace(/<!DOCTYPE[^\\[]*\\[[^\\]]*\\]>/gm,\"\");\n\t\twhile((Rn = xlmlregex.exec(str))) switch((Rn[3]=Rn[3].replace(/_.*$/,\"\"))) {\n\n\t\t\tcase 'table': case '工作表': // 9.1.2 <table:table>\n\t\t\t\tif(Rn[1]==='/') {\n\t\t\t\t\tif(range.e.c >= range.s.c && range.e.r >= range.s.r) ws['!ref'] = encode_range(range);\n\t\t\t\t\telse ws['!ref'] = \"A1:A1\";\n\t\t\t\t\tif(opts.sheetRows > 0 && opts.sheetRows <= range.e.r) {\n\t\t\t\t\t\tws['!fullref'] = ws['!ref'];\n\t\t\t\t\t\trange.e.r = opts.sheetRows - 1;\n\t\t\t\t\t\tws['!ref'] = encode_range(range);\n\t\t\t\t\t}\n\t\t\t\t\tif(merges.length) ws['!merges'] = merges;\n\t\t\t\t\tif(rowinfo.length) ws[\"!rows\"] = rowinfo;\n\t\t\t\t\tsheetag.name = sheetag['名称'] || sheetag.name;\n\t\t\t\t\tif(typeof JSON !== 'undefined') JSON.stringify(sheetag);\n\t\t\t\t\tSheetNames.push(sheetag.name);\n\t\t\t\t\tSheets[sheetag.name] = ws;\n\t\t\t\t\tintable = false;\n\t\t\t\t}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') {\n\t\t\t\t\tsheetag = parsexmltag(Rn[0], false);\n\t\t\t\t\tR = C = -1;\n\t\t\t\t\trange.s.r = range.s.c = 10000000; range.e.r = range.e.c = 0;\n\t\t\t\t\tws = opts.dense ? ([]/*:any*/) : ({}/*:any*/); merges = [];\n\t\t\t\t\trowinfo = [];\n\t\t\t\t\tintable = true;\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\tcase 'table-row-group': // 9.1.9 <table:table-row-group>\n\t\t\t\tif(Rn[1] === \"/\") --row_ol; else ++row_ol;\n\t\t\t\tbreak;\n\t\t\tcase 'table-row': case '行': // 9.1.3 <table:table-row>\n\t\t\t\tif(Rn[1] === '/') { R+=rowpeat; rowpeat = 1; break; }\n\t\t\t\trowtag = parsexmltag(Rn[0], false);\n\t\t\t\tif(rowtag['行号']) R = rowtag['行号'] - 1; else if(R == -1) R = 0;\n\t\t\t\trowpeat = +rowtag['number-rows-repeated'] || 1;\n\t\t\t\t/* TODO: remove magic */\n\t\t\t\tif(rowpeat < 10) for(i = 0; i < rowpeat; ++i) if(row_ol > 0) rowinfo[R + i] = {level: row_ol};\n\t\t\t\tC = -1; break;\n\t\t\tcase 'covered-table-cell': // 9.1.5 <table:covered-table-cell>\n\t\t\t\tif(Rn[1] !== '/') ++C;\n\t\t\t\tif(opts.sheetStubs) {\n\t\t\t\t\tif(opts.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = {t:'z'}; }\n\t\t\t\t\telse ws[encode_cell({r:R,c:C})] = {t:'z'};\n\t\t\t\t}\n\t\t\t\ttextp = \"\"; textR = [];\n\t\t\t\tbreak; /* stub */\n\t\t\tcase 'table-cell': case '数据':\n\t\t\t\tif(Rn[0].charAt(Rn[0].length-2) === '/') {\n\t\t\t\t\t++C;\n\t\t\t\t\tctag = parsexmltag(Rn[0], false);\n\t\t\t\t\tcolpeat = parseInt(ctag['number-columns-repeated']||\"1\", 10);\n\t\t\t\t\tq = ({t:'z', v:null/*:: , z:null, w:\"\",c:[]*/}/*:any*/);\n\t\t\t\t\tif(ctag.formula && opts.cellFormula != false) q.f = ods_to_csf_formula(unescapexml(ctag.formula));\n\t\t\t\t\tif((ctag['数据类型'] || ctag['value-type']) == \"string\") {\n\t\t\t\t\t\tq.t = \"s\"; q.v = unescapexml(ctag['string-value'] || \"\");\n\t\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\t\tif(!ws[R]) ws[R] = [];\n\t\t\t\t\t\t\tws[R][C] = q;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tws[encode_cell({r:R,c:C})] = q;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tC+= colpeat-1;\n\t\t\t\t} else if(Rn[1]!=='/') {\n\t\t\t\t\t++C;\n\t\t\t\t\ttextp = \"\"; textpidx = 0; textR = [];\n\t\t\t\t\tcolpeat = 1;\n\t\t\t\t\tvar rptR = rowpeat ? R + rowpeat - 1 : R;\n\t\t\t\t\tif(C > range.e.c) range.e.c = C;\n\t\t\t\t\tif(C < range.s.c) range.s.c = C;\n\t\t\t\t\tif(R < range.s.r) range.s.r = R;\n\t\t\t\t\tif(rptR > range.e.r) range.e.r = rptR;\n\t\t\t\t\tctag = parsexmltag(Rn[0], false);\n\t\t\t\t\tcomments = []; comment = ({}/*:any*/);\n\t\t\t\t\tq = ({t:ctag['数据类型'] || ctag['value-type'], v:null/*:: , z:null, w:\"\",c:[]*/}/*:any*/);\n\t\t\t\t\tif(opts.cellFormula) {\n\t\t\t\t\t\tif(ctag.formula) ctag.formula = unescapexml(ctag.formula);\n\t\t\t\t\t\tif(ctag['number-matrix-columns-spanned'] && ctag['number-matrix-rows-spanned']) {\n\t\t\t\t\t\t\tmR = parseInt(ctag['number-matrix-rows-spanned'],10) || 0;\n\t\t\t\t\t\t\tmC = parseInt(ctag['number-matrix-columns-spanned'],10) || 0;\n\t\t\t\t\t\t\tmrange = {s: {r:R,c:C}, e:{r:R + mR-1,c:C + mC-1}};\n\t\t\t\t\t\t\tq.F = encode_range(mrange);\n\t\t\t\t\t\t\tarrayf.push([mrange, q.F]);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif(ctag.formula) q.f = ods_to_csf_formula(ctag.formula);\n\t\t\t\t\t\telse for(i = 0; i < arrayf.length; ++i)\n\t\t\t\t\t\t\tif(R >= arrayf[i][0].s.r && R <= arrayf[i][0].e.r)\n\t\t\t\t\t\t\t\tif(C >= arrayf[i][0].s.c && C <= arrayf[i][0].e.c)\n\t\t\t\t\t\t\t\t\tq.F = arrayf[i][1];\n\t\t\t\t\t}\n\t\t\t\t\tif(ctag['number-columns-spanned'] || ctag['number-rows-spanned']) {\n\t\t\t\t\t\tmR = parseInt(ctag['number-rows-spanned'],10) || 0;\n\t\t\t\t\t\tmC = parseInt(ctag['number-columns-spanned'],10) || 0;\n\t\t\t\t\t\tmrange = {s: {r:R,c:C}, e:{r:R + mR-1,c:C + mC-1}};\n\t\t\t\t\t\tmerges.push(mrange);\n\t\t\t\t\t}\n\n\t\t\t\t\t/* 19.675.2 table:number-columns-repeated */\n\t\t\t\t\tif(ctag['number-columns-repeated']) colpeat = parseInt(ctag['number-columns-repeated'], 10);\n\n\t\t\t\t\t/* 19.385 office:value-type */\n\t\t\t\t\tswitch(q.t) {\n\t\t\t\t\t\tcase 'boolean': q.t = 'b'; q.v = parsexmlbool(ctag['boolean-value']); break;\n\t\t\t\t\t\tcase 'float': q.t = 'n'; q.v = parseFloat(ctag.value); break;\n\t\t\t\t\t\tcase 'percentage': q.t = 'n'; q.v = parseFloat(ctag.value); break;\n\t\t\t\t\t\tcase 'currency': q.t = 'n'; q.v = parseFloat(ctag.value); break;\n\t\t\t\t\t\tcase 'date': q.t = 'd'; q.v = parseDate(ctag['date-value']);\n\t\t\t\t\t\t\tif(!opts.cellDates) { q.t = 'n'; q.v = datenum(q.v); }\n\t\t\t\t\t\t\tq.z = 'm/d/yy'; break;\n\t\t\t\t\t\tcase 'time': q.t = 'n'; q.v = parse_isodur(ctag['time-value'])/86400;\n\t\t\t\t\t\t\tif(opts.cellDates) { q.t = 'd'; q.v = numdate(q.v); }\n\t\t\t\t\t\t\tq.z = 'HH:MM:SS'; break;\n\t\t\t\t\t\tcase 'number': q.t = 'n'; q.v = parseFloat(ctag['数据数值']); break;\n\t\t\t\t\t\tdefault:\n\t\t\t\t\t\t\tif(q.t === 'string' || q.t === 'text' || !q.t) {\n\t\t\t\t\t\t\t\tq.t = 's';\n\t\t\t\t\t\t\t\tif(ctag['string-value'] != null) { textp = unescapexml(ctag['string-value']); textR = []; }\n\t\t\t\t\t\t\t} else throw new Error('Unsupported value type ' + q.t);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tisstub = false;\n\t\t\t\t\tif(q.t === 's') {\n\t\t\t\t\t\tq.v = textp || '';\n\t\t\t\t\t\tif(textR.length) q.R = textR;\n\t\t\t\t\t\tisstub = textpidx == 0;\n\t\t\t\t\t}\n\t\t\t\t\tif(atag.Target) q.l = atag;\n\t\t\t\t\tif(comments.length > 0) { q.c = comments; comments = []; }\n\t\t\t\t\tif(textp && opts.cellText !== false) q.w = textp;\n\t\t\t\t\tif(isstub) { q.t = \"z\"; delete q.v; }\n\t\t\t\t\tif(!isstub || opts.sheetStubs) {\n\t\t\t\t\t\tif(!(opts.sheetRows && opts.sheetRows <= R)) {\n\t\t\t\t\t\t\tfor(var rpt = 0; rpt < rowpeat; ++rpt) {\n\t\t\t\t\t\t\t\tcolpeat = parseInt(ctag['number-columns-repeated']||\"1\", 10);\n\t\t\t\t\t\t\t\tif(opts.dense) {\n\t\t\t\t\t\t\t\t\tif(!ws[R + rpt]) ws[R + rpt] = [];\n\t\t\t\t\t\t\t\t\tws[R + rpt][C] = rpt == 0 ? q : dup(q);\n\t\t\t\t\t\t\t\t\twhile(--colpeat > 0) ws[R + rpt][C + colpeat] = dup(q);\n\t\t\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t\t\tws[encode_cell({r:R + rpt,c:C})] = q;\n\t\t\t\t\t\t\t\t\twhile(--colpeat > 0) ws[encode_cell({r:R + rpt,c:C + colpeat})] = dup(q);\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\tif(range.e.c <= C) range.e.c = C;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\tcolpeat = parseInt(ctag['number-columns-repeated']||\"1\", 10);\n\t\t\t\t\tC += colpeat-1; colpeat = 0;\n\t\t\t\t\tq = {/*:: t:\"\", v:null, z:null, w:\"\",c:[]*/};\n\t\t\t\t\ttextp = \"\"; textR = [];\n\t\t\t\t}\n\t\t\t\tatag = ({}/*:any*/);\n\t\t\t\tbreak; // 9.1.4 <table:table-cell>\n\n\t\t\t/* pure state */\n\t\t\tcase 'document': // TODO: <office:document> is the root for FODS\n\t\t\tcase 'document-content': case '电子表格文档': // 3.1.3.2 <office:document-content>\n\t\t\tcase 'spreadsheet': case '主体': // 3.7 <office:spreadsheet>\n\t\t\tcase 'scripts': // 3.12 <office:scripts>\n\t\t\tcase 'styles': // TODO <office:styles>\n\t\t\tcase 'font-face-decls': // 3.14 <office:font-face-decls>\n\t\t\tcase 'master-styles': // 3.15.4 <office:master-styles> -- relevant for FODS\n\t\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], true]);\n\t\t\t\tbreak;\n\n\t\t\tcase 'annotation': // 14.1 <office:annotation>\n\t\t\t\tif(Rn[1]==='/'){\n\t\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;\n\t\t\t\t\tcomment.t = textp;\n\t\t\t\t\tif(textR.length) /*::(*/comment/*:: :any)*/.R = textR;\n\t\t\t\t\tcomment.a = creator;\n\t\t\t\t\tcomments.push(comment);\n\t\t\t\t}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') {state.push([Rn[3], false]);}\n\t\t\t\tcreator = \"\"; creatoridx = 0;\n\t\t\t\ttextp = \"\"; textpidx = 0; textR = [];\n\t\t\t\tbreak;\n\n\t\t\tcase 'creator': // 4.3.2.7 <dc:creator>\n\t\t\t\tif(Rn[1]==='/') { creator = str.slice(creatoridx,Rn.index); }\n\t\t\t\telse creatoridx = Rn.index + Rn[0].length;\n\t\t\t\tbreak;\n\n\t\t\t/* ignore state */\n\t\t\tcase 'meta': case '元数据': // TODO: <office:meta> <uof:元数据> FODS/UOF\n\t\t\tcase 'settings': // TODO: <office:settings>\n\t\t\tcase 'config-item-set': // TODO: <office:config-item-set>\n\t\t\tcase 'config-item-map-indexed': // TODO: <office:config-item-map-indexed>\n\t\t\tcase 'config-item-map-entry': // TODO: <office:config-item-map-entry>\n\t\t\tcase 'config-item-map-named': // TODO: <office:config-item-map-entry>\n\t\t\tcase 'shapes': // 9.2.8 <table:shapes>\n\t\t\tcase 'frame': // 10.4.2 <draw:frame>\n\t\t\tcase 'text-box': // 10.4.3 <draw:text-box>\n\t\t\tcase 'image': // 10.4.4 <draw:image>\n\t\t\tcase 'data-pilot-tables': // 9.6.2 <table:data-pilot-tables>\n\t\t\tcase 'list-style': // 16.30 <text:list-style>\n\t\t\tcase 'form': // 13.13 <form:form>\n\t\t\tcase 'dde-links': // 9.8 <table:dde-links>\n\t\t\tcase 'event-listeners': // TODO\n\t\t\tcase 'chart': // TODO\n\t\t\t\tif(Rn[1]==='/'){if((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;}\n\t\t\t\telse if(Rn[0].charAt(Rn[0].length-2) !== '/') state.push([Rn[3], false]);\n\t\t\t\ttextp = \"\"; textpidx = 0; textR = [];\n\t\t\t\tbreak;\n\n\t\t\tcase 'scientific-number': // TODO: <number:scientific-number>\n\t\t\t\tbreak;\n\t\t\tcase 'currency-symbol': // TODO: <number:currency-symbol>\n\t\t\t\tbreak;\n\t\t\tcase 'currency-style': // TODO: <number:currency-style>\n\t\t\t\tbreak;\n\t\t\tcase 'number-style': // 16.27.2 <number:number-style>\n\t\t\tcase 'percentage-style': // 16.27.9 <number:percentage-style>\n\t\t\tcase 'date-style': // 16.27.10 <number:date-style>\n\t\t\tcase 'time-style': // 16.27.18 <number:time-style>\n\t\t\t\tif(Rn[1]==='/'){\n\t\t\t\t\tnumber_format_map[NFtag.name] = NF;\n\t\t\t\t\tif((tmp=state.pop())[0]!==Rn[3]) throw \"Bad state: \"+tmp;\n\t\t\t\t} else if(Rn[0].charAt(Rn[0].length-2) !== '/') {\n\t\t\t\t\tNF = \"\";\n\t\t\t\t\tNFtag = parsexmltag(Rn[0], false);\n\t\t\t\t\tstate.push([Rn[3], true]);\n\t\t\t\t} break;\n\n\t\t\tcase 'script': break; // 3.13 <office:script>\n\t\t\tcase 'libraries': break; // TODO: <ooo:libraries>\n\t\t\tcase 'automatic-styles': break; // 3.15.3 <office:automatic-styles>\n\n\t\t\tcase 'default-style': // TODO: <style:default-style>\n\t\t\tcase 'page-layout': break; // TODO: <style:page-layout>\n\t\t\tcase 'style': // 16.2 <style:style>\n\t\t\t\tbreak;\n\t\t\tcase 'map': break; // 16.3 <style:map>\n\t\t\tcase 'font-face': break; // 16.21 <style:font-face>\n\n\t\t\tcase 'paragraph-properties': break; // 17.6 <style:paragraph-properties>\n\t\t\tcase 'table-properties': break; // 17.15 <style:table-properties>\n\t\t\tcase 'table-column-properties': break; // 17.16 <style:table-column-properties>\n\t\t\tcase 'table-row-properties': break; // 17.17 <style:table-row-properties>\n\t\t\tcase 'table-cell-properties': break; // 17.18 <style:table-cell-properties>\n\n\t\t\tcase 'number': // 16.27.3 <number:number>\n\t\t\t\tswitch(state[state.length-1][0]) {\n\t\t\t\t\tcase 'time-style':\n\t\t\t\t\tcase 'date-style':\n\t\t\t\t\t\ttag = parsexmltag(Rn[0], false);\n\t\t\t\t\t\tNF += number_formats_ods[Rn[3]][tag.style==='long'?1:0]; break;\n\t\t\t\t} break;\n\n\t\t\tcase 'fraction': break; // TODO 16.27.6 <number:fraction>\n\n\t\t\tcase 'day': // 16.27.11 <number:day>\n\t\t\tcase 'month': // 16.27.12 <number:month>\n\t\t\tcase 'year': // 16.27.13 <number:year>\n\t\t\tcase 'era': // 16.27.14 <number:era>\n\t\t\tcase 'day-of-week': // 16.27.15 <number:day-of-week>\n\t\t\tcase 'week-of-year': // 16.27.16 <number:week-of-year>\n\t\t\tcase 'quarter': // 16.27.17 <number:quarter>\n\t\t\tcase 'hours': // 16.27.19 <number:hours>\n\t\t\tcase 'minutes': // 16.27.20 <number:minutes>\n\t\t\tcase 'seconds': // 16.27.21 <number:seconds>\n\t\t\tcase 'am-pm': // 16.27.22 <number:am-pm>\n\t\t\t\tswitch(state[state.length-1][0]) {\n\t\t\t\t\tcase 'time-style':\n\t\t\t\t\tcase 'date-style':\n\t\t\t\t\t\ttag = parsexmltag(Rn[0], false);\n\t\t\t\t\t\tNF += number_formats_ods[Rn[3]][tag.style==='long'?1:0]; break;\n\t\t\t\t} break;\n\n\t\t\tcase 'boolean-style': break; // 16.27.23 <number:boolean-style>\n\t\t\tcase 'boolean': break; // 16.27.24 <number:boolean>\n\t\t\tcase 'text-style': break; // 16.27.25 <number:text-style>\n\t\t\tcase 'text': // 16.27.26 <number:text>\n\t\t\t\tif(Rn[0].slice(-2) === \"/>\") break;\n\t\t\t\telse if(Rn[1]===\"/\") switch(state[state.length-1][0]) {\n\t\t\t\t\tcase 'number-style':\n\t\t\t\t\tcase 'date-style':\n\t\t\t\t\tcase 'time-style':\n\t\t\t\t\t\tNF += str.slice(pidx, Rn.index);\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\telse pidx = Rn.index + Rn[0].length;\n\t\t\t\tbreak;\n\n\t\t\tcase 'named-range': // 9.4.12 <table:named-range>\n\t\t\t\ttag = parsexmltag(Rn[0], false);\n\t\t\t\t_Ref = ods_to_csf_3D(tag['cell-range-address']);\n\t\t\t\tvar nrange = ({Name:tag.name, Ref:_Ref[0] + '!' + _Ref[1]}/*:any*/);\n\t\t\t\tif(intable) nrange.Sheet = SheetNames.length;\n\t\t\t\tWB.Names.push(nrange);\n\t\t\t\tbreak;\n\n\t\t\tcase 'text-content': break; // 16.27.27 <number:text-content>\n\t\t\tcase 'text-properties': break; // 16.27.27 <style:text-properties>\n\t\t\tcase 'embedded-text': break; // 16.27.4 <number:embedded-text>\n\n\t\t\tcase 'body': case '电子表格': break; // 3.3 16.9.6 19.726.3\n\n\t\t\tcase 'forms': break; // 12.25.2 13.2\n\t\t\tcase 'table-column': break; // 9.1.6 <table:table-column>\n\t\t\tcase 'table-header-rows': break; // 9.1.7 <table:table-header-rows>\n\t\t\tcase 'table-rows': break; // 9.1.12 <table:table-rows>\n\t\t\t/* TODO: outline levels */\n\t\t\tcase 'table-column-group': break; // 9.1.10 <table:table-column-group>\n\t\t\tcase 'table-header-columns': break; // 9.1.11 <table:table-header-columns>\n\t\t\tcase 'table-columns': break; // 9.1.12 <table:table-columns>\n\n\t\t\tcase 'null-date': break; // 9.4.2 <table:null-date> TODO: date1904\n\n\t\t\tcase 'graphic-properties': break; // 17.21 <style:graphic-properties>\n\t\t\tcase 'calculation-settings': break; // 9.4.1 <table:calculation-settings>\n\t\t\tcase 'named-expressions': break; // 9.4.11 <table:named-expressions>\n\t\t\tcase 'label-range': break; // 9.4.9 <table:label-range>\n\t\t\tcase 'label-ranges': break; // 9.4.10 <table:label-ranges>\n\t\t\tcase 'named-expression': break; // 9.4.13 <table:named-expression>\n\t\t\tcase 'sort': break; // 9.4.19 <table:sort>\n\t\t\tcase 'sort-by': break; // 9.4.20 <table:sort-by>\n\t\t\tcase 'sort-groups': break; // 9.4.22 <table:sort-groups>\n\n\t\t\tcase 'tab': break; // 6.1.4 <text:tab>\n\t\t\tcase 'line-break': break; // 6.1.5 <text:line-break>\n\t\t\tcase 'span': break; // 6.1.7 <text:span>\n\t\t\tcase 'p': case '文本串': // 5.1.3 <text:p>\n\t\t\t\tif(['master-styles'].indexOf(state[state.length-1][0]) > -1) break;\n\t\t\t\tif(Rn[1]==='/' && (!ctag || !ctag['string-value'])) {\n\t\t\t\t\tvar ptp = parse_text_p(str.slice(textpidx,Rn.index), textptag);\n\t\t\t\t\ttextp = (textp.length > 0 ? textp + \"\\n\" : \"\") + ptp[0];\n\t\t\t\t} else { textptag = parsexmltag(Rn[0], false); textpidx = Rn.index + Rn[0].length; }\n\t\t\t\tbreak; // <text:p>\n\t\t\tcase 's': break; // <text:s>\n\n\t\t\tcase 'database-range': // 9.4.15 <table:database-range>\n\t\t\t\tif(Rn[1]==='/') break;\n\t\t\t\ttry {\n\t\t\t\t\t_Ref = ods_to_csf_3D(parsexmltag(Rn[0])['target-range-address']);\n\t\t\t\t\tSheets[_Ref[0]]['!autofilter'] = { ref:_Ref[1] };\n\t\t\t\t} catch(e) {/* empty */}\n\t\t\t\tbreak;\n\n\t\t\tcase 'date': break; // <*:date>\n\n\t\t\tcase 'object': break; // 10.4.6.2 <draw:object>\n\t\t\tcase 'title': case '标题': break; // <*:title> OR <uof:标题>\n\t\t\tcase 'desc': break; // <*:desc>\n\t\t\tcase 'binary-data': break; // 10.4.5 TODO: b64 blob\n\n\t\t\t/* 9.2 Advanced Tables */\n\t\t\tcase 'table-source': break; // 9.2.6\n\t\t\tcase 'scenario': break; // 9.2.6\n\n\t\t\tcase 'iteration': break; // 9.4.3 <table:iteration>\n\t\t\tcase 'content-validations': break; // 9.4.4 <table:\n\t\t\tcase 'content-validation': break; // 9.4.5 <table:\n\t\t\tcase 'help-message': break; // 9.4.6 <table:\n\t\t\tcase 'error-message': break; // 9.4.7 <table:\n\t\t\tcase 'database-ranges': break; // 9.4.14 <table:database-ranges>\n\t\t\tcase 'filter': break; // 9.5.2 <table:filter>\n\t\t\tcase 'filter-and': break; // 9.5.3 <table:filter-and>\n\t\t\tcase 'filter-or': break; // 9.5.4 <table:filter-or>\n\t\t\tcase 'filter-condition': break; // 9.5.5 <table:filter-condition>\n\n\t\t\tcase 'list-level-style-bullet': break; // 16.31 <text:\n\t\t\tcase 'list-level-style-number': break; // 16.32 <text:\n\t\t\tcase 'list-level-properties': break; // 17.19 <style:\n\n\t\t\t/* 7.3 Document Fields */\n\t\t\tcase 'sender-firstname': // 7.3.6.2\n\t\t\tcase 'sender-lastname': // 7.3.6.3\n\t\t\tcase 'sender-initials': // 7.3.6.4\n\t\t\tcase 'sender-title': // 7.3.6.5\n\t\t\tcase 'sender-position': // 7.3.6.6\n\t\t\tcase 'sender-email': // 7.3.6.7\n\t\t\tcase 'sender-phone-private': // 7.3.6.8\n\t\t\tcase 'sender-fax': // 7.3.6.9\n\t\t\tcase 'sender-company': // 7.3.6.10\n\t\t\tcase 'sender-phone-work': // 7.3.6.11\n\t\t\tcase 'sender-street': // 7.3.6.12\n\t\t\tcase 'sender-city': // 7.3.6.13\n\t\t\tcase 'sender-postal-code': // 7.3.6.14\n\t\t\tcase 'sender-country': // 7.3.6.15\n\t\t\tcase 'sender-state-or-province': // 7.3.6.16\n\t\t\tcase 'author-name': // 7.3.7.1\n\t\t\tcase 'author-initials': // 7.3.7.2\n\t\t\tcase 'chapter': // 7.3.8\n\t\t\tcase 'file-name': // 7.3.9\n\t\t\tcase 'template-name': // 7.3.9\n\t\t\tcase 'sheet-name': // 7.3.9\n\t\t\t\tbreak;\n\n\t\t\tcase 'event-listener':\n\t\t\t\tbreak;\n\t\t\t/* TODO: FODS Properties */\n\t\t\tcase 'initial-creator':\n\t\t\tcase 'creation-date':\n\t\t\tcase 'print-date':\n\t\t\tcase 'generator':\n\t\t\tcase 'document-statistic':\n\t\t\tcase 'user-defined':\n\t\t\tcase 'editing-duration':\n\t\t\tcase 'editing-cycles':\n\t\t\t\tbreak;\n\n\t\t\t/* TODO: FODS Config */\n\t\t\tcase 'config-item':\n\t\t\t\tbreak;\n\n\t\t\t/* TODO: style tokens */\n\t\t\tcase 'page-number': break; // TODO <text:page-number>\n\t\t\tcase 'page-count': break; // TODO <text:page-count>\n\t\t\tcase 'time': break; // TODO <text:time>\n\n\t\t\t/* 9.3 Advanced Table Cells */\n\t\t\tcase 'cell-range-source': break; // 9.3.1 <table:\n\t\t\tcase 'detective': break; // 9.3.2 <table:\n\t\t\tcase 'operation': break; // 9.3.3 <table:\n\t\t\tcase 'highlighted-range': break; // 9.3.4 <table:\n\n\t\t\t/* 9.6 Data Pilot Tables <table: */\n\t\t\tcase 'data-pilot-table': // 9.6.3\n\t\t\tcase 'source-cell-range': // 9.6.5\n\t\t\tcase 'source-service': // 9.6.6\n\t\t\tcase 'data-pilot-field': // 9.6.7\n\t\t\tcase 'data-pilot-level': // 9.6.8\n\t\t\tcase 'data-pilot-subtotals': // 9.6.9\n\t\t\tcase 'data-pilot-subtotal': // 9.6.10\n\t\t\tcase 'data-pilot-members': // 9.6.11\n\t\t\tcase 'data-pilot-member': // 9.6.12\n\t\t\tcase 'data-pilot-display-info': // 9.6.13\n\t\t\tcase 'data-pilot-sort-info': // 9.6.14\n\t\t\tcase 'data-pilot-layout-info': // 9.6.15\n\t\t\tcase 'data-pilot-field-reference': // 9.6.16\n\t\t\tcase 'data-pilot-groups': // 9.6.17\n\t\t\tcase 'data-pilot-group': // 9.6.18\n\t\t\tcase 'data-pilot-group-member': // 9.6.19\n\t\t\t\tbreak;\n\n\t\t\t/* 10.3 Drawing Shapes */\n\t\t\tcase 'rect': // 10.3.2\n\t\t\t\tbreak;\n\n\t\t\t/* 14.6 DDE Connections */\n\t\t\tcase 'dde-connection-decls': // 14.6.2 <text:\n\t\t\tcase 'dde-connection-decl': // 14.6.3 <text:\n\t\t\tcase 'dde-link': // 14.6.4 <table:\n\t\t\tcase 'dde-source': // 14.6.5 <office:\n\t\t\t\tbreak;\n\n\t\t\tcase 'properties': break; // 13.7 <form:properties>\n\t\t\tcase 'property': break; // 13.8 <form:property>\n\n\t\t\tcase 'a': // 6.1.8 hyperlink\n\t\t\t\tif(Rn[1]!== '/') {\n\t\t\t\t\tatag = parsexmltag(Rn[0], false);\n\t\t\t\t\tif(!atag.href) break;\n\t\t\t\t\tatag.Target = unescapexml(atag.href); delete atag.href;\n\t\t\t\t\tif(atag.Target.charAt(0) == \"#\" && atag.Target.indexOf(\".\") > -1) {\n\t\t\t\t\t\t_Ref = ods_to_csf_3D(atag.Target.slice(1));\n\t\t\t\t\t\tatag.Target = \"#\" + _Ref[0] + \"!\" + _Ref[1];\n\t\t\t\t\t} else if(atag.Target.match(/^\\.\\.[\\\\\\/]/)) atag.Target = atag.Target.slice(3);\n\t\t\t\t}\n\t\t\t\tbreak;\n\n\t\t\t/* non-standard */\n\t\t\tcase 'table-protection': break;\n\t\t\tcase 'data-pilot-grand-total': break; // <table:\n\t\t\tcase 'office-document-common-attrs': break; // bare\n\t\t\tdefault: switch(Rn[2]) {\n\t\t\t\tcase 'dc:':       // TODO: properties\n\t\t\t\tcase 'calcext:':  // ignore undocumented extensions\n\t\t\t\tcase 'loext:':    // ignore undocumented extensions\n\t\t\t\tcase 'ooo:':      // ignore undocumented extensions\n\t\t\t\tcase 'chartooo:': // ignore undocumented extensions\n\t\t\t\tcase 'draw:':     // TODO: drawing\n\t\t\t\tcase 'style:':    // TODO: styles\n\t\t\t\tcase 'chart:':    // TODO: charts\n\t\t\t\tcase 'form:':     // TODO: forms\n\t\t\t\tcase 'uof:':      // TODO: uof\n\t\t\t\tcase '表:':       // TODO: uof\n\t\t\t\tcase '字:':       // TODO: uof\n\t\t\t\t\tbreak;\n\t\t\t\tdefault: if(opts.WTF) throw new Error(Rn);\n\t\t\t}\n\t\t}\n\t\tvar out/*:Workbook*/ = ({\n\t\t\tSheets: Sheets,\n\t\t\tSheetNames: SheetNames,\n\t\t\tWorkbook: WB\n\t\t}/*:any*/);\n\t\tif(opts.bookSheets) delete /*::(*/out/*:: :any)*/.Sheets;\n\t\treturn out;\n}\n\nfunction parse_ods(zip/*:ZIPFile*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\topts = opts || ({}/*:any*/);\n\tif(safegetzipfile(zip, 'META-INF/manifest.xml')) parse_manifest(getzipdata(zip, 'META-INF/manifest.xml'), opts);\n\tvar content = getzipstr(zip, 'content.xml');\n\tif(!content) throw new Error(\"Missing content.xml in ODS / UOF file\");\n\tvar wb = parse_content_xml(utf8read(content), opts);\n\tif(safegetzipfile(zip, 'meta.xml')) wb.Props = parse_core_props(getzipdata(zip, 'meta.xml'));\n\treturn wb;\n}\nfunction parse_fods(data/*:string*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\treturn parse_content_xml(data, opts);\n}\n\n/* OpenDocument */\nvar write_styles_ods/*:{(wb:any, opts:any):string}*/ = /* @__PURE__ */(function() {\n\tvar master_styles = [\n\t\t'<office:master-styles>',\n\t\t\t'<style:master-page style:name=\"mp1\" style:page-layout-name=\"mp1\">',\n\t\t\t\t'<style:header/>',\n\t\t\t\t'<style:header-left style:display=\"false\"/>',\n\t\t\t\t'<style:footer/>',\n\t\t\t\t'<style:footer-left style:display=\"false\"/>',\n\t\t\t'</style:master-page>',\n\t\t'</office:master-styles>'\n\t].join(\"\");\n\n\tvar payload = '<office:document-styles ' + wxt_helper({\n\t\t'xmlns:office':   \"urn:oasis:names:tc:opendocument:xmlns:office:1.0\",\n\t\t'xmlns:table':    \"urn:oasis:names:tc:opendocument:xmlns:table:1.0\",\n\t\t'xmlns:style':    \"urn:oasis:names:tc:opendocument:xmlns:style:1.0\",\n\t\t'xmlns:text':     \"urn:oasis:names:tc:opendocument:xmlns:text:1.0\",\n\t\t'xmlns:draw':     \"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\",\n\t\t'xmlns:fo':       \"urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0\",\n\t\t'xmlns:xlink':    \"http://www.w3.org/1999/xlink\",\n\t\t'xmlns:dc':       \"http://purl.org/dc/elements/1.1/\",\n\t\t'xmlns:number':   \"urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0\",\n\t\t'xmlns:svg':      \"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\",\n\t\t'xmlns:of':       \"urn:oasis:names:tc:opendocument:xmlns:of:1.2\",\n\t\t'office:version': \"1.2\"\n\t}) + '>' + master_styles + '</office:document-styles>';\n\n\treturn function wso(/*::wb, opts*/) {\n\t\treturn XML_HEADER + payload;\n\t};\n})();\nvar write_content_ods/*:{(wb:any, opts:any):string}*/ = /* @__PURE__ */(function() {\n\t/* 6.1.2 White Space Characters */\n\tvar write_text_p = function(text/*:string*/)/*:string*/ {\n\t\treturn escapexml(text)\n\t\t\t.replace(/  +/g, function($$){return '<text:s text:c=\"'+$$.length+'\"/>';})\n\t\t\t.replace(/\\t/g, \"<text:tab/>\")\n\t\t\t.replace(/\\n/g, \"</text:p><text:p>\")\n\t\t\t.replace(/^ /, \"<text:s/>\").replace(/ $/, \"<text:s/>\");\n\t};\n\n\tvar null_cell_xml = '          <table:table-cell />\\n';\n\tvar covered_cell_xml = '          <table:covered-table-cell/>\\n';\n\tvar write_ws = function(ws, wb/*:Workbook*/, i/*:number*//*::, opts*/)/*:string*/ {\n\t\t/* Section 9 Tables */\n\t\tvar o/*:Array<string>*/ = [];\n\t\to.push('      <table:table table:name=\"' + escapexml(wb.SheetNames[i]) + '\" table:style-name=\"ta1\">\\n');\n\t\tvar R=0,C=0, range = decode_range(ws['!ref']||\"A1\");\n\t\tvar marr/*:Array<Range>*/ = ws['!merges'] || [], mi = 0;\n\t\tvar dense = Array.isArray(ws);\n\t\tif(ws[\"!cols\"]) {\n\t\t\tfor(C = 0; C <= range.e.c; ++C) o.push('        <table:table-column' + (ws[\"!cols\"][C] ? ' table:style-name=\"co' + ws[\"!cols\"][C].ods + '\"' : '') + '></table:table-column>\\n');\n\t\t}\n\t\tvar H = \"\", ROWS = ws[\"!rows\"]||[];\n\t\tfor(R = 0; R < range.s.r; ++R) {\n\t\t\tH = ROWS[R] ? ' table:style-name=\"ro' + ROWS[R].ods + '\"' : \"\";\n\t\t\to.push('        <table:table-row' + H + '></table:table-row>\\n');\n\t\t}\n\t\tfor(; R <= range.e.r; ++R) {\n\t\t\tH = ROWS[R] ? ' table:style-name=\"ro' + ROWS[R].ods + '\"' : \"\";\n\t\t\to.push('        <table:table-row' + H + '>\\n');\n\t\t\tfor(C=0; C < range.s.c; ++C) o.push(null_cell_xml);\n\t\t\tfor(; C <= range.e.c; ++C) {\n\t\t\t\tvar skip = false, ct = {}, textp = \"\";\n\t\t\t\tfor(mi = 0; mi != marr.length; ++mi) {\n\t\t\t\t\tif(marr[mi].s.c > C) continue;\n\t\t\t\t\tif(marr[mi].s.r > R) continue;\n\t\t\t\t\tif(marr[mi].e.c < C) continue;\n\t\t\t\t\tif(marr[mi].e.r < R) continue;\n\t\t\t\t\tif(marr[mi].s.c != C || marr[mi].s.r != R) skip = true;\n\t\t\t\t\tct['table:number-columns-spanned'] = (marr[mi].e.c - marr[mi].s.c + 1);\n\t\t\t\t\tct['table:number-rows-spanned'] =    (marr[mi].e.r - marr[mi].s.r + 1);\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t\tif(skip) { o.push(covered_cell_xml); continue; }\n\t\t\t\tvar ref = encode_cell({r:R, c:C}), cell = dense ? (ws[R]||[])[C]: ws[ref];\n\t\t\t\tif(cell && cell.f) {\n\t\t\t\t\tct['table:formula'] = escapexml(csf_to_ods_formula(cell.f));\n\t\t\t\t\tif(cell.F) {\n\t\t\t\t\t\tif(cell.F.slice(0, ref.length) == ref) {\n\t\t\t\t\t\t\tvar _Fref = decode_range(cell.F);\n\t\t\t\t\t\t\tct['table:number-matrix-columns-spanned'] = (_Fref.e.c - _Fref.s.c + 1);\n\t\t\t\t\t\t\tct['table:number-matrix-rows-spanned'] =    (_Fref.e.r - _Fref.s.r + 1);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tif(!cell) { o.push(null_cell_xml); continue; }\n\t\t\t\tswitch(cell.t) {\n\t\t\t\t\tcase 'b':\n\t\t\t\t\t\ttextp = (cell.v ? 'TRUE' : 'FALSE');\n\t\t\t\t\t\tct['office:value-type'] = \"boolean\";\n\t\t\t\t\t\tct['office:boolean-value'] = (cell.v ? 'true' : 'false');\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'n':\n\t\t\t\t\t\ttextp = (cell.w||String(cell.v||0));\n\t\t\t\t\t\tct['office:value-type'] = \"float\";\n\t\t\t\t\t\tct['office:value'] = (cell.v||0);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 's': case 'str':\n\t\t\t\t\t\ttextp = cell.v == null ? \"\" : cell.v;\n\t\t\t\t\t\tct['office:value-type'] = \"string\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase 'd':\n\t\t\t\t\t\ttextp = (cell.w||(parseDate(cell.v).toISOString()));\n\t\t\t\t\t\tct['office:value-type'] = \"date\";\n\t\t\t\t\t\tct['office:date-value'] = (parseDate(cell.v).toISOString());\n\t\t\t\t\t\tct['table:style-name'] = \"ce1\";\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t//case 'e':\n\t\t\t\t\tdefault: o.push(null_cell_xml); continue;\n\t\t\t\t}\n\t\t\t\tvar text_p = write_text_p(textp);\n\t\t\t\tif(cell.l && cell.l.Target) {\n\t\t\t\t\tvar _tgt = cell.l.Target;\n\t\t\t\t\t_tgt = _tgt.charAt(0) == \"#\" ? \"#\" + csf_to_ods_3D(_tgt.slice(1)) : _tgt;\n\t\t\t\t\t// TODO: choose correct parent path format based on link delimiters\n\t\t\t\t\tif(_tgt.charAt(0) != \"#\" && !_tgt.match(/^\\w+:/)) _tgt = '../' + _tgt;\n\t\t\t\t\ttext_p = writextag('text:a', text_p, {'xlink:href': _tgt.replace(/&/g, \"&amp;\")});\n\t\t\t\t}\n\t\t\t\to.push('          ' + writextag('table:table-cell', writextag('text:p', text_p, {}), ct) + '\\n');\n\t\t\t}\n\t\t\to.push('        </table:table-row>\\n');\n\t\t}\n\t\to.push('      </table:table>\\n');\n\t\treturn o.join(\"\");\n\t};\n\n\tvar write_automatic_styles_ods = function(o/*:Array<string>*/, wb) {\n\t\to.push(' <office:automatic-styles>\\n');\n\n\t\to.push('  <number:date-style style:name=\"N37\" number:automatic-order=\"true\">\\n');\n\t\to.push('   <number:month number:style=\"long\"/>\\n');\n\t\to.push('   <number:text>/</number:text>\\n');\n\t\to.push('   <number:day number:style=\"long\"/>\\n');\n\t\to.push('   <number:text>/</number:text>\\n');\n\t\to.push('   <number:year/>\\n');\n\t\to.push('  </number:date-style>\\n');\n\n\t\t/* column styles */\n\t\tvar cidx = 0;\n\t\twb.SheetNames.map(function(n) { return wb.Sheets[n]; }).forEach(function(ws) {\n\t\t\tif(!ws) return;\n\t\t\tif(ws[\"!cols\"]) {\n\t\t\t\tfor(var C = 0; C < ws[\"!cols\"].length; ++C) if(ws[\"!cols\"][C]) {\n\t\t\t\t\tvar colobj = ws[\"!cols\"][C];\n\t\t\t\t\tif(colobj.width == null && colobj.wpx == null && colobj.wch == null) continue;\n\t\t\t\t\tprocess_col(colobj);\n\t\t\t\t\tcolobj.ods = cidx;\n\t\t\t\t\tvar w = ws[\"!cols\"][C].wpx + \"px\";\n\t\t\t\t\to.push('  <style:style style:name=\"co' + cidx + '\" style:family=\"table-column\">\\n');\n\t\t\t\t\to.push('   <style:table-column-properties fo:break-before=\"auto\" style:column-width=\"' + w + '\"/>\\n');\n\t\t\t\t\to.push('  </style:style>\\n');\n\t\t\t\t\t++cidx;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\t/* row styles */\n\t\tvar ridx = 0;\n\t\twb.SheetNames.map(function(n) { return wb.Sheets[n]; }).forEach(function(ws) {\n\t\t\tif(!ws) return;\n\t\t\tif(ws[\"!rows\"]) {\n\t\t\t\tfor(var R = 0; R < ws[\"!rows\"].length; ++R) if(ws[\"!rows\"][R]) {\n\t\t\t\t\tws[\"!rows\"][R].ods = ridx;\n\t\t\t\t\tvar h = ws[\"!rows\"][R].hpx + \"px\";\n\t\t\t\t\to.push('  <style:style style:name=\"ro' + ridx + '\" style:family=\"table-row\">\\n');\n\t\t\t\t\to.push('   <style:table-row-properties fo:break-before=\"auto\" style:row-height=\"' + h + '\"/>\\n');\n\t\t\t\t\to.push('  </style:style>\\n');\n\t\t\t\t\t++ridx;\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\n\t\t/* table */\n\t\to.push('  <style:style style:name=\"ta1\" style:family=\"table\" style:master-page-name=\"mp1\">\\n');\n\t\to.push('   <style:table-properties table:display=\"true\" style:writing-mode=\"lr-tb\"/>\\n');\n\t\to.push('  </style:style>\\n');\n\n\t\t/* table cells, text */\n\t\to.push('  <style:style style:name=\"ce1\" style:family=\"table-cell\" style:parent-style-name=\"Default\" style:data-style-name=\"N37\"/>\\n');\n\n\t\t/* page-layout */\n\n\t\to.push(' </office:automatic-styles>\\n');\n\t};\n\n\treturn function wcx(wb, opts) {\n\t\tvar o = [XML_HEADER];\n\t\t/* 3.1.3.2 */\n\t\tvar attr = wxt_helper({\n\t\t\t'xmlns:office':       \"urn:oasis:names:tc:opendocument:xmlns:office:1.0\",\n\t\t\t'xmlns:table':        \"urn:oasis:names:tc:opendocument:xmlns:table:1.0\",\n\t\t\t'xmlns:style':        \"urn:oasis:names:tc:opendocument:xmlns:style:1.0\",\n\t\t\t'xmlns:text':         \"urn:oasis:names:tc:opendocument:xmlns:text:1.0\",\n\t\t\t'xmlns:draw':         \"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\",\n\t\t\t'xmlns:fo':           \"urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0\",\n\t\t\t'xmlns:xlink':        \"http://www.w3.org/1999/xlink\",\n\t\t\t'xmlns:dc':           \"http://purl.org/dc/elements/1.1/\",\n\t\t\t'xmlns:meta':         \"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\",\n\t\t\t'xmlns:number':       \"urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0\",\n\t\t\t'xmlns:presentation': \"urn:oasis:names:tc:opendocument:xmlns:presentation:1.0\",\n\t\t\t'xmlns:svg':          \"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\",\n\t\t\t'xmlns:chart':        \"urn:oasis:names:tc:opendocument:xmlns:chart:1.0\",\n\t\t\t'xmlns:dr3d':         \"urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0\",\n\t\t\t'xmlns:math':         \"http://www.w3.org/1998/Math/MathML\",\n\t\t\t'xmlns:form':         \"urn:oasis:names:tc:opendocument:xmlns:form:1.0\",\n\t\t\t'xmlns:script':       \"urn:oasis:names:tc:opendocument:xmlns:script:1.0\",\n\t\t\t'xmlns:ooo':          \"http://openoffice.org/2004/office\",\n\t\t\t'xmlns:ooow':         \"http://openoffice.org/2004/writer\",\n\t\t\t'xmlns:oooc':         \"http://openoffice.org/2004/calc\",\n\t\t\t'xmlns:dom':          \"http://www.w3.org/2001/xml-events\",\n\t\t\t'xmlns:xforms':       \"http://www.w3.org/2002/xforms\",\n\t\t\t'xmlns:xsd':          \"http://www.w3.org/2001/XMLSchema\",\n\t\t\t'xmlns:xsi':          \"http://www.w3.org/2001/XMLSchema-instance\",\n\t\t\t'xmlns:sheet':        \"urn:oasis:names:tc:opendocument:sh33tjs:1.0\",\n\t\t\t'xmlns:rpt':          \"http://openoffice.org/2005/report\",\n\t\t\t'xmlns:of':           \"urn:oasis:names:tc:opendocument:xmlns:of:1.2\",\n\t\t\t'xmlns:xhtml':        \"http://www.w3.org/1999/xhtml\",\n\t\t\t'xmlns:grddl':        \"http://www.w3.org/2003/g/data-view#\",\n\t\t\t'xmlns:tableooo':     \"http://openoffice.org/2009/table\",\n\t\t\t'xmlns:drawooo':      \"http://openoffice.org/2010/draw\",\n\t\t\t'xmlns:calcext':      \"urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0\",\n\t\t\t'xmlns:loext':        \"urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0\",\n\t\t\t'xmlns:field':        \"urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0\",\n\t\t\t'xmlns:formx':        \"urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0\",\n\t\t\t'xmlns:css3t':        \"http://www.w3.org/TR/css3-text/\",\n\t\t\t'office:version':     \"1.2\"\n\t\t});\n\n\t\tvar fods = wxt_helper({\n\t\t\t'xmlns:config':    \"urn:oasis:names:tc:opendocument:xmlns:config:1.0\",\n\t\t\t'office:mimetype': \"application/vnd.oasis.opendocument.spreadsheet\"\n\t\t});\n\n\t\tif(opts.bookType == \"fods\") {\n\t\t\to.push('<office:document' + attr + fods + '>\\n');\n\t\t\to.push(write_meta_ods().replace(/office:document-meta/g, \"office:meta\"));\n\t\t\t// TODO: settings (equiv of settings.xml for ODS)\n\t\t} else o.push('<office:document-content' + attr  + '>\\n');\n\t\t// o.push('  <office:scripts/>\\n');\n\t\twrite_automatic_styles_ods(o, wb);\n\t\to.push('  <office:body>\\n');\n\t\to.push('    <office:spreadsheet>\\n');\n\t\tfor(var i = 0; i != wb.SheetNames.length; ++i) o.push(write_ws(wb.Sheets[wb.SheetNames[i]], wb, i, opts));\n\t\to.push('    </office:spreadsheet>\\n');\n\t\to.push('  </office:body>\\n');\n\t\tif(opts.bookType == \"fods\") o.push('</office:document>');\n\t\telse o.push('</office:document-content>');\n\t\treturn o.join(\"\");\n\t};\n})();\n\nfunction write_ods(wb/*:any*/, opts/*:any*/) {\n\tif(opts.bookType == \"fods\") return write_content_ods(wb, opts);\n\n\tvar zip = zip_new();\n\tvar f = \"\";\n\n\tvar manifest/*:Array<Array<string> >*/ = [];\n\tvar rdf/*:Array<[string, string]>*/ = [];\n\n\t/* Part 3 Section 3.3 MIME Media Type */\n\tf = \"mimetype\";\n\tzip_add_file(zip, f, \"application/vnd.oasis.opendocument.spreadsheet\");\n\n\t/* Part 1 Section 2.2 Documents */\n\tf = \"content.xml\";\n\tzip_add_file(zip, f, write_content_ods(wb, opts));\n\tmanifest.push([f, \"text/xml\"]);\n\trdf.push([f, \"ContentFile\"]);\n\n\t/* TODO: these are hard-coded styles to satiate excel */\n\tf = \"styles.xml\";\n\tzip_add_file(zip, f, write_styles_ods(wb, opts));\n\tmanifest.push([f, \"text/xml\"]);\n\trdf.push([f, \"StylesFile\"]);\n\n\t/* TODO: this is hard-coded to satiate excel */\n\tf = \"meta.xml\";\n\tzip_add_file(zip, f, XML_HEADER + write_meta_ods(/*::wb, opts*/));\n\tmanifest.push([f, \"text/xml\"]);\n\trdf.push([f, \"MetadataFile\"]);\n\n\t/* Part 3 Section 6 Metadata Manifest File */\n\tf = \"manifest.rdf\";\n\tzip_add_file(zip, f, write_rdf(rdf/*, opts*/));\n\tmanifest.push([f, \"application/rdf+xml\"]);\n\n\t/* Part 3 Section 4 Manifest File */\n\tf = \"META-INF/manifest.xml\";\n\tzip_add_file(zip, f, write_manifest(manifest/*, opts*/));\n\n\treturn zip;\n}\n\n/*! sheetjs (C) 2013-present SheetJS -- http://sheetjs.com */\nfunction u8_to_dataview(array) {\n  return new DataView(array.buffer, array.byteOffset, array.byteLength);\n}\nfunction u8str(u8) {\n  return typeof TextDecoder != \"undefined\" ? new TextDecoder().decode(u8) : utf8read(a2s(u8));\n}\nfunction stru8(str) {\n  return typeof TextEncoder != \"undefined\" ? new TextEncoder().encode(str) : s2a(utf8write(str));\n}\nfunction u8contains(body, search) {\n  outer:\n    for (var L = 0; L <= body.length - search.length; ++L) {\n      for (var j = 0; j < search.length; ++j)\n        if (body[L + j] != search[j])\n          continue outer;\n      return true;\n    }\n  return false;\n}\nfunction u8concat(u8a) {\n  var len = u8a.reduce(function(acc, x) {\n    return acc + x.length;\n  }, 0);\n  var out = new Uint8Array(len);\n  var off = 0;\n  u8a.forEach(function(u8) {\n    out.set(u8, off);\n    off += u8.length;\n  });\n  return out;\n}\nfunction popcnt(x) {\n  x -= x >> 1 & 1431655765;\n  x = (x & 858993459) + (x >> 2 & 858993459);\n  return (x + (x >> 4) & 252645135) * 16843009 >>> 24;\n}\nfunction readDecimal128LE(buf, offset) {\n  var exp = (buf[offset + 15] & 127) << 7 | buf[offset + 14] >> 1;\n  var mantissa = buf[offset + 14] & 1;\n  for (var j = offset + 13; j >= offset; --j)\n    mantissa = mantissa * 256 + buf[j];\n  return (buf[offset + 15] & 128 ? -mantissa : mantissa) * Math.pow(10, exp - 6176);\n}\nfunction writeDecimal128LE(buf, offset, value) {\n  var exp = Math.floor(value == 0 ? 0 : Math.LOG10E * Math.log(Math.abs(value))) + 6176 - 20;\n  var mantissa = value / Math.pow(10, exp - 6176);\n  buf[offset + 15] |= exp >> 7;\n  buf[offset + 14] |= (exp & 127) << 1;\n  for (var i = 0; mantissa >= 1; ++i, mantissa /= 256)\n    buf[offset + i] = mantissa & 255;\n  buf[offset + 15] |= value >= 0 ? 0 : 128;\n}\nfunction parse_varint49(buf, ptr) {\n  var l = ptr ? ptr[0] : 0;\n  var usz = buf[l] & 127;\n  varint:\n    if (buf[l++] >= 128) {\n      usz |= (buf[l] & 127) << 7;\n      if (buf[l++] < 128)\n        break varint;\n      usz |= (buf[l] & 127) << 14;\n      if (buf[l++] < 128)\n        break varint;\n      usz |= (buf[l] & 127) << 21;\n      if (buf[l++] < 128)\n        break varint;\n      usz += (buf[l] & 127) * Math.pow(2, 28);\n      ++l;\n      if (buf[l++] < 128)\n        break varint;\n      usz += (buf[l] & 127) * Math.pow(2, 35);\n      ++l;\n      if (buf[l++] < 128)\n        break varint;\n      usz += (buf[l] & 127) * Math.pow(2, 42);\n      ++l;\n      if (buf[l++] < 128)\n        break varint;\n    }\n  if (ptr)\n    ptr[0] = l;\n  return usz;\n}\nfunction write_varint49(v) {\n  var usz = new Uint8Array(7);\n  usz[0] = v & 127;\n  var L = 1;\n  sz:\n    if (v > 127) {\n      usz[L - 1] |= 128;\n      usz[L] = v >> 7 & 127;\n      ++L;\n      if (v <= 16383)\n        break sz;\n      usz[L - 1] |= 128;\n      usz[L] = v >> 14 & 127;\n      ++L;\n      if (v <= 2097151)\n        break sz;\n      usz[L - 1] |= 128;\n      usz[L] = v >> 21 & 127;\n      ++L;\n      if (v <= 268435455)\n        break sz;\n      usz[L - 1] |= 128;\n      usz[L] = v / 256 >>> 21 & 127;\n      ++L;\n      if (v <= 34359738367)\n        break sz;\n      usz[L - 1] |= 128;\n      usz[L] = v / 65536 >>> 21 & 127;\n      ++L;\n      if (v <= 4398046511103)\n        break sz;\n      usz[L - 1] |= 128;\n      usz[L] = v / 16777216 >>> 21 & 127;\n      ++L;\n    }\n  return usz.slice(0, L);\n}\nfunction varint_to_i32(buf) {\n  var l = 0, i32 = buf[l] & 127;\n  varint:\n    if (buf[l++] >= 128) {\n      i32 |= (buf[l] & 127) << 7;\n      if (buf[l++] < 128)\n        break varint;\n      i32 |= (buf[l] & 127) << 14;\n      if (buf[l++] < 128)\n        break varint;\n      i32 |= (buf[l] & 127) << 21;\n      if (buf[l++] < 128)\n        break varint;\n      i32 |= (buf[l] & 127) << 28;\n    }\n  return i32;\n}\nfunction parse_shallow(buf) {\n  var out = [], ptr = [0];\n  while (ptr[0] < buf.length) {\n    var off = ptr[0];\n    var num = parse_varint49(buf, ptr);\n    var type = num & 7;\n    num = Math.floor(num / 8);\n    var len = 0;\n    var res;\n    if (num == 0)\n      break;\n    switch (type) {\n      case 0:\n        {\n          var l = ptr[0];\n          while (buf[ptr[0]++] >= 128)\n            ;\n          res = buf.slice(l, ptr[0]);\n        }\n        break;\n      case 5:\n        len = 4;\n        res = buf.slice(ptr[0], ptr[0] + len);\n        ptr[0] += len;\n        break;\n      case 1:\n        len = 8;\n        res = buf.slice(ptr[0], ptr[0] + len);\n        ptr[0] += len;\n        break;\n      case 2:\n        len = parse_varint49(buf, ptr);\n        res = buf.slice(ptr[0], ptr[0] + len);\n        ptr[0] += len;\n        break;\n      case 3:\n      case 4:\n      default:\n        throw new Error(\"PB Type \".concat(type, \" for Field \").concat(num, \" at offset \").concat(off));\n    }\n    var v = { data: res, type: type };\n    if (out[num] == null)\n      out[num] = [v];\n    else\n      out[num].push(v);\n  }\n  return out;\n}\nfunction write_shallow(proto) {\n  var out = [];\n  proto.forEach(function(field, idx) {\n    field.forEach(function(item) {\n      if (!item.data)\n        return;\n      out.push(write_varint49(idx * 8 + item.type));\n      if (item.type == 2)\n        out.push(write_varint49(item.data.length));\n      out.push(item.data);\n    });\n  });\n  return u8concat(out);\n}\nfunction mappa(data, cb) {\n  return (data == null ? void 0 : data.map(function(d) {\n    return cb(d.data);\n  })) || [];\n}\nfunction parse_iwa_file(buf) {\n  var _a;\n  var out = [], ptr = [0];\n  while (ptr[0] < buf.length) {\n    var len = parse_varint49(buf, ptr);\n    var ai = parse_shallow(buf.slice(ptr[0], ptr[0] + len));\n    ptr[0] += len;\n    var res = {\n      id: varint_to_i32(ai[1][0].data),\n      messages: []\n    };\n    ai[2].forEach(function(b) {\n      var mi = parse_shallow(b.data);\n      var fl = varint_to_i32(mi[3][0].data);\n      res.messages.push({\n        meta: mi,\n        data: buf.slice(ptr[0], ptr[0] + fl)\n      });\n      ptr[0] += fl;\n    });\n    if ((_a = ai[3]) == null ? void 0 : _a[0])\n      res.merge = varint_to_i32(ai[3][0].data) >>> 0 > 0;\n    out.push(res);\n  }\n  return out;\n}\nfunction write_iwa_file(ias) {\n  var bufs = [];\n  ias.forEach(function(ia) {\n    var ai = [];\n    ai[1] = [{ data: write_varint49(ia.id), type: 0 }];\n    ai[2] = [];\n    if (ia.merge != null)\n      ai[3] = [{ data: write_varint49(+!!ia.merge), type: 0 }];\n    var midata = [];\n    ia.messages.forEach(function(mi) {\n      midata.push(mi.data);\n      mi.meta[3] = [{ type: 0, data: write_varint49(mi.data.length) }];\n      ai[2].push({ data: write_shallow(mi.meta), type: 2 });\n    });\n    var aipayload = write_shallow(ai);\n    bufs.push(write_varint49(aipayload.length));\n    bufs.push(aipayload);\n    midata.forEach(function(mid) {\n      return bufs.push(mid);\n    });\n  });\n  return u8concat(bufs);\n}\nfunction parse_snappy_chunk(type, buf) {\n  if (type != 0)\n    throw new Error(\"Unexpected Snappy chunk type \".concat(type));\n  var ptr = [0];\n  var usz = parse_varint49(buf, ptr);\n  var chunks = [];\n  while (ptr[0] < buf.length) {\n    var tag = buf[ptr[0]] & 3;\n    if (tag == 0) {\n      var len = buf[ptr[0]++] >> 2;\n      if (len < 60)\n        ++len;\n      else {\n        var c = len - 59;\n        len = buf[ptr[0]];\n        if (c > 1)\n          len |= buf[ptr[0] + 1] << 8;\n        if (c > 2)\n          len |= buf[ptr[0] + 2] << 16;\n        if (c > 3)\n          len |= buf[ptr[0] + 3] << 24;\n        len >>>= 0;\n        len++;\n        ptr[0] += c;\n      }\n      chunks.push(buf.slice(ptr[0], ptr[0] + len));\n      ptr[0] += len;\n      continue;\n    } else {\n      var offset = 0, length = 0;\n      if (tag == 1) {\n        length = (buf[ptr[0]] >> 2 & 7) + 4;\n        offset = (buf[ptr[0]++] & 224) << 3;\n        offset |= buf[ptr[0]++];\n      } else {\n        length = (buf[ptr[0]++] >> 2) + 1;\n        if (tag == 2) {\n          offset = buf[ptr[0]] | buf[ptr[0] + 1] << 8;\n          ptr[0] += 2;\n        } else {\n          offset = (buf[ptr[0]] | buf[ptr[0] + 1] << 8 | buf[ptr[0] + 2] << 16 | buf[ptr[0] + 3] << 24) >>> 0;\n          ptr[0] += 4;\n        }\n      }\n      chunks = [u8concat(chunks)];\n      if (offset == 0)\n        throw new Error(\"Invalid offset 0\");\n      if (offset > chunks[0].length)\n        throw new Error(\"Invalid offset beyond length\");\n      if (length >= offset) {\n        chunks.push(chunks[0].slice(-offset));\n        length -= offset;\n        while (length >= chunks[chunks.length - 1].length) {\n          chunks.push(chunks[chunks.length - 1]);\n          length -= chunks[chunks.length - 1].length;\n        }\n      }\n      chunks.push(chunks[0].slice(-offset, -offset + length));\n    }\n  }\n  var o = u8concat(chunks);\n  if (o.length != usz)\n    throw new Error(\"Unexpected length: \".concat(o.length, \" != \").concat(usz));\n  return o;\n}\nfunction decompress_iwa_file(buf) {\n  var out = [];\n  var l = 0;\n  while (l < buf.length) {\n    var t = buf[l++];\n    var len = buf[l] | buf[l + 1] << 8 | buf[l + 2] << 16;\n    l += 3;\n    out.push(parse_snappy_chunk(t, buf.slice(l, l + len)));\n    l += len;\n  }\n  if (l !== buf.length)\n    throw new Error(\"data is not a valid framed stream!\");\n  return u8concat(out);\n}\nfunction compress_iwa_file(buf) {\n  var out = [];\n  var l = 0;\n  while (l < buf.length) {\n    var c = Math.min(buf.length - l, 268435455);\n    var frame = new Uint8Array(4);\n    out.push(frame);\n    var usz = write_varint49(c);\n    var L = usz.length;\n    out.push(usz);\n    if (c <= 60) {\n      L++;\n      out.push(new Uint8Array([c - 1 << 2]));\n    } else if (c <= 256) {\n      L += 2;\n      out.push(new Uint8Array([240, c - 1 & 255]));\n    } else if (c <= 65536) {\n      L += 3;\n      out.push(new Uint8Array([244, c - 1 & 255, c - 1 >> 8 & 255]));\n    } else if (c <= 16777216) {\n      L += 4;\n      out.push(new Uint8Array([248, c - 1 & 255, c - 1 >> 8 & 255, c - 1 >> 16 & 255]));\n    } else if (c <= 4294967296) {\n      L += 5;\n      out.push(new Uint8Array([252, c - 1 & 255, c - 1 >> 8 & 255, c - 1 >> 16 & 255, c - 1 >>> 24 & 255]));\n    }\n    out.push(buf.slice(l, l + c));\n    L += c;\n    frame[0] = 0;\n    frame[1] = L & 255;\n    frame[2] = L >> 8 & 255;\n    frame[3] = L >> 16 & 255;\n    l += c;\n  }\n  return u8concat(out);\n}\nfunction parse_old_storage(buf, sst, rsst, v) {\n  var dv = u8_to_dataview(buf);\n  var flags = dv.getUint32(4, true);\n  var data_offset = (v > 1 ? 12 : 8) + popcnt(flags & (v > 1 ? 3470 : 398)) * 4;\n  var ridx = -1, sidx = -1, ieee = NaN, dt = new Date(2001, 0, 1);\n  if (flags & 512) {\n    ridx = dv.getUint32(data_offset, true);\n    data_offset += 4;\n  }\n  data_offset += popcnt(flags & (v > 1 ? 12288 : 4096)) * 4;\n  if (flags & 16) {\n    sidx = dv.getUint32(data_offset, true);\n    data_offset += 4;\n  }\n  if (flags & 32) {\n    ieee = dv.getFloat64(data_offset, true);\n    data_offset += 8;\n  }\n  if (flags & 64) {\n    dt.setTime(dt.getTime() + dv.getFloat64(data_offset, true) * 1e3);\n    data_offset += 8;\n  }\n  var ret;\n  switch (buf[2]) {\n    case 0:\n      break;\n    case 2:\n      ret = { t: \"n\", v: ieee };\n      break;\n    case 3:\n      ret = { t: \"s\", v: sst[sidx] };\n      break;\n    case 5:\n      ret = { t: \"d\", v: dt };\n      break;\n    case 6:\n      ret = { t: \"b\", v: ieee > 0 };\n      break;\n    case 7:\n      ret = { t: \"n\", v: ieee / 86400 };\n      break;\n    case 8:\n      ret = { t: \"e\", v: 0 };\n      break;\n    case 9:\n      {\n        if (ridx > -1)\n          ret = { t: \"s\", v: rsst[ridx] };\n        else if (sidx > -1)\n          ret = { t: \"s\", v: sst[sidx] };\n        else if (!isNaN(ieee))\n          ret = { t: \"n\", v: ieee };\n        else\n          throw new Error(\"Unsupported cell type \".concat(buf.slice(0, 4)));\n      }\n      break;\n    default:\n      throw new Error(\"Unsupported cell type \".concat(buf.slice(0, 4)));\n  }\n  return ret;\n}\nfunction parse_new_storage(buf, sst, rsst) {\n  var dv = u8_to_dataview(buf);\n  var flags = dv.getUint32(8, true);\n  var data_offset = 12;\n  var ridx = -1, sidx = -1, d128 = NaN, ieee = NaN, dt = new Date(2001, 0, 1);\n  if (flags & 1) {\n    d128 = readDecimal128LE(buf, data_offset);\n    data_offset += 16;\n  }\n  if (flags & 2) {\n    ieee = dv.getFloat64(data_offset, true);\n    data_offset += 8;\n  }\n  if (flags & 4) {\n    dt.setTime(dt.getTime() + dv.getFloat64(data_offset, true) * 1e3);\n    data_offset += 8;\n  }\n  if (flags & 8) {\n    sidx = dv.getUint32(data_offset, true);\n    data_offset += 4;\n  }\n  if (flags & 16) {\n    ridx = dv.getUint32(data_offset, true);\n    data_offset += 4;\n  }\n  var ret;\n  switch (buf[1]) {\n    case 0:\n      break;\n    case 2:\n      ret = { t: \"n\", v: d128 };\n      break;\n    case 3:\n      ret = { t: \"s\", v: sst[sidx] };\n      break;\n    case 5:\n      ret = { t: \"d\", v: dt };\n      break;\n    case 6:\n      ret = { t: \"b\", v: ieee > 0 };\n      break;\n    case 7:\n      ret = { t: \"n\", v: ieee / 86400 };\n      break;\n    case 8:\n      ret = { t: \"e\", v: 0 };\n      break;\n    case 9:\n      {\n        if (ridx > -1)\n          ret = { t: \"s\", v: rsst[ridx] };\n        else\n          throw new Error(\"Unsupported cell type \".concat(buf[1], \" : \").concat(flags & 31, \" : \").concat(buf.slice(0, 4)));\n      }\n      break;\n    case 10:\n      ret = { t: \"n\", v: d128 };\n      break;\n    default:\n      throw new Error(\"Unsupported cell type \".concat(buf[1], \" : \").concat(flags & 31, \" : \").concat(buf.slice(0, 4)));\n  }\n  return ret;\n}\nfunction write_new_storage(cell, sst) {\n  var out = new Uint8Array(32), dv = u8_to_dataview(out), l = 12, flags = 0;\n  out[0] = 5;\n  switch (cell.t) {\n    case \"n\":\n      out[1] = 2;\n      writeDecimal128LE(out, l, cell.v);\n      flags |= 1;\n      l += 16;\n      break;\n    case \"b\":\n      out[1] = 6;\n      dv.setFloat64(l, cell.v ? 1 : 0, true);\n      flags |= 2;\n      l += 8;\n      break;\n    case \"s\":\n      if (sst.indexOf(cell.v) == -1)\n        throw new Error(\"Value \".concat(cell.v, \" missing from SST!\"));\n      out[1] = 3;\n      dv.setUint32(l, sst.indexOf(cell.v), true);\n      flags |= 8;\n      l += 4;\n      break;\n    default:\n      throw \"unsupported cell type \" + cell.t;\n  }\n  dv.setUint32(8, flags, true);\n  return out.slice(0, l);\n}\nfunction write_old_storage(cell, sst) {\n  var out = new Uint8Array(32), dv = u8_to_dataview(out), l = 12, flags = 0;\n  out[0] = 3;\n  switch (cell.t) {\n    case \"n\":\n      out[2] = 2;\n      dv.setFloat64(l, cell.v, true);\n      flags |= 32;\n      l += 8;\n      break;\n    case \"b\":\n      out[2] = 6;\n      dv.setFloat64(l, cell.v ? 1 : 0, true);\n      flags |= 32;\n      l += 8;\n      break;\n    case \"s\":\n      if (sst.indexOf(cell.v) == -1)\n        throw new Error(\"Value \".concat(cell.v, \" missing from SST!\"));\n      out[2] = 3;\n      dv.setUint32(l, sst.indexOf(cell.v), true);\n      flags |= 16;\n      l += 4;\n      break;\n    default:\n      throw \"unsupported cell type \" + cell.t;\n  }\n  dv.setUint32(4, flags, true);\n  return out.slice(0, l);\n}\nfunction parse_cell_storage(buf, sst, rsst) {\n  switch (buf[0]) {\n    case 0:\n    case 1:\n    case 2:\n    case 3:\n      return parse_old_storage(buf, sst, rsst, buf[0]);\n    case 5:\n      return parse_new_storage(buf, sst, rsst);\n    default:\n      throw new Error(\"Unsupported payload version \".concat(buf[0]));\n  }\n}\nfunction parse_TSP_Reference(buf) {\n  var pb = parse_shallow(buf);\n  return parse_varint49(pb[1][0].data);\n}\nfunction write_TSP_Reference(idx) {\n  var out = [];\n  out[1] = [{ type: 0, data: write_varint49(idx) }];\n  return write_shallow(out);\n}\nfunction parse_TST_TableDataList(M, root) {\n  var pb = parse_shallow(root.data);\n  var type = varint_to_i32(pb[1][0].data);\n  var entries = pb[3];\n  var data = [];\n  (entries || []).forEach(function(entry) {\n    var le = parse_shallow(entry.data);\n    var key = varint_to_i32(le[1][0].data) >>> 0;\n    switch (type) {\n      case 1:\n        data[key] = u8str(le[3][0].data);\n        break;\n      case 8:\n        {\n          var rt = M[parse_TSP_Reference(le[9][0].data)][0];\n          var rtp = parse_shallow(rt.data);\n          var rtpref = M[parse_TSP_Reference(rtp[1][0].data)][0];\n          var mtype = varint_to_i32(rtpref.meta[1][0].data);\n          if (mtype != 2001)\n            throw new Error(\"2000 unexpected reference to \".concat(mtype));\n          var tswpsa = parse_shallow(rtpref.data);\n          data[key] = tswpsa[3].map(function(x) {\n            return u8str(x.data);\n          }).join(\"\");\n        }\n        break;\n    }\n  });\n  return data;\n}\nfunction parse_TST_TileRowInfo(u8, type) {\n  var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n;\n  var pb = parse_shallow(u8);\n  var R = varint_to_i32(pb[1][0].data) >>> 0;\n  var cnt = varint_to_i32(pb[2][0].data) >>> 0;\n  var wide_offsets = ((_b = (_a = pb[8]) == null ? void 0 : _a[0]) == null ? void 0 : _b.data) && varint_to_i32(pb[8][0].data) > 0 || false;\n  var used_storage_u8, used_storage;\n  if (((_d = (_c = pb[7]) == null ? void 0 : _c[0]) == null ? void 0 : _d.data) && type != 0) {\n    used_storage_u8 = (_f = (_e = pb[7]) == null ? void 0 : _e[0]) == null ? void 0 : _f.data;\n    used_storage = (_h = (_g = pb[6]) == null ? void 0 : _g[0]) == null ? void 0 : _h.data;\n  } else if (((_j = (_i = pb[4]) == null ? void 0 : _i[0]) == null ? void 0 : _j.data) && type != 1) {\n    used_storage_u8 = (_l = (_k = pb[4]) == null ? void 0 : _k[0]) == null ? void 0 : _l.data;\n    used_storage = (_n = (_m = pb[3]) == null ? void 0 : _m[0]) == null ? void 0 : _n.data;\n  } else\n    throw \"NUMBERS Tile missing \".concat(type, \" cell storage\");\n  var width = wide_offsets ? 4 : 1;\n  var used_storage_offsets = u8_to_dataview(used_storage_u8);\n  var offsets = [];\n  for (var C = 0; C < used_storage_u8.length / 2; ++C) {\n    var off = used_storage_offsets.getUint16(C * 2, true);\n    if (off < 65535)\n      offsets.push([C, off]);\n  }\n  if (offsets.length != cnt)\n    throw \"Expected \".concat(cnt, \" cells, found \").concat(offsets.length);\n  var cells = [];\n  for (C = 0; C < offsets.length - 1; ++C)\n    cells[offsets[C][0]] = used_storage.subarray(offsets[C][1] * width, offsets[C + 1][1] * width);\n  if (offsets.length >= 1)\n    cells[offsets[offsets.length - 1][0]] = used_storage.subarray(offsets[offsets.length - 1][1] * width);\n  return { R: R, cells: cells };\n}\nfunction parse_TST_Tile(M, root) {\n  var _a;\n  var pb = parse_shallow(root.data);\n  var storage = ((_a = pb == null ? void 0 : pb[7]) == null ? void 0 : _a[0]) ? varint_to_i32(pb[7][0].data) >>> 0 > 0 ? 1 : 0 : -1;\n  var ri = mappa(pb[5], function(u8) {\n    return parse_TST_TileRowInfo(u8, storage);\n  });\n  return {\n    nrows: varint_to_i32(pb[4][0].data) >>> 0,\n    data: ri.reduce(function(acc, x) {\n      if (!acc[x.R])\n        acc[x.R] = [];\n      x.cells.forEach(function(cell, C) {\n        if (acc[x.R][C])\n          throw new Error(\"Duplicate cell r=\".concat(x.R, \" c=\").concat(C));\n        acc[x.R][C] = cell;\n      });\n      return acc;\n    }, [])\n  };\n}\nfunction parse_TST_TableModelArchive(M, root, ws) {\n  var _a;\n  var pb = parse_shallow(root.data);\n  var range = { s: { r: 0, c: 0 }, e: { r: 0, c: 0 } };\n  range.e.r = (varint_to_i32(pb[6][0].data) >>> 0) - 1;\n  if (range.e.r < 0)\n    throw new Error(\"Invalid row varint \".concat(pb[6][0].data));\n  range.e.c = (varint_to_i32(pb[7][0].data) >>> 0) - 1;\n  if (range.e.c < 0)\n    throw new Error(\"Invalid col varint \".concat(pb[7][0].data));\n  ws[\"!ref\"] = encode_range(range);\n  var store = parse_shallow(pb[4][0].data);\n  var sst = parse_TST_TableDataList(M, M[parse_TSP_Reference(store[4][0].data)][0]);\n  var rsst = ((_a = store[17]) == null ? void 0 : _a[0]) ? parse_TST_TableDataList(M, M[parse_TSP_Reference(store[17][0].data)][0]) : [];\n  var tile = parse_shallow(store[3][0].data);\n  var _R = 0;\n  tile[1].forEach(function(t) {\n    var tl = parse_shallow(t.data);\n    var ref = M[parse_TSP_Reference(tl[2][0].data)][0];\n    var mtype = varint_to_i32(ref.meta[1][0].data);\n    if (mtype != 6002)\n      throw new Error(\"6001 unexpected reference to \".concat(mtype));\n    var _tile = parse_TST_Tile(M, ref);\n    _tile.data.forEach(function(row, R) {\n      row.forEach(function(buf, C) {\n        var addr = encode_cell({ r: _R + R, c: C });\n        var res = parse_cell_storage(buf, sst, rsst);\n        if (res)\n          ws[addr] = res;\n      });\n    });\n    _R += _tile.nrows;\n  });\n}\nfunction parse_TST_TableInfoArchive(M, root) {\n  var pb = parse_shallow(root.data);\n  var out = { \"!ref\": \"A1\" };\n  var tableref = M[parse_TSP_Reference(pb[2][0].data)];\n  var mtype = varint_to_i32(tableref[0].meta[1][0].data);\n  if (mtype != 6001)\n    throw new Error(\"6000 unexpected reference to \".concat(mtype));\n  parse_TST_TableModelArchive(M, tableref[0], out);\n  return out;\n}\nfunction parse_TN_SheetArchive(M, root) {\n  var _a;\n  var pb = parse_shallow(root.data);\n  var out = {\n    name: ((_a = pb[1]) == null ? void 0 : _a[0]) ? u8str(pb[1][0].data) : \"\",\n    sheets: []\n  };\n  var shapeoffs = mappa(pb[2], parse_TSP_Reference);\n  shapeoffs.forEach(function(off) {\n    M[off].forEach(function(m) {\n      var mtype = varint_to_i32(m.meta[1][0].data);\n      if (mtype == 6e3)\n        out.sheets.push(parse_TST_TableInfoArchive(M, m));\n    });\n  });\n  return out;\n}\nfunction parse_TN_DocumentArchive(M, root) {\n  var out = book_new();\n  var pb = parse_shallow(root.data);\n  var sheetoffs = mappa(pb[1], parse_TSP_Reference);\n  sheetoffs.forEach(function(off) {\n    M[off].forEach(function(m) {\n      var mtype = varint_to_i32(m.meta[1][0].data);\n      if (mtype == 2) {\n        var root2 = parse_TN_SheetArchive(M, m);\n        root2.sheets.forEach(function(sheet, idx) {\n          book_append_sheet(out, sheet, idx == 0 ? root2.name : root2.name + \"_\" + idx, true);\n        });\n      }\n    });\n  });\n  if (out.SheetNames.length == 0)\n    throw new Error(\"Empty NUMBERS file\");\n  return out;\n}\nfunction parse_numbers_iwa(cfb) {\n  var _a, _b, _c, _d;\n  var M = {}, indices = [];\n  cfb.FullPaths.forEach(function(p) {\n    if (p.match(/\\.iwpv2/))\n      throw new Error(\"Unsupported password protection\");\n  });\n  cfb.FileIndex.forEach(function(s) {\n    if (!s.name.match(/\\.iwa$/))\n      return;\n    var o;\n    try {\n      o = decompress_iwa_file(s.content);\n    } catch (e) {\n      return console.log(\"?? \" + s.content.length + \" \" + (e.message || e));\n    }\n    var packets;\n    try {\n      packets = parse_iwa_file(o);\n    } catch (e) {\n      return console.log(\"## \" + (e.message || e));\n    }\n    packets.forEach(function(packet) {\n      M[packet.id] = packet.messages;\n      indices.push(packet.id);\n    });\n  });\n  if (!indices.length)\n    throw new Error(\"File has no messages\");\n  var docroot = ((_d = (_c = (_b = (_a = M == null ? void 0 : M[1]) == null ? void 0 : _a[0]) == null ? void 0 : _b.meta) == null ? void 0 : _c[1]) == null ? void 0 : _d[0].data) && varint_to_i32(M[1][0].meta[1][0].data) == 1 && M[1][0];\n  if (!docroot)\n    indices.forEach(function(idx) {\n      M[idx].forEach(function(iwam) {\n        var mtype = varint_to_i32(iwam.meta[1][0].data) >>> 0;\n        if (mtype == 1) {\n          if (!docroot)\n            docroot = iwam;\n          else\n            throw new Error(\"Document has multiple roots\");\n        }\n      });\n    });\n  if (!docroot)\n    throw new Error(\"Cannot find Document root\");\n  return parse_TN_DocumentArchive(M, docroot);\n}\nfunction write_tile_row(tri, data, SST) {\n  var _a, _b, _c, _d;\n  if (!((_a = tri[6]) == null ? void 0 : _a[0]) || !((_b = tri[7]) == null ? void 0 : _b[0]))\n    throw \"Mutation only works on post-BNC storages!\";\n  var wide_offsets = ((_d = (_c = tri[8]) == null ? void 0 : _c[0]) == null ? void 0 : _d.data) && varint_to_i32(tri[8][0].data) > 0 || false;\n  if (wide_offsets)\n    throw \"Math only works with normal offsets\";\n  var cnt = 0;\n  var dv = u8_to_dataview(tri[7][0].data), last_offset = 0, cell_storage = [];\n  var _dv = u8_to_dataview(tri[4][0].data), _last_offset = 0, _cell_storage = [];\n  for (var C = 0; C < data.length; ++C) {\n    if (data[C] == null) {\n      dv.setUint16(C * 2, 65535, true);\n      _dv.setUint16(C * 2, 65535);\n      continue;\n    }\n    dv.setUint16(C * 2, last_offset, true);\n    _dv.setUint16(C * 2, _last_offset, true);\n    var celload, _celload;\n    switch (typeof data[C]) {\n      case \"string\":\n        celload = write_new_storage({ t: \"s\", v: data[C] }, SST);\n        _celload = write_old_storage({ t: \"s\", v: data[C] }, SST);\n        break;\n      case \"number\":\n        celload = write_new_storage({ t: \"n\", v: data[C] }, SST);\n        _celload = write_old_storage({ t: \"n\", v: data[C] }, SST);\n        break;\n      case \"boolean\":\n        celload = write_new_storage({ t: \"b\", v: data[C] }, SST);\n        _celload = write_old_storage({ t: \"b\", v: data[C] }, SST);\n        break;\n      default:\n        throw new Error(\"Unsupported value \" + data[C]);\n    }\n    cell_storage.push(celload);\n    last_offset += celload.length;\n    _cell_storage.push(_celload);\n    _last_offset += _celload.length;\n    ++cnt;\n  }\n  tri[2][0].data = write_varint49(cnt);\n  for (; C < tri[7][0].data.length / 2; ++C) {\n    dv.setUint16(C * 2, 65535, true);\n    _dv.setUint16(C * 2, 65535, true);\n  }\n  tri[6][0].data = u8concat(cell_storage);\n  tri[3][0].data = u8concat(_cell_storage);\n  return cnt;\n}\nfunction write_numbers_iwa(wb, opts) {\n  if (!opts || !opts.numbers)\n    throw new Error(\"Must pass a `numbers` option -- check the README\");\n  var ws = wb.Sheets[wb.SheetNames[0]];\n  if (wb.SheetNames.length > 1)\n    console.error(\"The Numbers writer currently writes only the first table\");\n  var range = decode_range(ws[\"!ref\"]);\n  range.s.r = range.s.c = 0;\n  var trunc = false;\n  if (range.e.c > 9) {\n    trunc = true;\n    range.e.c = 9;\n  }\n  if (range.e.r > 49) {\n    trunc = true;\n    range.e.r = 49;\n  }\n  if (trunc)\n    console.error(\"The Numbers writer is currently limited to \".concat(encode_range(range)));\n  var data = sheet_to_json(ws, { range: range, header: 1 });\n  var SST = [\"~Sh33tJ5~\"];\n  data.forEach(function(row) {\n    return row.forEach(function(cell) {\n      if (typeof cell == \"string\")\n        SST.push(cell);\n    });\n  });\n  var dependents = {};\n  var indices = [];\n  var cfb = CFB.read(opts.numbers, { type: \"base64\" });\n  cfb.FileIndex.map(function(fi, idx) {\n    return [fi, cfb.FullPaths[idx]];\n  }).forEach(function(row) {\n    var fi = row[0], fp = row[1];\n    if (fi.type != 2)\n      return;\n    if (!fi.name.match(/\\.iwa/))\n      return;\n    var old_content = fi.content;\n    var raw1 = decompress_iwa_file(old_content);\n    var x2 = parse_iwa_file(raw1);\n    x2.forEach(function(packet2) {\n      indices.push(packet2.id);\n      dependents[packet2.id] = { deps: [], location: fp, type: varint_to_i32(packet2.messages[0].meta[1][0].data) };\n    });\n  });\n  indices.sort(function(x2, y2) {\n    return x2 - y2;\n  });\n  var indices_varint = indices.filter(function(x2) {\n    return x2 > 1;\n  }).map(function(x2) {\n    return [x2, write_varint49(x2)];\n  });\n  cfb.FileIndex.map(function(fi, idx) {\n    return [fi, cfb.FullPaths[idx]];\n  }).forEach(function(row) {\n    var fi = row[0], fp = row[1];\n    if (!fi.name.match(/\\.iwa/))\n      return;\n    var x2 = parse_iwa_file(decompress_iwa_file(fi.content));\n    x2.forEach(function(ia) {\n      ia.messages.forEach(function(m) {\n        indices_varint.forEach(function(ivi) {\n          if (ia.messages.some(function(mess) {\n            return varint_to_i32(mess.meta[1][0].data) != 11006 && u8contains(mess.data, ivi[1]);\n          })) {\n            dependents[ivi[0]].deps.push(ia.id);\n          }\n        });\n      });\n    });\n  });\n  function get_unique_msgid() {\n    for (var i = 927262; i < 2e6; ++i)\n      if (!dependents[i])\n        return i;\n    throw new Error(\"Too many messages\");\n  }\n  var entry = CFB.find(cfb, dependents[1].location);\n  var x = parse_iwa_file(decompress_iwa_file(entry.content));\n  var docroot;\n  for (var xi = 0; xi < x.length; ++xi) {\n    var packet = x[xi];\n    if (packet.id == 1)\n      docroot = packet;\n  }\n  var sheetrootref = parse_TSP_Reference(parse_shallow(docroot.messages[0].data)[1][0].data);\n  entry = CFB.find(cfb, dependents[sheetrootref].location);\n  x = parse_iwa_file(decompress_iwa_file(entry.content));\n  for (xi = 0; xi < x.length; ++xi) {\n    packet = x[xi];\n    if (packet.id == sheetrootref)\n      docroot = packet;\n  }\n  sheetrootref = parse_TSP_Reference(parse_shallow(docroot.messages[0].data)[2][0].data);\n  entry = CFB.find(cfb, dependents[sheetrootref].location);\n  x = parse_iwa_file(decompress_iwa_file(entry.content));\n  for (xi = 0; xi < x.length; ++xi) {\n    packet = x[xi];\n    if (packet.id == sheetrootref)\n      docroot = packet;\n  }\n  sheetrootref = parse_TSP_Reference(parse_shallow(docroot.messages[0].data)[2][0].data);\n  entry = CFB.find(cfb, dependents[sheetrootref].location);\n  x = parse_iwa_file(decompress_iwa_file(entry.content));\n  for (xi = 0; xi < x.length; ++xi) {\n    packet = x[xi];\n    if (packet.id == sheetrootref)\n      docroot = packet;\n  }\n  var pb = parse_shallow(docroot.messages[0].data);\n  {\n    pb[6][0].data = write_varint49(range.e.r + 1);\n    pb[7][0].data = write_varint49(range.e.c + 1);\n    var cruidsref = parse_TSP_Reference(pb[46][0].data);\n    var oldbucket = CFB.find(cfb, dependents[cruidsref].location);\n    var _x = parse_iwa_file(decompress_iwa_file(oldbucket.content));\n    {\n      for (var j = 0; j < _x.length; ++j) {\n        if (_x[j].id == cruidsref)\n          break;\n      }\n      if (_x[j].id != cruidsref)\n        throw \"Bad ColumnRowUIDMapArchive\";\n      var cruids = parse_shallow(_x[j].messages[0].data);\n      cruids[1] = [];\n      cruids[2] = [], cruids[3] = [];\n      for (var C = 0; C <= range.e.c; ++C) {\n        var uuid = [];\n        uuid[1] = uuid[2] = [{ type: 0, data: write_varint49(C + 420690) }];\n        cruids[1].push({ type: 2, data: write_shallow(uuid) });\n        cruids[2].push({ type: 0, data: write_varint49(C) });\n        cruids[3].push({ type: 0, data: write_varint49(C) });\n      }\n      cruids[4] = [];\n      cruids[5] = [], cruids[6] = [];\n      for (var R = 0; R <= range.e.r; ++R) {\n        uuid = [];\n        uuid[1] = uuid[2] = [{ type: 0, data: write_varint49(R + 726270) }];\n        cruids[4].push({ type: 2, data: write_shallow(uuid) });\n        cruids[5].push({ type: 0, data: write_varint49(R) });\n        cruids[6].push({ type: 0, data: write_varint49(R) });\n      }\n      _x[j].messages[0].data = write_shallow(cruids);\n    }\n    oldbucket.content = compress_iwa_file(write_iwa_file(_x));\n    oldbucket.size = oldbucket.content.length;\n    delete pb[46];\n    var store = parse_shallow(pb[4][0].data);\n    {\n      store[7][0].data = write_varint49(range.e.r + 1);\n      var row_headers = parse_shallow(store[1][0].data);\n      var row_header_ref = parse_TSP_Reference(row_headers[2][0].data);\n      oldbucket = CFB.find(cfb, dependents[row_header_ref].location);\n      _x = parse_iwa_file(decompress_iwa_file(oldbucket.content));\n      {\n        if (_x[0].id != row_header_ref)\n          throw \"Bad HeaderStorageBucket\";\n        var base_bucket = parse_shallow(_x[0].messages[0].data);\n        for (R = 0; R < data.length; ++R) {\n          var _bucket = parse_shallow(base_bucket[2][0].data);\n          _bucket[1][0].data = write_varint49(R);\n          _bucket[4][0].data = write_varint49(data[R].length);\n          base_bucket[2][R] = { type: base_bucket[2][0].type, data: write_shallow(_bucket) };\n        }\n        _x[0].messages[0].data = write_shallow(base_bucket);\n      }\n      oldbucket.content = compress_iwa_file(write_iwa_file(_x));\n      oldbucket.size = oldbucket.content.length;\n      var col_header_ref = parse_TSP_Reference(store[2][0].data);\n      oldbucket = CFB.find(cfb, dependents[col_header_ref].location);\n      _x = parse_iwa_file(decompress_iwa_file(oldbucket.content));\n      {\n        if (_x[0].id != col_header_ref)\n          throw \"Bad HeaderStorageBucket\";\n        base_bucket = parse_shallow(_x[0].messages[0].data);\n        for (C = 0; C <= range.e.c; ++C) {\n          _bucket = parse_shallow(base_bucket[2][0].data);\n          _bucket[1][0].data = write_varint49(C);\n          _bucket[4][0].data = write_varint49(range.e.r + 1);\n          base_bucket[2][C] = { type: base_bucket[2][0].type, data: write_shallow(_bucket) };\n        }\n        _x[0].messages[0].data = write_shallow(base_bucket);\n      }\n      oldbucket.content = compress_iwa_file(write_iwa_file(_x));\n      oldbucket.size = oldbucket.content.length;\n      var sstref = parse_TSP_Reference(store[4][0].data);\n      (function() {\n        var sentry = CFB.find(cfb, dependents[sstref].location);\n        var sx = parse_iwa_file(decompress_iwa_file(sentry.content));\n        var sstroot;\n        for (var sxi = 0; sxi < sx.length; ++sxi) {\n          var packet2 = sx[sxi];\n          if (packet2.id == sstref)\n            sstroot = packet2;\n        }\n        var sstdata = parse_shallow(sstroot.messages[0].data);\n        {\n          sstdata[3] = [];\n          var newsst = [];\n          SST.forEach(function(str, i) {\n            newsst[1] = [{ type: 0, data: write_varint49(i) }];\n            newsst[2] = [{ type: 0, data: write_varint49(1) }];\n            newsst[3] = [{ type: 2, data: stru8(str) }];\n            sstdata[3].push({ type: 2, data: write_shallow(newsst) });\n          });\n        }\n        sstroot.messages[0].data = write_shallow(sstdata);\n        var sy = write_iwa_file(sx);\n        var raw32 = compress_iwa_file(sy);\n        sentry.content = raw32;\n        sentry.size = sentry.content.length;\n      })();\n      var tile = parse_shallow(store[3][0].data);\n      {\n        var t = tile[1][0];\n        delete tile[2];\n        var tl = parse_shallow(t.data);\n        {\n          var tileref = parse_TSP_Reference(tl[2][0].data);\n          (function() {\n            var tentry = CFB.find(cfb, dependents[tileref].location);\n            var tx = parse_iwa_file(decompress_iwa_file(tentry.content));\n            var tileroot;\n            for (var sxi = 0; sxi < tx.length; ++sxi) {\n              var packet2 = tx[sxi];\n              if (packet2.id == tileref)\n                tileroot = packet2;\n            }\n            var tiledata = parse_shallow(tileroot.messages[0].data);\n            {\n              delete tiledata[6];\n              delete tile[7];\n              var rowload = new Uint8Array(tiledata[5][0].data);\n              tiledata[5] = [];\n              var cnt = 0;\n              for (var R2 = 0; R2 <= range.e.r; ++R2) {\n                var tilerow = parse_shallow(rowload);\n                cnt += write_tile_row(tilerow, data[R2], SST);\n                tilerow[1][0].data = write_varint49(R2);\n                tiledata[5].push({ data: write_shallow(tilerow), type: 2 });\n              }\n              tiledata[1] = [{ type: 0, data: write_varint49(range.e.c + 1) }];\n              tiledata[2] = [{ type: 0, data: write_varint49(range.e.r + 1) }];\n              tiledata[3] = [{ type: 0, data: write_varint49(cnt) }];\n              tiledata[4] = [{ type: 0, data: write_varint49(range.e.r + 1) }];\n            }\n            tileroot.messages[0].data = write_shallow(tiledata);\n            var ty = write_iwa_file(tx);\n            var raw32 = compress_iwa_file(ty);\n            tentry.content = raw32;\n            tentry.size = tentry.content.length;\n          })();\n        }\n        t.data = write_shallow(tl);\n      }\n      store[3][0].data = write_shallow(tile);\n    }\n    pb[4][0].data = write_shallow(store);\n  }\n  docroot.messages[0].data = write_shallow(pb);\n  var y = write_iwa_file(x);\n  var raw3 = compress_iwa_file(y);\n  entry.content = raw3;\n  entry.size = entry.content.length;\n  return cfb;\n}\nfunction fix_opts_func(defaults/*:Array<Array<any> >*/)/*:{(o:any):void}*/ {\n\treturn function fix_opts(opts) {\n\t\tfor(var i = 0; i != defaults.length; ++i) {\n\t\t\tvar d = defaults[i];\n\t\t\tif(opts[d[0]] === undefined) opts[d[0]] = d[1];\n\t\t\tif(d[2] === 'n') opts[d[0]] = Number(opts[d[0]]);\n\t\t}\n\t};\n}\n\nfunction fix_read_opts(opts) {\nfix_opts_func([\n\t['cellNF', false], /* emit cell number format string as .z */\n\t['cellHTML', true], /* emit html string as .h */\n\t['cellFormula', true], /* emit formulae as .f */\n\t['cellStyles', false], /* emits style/theme as .s */\n\t['cellText', true], /* emit formatted text as .w */\n\t['cellDates', false], /* emit date cells with type `d` */\n\n\t['sheetStubs', false], /* emit empty cells */\n\t['sheetRows', 0, 'n'], /* read n rows (0 = read all rows) */\n\n\t['bookDeps', false], /* parse calculation chains */\n\t['bookSheets', false], /* only try to get sheet names (no Sheets) */\n\t['bookProps', false], /* only try to get properties (no Sheets) */\n\t['bookFiles', false], /* include raw file structure (keys, files, cfb) */\n\t['bookVBA', false], /* include vba raw data (vbaraw) */\n\n\t['password',''], /* password */\n\t['WTF', false] /* WTF mode (throws errors) */\n])(opts);\n}\n\nfunction fix_write_opts(opts) {\nfix_opts_func([\n\t['cellDates', false], /* write date cells with type `d` */\n\n\t['bookSST', false], /* Generate Shared String Table */\n\n\t['bookType', 'xlsx'], /* Type of workbook (xlsx/m/b) */\n\n\t['compression', false], /* Use file compression */\n\n\t['WTF', false] /* WTF mode (throws errors) */\n])(opts);\n}\nfunction get_sheet_type(n/*:string*/)/*:string*/ {\n\tif(RELS.WS.indexOf(n) > -1) return \"sheet\";\n\tif(RELS.CS && n == RELS.CS) return \"chart\";\n\tif(RELS.DS && n == RELS.DS) return \"dialog\";\n\tif(RELS.MS && n == RELS.MS) return \"macro\";\n\treturn (n && n.length) ? n : \"sheet\";\n}\nfunction safe_parse_wbrels(wbrels, sheets) {\n\tif(!wbrels) return 0;\n\ttry {\n\t\twbrels = sheets.map(function pwbr(w) { if(!w.id) w.id = w.strRelID; return [w.name, wbrels['!id'][w.id].Target, get_sheet_type(wbrels['!id'][w.id].Type)]; });\n\t} catch(e) { return null; }\n\treturn !wbrels || wbrels.length === 0 ? null : wbrels;\n}\n\nfunction safe_parse_sheet(zip, path/*:string*/, relsPath/*:string*/, sheet, idx/*:number*/, sheetRels, sheets, stype/*:string*/, opts, wb, themes, styles) {\n\ttry {\n\t\tsheetRels[sheet]=parse_rels(getzipstr(zip, relsPath, true), path);\n\t\tvar data = getzipdata(zip, path);\n\t\tvar _ws;\n\t\tswitch(stype) {\n\t\t\tcase 'sheet':  _ws = parse_ws(data, path, idx, opts, sheetRels[sheet], wb, themes, styles); break;\n\t\t\tcase 'chart':  _ws = parse_cs(data, path, idx, opts, sheetRels[sheet], wb, themes, styles);\n\t\t\t\tif(!_ws || !_ws['!drawel']) break;\n\t\t\t\tvar dfile = resolve_path(_ws['!drawel'].Target, path);\n\t\t\t\tvar drelsp = get_rels_path(dfile);\n\t\t\t\tvar draw = parse_drawing(getzipstr(zip, dfile, true), parse_rels(getzipstr(zip, drelsp, true), dfile));\n\t\t\t\tvar chartp = resolve_path(draw, dfile);\n\t\t\t\tvar crelsp = get_rels_path(chartp);\n\t\t\t\t_ws = parse_chart(getzipstr(zip, chartp, true), chartp, opts, parse_rels(getzipstr(zip, crelsp, true), chartp), wb, _ws);\n\t\t\t\tbreak;\n\t\t\tcase 'macro':  _ws = parse_ms(data, path, idx, opts, sheetRels[sheet], wb, themes, styles); break;\n\t\t\tcase 'dialog': _ws = parse_ds(data, path, idx, opts, sheetRels[sheet], wb, themes, styles); break;\n\t\t\tdefault: throw new Error(\"Unrecognized sheet type \" + stype);\n\t\t}\n\t\tsheets[sheet] = _ws;\n\n\t\t/* scan rels for comments and threaded comments */\n\t\tvar tcomments = [];\n\t\tif(sheetRels && sheetRels[sheet]) keys(sheetRels[sheet]).forEach(function(n) {\n\t\t\tvar dfile = \"\";\n\t\t\tif(sheetRels[sheet][n].Type == RELS.CMNT) {\n\t\t\t\tdfile = resolve_path(sheetRels[sheet][n].Target, path);\n\t\t\t\tvar comments = parse_cmnt(getzipdata(zip, dfile, true), dfile, opts);\n\t\t\t\tif(!comments || !comments.length) return;\n\t\t\t\tsheet_insert_comments(_ws, comments, false);\n\t\t\t}\n\t\t\tif(sheetRels[sheet][n].Type == RELS.TCMNT) {\n\t\t\t\tdfile = resolve_path(sheetRels[sheet][n].Target, path);\n\t\t\t\ttcomments = tcomments.concat(parse_tcmnt_xml(getzipdata(zip, dfile, true), opts));\n\t\t\t}\n\t\t});\n\t\tif(tcomments && tcomments.length) sheet_insert_comments(_ws, tcomments, true, opts.people || []);\n\t} catch(e) { if(opts.WTF) throw e; }\n}\n\nfunction strip_front_slash(x/*:string*/)/*:string*/ { return x.charAt(0) == '/' ? x.slice(1) : x; }\n\nfunction parse_zip(zip/*:ZIP*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tmake_ssf();\n\topts = opts || {};\n\tfix_read_opts(opts);\n\n\t/* OpenDocument Part 3 Section 2.2.1 OpenDocument Package */\n\tif(safegetzipfile(zip, 'META-INF/manifest.xml')) return parse_ods(zip, opts);\n\t/* UOC */\n\tif(safegetzipfile(zip, 'objectdata.xml')) return parse_ods(zip, opts);\n\t/* Numbers */\n\tif(safegetzipfile(zip, 'Index/Document.iwa')) {\n\t\tif(typeof Uint8Array == \"undefined\") throw new Error('NUMBERS file parsing requires Uint8Array support');\n\t\tif(typeof parse_numbers_iwa != \"undefined\") {\n\t\t\tif(zip.FileIndex) return parse_numbers_iwa(zip);\n\t\t\tvar _zip = CFB.utils.cfb_new();\n\t\t\tzipentries(zip).forEach(function(e) { zip_add_file(_zip, e, getzipbin(zip, e)); });\n\t\t\treturn parse_numbers_iwa(_zip);\n\t\t}\n\t\tthrow new Error('Unsupported NUMBERS file');\n\t}\n\tif(!safegetzipfile(zip, '[Content_Types].xml')) {\n\t\tif(safegetzipfile(zip, 'index.xml.gz')) throw new Error('Unsupported NUMBERS 08 file');\n\t\tif(safegetzipfile(zip, 'index.xml')) throw new Error('Unsupported NUMBERS 09 file');\n\t\tthrow new Error('Unsupported ZIP file');\n\t}\n\n\tvar entries = zipentries(zip);\n\tvar dir = parse_ct((getzipstr(zip, '[Content_Types].xml')/*:?any*/));\n\tvar xlsb = false;\n\tvar sheets, binname;\n\tif(dir.workbooks.length === 0) {\n\t\tbinname = \"xl/workbook.xml\";\n\t\tif(getzipdata(zip,binname, true)) dir.workbooks.push(binname);\n\t}\n\tif(dir.workbooks.length === 0) {\n\t\tbinname = \"xl/workbook.bin\";\n\t\tif(!getzipdata(zip,binname,true)) throw new Error(\"Could not find workbook\");\n\t\tdir.workbooks.push(binname);\n\t\txlsb = true;\n\t}\n\tif(dir.workbooks[0].slice(-3) == \"bin\") xlsb = true;\n\n\tvar themes = ({}/*:any*/);\n\tvar styles = ({}/*:any*/);\n\tif(!opts.bookSheets && !opts.bookProps) {\n\t\tstrs = [];\n\t\tif(dir.sst) try { strs=parse_sst(getzipdata(zip, strip_front_slash(dir.sst)), dir.sst, opts); } catch(e) { if(opts.WTF) throw e; }\n\n\t\tif(opts.cellStyles && dir.themes.length) themes = parse_theme(getzipstr(zip, dir.themes[0].replace(/^\\//,''), true)||\"\",dir.themes[0], opts);\n\n\t\tif(dir.style) styles = parse_sty(getzipdata(zip, strip_front_slash(dir.style)), dir.style, themes, opts);\n\t}\n\n\t/*var externbooks = */dir.links.map(function(link) {\n\t\ttry {\n\t\t\tvar rels = parse_rels(getzipstr(zip, get_rels_path(strip_front_slash(link))), link);\n\t\t\treturn parse_xlink(getzipdata(zip, strip_front_slash(link)), rels, link, opts);\n\t\t} catch(e) {}\n\t});\n\n\tvar wb = parse_wb(getzipdata(zip, strip_front_slash(dir.workbooks[0])), dir.workbooks[0], opts);\n\n\tvar props = {}, propdata = \"\";\n\n\tif(dir.coreprops.length) {\n\t\tpropdata = getzipdata(zip, strip_front_slash(dir.coreprops[0]), true);\n\t\tif(propdata) props = parse_core_props(propdata);\n\t\tif(dir.extprops.length !== 0) {\n\t\t\tpropdata = getzipdata(zip, strip_front_slash(dir.extprops[0]), true);\n\t\t\tif(propdata) parse_ext_props(propdata, props, opts);\n\t\t}\n\t}\n\n\tvar custprops = {};\n\tif(!opts.bookSheets || opts.bookProps) {\n\t\tif (dir.custprops.length !== 0) {\n\t\t\tpropdata = getzipstr(zip, strip_front_slash(dir.custprops[0]), true);\n\t\t\tif(propdata) custprops = parse_cust_props(propdata, opts);\n\t\t}\n\t}\n\n\tvar out = ({}/*:any*/);\n\tif(opts.bookSheets || opts.bookProps) {\n\t\tif(wb.Sheets) sheets = wb.Sheets.map(function pluck(x){ return x.name; });\n\t\telse if(props.Worksheets && props.SheetNames.length > 0) sheets=props.SheetNames;\n\t\tif(opts.bookProps) { out.Props = props; out.Custprops = custprops; }\n\t\tif(opts.bookSheets && typeof sheets !== 'undefined') out.SheetNames = sheets;\n\t\tif(opts.bookSheets ? out.SheetNames : opts.bookProps) return out;\n\t}\n\tsheets = {};\n\n\tvar deps = {};\n\tif(opts.bookDeps && dir.calcchain) deps=parse_cc(getzipdata(zip, strip_front_slash(dir.calcchain)),dir.calcchain,opts);\n\n\tvar i=0;\n\tvar sheetRels = ({}/*:any*/);\n\tvar path, relsPath;\n\n\t{\n\t\tvar wbsheets = wb.Sheets;\n\t\tprops.Worksheets = wbsheets.length;\n\t\tprops.SheetNames = [];\n\t\tfor(var j = 0; j != wbsheets.length; ++j) {\n\t\t\tprops.SheetNames[j] = wbsheets[j].name;\n\t\t}\n\t}\n\n\tvar wbext = xlsb ? \"bin\" : \"xml\";\n\tvar wbrelsi = dir.workbooks[0].lastIndexOf(\"/\");\n\tvar wbrelsfile = (dir.workbooks[0].slice(0, wbrelsi+1) + \"_rels/\" + dir.workbooks[0].slice(wbrelsi+1) + \".rels\").replace(/^\\//,\"\");\n\tif(!safegetzipfile(zip, wbrelsfile)) wbrelsfile = 'xl/_rels/workbook.' + wbext + '.rels';\n\tvar wbrels = parse_rels(getzipstr(zip, wbrelsfile, true), wbrelsfile.replace(/_rels.*/, \"s5s\"));\n\n\tif((dir.metadata || []).length >= 1) {\n\t\t/* TODO: MDX and other types of metadata */\n\t\topts.xlmeta = parse_xlmeta(getzipdata(zip, strip_front_slash(dir.metadata[0])),dir.metadata[0],opts);\n\t}\n\n\tif((dir.people || []).length >= 1) {\n\t\topts.people = parse_people_xml(getzipdata(zip, strip_front_slash(dir.people[0])),opts);\n\t}\n\n\tif(wbrels) wbrels = safe_parse_wbrels(wbrels, wb.Sheets);\n\n\t/* Numbers iOS hack */\n\tvar nmode = (getzipdata(zip,\"xl/worksheets/sheet.xml\",true))?1:0;\n\twsloop: for(i = 0; i != props.Worksheets; ++i) {\n\t\tvar stype = \"sheet\";\n\t\tif(wbrels && wbrels[i]) {\n\t\t\tpath = 'xl/' + (wbrels[i][1]).replace(/[\\/]?xl\\//, \"\");\n\t\t\tif(!safegetzipfile(zip, path)) path = wbrels[i][1];\n\t\t\tif(!safegetzipfile(zip, path)) path = wbrelsfile.replace(/_rels\\/.*$/,\"\") + wbrels[i][1];\n\t\t\tstype = wbrels[i][2];\n\t\t} else {\n\t\t\tpath = 'xl/worksheets/sheet'+(i+1-nmode)+\".\" + wbext;\n\t\t\tpath = path.replace(/sheet0\\./,\"sheet.\");\n\t\t}\n\t\trelsPath = path.replace(/^(.*)(\\/)([^\\/]*)$/, \"$1/_rels/$3.rels\");\n\t\tif(opts && opts.sheets != null) switch(typeof opts.sheets) {\n\t\t\tcase \"number\": if(i != opts.sheets) continue wsloop; break;\n\t\t\tcase \"string\": if(props.SheetNames[i].toLowerCase() != opts.sheets.toLowerCase()) continue wsloop; break;\n\t\t\tdefault: if(Array.isArray && Array.isArray(opts.sheets)) {\n\t\t\t\tvar snjseen = false;\n\t\t\t\tfor(var snj = 0; snj != opts.sheets.length; ++snj) {\n\t\t\t\t\tif(typeof opts.sheets[snj] == \"number\" && opts.sheets[snj] == i) snjseen=1;\n\t\t\t\t\tif(typeof opts.sheets[snj] == \"string\" && opts.sheets[snj].toLowerCase() == props.SheetNames[i].toLowerCase()) snjseen = 1;\n\t\t\t\t}\n\t\t\t\tif(!snjseen) continue wsloop;\n\t\t\t}\n\t\t}\n\t\tsafe_parse_sheet(zip, path, relsPath, props.SheetNames[i], i, sheetRels, sheets, stype, opts, wb, themes, styles);\n\t}\n\n\tout = ({\n\t\tDirectory: dir,\n\t\tWorkbook: wb,\n\t\tProps: props,\n\t\tCustprops: custprops,\n\t\tDeps: deps,\n\t\tSheets: sheets,\n\t\tSheetNames: props.SheetNames,\n\t\tStrings: strs,\n\t\tStyles: styles,\n\t\tThemes: themes,\n\t\tSSF: dup(table_fmt)\n\t}/*:any*/);\n\tif(opts && opts.bookFiles) {\n\t\tif(zip.files) {\n\t\t\tout.keys = entries;\n\t\t\tout.files = zip.files;\n\t\t} else {\n\t\t\tout.keys = [];\n\t\t\tout.files = {};\n\t\t\tzip.FullPaths.forEach(function(p, idx) {\n\t\t\t\tp = p.replace(/^Root Entry[\\/]/, \"\");\n\t\t\t\tout.keys.push(p);\n\t\t\t\tout.files[p] = zip.FileIndex[idx];\n\t\t\t});\n\t\t}\n\t}\n\tif(opts && opts.bookVBA) {\n\t\tif(dir.vba.length > 0) out.vbaraw = getzipdata(zip,strip_front_slash(dir.vba[0]),true);\n\t\telse if(dir.defaults && dir.defaults.bin === CT_VBA) out.vbaraw = getzipdata(zip, 'xl/vbaProject.bin',true);\n\t}\n\treturn out;\n}\n\n/* [MS-OFFCRYPTO] 2.1.1 */\nfunction parse_xlsxcfb(cfb, _opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tvar opts = _opts || {};\n\tvar f = 'Workbook', data = CFB.find(cfb, f);\n\ttry {\n\tf = '/!DataSpaces/Version';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\t/*var version = */parse_DataSpaceVersionInfo(data.content);\n\n\t/* 2.3.4.1 */\n\tf = '/!DataSpaces/DataSpaceMap';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\tvar dsm = parse_DataSpaceMap(data.content);\n\tif(dsm.length !== 1 || dsm[0].comps.length !== 1 || dsm[0].comps[0].t !== 0 || dsm[0].name !== \"StrongEncryptionDataSpace\" || dsm[0].comps[0].v !== \"EncryptedPackage\")\n\t\tthrow new Error(\"ECMA-376 Encrypted file bad \" + f);\n\n\t/* 2.3.4.2 */\n\tf = '/!DataSpaces/DataSpaceInfo/StrongEncryptionDataSpace';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\tvar seds = parse_DataSpaceDefinition(data.content);\n\tif(seds.length != 1 || seds[0] != \"StrongEncryptionTransform\")\n\t\tthrow new Error(\"ECMA-376 Encrypted file bad \" + f);\n\n\t/* 2.3.4.3 */\n\tf = '/!DataSpaces/TransformInfo/StrongEncryptionTransform/!Primary';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\t/*var hdr = */parse_Primary(data.content);\n\t} catch(e) {}\n\n\tf = '/EncryptionInfo';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\tvar einfo = parse_EncryptionInfo(data.content);\n\n\t/* 2.3.4.4 */\n\tf = '/EncryptedPackage';\n\tdata = CFB.find(cfb, f); if(!data || !data.content) throw new Error(\"ECMA-376 Encrypted file missing \" + f);\n\n/*global decrypt_agile */\n/*:: declare var decrypt_agile:any; */\n\tif(einfo[0] == 0x04 && typeof decrypt_agile !== 'undefined') return decrypt_agile(einfo[1], data.content, opts.password || \"\", opts);\n/*global decrypt_std76 */\n/*:: declare var decrypt_std76:any; */\n\tif(einfo[0] == 0x02 && typeof decrypt_std76 !== 'undefined') return decrypt_std76(einfo[1], data.content, opts.password || \"\", opts);\n\tthrow new Error(\"File is password-protected\");\n}\n\nfunction write_zip(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:ZIP*/ {\n\tif(opts.bookType == \"ods\") return write_ods(wb, opts);\n\tif(opts.bookType == \"numbers\") return write_numbers_iwa(wb, opts);\n\tif(opts.bookType == \"xlsb\") return write_zip_xlsxb(wb, opts);\n\treturn write_zip_xlsx(wb, opts);\n}\n\n/* XLSX and XLSB writing are very similar.  Originally they were unified in one\n   export function.  This is horrible for tree shaking in the common case (most\n   applications need to export files in one format) so this function supports\n   both formats while write_zip_xlsx only handles XLSX */\nfunction write_zip_xlsxb(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:ZIP*/ {\n\t_shapeid = 1024;\n\tif(wb && !wb.SSF) {\n\t\twb.SSF = dup(table_fmt);\n\t}\n\tif(wb && wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\topts.revssf = evert_num(wb.SSF); opts.revssf[wb.SSF[65535]] = 0;\n\t\topts.ssf = wb.SSF;\n\t}\n\topts.rels = {}; opts.wbrels = {};\n\topts.Strings = /*::((*/[]/*:: :any):SST)*/; opts.Strings.Count = 0; opts.Strings.Unique = 0;\n\tif(browser_has_Map) opts.revStrings = new Map();\n\telse { opts.revStrings = {}; opts.revStrings.foo = []; delete opts.revStrings.foo; }\n\tvar wbext = opts.bookType == \"xlsb\" ? \"bin\" : \"xml\";\n\tvar vbafmt = VBAFMTS.indexOf(opts.bookType) > -1;\n\tvar ct = new_ct();\n\tfix_write_opts(opts = opts || {});\n\tvar zip = zip_new();\n\tvar f = \"\", rId = 0;\n\n\topts.cellXfs = [];\n\tget_cell_style(opts.cellXfs, {}, {revssf:{\"General\":0}});\n\n\tif(!wb.Props) wb.Props = {};\n\n\tf = \"docProps/core.xml\";\n\tzip_add_file(zip, f, write_core_props(wb.Props, opts));\n\tct.coreprops.push(f);\n\tadd_rels(opts.rels, 2, f, RELS.CORE_PROPS);\n\n\t/*::if(!wb.Props) throw \"unreachable\"; */\n\tf = \"docProps/app.xml\";\n\tif(wb.Props && wb.Props.SheetNames){/* empty */}\n\telse if(!wb.Workbook || !wb.Workbook.Sheets) wb.Props.SheetNames = wb.SheetNames;\n\telse {\n\t\tvar _sn = [];\n\t\tfor(var _i = 0; _i < wb.SheetNames.length; ++_i)\n\t\t\tif((wb.Workbook.Sheets[_i]||{}).Hidden != 2) _sn.push(wb.SheetNames[_i]);\n\t\twb.Props.SheetNames = _sn;\n\t}\n\twb.Props.Worksheets = wb.Props.SheetNames.length;\n\tzip_add_file(zip, f, write_ext_props(wb.Props, opts));\n\tct.extprops.push(f);\n\tadd_rels(opts.rels, 3, f, RELS.EXT_PROPS);\n\n\tif(wb.Custprops !== wb.Props && keys(wb.Custprops||{}).length > 0) {\n\t\tf = \"docProps/custom.xml\";\n\t\tzip_add_file(zip, f, write_cust_props(wb.Custprops, opts));\n\t\tct.custprops.push(f);\n\t\tadd_rels(opts.rels, 4, f, RELS.CUST_PROPS);\n\t}\n\n\tfor(rId=1;rId <= wb.SheetNames.length; ++rId) {\n\t\tvar wsrels = {'!id':{}};\n\t\tvar ws = wb.Sheets[wb.SheetNames[rId-1]];\n\t\tvar _type = (ws || {})[\"!type\"] || \"sheet\";\n\t\tswitch(_type) {\n\t\tcase \"chart\":\n\t\t\t/* falls through */\n\t\tdefault:\n\t\t\tf = \"xl/worksheets/sheet\" + rId + \".\" + wbext;\n\t\t\tzip_add_file(zip, f, write_ws(rId-1, f, opts, wb, wsrels));\n\t\t\tct.sheets.push(f);\n\t\t\tadd_rels(opts.wbrels, -1, \"worksheets/sheet\" + rId + \".\" + wbext, RELS.WS[0]);\n\t\t}\n\n\t\tif(ws) {\n\t\t\tvar comments = ws['!comments'];\n\t\t\tvar need_vml = false;\n\t\t\tvar cf = \"\";\n\t\t\tif(comments && comments.length > 0) {\n\t\t\t\tcf = \"xl/comments\" + rId + \".\" + wbext;\n\t\t\t\tzip_add_file(zip, cf, write_cmnt(comments, cf, opts));\n\t\t\t\tct.comments.push(cf);\n\t\t\t\tadd_rels(wsrels, -1, \"../comments\" + rId + \".\" + wbext, RELS.CMNT);\n\t\t\t\tneed_vml = true;\n\t\t\t}\n\t\t\tif(ws['!legacy']) {\n\t\t\t\tif(need_vml) zip_add_file(zip, \"xl/drawings/vmlDrawing\" + (rId) + \".vml\", write_comments_vml(rId, ws['!comments']));\n\t\t\t}\n\t\t\tdelete ws['!comments'];\n\t\t\tdelete ws['!legacy'];\n\t\t}\n\n\t\tif(wsrels['!id'].rId1) zip_add_file(zip, get_rels_path(f), write_rels(wsrels));\n\t}\n\n\tif(opts.Strings != null && opts.Strings.length > 0) {\n\t\tf = \"xl/sharedStrings.\" + wbext;\n\t\tzip_add_file(zip, f, write_sst(opts.Strings, f, opts));\n\t\tct.strs.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"sharedStrings.\" + wbext, RELS.SST);\n\t}\n\n\tf = \"xl/workbook.\" + wbext;\n\tzip_add_file(zip, f, write_wb(wb, f, opts));\n\tct.workbooks.push(f);\n\tadd_rels(opts.rels, 1, f, RELS.WB);\n\n\t/* TODO: something more intelligent with themes */\n\n\tf = \"xl/theme/theme1.xml\";\n\tzip_add_file(zip, f, write_theme(wb.Themes, opts));\n\tct.themes.push(f);\n\tadd_rels(opts.wbrels, -1, \"theme/theme1.xml\", RELS.THEME);\n\n\t/* TODO: something more intelligent with styles */\n\n\tf = \"xl/styles.\" + wbext;\n\tzip_add_file(zip, f, write_sty(wb, f, opts));\n\tct.styles.push(f);\n\tadd_rels(opts.wbrels, -1, \"styles.\" + wbext, RELS.STY);\n\n\tif(wb.vbaraw && vbafmt) {\n\t\tf = \"xl/vbaProject.bin\";\n\t\tzip_add_file(zip, f, wb.vbaraw);\n\t\tct.vba.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"vbaProject.bin\", RELS.VBA);\n\t}\n\n\tf = \"xl/metadata.\" + wbext;\n\tzip_add_file(zip, f, write_xlmeta(f));\n\tct.metadata.push(f);\n\tadd_rels(opts.wbrels, -1, \"metadata.\" + wbext, RELS.XLMETA);\n\n\tzip_add_file(zip, \"[Content_Types].xml\", write_ct(ct, opts));\n\tzip_add_file(zip, '_rels/.rels', write_rels(opts.rels));\n\tzip_add_file(zip, 'xl/_rels/workbook.' + wbext + '.rels', write_rels(opts.wbrels));\n\n\tdelete opts.revssf; delete opts.ssf;\n\treturn zip;\n}\n\nfunction write_zip_xlsx(wb/*:Workbook*/, opts/*:WriteOpts*/)/*:ZIP*/ {\n\t_shapeid = 1024;\n\tif(wb && !wb.SSF) {\n\t\twb.SSF = dup(table_fmt);\n\t}\n\tif(wb && wb.SSF) {\n\t\tmake_ssf(); SSF_load_table(wb.SSF);\n\t\t// $FlowIgnore\n\t\topts.revssf = evert_num(wb.SSF); opts.revssf[wb.SSF[65535]] = 0;\n\t\topts.ssf = wb.SSF;\n\t}\n\topts.rels = {}; opts.wbrels = {};\n\topts.Strings = /*::((*/[]/*:: :any):SST)*/; opts.Strings.Count = 0; opts.Strings.Unique = 0;\n\tif(browser_has_Map) opts.revStrings = new Map();\n\telse { opts.revStrings = {}; opts.revStrings.foo = []; delete opts.revStrings.foo; }\n\tvar wbext = \"xml\";\n\tvar vbafmt = VBAFMTS.indexOf(opts.bookType) > -1;\n\tvar ct = new_ct();\n\tfix_write_opts(opts = opts || {});\n\tvar zip = zip_new();\n\tvar f = \"\", rId = 0;\n\n\topts.cellXfs = [];\n\tget_cell_style(opts.cellXfs, {}, {revssf:{\"General\":0}});\n\n\tif(!wb.Props) wb.Props = {};\n\n\tf = \"docProps/core.xml\";\n\tzip_add_file(zip, f, write_core_props(wb.Props, opts));\n\tct.coreprops.push(f);\n\tadd_rels(opts.rels, 2, f, RELS.CORE_PROPS);\n\n\t/*::if(!wb.Props) throw \"unreachable\"; */\n\tf = \"docProps/app.xml\";\n\tif(wb.Props && wb.Props.SheetNames){/* empty */}\n\telse if(!wb.Workbook || !wb.Workbook.Sheets) wb.Props.SheetNames = wb.SheetNames;\n\telse {\n\t\tvar _sn = [];\n\t\tfor(var _i = 0; _i < wb.SheetNames.length; ++_i)\n\t\t\tif((wb.Workbook.Sheets[_i]||{}).Hidden != 2) _sn.push(wb.SheetNames[_i]);\n\t\twb.Props.SheetNames = _sn;\n\t}\n\twb.Props.Worksheets = wb.Props.SheetNames.length;\n\tzip_add_file(zip, f, write_ext_props(wb.Props, opts));\n\tct.extprops.push(f);\n\tadd_rels(opts.rels, 3, f, RELS.EXT_PROPS);\n\n\tif(wb.Custprops !== wb.Props && keys(wb.Custprops||{}).length > 0) {\n\t\tf = \"docProps/custom.xml\";\n\t\tzip_add_file(zip, f, write_cust_props(wb.Custprops, opts));\n\t\tct.custprops.push(f);\n\t\tadd_rels(opts.rels, 4, f, RELS.CUST_PROPS);\n\t}\n\n\tvar people = [\"SheetJ5\"];\n\topts.tcid = 0;\n\n\tfor(rId=1;rId <= wb.SheetNames.length; ++rId) {\n\t\tvar wsrels = {'!id':{}};\n\t\tvar ws = wb.Sheets[wb.SheetNames[rId-1]];\n\t\tvar _type = (ws || {})[\"!type\"] || \"sheet\";\n\t\tswitch(_type) {\n\t\tcase \"chart\":\n\t\t\t/* falls through */\n\t\tdefault:\n\t\t\tf = \"xl/worksheets/sheet\" + rId + \".\" + wbext;\n\t\t\tzip_add_file(zip, f, write_ws_xml(rId-1, opts, wb, wsrels));\n\t\t\tct.sheets.push(f);\n\t\t\tadd_rels(opts.wbrels, -1, \"worksheets/sheet\" + rId + \".\" + wbext, RELS.WS[0]);\n\t\t}\n\n\t\tif(ws) {\n\t\t\tvar comments = ws['!comments'];\n\t\t\tvar need_vml = false;\n\t\t\tvar cf = \"\";\n\t\t\tif(comments && comments.length > 0) {\n\t\t\t\tvar needtc = false;\n\t\t\t\tcomments.forEach(function(carr) {\n\t\t\t\t\tcarr[1].forEach(function(c) { if(c.T == true) needtc = true; });\n\t\t\t\t});\n\t\t\t\tif(needtc) {\n\t\t\t\t\tcf = \"xl/threadedComments/threadedComment\" + rId + \".\" + wbext;\n\t\t\t\t\tzip_add_file(zip, cf, write_tcmnt_xml(comments, people, opts));\n\t\t\t\t\tct.threadedcomments.push(cf);\n\t\t\t\t\tadd_rels(wsrels, -1, \"../threadedComments/threadedComment\" + rId + \".\" + wbext, RELS.TCMNT);\n\t\t\t\t}\n\n\t\t\t\tcf = \"xl/comments\" + rId + \".\" + wbext;\n\t\t\t\tzip_add_file(zip, cf, write_comments_xml(comments, opts));\n\t\t\t\tct.comments.push(cf);\n\t\t\t\tadd_rels(wsrels, -1, \"../comments\" + rId + \".\" + wbext, RELS.CMNT);\n\t\t\t\tneed_vml = true;\n\t\t\t}\n\t\t\tif(ws['!legacy']) {\n\t\t\t\tif(need_vml) zip_add_file(zip, \"xl/drawings/vmlDrawing\" + (rId) + \".vml\", write_comments_vml(rId, ws['!comments']));\n\t\t\t}\n\t\t\tdelete ws['!comments'];\n\t\t\tdelete ws['!legacy'];\n\t\t}\n\n\t\tif(wsrels['!id'].rId1) zip_add_file(zip, get_rels_path(f), write_rels(wsrels));\n\t}\n\n\tif(opts.Strings != null && opts.Strings.length > 0) {\n\t\tf = \"xl/sharedStrings.\" + wbext;\n\t\tzip_add_file(zip, f, write_sst_xml(opts.Strings, opts));\n\t\tct.strs.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"sharedStrings.\" + wbext, RELS.SST);\n\t}\n\n\tf = \"xl/workbook.\" + wbext;\n\tzip_add_file(zip, f, write_wb_xml(wb, opts));\n\tct.workbooks.push(f);\n\tadd_rels(opts.rels, 1, f, RELS.WB);\n\n\t/* TODO: something more intelligent with themes */\n\n\tf = \"xl/theme/theme1.xml\";\n\tzip_add_file(zip, f, write_theme(wb.Themes, opts));\n\tct.themes.push(f);\n\tadd_rels(opts.wbrels, -1, \"theme/theme1.xml\", RELS.THEME);\n\n\t/* TODO: something more intelligent with styles */\n\n\tf = \"xl/styles.\" + wbext;\n\tzip_add_file(zip, f, write_sty_xml(wb, opts));\n\tct.styles.push(f);\n\tadd_rels(opts.wbrels, -1, \"styles.\" + wbext, RELS.STY);\n\n\tif(wb.vbaraw && vbafmt) {\n\t\tf = \"xl/vbaProject.bin\";\n\t\tzip_add_file(zip, f, wb.vbaraw);\n\t\tct.vba.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"vbaProject.bin\", RELS.VBA);\n\t}\n\n\tf = \"xl/metadata.\" + wbext;\n\tzip_add_file(zip, f, write_xlmeta_xml());\n\tct.metadata.push(f);\n\tadd_rels(opts.wbrels, -1, \"metadata.\" + wbext, RELS.XLMETA);\n\n\tif(people.length > 1) {\n\t\tf = \"xl/persons/person.xml\";\n\t\tzip_add_file(zip, f, write_people_xml(people, opts));\n\t\tct.people.push(f);\n\t\tadd_rels(opts.wbrels, -1, \"persons/person.xml\", RELS.PEOPLE);\n\t}\n\n\tzip_add_file(zip, \"[Content_Types].xml\", write_ct(ct, opts));\n\tzip_add_file(zip, '_rels/.rels', write_rels(opts.rels));\n\tzip_add_file(zip, 'xl/_rels/workbook.' + wbext + '.rels', write_rels(opts.wbrels));\n\n\tdelete opts.revssf; delete opts.ssf;\n\treturn zip;\n}\n\nfunction firstbyte(f/*:RawData*/,o/*:?TypeOpts*/)/*:Array<number>*/ {\n\tvar x = \"\";\n\tswitch((o||{}).type || \"base64\") {\n\t\tcase 'buffer': return [f[0], f[1], f[2], f[3], f[4], f[5], f[6], f[7]];\n\t\tcase 'base64': x = Base64_decode(f.slice(0,12)); break;\n\t\tcase 'binary': x = f; break;\n\t\tcase 'array':  return [f[0], f[1], f[2], f[3], f[4], f[5], f[6], f[7]];\n\t\tdefault: throw new Error(\"Unrecognized type \" + (o && o.type || \"undefined\"));\n\t}\n\treturn [x.charCodeAt(0), x.charCodeAt(1), x.charCodeAt(2), x.charCodeAt(3), x.charCodeAt(4), x.charCodeAt(5), x.charCodeAt(6), x.charCodeAt(7)];\n}\n\nfunction read_cfb(cfb/*:CFBContainer*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tif(CFB.find(cfb, \"EncryptedPackage\")) return parse_xlsxcfb(cfb, opts);\n\treturn parse_xlscfb(cfb, opts);\n}\n\nfunction read_zip(data/*:RawData*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tvar zip, d = data;\n\tvar o = opts||{};\n\tif(!o.type) o.type = (has_buf && Buffer.isBuffer(data)) ? \"buffer\" : \"base64\";\n\tzip = zip_read(d, o);\n\treturn parse_zip(zip, o);\n}\n\nfunction read_plaintext(data/*:string*/, o/*:ParseOpts*/)/*:Workbook*/ {\n\tvar i = 0;\n\tmain: while(i < data.length) switch(data.charCodeAt(i)) {\n\t\tcase 0x0A: case 0x0D: case 0x20: ++i; break;\n\t\tcase 0x3C: return parse_xlml(data.slice(i),o);\n\t\tdefault: break main;\n\t}\n\treturn PRN.to_workbook(data, o);\n}\n\nfunction read_plaintext_raw(data/*:RawData*/, o/*:ParseOpts*/)/*:Workbook*/ {\n\tvar str = \"\", bytes = firstbyte(data, o);\n\tswitch(o.type) {\n\t\tcase 'base64': str = Base64_decode(data); break;\n\t\tcase 'binary': str = data; break;\n\t\tcase 'buffer': str = data.toString('binary'); break;\n\t\tcase 'array': str = cc2str(data); break;\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n\tif(bytes[0] == 0xEF && bytes[1] == 0xBB && bytes[2] == 0xBF) str = utf8read(str);\n\to.type = \"binary\";\n\treturn read_plaintext(str, o);\n}\n\nfunction read_utf16(data/*:RawData*/, o/*:ParseOpts*/)/*:Workbook*/ {\n\tvar d = data;\n\tif(o.type == 'base64') d = Base64_decode(d);\n\td = $cptable.utils.decode(1200, d.slice(2), 'str');\n\to.type = \"binary\";\n\treturn read_plaintext(d, o);\n}\n\nfunction bstrify(data/*:string*/)/*:string*/ {\n\treturn !data.match(/[^\\x00-\\x7F]/) ? data : utf8write(data);\n}\n\nfunction read_prn(data, d, o, str) {\n\tif(str) { o.type = \"string\"; return PRN.to_workbook(data, o); }\n\treturn PRN.to_workbook(d, o);\n}\n\nfunction readSync(data/*:RawData*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\treset_cp();\n\tvar o = opts||{};\n\tif(typeof ArrayBuffer !== 'undefined' && data instanceof ArrayBuffer) return readSync(new Uint8Array(data), (o = dup(o), o.type = \"array\", o));\n\tif(typeof Uint8Array !== 'undefined' && data instanceof Uint8Array && !o.type) o.type = typeof Deno !== \"undefined\" ? \"buffer\" : \"array\";\n\tvar d = data, n = [0,0,0,0], str = false;\n\tif(o.cellStyles) { o.cellNF = true; o.sheetStubs = true; }\n\t_ssfopts = {};\n\tif(o.dateNF) _ssfopts.dateNF = o.dateNF;\n\tif(!o.type) o.type = (has_buf && Buffer.isBuffer(data)) ? \"buffer\" : \"base64\";\n\tif(o.type == \"file\") { o.type = has_buf ? \"buffer\" : \"binary\"; d = read_binary(data); if(typeof Uint8Array !== 'undefined' && !has_buf) o.type = \"array\"; }\n\tif(o.type == \"string\") { str = true; o.type = \"binary\"; o.codepage = 65001; d = bstrify(data); }\n\tif(o.type == 'array' && typeof Uint8Array !== 'undefined' && data instanceof Uint8Array && typeof ArrayBuffer !== 'undefined') {\n\t\t// $FlowIgnore\n\t\tvar ab=new ArrayBuffer(3), vu=new Uint8Array(ab); vu.foo=\"bar\";\n\t\t// $FlowIgnore\n\t\tif(!vu.foo) {o=dup(o); o.type='array'; return readSync(ab2a(d), o);}\n\t}\n\tswitch((n = firstbyte(d, o))[0]) {\n\t\tcase 0xD0: if(n[1] === 0xCF && n[2] === 0x11 && n[3] === 0xE0 && n[4] === 0xA1 && n[5] === 0xB1 && n[6] === 0x1A && n[7] === 0xE1) return read_cfb(CFB.read(d, o), o); break;\n\t\tcase 0x09: if(n[1] <= 0x08) return parse_xlscfb(d, o); break;\n\t\tcase 0x3C: return parse_xlml(d, o);\n\t\tcase 0x49:\n\t\t\tif(n[1] === 0x49 && n[2] === 0x2a && n[3] === 0x00) throw new Error(\"TIFF Image File is not a spreadsheet\");\n\t\t\tif(n[1] === 0x44) return read_wb_ID(d, o);\n\t\t\tbreak;\n\t\tcase 0x54: if(n[1] === 0x41 && n[2] === 0x42 && n[3] === 0x4C) return DIF.to_workbook(d, o); break;\n\t\tcase 0x50: return (n[1] === 0x4B && n[2] < 0x09 && n[3] < 0x09) ? read_zip(d, o) : read_prn(data, d, o, str);\n\t\tcase 0xEF: return n[3] === 0x3C ? parse_xlml(d, o) : read_prn(data, d, o, str);\n\t\tcase 0xFF:\n\t\t\tif(n[1] === 0xFE) { return read_utf16(d, o); }\n\t\t\telse if(n[1] === 0x00 && n[2] === 0x02 && n[3] === 0x00) return WK_.to_workbook(d, o);\n\t\t\tbreak;\n\t\tcase 0x00:\n\t\t\tif(n[1] === 0x00) {\n\t\t\t\tif(n[2] >= 0x02 && n[3] === 0x00) return WK_.to_workbook(d, o);\n\t\t\t\tif(n[2] === 0x00 && (n[3] === 0x08 || n[3] === 0x09)) return WK_.to_workbook(d, o);\n\t\t\t}\n\t\t\tbreak;\n\t\tcase 0x03: case 0x83: case 0x8B: case 0x8C: return DBF.to_workbook(d, o);\n\t\tcase 0x7B: if(n[1] === 0x5C && n[2] === 0x72 && n[3] === 0x74) return RTF.to_workbook(d, o); break;\n\t\tcase 0x0A: case 0x0D: case 0x20: return read_plaintext_raw(d, o);\n\t\tcase 0x89: if(n[1] === 0x50 && n[2] === 0x4E && n[3] === 0x47) throw new Error(\"PNG Image File is not a spreadsheet\"); break;\n\t}\n\tif(DBF_SUPPORTED_VERSIONS.indexOf(n[0]) > -1 && n[2] <= 12 && n[3] <= 31) return DBF.to_workbook(d, o);\n\treturn read_prn(data, d, o, str);\n}\n\nfunction readFileSync(filename/*:string*/, opts/*:?ParseOpts*/)/*:Workbook*/ {\n\tvar o = opts||{}; o.type = 'file';\n\treturn readSync(filename, o);\n}\nfunction write_cfb_ctr(cfb/*:CFBContainer*/, o/*:WriteOpts*/)/*:any*/ {\n\tswitch(o.type) {\n\t\tcase \"base64\": case \"binary\": break;\n\t\tcase \"buffer\": case \"array\": o.type = \"\"; break;\n\t\tcase \"file\": return write_dl(o.file, CFB.write(cfb, {type:has_buf ? 'buffer' : \"\"}));\n\t\tcase \"string\": throw new Error(\"'string' output type invalid for '\" + o.bookType + \"' files\");\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n\treturn CFB.write(cfb, o);\n}\n\n/*:: declare var encrypt_agile:any; */\nfunction write_zip_type(wb/*:Workbook*/, opts/*:?WriteOpts*/)/*:any*/ {\n\tvar o = dup(opts||{});\n\tvar z = write_zip(wb, o);\n\treturn write_zip_denouement(z, o);\n}\nfunction write_zip_typeXLSX(wb/*:Workbook*/, opts/*:?WriteOpts*/)/*:any*/ {\n\tvar o = dup(opts||{});\n\tvar z = write_zip_xlsx(wb, o);\n\treturn write_zip_denouement(z, o);\n}\nfunction write_zip_denouement(z/*:any*/, o/*:?WriteOpts*/)/*:any*/ {\n\tvar oopts = {};\n\tvar ftype = has_buf ? \"nodebuffer\" : (typeof Uint8Array !== \"undefined\" ? \"array\" : \"string\");\n\tif(o.compression) oopts.compression = 'DEFLATE';\n\tif(o.password) oopts.type = ftype;\n\telse switch(o.type) {\n\t\tcase \"base64\": oopts.type = \"base64\"; break;\n\t\tcase \"binary\": oopts.type = \"string\"; break;\n\t\tcase \"string\": throw new Error(\"'string' output type invalid for '\" + o.bookType + \"' files\");\n\t\tcase \"buffer\":\n\t\tcase \"file\": oopts.type = ftype; break;\n\t\tdefault: throw new Error(\"Unrecognized type \" + o.type);\n\t}\n\tvar out = z.FullPaths ? CFB.write(z, {fileType:\"zip\", type: /*::(*/{\"nodebuffer\": \"buffer\", \"string\": \"binary\"}/*:: :any)*/[oopts.type] || oopts.type, compression: !!o.compression}) : z.generate(oopts);\n\tif(typeof Deno !== \"undefined\") {\n\t\tif(typeof out == \"string\") {\n\t\t\tif(o.type == \"binary\" || o.type == \"base64\") return out;\n\t\t\tout = new Uint8Array(s2ab(out));\n\t\t}\n\t}\n/*jshint -W083 */\n\tif(o.password && typeof encrypt_agile !== 'undefined') return write_cfb_ctr(encrypt_agile(out, o.password), o); // eslint-disable-line no-undef\n/*jshint +W083 */\n\tif(o.type === \"file\") return write_dl(o.file, out);\n\treturn o.type == \"string\" ? utf8read(/*::(*/out/*:: :any)*/) : out;\n}\n\nfunction write_cfb_type(wb/*:Workbook*/, opts/*:?WriteOpts*/)/*:any*/ {\n\tvar o = opts||{};\n\tvar cfb/*:CFBContainer*/ = write_xlscfb(wb, o);\n\treturn write_cfb_ctr(cfb, o);\n}\n\nfunction write_string_type(out/*:string*/, opts/*:WriteOpts*/, bom/*:?string*/)/*:any*/ {\n\tif(!bom) bom = \"\";\n\tvar o = bom + out;\n\tswitch(opts.type) {\n\t\tcase \"base64\": return Base64_encode(utf8write(o));\n\t\tcase \"binary\": return utf8write(o);\n\t\tcase \"string\": return out;\n\t\tcase \"file\": return write_dl(opts.file, o, 'utf8');\n\t\tcase \"buffer\": {\n\t\t\tif(has_buf) return Buffer_from(o, 'utf8');\n\t\t\telse if(typeof TextEncoder !== \"undefined\") return new TextEncoder().encode(o);\n\t\t\telse return write_string_type(o, {type:'binary'}).split(\"\").map(function(c) { return c.charCodeAt(0); });\n\t\t}\n\t}\n\tthrow new Error(\"Unrecognized type \" + opts.type);\n}\n\nfunction write_stxt_type(out/*:string*/, opts/*:WriteOpts*/)/*:any*/ {\n\tswitch(opts.type) {\n\t\tcase \"base64\": return Base64_encode(out);\n\t\tcase \"binary\": return out;\n\t\tcase \"string\": return out; /* override in sheet_to_txt */\n\t\tcase \"file\": return write_dl(opts.file, out, 'binary');\n\t\tcase \"buffer\": {\n\t\t\tif(has_buf) return Buffer_from(out, 'binary');\n\t\t\telse return out.split(\"\").map(function(c) { return c.charCodeAt(0); });\n\t\t}\n\t}\n\tthrow new Error(\"Unrecognized type \" + opts.type);\n}\n\n/* TODO: test consistency */\nfunction write_binary_type(out, opts/*:WriteOpts*/)/*:any*/ {\n\tswitch(opts.type) {\n\t\tcase \"string\":\n\t\tcase \"base64\":\n\t\tcase \"binary\":\n\t\t\tvar bstr = \"\";\n\t\t\t// $FlowIgnore\n\t\t\tfor(var i = 0; i < out.length; ++i) bstr += String.fromCharCode(out[i]);\n\t\t\treturn opts.type == 'base64' ? Base64_encode(bstr) : opts.type == 'string' ? utf8read(bstr) : bstr;\n\t\tcase \"file\": return write_dl(opts.file, out);\n\t\tcase \"buffer\": return out;\n\t\tdefault: throw new Error(\"Unrecognized type \" + opts.type);\n\t}\n}\n\nfunction writeSyncXLSX(wb/*:Workbook*/, opts/*:?WriteOpts*/) {\n\treset_cp();\n\tcheck_wb(wb);\n\tvar o = dup(opts||{});\n\tif(o.cellStyles) { o.cellNF = true; o.sheetStubs = true; }\n\tif(o.type == \"array\") { o.type = \"binary\"; var out/*:string*/ = (writeSyncXLSX(wb, o)/*:any*/); o.type = \"array\"; return s2ab(out); }\n\treturn write_zip_typeXLSX(wb, o);\n}\n\nfunction writeSync(wb/*:Workbook*/, opts/*:?WriteOpts*/) {\n\treset_cp();\n\tcheck_wb(wb);\n\tvar o = dup(opts||{});\n\tif(o.cellStyles) { o.cellNF = true; o.sheetStubs = true; }\n\tif(o.type == \"array\") { o.type = \"binary\"; var out/*:string*/ = (writeSync(wb, o)/*:any*/); o.type = \"array\"; return s2ab(out); }\n\tvar idx = 0;\n\tif(o.sheet) {\n\t\tif(typeof o.sheet == \"number\") idx = o.sheet;\n\t\telse idx = wb.SheetNames.indexOf(o.sheet);\n\t\tif(!wb.SheetNames[idx]) throw new Error(\"Sheet not found: \" + o.sheet + \" : \" + (typeof o.sheet));\n\t}\n\tswitch(o.bookType || 'xlsb') {\n\t\tcase 'xml':\n\t\tcase 'xlml': return write_string_type(write_xlml(wb, o), o);\n\t\tcase 'slk':\n\t\tcase 'sylk': return write_string_type(SYLK.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'htm':\n\t\tcase 'html': return write_string_type(sheet_to_html(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'txt': return write_stxt_type(sheet_to_txt(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'csv': return write_string_type(sheet_to_csv(wb.Sheets[wb.SheetNames[idx]], o), o, \"\\ufeff\");\n\t\tcase 'dif': return write_string_type(DIF.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'dbf': return write_binary_type(DBF.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'prn': return write_string_type(PRN.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'rtf': return write_string_type(RTF.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'eth': return write_string_type(ETH.from_sheet(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'fods': return write_string_type(write_ods(wb, o), o);\n\t\tcase 'wk1': return write_binary_type(WK_.sheet_to_wk1(wb.Sheets[wb.SheetNames[idx]], o), o);\n\t\tcase 'wk3': return write_binary_type(WK_.book_to_wk3(wb, o), o);\n\t\tcase 'biff2': if(!o.biff) o.biff = 2; /* falls through */\n\t\tcase 'biff3': if(!o.biff) o.biff = 3; /* falls through */\n\t\tcase 'biff4': if(!o.biff) o.biff = 4; return write_binary_type(write_biff_buf(wb, o), o);\n\t\tcase 'biff5': if(!o.biff) o.biff = 5; /* falls through */\n\t\tcase 'biff8':\n\t\tcase 'xla':\n\t\tcase 'xls': if(!o.biff) o.biff = 8; return write_cfb_type(wb, o);\n\t\tcase 'xlsx':\n\t\tcase 'xlsm':\n\t\tcase 'xlam':\n\t\tcase 'xlsb':\n\t\tcase 'numbers':\n\t\tcase 'ods': return write_zip_type(wb, o);\n\t\tdefault: throw new Error (\"Unrecognized bookType |\" + o.bookType + \"|\");\n\t}\n}\n\nfunction resolve_book_type(o/*:WriteFileOpts*/) {\n\tif(o.bookType) return;\n\tvar _BT = {\n\t\t\"xls\": \"biff8\",\n\t\t\"htm\": \"html\",\n\t\t\"slk\": \"sylk\",\n\t\t\"socialcalc\": \"eth\",\n\t\t\"Sh33tJS\": \"WTF\"\n\t};\n\tvar ext = o.file.slice(o.file.lastIndexOf(\".\")).toLowerCase();\n\tif(ext.match(/^\\.[a-z]+$/)) o.bookType = ext.slice(1);\n\to.bookType = _BT[o.bookType] || o.bookType;\n}\n\nfunction writeFileSync(wb/*:Workbook*/, filename/*:string*/, opts/*:?WriteFileOpts*/) {\n\tvar o = opts||{}; o.type = 'file';\n\to.file = filename;\n\tresolve_book_type(o);\n\treturn writeSync(wb, o);\n}\n\nfunction writeFileSyncXLSX(wb/*:Workbook*/, filename/*:string*/, opts/*:?WriteFileOpts*/) {\n\tvar o = opts||{}; o.type = 'file';\n\to.file = filename;\n\tresolve_book_type(o);\n\treturn writeSyncXLSX(wb, o);\n}\n\n\nfunction writeFileAsync(filename/*:string*/, wb/*:Workbook*/, opts/*:?WriteFileOpts*/, cb/*:?(e?:ErrnoError)=>void*/) {\n\tvar o = opts||{}; o.type = 'file';\n\to.file = filename;\n\tresolve_book_type(o);\n\to.type = 'buffer';\n\tvar _cb = cb; if(!(_cb instanceof Function)) _cb = (opts/*:any*/);\n\treturn _fs.writeFile(filename, writeSync(wb, o), _cb);\n}\n/*::\ntype MJRObject = {\n\trow: any;\n\tisempty: boolean;\n};\n*/\nfunction make_json_row(sheet/*:Worksheet*/, r/*:Range*/, R/*:number*/, cols/*:Array<string>*/, header/*:number*/, hdr/*:Array<any>*/, dense/*:boolean*/, o/*:Sheet2JSONOpts*/)/*:MJRObject*/ {\n\tvar rr = encode_row(R);\n\tvar defval = o.defval, raw = o.raw || !Object.prototype.hasOwnProperty.call(o, \"raw\");\n\tvar isempty = true;\n\tvar row/*:any*/ = (header === 1) ? [] : {};\n\tif(header !== 1) {\n\t\tif(Object.defineProperty) try { Object.defineProperty(row, '__rowNum__', {value:R, enumerable:false}); } catch(e) { row.__rowNum__ = R; }\n\t\telse row.__rowNum__ = R;\n\t}\n\tif(!dense || sheet[R]) for (var C = r.s.c; C <= r.e.c; ++C) {\n\t\tvar val = dense ? sheet[R][C] : sheet[cols[C] + rr];\n\t\tif(val === undefined || val.t === undefined) {\n\t\t\tif(defval === undefined) continue;\n\t\t\tif(hdr[C] != null) { row[hdr[C]] = defval; }\n\t\t\tcontinue;\n\t\t}\n\t\tvar v = val.v;\n\t\tswitch(val.t){\n\t\t\tcase 'z': if(v == null) break; continue;\n\t\t\tcase 'e': v = (v == 0 ? null : void 0); break;\n\t\t\tcase 's': case 'd': case 'b': case 'n': break;\n\t\t\tdefault: throw new Error('unrecognized type ' + val.t);\n\t\t}\n\t\tif(hdr[C] != null) {\n\t\t\tif(v == null) {\n\t\t\t\tif(val.t == \"e\" && v === null) row[hdr[C]] = null;\n\t\t\t\telse if(defval !== undefined) row[hdr[C]] = defval;\n\t\t\t\telse if(raw && v === null) row[hdr[C]] = null;\n\t\t\t\telse continue;\n\t\t\t} else {\n\t\t\t\trow[hdr[C]] = raw && (val.t !== \"n\" || (val.t === \"n\" && o.rawNumbers !== false)) ? v : format_cell(val,v,o);\n\t\t\t}\n\t\t\tif(v != null) isempty = false;\n\t\t}\n\t}\n\treturn { row: row, isempty: isempty };\n}\n\n\nfunction sheet_to_json(sheet/*:Worksheet*/, opts/*:?Sheet2JSONOpts*/) {\n\tif(sheet == null || sheet[\"!ref\"] == null) return [];\n\tvar val = {t:'n',v:0}, header = 0, offset = 1, hdr/*:Array<any>*/ = [], v=0, vv=\"\";\n\tvar r = {s:{r:0,c:0},e:{r:0,c:0}};\n\tvar o = opts || {};\n\tvar range = o.range != null ? o.range : sheet[\"!ref\"];\n\tif(o.header === 1) header = 1;\n\telse if(o.header === \"A\") header = 2;\n\telse if(Array.isArray(o.header)) header = 3;\n\telse if(o.header == null) header = 0;\n\tswitch(typeof range) {\n\t\tcase 'string': r = safe_decode_range(range); break;\n\t\tcase 'number': r = safe_decode_range(sheet[\"!ref\"]); r.s.r = range; break;\n\t\tdefault: r = range;\n\t}\n\tif(header > 0) offset = 0;\n\tvar rr = encode_row(r.s.r);\n\tvar cols/*:Array<string>*/ = [];\n\tvar out/*:Array<any>*/ = [];\n\tvar outi = 0, counter = 0;\n\tvar dense = Array.isArray(sheet);\n\tvar R = r.s.r, C = 0;\n\tvar header_cnt = {};\n\tif(dense && !sheet[R]) sheet[R] = [];\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\tif(((colinfo[C]||{}).hidden)) continue;\n\t\tcols[C] = encode_col(C);\n\t\tval = dense ? sheet[R][C] : sheet[cols[C] + rr];\n\t\tswitch(header) {\n\t\t\tcase 1: hdr[C] = C - r.s.c; break;\n\t\t\tcase 2: hdr[C] = cols[C]; break;\n\t\t\tcase 3: hdr[C] = o.header[C - r.s.c]; break;\n\t\t\tdefault:\n\t\t\t\tif(val == null) val = {w: \"__EMPTY\", t: \"s\"};\n\t\t\t\tvv = v = format_cell(val, null, o);\n\t\t\t\tcounter = header_cnt[v] || 0;\n\t\t\t\tif(!counter) header_cnt[v] = 1;\n\t\t\t\telse {\n\t\t\t\t\tdo { vv = v + \"_\" + (counter++); } while(header_cnt[vv]); header_cnt[v] = counter;\n\t\t\t\t\theader_cnt[vv] = 1;\n\t\t\t\t}\n\t\t\t\thdr[C] = vv;\n\t\t}\n\t}\n\tfor (R = r.s.r + offset; R <= r.e.r; ++R) {\n\t\tif ((rowinfo[R]||{}).hidden) continue;\n\t\tvar row = make_json_row(sheet, r, R, cols, header, hdr, dense, o);\n\t\tif((row.isempty === false) || (header === 1 ? o.blankrows !== false : !!o.blankrows)) out[outi++] = row.row;\n\t}\n\tout.length = outi;\n\treturn out;\n}\n\nvar qreg = /\"/g;\nfunction make_csv_row(sheet/*:Worksheet*/, r/*:Range*/, R/*:number*/, cols/*:Array<string>*/, fs/*:number*/, rs/*:number*/, FS/*:string*/, o/*:Sheet2CSVOpts*/)/*:?string*/ {\n\tvar isempty = true;\n\tvar row/*:Array<string>*/ = [], txt = \"\", rr = encode_row(R);\n\tfor(var C = r.s.c; C <= r.e.c; ++C) {\n\t\tif (!cols[C]) continue;\n\t\tvar val = o.dense ? (sheet[R]||[])[C]: sheet[cols[C] + rr];\n\t\tif(val == null) txt = \"\";\n\t\telse if(val.v != null) {\n\t\t\tisempty = false;\n\t\t\ttxt = ''+(o.rawNumbers && val.t == \"n\" ? val.v : format_cell(val, null, o));\n\t\t\tfor(var i = 0, cc = 0; i !== txt.length; ++i) if((cc = txt.charCodeAt(i)) === fs || cc === rs || cc === 34 || o.forceQuotes) {txt = \"\\\"\" + txt.replace(qreg, '\"\"') + \"\\\"\"; break; }\n\t\t\tif(txt == \"ID\") txt = '\"ID\"';\n\t\t} else if(val.f != null && !val.F) {\n\t\t\tisempty = false;\n\t\t\ttxt = '=' + val.f; if(txt.indexOf(\",\") >= 0) txt = '\"' + txt.replace(qreg, '\"\"') + '\"';\n\t\t} else txt = \"\";\n\t\t/* NOTE: Excel CSV does not support array formulae */\n\t\trow.push(txt);\n\t}\n\tif(o.blankrows === false && isempty) return null;\n\treturn row.join(FS);\n}\n\nfunction sheet_to_csv(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/)/*:string*/ {\n\tvar out/*:Array<string>*/ = [];\n\tvar o = opts == null ? {} : opts;\n\tif(sheet == null || sheet[\"!ref\"] == null) return \"\";\n\tvar r = safe_decode_range(sheet[\"!ref\"]);\n\tvar FS = o.FS !== undefined ? o.FS : \",\", fs = FS.charCodeAt(0);\n\tvar RS = o.RS !== undefined ? o.RS : \"\\n\", rs = RS.charCodeAt(0);\n\tvar endregex = new RegExp((FS==\"|\" ? \"\\\\|\" : FS)+\"+$\");\n\tvar row = \"\", cols/*:Array<string>*/ = [];\n\to.dense = Array.isArray(sheet);\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(var C = r.s.c; C <= r.e.c; ++C) if (!((colinfo[C]||{}).hidden)) cols[C] = encode_col(C);\n\tvar w = 0;\n\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\tif ((rowinfo[R]||{}).hidden) continue;\n\t\trow = make_csv_row(sheet, r, R, cols, fs, rs, FS, o);\n\t\tif(row == null) { continue; }\n\t\tif(o.strip) row = row.replace(endregex,\"\");\n\t\tif(row || (o.blankrows !== false)) out.push((w++ ? RS : \"\") + row);\n\t}\n\tdelete o.dense;\n\treturn out.join(\"\");\n}\n\nfunction sheet_to_txt(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/) {\n\tif(!opts) opts = {}; opts.FS = \"\\t\"; opts.RS = \"\\n\";\n\tvar s = sheet_to_csv(sheet, opts);\n\tif(typeof $cptable == 'undefined' || opts.type == 'string') return s;\n\tvar o = $cptable.utils.encode(1200, s, 'str');\n\treturn String.fromCharCode(255) + String.fromCharCode(254) + o;\n}\n\nfunction sheet_to_formulae(sheet/*:Worksheet*/)/*:Array<string>*/ {\n\tvar y = \"\", x, val=\"\";\n\tif(sheet == null || sheet[\"!ref\"] == null) return [];\n\tvar r = safe_decode_range(sheet['!ref']), rr = \"\", cols/*:Array<string>*/ = [], C;\n\tvar cmds/*:Array<string>*/ = [];\n\tvar dense = Array.isArray(sheet);\n\tfor(C = r.s.c; C <= r.e.c; ++C) cols[C] = encode_col(C);\n\tfor(var R = r.s.r; R <= r.e.r; ++R) {\n\t\trr = encode_row(R);\n\t\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\t\ty = cols[C] + rr;\n\t\t\tx = dense ? (sheet[R]||[])[C] : sheet[y];\n\t\t\tval = \"\";\n\t\t\tif(x === undefined) continue;\n\t\t\telse if(x.F != null) {\n\t\t\t\ty = x.F;\n\t\t\t\tif(!x.f) continue;\n\t\t\t\tval = x.f;\n\t\t\t\tif(y.indexOf(\":\") == -1) y = y + \":\" + y;\n\t\t\t}\n\t\t\tif(x.f != null) val = x.f;\n\t\t\telse if(x.t == 'z') continue;\n\t\t\telse if(x.t == 'n' && x.v != null) val = \"\" + x.v;\n\t\t\telse if(x.t == 'b') val = x.v ? \"TRUE\" : \"FALSE\";\n\t\t\telse if(x.w !== undefined) val = \"'\" + x.w;\n\t\t\telse if(x.v === undefined) continue;\n\t\t\telse if(x.t == 's') val = \"'\" + x.v;\n\t\t\telse val = \"\"+x.v;\n\t\t\tcmds[cmds.length] = y + \"=\" + val;\n\t\t}\n\t}\n\treturn cmds;\n}\n\nfunction sheet_add_json(_ws/*:?Worksheet*/, js/*:Array<any>*/, opts)/*:Worksheet*/ {\n\tvar o = opts || {};\n\tvar offset = +!o.skipHeader;\n\tvar ws/*:Worksheet*/ = _ws || ({}/*:any*/);\n\tvar _R = 0, _C = 0;\n\tif(ws && o.origin != null) {\n\t\tif(typeof o.origin == 'number') _R = o.origin;\n\t\telse {\n\t\t\tvar _origin/*:CellAddress*/ = typeof o.origin == \"string\" ? decode_cell(o.origin) : o.origin;\n\t\t\t_R = _origin.r; _C = _origin.c;\n\t\t}\n\t}\n\tvar cell/*:Cell*/;\n\tvar range/*:Range*/ = ({s: {c:0, r:0}, e: {c:_C, r:_R + js.length - 1 + offset}}/*:any*/);\n\tif(ws['!ref']) {\n\t\tvar _range = safe_decode_range(ws['!ref']);\n\t\trange.e.c = Math.max(range.e.c, _range.e.c);\n\t\trange.e.r = Math.max(range.e.r, _range.e.r);\n\t\tif(_R == -1) { _R = _range.e.r + 1; range.e.r = _R + js.length - 1 + offset; }\n\t} else {\n\t\tif(_R == -1) { _R = 0; range.e.r = js.length - 1 + offset; }\n\t}\n\tvar hdr/*:Array<string>*/ = o.header || [], C = 0;\n\n\tjs.forEach(function (JS, R/*:number*/) {\n\t\tkeys(JS).forEach(function(k) {\n\t\t\tif((C=hdr.indexOf(k)) == -1) hdr[C=hdr.length] = k;\n\t\t\tvar v = JS[k];\n\t\t\tvar t = 'z';\n\t\t\tvar z = \"\";\n\t\t\tvar ref = encode_cell({c:_C + C,r:_R + R + offset});\n\t\t\tcell = ws_get_cell_stub(ws, ref);\n\t\t\tif(v && typeof v === 'object' && !(v instanceof Date)){\n\t\t\t\tws[ref] = v;\n\t\t\t} else {\n\t\t\t\tif(typeof v == 'number') t = 'n';\n\t\t\t\telse if(typeof v == 'boolean') t = 'b';\n\t\t\t\telse if(typeof v == 'string') t = 's';\n\t\t\t\telse if(v instanceof Date) {\n\t\t\t\t\tt = 'd';\n\t\t\t\t\tif(!o.cellDates) { t = 'n'; v = datenum(v); }\n\t\t\t\t\tz = (o.dateNF || table_fmt[14]);\n\t\t\t\t}\n\t\t\t\telse if(v === null && o.nullError) { t = 'e'; v = 0; }\n\t\t\t\tif(!cell) ws[ref] = cell = ({t:t, v:v}/*:any*/);\n\t\t\t\telse {\n\t\t\t\t\tcell.t = t; cell.v = v;\n\t\t\t\t\tdelete cell.w; delete cell.R;\n\t\t\t\t\tif(z) cell.z = z;\n\t\t\t\t}\n\t\t\t\tif(z) cell.z = z;\n\t\t\t}\n\t\t});\n\t});\n\trange.e.c = Math.max(range.e.c, _C + hdr.length - 1);\n\tvar __R = encode_row(_R);\n\tif(offset) for(C = 0; C < hdr.length; ++C) ws[encode_col(C + _C) + __R] = {t:'s', v:hdr[C]};\n\tws['!ref'] = encode_range(range);\n\treturn ws;\n}\nfunction json_to_sheet(js/*:Array<any>*/, opts)/*:Worksheet*/ { return sheet_add_json(null, js, opts); }\n\n/* get cell, creating a stub if necessary */\nfunction ws_get_cell_stub(ws/*:Worksheet*/, R, C/*:?number*/)/*:Cell*/ {\n\t/* A1 cell address */\n\tif(typeof R == \"string\") {\n\t\t/* dense */\n\t\tif(Array.isArray(ws)) {\n\t\t\tvar RC = decode_cell(R);\n\t\t\tif(!ws[RC.r]) ws[RC.r] = [];\n\t\t\treturn ws[RC.r][RC.c] || (ws[RC.r][RC.c] = {t:'z'});\n\t\t}\n\t\treturn ws[R] || (ws[R] = {t:'z'});\n\t}\n\t/* cell address object */\n\tif(typeof R != \"number\") return ws_get_cell_stub(ws, encode_cell(R));\n\t/* R and C are 0-based indices */\n\treturn ws_get_cell_stub(ws, encode_cell({r:R,c:C||0}));\n}\n\n/* find sheet index for given name / validate index */\nfunction wb_sheet_idx(wb/*:Workbook*/, sh/*:number|string*/) {\n\tif(typeof sh == \"number\") {\n\t\tif(sh >= 0 && wb.SheetNames.length > sh) return sh;\n\t\tthrow new Error(\"Cannot find sheet # \" + sh);\n\t} else if(typeof sh == \"string\") {\n\t\tvar idx = wb.SheetNames.indexOf(sh);\n\t\tif(idx > -1) return idx;\n\t\tthrow new Error(\"Cannot find sheet name |\" + sh + \"|\");\n\t} else throw new Error(\"Cannot find sheet |\" + sh + \"|\");\n}\n\n/* simple blank workbook object */\nfunction book_new()/*:Workbook*/ {\n\treturn { SheetNames: [], Sheets: {} };\n}\n\n/* add a worksheet to the end of a given workbook */\nfunction book_append_sheet(wb/*:Workbook*/, ws/*:Worksheet*/, name/*:?string*/, roll/*:?boolean*/)/*:string*/ {\n\tvar i = 1;\n\tif(!name) for(; i <= 0xFFFF; ++i, name = undefined) if(wb.SheetNames.indexOf(name = \"Sheet\" + i) == -1) break;\n\tif(!name || wb.SheetNames.length >= 0xFFFF) throw new Error(\"Too many worksheets\");\n\tif(roll && wb.SheetNames.indexOf(name) >= 0) {\n\t\tvar m = name.match(/(^.*?)(\\d+)$/);\n\t\ti = m && +m[2] || 0;\n\t\tvar root = m && m[1] || name;\n\t\tfor(++i; i <= 0xFFFF; ++i) if(wb.SheetNames.indexOf(name = root + i) == -1) break;\n\t}\n\tcheck_ws_name(name);\n\tif(wb.SheetNames.indexOf(name) >= 0) throw new Error(\"Worksheet with name |\" + name + \"| already exists!\");\n\n\twb.SheetNames.push(name);\n\twb.Sheets[name] = ws;\n\treturn name;\n}\n\n/* set sheet visibility (visible/hidden/very hidden) */\nfunction book_set_sheet_visibility(wb/*:Workbook*/, sh/*:number|string*/, vis/*:number*/) {\n\tif(!wb.Workbook) wb.Workbook = {};\n\tif(!wb.Workbook.Sheets) wb.Workbook.Sheets = [];\n\n\tvar idx = wb_sheet_idx(wb, sh);\n\t// $FlowIgnore\n\tif(!wb.Workbook.Sheets[idx]) wb.Workbook.Sheets[idx] = {};\n\n\tswitch(vis) {\n\t\tcase 0: case 1: case 2: break;\n\t\tdefault: throw new Error(\"Bad sheet visibility setting \" + vis);\n\t}\n\t// $FlowIgnore\n\twb.Workbook.Sheets[idx].Hidden = vis;\n}\n\n/* set number format */\nfunction cell_set_number_format(cell/*:Cell*/, fmt/*:string|number*/) {\n\tcell.z = fmt;\n\treturn cell;\n}\n\n/* set cell hyperlink */\nfunction cell_set_hyperlink(cell/*:Cell*/, target/*:string*/, tooltip/*:?string*/) {\n\tif(!target) {\n\t\tdelete cell.l;\n\t} else {\n\t\tcell.l = ({ Target: target }/*:Hyperlink*/);\n\t\tif(tooltip) cell.l.Tooltip = tooltip;\n\t}\n\treturn cell;\n}\nfunction cell_set_internal_link(cell/*:Cell*/, range/*:string*/, tooltip/*:?string*/) { return cell_set_hyperlink(cell, \"#\" + range, tooltip); }\n\n/* add to cell comments */\nfunction cell_add_comment(cell/*:Cell*/, text/*:string*/, author/*:?string*/) {\n\tif(!cell.c) cell.c = [];\n\tcell.c.push({t:text, a:author||\"SheetJS\"});\n}\n\n/* set array formula and flush related cells */\nfunction sheet_set_array_formula(ws/*:Worksheet*/, range, formula/*:string*/, dynamic/*:boolean*/) {\n\tvar rng = typeof range != \"string\" ? range : safe_decode_range(range);\n\tvar rngstr = typeof range == \"string\" ? range : encode_range(range);\n\tfor(var R = rng.s.r; R <= rng.e.r; ++R) for(var C = rng.s.c; C <= rng.e.c; ++C) {\n\t\tvar cell = ws_get_cell_stub(ws, R, C);\n\t\tcell.t = 'n';\n\t\tcell.F = rngstr;\n\t\tdelete cell.v;\n\t\tif(R == rng.s.r && C == rng.s.c) {\n\t\t\tcell.f = formula;\n\t\t\tif(dynamic) cell.D = true;\n\t\t}\n\t}\n\treturn ws;\n}\n\nvar utils/*:any*/ = {\n\tencode_col: encode_col,\n\tencode_row: encode_row,\n\tencode_cell: encode_cell,\n\tencode_range: encode_range,\n\tdecode_col: decode_col,\n\tdecode_row: decode_row,\n\tsplit_cell: split_cell,\n\tdecode_cell: decode_cell,\n\tdecode_range: decode_range,\n\tformat_cell: format_cell,\n\tsheet_add_aoa: sheet_add_aoa,\n\tsheet_add_json: sheet_add_json,\n\tsheet_add_dom: sheet_add_dom,\n\taoa_to_sheet: aoa_to_sheet,\n\tjson_to_sheet: json_to_sheet,\n\ttable_to_sheet: parse_dom_table,\n\ttable_to_book: table_to_book,\n\tsheet_to_csv: sheet_to_csv,\n\tsheet_to_txt: sheet_to_txt,\n\tsheet_to_json: sheet_to_json,\n\tsheet_to_html: sheet_to_html,\n\tsheet_to_formulae: sheet_to_formulae,\n\tsheet_to_row_object_array: sheet_to_json,\n\tsheet_get_cell: ws_get_cell_stub,\n\tbook_new: book_new,\n\tbook_append_sheet: book_append_sheet,\n\tbook_set_sheet_visibility: book_set_sheet_visibility,\n\tcell_set_number_format: cell_set_number_format,\n\tcell_set_hyperlink: cell_set_hyperlink,\n\tcell_set_internal_link: cell_set_internal_link,\n\tcell_add_comment: cell_add_comment,\n\tsheet_set_array_formula: sheet_set_array_formula,\n\tconsts: {\n\t\tSHEET_VISIBLE: 0,\n\t\tSHEET_HIDDEN: 1,\n\t\tSHEET_VERY_HIDDEN: 2\n\t}\n};\n\nvar _Readable;\nfunction set_readable(R) { _Readable = R; }\n\nfunction write_csv_stream(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/) {\n\tvar stream = _Readable();\n\tvar o = opts == null ? {} : opts;\n\tif(sheet == null || sheet[\"!ref\"] == null) { stream.push(null); return stream; }\n\tvar r = safe_decode_range(sheet[\"!ref\"]);\n\tvar FS = o.FS !== undefined ? o.FS : \",\", fs = FS.charCodeAt(0);\n\tvar RS = o.RS !== undefined ? o.RS : \"\\n\", rs = RS.charCodeAt(0);\n\tvar endregex = new RegExp((FS==\"|\" ? \"\\\\|\" : FS)+\"+$\");\n\tvar row/*:?string*/ = \"\", cols/*:Array<string>*/ = [];\n\to.dense = Array.isArray(sheet);\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<RowInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(var C = r.s.c; C <= r.e.c; ++C) if (!((colinfo[C]||{}).hidden)) cols[C] = encode_col(C);\n\tvar R = r.s.r;\n\tvar BOM = false, w = 0;\n\tstream._read = function() {\n\t\tif(!BOM) { BOM = true; return stream.push(\"\\uFEFF\"); }\n\t\twhile(R <= r.e.r) {\n\t\t\t++R;\n\t\t\tif ((rowinfo[R-1]||{}).hidden) continue;\n\t\t\trow = make_csv_row(sheet, r, R-1, cols, fs, rs, FS, o);\n\t\t\tif(row != null) {\n\t\t\t\tif(o.strip) row = row.replace(endregex,\"\");\n\t\t\t\tif(row || (o.blankrows !== false)) return stream.push((w++ ? RS : \"\") + row);\n\t\t\t}\n\t\t}\n\t\treturn stream.push(null);\n\t};\n\treturn stream;\n}\n\nfunction write_html_stream(ws/*:Worksheet*/, opts/*:?Sheet2HTMLOpts*/) {\n\tvar stream = _Readable();\n\n\tvar o = opts || {};\n\tvar header = o.header != null ? o.header : HTML_BEGIN;\n\tvar footer = o.footer != null ? o.footer : HTML_END;\n\tstream.push(header);\n\tvar r = decode_range(ws['!ref']);\n\to.dense = Array.isArray(ws);\n\tstream.push(make_html_preamble(ws, r, o));\n\tvar R = r.s.r;\n\tvar end = false;\n\tstream._read = function() {\n\t\tif(R > r.e.r) {\n\t\t\tif(!end) { end = true; stream.push(\"</table>\" + footer); }\n\t\t\treturn stream.push(null);\n\t\t}\n\t\twhile(R <= r.e.r) {\n\t\t\tstream.push(make_html_row(ws, r, R, o));\n\t\t\t++R;\n\t\t\tbreak;\n\t\t}\n\t};\n\treturn stream;\n}\n\nfunction write_json_stream(sheet/*:Worksheet*/, opts/*:?Sheet2CSVOpts*/) {\n\tvar stream = _Readable({objectMode:true});\n\n\tif(sheet == null || sheet[\"!ref\"] == null) { stream.push(null); return stream; }\n\tvar val = {t:'n',v:0}, header = 0, offset = 1, hdr/*:Array<any>*/ = [], v=0, vv=\"\";\n\tvar r = {s:{r:0,c:0},e:{r:0,c:0}};\n\tvar o = opts || {};\n\tvar range = o.range != null ? o.range : sheet[\"!ref\"];\n\tif(o.header === 1) header = 1;\n\telse if(o.header === \"A\") header = 2;\n\telse if(Array.isArray(o.header)) header = 3;\n\tswitch(typeof range) {\n\t\tcase 'string': r = safe_decode_range(range); break;\n\t\tcase 'number': r = safe_decode_range(sheet[\"!ref\"]); r.s.r = range; break;\n\t\tdefault: r = range;\n\t}\n\tif(header > 0) offset = 0;\n\tvar rr = encode_row(r.s.r);\n\tvar cols/*:Array<string>*/ = [];\n\tvar counter = 0;\n\tvar dense = Array.isArray(sheet);\n\tvar R = r.s.r, C = 0;\n\tvar header_cnt = {};\n\tif(dense && !sheet[R]) sheet[R] = [];\n\tvar colinfo/*:Array<ColInfo>*/ = o.skipHidden && sheet[\"!cols\"] || [];\n\tvar rowinfo/*:Array<RowInfo>*/ = o.skipHidden && sheet[\"!rows\"] || [];\n\tfor(C = r.s.c; C <= r.e.c; ++C) {\n\t\tif(((colinfo[C]||{}).hidden)) continue;\n\t\tcols[C] = encode_col(C);\n\t\tval = dense ? sheet[R][C] : sheet[cols[C] + rr];\n\t\tswitch(header) {\n\t\t\tcase 1: hdr[C] = C - r.s.c; break;\n\t\t\tcase 2: hdr[C] = cols[C]; break;\n\t\t\tcase 3: hdr[C] = o.header[C - r.s.c]; break;\n\t\t\tdefault:\n\t\t\t\tif(val == null) val = {w: \"__EMPTY\", t: \"s\"};\n\t\t\t\tvv = v = format_cell(val, null, o);\n\t\t\t\tcounter = header_cnt[v] || 0;\n\t\t\t\tif(!counter) header_cnt[v] = 1;\n\t\t\t\telse {\n\t\t\t\t\tdo { vv = v + \"_\" + (counter++); } while(header_cnt[vv]); header_cnt[v] = counter;\n\t\t\t\t\theader_cnt[vv] = 1;\n\t\t\t\t}\n\t\t\t\thdr[C] = vv;\n\t\t}\n\t}\n\tR = r.s.r + offset;\n\tstream._read = function() {\n\t\twhile(R <= r.e.r) {\n\t\t\tif ((rowinfo[R-1]||{}).hidden) continue;\n\t\t\tvar row = make_json_row(sheet, r, R, cols, header, hdr, dense, o);\n\t\t\t++R;\n\t\t\tif((row.isempty === false) || (header === 1 ? o.blankrows !== false : !!o.blankrows)) {\n\t\t\t\tstream.push(row.row);\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t\treturn stream.push(null);\n\t};\n\treturn stream;\n}\n\nvar __stream = {\n\tto_json: write_json_stream,\n\tto_html: write_html_stream,\n\tto_csv: write_csv_stream,\n  set_readable: set_readable\n};\nexport const version = XLSX.version;\nexport {\n\tparse_xlscfb,\n\tparse_zip,\n\treadSync as read,\n\treadFileSync as readFile,\n\treadFileSync,\n\twriteSync as write,\n\twriteFileSync as writeFile,\n\twriteFileSync,\n\twriteFileAsync,\n\twriteSyncXLSX as writeXLSX,\n\twriteFileSyncXLSX as writeFileXLSX,\n\tutils,\n\t__stream as stream,\n\tSSF,\n\tCFB\n};\n","export function parseDataSheet(sheet, options) {\n  const { keepUndefined } = options;\n  const data = sheet.data.slice(1);\n  const variableNames = data.shift();\n  const variableUnits = data.shift();\n  const variables = [];\n  for (let j = 0; j < data.length; j++) {\n    if (!keepUndefined) {\n      let containsUndefined = false;\n      for (let i = 0; i < variableNames.length; i++) {\n        if (data[j][i] === undefined) {\n          containsUndefined = true;\n        }\n      }\n      if (containsUndefined) {\n        continue;\n      }\n    }\n    for (let i = 0; i < variableNames.length; i++) {\n      variables.push({\n        label: variableNames[i],\n        units: variableUnits[i],\n        data: [],\n      });\n      variables[i].data.push(data[j][i]);\n    }\n  }\n  return variables;\n}\n\nexport function checkVariables(parsed, variables) {\n  for (let i = 0; i < parsed.length; i++) {\n    const targetVariable = variables[Object.keys(variables)[i]];\n    if (!targetVariable) {\n      continue;\n    }\n    if (\n      parsed[i].label !== targetVariable.label ||\n      parsed[i].units !== targetVariable.units\n    ) {\n      throw new Error(\n        `Column ${i} is not ${targetVariable.label} in ${targetVariable.units}`,\n      );\n    }\n  }\n}\n","export function calculateResidual(result) {\n  if (!result?.meta?.zones) return;\n  if (!result?.meta?.sampleMass) return;\n\n  const zones = result.meta.zones;\n  let relativeResidual = 1;\n  const residual = {\n    value: result.meta.sampleMass.value,\n    units: result.meta.sampleMass.units,\n  };\n  for (let zone of zones) {\n    if (residual.units !== zone.massLoss.units) {\n      throw new Error('zone mass loss units different from sample mass units');\n    }\n    residual.value -= zone.massLoss.value;\n    relativeResidual -= zone.relativeMassLoss;\n  }\n  zones.push({\n    relativeMassLoss: relativeResidual,\n    massLoss: residual,\n    kind: 'Residual',\n  });\n}\n","/**\n * If the line starts with a text it is a label\n * @param {string} [text='']\n * @return {object}\n */\nexport function createLabeledRecords(text = '') {\n  let result = new Map(); // garanty the order of the keys\n  let lines = text.split(/[\\r\\n]+/);\n  let label = '';\n  for (let line of lines) {\n    if (line.startsWith(' ')) {\n      // we continue the previous field\n      let currentValue = result.get(label) || '';\n      if (currentValue) currentValue += '\\n';\n      if (line.startsWith('  ')) line = line.substring(2);\n      currentValue += line;\n      result.set(label, currentValue);\n    } else {\n      // it is a new label\n      label = line.replace(/:$/, '');\n    }\n  }\n  return result;\n}\n","/**\n * Return an object with the value and the unit\n * @param {string} [value]\n * @param {object} [options={}]\n * @param {number} [options.factor=1] multiply value by a factor during conversion\n * @return {object}\n */\nexport function split(string, options = {}) {\n  const { factor = 1 } = options;\n  const { stringValue, units } = string.match(\n    /(?<stringValue>[0-9.-]+[eE]?[0-9.-]*)(?<units>.*)/,\n    '$1',\n  ).groups;\n\n  return {\n    value: Number(stringValue) * factor,\n    units: units.trim(),\n  };\n}\n","import { split } from 'value-units';\n\n/**\n * We will parse some importation information that are present in the labeledRecords\n */\n\nexport function getMetaTGA(labeledRecords) {\n  let meta = {};\n  if (labeledRecords.get('Method')) {\n    meta.method = labeledRecords.get('Method');\n  }\n  if (labeledRecords.get('Sample Holder')) {\n    meta.holder = parseHolder(labeledRecords.get('Sample Holder'));\n  }\n  meta.initialValue = split(labeledRecords.get('Initial Value'));\n  if (labeledRecords.has('Results')) {\n    meta.zones = parseResults(labeledRecords.get('Results'));\n  }\n  return meta;\n}\n\nfunction parseHolder(text) {\n  if (!text) return {};\n  let holder = {};\n  let lines = text.split('\\n');\n  for (let line of lines) {\n    if (line.includes(':')) {\n      let fields = line.split(':', 2);\n      let label = fields[0].trim().toLowerCase();\n      let value = fields[1].trim();\n      switch (label) {\n        case 'weight':\n          holder.mass = split(value);\n          break;\n        case 'material':\n          holder[label] = value;\n          break;\n        default:\n      }\n    } else {\n      holder.kind = line.trim();\n    }\n  }\n  return holder;\n}\n\nfunction parseResults(text) {\n  let results = [];\n  let result = {};\n  let lines = text.split('\\n');\n  for (let i = 0; i < lines.length; i++) {\n    let line = lines[i];\n    let nextLine = lines[i + 1];\n    line = line.replace(/^\\? /, '');\n    if (line.includes('Step')) {\n      result = {};\n      results.push(result);\n      if (!line.includes('%')) {\n        throw new Error('tga parsing problem, step does not contain %');\n      }\n      result.relativeMassLoss =\n        Number(line.replace(/^.*Step(.*)%.*/, '$1')) / -100;\n      result.massLoss = split(nextLine, { factor: -1 });\n    } else if (line.startsWith('Type')) {\n      result.kind = line.replace('Type', '').trim();\n    } else if (line.startsWith('Left Limit')) {\n      result.from = split(line.replace('Left Limit', ''));\n    } else if (line.startsWith('Right Limit')) {\n      result.to = split(line.replace('Right Limit', ''));\n    } else if (line.startsWith('Midpoint')) {\n      result.middlePoint = split(line.replace('Midpoint', ''));\n    } else if (line.startsWith('Inflect. Pt.')) {\n      result.inflectionPoint = split(line.replace('Inflect. Pt.', ''));\n    }\n  }\n  return results;\n}\n","export function improveRelativeResult(result) {\n  if (result.meta.initialValue.units === 'mg') {\n    result.meta.sampleMass = result.meta.initialValue;\n    return;\n  }\n\n  if (result.meta.initialValue.units !== '%') return;\n  if (result.meta.zones?.length < 1) return;\n\n  const firstZone = result.meta.zones[0];\n\n  if (firstZone.massLoss.units !== 'mg') return;\n  if (Math.abs(firstZone.massLoss.value) < 0.0001) return;\n\n  result.meta.sampleMass = {\n    value: firstZone.massLoss.value / firstZone.relativeMassLoss,\n    units: firstZone.massLoss.units,\n  };\n\n  // we can now calculate the 'y' variable\n  const ratio = result.meta.sampleMass.value / result.meta.initialValue.value;\n\n  const percentData = result.variables['%'].data;\n  result.variables.y = {\n    label: 'Weight',\n    units: result.meta.sampleMass.units,\n    data: [],\n  };\n  for (let i = 0; i < percentData.length; i++) {\n    result.variables.y.data.push(percentData[i] * ratio);\n  }\n}\n","export function parseCurveValues(text = '') {\n  let lines = text.split('\\n').filter((line) => line.replace(/ /g, '') !== '');\n  let result = { columnIndex: [] };\n  // the 2 first lines are information about the data\n  // the first line is the label\n  // the second line is the unit\n  for (let i = 0; i < lines.length; i++) {\n    let fields = lines[i].trim().split(/ {2,}/);\n    if (i === 0) {\n      result.labels = fields;\n      result.data = new Array(fields.length);\n      for (let j = 0; j < fields.length; j++) {\n        result.columnIndex[fields[j]] = j;\n        result.data[j] = [];\n      }\n    } else if (i === 1) {\n      result.units = new Array(result.labels.length - fields.length);\n      result.units = result.units.concat(\n        fields.map((field) => field.replace(/[[\\]]/g, '')),\n      );\n    } else {\n      if (fields.length !== result.labels.length) {\n        throw new Error('Can not parse data for line: ', fields);\n      }\n      for (let j = 0; j < fields.length; j++) {\n        let value = Number(fields[j]);\n        if (isNaN(value)) {\n          throw new Error('Problem parsing number: ', fields[j]);\n        }\n        result.data[j].push(value);\n      }\n    }\n  }\n  return result;\n}\n","import { getParts } from './utils/getParts';\n\nconst decoder = new TextDecoder('iso8859-1');\n\nexport function hgParseThermoFinnigan(blob) {\n  let text = decoder.decode(blob);\n\n  let lines = text.split(/\\r?\\n/);\n  let parts = getParts(lines);\n  let meta = {\n    solidReporting: parseMeta(parts, 'SOLID REPORTING'),\n    testInformation: parseMeta(parts, 'TEST INFORMATION'),\n    analyticalConditions: parseMeta(parts, 'ANALYTICAL CONDITIONS'),\n    preparation: parseMeta(parts, 'PREPARATION'),\n    totalPoreSize: parseMeta(parts, 'TOTAL PORE SIZE'),\n    tableTotalPoreSize: parseTable(parts, 'TABLE TOTAL PORE SIZE'),\n    tableTotalSurfaceArea: parseTable(parts, 'TABLE TOTAL SURFACE AREA'),\n  };\n\n  let variables = parseExperimentalData(parts['EXPERIMENTAL DATA']);\n\n  // remove undefined values\n  Object.keys(meta).forEach((key) => {\n    if (meta[key] === undefined) {\n      delete meta[key];\n    }\n  });\n  return { meta, variables };\n}\n\nfunction parseTable(parts, label) {\n  if (!parts[label]) {\n    return undefined;\n  }\n  let lines = parts[label].map((line) =>\n    line\n      .replace(/,+$/, '')\n      .split(/; * /)\n      .map((field) => field.trim()),\n  );\n\n  let headers = lines[0]\n    .filter((field) => field)\n    .map((field, index) => `${field}[${lines[1][index].replace(/[()]/g, '')}]`);\n\n  let result = [];\n  for (let i = 2; i < lines.length; i++) {\n    const line = lines[i];\n    const currentLine = {};\n    headers.forEach((header, index) => (currentLine[header] = line[index]));\n    result.push(currentLine);\n  }\n  return result;\n}\n\nfunction parseMeta(parts, label) {\n  let parsed = {};\n  if (!parts[label]) {\n    return undefined;\n  }\n  for (let line of parts[label]) {\n    let label = line.replace(/^(.*?); *(.*)$/, '$1').replace(/:? *$/, '');\n    let value = line\n      .replace(/^(.*?); *(.*)$/, '$2')\n      .replace(/,+$/, '')\n      .replace(' : ; ', ' : ');\n    if (!isNaN(value)) {\n      value = Number(value);\n    }\n    parsed[label] = value;\n  }\n  return parsed;\n}\n\nfunction parseExperimentalData(lines) {\n  let variables = lines[0]\n    .replace(/,+$/, '')\n    .split(/; * /)\n    .map((header) => header.trim())\n    .map((line, index) => {\n      return {\n        symbol: String.fromCharCode(index + 65),\n        data: [],\n        label: line.replace(/ ?\\(.*/, ''),\n        units: line.replace(/.*\\((.*)\\).*/, '$1'),\n      };\n    });\n\n  for (let i = 1; i < lines.length; i++) {\n    let fields = lines[i].replace(/,*$/, '').split(/ *; */);\n    for (let j = 0; j < variables.length; j++) {\n      variables[j].data.push(Number(fields[j]));\n    }\n  }\n\n  const variablesObject = {};\n  variables.forEach((variable) => {\n    variablesObject[variable.symbol] = {\n      data: variable.data,\n      units: variable.units,\n      label: variable.label,\n    };\n  });\n\n  return variablesObject;\n}\n","import { ensureString } from 'ensure-string';\n\nimport { calculateResidual } from './util/calculateResidual';\nimport { createLabeledRecords } from './util/createLabeledRecords';\nimport { getMetaTGA } from './util/getMetaTGA';\nimport { improveRelativeResult } from './util/improveRelativeResult';\nimport { parseCurveValues } from './util/parseCurveValues';\n\nconst variables = {\n  't-s': { code: 't', label: 'time' },\n  'Ts-°C': { code: 'x', label: 'Temperature recorded' },\n  'Tr-°C': { code: 'r', label: 'Temperature programmed' },\n  'Value-mg': { code: 'y', label: 'Weight' },\n  'Value-mW': { code: 'p', label: 'Power' },\n  'Value-%': { code: '%', label: 'Percent' },\n};\n\nexport function tgaParseMettlerToledo(arrayBuffer) {\n  const text = ensureString(arrayBuffer);\n\n  let results = [];\n  // TGA text format may contain many parts separated by 'Curve Name'\n  const parts = text.split(/(?=Curve Name:)/);\n  for (const part of parts) {\n    if (part.startsWith('Curve Name:')) {\n      let labeledRecords = createLabeledRecords(part);\n      let parsedCurveValues;\n      if (labeledRecords.has('Curve Values')) {\n        parsedCurveValues = parseCurveValues(\n          labeledRecords.get('Curve Values'),\n        );\n        labeledRecords.set('Curve Values', parsedCurveValues);\n      }\n\n      improveTGALabeledRecords(labeledRecords);\n\n      const data = {};\n      for (let i = 0; i < parsedCurveValues.units.length; i++) {\n        const variableName =\n          parsedCurveValues.labels && parsedCurveValues.labels[i];\n        const units = parsedCurveValues.units && parsedCurveValues.units[i];\n        const dataValues = parsedCurveValues.data && parsedCurveValues.data[i];\n        const variable = variables[`${variableName}-${units}`];\n        if (variable && variable.code) {\n          data[variable.code] = {\n            units,\n            data: dataValues,\n            label: variable.label,\n          };\n        }\n      }\n\n      let result = {\n        meta: getMetaTGA(labeledRecords),\n        variables: data,\n        info: {\n          dataType: 'TGA',\n        },\n      };\n\n      improveRelativeResult(result);\n      calculateResidual(result);\n\n      results.push(result);\n    }\n  }\n  return results;\n}\n\nfunction improveTGALabeledRecords(labeledRecords) {\n  let record = labeledRecords.get('Curve Values');\n  let value = `${record.data[record.data.length - 1][0]} ${record.units[\n    record.data.length - 1\n  ].replace(/[[\\]]/g, '')}`;\n  labeledRecords.set('Initial Value', value);\n}\n","import { getAllSheetsFromXLS } from '../../utils/getAllSheetsFromXLS';\nimport {\n  checkVariables,\n  parseDataSheet,\n} from '../../utils/taInstrumentsUtilities.js';\n\nexport function tgaParseTAInstrumentsXLS(blob, options = {}) {\n  const { keepUndefined = false } = options;\n  const xlsSheets = getAllSheetsFromXLS(blob);\n\n  const sheets = [];\n  for (let xlsSheet of xlsSheets) {\n    if (xlsSheet.sheetName === 'Details') continue;\n    sheets.push({\n      name: xlsSheet.sheetName,\n      variables: getVariables([xlsSheet], { keepUndefined }),\n    });\n  }\n\n  return {\n    meta: getMeta(xlsSheets),\n    variables: getVariables(xlsSheets, { keepUndefined }),\n    sheets,\n  };\n}\n\nfunction getMeta(sheets) {\n  const sheet = sheets.find((sheet) => sheet.sheetName === 'Details');\n  if (!sheet) {\n    return {};\n  }\n  const meta = {};\n  for (let datum of sheet.data) {\n    meta[datum[0]] = datum[1];\n  }\n  return meta;\n}\n\nfunction getVariables(sheets, options) {\n  const { keepUndefined } = options;\n  sheets = sheets.filter((sheet) => sheet.sheetName !== 'Details');\n\n  const variables = {\n    t: {\n      symbol: 't',\n      label: 'Time',\n      units: 'min',\n      data: [],\n    },\n    x: {\n      symbol: 'x',\n      label: 'Temperature',\n      units: '°C',\n      data: [],\n    },\n    y: {\n      symbol: 'y',\n      label: 'Weight',\n      units: 'mg',\n      data: [],\n    },\n    z: {\n      symbol: 'z',\n      label: 'Weight',\n      units: '%',\n      data: [],\n    },\n  };\n\n  for (let sheet of sheets) {\n    const parsed = parseDataSheet(sheet, { keepUndefined });\n    checkVariables(parsed, variables);\n\n    variables.t.data = variables.t.data.concat(parsed[0].data);\n    variables.x.data = variables.x.data.concat(parsed[1].data);\n    variables.y.data = variables.y.data.concat(parsed[2].data);\n    variables.z.data = variables.z.data.concat(parsed[3].data);\n  }\n  return variables;\n}\n","import { read, utils } from 'xlsx';\n\nexport function getAllSheetsFromXLS(blob) {\n  const workbook = read(blob, { type: 'array' });\n\n  const sheets = [];\n  const sheetNames = workbook.SheetNames;\n  for (const sheetName of sheetNames) {\n    const sheet = {\n      sheetName,\n      data: utils.sheet_to_json(workbook.Sheets[sheetName], {\n        header: 1,\n      }),\n    };\n    if (!sheet.data.length) continue;\n    sheets.push(sheet);\n  }\n  return sheets;\n}\n","'use strict';\n\nconst nameStartChar = ':A-Za-z_\\\\u00C0-\\\\u00D6\\\\u00D8-\\\\u00F6\\\\u00F8-\\\\u02FF\\\\u0370-\\\\u037D\\\\u037F-\\\\u1FFF\\\\u200C-\\\\u200D\\\\u2070-\\\\u218F\\\\u2C00-\\\\u2FEF\\\\u3001-\\\\uD7FF\\\\uF900-\\\\uFDCF\\\\uFDF0-\\\\uFFFD';\nconst nameChar = nameStartChar + '\\\\-.\\\\d\\\\u00B7\\\\u0300-\\\\u036F\\\\u203F-\\\\u2040';\nconst nameRegexp = '[' + nameStartChar + '][' + nameChar + ']*'\nconst regexName = new RegExp('^' + nameRegexp + '$');\n\nconst getAllMatches = function(string, regex) {\n  const matches = [];\n  let match = regex.exec(string);\n  while (match) {\n    const allmatches = [];\n    allmatches.startIndex = regex.lastIndex - match[0].length;\n    const len = match.length;\n    for (let index = 0; index < len; index++) {\n      allmatches.push(match[index]);\n    }\n    matches.push(allmatches);\n    match = regex.exec(string);\n  }\n  return matches;\n};\n\nconst isName = function(string) {\n  const match = regexName.exec(string);\n  return !(match === null || typeof match === 'undefined');\n};\n\nexports.isExist = function(v) {\n  return typeof v !== 'undefined';\n};\n\nexports.isEmptyObject = function(obj) {\n  return Object.keys(obj).length === 0;\n};\n\n/**\n * Copy all the properties of a into b.\n * @param {*} target\n * @param {*} a\n */\nexports.merge = function(target, a, arrayMode) {\n  if (a) {\n    const keys = Object.keys(a); // will return an array of own properties\n    const len = keys.length; //don't make it inline\n    for (let i = 0; i < len; i++) {\n      if (arrayMode === 'strict') {\n        target[keys[i]] = [ a[keys[i]] ];\n      } else {\n        target[keys[i]] = a[keys[i]];\n      }\n    }\n  }\n};\n/* exports.merge =function (b,a){\n  return Object.assign(b,a);\n} */\n\nexports.getValue = function(v) {\n  if (exports.isExist(v)) {\n    return v;\n  } else {\n    return '';\n  }\n};\n\n// const fakeCall = function(a) {return a;};\n// const fakeCallNoReturn = function() {};\n\nexports.isName = isName;\nexports.getAllMatches = getAllMatches;\nexports.nameRegexp = nameRegexp;\n","'use strict';\n\nconst util = require('./util');\n\nconst defaultOptions = {\n  allowBooleanAttributes: false, //A tag can have attributes without any value\n  unpairedTags: []\n};\n\n//const tagsPattern = new RegExp(\"<\\\\/?([\\\\w:\\\\-_\\.]+)\\\\s*\\/?>\",\"g\");\nexports.validate = function (xmlData, options) {\n  options = Object.assign({}, defaultOptions, options);\n\n  //xmlData = xmlData.replace(/(\\r\\n|\\n|\\r)/gm,\"\");//make it single line\n  //xmlData = xmlData.replace(/(^\\s*<\\?xml.*?\\?>)/g,\"\");//Remove XML starting tag\n  //xmlData = xmlData.replace(/(<!DOCTYPE[\\s\\w\\\"\\.\\/\\-\\:]+(\\[.*\\])*\\s*>)/g,\"\");//Remove DOCTYPE\n  const tags = [];\n  let tagFound = false;\n\n  //indicates that the root tag has been closed (aka. depth 0 has been reached)\n  let reachedRoot = false;\n\n  if (xmlData[0] === '\\ufeff') {\n    // check for byte order mark (BOM)\n    xmlData = xmlData.substr(1);\n  }\n  \n  for (let i = 0; i < xmlData.length; i++) {\n\n    if (xmlData[i] === '<' && xmlData[i+1] === '?') {\n      i+=2;\n      i = readPI(xmlData,i);\n      if (i.err) return i;\n    }else if (xmlData[i] === '<') {\n      //starting of tag\n      //read until you reach to '>' avoiding any '>' in attribute value\n      let tagStartPos = i;\n      i++;\n      \n      if (xmlData[i] === '!') {\n        i = readCommentAndCDATA(xmlData, i);\n        continue;\n      } else {\n        let closingTag = false;\n        if (xmlData[i] === '/') {\n          //closing tag\n          closingTag = true;\n          i++;\n        }\n        //read tagname\n        let tagName = '';\n        for (; i < xmlData.length &&\n          xmlData[i] !== '>' &&\n          xmlData[i] !== ' ' &&\n          xmlData[i] !== '\\t' &&\n          xmlData[i] !== '\\n' &&\n          xmlData[i] !== '\\r'; i++\n        ) {\n          tagName += xmlData[i];\n        }\n        tagName = tagName.trim();\n        //console.log(tagName);\n\n        if (tagName[tagName.length - 1] === '/') {\n          //self closing tag without attributes\n          tagName = tagName.substring(0, tagName.length - 1);\n          //continue;\n          i--;\n        }\n        if (!validateTagName(tagName)) {\n          let msg;\n          if (tagName.trim().length === 0) {\n            msg = \"Invalid space after '<'.\";\n          } else {\n            msg = \"Tag '\"+tagName+\"' is an invalid name.\";\n          }\n          return getErrorObject('InvalidTag', msg, getLineNumberForPosition(xmlData, i));\n        }\n\n        const result = readAttributeStr(xmlData, i);\n        if (result === false) {\n          return getErrorObject('InvalidAttr', \"Attributes for '\"+tagName+\"' have open quote.\", getLineNumberForPosition(xmlData, i));\n        }\n        let attrStr = result.value;\n        i = result.index;\n\n        if (attrStr[attrStr.length - 1] === '/') {\n          //self closing tag\n          const attrStrStart = i - attrStr.length;\n          attrStr = attrStr.substring(0, attrStr.length - 1);\n          const isValid = validateAttributeString(attrStr, options);\n          if (isValid === true) {\n            tagFound = true;\n            //continue; //text may presents after self closing tag\n          } else {\n            //the result from the nested function returns the position of the error within the attribute\n            //in order to get the 'true' error line, we need to calculate the position where the attribute begins (i - attrStr.length) and then add the position within the attribute\n            //this gives us the absolute index in the entire xml, which we can use to find the line at last\n            return getErrorObject(isValid.err.code, isValid.err.msg, getLineNumberForPosition(xmlData, attrStrStart + isValid.err.line));\n          }\n        } else if (closingTag) {\n          if (!result.tagClosed) {\n            return getErrorObject('InvalidTag', \"Closing tag '\"+tagName+\"' doesn't have proper closing.\", getLineNumberForPosition(xmlData, i));\n          } else if (attrStr.trim().length > 0) {\n            return getErrorObject('InvalidTag', \"Closing tag '\"+tagName+\"' can't have attributes or invalid starting.\", getLineNumberForPosition(xmlData, tagStartPos));\n          } else if (tags.length === 0) {\n            return getErrorObject('InvalidTag', \"Closing tag '\"+tagName+\"' has not been opened.\", getLineNumberForPosition(xmlData, tagStartPos));\n          } else {\n            const otg = tags.pop();\n            if (tagName !== otg.tagName) {\n              let openPos = getLineNumberForPosition(xmlData, otg.tagStartPos);\n              return getErrorObject('InvalidTag',\n                \"Expected closing tag '\"+otg.tagName+\"' (opened in line \"+openPos.line+\", col \"+openPos.col+\") instead of closing tag '\"+tagName+\"'.\",\n                getLineNumberForPosition(xmlData, tagStartPos));\n            }\n\n            //when there are no more tags, we reached the root level.\n            if (tags.length == 0) {\n              reachedRoot = true;\n            }\n          }\n        } else {\n          const isValid = validateAttributeString(attrStr, options);\n          if (isValid !== true) {\n            //the result from the nested function returns the position of the error within the attribute\n            //in order to get the 'true' error line, we need to calculate the position where the attribute begins (i - attrStr.length) and then add the position within the attribute\n            //this gives us the absolute index in the entire xml, which we can use to find the line at last\n            return getErrorObject(isValid.err.code, isValid.err.msg, getLineNumberForPosition(xmlData, i - attrStr.length + isValid.err.line));\n          }\n\n          //if the root level has been reached before ...\n          if (reachedRoot === true) {\n            return getErrorObject('InvalidXml', 'Multiple possible root nodes found.', getLineNumberForPosition(xmlData, i));\n          } else if(options.unpairedTags.indexOf(tagName) !== -1){\n            //don't push into stack\n          } else {\n            tags.push({tagName, tagStartPos});\n          }\n          tagFound = true;\n        }\n\n        //skip tag text value\n        //It may include comments and CDATA value\n        for (i++; i < xmlData.length; i++) {\n          if (xmlData[i] === '<') {\n            if (xmlData[i + 1] === '!') {\n              //comment or CADATA\n              i++;\n              i = readCommentAndCDATA(xmlData, i);\n              continue;\n            } else if (xmlData[i+1] === '?') {\n              i = readPI(xmlData, ++i);\n              if (i.err) return i;\n            } else{\n              break;\n            }\n          } else if (xmlData[i] === '&') {\n            const afterAmp = validateAmpersand(xmlData, i);\n            if (afterAmp == -1)\n              return getErrorObject('InvalidChar', \"char '&' is not expected.\", getLineNumberForPosition(xmlData, i));\n            i = afterAmp;\n          }else{\n            if (reachedRoot === true && !isWhiteSpace(xmlData[i])) {\n              return getErrorObject('InvalidXml', \"Extra text at the end\", getLineNumberForPosition(xmlData, i));\n            }\n          }\n        } //end of reading tag text value\n        if (xmlData[i] === '<') {\n          i--;\n        }\n      }\n    } else {\n      if ( isWhiteSpace(xmlData[i])) {\n        continue;\n      }\n      return getErrorObject('InvalidChar', \"char '\"+xmlData[i]+\"' is not expected.\", getLineNumberForPosition(xmlData, i));\n    }\n  }\n\n  if (!tagFound) {\n    return getErrorObject('InvalidXml', 'Start tag expected.', 1);\n  }else if (tags.length == 1) {\n      return getErrorObject('InvalidTag', \"Unclosed tag '\"+tags[0].tagName+\"'.\", getLineNumberForPosition(xmlData, tags[0].tagStartPos));\n  }else if (tags.length > 0) {\n      return getErrorObject('InvalidXml', \"Invalid '\"+\n          JSON.stringify(tags.map(t => t.tagName), null, 4).replace(/\\r?\\n/g, '')+\n          \"' found.\", {line: 1, col: 1});\n  }\n\n  return true;\n};\n\nfunction isWhiteSpace(char){\n  return char === ' ' || char === '\\t' || char === '\\n'  || char === '\\r';\n}\n/**\n * Read Processing insstructions and skip\n * @param {*} xmlData\n * @param {*} i\n */\nfunction readPI(xmlData, i) {\n  const start = i;\n  for (; i < xmlData.length; i++) {\n    if (xmlData[i] == '?' || xmlData[i] == ' ') {\n      //tagname\n      const tagname = xmlData.substr(start, i - start);\n      if (i > 5 && tagname === 'xml') {\n        return getErrorObject('InvalidXml', 'XML declaration allowed only at the start of the document.', getLineNumberForPosition(xmlData, i));\n      } else if (xmlData[i] == '?' && xmlData[i + 1] == '>') {\n        //check if valid attribut string\n        i++;\n        break;\n      } else {\n        continue;\n      }\n    }\n  }\n  return i;\n}\n\nfunction readCommentAndCDATA(xmlData, i) {\n  if (xmlData.length > i + 5 && xmlData[i + 1] === '-' && xmlData[i + 2] === '-') {\n    //comment\n    for (i += 3; i < xmlData.length; i++) {\n      if (xmlData[i] === '-' && xmlData[i + 1] === '-' && xmlData[i + 2] === '>') {\n        i += 2;\n        break;\n      }\n    }\n  } else if (\n    xmlData.length > i + 8 &&\n    xmlData[i + 1] === 'D' &&\n    xmlData[i + 2] === 'O' &&\n    xmlData[i + 3] === 'C' &&\n    xmlData[i + 4] === 'T' &&\n    xmlData[i + 5] === 'Y' &&\n    xmlData[i + 6] === 'P' &&\n    xmlData[i + 7] === 'E'\n  ) {\n    let angleBracketsCount = 1;\n    for (i += 8; i < xmlData.length; i++) {\n      if (xmlData[i] === '<') {\n        angleBracketsCount++;\n      } else if (xmlData[i] === '>') {\n        angleBracketsCount--;\n        if (angleBracketsCount === 0) {\n          break;\n        }\n      }\n    }\n  } else if (\n    xmlData.length > i + 9 &&\n    xmlData[i + 1] === '[' &&\n    xmlData[i + 2] === 'C' &&\n    xmlData[i + 3] === 'D' &&\n    xmlData[i + 4] === 'A' &&\n    xmlData[i + 5] === 'T' &&\n    xmlData[i + 6] === 'A' &&\n    xmlData[i + 7] === '['\n  ) {\n    for (i += 8; i < xmlData.length; i++) {\n      if (xmlData[i] === ']' && xmlData[i + 1] === ']' && xmlData[i + 2] === '>') {\n        i += 2;\n        break;\n      }\n    }\n  }\n\n  return i;\n}\n\nconst doubleQuote = '\"';\nconst singleQuote = \"'\";\n\n/**\n * Keep reading xmlData until '<' is found outside the attribute value.\n * @param {string} xmlData\n * @param {number} i\n */\nfunction readAttributeStr(xmlData, i) {\n  let attrStr = '';\n  let startChar = '';\n  let tagClosed = false;\n  for (; i < xmlData.length; i++) {\n    if (xmlData[i] === doubleQuote || xmlData[i] === singleQuote) {\n      if (startChar === '') {\n        startChar = xmlData[i];\n      } else if (startChar !== xmlData[i]) {\n        //if vaue is enclosed with double quote then single quotes are allowed inside the value and vice versa\n      } else {\n        startChar = '';\n      }\n    } else if (xmlData[i] === '>') {\n      if (startChar === '') {\n        tagClosed = true;\n        break;\n      }\n    }\n    attrStr += xmlData[i];\n  }\n  if (startChar !== '') {\n    return false;\n  }\n\n  return {\n    value: attrStr,\n    index: i,\n    tagClosed: tagClosed\n  };\n}\n\n/**\n * Select all the attributes whether valid or invalid.\n */\nconst validAttrStrRegxp = new RegExp('(\\\\s*)([^\\\\s=]+)(\\\\s*=)?(\\\\s*([\\'\"])(([\\\\s\\\\S])*?)\\\\5)?', 'g');\n\n//attr, =\"sd\", a=\"amit's\", a=\"sd\"b=\"saf\", ab  cd=\"\"\n\nfunction validateAttributeString(attrStr, options) {\n  //console.log(\"start:\"+attrStr+\":end\");\n\n  //if(attrStr.trim().length === 0) return true; //empty string\n\n  const matches = util.getAllMatches(attrStr, validAttrStrRegxp);\n  const attrNames = {};\n\n  for (let i = 0; i < matches.length; i++) {\n    if (matches[i][1].length === 0) {\n      //nospace before attribute name: a=\"sd\"b=\"saf\"\n      return getErrorObject('InvalidAttr', \"Attribute '\"+matches[i][2]+\"' has no space in starting.\", getPositionFromMatch(matches[i]))\n    } else if (matches[i][3] !== undefined && matches[i][4] === undefined) {\n      return getErrorObject('InvalidAttr', \"Attribute '\"+matches[i][2]+\"' is without value.\", getPositionFromMatch(matches[i]));\n    } else if (matches[i][3] === undefined && !options.allowBooleanAttributes) {\n      //independent attribute: ab\n      return getErrorObject('InvalidAttr', \"boolean attribute '\"+matches[i][2]+\"' is not allowed.\", getPositionFromMatch(matches[i]));\n    }\n    /* else if(matches[i][6] === undefined){//attribute without value: ab=\n                    return { err: { code:\"InvalidAttr\",msg:\"attribute \" + matches[i][2] + \" has no value assigned.\"}};\n                } */\n    const attrName = matches[i][2];\n    if (!validateAttrName(attrName)) {\n      return getErrorObject('InvalidAttr', \"Attribute '\"+attrName+\"' is an invalid name.\", getPositionFromMatch(matches[i]));\n    }\n    if (!attrNames.hasOwnProperty(attrName)) {\n      //check for duplicate attribute.\n      attrNames[attrName] = 1;\n    } else {\n      return getErrorObject('InvalidAttr', \"Attribute '\"+attrName+\"' is repeated.\", getPositionFromMatch(matches[i]));\n    }\n  }\n\n  return true;\n}\n\nfunction validateNumberAmpersand(xmlData, i) {\n  let re = /\\d/;\n  if (xmlData[i] === 'x') {\n    i++;\n    re = /[\\da-fA-F]/;\n  }\n  for (; i < xmlData.length; i++) {\n    if (xmlData[i] === ';')\n      return i;\n    if (!xmlData[i].match(re))\n      break;\n  }\n  return -1;\n}\n\nfunction validateAmpersand(xmlData, i) {\n  // https://www.w3.org/TR/xml/#dt-charref\n  i++;\n  if (xmlData[i] === ';')\n    return -1;\n  if (xmlData[i] === '#') {\n    i++;\n    return validateNumberAmpersand(xmlData, i);\n  }\n  let count = 0;\n  for (; i < xmlData.length; i++, count++) {\n    if (xmlData[i].match(/\\w/) && count < 20)\n      continue;\n    if (xmlData[i] === ';')\n      break;\n    return -1;\n  }\n  return i;\n}\n\nfunction getErrorObject(code, message, lineNumber) {\n  return {\n    err: {\n      code: code,\n      msg: message,\n      line: lineNumber.line || lineNumber,\n      col: lineNumber.col,\n    },\n  };\n}\n\nfunction validateAttrName(attrName) {\n  return util.isName(attrName);\n}\n\n// const startsWithXML = /^xml/i;\n\nfunction validateTagName(tagname) {\n  return util.isName(tagname) /* && !tagname.match(startsWithXML) */;\n}\n\n//this function returns the line number for the character at the given index\nfunction getLineNumberForPosition(xmlData, index) {\n  const lines = xmlData.substring(0, index).split(/\\r?\\n/);\n  return {\n    line: lines.length,\n\n    // column number is last line's length + 1, because column numbering starts at 1:\n    col: lines[lines.length - 1].length + 1\n  };\n}\n\n//this function returns the position of the first character of match within attrStr\nfunction getPositionFromMatch(match) {\n  return match.startIndex + match[1].length;\n}\n","const EOL = \"\\n\";\n\n/**\n * \n * @param {array} jArray \n * @param {any} options \n * @returns \n */\nfunction toXml(jArray, options) {\n    let indentation = \"\";\n    if (options.format && options.indentBy.length > 0) {\n        indentation = EOL;\n    }\n    return arrToStr(jArray, options, \"\", indentation);\n}\n\nfunction arrToStr(arr, options, jPath, indentation) {\n    let xmlStr = \"\";\n    let isPreviousElementTag = false;\n\n    for (let i = 0; i < arr.length; i++) {\n        const tagObj = arr[i];\n        const tagName = propName(tagObj);\n        if(tagName === undefined) continue;\n\n        let newJPath = \"\";\n        if (jPath.length === 0) newJPath = tagName\n        else newJPath = `${jPath}.${tagName}`;\n\n        if (tagName === options.textNodeName) {\n            let tagText = tagObj[tagName];\n            if (!isStopNode(newJPath, options)) {\n                tagText = options.tagValueProcessor(tagName, tagText);\n                tagText = replaceEntitiesValue(tagText, options);\n            }\n            if (isPreviousElementTag) {\n                xmlStr += indentation;\n            }\n            xmlStr += tagText;\n            isPreviousElementTag = false;\n            continue;\n        } else if (tagName === options.cdataPropName) {\n            if (isPreviousElementTag) {\n                xmlStr += indentation;\n            }\n            xmlStr += `<![CDATA[${tagObj[tagName][0][options.textNodeName]}]]>`;\n            isPreviousElementTag = false;\n            continue;\n        } else if (tagName === options.commentPropName) {\n            xmlStr += indentation + `<!--${tagObj[tagName][0][options.textNodeName]}-->`;\n            isPreviousElementTag = true;\n            continue;\n        } else if (tagName[0] === \"?\") {\n            const attStr = attr_to_str(tagObj[\":@\"], options);\n            const tempInd = tagName === \"?xml\" ? \"\" : indentation;\n            let piTextNodeName = tagObj[tagName][0][options.textNodeName];\n            piTextNodeName = piTextNodeName.length !== 0 ? \" \" + piTextNodeName : \"\"; //remove extra spacing\n            xmlStr += tempInd + `<${tagName}${piTextNodeName}${attStr}?>`;\n            isPreviousElementTag = true;\n            continue;\n        }\n        let newIdentation = indentation;\n        if (newIdentation !== \"\") {\n            newIdentation += options.indentBy;\n        }\n        const attStr = attr_to_str(tagObj[\":@\"], options);\n        const tagStart = indentation + `<${tagName}${attStr}`;\n        const tagValue = arrToStr(tagObj[tagName], options, newJPath, newIdentation);\n        if (options.unpairedTags.indexOf(tagName) !== -1) {\n            if (options.suppressUnpairedNode) xmlStr += tagStart + \">\";\n            else xmlStr += tagStart + \"/>\";\n        } else if ((!tagValue || tagValue.length === 0) && options.suppressEmptyNode) {\n            xmlStr += tagStart + \"/>\";\n        } else if (tagValue && tagValue.endsWith(\">\")) {\n            xmlStr += tagStart + `>${tagValue}${indentation}</${tagName}>`;\n        } else {\n            xmlStr += tagStart + \">\";\n            if (tagValue && indentation !== \"\" && (tagValue.includes(\"/>\") || tagValue.includes(\"</\"))) {\n                xmlStr += indentation + options.indentBy + tagValue + indentation;\n            } else {\n                xmlStr += tagValue;\n            }\n            xmlStr += `</${tagName}>`;\n        }\n        isPreviousElementTag = true;\n    }\n\n    return xmlStr;\n}\n\nfunction propName(obj) {\n    const keys = Object.keys(obj);\n    for (let i = 0; i < keys.length; i++) {\n        const key = keys[i];\n        if(!obj.hasOwnProperty(key)) continue;\n        if (key !== \":@\") return key;\n    }\n}\n\nfunction attr_to_str(attrMap, options) {\n    let attrStr = \"\";\n    if (attrMap && !options.ignoreAttributes) {\n        for (let attr in attrMap) {\n            if(!attrMap.hasOwnProperty(attr)) continue;\n            let attrVal = options.attributeValueProcessor(attr, attrMap[attr]);\n            attrVal = replaceEntitiesValue(attrVal, options);\n            if (attrVal === true && options.suppressBooleanAttributes) {\n                attrStr += ` ${attr.substr(options.attributeNamePrefix.length)}`;\n            } else {\n                attrStr += ` ${attr.substr(options.attributeNamePrefix.length)}=\"${attrVal}\"`;\n            }\n        }\n    }\n    return attrStr;\n}\n\nfunction isStopNode(jPath, options) {\n    jPath = jPath.substr(0, jPath.length - options.textNodeName.length - 1);\n    let tagName = jPath.substr(jPath.lastIndexOf(\".\") + 1);\n    for (let index in options.stopNodes) {\n        if (options.stopNodes[index] === jPath || options.stopNodes[index] === \"*.\" + tagName) return true;\n    }\n    return false;\n}\n\nfunction replaceEntitiesValue(textValue, options) {\n    if (textValue && textValue.length > 0 && options.processEntities) {\n        for (let i = 0; i < options.entities.length; i++) {\n            const entity = options.entities[i];\n            textValue = textValue.replace(entity.regex, entity.val);\n        }\n    }\n    return textValue;\n}\nmodule.exports = toXml;\n","'use strict';\n//parse Empty Node as self closing node\nconst buildFromOrderedJs = require('./orderedJs2Xml');\nconst getIgnoreAttributesFn = require('../ignoreAttributes')\n\nconst defaultOptions = {\n  attributeNamePrefix: '@_',\n  attributesGroupName: false,\n  textNodeName: '#text',\n  ignoreAttributes: true,\n  cdataPropName: false,\n  format: false,\n  indentBy: '  ',\n  suppressEmptyNode: false,\n  suppressUnpairedNode: true,\n  suppressBooleanAttributes: true,\n  tagValueProcessor: function(key, a) {\n    return a;\n  },\n  attributeValueProcessor: function(attrName, a) {\n    return a;\n  },\n  preserveOrder: false,\n  commentPropName: false,\n  unpairedTags: [],\n  entities: [\n    { regex: new RegExp(\"&\", \"g\"), val: \"&amp;\" },//it must be on top\n    { regex: new RegExp(\">\", \"g\"), val: \"&gt;\" },\n    { regex: new RegExp(\"<\", \"g\"), val: \"&lt;\" },\n    { regex: new RegExp(\"\\'\", \"g\"), val: \"&apos;\" },\n    { regex: new RegExp(\"\\\"\", \"g\"), val: \"&quot;\" }\n  ],\n  processEntities: true,\n  stopNodes: [],\n  // transformTagName: false,\n  // transformAttributeName: false,\n  oneListGroup: false\n};\n\nfunction Builder(options) {\n  this.options = Object.assign({}, defaultOptions, options);\n  if (this.options.ignoreAttributes === true || this.options.attributesGroupName) {\n    this.isAttribute = function(/*a*/) {\n      return false;\n    };\n  } else {\n    this.ignoreAttributesFn = getIgnoreAttributesFn(this.options.ignoreAttributes)\n    this.attrPrefixLen = this.options.attributeNamePrefix.length;\n    this.isAttribute = isAttribute;\n  }\n\n  this.processTextOrObjNode = processTextOrObjNode\n\n  if (this.options.format) {\n    this.indentate = indentate;\n    this.tagEndChar = '>\\n';\n    this.newLine = '\\n';\n  } else {\n    this.indentate = function() {\n      return '';\n    };\n    this.tagEndChar = '>';\n    this.newLine = '';\n  }\n}\n\nBuilder.prototype.build = function(jObj) {\n  if(this.options.preserveOrder){\n    return buildFromOrderedJs(jObj, this.options);\n  }else {\n    if(Array.isArray(jObj) && this.options.arrayNodeName && this.options.arrayNodeName.length > 1){\n      jObj = {\n        [this.options.arrayNodeName] : jObj\n      }\n    }\n    return this.j2x(jObj, 0, []).val;\n  }\n};\n\nBuilder.prototype.j2x = function(jObj, level, ajPath) {\n  let attrStr = '';\n  let val = '';\n  const jPath = ajPath.join('.')\n  for (let key in jObj) {\n    if(!Object.prototype.hasOwnProperty.call(jObj, key)) continue;\n    if (typeof jObj[key] === 'undefined') {\n      // supress undefined node only if it is not an attribute\n      if (this.isAttribute(key)) {\n        val += '';\n      }\n    } else if (jObj[key] === null) {\n      // null attribute should be ignored by the attribute list, but should not cause the tag closing\n      if (this.isAttribute(key)) {\n        val += '';\n      } else if (key === this.options.cdataPropName) {\n        val += '';\n      } else if (key[0] === '?') {\n        val += this.indentate(level) + '<' + key + '?' + this.tagEndChar;\n      } else {\n        val += this.indentate(level) + '<' + key + '/' + this.tagEndChar;\n      }\n      // val += this.indentate(level) + '<' + key + '/' + this.tagEndChar;\n    } else if (jObj[key] instanceof Date) {\n      val += this.buildTextValNode(jObj[key], key, '', level);\n    } else if (typeof jObj[key] !== 'object') {\n      //premitive type\n      const attr = this.isAttribute(key);\n      if (attr && !this.ignoreAttributesFn(attr, jPath)) {\n        attrStr += this.buildAttrPairStr(attr, '' + jObj[key]);\n      } else if (!attr) {\n        //tag value\n        if (key === this.options.textNodeName) {\n          let newval = this.options.tagValueProcessor(key, '' + jObj[key]);\n          val += this.replaceEntitiesValue(newval);\n        } else {\n          val += this.buildTextValNode(jObj[key], key, '', level);\n        }\n      }\n    } else if (Array.isArray(jObj[key])) {\n      //repeated nodes\n      const arrLen = jObj[key].length;\n      let listTagVal = \"\";\n      let listTagAttr = \"\";\n      for (let j = 0; j < arrLen; j++) {\n        const item = jObj[key][j];\n        if (typeof item === 'undefined') {\n          // supress undefined node\n        } else if (item === null) {\n          if(key[0] === \"?\") val += this.indentate(level) + '<' + key + '?' + this.tagEndChar;\n          else val += this.indentate(level) + '<' + key + '/' + this.tagEndChar;\n          // val += this.indentate(level) + '<' + key + '/' + this.tagEndChar;\n        } else if (typeof item === 'object') {\n          if(this.options.oneListGroup){\n            const result = this.j2x(item, level + 1, ajPath.concat(key));\n            listTagVal += result.val;\n            if (this.options.attributesGroupName && item.hasOwnProperty(this.options.attributesGroupName)) {\n              listTagAttr += result.attrStr\n            }\n          }else{\n            listTagVal += this.processTextOrObjNode(item, key, level, ajPath)\n          }\n        } else {\n          if (this.options.oneListGroup) {\n            let textValue = this.options.tagValueProcessor(key, item);\n            textValue = this.replaceEntitiesValue(textValue);\n            listTagVal += textValue;\n          } else {\n            listTagVal += this.buildTextValNode(item, key, '', level);\n          }\n        }\n      }\n      if(this.options.oneListGroup){\n        listTagVal = this.buildObjectNode(listTagVal, key, listTagAttr, level);\n      }\n      val += listTagVal;\n    } else {\n      //nested node\n      if (this.options.attributesGroupName && key === this.options.attributesGroupName) {\n        const Ks = Object.keys(jObj[key]);\n        const L = Ks.length;\n        for (let j = 0; j < L; j++) {\n          attrStr += this.buildAttrPairStr(Ks[j], '' + jObj[key][Ks[j]]);\n        }\n      } else {\n        val += this.processTextOrObjNode(jObj[key], key, level, ajPath)\n      }\n    }\n  }\n  return {attrStr: attrStr, val: val};\n};\n\nBuilder.prototype.buildAttrPairStr = function(attrName, val){\n  val = this.options.attributeValueProcessor(attrName, '' + val);\n  val = this.replaceEntitiesValue(val);\n  if (this.options.suppressBooleanAttributes && val === \"true\") {\n    return ' ' + attrName;\n  } else return ' ' + attrName + '=\"' + val + '\"';\n}\n\nfunction processTextOrObjNode (object, key, level, ajPath) {\n  const result = this.j2x(object, level + 1, ajPath.concat(key));\n  if (object[this.options.textNodeName] !== undefined && Object.keys(object).length === 1) {\n    return this.buildTextValNode(object[this.options.textNodeName], key, result.attrStr, level);\n  } else {\n    return this.buildObjectNode(result.val, key, result.attrStr, level);\n  }\n}\n\nBuilder.prototype.buildObjectNode = function(val, key, attrStr, level) {\n  if(val === \"\"){\n    if(key[0] === \"?\") return  this.indentate(level) + '<' + key + attrStr+ '?' + this.tagEndChar;\n    else {\n      return this.indentate(level) + '<' + key + attrStr + this.closeTag(key) + this.tagEndChar;\n    }\n  }else{\n\n    let tagEndExp = '</' + key + this.tagEndChar;\n    let piClosingChar = \"\";\n    \n    if(key[0] === \"?\") {\n      piClosingChar = \"?\";\n      tagEndExp = \"\";\n    }\n  \n    // attrStr is an empty string in case the attribute came as undefined or null\n    if ((attrStr || attrStr === '') && val.indexOf('<') === -1) {\n      return ( this.indentate(level) + '<' +  key + attrStr + piClosingChar + '>' + val + tagEndExp );\n    } else if (this.options.commentPropName !== false && key === this.options.commentPropName && piClosingChar.length === 0) {\n      return this.indentate(level) + `<!--${val}-->` + this.newLine;\n    }else {\n      return (\n        this.indentate(level) + '<' + key + attrStr + piClosingChar + this.tagEndChar +\n        val +\n        this.indentate(level) + tagEndExp    );\n    }\n  }\n}\n\nBuilder.prototype.closeTag = function(key){\n  let closeTag = \"\";\n  if(this.options.unpairedTags.indexOf(key) !== -1){ //unpaired\n    if(!this.options.suppressUnpairedNode) closeTag = \"/\"\n  }else if(this.options.suppressEmptyNode){ //empty\n    closeTag = \"/\";\n  }else{\n    closeTag = `></${key}`\n  }\n  return closeTag;\n}\n\nfunction buildEmptyObjNode(val, key, attrStr, level) {\n  if (val !== '') {\n    return this.buildObjectNode(val, key, attrStr, level);\n  } else {\n    if(key[0] === \"?\") return  this.indentate(level) + '<' + key + attrStr+ '?' + this.tagEndChar;\n    else {\n      return  this.indentate(level) + '<' + key + attrStr + '/' + this.tagEndChar;\n      // return this.buildTagStr(level,key, attrStr);\n    }\n  }\n}\n\nBuilder.prototype.buildTextValNode = function(val, key, attrStr, level) {\n  if (this.options.cdataPropName !== false && key === this.options.cdataPropName) {\n    return this.indentate(level) + `<![CDATA[${val}]]>` +  this.newLine;\n  }else if (this.options.commentPropName !== false && key === this.options.commentPropName) {\n    return this.indentate(level) + `<!--${val}-->` +  this.newLine;\n  }else if(key[0] === \"?\") {//PI tag\n    return  this.indentate(level) + '<' + key + attrStr+ '?' + this.tagEndChar; \n  }else{\n    let textValue = this.options.tagValueProcessor(key, val);\n    textValue = this.replaceEntitiesValue(textValue);\n  \n    if( textValue === ''){\n      return this.indentate(level) + '<' + key + attrStr + this.closeTag(key) + this.tagEndChar;\n    }else{\n      return this.indentate(level) + '<' + key + attrStr + '>' +\n         textValue +\n        '</' + key + this.tagEndChar;\n    }\n  }\n}\n\nBuilder.prototype.replaceEntitiesValue = function(textValue){\n  if(textValue && textValue.length > 0 && this.options.processEntities){\n    for (let i=0; i<this.options.entities.length; i++) {\n      const entity = this.options.entities[i];\n      textValue = textValue.replace(entity.regex, entity.val);\n    }\n  }\n  return textValue;\n}\n\nfunction indentate(level) {\n  return this.options.indentBy.repeat(level);\n}\n\nfunction isAttribute(name /*, options*/) {\n  if (name.startsWith(this.options.attributeNamePrefix) && name !== this.options.textNodeName) {\n    return name.substr(this.attrPrefixLen);\n  } else {\n    return false;\n  }\n}\n\nmodule.exports = Builder;\n","function getIgnoreAttributesFn(ignoreAttributes) {\n    if (typeof ignoreAttributes === 'function') {\n        return ignoreAttributes\n    }\n    if (Array.isArray(ignoreAttributes)) {\n        return (attrName) => {\n            for (const pattern of ignoreAttributes) {\n                if (typeof pattern === 'string' && attrName === pattern) {\n                    return true\n                }\n                if (pattern instanceof RegExp && pattern.test(attrName)) {\n                    return true\n                }\n            }\n        }\n    }\n    return () => false\n}\n\nmodule.exports = getIgnoreAttributesFn","// @ts-expect-error imported library for which we don't have types\nimport { tgaParseMettlerToledo } from 'physical-chemistry-parser';\nimport { Analysis } from '../index.js';\nexport function fromMettlerToledo(arrayBuffer) {\n    const analysis = new Analysis();\n    const results = tgaParseMettlerToledo(arrayBuffer);\n    // we try to find the right results\n    const result = results.find((result) => result.variables?.y &&\n        (result.variables.y.units === 'mg' || result.variables.y.units === '%'));\n    const cheminfo = { meta: result.meta };\n    analysis.pushSpectrum(result.variables, {\n        dataType: 'TGA',\n        meta: { ...result.meta, cheminfo },\n    });\n    return analysis;\n}\n//# sourceMappingURL=fromMettlerToledo.js.map","import { Analysis } from 'common-spectrum';\nimport { ensureString } from 'ensure-string';\nexport function fromNetzsch(arrayBuffer) {\n    const text = ensureString(arrayBuffer, { encoding: 'iso8859-1' });\n    const lines = text.split(/\\r?\\n/).filter(Boolean);\n    const parsed = {\n        meta: {},\n        variables: {\n            x: {\n                data: [],\n                label: 'Sample temperature [°C]',\n                isDependent: true,\n            },\n            y: {\n                data: [],\n                label: 'Weight [mg]',\n                isDependent: true,\n            },\n            t: {\n                data: [],\n                label: 'Time [min]',\n                isDependent: false,\n            },\n        },\n    };\n    let inData = false;\n    for (const line of lines) {\n        if (inData) {\n            const [temperature, time, weight] = line\n                .split(';')\n                .map(Number.parseFloat);\n            parsed.variables.x.data.push(temperature);\n            parsed.variables.y.data.push(weight);\n            parsed.variables.t.data.push(time);\n        }\n        else if (line.startsWith('##')) {\n            inData = true;\n        }\n        else {\n            const groups = /#(?<label>.*?):(?<value>.*)/.exec(line)?.groups;\n            if (!groups)\n                throw new Error('TGA Netzsch parsing error');\n            const { label, value } = groups;\n            parsed.meta[label] = value;\n        }\n    }\n    const mass = Number.parseFloat(parsed.meta['SAMPLE MASS /mg']);\n    parsed.variables.y.data = parsed.variables.y.data.map((i) => {\n        return (i / 100) * mass;\n    });\n    const analysis = new Analysis();\n    analysis.pushSpectrum(parsed.variables, {\n        meta: parsed.meta,\n        dataType: 'TGA',\n    });\n    return analysis;\n}\n//# sourceMappingURL=fromNetzsch.js.map","import { ensureString } from 'ensure-string';\nexport function parsePerkinElmerAscii(blob) {\n    const sections = getSections(blob);\n    return sections;\n}\nfunction getSections(blob) {\n    const result = {\n        header: {},\n        methodSteps: {\n            info: [],\n            steps: [],\n        },\n        footer: '',\n    };\n    const text = ensureString(blob);\n    const lines = text.split(/\\r?\\n/);\n    let currentSection = 'header';\n    let currentStep = {\n        id: 0,\n        label: '',\n        description: '',\n        variables: [],\n    };\n    let dataHeaders = [];\n    for (let i = 0; i < lines.length; i++) {\n        const line = lines[i];\n        if (line.startsWith('Method Steps:')) {\n            currentSection = 'methodSteps';\n            continue;\n        }\n        if (currentSection === 'methodSteps' &&\n            line.startsWith('1)') &&\n            result.methodSteps.steps.length > 0) {\n            currentSection = 'dataFirstLine';\n        }\n        switch (currentSection) {\n            case 'header':\n                {\n                    const [key, ...rest] = line.split(':').map((s) => s.trim());\n                    const value = rest.join(':');\n                    if (key && value.length > 0) {\n                        result.header[key] = value;\n                    }\n                }\n                break;\n            case 'methodSteps':\n                if (line.match(/^[0-9]/)) {\n                    // 1)\tHold for 1.0 min at 50.00�C\n                    const match = line.match(/^([0-9]+)\\)\\s+/);\n                    if (match) {\n                        result.methodSteps.steps.push({\n                            id: Number.parseInt(match[1], 10),\n                            label: line.replace('\\t', ' ').trim(),\n                            description: '',\n                            variables: [],\n                        });\n                    }\n                }\n                else {\n                    if (line.trim() === '')\n                        continue;\n                    result.methodSteps.info.push(line.replaceAll('\\t', '  '));\n                }\n                break;\n            case 'dataFirstLine':\n                {\n                    const { step, description } = parseDataBlockHeader(line, result);\n                    currentStep = step;\n                    currentStep.description = description;\n                    currentSection = 'dataHeader';\n                }\n                break;\n            case 'dataHeader':\n                dataHeaders = parseDataHeader(line, lines[i + 1]);\n                i++;\n                currentSection = 'data';\n                currentStep.variables = structuredClone(dataHeaders);\n                break;\n            case 'data':\n                if (line.trim() === '') {\n                    currentSection = 'endData';\n                    continue;\n                }\n                if (line.match(/^[0-9+]\\)/)) {\n                    // new data block\n                    const { description, step } = parseDataBlockHeader(line, result);\n                    currentStep = step;\n                    currentStep.variables = structuredClone(dataHeaders);\n                    currentStep.description = description;\n                }\n                else {\n                    const dataParts = line\n                        .split('\\t')\n                        .map((s) => s.trim())\n                        .map(Number);\n                    if (dataParts.length !== currentStep?.variables.length) {\n                        throw new Error(`Data length mismatch in step ${currentStep?.id}: expected ${currentStep?.variables.length}, got ${dataParts.length}`);\n                    }\n                    for (let j = 0; j < dataParts.length; j++) {\n                        currentStep?.variables[j].data.push(dataParts[j]);\n                    }\n                }\n                break;\n            case 'endData':\n                if (line.trim() === '') {\n                    continue;\n                }\n                currentSection = 'footer';\n                break;\n            case 'footer': {\n                result.footer += `${line}\\n`;\n                break;\n            }\n            default:\n                break;\n        }\n    }\n    return result;\n}\nfunction parseDataBlockHeader(line, result) {\n    const match = line.match(/^([0-9]+)\\) (.+)/);\n    if (!match) {\n        throw new Error(`Could not parse data block header line: ${line}`);\n    }\n    const id = Number.parseInt(match[1], 10);\n    // find the corresponding step\n    const step = result.methodSteps.steps.find((s) => s.id === id);\n    if (!step) {\n        throw new Error(`Could not find method step for data block id: ${id}`);\n    }\n    return {\n        id,\n        description: match[2].trim(),\n        step,\n    };\n}\n/**\n * need to combine both lines to get the full header information as an array\n * @param line\n * @param nextLine\n */\nfunction parseDataHeader(line, nextLine) {\n    const firstLineParts = line.split('\\t').map((s) => s.trim());\n    const secondLineParts = nextLine.split('\\t').map((s) => s.trim());\n    const combined = [];\n    for (let i = 0; i < firstLineParts.length; i++) {\n        let combinedHeader = firstLineParts[i];\n        if (i < secondLineParts.length && secondLineParts[i] !== '') {\n            combinedHeader += ` ${secondLineParts[i]}`;\n        }\n        combined.push(combinedHeader);\n    }\n    return combined.map((label) => ({ label, data: [] }));\n}\n//# sourceMappingURL=parsePerkinElmerAscii.js.map","import { ensureString } from 'ensure-string';\nimport { Analysis } from '../index.js';\nimport { parsePerkinElmerAscii } from \"./parser/parsePerkinElmerAscii.js\";\n/**\n * Creates a new Chromatogram element based in a JCAMP string\n * @param text - String containing the JCAMP data\n * @param arrayBuffer\n * @returns - New class element with the given data\n */\nexport function fromPerkinElmer(arrayBuffer) {\n    const text = ensureString(arrayBuffer);\n    const analysis = new Analysis();\n    const parsed = parsePerkinElmerAscii(text);\n    const meta = {\n        ...parsed.header,\n        stepsInfo: parsed.methodSteps.info,\n        methodSteps: parsed.methodSteps.steps.map((step) => step.label),\n        footer: parsed.footer,\n    };\n    const variables = parsed.methodSteps.steps[0].variables;\n    for (let i = 1; i < parsed.methodSteps.steps.length; i++) {\n        const stepVariable = parsed.methodSteps.steps[i].variables;\n        for (let j = 0; j < variables.length; j++) {\n            if (variables[j].data && stepVariable[j].data) {\n                variables[j].data = variables[j].data.concat(stepVariable[j].data);\n            }\n        }\n    }\n    analysis.pushSpectrum({\n        x: {\n            data: variables.find((v) => v.label.startsWith('Sample Temperature'))\n                ?.data || [],\n            label: 'Temperature [°C]',\n        },\n        y: {\n            data: variables.find((v) => v.label.startsWith('Unsubtracted Weight'))\n                ?.data || [],\n            label: 'Weight [mg]',\n        },\n    }, {\n        dataType: 'TGA',\n        title: meta['Sample ID'] || '',\n        meta,\n    });\n    analysis.pushSpectrum({\n        x: {\n            data: variables.find((v) => v.label.startsWith('Time'))?.data || [],\n            label: 'Time [min]',\n        },\n        y: {\n            data: variables.find((v) => v.label.startsWith('Unsubtracted Weight'))\n                ?.data || [],\n            label: 'Weight [mg]',\n        },\n    }, {\n        dataType: 'TGA',\n        title: meta['Sample ID'] || '',\n        meta,\n    });\n    return analysis;\n}\n//# sourceMappingURL=fromPerkinElmer.js.map","const decoder = new TextDecoder('iso8859-1');\n\nexport function xrfParserPanalytical(blob) {\n  let text = decoder.decode(blob);\n\n  let lines = text.split(/\\r?\\n/);\n  let meta = {};\n  let headers;\n  let data = [];\n  let variables = {};\n  for (let line of lines) {\n    if (line.includes(':')) {\n      let fields = line.split(/ +: +/);\n      let value = fields.slice(1).join(':');\n      let numberValue = value.replace(/,/g, '.');\n      meta[fields[0]] = isNaN(numberValue) ? value : parseFloat(numberValue);\n    } else if (line.match(/^[A-Z]/)) {\n      // header of tables\n      headers = line.split(/\\t/);\n    } else if (line.match(/^\\s*$/)) {\n      // skip this line\n    } else {\n      data.push(\n        line.split(/\\t/).map((field) => parseFloat(field.replace(',', '.'))),\n      );\n    }\n  }\n  for (let i = 0; i < headers.length; i++) {\n    let id;\n    switch (i) {\n      case 0:\n        id = 'X';\n        break;\n      case 1:\n        id = 'Y';\n        break;\n      default:\n        id = String.fromCharCode(63 + i);\n    }\n    let units = headers[i].split('(')[1];\n    units = units ? units.replace(')', '') : '';\n    variables[id] = {\n      label: headers[i].replace(/ \\(.*/, ''),\n      units,\n      data: data.map((datum) => datum[i]),\n    };\n  }\n  return { meta, variables };\n}\n","/* @license\nPapa Parse\nv5.5.3\nhttps://github.com/mholt/PapaParse\nLicense: MIT\n*/\n((e,t)=>{\"function\"==typeof define&&define.amd?define([],t):\"object\"==typeof module&&\"undefined\"!=typeof exports?module.exports=t():e.Papa=t()})(this,function r(){var n=\"undefined\"!=typeof self?self:\"undefined\"!=typeof window?window:void 0!==n?n:{};var d,s=!n.document&&!!n.postMessage,a=n.IS_PAPA_WORKER||!1,o={},h=0,v={};function u(e){this._handle=null,this._finished=!1,this._completed=!1,this._halted=!1,this._input=null,this._baseIndex=0,this._partialLine=\"\",this._rowCount=0,this._start=0,this._nextChunk=null,this.isFirstChunk=!0,this._completeResults={data:[],errors:[],meta:{}},function(e){var t=b(e);t.chunkSize=parseInt(t.chunkSize),e.step||e.chunk||(t.chunkSize=null);this._handle=new i(t),(this._handle.streamer=this)._config=t}.call(this,e),this.parseChunk=function(t,e){var i=parseInt(this._config.skipFirstNLines)||0;if(this.isFirstChunk&&0<i){let e=this._config.newline;e||(r=this._config.quoteChar||'\"',e=this._handle.guessLineEndings(t,r)),t=[...t.split(e).slice(i)].join(e)}this.isFirstChunk&&U(this._config.beforeFirstChunk)&&void 0!==(r=this._config.beforeFirstChunk(t))&&(t=r),this.isFirstChunk=!1,this._halted=!1;var i=this._partialLine+t,r=(this._partialLine=\"\",this._handle.parse(i,this._baseIndex,!this._finished));if(!this._handle.paused()&&!this._handle.aborted()){t=r.meta.cursor,i=(this._finished||(this._partialLine=i.substring(t-this._baseIndex),this._baseIndex=t),r&&r.data&&(this._rowCount+=r.data.length),this._finished||this._config.preview&&this._rowCount>=this._config.preview);if(a)n.postMessage({results:r,workerId:v.WORKER_ID,finished:i});else if(U(this._config.chunk)&&!e){if(this._config.chunk(r,this._handle),this._handle.paused()||this._handle.aborted())return void(this._halted=!0);this._completeResults=r=void 0}return this._config.step||this._config.chunk||(this._completeResults.data=this._completeResults.data.concat(r.data),this._completeResults.errors=this._completeResults.errors.concat(r.errors),this._completeResults.meta=r.meta),this._completed||!i||!U(this._config.complete)||r&&r.meta.aborted||(this._config.complete(this._completeResults,this._input),this._completed=!0),i||r&&r.meta.paused||this._nextChunk(),r}this._halted=!0},this._sendError=function(e){U(this._config.error)?this._config.error(e):a&&this._config.error&&n.postMessage({workerId:v.WORKER_ID,error:e,finished:!1})}}function f(e){var r;(e=e||{}).chunkSize||(e.chunkSize=v.RemoteChunkSize),u.call(this,e),this._nextChunk=s?function(){this._readChunk(),this._chunkLoaded()}:function(){this._readChunk()},this.stream=function(e){this._input=e,this._nextChunk()},this._readChunk=function(){if(this._finished)this._chunkLoaded();else{if(r=new XMLHttpRequest,this._config.withCredentials&&(r.withCredentials=this._config.withCredentials),s||(r.onload=y(this._chunkLoaded,this),r.onerror=y(this._chunkError,this)),r.open(this._config.downloadRequestBody?\"POST\":\"GET\",this._input,!s),this._config.downloadRequestHeaders){var e,t=this._config.downloadRequestHeaders;for(e in t)r.setRequestHeader(e,t[e])}var i;this._config.chunkSize&&(i=this._start+this._config.chunkSize-1,r.setRequestHeader(\"Range\",\"bytes=\"+this._start+\"-\"+i));try{r.send(this._config.downloadRequestBody)}catch(e){this._chunkError(e.message)}s&&0===r.status&&this._chunkError()}},this._chunkLoaded=function(){4===r.readyState&&(r.status<200||400<=r.status?this._chunkError():(this._start+=this._config.chunkSize||r.responseText.length,this._finished=!this._config.chunkSize||this._start>=(e=>null!==(e=e.getResponseHeader(\"Content-Range\"))?parseInt(e.substring(e.lastIndexOf(\"/\")+1)):-1)(r),this.parseChunk(r.responseText)))},this._chunkError=function(e){e=r.statusText||e;this._sendError(new Error(e))}}function l(e){(e=e||{}).chunkSize||(e.chunkSize=v.LocalChunkSize),u.call(this,e);var i,r,n=\"undefined\"!=typeof FileReader;this.stream=function(e){this._input=e,r=e.slice||e.webkitSlice||e.mozSlice,n?((i=new FileReader).onload=y(this._chunkLoaded,this),i.onerror=y(this._chunkError,this)):i=new FileReaderSync,this._nextChunk()},this._nextChunk=function(){this._finished||this._config.preview&&!(this._rowCount<this._config.preview)||this._readChunk()},this._readChunk=function(){var e=this._input,t=(this._config.chunkSize&&(t=Math.min(this._start+this._config.chunkSize,this._input.size),e=r.call(e,this._start,t)),i.readAsText(e,this._config.encoding));n||this._chunkLoaded({target:{result:t}})},this._chunkLoaded=function(e){this._start+=this._config.chunkSize,this._finished=!this._config.chunkSize||this._start>=this._input.size,this.parseChunk(e.target.result)},this._chunkError=function(){this._sendError(i.error)}}function c(e){var i;u.call(this,e=e||{}),this.stream=function(e){return i=e,this._nextChunk()},this._nextChunk=function(){var e,t;if(!this._finished)return e=this._config.chunkSize,i=e?(t=i.substring(0,e),i.substring(e)):(t=i,\"\"),this._finished=!i,this.parseChunk(t)}}function p(e){u.call(this,e=e||{});var t=[],i=!0,r=!1;this.pause=function(){u.prototype.pause.apply(this,arguments),this._input.pause()},this.resume=function(){u.prototype.resume.apply(this,arguments),this._input.resume()},this.stream=function(e){this._input=e,this._input.on(\"data\",this._streamData),this._input.on(\"end\",this._streamEnd),this._input.on(\"error\",this._streamError)},this._checkIsFinished=function(){r&&1===t.length&&(this._finished=!0)},this._nextChunk=function(){this._checkIsFinished(),t.length?this.parseChunk(t.shift()):i=!0},this._streamData=y(function(e){try{t.push(\"string\"==typeof e?e:e.toString(this._config.encoding)),i&&(i=!1,this._checkIsFinished(),this.parseChunk(t.shift()))}catch(e){this._streamError(e)}},this),this._streamError=y(function(e){this._streamCleanUp(),this._sendError(e)},this),this._streamEnd=y(function(){this._streamCleanUp(),r=!0,this._streamData(\"\")},this),this._streamCleanUp=y(function(){this._input.removeListener(\"data\",this._streamData),this._input.removeListener(\"end\",this._streamEnd),this._input.removeListener(\"error\",this._streamError)},this)}function i(m){var n,s,a,t,o=Math.pow(2,53),h=-o,u=/^\\s*-?(\\d+\\.?|\\.\\d+|\\d+\\.\\d+)([eE][-+]?\\d+)?\\s*$/,d=/^((\\d{4}-[01]\\d-[0-3]\\dT[0-2]\\d:[0-5]\\d:[0-5]\\d\\.\\d+([+-][0-2]\\d:[0-5]\\d|Z))|(\\d{4}-[01]\\d-[0-3]\\dT[0-2]\\d:[0-5]\\d:[0-5]\\d([+-][0-2]\\d:[0-5]\\d|Z))|(\\d{4}-[01]\\d-[0-3]\\dT[0-2]\\d:[0-5]\\d([+-][0-2]\\d:[0-5]\\d|Z)))$/,i=this,r=0,f=0,l=!1,e=!1,c=[],p={data:[],errors:[],meta:{}};function y(e){return\"greedy\"===m.skipEmptyLines?\"\"===e.join(\"\").trim():1===e.length&&0===e[0].length}function g(){if(p&&a&&(k(\"Delimiter\",\"UndetectableDelimiter\",\"Unable to auto-detect delimiting character; defaulted to '\"+v.DefaultDelimiter+\"'\"),a=!1),m.skipEmptyLines&&(p.data=p.data.filter(function(e){return!y(e)})),_()){if(p)if(Array.isArray(p.data[0])){for(var e=0;_()&&e<p.data.length;e++)p.data[e].forEach(t);p.data.splice(0,1)}else p.data.forEach(t);function t(e,t){U(m.transformHeader)&&(e=m.transformHeader(e,t)),c.push(e)}}function i(e,t){for(var i=m.header?{}:[],r=0;r<e.length;r++){var n=r,s=e[r],s=((e,t)=>(e=>(m.dynamicTypingFunction&&void 0===m.dynamicTyping[e]&&(m.dynamicTyping[e]=m.dynamicTypingFunction(e)),!0===(m.dynamicTyping[e]||m.dynamicTyping)))(e)?\"true\"===t||\"TRUE\"===t||\"false\"!==t&&\"FALSE\"!==t&&((e=>{if(u.test(e)){e=parseFloat(e);if(h<e&&e<o)return 1}})(t)?parseFloat(t):d.test(t)?new Date(t):\"\"===t?null:t):t)(n=m.header?r>=c.length?\"__parsed_extra\":c[r]:n,s=m.transform?m.transform(s,n):s);\"__parsed_extra\"===n?(i[n]=i[n]||[],i[n].push(s)):i[n]=s}return m.header&&(r>c.length?k(\"FieldMismatch\",\"TooManyFields\",\"Too many fields: expected \"+c.length+\" fields but parsed \"+r,f+t):r<c.length&&k(\"FieldMismatch\",\"TooFewFields\",\"Too few fields: expected \"+c.length+\" fields but parsed \"+r,f+t)),i}var r;p&&(m.header||m.dynamicTyping||m.transform)&&(r=1,!p.data.length||Array.isArray(p.data[0])?(p.data=p.data.map(i),r=p.data.length):p.data=i(p.data,0),m.header&&p.meta&&(p.meta.fields=c),f+=r)}function _(){return m.header&&0===c.length}function k(e,t,i,r){e={type:e,code:t,message:i};void 0!==r&&(e.row=r),p.errors.push(e)}U(m.step)&&(t=m.step,m.step=function(e){p=e,_()?g():(g(),0!==p.data.length&&(r+=e.data.length,m.preview&&r>m.preview?s.abort():(p.data=p.data[0],t(p,i))))}),this.parse=function(e,t,i){var r=m.quoteChar||'\"',r=(m.newline||(m.newline=this.guessLineEndings(e,r)),a=!1,m.delimiter?U(m.delimiter)&&(m.delimiter=m.delimiter(e),p.meta.delimiter=m.delimiter):((r=((e,t,i,r,n)=>{var s,a,o,h;n=n||[\",\",\"\\t\",\"|\",\";\",v.RECORD_SEP,v.UNIT_SEP];for(var u=0;u<n.length;u++){for(var d,f=n[u],l=0,c=0,p=0,g=(o=void 0,new E({comments:r,delimiter:f,newline:t,preview:10}).parse(e)),_=0;_<g.data.length;_++)i&&y(g.data[_])?p++:(d=g.data[_].length,c+=d,void 0===o?o=d:0<d&&(l+=Math.abs(d-o),o=d));0<g.data.length&&(c/=g.data.length-p),(void 0===a||l<=a)&&(void 0===h||h<c)&&1.99<c&&(a=l,s=f,h=c)}return{successful:!!(m.delimiter=s),bestDelimiter:s}})(e,m.newline,m.skipEmptyLines,m.comments,m.delimitersToGuess)).successful?m.delimiter=r.bestDelimiter:(a=!0,m.delimiter=v.DefaultDelimiter),p.meta.delimiter=m.delimiter),b(m));return m.preview&&m.header&&r.preview++,n=e,s=new E(r),p=s.parse(n,t,i),g(),l?{meta:{paused:!0}}:p||{meta:{paused:!1}}},this.paused=function(){return l},this.pause=function(){l=!0,s.abort(),n=U(m.chunk)?\"\":n.substring(s.getCharIndex())},this.resume=function(){i.streamer._halted?(l=!1,i.streamer.parseChunk(n,!0)):setTimeout(i.resume,3)},this.aborted=function(){return e},this.abort=function(){e=!0,s.abort(),p.meta.aborted=!0,U(m.complete)&&m.complete(p),n=\"\"},this.guessLineEndings=function(e,t){e=e.substring(0,1048576);var t=new RegExp(P(t)+\"([^]*?)\"+P(t),\"gm\"),i=(e=e.replace(t,\"\")).split(\"\\r\"),t=e.split(\"\\n\"),e=1<t.length&&t[0].length<i[0].length;if(1===i.length||e)return\"\\n\";for(var r=0,n=0;n<i.length;n++)\"\\n\"===i[n][0]&&r++;return r>=i.length/2?\"\\r\\n\":\"\\r\"}}function P(e){return e.replace(/[.*+?^${}()|[\\]\\\\]/g,\"\\\\$&\")}function E(C){var S=(C=C||{}).delimiter,O=C.newline,x=C.comments,I=C.step,A=C.preview,T=C.fastMode,D=null,L=!1,F=null==C.quoteChar?'\"':C.quoteChar,j=F;if(void 0!==C.escapeChar&&(j=C.escapeChar),(\"string\"!=typeof S||-1<v.BAD_DELIMITERS.indexOf(S))&&(S=\",\"),x===S)throw new Error(\"Comment character same as delimiter\");!0===x?x=\"#\":(\"string\"!=typeof x||-1<v.BAD_DELIMITERS.indexOf(x))&&(x=!1),\"\\n\"!==O&&\"\\r\"!==O&&\"\\r\\n\"!==O&&(O=\"\\n\");var z=0,M=!1;this.parse=function(i,t,r){if(\"string\"!=typeof i)throw new Error(\"Input must be a string\");var n=i.length,e=S.length,s=O.length,a=x.length,o=U(I),h=[],u=[],d=[],f=z=0;if(!i)return w();if(T||!1!==T&&-1===i.indexOf(F)){for(var l=i.split(O),c=0;c<l.length;c++){if(d=l[c],z+=d.length,c!==l.length-1)z+=O.length;else if(r)return w();if(!x||d.substring(0,a)!==x){if(o){if(h=[],k(d.split(S)),R(),M)return w()}else k(d.split(S));if(A&&A<=c)return h=h.slice(0,A),w(!0)}}return w()}for(var p=i.indexOf(S,z),g=i.indexOf(O,z),_=new RegExp(P(j)+P(F),\"g\"),m=i.indexOf(F,z);;)if(i[z]===F)for(m=z,z++;;){if(-1===(m=i.indexOf(F,m+1)))return r||u.push({type:\"Quotes\",code:\"MissingQuotes\",message:\"Quoted field unterminated\",row:h.length,index:z}),E();if(m===n-1)return E(i.substring(z,m).replace(_,F));if(F===j&&i[m+1]===j)m++;else if(F===j||0===m||i[m-1]!==j){-1!==p&&p<m+1&&(p=i.indexOf(S,m+1));var y=v(-1===(g=-1!==g&&g<m+1?i.indexOf(O,m+1):g)?p:Math.min(p,g));if(i.substr(m+1+y,e)===S){d.push(i.substring(z,m).replace(_,F)),i[z=m+1+y+e]!==F&&(m=i.indexOf(F,z)),p=i.indexOf(S,z),g=i.indexOf(O,z);break}y=v(g);if(i.substring(m+1+y,m+1+y+s)===O){if(d.push(i.substring(z,m).replace(_,F)),b(m+1+y+s),p=i.indexOf(S,z),m=i.indexOf(F,z),o&&(R(),M))return w();if(A&&h.length>=A)return w(!0);break}u.push({type:\"Quotes\",code:\"InvalidQuotes\",message:\"Trailing quote on quoted field is malformed\",row:h.length,index:z}),m++}}else if(x&&0===d.length&&i.substring(z,z+a)===x){if(-1===g)return w();z=g+s,g=i.indexOf(O,z),p=i.indexOf(S,z)}else if(-1!==p&&(p<g||-1===g))d.push(i.substring(z,p)),z=p+e,p=i.indexOf(S,z);else{if(-1===g)break;if(d.push(i.substring(z,g)),b(g+s),o&&(R(),M))return w();if(A&&h.length>=A)return w(!0)}return E();function k(e){h.push(e),f=z}function v(e){var t=0;return t=-1!==e&&(e=i.substring(m+1,e))&&\"\"===e.trim()?e.length:t}function E(e){return r||(void 0===e&&(e=i.substring(z)),d.push(e),z=n,k(d),o&&R()),w()}function b(e){z=e,k(d),d=[],g=i.indexOf(O,z)}function w(e){if(C.header&&!t&&h.length&&!L){var s=h[0],a=Object.create(null),o=new Set(s);let n=!1;for(let r=0;r<s.length;r++){let i=s[r];if(a[i=U(C.transformHeader)?C.transformHeader(i,r):i]){let e,t=a[i];for(;e=i+\"_\"+t,t++,o.has(e););o.add(e),s[r]=e,a[i]++,n=!0,(D=null===D?{}:D)[e]=i}else a[i]=1,s[r]=i;o.add(i)}n&&console.warn(\"Duplicate headers found and renamed.\"),L=!0}return{data:h,errors:u,meta:{delimiter:S,linebreak:O,aborted:M,truncated:!!e,cursor:f+(t||0),renamedHeaders:D}}}function R(){I(w()),h=[],u=[]}},this.abort=function(){M=!0},this.getCharIndex=function(){return z}}function g(e){var t=e.data,i=o[t.workerId],r=!1;if(t.error)i.userError(t.error,t.file);else if(t.results&&t.results.data){var n={abort:function(){r=!0,_(t.workerId,{data:[],errors:[],meta:{aborted:!0}})},pause:m,resume:m};if(U(i.userStep)){for(var s=0;s<t.results.data.length&&(i.userStep({data:t.results.data[s],errors:t.results.errors,meta:t.results.meta},n),!r);s++);delete t.results}else U(i.userChunk)&&(i.userChunk(t.results,n,t.file),delete t.results)}t.finished&&!r&&_(t.workerId,t.results)}function _(e,t){var i=o[e];U(i.userComplete)&&i.userComplete(t),i.terminate(),delete o[e]}function m(){throw new Error(\"Not implemented.\")}function b(e){if(\"object\"!=typeof e||null===e)return e;var t,i=Array.isArray(e)?[]:{};for(t in e)i[t]=b(e[t]);return i}function y(e,t){return function(){e.apply(t,arguments)}}function U(e){return\"function\"==typeof e}return v.parse=function(e,t){var i=(t=t||{}).dynamicTyping||!1;U(i)&&(t.dynamicTypingFunction=i,i={});if(t.dynamicTyping=i,t.transform=!!U(t.transform)&&t.transform,!t.worker||!v.WORKERS_SUPPORTED)return i=null,v.NODE_STREAM_INPUT,\"string\"==typeof e?(e=(e=>65279!==e.charCodeAt(0)?e:e.slice(1))(e),i=new(t.download?f:c)(t)):!0===e.readable&&U(e.read)&&U(e.on)?i=new p(t):(n.File&&e instanceof File||e instanceof Object)&&(i=new l(t)),i.stream(e);(i=(()=>{var e;return!!v.WORKERS_SUPPORTED&&(e=(()=>{var e=n.URL||n.webkitURL||null,t=r.toString();return v.BLOB_URL||(v.BLOB_URL=e.createObjectURL(new Blob([\"var global = (function() { if (typeof self !== 'undefined') { return self; } if (typeof window !== 'undefined') { return window; } if (typeof global !== 'undefined') { return global; } return {}; })(); global.IS_PAPA_WORKER=true; \",\"(\",t,\")();\"],{type:\"text/javascript\"})))})(),(e=new n.Worker(e)).onmessage=g,e.id=h++,o[e.id]=e)})()).userStep=t.step,i.userChunk=t.chunk,i.userComplete=t.complete,i.userError=t.error,t.step=U(t.step),t.chunk=U(t.chunk),t.complete=U(t.complete),t.error=U(t.error),delete t.worker,i.postMessage({input:e,config:t,workerId:i.id})},v.unparse=function(e,t){var n=!1,_=!0,m=\",\",y=\"\\r\\n\",s='\"',a=s+s,i=!1,r=null,o=!1,h=((()=>{if(\"object\"==typeof t){if(\"string\"!=typeof t.delimiter||v.BAD_DELIMITERS.filter(function(e){return-1!==t.delimiter.indexOf(e)}).length||(m=t.delimiter),\"boolean\"!=typeof t.quotes&&\"function\"!=typeof t.quotes&&!Array.isArray(t.quotes)||(n=t.quotes),\"boolean\"!=typeof t.skipEmptyLines&&\"string\"!=typeof t.skipEmptyLines||(i=t.skipEmptyLines),\"string\"==typeof t.newline&&(y=t.newline),\"string\"==typeof t.quoteChar&&(s=t.quoteChar),\"boolean\"==typeof t.header&&(_=t.header),Array.isArray(t.columns)){if(0===t.columns.length)throw new Error(\"Option columns is empty\");r=t.columns}void 0!==t.escapeChar&&(a=t.escapeChar+s),t.escapeFormulae instanceof RegExp?o=t.escapeFormulae:\"boolean\"==typeof t.escapeFormulae&&t.escapeFormulae&&(o=/^[=+\\-@\\t\\r].*$/)}})(),new RegExp(P(s),\"g\"));\"string\"==typeof e&&(e=JSON.parse(e));if(Array.isArray(e)){if(!e.length||Array.isArray(e[0]))return u(null,e,i);if(\"object\"==typeof e[0])return u(r||Object.keys(e[0]),e,i)}else if(\"object\"==typeof e)return\"string\"==typeof e.data&&(e.data=JSON.parse(e.data)),Array.isArray(e.data)&&(e.fields||(e.fields=e.meta&&e.meta.fields||r),e.fields||(e.fields=Array.isArray(e.data[0])?e.fields:\"object\"==typeof e.data[0]?Object.keys(e.data[0]):[]),Array.isArray(e.data[0])||\"object\"==typeof e.data[0]||(e.data=[e.data])),u(e.fields||[],e.data||[],i);throw new Error(\"Unable to serialize unrecognized input\");function u(e,t,i){var r=\"\",n=(\"string\"==typeof e&&(e=JSON.parse(e)),\"string\"==typeof t&&(t=JSON.parse(t)),Array.isArray(e)&&0<e.length),s=!Array.isArray(t[0]);if(n&&_){for(var a=0;a<e.length;a++)0<a&&(r+=m),r+=k(e[a],a);0<t.length&&(r+=y)}for(var o=0;o<t.length;o++){var h=(n?e:t[o]).length,u=!1,d=n?0===Object.keys(t[o]).length:0===t[o].length;if(i&&!n&&(u=\"greedy\"===i?\"\"===t[o].join(\"\").trim():1===t[o].length&&0===t[o][0].length),\"greedy\"===i&&n){for(var f=[],l=0;l<h;l++){var c=s?e[l]:l;f.push(t[o][c])}u=\"\"===f.join(\"\").trim()}if(!u){for(var p=0;p<h;p++){0<p&&!d&&(r+=m);var g=n&&s?e[p]:p;r+=k(t[o][g],p)}o<t.length-1&&(!i||0<h&&!d)&&(r+=y)}}return r}function k(e,t){var i,r;return null==e?\"\":e.constructor===Date?JSON.stringify(e).slice(1,25):(r=!1,o&&\"string\"==typeof e&&o.test(e)&&(e=\"'\"+e,r=!0),i=e.toString().replace(h,a),(r=r||!0===n||\"function\"==typeof n&&n(e,t)||Array.isArray(n)&&n[t]||((e,t)=>{for(var i=0;i<t.length;i++)if(-1<e.indexOf(t[i]))return!0;return!1})(i,v.BAD_DELIMITERS)||-1<i.indexOf(m)||\" \"===i.charAt(0)||\" \"===i.charAt(i.length-1))?s+i+s:i)}},v.RECORD_SEP=String.fromCharCode(30),v.UNIT_SEP=String.fromCharCode(31),v.BYTE_ORDER_MARK=\"\\ufeff\",v.BAD_DELIMITERS=[\"\\r\",\"\\n\",'\"',v.BYTE_ORDER_MARK],v.WORKERS_SUPPORTED=!s&&!!n.Worker,v.NODE_STREAM_INPUT=1,v.LocalChunkSize=10485760,v.RemoteChunkSize=5242880,v.DefaultDelimiter=\",\",v.Parser=E,v.ParserHandle=i,v.NetworkStreamer=f,v.FileStreamer=l,v.StringStreamer=c,v.ReadableStreamStreamer=p,n.jQuery&&((d=n.jQuery).fn.parse=function(o){var i=o.config||{},h=[];return this.each(function(e){if(!(\"INPUT\"===d(this).prop(\"tagName\").toUpperCase()&&\"file\"===d(this).attr(\"type\").toLowerCase()&&n.FileReader)||!this.files||0===this.files.length)return!0;for(var t=0;t<this.files.length;t++)h.push({file:this.files[t],inputElem:this,instanceConfig:d.extend({},i)})}),e(),this;function e(){if(0===h.length)U(o.complete)&&o.complete();else{var e,t,i,r,n=h[0];if(U(o.before)){var s=o.before(n.file,n.inputElem);if(\"object\"==typeof s){if(\"abort\"===s.action)return e=\"AbortError\",t=n.file,i=n.inputElem,r=s.reason,void(U(o.error)&&o.error({name:e},t,i,r));if(\"skip\"===s.action)return void u();\"object\"==typeof s.config&&(n.instanceConfig=d.extend(n.instanceConfig,s.config))}else if(\"skip\"===s)return void u()}var a=n.instanceConfig.complete;n.instanceConfig.complete=function(e){U(a)&&a(e,n.file,n.inputElem),u()},v.parse(n.file,n.instanceConfig)}}function u(){h.splice(0,1),e()}}),a&&(n.onmessage=function(e){e=e.data;void 0===v.WORKER_ID&&e&&(v.WORKER_ID=e.workerId);\"string\"==typeof e.input?n.postMessage({workerId:v.WORKER_ID,results:v.parse(e.input,e.config),finished:!0}):(n.File&&e.input instanceof File||e.input instanceof Object)&&(e=v.parse(e.input,e.config))&&n.postMessage({workerId:v.WORKER_ID,results:e,finished:!0})}),(f.prototype=Object.create(u.prototype)).constructor=f,(l.prototype=Object.create(u.prototype)).constructor=l,(c.prototype=Object.create(c.prototype)).constructor=c,(p.prototype=Object.create(u.prototype)).constructor=p,v});","import { ensureString } from 'ensure-string';\nimport Papa from 'papaparse';\nimport { Analysis } from '../index.js';\n/**\n * Creates a new Chromatogram element based in a JCAMP string\n * @param text - String containing the JCAMP data\n * @param arrayBuffer\n * @returns - New class element with the given data\n */\nexport function fromPerkinElmerCSV(arrayBuffer) {\n    const text = ensureString(arrayBuffer);\n    const parsed = Papa.parse(text, {\n        skipEmptyLines: true,\n        header: true,\n        dynamicTyping: true,\n    }).data;\n    const analysis = new Analysis();\n    analysis.pushSpectrum({\n        x: {\n            data: parsed.map((d) => d['Sample Temperature']),\n            label: 'Sample temperature [°C]',\n            isDependent: true,\n        },\n        y: {\n            data: parsed.map((d) => d['Unsubtracted Weight']),\n            label: 'Weight [mg]',\n            isDependent: true,\n        },\n        p: {\n            data: parsed.map((d) => d['Program Temperature']),\n            label: 'Program temperature [°C]',\n            isDependent: true,\n        },\n        t: {\n            data: parsed.map((d) => d.Time),\n            label: 'Time [min]',\n            isDependent: false,\n        },\n    }, { dataType: 'TGA' });\n    return analysis;\n}\n//# sourceMappingURL=fromPerkinElmerCSV.js.map","import { ensureString } from 'ensure-string';\nexport function parseTAInstruments(arrayBuffer) {\n    let text = ensureString(arrayBuffer);\n    text = text.replaceAll(/[\\r\\f]/g, '');\n    const metaLines = text.split(/\\n/).filter((line) => /^[a-zA-Z]/.test(line));\n    const allDataLines = text\n        .split(/\\n/)\n        .filter((line) => /^[0-9.-]/.exec(line))\n        .map((line) => line.split(/\\s+/).map(Number));\n    const meta = parseMeta(metaLines);\n    //let events = allDataLines.filter((line) => line[0] < 0);\n    const dataLines = allDataLines.filter((line) => line[0] > 0);\n    meta.balancePurgeFlow = [];\n    meta.samplePurgeFlow = [];\n    // We now assume that we always have 5 columns in the same order ...\n    const result = {\n        meta,\n        data: {\n            time: [],\n            weight: [],\n            temperature: [],\n        },\n    };\n    result.data.time = dataLines.map((fields) => fields[0]);\n    result.data.temperature = dataLines.map((fields) => fields[1]);\n    result.data.weight = dataLines.map((fields) => fields[2]);\n    result.meta.balancePurgeFlow = dataLines.map((fields) => fields[3]);\n    result.meta.samplePurgeFlow = dataLines.map((fields) => fields[4]);\n    return result;\n}\nfunction splitTrim(string, item = 1) {\n    return string.split(/\\t/)[item].replace(/^[ \\t]*(.*?)[ \\t]*$/, '$1');\n}\nfunction parseMeta(lines) {\n    const meta = { comments: [], methodSteps: [] };\n    for (const [i, line] of lines.entries()) {\n        if (/^Instrument/.exec(line)) {\n            meta.instrument = splitTrim(line);\n        }\n        else if (/^InstSerial/.exec(line)) {\n            meta.instrumentSerial = splitTrim(line);\n        }\n        else if (/^Sample/.exec(line)) {\n            meta.sampleName = splitTrim(line);\n        }\n        else if (/^Size/.exec(line)) {\n            meta.weight = Number.parseFloat(splitTrim(line));\n            meta.weightUnit = splitTrim(line, 2);\n        }\n        else if (/^Xcomment|^Comment/.exec(line)) {\n            meta.comments.push(splitTrim(line));\n        }\n        else if (/^Method/.exec(line)) {\n            meta.method = splitTrim(line);\n        }\n        else if (/^Mode/.exec(line)) {\n            meta.mode = splitTrim(line);\n        }\n        else if (/^File/.exec(line)) {\n            meta.file = splitTrim(line);\n        }\n        else if (/^Date/.exec(line)) {\n            meta.date = splitTrim(line);\n        }\n        else if (/^Time/.exec(line)) {\n            meta.time = splitTrim(line);\n        }\n        else if (/^OrgMethod/.exec(line)) {\n            meta.methodSteps.push(splitTrim(line));\n        }\n        else if (/^Controls/.exec(line)) {\n            meta.controls = splitTrim(line);\n        }\n        else if (/^FurnaceType/.exec(line)) {\n            meta.furnaceType = splitTrim(line);\n        }\n        else if (/^Operator/.exec(line)) {\n            meta.operator = splitTrim(line);\n        }\n        else if (/^RunSerial/.exec(line)) {\n            meta.runSerial = splitTrim(line);\n        }\n        else if (/^ProcName/.exec(line)) {\n            meta.procName = splitTrim(line);\n        }\n        else if (/^OrgFile/.exec(line)) {\n            meta.dataStart = i + 1;\n            break;\n        }\n    }\n    return meta;\n}\n//# sourceMappingURL=parseTAInstruments.js.map","import { ensureString } from 'ensure-string';\nimport { Analysis } from '../index.js';\nimport { parseTAInstruments } from \"./parser/parseTAInstruments.js\";\nexport function fromTAInstruments(arrayBuffer) {\n    const text = ensureString(arrayBuffer);\n    const analysis = new Analysis();\n    const parsed = parseTAInstruments(text);\n    analysis.pushSpectrum({\n        x: {\n            data: parsed.data.temperature,\n            isDependent: true,\n            label: 'Program temperature [°C]',\n        },\n        y: {\n            data: parsed.data.weight,\n            isDependent: true,\n            label: 'Weight [mg]',\n        },\n        t: {\n            data: parsed.data.time,\n            isDependent: false,\n            label: 'Time [min]',\n        },\n    }, { dataType: 'TGA', title: parsed.meta.sampleName, meta: parsed.meta });\n    return analysis;\n}\n//# sourceMappingURL=fromTAInstruments.js.map","//@ts-expect-error imported library\nimport { tgaParseTAInstrumentsXLS } from 'physical-chemistry-parser';\nimport { Analysis } from '../index.js';\nexport function fromTAInstrumentsExcel(arrayBuffer) {\n    const analysis = new Analysis();\n    const parsed = tgaParseTAInstrumentsXLS(arrayBuffer);\n    analysis.pushSpectrum(parsed.variables, {\n        dataType: 'TGA',\n        title: parsed.meta['Sample name'],\n        meta: {\n            ...parsed.meta,\n            cheminfo: {\n                meta: {\n                    method: 'Full',\n                },\n            },\n        },\n    });\n    for (const sheet of parsed.sheets) {\n        analysis.pushSpectrum(sheet.variables, {\n            dataType: 'TGA',\n            title: parsed.meta['Sample name'],\n            meta: {\n                ...parsed.meta,\n                cheminfo: {\n                    meta: {\n                        method: sheet.name,\n                    },\n                },\n            },\n        });\n    }\n    return analysis;\n}\n//# sourceMappingURL=fromTAInstrumentsExcel.js.map"],"names":["toString","Object","prototype","isAnyArray","value","tag","call","endsWith","includes","getOutputArray","output","length","undefined","TypeError","Float64Array","xMedian","input","options","exact","array","slice","middleIndex","calcMiddle","median","quickSelect","low","high","middle","currentLow","currentHigh","swap","i","j","temp","Math","floor","xCheck","minLength","Error","xFindClosestIndex","target","sorted","abs","index","diff","Number","POSITIVE_INFINITY","currentDiff","xGetFromToIndex","x","fromIndex","toIndex","from","to","xAdd","array1","array2","isConstant","constant","array3","xApplyFunctionStr","variableLabel","fctString","fct","Function","replaceAll","toReturn","isNaN","xMultiply","arguments","Array","currentMin","_options$fromIndex","_options$toIndex","isInteger","minValue","min","currentMax","maxValue","max","RangeError","_options$min","autoMinMax","_options$max","factor","defineProperty","matrix","require$$0","rescale","require$$1","indent","repeat","indentData","inspectMatrixWithOptions","maxRows","maxColumns","maxNumSize","padMinus","constructor","name","rows","columns","maxI","maxJ","result","loop","get","line","push","formatNumber","join","inspectData","num","formatNumber2","padEnd","len","str","fix","toFixed","startsWith","exp","toExponential","checkRowIndex","outer","checkColumnIndex","checkRowVector","vector","to1DArray","checkColumnVector","checkRowIndices","rowIndices","checkColumnIndices","columnIndices","checkRange","startRow","endRow","startColumn","endColumn","checkNumber","newArray","checkNonEmpty","isEmpty","AbstractMatrix","from1DArray","newRows","newColumns","newData","newMatrix","Matrix","row","column","set","rowVector","columnVector","zeros","ones","fill","rand","random","randInt","interval","round","eye","this","diag","data","l","matrix1","matrix2","checkMatrix","isMatrix","klass","size","apply","callback","to2DArray","copy","toJSON","isRowVector","isColumnVector","isVector","isSquare","isSymmetric","isDistance","isEchelonForm","previousColumn","checked","isReducedEchelonForm","k","echelonForm","clone","h","iMax","swapRows","tmp","reducedEchelonForm","m","n","maxRow","p","pivot","setSubMatrix","neg","mulS","getRow","getRowVector","setRow","row1","row2","getColumn","getColumnVector","setColumn","swapColumns","column1","column2","addRowVector","subRowVector","mulRowVector","divRowVector","addColumnVector","subColumnVector","mulColumnVector","divColumnVector","mulRow","mulColumn","by","NaN","NEGATIVE_INFINITY","maxIndex","v","idx","minIndex","maxRowIndex","minRow","minRowIndex","maxColumn","maxColumnIndex","minColumn","minColumnIndex","norm","type","sqrt","dot","cumulativeSum","sum","vector2","vector1","mmul","other","Bcolj","s","mpow","scalar","bb","e","strassen2x2","a11","b11","a12","b12","a21","b21","a22","b22","m1","m2","m3","m4","m5","c00","c01","c10","c11","strassen3x3","a00","a01","a02","a10","a20","b00","b01","b02","b10","b20","m6","m7","m8","m9","m12","m13","m14","m15","m16","m17","m18","c02","c12","c20","c21","c22","mmulStrassen","y","r1","c1","r2","c2","embed","mat","cols","r","c","resultat","console","warn","blockMult","a","b","halfRows","parseInt","halfCols","subMatrix","add","sub","scaleRows","isFinite","scaleColumns","flipRows","ceil","first","last","flipColumns","kroneckerProduct","q","kroneckerSum","AxI","IxB","transpose","sortRows","compareFunction","compareNumbers","sort","sortColumns","subMatrixRow","indices","subMatrixColumn","selection","rowIndex","columnIndex","trace","entries","sumByRow","sumByColumn","sumAll","product","productByRow","productByColumn","productAll","mean","variance","unbiased","sum1","sum2","varianceByRow","varianceByColumn","varianceAll","standardDeviation","center","centerByRow","centerByColumn","centerAll","scale","getScaleByRow","scaleByRow","getScaleByColumn","scaleByColumn","divider","getScaleAll","scaleAll","Symbol","iterator","col","values","isArrayOfNumbers","every","element","for","randomInt","diagonal","identity","negate","tensorProduct","initData","nRows","nColumns","super","arrayData","removeRow","splice","addRow","removeColumn","newRow","addColumn","addS","addM","subS","subM","subtract","subtractS","subtractM","mul","mulM","multiply","multiplyS","multiplyM","div","divS","divM","divide","divideS","divideM","mod","modS","modM","modulus","modulusS","modulusM","and","andS","andM","or","orS","orM","xor","xorS","xorM","leftShift","leftShiftS","leftShiftM","signPropagatingRightShift","signPropagatingRightShiftS","signPropagatingRightShiftM","rightShift","rightShiftS","rightShiftM","zeroFillRightShift","zeroFillRightShiftS","zeroFillRightShiftM","not","acos","acosh","asin","asinh","atan","atanh","cbrt","clz32","cos","cosh","expm1","fround","log","log1p","log10","log2","sign","sin","sinh","tan","tanh","trunc","pow","arg0","powS","powM","installMathOperations","SymmetricMatrix","diagonalSize","isSymmetricMatrix","klassType","upperRightEntries","toMatrix","removeCross","addCross","applyMask","mask","sidesToRemove","passthroughs","reverse","sideIndex","toCompact","compact","fromCompact","compactSize","JSON","stringify","upperRightValues","DistanceMatrix","isDistanceMatrix","klassSubType","sideSize","toSymmetricMatrix","BaseView","MatrixSelectionView","WrapperMatrix1D","_calculateIndex","WrapperMatrix2D","LuDecomposition","t","LUcolj","kmax","lu","pivotVector","pivotSign","LU","isSingular","solve","count","X","determinant","lowerTriangularMatrix","upperTriangularMatrix","pivotPermutationVector","hypotenuse","QrDecomposition","qr","rdiag","nrm","QR","Rdiag","isFullRank","orthogonalMatrix","SingularValueDecomposition","computeLeftSingularVectors","computeRightSingularVectors","autoTranspose","wantu","Boolean","wantv","swapped","aux","nu","ni","U","V","work","si","nct","nrt","mrc","pp","eps","EPSILON","kase","alpha","MIN_VALUE","ks","f","cs","sn","sp","spm1","epm1","sk","ek","shift","g","Y","threshold","scols","Ls","rightSingularVectors","VL","vrows","urows","VLU","solveForDiagonal","inverse","vcols","ucols","condition","norm2","rank","tol","ii","leftSingularVectors","diagonalMatrix","leftHandSide","rightHandSide","useSVD","xrange","exception","range","dependenciesOneRow","error","thresholdValue","thresholdError","returnArray","EigenvalueDecomposition","assumeSymmetric","d","hh","tred2","dl1","c3","el1","s2","tst1","tql2","H","ort","orthes","nn","w","ra","sa","vr","vi","notlast","cdivres","exshift","z","iter","cdiv","hqr2","realEigenvalues","imaginaryEigenvalues","eigenvectorMatrix","xr","xi","yr","yi","CholeskyDecomposition","dimension","positiveDefinite","L","isPositiveDefinite","B","nipals","scaleScores","maxIterations","terminationCriteria","u","tOld","counter","xResidual","residual","yResidual","betas","CHO","EVD","Matrix_1","MatrixColumnSelectionView","MatrixColumnView","MatrixFlipColumnView","MatrixFlipRowView","MatrixRowSelectionView","MatrixRowView","MatrixSubView","MatrixTransposeView_1","MatrixTransposeView","NIPALS","Nipals","SVD","correlation","xMatrix","yMatrix","yIsSame","sdx","sdy","corr","covariance","cov","_default","default","subMatrix0","subMatrix1","subMatrix2","linearDependencies","results","Abis","pseudoInverse","svdSolution","solve_1","wrap","xMean","sumValue","xStandardDeviation","sqrError","xVariance","xEnsureFloat64","FFT","_csize","table","angle","PI","power","_width","_bitrev","revShift","_out","_data","_inv","createFromToArray","includeFrom","includeTo","distribution","delta","base","firstExponent","xMaxValue","xMinValue","xIsMonotonic","at","xMinMaxValues","fromComplexArray","complex","storage","res","createComplexArray","toComplexArray","completeSpectrum","spectrum","half","transform","out","_transform4","realTransform","_realTransform4","inverseTransform","outOff","step","bitrev","off","_singleTransform2","_singleTransform4","inv","quarterLen","limit","A","C","D","Ar","Ai","Br","Bi","Cr","Ci","Dr","Di","MAr","MAi","tableBr","tableBi","MBr","MBi","tableCr","tableCi","MCr","MCi","tableDr","tableDi","MDr","MDi","T0r","T0i","T1r","T1i","T2r","T2i","T3r","T3i","FAr","FAi","FCr","FCi","FBr","FBi","FDr","FDi","evenR","evenI","oddR","oddI","leftR","leftI","rightR","rightI","step2","step3","_singleRealTransform2","_singleRealTransform4","halfLen","hquarterLen","SFAr","SFAi","SFBr","SFBi","SA","SB","P1","Q1","P2","Q2","P3","Q3","P4","Q4","P5","Q5","polyval","coef","calc","P","Q","erfcinv","val","simpleNormInvNumber","magnitudeMode","SQRT2","simpleNormInv","xNoiseSanPlot","cutOff","refine","scaleFactor","factorStd","fixOffset","filter","_e","prepareData","medianIndex","firstNegativeValueIndex","findIndex","lastPositiveValueIndex","signPositive","signNegative","cutOffDist","considerList","indexMax","minKi","MAX_SAFE_INTEGER","whereToCutStat","top","elementsOfCutOff","averageValue","kiSqrt","determineCutOff","initialNoiseLevelPositive","skyPoint","initialNoiseLevelNegative","noiseLevelPositive","noiseLevelNegative","cloneSignPositive","cloneSignNegative","cutOffSignalsIndexPlus","cutOffSignalsIndexNeg","cutOffSignals","correctionFactor","effectiveCutOffDist","refinedCorrectionFactor","positive","negative","snr","sanplot","generateSanPlot","fromTo","logBaseY","key","logOfBase","xNoiseStandardDeviation","mad","averageDeviations","xMedianAbsoluteDeviation","sd","xNormed","algorithm","absoluteSumValue","absoluteSum","currentMaxValue","sumFactor","xSum","String","xParetoNormalization","sqrtSD","xRolling","window","padding","padded","fromEnd","toEnd","xPadding","subarray","matrixMinMaxZ","firstLength","matrixCheck","nbRows","nbColumns","xyCheck","xyEnsureGrowingX","prevX","currentIndex","zonesNormalize","zones","exclusions","map","zone","currentZone","beforeExclusionsZones","normalizedExclusions","currentExclusionIndex","zoneIndex","integral","x0","x1","slope","intercept","getSlope","y0","y1","xyEquallySpaced","xLength","variant","numberOfPoints","zonesWithPointsRes","normalizedZones","zonesWithNumberOfPoints","unitsPerPoint","reduce","previous","current","currentTotal","tempZone","tempZoneNumberOfPoints","zonesWithPoints","xResult","yResult","zoneResult","processZone","concat","halfStep","lastStep","start","previousX","MAX_VALUE","previousY","nextX","nextY","frontOutsideSpectra","backOutsideSpectra","currentValue","currentPoints","main","equallySpacedSlot","initialOriginalStep","lastOriginalStep","MIN_SAFE_INTEGER","sumAtMin","sumAtMax","equallySpacedSmooth","xyFilterX","currentZoneIndex","newX","newY","position","xyFilterXPositive","xyGrowingX","toReversed","addStyle","serie","color","opacity","lineWidth","match","toUpperCase","replace","style","width","dash","label","id","COLORS","defaultBoundary","prepare","M","Pinv","Mt","ar","ac","Ap","Ax","LNZ","coloffset","adr","Lp","Parent","Lnz","Flag","Pattern","bp1","kk","p2","ldlSymbolic","Lx","Li","lKi","ldlNumeric","ldlPerm","ldlLsolve","ldlDsolve","ldlLTsolve","ldlPermt","cuthillMckee_1","list","adj","visited","toVisit","eol","ptr","nbhd","compareNum","getCloseIndex","goal","closest","getClosestNumber","prev","curr","indexOf","updateSystem","weights","nbPoints","newVector","next","airPLS","controlPoints","Int8Array","forEach","indexFrom","indexTo","getControlPoints","baseline","iteration","lambda","tolerance","sumNegDifferences","corrected","stopCriterion","xAbsoluteSum","getStopCriterion","lowerTriangularNonZeros","permutationEncodedArray","getDeltaMatrix","cuthillMckee","prevNegSum","cholesky","cho","applyCorrection","absChange","_typeof","obj","sequentialFill","_options","_options$from","_options$to","_options$size","isArray","_i","checkArrayLength","BaseRegression","predict","_predict","xVal","train","precision","toLaTeX","score","y2","ySum","chi2","rmsd","xSquared","ySquared","xY","maybeToPrecision","number","figures","toPrecision","PolynomialRegression","degree","powers","coefficients","interceptAtZero","nCoefficients","F","FT","regress","_toFormula","isLaTeX","sup","closeSup","times","fn","load","json","iterativePolynomialBaseline","ys","numberPoints","regressionOptions","Regression","regression","fitting","oldFitting","baselineCorrectionRegression","correctedSpectrum","rollingAverageBaseline","xRollingAverage","rollingBallBaseline","maxima","minima","windowM","windowS","windowLeft","windowRight","rollingBall","rollingMedianBaseline","xRollingMedian","sgg","xs","windowSize","derivative","polynomial","np","ans","weight","fullWeights","hs","constantH","wg1","wg2","d1","d2","getHs","wg","gramPoly","Grampoly","genFact","gf","getMinMaxIntervalsDy","dY","dX","lastMax","lastMin","intervalL","intervalR","tryMatchOneIntervalWithMinData","lastK","minData","yThreshold","intervalWidth","intervalCenter","yData","minDistance","possible","newLastIndex","centerIndex","deltaX","currentDistance","lastIndex","getPeakFromIntervals","peaks","ddY","crypto","randomUUID","inflectionPoints","isLessAndGreaterThanZero","back","firstDerivative","crossDy","xGetCrossZeroPoints","gsd","noiseLevel","sgOptions","smoothY","maxCriteria","minMaxRatio","realTopDetection","peakDetectionAlgorithm","isEquallySpaced","maxDx","minDx","absoluteDifference","xIsEquallySpaced","noiseInfo","xValue","minY","maxY","peakData","minddY","secondDerivative","lastJ","yIndex","autoAlgorithm","peak","beta","gamma","xCurrent","xPrevious","optimizeTop","airpls","baselineFct","targetX","nbPeaks","gsdOptions","xRescale","existingMax","existingMin","function","getNormalizedSpectrum","variables","newSpectrum","units","title","dataType","meta","applyRangeSelectionFirst","filters","structuredClone","unshift","logs","Date","now","filterFct","Filters","time","filterXY","isMonotonic","exports","isString","isFiniteImpl","isNumber","uniq","strings","seen","item","hasOwnProperty","compareArray","assign","properties","keys","mulSafe","decimals","arg","getFractional","divSafe","den","QtyError","err","create","message","stack","throwIncompatibleUnits","left","right","UNITS","BASE_UNITS","UNITY","UNITY_ARRAY","validateUnitDefinition","unitDef","definition","numerator","denominator","unit","PREFIX_VALUES","PREFIX_MAP","UNIT_VALUES","UNIT_MAP","OUTPUT_MAP","getUnits","kind","unitKeys","substr","getKinds","toLowerCase","getAliases","unitName","SIGNATURE_VECTOR","unitSignature","signature","unitSignatureVector","isBase","toBase","SIGN","INTEGER","FRACTION","QTY_STRING_REGEX","RegExp","POWER_OP","SAFE_POWER","TOP_REGEX","BOTTOM_REGEX","parse","trim","exec","scalarMatch","parseFloat","nx","bottom","UNIT_TEST_REGEX","test","parseUnits","PREFIX_REGEX","UNIT_REGEX","UNIT_MATCH","UNIT_MATCH_REGEX","parsedUnitsCache","cached","unitMatch","normalizedUnits","globalParse","isQty","Qty","initValue","initUnits","assertValidConstructorArgs","baseScalar","_conversionCache","isDefinitionObject","updateBaseScalar","isTemperature","KINDS","knownSignature","subtractTemperatures","lhs","rhs","lhsUnits","rhsConverted","dstDegrees","getDegreeUnits","subtractTempDegrees","deg","tempDegrees","addTempDegrees","toDegrees","src","dst","dstScalar","srcDegK","toDegK","dstUnits","qty","toTemp","toTempK","swiftConverter","srcUnits","convert","srcQty","dstQty","eq","isDegrees","isCompatible","isInverse","baseUnitCache","toBaseUnits","toFloat","isUnitless","toPrec","precQuantity","cleanTerms","num1","den1","num2","den2","notUnity","combined","combineTerms","terms","direction","prefix","prefixValue","combinedPrefixValue","prop","NestedMap","defaultFormatter","op1","op2","numdenscale","compareTo","lt","lte","gt","gte","same","_isBase","childMap","formatter","_units","numIsUnity","denIsUnity","numUnits","stringifyUnits","denUnits","targetUnitsOrMaxDecimalsOrPrec","maxDecimals","targetUnits","format","targetQty","stringifiedUnitsCache","stringified","simplify","getOutputNames","token","tokenNext","unitNames","acc","unitCounter","unitCount","version","factory","convertUnit","fromUnit","toUnit","normalize","testRegExp","ensureRegexp","string","parts","stringToRegexp","flags","getConvertedVariable","variable","newUnits","getXYSpectra","spectra","selector","selectedSpectra","labels","xUnits","yUnits","xVariable","yVariable","xLabel","yLabel","split","getPossibleVariable","variableName","convertibleUnits","regexpLabel","upper","hasOwn","lower","possibleFiltered","Analysis","spectrumCallback","cache","ids","analysis","object","internalReplacer","ArrayBuffer","isView","space","fromJSON","pushSpectrum","analysisOptions","standardizeData","getXYSpectrum","getXY","normalization","getNormalizedSpectra","normalizedSpectra","getSpectrum","getXLabel","getYLabel","appendDistinctParameter","appendDistinctValue","AnalysesManager","analyses","analysesManager","addAnalysis","getAnalysisIndex","getAnalyses","processedAnalysisIds","Set","has","getSpectra","getAnalysisBySpectrumId","getSpectrumById","getDistinctTitles","getDistinctUnits","getDistinctLabelUnits","normalizeLabelUnits","getDistinctLabels","getDistinctDataTypes","getDistinctMeta","removeAllAnalyses","removeAnalysis","originalLabel","originalUnits","search","ensureString","blob","encoding","guessEncoding","TextDecoder","decode","uint8","Uint8Array","buffer","byteOffset","byteLength","buf","isutf8","parseString","lowercase","getGyromagneticRatio","nucleus","realNucleus","gyromagneticRatio","nucleusNumber","filteredNuclei","getGyromagneticNucleus","fromEntries","_ref","module","quickSelectMedian","$","E","o","te","ne","series","ms","pageValue","chromatogram","re","O","logger","xFactor","info","yFactor","isXYdata","firstX","firstY","codePointAt","I","S","N","oe","isPeaktable","ue","ce","isXYAdata","se","Z","lastY","ntuples","symbol","find","some","ie","pe","ae","minX","maxX","minZ","maxZ","noise","G","noContour","contourLines","nbContourLevels","fe","noiseMultiplier","zValue","lines","_","ee","T","segments","minMax","J","intensity","observeFrequency","shiftOffsetVal","lastX","$NUC2","$NUC1","yType","xType","W","pageSymbol","dynamicTyping","le","de","twoD","wantXY","profiling","keepSpectra","K","charAt","vardim","varname","R","he","removeComments","keepRecordsRegExp","canonicDataLabels","canonicMetadataLabels","withoutXY","noTrimRegExp","fromJcamp","jcamp","converted","ge","debug","flatten","children","datatable","dataClass","jcampDX","jcampCS","shiftOffsetNum","vartype","varform","page","sampleDescription","pop","be","entry","currentSpectrum","addJcamp","addInfoData","header","checkNumberOrArray","getExtremeValues","firstLast","getBestFactor","onlyInteger","getFactorNumber","getNumber","rounded","rescaleAndEnsureInteger","xDivide","newLine","pseudoDigits","vectorEncoder","intervalX","xyEncoding","fixEncoding","outputData","dataLength","squeezedDigit","squeezedEncoding","differenceEncoding","mult","charCount","encodedData","encodedNumber","diffData","numDiff","differenceDigit","duplicateDigit","differenceDuplicateEncoding","commaSeparatedValuesEncoding","packedEncoding","separator","sqzDigits","charCodeAt","substring","diffDigits","dupDigits","owner","origin","resInfo","xyDataCreator","peakTableCreator","fromVariables","forceNtuples","jcampOptions","varName","varType","varDim","isDependent","point","creatorNtuples","xData","toJcamps","jcamps","getJcamp","toJcamp","JSGraph","getJSGraph","colors","opacities","linesWidth","xAxis","yAxis","firstSpectrum","logScale","axes","unitWrapperBefore","unitWrapperAfter","flipped","display","getNormalizationAnnotations","boundary","annotations","exclusion","ignore","strokeWidth","fillColor","current_ansi","VALID_ANSI","CS2CP","set_ansi","cp","set_cp","reset_cp","char_codes","utf16beread","fromCharCode","$cptable","debom","utf16leread","_getchar","_getansi","Base64_map","Base64_encode","e1","e2","e3","e4","Base64_decode","has_buf","Buffer","process","versions","node","Buffer_from","nbfs","enc","bind","new_raw_buf","alloc","new_unsafe_buf","allocUnsafe","s2a","a2s","ab2a","bconcat","bufs","isBuffer","maxlen","chr0","chr1","_strrev","pad0","pad_","rpad_","p2_32","pad0r","pad0r1","pad0r2","SSF_isgeneral","days","months","table_fmt","SSF_default_map","SSF_default_str","SSF_frac","mixed","sgn","P_2","P_1","Q_2","Q_1","SSF_parse_date_code","opts","b2","date","dow","dout","date1904","setDate","getDate","getFullYear","getMonth","getDay","SSF_fix_hijri","SSFbasedate","SSFdnthresh","getTime","SSFbase1904","datenum_local","epoch","getTimezoneOffset","SSF_strip_decimal","SSF_general_num","LOG10E","SSF_small_exp","SSF_large_exp","SSF_normalize_exp","SSF_general","SSF_format","SSF_write_date","fmt","ss0","ss","tt","outl","commaify","pct1","write_num_exp","period","fakee","$$","$1","$2","$3","frac1","dec1","closeparen","phone","hashq","cc","rnd","dd","dec","_frac","write_num_flt","ffmt","write_num","write_num_cm","sfmt","write_num_pct","ri","ff","aval","rr","myn","myd","write_num_f1","carry","oa","lres","rres","flr","write_num_exp2","write_num_int","write_num_cm2","write_num_pct2","write_num_f2","lastIndexOf","SSF_abstime","fmt_is_date","cfregex2","chkcond","thresh","choose_fmt","in_str","SSF_split_fmt","lat","dateNF","flen","dt","lst","hr","ssm","bt","jj","nstr","myv","ostr","vv","decpt","lasti","retval","eval_fmt","SSF_load","make_ssf","SSFImplicit","dateNFregex","CRC32","T0","Int32Array","signed_crc_table","TT","slice_by_16_tables","T1","T2","T3","T4","T5","T6","T7","T8","T9","Ta","Tb","Tc","Td","Te","Tf","bstr","seed","CFB","fs","dirname","filename","write_dos_date","hms","getHours","getMinutes","getSeconds","write_shift","ymd","parse_extra_field","prep_blob","read_shift","sz","tgt","mtime","atime","ctime","mt","get_fs","file","parse_zip","root","di","mboundary","FileIndex","FullPaths","init_cfb","start_di","fcnt","parse_mime","parse_mad","mver","nmfs","difat_sec_cnt","dir_start","minifat_start","difat_start","ssz","fat_addrs","mv","chk","HEADER_SIGNATURE","check_get_mver","check_shifts","dir_cnt","sectors","nsectors","sectorify","sleuth_fat","sector_list","sl","chkd","buf_chain","addr","__readInt32LE","nodes","__toBuffer","make_sector_list","ENDOFCHAIN","Paths","files","mini","minifat_store","pl","sector","namelen","__utf16le","clsid","state","ct","read_date","get_sector_list","content","get_mfat_entry","read_directory","FI","FP","dad","build_full_paths","raw","payload","MSSZ","new_buf","cnt","offset","__readUInt32LE","cfb","CLSID","nm","rebuild_cfb","seed_cfb","gc","_file","fullPaths","HEADER_CLSID","namecmp","elt","_write","_opts","fileType","fp","fi","ca","cstr","dispcnt","csl","qp","get_content_type","write_quoted_printable","write_base64_76","write_mad","cdirs","method","compression","start_cd","crcs","sz_cd","namebuf","outbuf","_deflateRawSync","write_zip","mini_size","fat_size","mfat_cnt","fat_base","fat_cnt","difat_cnt","HEADER_SIG","chainit","consts","DIFSECT","FATSECT","_nm","_zlib","MAXREGSECT","FREESECT","HEADER_MINOR_VERSION","MAXREGSID","NOSTREAM","EntryTypes","deflateRawSync","_deflate","CLEN_ORDER","LEN_LN","DST_LN","bit_swap_8","use_typed_arrays","bitswap8","bit_swap_n","rev","read_bits_2","bl","read_bits_3","read_bits_5","read_bits_7","read_bits_n","write_bits_3","write_bits_1","write_bits_8","write_bits_16","realloc","zero_fill_array","build_tree","clens","cmap","MAX","ccode","bl_count","Uint16Array","ctree","cleni","fix_lmap","fix_dmap","dlens","_deflateRaw","DST_LN_RE","LEN_LN_RE","boff","write_stored","addrs","hash","mlen","len_eb","dst_eb","write_huff_fixed","dyn_lmap","dyn_dmap","dyn_cmap","dyn_len_1","dyn_len_2","dyn","_HLIT","_HDIST","_HCLEN","read_bits_4","next_code","hcodes","h1","h2","_inflate","usz","woff","OL","max_len_1","max_len_2","bits","code","inflate","warn_or_throw","wrn","msg","csz","efsz","fcsz","EF","parse_local_file","meth","setMilliseconds","setFullYear","setMonth","setHours","setMinutes","setSeconds","parse_dos_date","_csz","_usz","ef","InflRaw","InflateRaw","_processChunk","_finishFlushFlag","bytesRead","_inflateRawSync","cfb_add","unsafe","ContentTypeMap","htm","xml","gif","jpg","png","mso","thmx","sh33tj5","ctype","ext","text","encoded","end","fdata","fname","cte","oi","parse_quoted_printable","fpath","utils","cfb_gc","path","UCFullPaths","UCPaths","UCPath","read","readFileSync","read_file","write","writeFileSync","writeFile","cfb_new","cfb_del","cfb_mov","old_name","new_name","ReadShift","CheckField","use_zlib","zlib","_inflateRaw","o2","evert","basedate","datenum","refdate","dnthresh","refoffset","numdate","setTime","parse_isodur","sec","good_pd_date_1","good_pd_date","good_pd","parseDate","fixdate","cc2str","arr","debomit","utf8write","dup","fuzzynum","wt","lower_months","fuzzydate","getYear","split_regex","safe_split_regex","def","getdatastr","asNodeBuffer","asBinary","getContent","getdatabin","safegetzipfile","zip","getzipfile","getzipdata","safe","getzipstr","zipentries","zip_add_file","widx","ridx","utf8decode","zip_read","resolve_path","XML_HEADER","attregexg","tagregex1","tagregex","nsregex","nsregex2","parsexmltag","skip_root","skip_LC","quot","strip_ns","encodings","rencoding","unescapexml","encregex","coderegex","decregex","htmlcharegex","escapehtml","xlml_fixstr","entregex","entrepl","parsexmlbool","utf8reada","orig","utf8readb","ww","utf8readc","utf8corpus","utf8read","matchtag","mtcache","htmldecode","entities","vtregex","vt_cache","vtvregex","vtmregex","parseVector","matches","baseType","WTF","wtregex","wxt_helper","writextag","xlml_normalize","xlmlregex","XMLNS","XMLNS_main","___toBuffer","___utf16le","__readUInt16LE","___hexlify","__hexlify","___utf8","__readUInt8","__utf8","___lpstr","__lpstr","___cpstr","__cpstr","___lpwstr","__lpwstr","___lpp4","__lpp4","___8lpp4","__8lpp4","___double","Infinity","read_double_le","__double","is_buf","readUInt32LE","readDoubleLE","__readInt16LE","__readInt32BE","oI","oR","loc","oo","lens","__writeUInt32LE","__writeInt32LE","__writeUInt16LE","WriteShift","bs","av","LN2","write_double_le","hexstr","fld","pos","parsenoop","recordhopper","cb","tmpbyte","cntbyte","RT","XLSBRecordEnum","buf_array","blksz","newblk","curbuf","endbuf","_bufs","shift_cell_xls","cell","cRel","rRel","biff","shift_range_xls","encode_cell_xls","encode_cell","fix_row","encode_range_xls","encode_row","encode_col","decode_row","rowstr","decode_col","colstr","decode_cell","decode_range","encode_range","safe_decode_range","safe_format_cell","XF","numFmtId","format_cell","BErr","sheet_to_workbook","sheet","sheets","SheetNames","Sheets","sheet_add_aoa","_ws","dense","ws","_R","_C","_origin","_range","__R","__C","nullError","sheetStubs","cellDates","cell_ref","aoa_to_sheet","parse_XLWideString","cchCharacters","parse_StrRun","ich","ifnt","parse_RichStr","rgsStrRun","dwSizeStrRun","parse_BrtCommentText","parse_XLSBCell","iStyleRef","parse_XLSBShortCell","parse_XLSBCodeName","parse_XLNullableWideString","parse_XLNameWideString","parse_RelID","parse_RkNumber","fX100","fInt","RK","parse_RfX","parse_UncheckedRfX","parse_Xnum","parse_ClipboardFormatOrString","VT_STRING","VT_CUSTOM","DocSummaryPIDDSI","SummaryPIDSI","CountryEnum","XLSFillPattern","rgbify","XLSIcv","RBErr","ct2type","RELS","WB","SHEET","HLINK","VML","XPATH","XMISS","XLINK","CXML","CXMLP","CMNT","CORE_PROPS","EXT_PROPS","CUST_PROPS","SST","STY","THEME","CHART","CHARTEX","CS","WS","DS","MS","IMG","DRAW","XLMETA","TCMNT","PEOPLE","VBA","get_rels_path","parse_rels","currentFilePath","rels","rel","Type","Target","Id","TargetMode","canonictarget","CORE_PROPS_REGEX","parse_core_props","cur","load_props_pairs","HP","TOP","props","hp","Worksheets","NamedRanges","DefinedNames","Chartsheets","ChartNames","custregex","evert_XLMLDPM","XLMLDocPropsMap","Title","Subject","Author","Keywords","Comments","LastAuthor","RevNumber","Application","LastPrinted","CreatedDate","ModifiedDate","Category","Manager","Company","AppVersion","ContentStatus","Identifier","Language","xlml_set_prop","Props","parse_FILETIME","dwLowDateTime","dwHighDateTime","toISOString","parse_lpstr","pad","parse_lpwstr","parse_VtStringBase","stringType","parse_VtString","parse_VtHeadingPair","headingString","parse_TypedPropertyValue","parse_dictionary","CodePage","dict","pid","parse_BLOB","bytes","ret","Size","parse_ClipboardData","parse_VtUnalignedString","cElements","parse_VtVecHeadingPairValue","parse_VtVecLpwstrValue","parse_VtVecUnalignedLpstrValue","parse_PropertySet","PIDSI","start_addr","NumProps","Dictionary","DictObj","PropID","Offset","PropH","fail","piddsi","oldpos","parsebool","parse_PropertySetStream","NumSets","FMTID0","FMTID1","Offset0","Offset1","SystemIdentifier","PSet1","PSet0","rval","FMTID","parsenoop2","parseuint16","parseuint16a","parslurp","parse_ShortXLUnicodeString","cch","parse_XLUnicodeRichExtendedString","cbExtRst","fExtSt","fRichSt","cRun","parse_XLUnicodeStringNoCch","parse_XLUnicodeString","parse_XLUnicodeString2","parse_HyperlinkMoniker","extra","url","parse_URLMoniker","cAnti","preamble","ansiPath","parse_FileMoniker","parse_HyperlinkString","parse_LongRGBA","parse_LongRGB","parse_XLSCell","ixfe","parse_XTI","parse_RkRec","parse_Ref8U","rwFirst","rwLast","parse_RefU","parse_Ref","parse_FtCmo","ot","parse_FtSkip","FtTab","cf","fSharedNote","parse_BOF","BIFFVer","parse_DefaultRowHeight","miyRw","Unsynced","DyZero","ExAsc","ExDsc","parse_BIFF2Format","parse_Dimensions","parse_BoolErr","parse_Bes","parse_XLHeaderFooter","parse_ExternName","body","fBuiltIn","fWantAdvise","fWantPict","fOle","fOleLink","fIcon","sbcch","udfName","parse_AddinUdf","Name","XLSLblBuiltIn","parse_Lbl","chKey","cce","itab","npflen","rgce","rgcb","parse_Rgce","parse_RgbExtra","parse_NameParsedFormula","parse_ExternSheet","parse_BIFF5ExternSheet","parse_Array","ref","parse_ArrayParsedFormula","parse_BIFF5OT","cchName","parse_ColInfo","cellStyles","colFirst","colLast","coldx","level","parse_Blank","parse_Scl","parse_String","DBF_SUPPORTED_VERSIONS","DBF","dbf_codepage_map","dbf_reverse_map","dbf_to_sheet","ft","memo","vfp","l7","nrow","fpos","rlen","current_cp","codepage","fields","field","hend","sheetRows","dbf_to_aoa","wch","_RLEN","to_workbook","to_sheet","from_sheet","ba","aoa","sheet_to_json","headers","hcnt","coltypes","colwidths","coldecimals","guess","_guess","hf","_f","hb","rout","_n","_s","SYLK","sylk_escapes","AA","BA","CA","DA","HA","JA","AE","BE","CE","HE","AI","BI","CI","HI","AO","BO","CO","DO","HO","AU","BU","CU","HU","Aa","Ba","Ca","Da","Ha","Ja","Ae","Be","Ce","He","Hi","Ao","Bo","Co","Do","Ho","Au","Bu","Cu","Hu","KC","Kc","DN","Dn","Hy","sylk_char_regex","sylk_char_fn","decode_sylk_char","newcc","sylk_to_aoa_str","records","rj","formats","next_cell_format","sht","rowinfo","colinfo","cw","Mval","rstr","record","C_seen_K","C_seen_X","C_seen_S","C_seen_E","formula","rc_to_a1","shrbase","shift_formula_str","F_seen","hidden","process_col","hpt","hpx","pt2px","sylk_to_sheet","aoasht","sylk_to_aoa","write_ws_cell_sylk","a1_to_rc","RS","rec","wpx","width2px","px2char","px2pt","write_ws_rows_sylk","coord","DIF","dif_to_aoa_str","metadata","dif_to_sheet","dif_to_aoa","sheet_to_dif","push_field","topic","push_value","ETH","encode","eth_to_sheet","eth_to_aoa","sep","sheet_to_eth_data","PRN","set_text_arr","guess_seps","guess_sep_weights","guess_sep","instr","dsv_to_sheet_str","FS","sepcc","startcc","_re","finish_cell","datestr","timestr","dateNF_fix","cellText","cellNF","prn_to_sheet_str","prn_to_aoa_str","prn_to_sheet","firstbyte","WK_","lotushopper","Enum","WK1Enum","lotus_to_workbook_buf","next_n","sidx","snames","realnames","refguess","vers","qpro","tmpcell","WK3Enum","osheets","rnames","parse_cell","parse_LABEL","write_LABEL","write_INTEGER","write_NUMBER","wk1_parse_rc","FuncTab","BinOpTab","parse_cell_3","write_LABEL_16","wsidx","parse_NUMBER_17","v1","v2","write_NUMBER_17","parse_NUMBER_27","parse_SHEETNAMECS","write_XFORMAT_SHEETNAME","argc","argL","argR","args","wk1_fmla_to_csf","sheet_to_wk1","write_biff_rec","write_RANGE","max_R","book_to_wk3","wb","wscnt","write_BOF_WK3","parse_rs","tregex","rpregex","parse_r","rpr","font","pass","shadow","outline","strike","uval","rgb","family","valign","parse_rpr","rregex","rend","rs","rs_to_html","nlregex","r_to_html","intro","outro","align","parse_rpr2","sitregex","sirregex","sirphregex","parse_si","html","cellHTML","sstr0","sstr1","sstr2","_JS2ANSI","parse_CRYPTOVersion","Major","Minor","parse_DataSpaceMapEntry","comps","parse_Primary","hdr","parse_TransformInfoHeader","ename","cmode","parse_EncryptionHeader","Flags","AlgID","valid","AlgIDHash","KeySize","ProviderType","CSPName","parse_EncryptionVerifier","Salt","Verifier","VerifierHash","parse_EncInfoStd","parse_EncInfoExt","parse_EncInfoAgl","KeyData","encryptedHmacKey","encryptedHmacValue","encs","uri","crypto_CreateXorArray_Method1","PadArray","InitialCode","XorMatrix","XorRor","byte1","byte2","Byte","password","Temp","PasswordLastChar","PadIndex","Password","XorKey","CurrentElement","Char","CreateXorKey_Method1","Index","ObfuscationArray","crypto_MakeXorDecryptor","XorArrayIndex","XorArray","Data","Value","crypto_DecryptData_Method1","parse_XORObfuscation","verificationBytes","verifier","PasswordArray","PasswordDecoded","crypto_CreatePasswordVerifier_Method1","insitu","parse_FilePassHeader","Info","EncryptionVersionInfo","EncryptedVerifier","EncryptedVerifierHash","parse_RC4Header","EncryptionHeader","EncryptionVerifier","parse_RC4CryptoHeader","RTF","rtf_to_sheet","rtf_to_sheet_str","rowtf","rtfre","last_index","rgb2Hex","rgb_tint","hex","tint","hsl","H6","L2","rgb2HSL","h6","hsl2RGB","MDW","px","char2width","chr","cycle_width","collw","find_mdw_colw","_MDW","coll","customWidth","PPI","pt","XLMLPatternTypeMap","None","Solid","Gray50","Gray75","Gray25","HorzStripe","VertStripe","ReverseDiagStripe","DiagStripe","DiagCross","ThickDiagCross","ThinHorzStripe","ThinVertStripe","ThinReverseDiagStripe","ThinHorzCross","cellXF_uint","cellXF_bool","parse_sty_xml","numFmtRegex","cellXfRegex","fillsRegex","fontsRegex","bordersRegex","themes","styles","NumberFmt","formatCode","parse_numFmts","Fonts","bold","italic","underline","condense","extend","vertAlign","scheme","auto","indexed","icv","theme","themeElements","clrScheme","parse_fonts","Fills","patternType","bgColor","fgColor","parse_fills","Borders","border","diagonalUp","diagonalDown","parse_borders","xf","CellXf","alignment","vertical","horizontal","textRotation","wrapText","parse_cellXfs","parse_BrtFill","parse_BrtBorder","XLSXThemeClrScheme","parse_clrScheme","lastClr","parse_fontScheme","parse_fmtScheme","clrsregex","fntsregex","fmtsregex","themeltregex","parse_theme_xml","parse_themeElements","parse_FullColorExt","xclrType","nTintShade","xclrValue","parse_IcvXF","parse_ColorTheme","parse_ExtProp","extType","parse_XFExtGradient","update_xfext","xfext","xfe","sheet_insert_comments","comments","threaded","people","comment","author","parse_BrtCommentAuthor","rcregex","rcbase","rcfunc","fstr","crefregex","$0","$4","$5","shift_formula_xlsx","_xlfn","parseread1","parse_ColRelU","parse_RgceArea","parse_RgceArea_BIFF2","parse_RgceLoc","parse_RgceLoc_BIFF2","parse_RgceElfLoc","fQuoted","parse_PtgAttrBaxcel","bitSemi","parse_PtgAttrSpaceType","parse_SerAr","parse_PtgExtraMem","parse_PtgExtraArray","parse_PtgElfLoc","parse_PtgElfNoop","parse_PtgElfLel","PtgListRT","PtgTypes","iftab","FtabArgc","Ftab","cparams","tab","parsetab","Cetab","nameindex","rl","parse_RgceLocRel_BIFF2","cl","parse_RgceLocRel","area","parse_RgceAreaRel","ixti","parse_PtgNameX_BIFF5","PtgDupes","Ptg18","coltype","rt","Ptg19","bitIf","bitGoto","ptgs","stringify_array","PtgBinOp","PtgAdd","PtgConcat","PtgDiv","PtgEq","PtgGe","PtgGt","PtgLe","PtgLt","PtgMul","PtgNe","PtgPower","PtgSub","get_ixti_raw","supbooks","XTI","SID","get_ixti","ixtiraw","sname","formula_quote_sheet_name","stringify_formula","nameidx","last_sp","fflen","func","lbl","names","xlfn","externbook","bookidx","ixtidata","lp","rp","sharedf","parsedf","fnd","arrayf","_left","parse_SharedParsedFormula","parse_Formula","parse_FormulaValue","cbf","parse_XLSCellParsedFormula","shared","parse_XLSBParsedFormula","parse_XLSBArrayParsedFormula","parse_XLSBCellParsedFormula","parse_XLSBNameParsedFormula","parse_XLSBSharedParsedFormula","ods_to_csf_formula","ods_to_csf_3D","strs","_ssfopts","default_margins","margins","mode","defs","footer","safe_format","fmtid","fillid","raw_rgb","mergecregex","sheetdataregex","hlinkregex","dimregex","colregex","afregex","marginregex","sheetprregex","sheetprregex2","svsregex","parse_ws_xml","data1","data2","mtch","sheetPr","parse_ws_xml_sheetpr","parse_ws_xml_sheetpr2","parse_ws_xml_dim","svs","Views","sviewregex","zoomScale","zoom","rightToLeft","RTL","parse_ws_xml_sheetviews","seencol","coli","colm","colM","outlineLevel","parse_ws_xml_cols","parse_ws_xml_data","afilter","parse_ws_xml_autofilter","merges","_merge","hlink","location","Rel","tooltip","Tooltip","rng","parse_ws_xml_hlinks","margin","tmpref","codeName","CodeName","cellregex","rowregex","isregex","refregex","match_v","match_f","sdata","sstr","ftag","cells","cref","tagr","tagc","do_format","rowobj","rowrite","marr","marrlen","xlen","rstarti","outa","ht","rslice","cellFormula","___f","_tag","fillId","cm","xlmeta","Cell","_r","parse_BrtWsDim","parse_BrtShortReal","parse_BrtMergeCell","BrtMarginKeys","parse_chart","csheet","nc","nf","parse_Cache","WBPropsDef","WBViewDef","SheetDef","CalcPrDef","push_defaults_array","defaults","push_defaults","parse_wb_defaults","WBProps","CalcPr","WBView","badchars","wbnsregex","parse_BrtFRTArchID$","ArchID","parse_wb","xmlns","Names","Sheet","Ref","Ptg","parse_wb_bin","dname","dnstart","Hidden","Comment","localSheetId","parse_wb_xml","parse_ws","ai","af","RR","aii","_d","relId","rfx","above","parse_ws_bin","parse_cs","parse_cs_bin","parse_cs_xml","parse_sty","parse_sty_bin","parse_sst","Count","Unique","parse_sst_bin","sst","uniqueCount","parse_sst_xml","parse_cmnt","authors","iauthor","parse_comments_bin","commentList","authtag","cmnttag","authorId","guid","textMatch","parse_comments_xml","parse_cc","parse_cc_bin","parse_cc_xml","parse_xlink","parse_xlink_bin","parse_xlmeta","Types","metatype","parse_xlmeta_bin","lastmeta","offsets","parse_xlmeta_xml","XLMLFormatMap","attregexg2","attregex2","xlml_parsexmltag","words","xlml_parsexmltagobj","xlml_set_custprop","Custprops","oval","safe_format_xlml","process_style_xlml","stag","Interior","ID","parse_xlml_data","csty","sid","StyleID","interiors","UTC","Formula","ArrayRange","xlml_clean_comment","parse_xlml_xml","Rn","opening","ishtml","_o","html_to_sheet","book_append_sheet","html_to_workbook","Currency","Fixed","Standard","Percent","Scientific","sheetnames","cursheet","sheetname","dtag","didx","fidx","pidx","cstys","Workbook","wsprops","raw_Rn3","HRef","HRefScreenTip","MergeAcross","MergeDown","cma","cmd","AutoFitHeight","Height","Format","ssfidx","Width","_col","Span","_NamedRange","_DefinedName","RefersTo","AutoFilter","Range","parse_fods","Margin","pagemargins","Top","Left","Right","Bottom","bookSheets","bookProps","SSF","parse_xlml","fix_read_opts","parse_compobj","AnsiUserType","AnsiClipboardFormat","parse_ClipboardFormatOrAnsiString","Reserved1","UnicodeClipboardFormat","parse_ClipboardFormatOrUnicodeString","Reserved2","CONTINUE_RT","slurp","RecordType","nextrt","XLSRecordEnum","ll","safe_format_xf","make_cell","parse_workbook","lastcell","cmnt","rngC","rngR","temp_val","country","Directory","last_formula","cur_sheet","Preamble","last_cell","XFs","palette","get_rgb","addcell","file_depth","xfd","icvFore","icvBack","process_cell_style","afi","rrtabid","lastuser","winlocked","wtf","objects","last_lbl","last_RT","BIFF2Fmt","BIFF2FmtTable","FilterDatabases","seen_codepage","Date1904","WriteProtect","cpval","CalcRefMode","FullCalc","fDialog","fBelow","fRight","ExternCount","tmpri","biffguess","fakebs8","rknum","rkrec","_fr","_fc","_fe","_arraystart","isst","_j","_ixfe","b4idx","b2idx","cmo","lastobj","TxO","ImData","noteobj","Strings","Encryption","Themes","Metadata","Country","PSCLSID","parse_xlscfb","CompObj","WorkbookP","bookVBA","vbaraw","newcfb","newpath","make_vba_xls","DSI","DocSummary","SI","Summary","HeadingPairs","TitlesOfParts","parse_xls_props","bookFiles","grbit","fBold","fItalic","fUnderline","fStrikeout","fOutline","fShadow","fCondense","fExtend","parse_FontFlags","bCharSet","charset","xColorType","nTS","bR","bG","bB","parse_BrtColor","ixfeParent","ifmt","defaultThemeVersion","strName","autoCompressPictures","backupFile","checkCompatibility","filterPrivacy","hidePivotFieldList","promptedSolutions","publishItems","refreshAllConnections","saveExternalLinkValues","showBorderUnselectedTables","showInkAnnotation","showObjects","showPivotChartFilter","updateLinks","iTabID","strRelID","fAlwaysCalc","idObj","stAuthor","parse_NoteSh","dyHeight","fl","Pos","Dim","CurTab","FirstTab","Selected","TabRatio","UserName","fts","parse_BIFF5Obj","parse_FtArray","ccv","rw","rkrecs","lastcol","ixfes","fStyle","alc","fWrap","alcV","fJustLast","trot","cIndent","fShrinkToFit","iReadOrder","fAtrNum","fAtrFnt","fAtrAlc","fAtrBdr","fAtrPat","fAtrProt","dgLeft","dgRight","dgTop","dgBottom","icvLeft","icvRight","grbitDiag","icvTop","icvBottom","icvDiag","dgDiag","fsxButton","parse_CellStyleXF","cmcs","ucnt","extsst","dsst","ctab","virtPath","rgst","texts","accel","parse_ControlInfo","cchText","sVer","displayName","targetFrameName","moniker","oleMoniker","fileTime","Loc","parse_Hyperlink","xnum","cUse","wzTooltip","cxfs","crc","cexts","cchComment","themeXML","parse_frtHeader","env","lcb","mtch2","hd","midx","colspan","rowspan","_t","make_html_row","editable","sheet_add_dom","or_R","or_C","getElementsByTagName","is_dom_element_hidden","elts","hasAttribute","getAttribute","innerHTML","Aelts","Aelti","parse_dom_table","get_computed_style","ownerDocument","defaultView","getComputedStyle","get_get_computed_style_function","getPropertyValue","parse_text_p","fixed","number_formats_ods","day","month","year","hours","minutes","seconds","era","quarter","parse_content_xml","sheetag","rowtag","NFtag","NF","ctag","textp","textpidx","textR","row_ol","number_format_map","mrange","rowpeat","colpeat","atag","_Ref","creator","creatoridx","isstub","intable","rptR","rpt","nrange","ptp","href","parse_ods","FEtag","parse_manifest","u8_to_dataview","DataView","u8str","u8","u8concat","u8a","popcnt","parse_varint49","varint","varint_to_i32","i32","parse_shallow","mappa","parse_snappy_chunk","chunks","parse_new_storage","rsst","dv","getUint32","data_offset","d128","ieee","mantissa","readDecimal128LE","getFloat64","parse_cell_storage","parse_old_storage","parse_TSP_Reference","parse_TST_TableDataList","pb","rtp","rtpref","mtype","tswpsa","parse_TST_Tile","_a","_b","_c","_g","_h","_k","_l","_m","used_storage_u8","used_storage","wide_offsets","used_storage_offsets","getUint16","parse_TST_TileRowInfo","nrows","parse_TST_TableInfoArchive","tableref","store","tile","tl","_tile","parse_TST_TableModelArchive","parse_TN_DocumentArchive","root2","parse_TN_SheetArchive","parse_numbers_iwa","packets","decompress_iwa_file","messages","mi","merge","parse_iwa_file","packet","docroot","iwam","safe_parse_sheet","relsPath","sheetRels","stype","dfile","drelsp","draw","parse_drawing","chartp","crelsp","parse_ds","tcomments","tidx","personId","parse_tcmnt_xml","strip_front_slash","_zip","getzipbin","binname","dir","workbooks","charts","dialogs","macros","threadedcomments","links","coreprops","extprops","custprops","calcchains","vba","drawings","TODO","ctext","Extension","ContentType","PartName","calcchain","parse_ct","xlsb","parse_theme","link","propdata","parse_ext_props","toks","parse_cust_props","deps","bookDeps","wbsheets","wbext","wbrelsi","wbrelsfile","wbrels","displayname","parse_people_xml","safe_parse_wbrels","nmode","wsloop","snjseen","snj","Deps","Styles","bin","parse_xlsxcfb","dsm","parse_DataSpaceMap","seds","parse_DataSpaceDefinition","einfo","parse_EncryptionInfo","decrypt_agile","decrypt_std76","read_plaintext","read_prn","readSync","Deno","File","Folder","infile","open","close","read_binary","bstrify","ab","vu","foo","read_cfb","OLD_WTF","read_wb_ID","read_zip","read_utf16","read_plaintext_raw","make_json_row","defval","isempty","enumerable","__rowNum__","rawNumbers","outi","header_cnt","skipHidden","blankrows","qreg","make_csv_row","txt","forceQuotes","sheet_to_csv","endregex","strip","sheet_add_json","js","skipHeader","JS","ws_get_cell_stub","RC","book_new","roll","check_ws_name","cell_set_hyperlink","split_cell","json_to_sheet","table_to_sheet","table_to_book","sheet_to_txt","sheet_to_html","make_html_preamble","sheet_to_formulae","cmds","sheet_to_row_object_array","sheet_get_cell","book_set_sheet_visibility","sh","vis","wb_sheet_idx","cell_set_number_format","cell_set_internal_link","cell_add_comment","sheet_set_array_formula","dynamic","rngstr","SHEET_VISIBLE","SHEET_HIDDEN","SHEET_VERY_HIDDEN","parseDataSheet","keepUndefined","variableNames","variableUnits","containsUndefined","checkVariables","parsed","targetVariable","calculateResidual","sampleMass","relativeResidual","massLoss","relativeMassLoss","createLabeledRecords","Map","stringValue","groups","getMetaTGA","labeledRecords","holder","mass","parseHolder","initialValue","nextLine","middlePoint","inflectionPoint","parseResults","improveRelativeResult","firstZone","ratio","percentData","parseCurveValues","improveTGALabeledRecords","tgaParseTAInstrumentsXLS","xlsSheets","workbook","sheetNames","sheetName","getAllSheetsFromXLS","xlsSheet","getVariables","getMeta","datum","nameStartChar","nameRegexp","regexName","isExist","isEmptyObject","arrayMode","getValue","isName","getAllMatches","regex","allmatches","startIndex","arrToStr","jPath","indentation","xmlStr","isPreviousElementTag","tagObj","tagName","propName","newJPath","textNodeName","tagText","isStopNode","tagValueProcessor","replaceEntitiesValue","cdataPropName","commentPropName","attStr","attr_to_str","tempInd","piTextNodeName","newIdentation","indentBy","tagStart","tagValue","unpairedTags","suppressUnpairedNode","suppressEmptyNode","attrMap","attrStr","ignoreAttributes","attr","attrVal","attributeValueProcessor","suppressBooleanAttributes","attributeNamePrefix","stopNodes","textValue","processEntities","entity","buildFromOrderedJs","jArray","getIgnoreAttributesFn","attrName","pattern","defaultOptions","attributesGroupName","preserveOrder","oneListGroup","Builder","isAttribute","ignoreAttributesFn","attrPrefixLen","processTextOrObjNode","indentate","tagEndChar","ajPath","j2x","buildTextValNode","buildObjectNode","fromMettlerToledo","arrayBuffer","part","parsedCurveValues","dataValues","tgaParseMettlerToledo","cheminfo","fromNetzsch","inData","temperature","parsePerkinElmerAscii","sections","methodSteps","steps","currentSection","currentStep","description","dataHeaders","rest","parseDataBlockHeader","parseDataHeader","dataParts","getSections","firstLineParts","secondLineParts","combinedHeader","fromPerkinElmer","stepsInfo","stepVariable","build","jObj","arrayNodeName","buildAttrPairStr","newval","arrLen","listTagVal","listTagAttr","Ks","closeTag","tagEndExp","piClosingChar","self","document","postMessage","IS_PAPA_WORKER","_handle","_finished","_completed","_halted","_input","_baseIndex","_partialLine","_rowCount","_start","_nextChunk","isFirstChunk","_completeResults","errors","chunkSize","chunk","streamer","_config","parseChunk","skipFirstNLines","newline","quoteChar","guessLineEndings","beforeFirstChunk","paused","aborted","cursor","preview","workerId","WORKER_ID","finished","complete","_sendError","RemoteChunkSize","_readChunk","_chunkLoaded","stream","XMLHttpRequest","withCredentials","onload","onerror","_chunkError","downloadRequestBody","downloadRequestHeaders","setRequestHeader","send","status","readyState","responseText","getResponseHeader","statusText","LocalChunkSize","FileReader","webkitSlice","mozSlice","FileReaderSync","readAsText","pause","resume","on","_streamData","_streamEnd","_streamError","_checkIsFinished","_streamCleanUp","removeListener","skipEmptyLines","DefaultDelimiter","transformHeader","dynamicTypingFunction","abort","delimiter","RECORD_SEP","UNIT_SEP","successful","bestDelimiter","delimitersToGuess","getCharIndex","setTimeout","fastMode","escapeChar","BAD_DELIMITERS","linebreak","truncated","renamedHeaders","userError","userStep","userChunk","userComplete","terminate","worker","WORKERS_SUPPORTED","NODE_STREAM_INPUT","download","readable","URL","webkitURL","BLOB_URL","createObjectURL","Blob","Worker","onmessage","config","unparse","quotes","escapeFormulae","BYTE_ORDER_MARK","Parser","ParserHandle","NetworkStreamer","FileStreamer","StringStreamer","ReadableStreamStreamer","jQuery","each","inputElem","instanceConfig","before","action","reason","fromPerkinElmerCSV","Papa","Time","parseTAInstruments","metaLines","allDataLines","instrument","splitTrim","instrumentSerial","sampleName","weightUnit","controls","furnaceType","operator","runSerial","procName","dataStart","parseMeta","dataLines","balancePurgeFlow","samplePurgeFlow","fromTAInstruments","fromTAInstrumentsExcel"],"mappings":"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AGy2D,IACpC,GAAa,CAAE/pE,EAAG,cAAesT,EA7FvB,GA8FV,IAAa,CAAA,EAEb,WAAmB,CAAEtT,EAAG,SAAUsT,EAnFxB,IAoFV,WAAmB,CAAEtT,EAAG,WAAYsT,EApF1B,IAqFV,WAAmB,CAAA,GAIvB62D,GAAc,CACV,EAAe,KACf,EAAe,KACf,EAAe,GACf,EAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,GAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,IAAe,KACf,MAAe,MAInBC,GAAiB,CACpB,KACA,QACA,aACA,WACA,YACA,iBACA,eACA,WACA,SACA,WACA,cACA,kBACA,gBACA,YACA,UACA,YACA,eACA,UACA,YAGD,SAASC,GAAOlN,GAA6D,OAAOA,EAAIjxC,IAAI,SAASt1B,GAAK,MAAO,CAAEA,GAAG,GAAI,IAAKA,GAAG,EAAG,IAAM,IAAFA,EAAQ,EAAI,CAIrJ,IA4FI0zE,GAAsBhN,GA5FE+M,GAAO,CAElC,EACA,SACA,SACA,MACA,IACA,SACA,SACA,MAGA,EACA,SACA,SACA,MACA,IACA,SACA,SACA,MAEA,QACA,MACA,IACA,QACA,QACA,MACA,SACA,QACA,SACA,SACA,SACA,SACA,QACA,SACA,MACA,SAEA,IACA,SACA,SACA,MACA,QACA,QACA,MACA,IACA,MACA,SACA,SACA,SACA,SACA,SACA,SACA,SAEA,QACA,QACA,SACA,SACA,SACA,S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CL,IAAK,iBACL,IAAK,UACL,IAAK,aACL,IAAK,eACL,IAAK,eACL,IAAK,aACL,IAAK,cACL,IAAK,cACL,IAAK,kBACL,IAAK,YACL,IAAK,iBACL,IAAK,cACL,IAAK,eACL,IAAK,eACL,IAAK,YACL,IAAK,QACL,IAAK,YACL,IAAK,UACL,IAAK,gBACL,IAAK,UACL,IAAK,aACL,IAAK,aACL,IAAK,gBACL,IAAK,YACL,IAAK,aACL,IAAK,UACL,IAAK,OACL,IAAK,cACL,IAAK,UACL,IAAK,YACL,IAAK,iBACL,IAAK,cACL,IAAK,oBACL,IAAK,gBACL,IAAK,eACL,IAAK,iBACL,IAAK,kBACL,IAAK,cACL,IAAK,qBACL,IAAK,SACL,IAAK,cACL,IAAK,WACL,IAAK,WACL,IAAK,eACL,IAAK,eACL,IAAK,iBACL,IAAK,eACL,IAAK,kBACL,IAAK,qBACL,IAAK,aACL,IAAK,YACL,IAAK,YACL,IAAK,gBACL,IAAK,cACL,IAAK,eACL,IAAK,kBACL,IAAK,oBACL,IAAK,kBACL,IAAK,iBACL,IAAK,UACL,IAAK,YACL,IAAK,YACL,IAAK,aACL,IAAK,cACL,IAAK,UACL,IAAK,SACL,IAAK,cACL,IAAK,UACL,IAAK,oBACL,IAAK,kBACL,IAAK,QACL,IAAK,aACL,IAAK,YACL,IAAK,cACL,IAAK,mBACL,IAAK,oBACL,IAAK,cACL,IAAK,cACL,IAAK,mBACL,IAAK,eACL,IAAK,aACL,IAAK,eACL,IAAK,gBACL,IAAK,aACL,IAAK,cACL,IAAK,cACL,IAAK,iBACL,IAAK,YACL,IAAK,cACL,IAAK,eACL,IAAK,aACL,IAAK,aACL,IAAK,gBACL,IAAK,eACL,IAAK,kBACL,IAAK,gBACL,IAAK,qBACL,IAAK,WACL,IAAK,OACL,IAAK,gBACL,IAAK,kBACL,IAAK,aACL,IAAK,aACL,IAAK,eACL,IAAK,iBACL,IAAK,cACL,IAAK,iBACL,IAAK,qBACL,IAAK,YACL,IAAK,oBACL,IAAK,WACL,IAAK,cACL,IAAK,iBACL,IAAK,WACL,IAAK,eACL,IAAK,gBACL,IAAK,gBACL,IAAK,mBACL,IAAK,iBACL,IAAK,eACL,IAAK,cACL,IAAK,YACL,IAAK,kBACL,IAAK,oBACL,IAAK,iBACL,IAAK,YACL,IAAK,aACL,IAAK,oBACL,IAAK,aACL,IAAK,eACL,IAAK,iBACL,IAAK,kBACL,IAAK,eACL,IAAK,gBACL,IAAK,gBACL,IAAK,qBACL,IAAK,mBACL,IAAK,qBACL,IAAK,yBACL,IAAK,cACL,IAAK,aACL,IAAK,mBACL,IAAK,sBACL,IAAK,eACL,IAAK,eACL,IAAK,gBACL,IAAK,cACL,IAAK,kBACL,IAAK,cACL,IAAK,gBACL,IAAK,kBACL,IAAK,2BACL,IAAK,eACL,IAAK,iBACL,IAAK,aACL,IAAK,iBACL,IAAK,YACL,IAAK,mBACL,IAAK,cACL,IAAK,wBACL,IAAK,kBACL,IAAK,qBACL,IAAK,kBACL,IAAK,kBACL,IAAK,kBACL,IAAK,qBACL,IAAK,aACL,IAAK,iBACL,IAAK,eACL,IAAK,mBACL,IAAK,aACL,IAAK,eACL,IAAK,kBACL,IAAK,gBACL,IAAK,gBACL,IAAK,kBACL,IAAK,kBACL,IAAK,gBACL,IAAK,iBACL,IAAK,uBACL,IAAK,0BACL,IAAK,iBACL,IAAK,eACL,IAAK,YACL,IAAK,cACL,IAAK,aACL,IAAK,iBACL,IAAK,kBACL,IAAK,kBACL,IAAK,gBACL,IAAK,kBACL,IAAK,gBACL,IAAK,gBACL,IAAK,qBACL,IAAK,cACL,IAAK,mBACL,IAAK,uBACL,IAAK,mBACL,IAAK,kBACL,IAAK,mBACL,IAAK,cACL,IAAK,iBACL,IAAK,kBACL,IAAK,eACL,IAAK,eACL,IAAK,oBACL,IAAK,sBACL,IAAK,sBACL,IAAK,mBACL,IAAK,qBACL,IAAK,qBACL,IAAK,gBACL,IAAK,aACL,IAAK,YACL,IAAK,cACL,IAAK,mBACL,IAAK,gBACL,IAAK,wBACL,IAAK,qBACL,IAAK,SACL,IAAK,kBACL,IAAK,gBACL,IAAK,kBACL,IAAK,gBACL,IAAK,gBACL,IAAK,mBACL,IAAK,mBACL,IAAK,oBACL,I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ACL,IAAK,OACL,IAAK,UACL,IAAK,UACL,IAAK,OACL,IAAK,WACL,IAAK,gBACL,IAAK,aACL,IAAK,eACL,IAAK,WACL,IAAK,YACL,IAAK,WACL,IAAK,OACL,IAAK,SACL,IAAK,OACL,IAAK,UACL,IAAK,QACL,IAAK,QACL,IAAK,YACL,IAAK,UACL,IAAK,aACL,IAAK,aACL,IAAK,WACL,IAAK,QACL,IAAK,UACL,IAAK,WACL,IAAK,QACL,IAAK,SACL,IAAK,OACL,IAAK,OACL,IAAK,UACL,IAAK,YACL,IAAK,MACL,IAAK,OACL,IAAK,OACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,MACL,IAAK,OACL,IAAK,UACL,IAAK,SACL,IAAK,WACL,IAAK,SACL,IAAK,aACL,IAAK,OACL,IAAK,OACL,IAAK,OACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,gBACL,IAAK,WACL,IAAK,aACL,IAAK,cACL,IAAK,gBACL,IAAK,kBACL,IAAK,gBACL,IAAK,WACL,IAAK,OACL,IAAK,QACL,IAAK,aACL,IAAK,KACL,IAAK,QACL,IAAK,SACL,IAAK,YACL,IAAK,cACL,IAAK,iBACL,IAAK,OACL,IAAK,gBACL,IAAK,WACL,IAAK,cACL,IAAK,WACL,IAAK,iBACL,IAAK,aACL,IAAK,YACL,IAAK,eACL,IAAK,eACL,IAAK,cACL,IAAK,aACL,IAAK,cACL,IAAK,eACL,IAAK,SACL,IAAK,WACL,IAAK,UACL,IAAK,UACL,IAAK,YACL,IAAK,UACL,IAAK,SACL,IAAK,SACL,IAAK,aACL,IAAK,YACL,IAAK,OACL,IAAK,YACL,IAAK,QACL,IAAK,OACL,IAAK,SACL,IAAK,YACL,IAAK,QACL,IAAK,YACL,IAAK,WACL,IAAK,UACL,IAAK,cACL,IAAK,cACL,IAAK,SACL,IAAK,eACL,IAAK,WACL,IAAK,YACL,IAAK,UACL,IAAK,WACL,IAAK,cACL,IAAK,MACL,IAAK,SACL,IAAK,UACL,IAAK,QACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,WACL,IAAK,UACL,IAAK,SACL,IAAK,QACL,IAAK,WACL,IAAK,QACL,IAAK,YACL,IAAK,UACL,IAAK,MACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,QACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,OACL,IAAK,OACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,WACL,IAAK,aACL,IAAK,cACL,IAAK,OACL,IAAK,WACL,IAAK,OACL,IAAK,gBACL,IAAK,YACL,IAAK,cACL,IAAK,QACL,IAAK,iBACL,IAAK,kBACL,IAAK,kBACL,IAAK,iBACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,QACL,IAAK,UACL,IAAK,aACL,IAAK,eACL,IAAK,oBACL,IAAK,QACL,IAAK,UACL,IAAK,aACL,IAAK,eACL,IAAK,QACL,IAAK,cACL,IAAK,cACL,IAAK,WACL,IAAK,eACL,IAAK,YACL,IAAK,WACL,IAAK,WACL,IAAK,OACL,IAAK,OACL,IAAK,UACL,IAAK,QACL,IAAK,SACL,IAAK,OACL,IAAK,WACL,IAAK,gBACL,IAAK,YACL,IAAK,kBACL,IAAK,eACL,IAAK,gBACL,IAAK,mBACL,IAAK,cACL,IAAK,gBACL,IAAK,cACL,IAAK,WACL,IAAK,MACL,IAAK,YACL,IAAK,aACL,IAAK,qBACL,IAAK,mBACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,QACL,IAAK,UACL,IAAK,QACL,IAAK,SACL,IAAK,OACL,IAAK,SACL,IAAK,UACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,aACL,IAAK,cACL,IAAK,YACL,IAAK,SACL,IAAK,UACL,IAAK,QACL,IAAK,YACL,IAAK,YACL,IAAK,aACL,IAAK,SACL,IAAK,WACL,IAAK,QACL,IAAK,SACL,IAAK,SACL,IAAK,QACL,IAAK,SACL,IAAK,MACL,IAAK,OACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,OACL,IAAK,OACL,IAAK,WACL,IAAK,WACL,IAAK,UACL,IAAK,WACL,IAAK,OACL,IAAK,YACL,IAAK,YACL,IAAK,UACL,IAAK,aACL,IAAK,aACL,IAAK,QACL,IAAK,QACL,IAAK,WACL,IAAK,WACL,IAAK,UACL,IAAK,SACL,IAAK,WACL,IAAK,UACL,IAAK,QACL,IAAK,UACL,IAAK,WACL,IAAK,YACL,IAAK,WACL,IAAK,aACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,cACL,IAAK,UACL,IAAK,YACL,IAAK,WACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,UACL,IAAK,cACL,IAAK,MACL,IAAK,cACL,IAAK,MACL,IAAK,aACL,IAAK,gBACL,IAAK,UACL,IAAK,eACL,IAAK,UACL,IAAK,WACL,IAAK,SACL,IAAK,YACL,IAAK,cAEHD,GAAW,CACb,EAAG,EACH,EAAG,EACH,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,GAAI,EACJ,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,IAAK,EACL,MAAO,GAGT,SAAS0E,GAAmBhkF,GAY3B,MAXmB,OAAhBA,EAAExhB,MAAM,EAAE,KAAawhB,EAAIA,EAAExhB,MAAM,IAEhB,IAAnBwhB,EAAEslC,WAAW,IAEO,KADtBtlC,EAAIA,EAAExhB,MAAM,IACP8mD,WAAW,KAAUtlC,EAAIA,EAAExhB,MAAM,KAMvCwhB,GAFAA,GAFAA,EAAIA,EAAEia,QAAQ,oBAAqB,KAE7BA,QAAQ,gDAAiD,SAASy0B,EAAIC,GAAM,OAAOA,EAAG10B,QAAQ,MAAM,GAAK,IAEzGA,QAAQ,sBAAuB,OAC5BA,QAAQ,QAAQ,KAAKA,QAAQ,MAAM,IAC7C,CAQA,SAASgqE,GAAcxzF,GACtB,IAAIM,EAAIN,EAAE4mC,MAAM,KAEhB,MAAO,CADCtmC,EAAE,GAAGsmC,MAAM,KAAK,GACbtmC,EAAE,GAAGsmC,MAAM,KAAK,IAAMtmC,EAAEhT,OAAS,EAAK,KAAOgT,EAAE,GAAGsmC,MAAM,KAAK,IAAMtmC,EAAE,GAAGsmC,MAAM,KAAK,IAAO,IACtG,CAMA,IAAI6sD,GAAO,GACPC,GAAW,CAAA,EA8Cf,SAASC,GAAgBC,EAAqBC,GAC7C,GAAID,EAAJ,CACA,IAAIE,EAAO,CAAC,GAAK,GAAK,IAAM,IAAM,GAAK,IAC5B,QAARD,IAAgBC,EAAO,CAAC,EAAG,EAAG,EAAG,EAAG,GAAK,KACvB,MAAlBF,EAAQt4D,OAAgBs4D,EAAQt4D,KAASw4D,EAAK,IAC5B,MAAlBF,EAAQr4D,QAAgBq4D,EAAQr4D,MAASu4D,EAAK,IAC5B,MAAlBF,EAAQxyE,MAAgBwyE,EAAQxyE,IAAS0yE,EAAK,IAC5B,MAAlBF,EAAQx1D,SAAgBw1D,EAAQx1D,OAAS01D,EAAK,IAC5B,MAAlBF,EAAQlhD,SAAgBkhD,EAAQlhD,OAASohD,EAAK,IAC5B,MAAlBF,EAAQG,SAAgBH,EAAQG,OAASD,EAAK,GARpC,CASd,CA0BA,SAASE,GAAY96F,EAAY+6F,EAAkBC,EAAoBv4C,EAAM8sC,EAAQC,GACpF,IACI/sC,EAAK4/B,SAAQriF,EAAEqa,EAAIynC,GAAUi5C,GACjC,CAAE,MAAMx3F,GAAK,GAAGk/C,EAAK+e,IAAK,MAAMj+D,CAAG,CACnC,GAAW,MAARvD,EAAEoT,GAAcqvC,EAAKg1B,WAAxB,CAEA,GADW,MAARz3E,EAAEoT,GAA4B,iBAARpT,EAAE8B,IAAgB9B,EAAE8B,EAAIg7D,GAAU98D,EAAE8B,MACxD2gD,IAA0B,IAAlBA,EAAK2/B,WAA+B,MAARpiF,EAAEoT,EAAW,IAErD,GADuB,MAApB0uC,GAAUi5C,IAAgBjyC,GAASE,GAAY+xC,IAAU,UAAWA,GAC5D,MAAR/6F,EAAEoT,EAAWpT,EAAE6Z,EAAI7Z,EAAE6Z,GAAKmtD,GAAKhnE,EAAE8B,QAC/B,GAAa,IAAVi5F,EACP,GAAW,MAAR/6F,EAAEoT,GACI,EAAJpT,EAAE8B,KAAS9B,EAAE8B,EAAG9B,EAAE6Z,EAAI7Z,EAAE8B,EAAErO,SAAS,IAClCuM,EAAE6Z,EAAIgqC,GAAgB7jD,EAAE8B,QAEzB,GAAW,MAAR9B,EAAEoT,EAAW,CACpB,IAAIsyC,EAAKyW,GAAQn8D,EAAE8B,GACD9B,EAAE6Z,GAAb,EAAH6rC,KAAUA,EAAUA,EAAGjyD,SAAS,IACzBowD,GAAgB6B,EAC5B,KACK,SAAWrxD,IAAR2L,EAAE8B,EAAiB,MAAO,GAC7B9B,EAAE6Z,EAAIqqC,GAAYlkD,EAAE8B,EAAE04F,GAAS,KAErB,MAARx6F,EAAEoT,EAAWpT,EAAE6Z,EAAIsqC,GAAW42C,EAAM5+B,GAAQn8D,EAAE8B,GAAG04F,IACpDx6F,EAAE6Z,EAAIsqC,GAAW42C,EAAM/6F,EAAE8B,EAAE04F,GACjC,CAAE,MAAMj3F,GAAK,GAAGk/C,EAAK+e,IAAK,MAAMj+D,CAAG,CACnC,GAAIk/C,EAAKg1B,YACI,MAAVujB,EAAgB,IAClBh7F,EAAEmD,EAAIqsF,EAAOmB,MAAMqK,GACfh7F,EAAEmD,EAAE2tF,SAAW9wF,EAAEmD,EAAE2tF,QAAQP,QAAUvwF,EAAEmD,EAAE2tF,QAAQ1K,MACpDpmF,EAAEmD,EAAE2tF,QAAQ1K,IAAMsG,GAAS6C,EAAOiB,cAAcC,UAAUzwF,EAAEmD,EAAE2tF,QAAQP,OAAOnK,IAAKpmF,EAAEmD,EAAE2tF,QAAQlE,MAAQ,GACnGnqC,EAAK+e,MAAKxhE,EAAEmD,EAAE2tF,QAAQmK,QAAU1L,EAAOiB,cAAcC,UAAUzwF,EAAEmD,EAAE2tF,QAAQP,OAAOnK,MAElFpmF,EAAEmD,EAAE0tF,SAAW7wF,EAAEmD,EAAE0tF,QAAQN,QAC9BvwF,EAAEmD,EAAE0tF,QAAQzK,IAAMsG,GAAS6C,EAAOiB,cAAcC,UAAUzwF,EAAEmD,EAAE0tF,QAAQN,OAAOnK,IAAKpmF,EAAEmD,EAAE0tF,QAAQjE,MAAQ,GACnGnqC,EAAK+e,MAAKxhE,EAAEmD,EAAE0tF,QAAQoK,QAAU1L,EAAOiB,cAAcC,UAAUzwF,EAAEmD,EAAE0tF,QAAQN,OAAOnK,KAEvF,CAAE,MAAM7iF,GAAK,GAAGk/C,EAAK+e,KAAOguB,EAAOmB,MAAO,MAAMptF,CAAG,CAhCf,CAiCrC,CAYA,IAAI23F,GAAc,gDACdC,GAAiB,2DACjBC,GAAa,8BACbC,GAAW,cACXC,GAAW,6BACXC,GAAU,mEACVC,GAAa,gCACbC,GAAe,yCACfC,GAAe,8DACfC,GAAW,oEAGf,SAASC,GAAa99F,EAAkB2kD,EAAM1gD,EAAgBwqE,EAAM+Y,EAAkBiK,EAAQC,GAC7F,IAAI1xF,EAAM,OAAOA,EACbyuE,IAAMA,EAAO,CAAC,MAAM,KAIxB,IAAIppE,EAAIs/C,EAAK+kB,MAAS,GAAe,CAAA,EACjC2b,EAAsB,CAAChgF,EAAG,CAAC2D,EAAE,IAASC,EAAE,KAAUxD,EAAG,CAACuD,EAAE,EAAGC,EAAE,IAE7D80F,EAAQ,GAAIC,EAAQ,GACpBC,EAAgBj+F,EAAKsyB,MAAM+qE,IAC5BY,GACFF,EAAQ/9F,EAAKjJ,MAAM,EAAGknG,EAAK3lG,OAC3B0lG,EAAQh+F,EAAKjJ,MAAMknG,EAAK3lG,MAAQ2lG,EAAK,GAAG3nG,SAClCynG,EAAQC,EAAQh+F,EAGvB,IAAIk+F,EAAUH,EAAMzrE,MAAMqrE,IACvBO,EAASC,GAAqBD,EAAQ,GAAI74F,EAAGmiF,EAAIvjF,IAC3Ci6F,EAAUH,EAAMzrE,MAAMsrE,MAyEhC,SAA+BM,EAAoBrmB,EAAiBxyE,EAAGmiF,EAAkBvjF,GACxFk6F,GAAqBD,EAAQnnG,MAAM,EAAGmnG,EAAQtoE,QAAQ,MAAOvwB,EAAGmiF,EAAIvjF,EACrE,CA3EiDm6F,CAAsBF,EAAQ,GAAIA,EAAQ,GAAQ74F,EAAGmiF,EAAIvjF,GAGzG,IAAI48D,GAAQk9B,EAAMzrE,MAAM,wBAAwB,CAACh6B,OAAM,IAAKA,MAC5D,GAAGuoE,EAAO,EAAG,CACZ,IAAIyY,EAAMykB,EAAMhnG,MAAM8pE,EAAKA,EAAK,IAAIvuC,MAAMirE,IACvCjkB,GAzCL,SAA0B3P,EAAkBtkE,GAC3C,IAAI6V,EAAI2tD,GAAkBxjE,GACvB6V,EAAE7V,EAAE2D,GAAGkS,EAAEzV,EAAEuD,GAAKkS,EAAE7V,EAAE4D,GAAGiS,EAAEzV,EAAEwD,GAAKiS,EAAE7V,EAAE2D,GAAG,GAAKkS,EAAE7V,EAAE4D,GAAG,IAAG0gE,EAAG,QAAUf,GAAa1tD,GACpF,CAsCUmjF,CAAiBh5F,EAAGi0E,EAAI,GACjC,CAGA,IAAIglB,EAAMP,EAAMzrE,MAAMurE,IACnBS,GAAOA,EAAI,IAiMf,SAAiCt+F,EAAMwnF,GAClCA,EAAG+W,QAAO/W,EAAG+W,MAAQ,CAAC,MACzBv+F,EAAKsyB,MAAMksE,KAAa,IAAInoE,QAAQ,SAASrtB,EAActR,GAC3D,IAAI1B,EAAMurE,GAAYv4D,GAElBw+E,EAAG+W,MAAM7mG,KAAI8vF,EAAG+W,MAAM7mG,GAAK,KAE3B1B,EAAIyoG,YAAWjX,EAAG+W,MAAM7mG,GAAGgnG,MAAQ1oG,EAAIyoG,WAExCl8B,GAAavsE,EAAI2oG,eAAcnX,EAAG+W,MAAM7mG,GAAGknG,KAAM,EACrD,EACD,CA5MmBC,CAAwBP,EAAI,GAAI9W,GAGlD,IAAIxrF,EAA6B,GACjC,GAAG2oD,EAAKg1B,WAAY,CAEnB,IAAI5wE,EAAOg1F,EAAMzrE,MAAMkrE,IACpBz0F,GA2IL,SAA2B/M,EAAS+M,GAEnC,IADA,IAAI+1F,GAAU,EACNC,EAAO,EAAGA,GAAQh2F,EAAKzS,SAAUyoG,EAAM,CAC9C,IAAIlP,EAAOtuB,GAAYx4D,EAAKg2F,IAAO,GAChClP,EAAKvO,SAAQuO,EAAKvO,OAAS/e,GAAastB,EAAKvO,SAChD,IAAI0d,EAAKv1F,SAASomF,EAAKt1F,IAAK,IAAI,EAAG0kG,EAAKx1F,SAASomF,EAAKn1F,IAAI,IAAI,EAK9D,IAJGm1F,EAAKqP,eAAcrP,EAAK9V,OAAU8V,EAAKqP,cAAgB,UACnDrP,EAAKt1F,WAAYs1F,EAAKn1F,IAAKm1F,EAAKn9D,OAASm9D,EAAKn9D,OACjDosE,GAAWjP,EAAKn9D,QAASosE,GAAU,EAAMnP,GAAcE,EAAKn9D,QAChE6uD,GAAYsO,GACNmP,GAAQC,GAAMjjG,EAAQgjG,KAAU1/B,GAAIuwB,EAC3C,CACD,CAvJWsP,CAAkBnjG,EAAS+M,EACrC,CAGGk1F,GAAMmB,GAAkBnB,EAAK,GAAI54F,EAAGs/C,EAAM0gC,EAAUoM,EAAQC,GAG/D,IAAI2N,EAAUrB,EAAM1rE,MAAMmrE,IACvB4B,IAASh6F,EAAE,eA0Jf,SAAiCrF,GAChC,IAAIi1C,EAAI,CAAEqkC,KAAMt5E,EAAKsyB,MAAM,kBAAkB,IAAI,IACjD,OAAO2iB,CACR,CA7JgCqqD,CAAwBD,EAAQ,KAG/D,IAAIE,EAA0B,GAC1BC,EAASxB,EAAM1rE,MAAM8qE,IACzB,GAAGoC,EAAQ,IAAI3+B,EAAO,EAAGA,GAAQ2+B,EAAOlpG,SAAUuqE,EACjD0+B,EAAO1+B,GAAQgI,GAAkB22B,EAAO3+B,GAAM9pE,MAAMyoG,EAAO3+B,GAAMjrC,QAAQ,KAAM,IAGhF,IAAI6pE,EAAQzB,EAAM1rE,MAAMgrE,IACrBmC,GA+EJ,SAA6Bp6F,EAAGrF,EAAwByuE,GAEvD,IADA,IAAI/E,EAAQzvE,MAAMi+B,QAAQ7yB,GAClB3N,EAAI,EAAGA,GAAKsI,EAAK1J,SAAUoB,EAAG,CACrC,IAAIgxB,EAAM64C,GAAYuB,GAAS9iE,EAAKtI,KAAK,GACzC,IAAIgxB,EAAI4wD,IAAK,OACb,IAAI5K,IAAQD,GAAQ,CAAA,GAAI,QAAQ,IAAI/lD,EAAImK,IACrC67C,GACFhmD,EAAIkmD,OAASF,EAAIE,OACdlmD,EAAIg3E,WAAUh3E,EAAIkmD,QAAU,IAAI9M,GAAYp5C,EAAIg3E,aAEnDh3E,EAAIkmD,OAAS,IAAM9M,GAAYp5C,EAAIg3E,UACnChxB,EAAM,CAACE,OAAQlmD,EAAIkmD,OAAQE,WAAY,aAExCpmD,EAAIi3E,IAAMjxB,EACPhmD,EAAIk3E,UAAWl3E,EAAIm3E,QAAUn3E,EAAIk3E,eAAgBl3E,EAAIk3E,SAExD,IADA,IAAIE,EAAMj3B,GAAkBngD,EAAI4wD,KACxB1/B,EAAEkmD,EAAIz6F,EAAE2D,EAAE4wC,GAAGkmD,EAAIr6F,EAAEuD,IAAI4wC,EAAG,IAAI,IAAI91B,EAAEg8E,EAAIz6F,EAAE4D,EAAE6a,GAAGg8E,EAAIr6F,EAAEwD,IAAI6a,EAAG,CACnE,IAAIosC,EAAO+X,GAAY,CAACh/D,EAAE6a,EAAE9a,EAAE4wC,IAC3B8vB,GACErkE,EAAEu0C,KAAIv0C,EAAEu0C,GAAK,IACbv0C,EAAEu0C,GAAG91B,KAAIze,EAAEu0C,GAAG91B,GAAK,CAACxO,EAAE,IAAItR,OAAEzN,IAChC8O,EAAEu0C,GAAG91B,GAAG7jB,EAAIyoB,IAERrjB,EAAE6qD,KAAO7qD,EAAE6qD,GAAQ,CAAC56C,EAAE,IAAItR,OAAEzN,IAChC8O,EAAE6qD,GAAMjwD,EAAIyoB,EAEd,CACD,CACD,CA3GWq3E,CAAoB16F,EAAGo6F,EAAOhxB,GAGxC,IA0G6BuxB,EACzB/qD,EA3GA2nD,EAAUoB,EAAM1rE,MAAMorE,IAI1B,GAHGd,IAASv3F,EAAE,aAyGe26F,EAzGoBz+B,GAAYq7B,EAAQ,IA0GjE3nD,EAAI,CAAA,EACR,CAAC,OAAQ,QAAS,MAAO,SAAU,SAAU,UAAU5e,QAAQ,SAAS90B,GACpEy+F,EAAOz+F,KAAI0zC,EAAE1zC,GAAK2lC,WAAW84D,EAAOz+F,IACxC,GACO0zC,KA5GH5vC,EAAE,SAAWggF,EAAS5/E,EAAEwD,GAAKo8E,EAAShgF,EAAE4D,GAAKo8E,EAAS5/E,EAAEuD,GAAKq8E,EAAShgF,EAAE2D,IAAG3D,EAAE,QAAUujE,GAAayc,IACrG1gC,EAAKy2B,UAAY,GAAK/1E,EAAE,QAAS,CACnC,IAAI46F,EAASp3B,GAAkBxjE,EAAE,SAC9Bs/C,EAAKy2B,YAAc6kB,EAAOx6F,EAAEuD,IAC9Bi3F,EAAOx6F,EAAEuD,EAAI27C,EAAKy2B,UAAY,EAC3B6kB,EAAOx6F,EAAEuD,EAAIq8E,EAAS5/E,EAAEuD,IAAGi3F,EAAOx6F,EAAEuD,EAAIq8E,EAAS5/E,EAAEuD,GACnDi3F,EAAOx6F,EAAEuD,EAAIi3F,EAAO56F,EAAE2D,IAAGi3F,EAAO56F,EAAE2D,EAAIi3F,EAAOx6F,EAAEuD,GAC/Ci3F,EAAOx6F,EAAEwD,EAAIo8E,EAAS5/E,EAAEwD,IAAGg3F,EAAOx6F,EAAEwD,EAAIo8E,EAAS5/E,EAAEwD,GACnDg3F,EAAOx6F,EAAEwD,EAAIg3F,EAAO56F,EAAE4D,IAAGg3F,EAAO56F,EAAE4D,EAAIg3F,EAAOx6F,EAAEwD,GAClD5D,EAAE,YAAcA,EAAE,QAClBA,EAAE,QAAUujE,GAAaq3B,GAE3B,CAGA,OAFGjkG,EAAQ1F,OAAS,IAAG+O,EAAE,SAAWrJ,GACjCujG,EAAOjpG,OAAS,IAAG+O,EAAE,WAAak6F,GAC9Bl6F,CACR,CAUA,SAAS84F,GAAqBD,EAAoB74F,EAAGmiF,EAAkBvjF,GACtE,IAAIjE,EAAOuhE,GAAY28B,GACnB1W,EAAGje,OAAOtlE,KAAMujF,EAAGje,OAAOtlE,GAAO,IAClCjE,EAAKkgG,WAAU1Y,EAAGje,OAAOtlE,GAAKk8F,SAAWr+B,GAAYgB,GAAS9iE,EAAKkgG,WACvE,CAmIA,IAAI1B,GAAa,0CAoEjB,IAAIY,GAAkC,WACrC,IAAIgB,EAAY,oBAAqBC,EAAW,mBAC5C3X,EAAS,qBAAsB4X,EAAU,yCACzCC,EAAW,uBACXC,EAAUz9B,GAAS,KAAM09B,EAAU19B,GAAS,KAEjD,OAAO,SAA2B29B,EAAkBr7F,EAAGs/C,EAAMw3B,EAAiBsV,EAAQC,GAWrF,IAVA,IAAwGxvF,EACpGlM,EACA2qG,EAAMC,EAEoC/pB,EAJ1CxuB,EAAK,EAAGzvD,EAAI,GAAIioG,EAA0B,GAAIC,EAA0B,GAAI78F,EAAI,EAAGvM,EAAE,EAAGgwD,EAAG,EAAGxsC,EAAE,GAC3F6lF,EAAO,EAAGC,EAAO,EAEtB/D,EAAQ,EAAGC,EAAS,EACpB+D,EAAYhnG,MAAMi+B,QAAQw5D,EAAO8B,QACjCkI,EAAoC,GACpCH,EAAU,GACV7xB,EAAQzvE,MAAMi+B,QAAQ7yB,GACtBtJ,EAA0B,GAAImlG,EAAS,CAAA,EAAIC,GAAU,EACrDh3B,IAAexlB,EAAKwlB,WAChBi3B,EAAOV,EAAM9wD,MAAMywD,GAAWvyC,EAAK,EAAGuzC,EAAUD,EAAK9qG,OAAQw3D,GAAMuzC,IAAWvzC,EAAI,CAEzF,IAAIwzC,GADJ1oG,EAAIwoG,EAAKtzC,GAAI/mB,QACAzwC,OACb,GAAY,IAATgrG,EAAH,CAGA,IAAIC,EAAU,EACdC,EAAM,IAAIn5C,EAAK,EAAGA,EAAKi5C,IAAQj5C,EAAI,OAA2BzvD,EAAEyvD,IAC/D,IAAK,IACJ,GAA0C,KAAXzvD,EAAEyvD,EAAG,GAAW,GAAIA,EAAI,MAAMm5C,CAAM,CACnE,GAAG78C,GAAQA,EAAKg1B,WAAY,CAI3B,GADAonB,EAAgB,OADhB/qG,EAAMurE,GAAY3oE,EAAE7B,MAAMwqG,EAAQl5C,IAAK,IAC5Br/C,EAAYS,SAASzT,EAAIgT,EAAG,IAAM+3F,EAAK,EAAGC,GAAO,EACzDr8C,EAAKy2B,WAAaz2B,EAAKy2B,UAAY2lB,EAAM,SAC5CG,EAAS,CAAA,EAAIC,GAAU,EACpBnrG,EAAIyrG,KAAMN,GAAU,EAAMD,EAAO1f,IAAMt6C,WAAWlxC,EAAIyrG,IAAKP,EAAOzf,IAAMC,GAAMwf,EAAO1f,MACvE,KAAdxrF,EAAIsrF,SAAiB6f,GAAU,EAAMD,EAAO5f,QAAS,GACjC,MAApBtrF,EAAIkpG,eAAwBiC,GAAU,EAAMD,EAAOnnB,OAAS/jF,EAAIkpG,cAChEiC,IAASplG,EAAKglG,EAAK,GAAKG,EAC5B,CACA,MACD,IAAK,IAAYK,EAAUl5C,EAE5B,GAAGk5C,GAAWl5C,EAAI,MAGlB,GADA04C,EAAgB,OADhB/qG,EAAMurE,GAAY3oE,EAAE7B,MAAMwqG,EAAQl5C,IAAK,IAC5Br/C,EAAYS,SAASzT,EAAIgT,EAAG,IAAM+3F,EAAK,EAAGC,GAAO,IACzDr8C,EAAKy2B,WAAaz2B,EAAKy2B,UAAY2lB,GAAtC,CACG5kB,EAAM92E,EAAE2D,EAAI+3F,EAAO,IAAG5kB,EAAM92E,EAAE2D,EAAI+3F,EAAO,GACzC5kB,EAAM12E,EAAEuD,EAAI+3F,EAAO,IAAG5kB,EAAM12E,EAAEuD,EAAI+3F,EAAO,GAEzCp8C,GAAQA,EAAKg1B,aACfunB,EAAS,CAAA,EAAIC,GAAU,EACpBnrG,EAAIyrG,KAAMN,GAAU,EAAMD,EAAO1f,IAAMt6C,WAAWlxC,EAAIyrG,IAAKP,EAAOzf,IAAMC,GAAMwf,EAAO1f,MACvE,KAAdxrF,EAAIsrF,SAAiB6f,GAAU,EAAMD,EAAO5f,QAAS,GACjC,MAApBtrF,EAAIkpG,eAAwBiC,GAAU,EAAMD,EAAOnnB,OAAS/jF,EAAIkpG,cAChEiC,IAASplG,EAAKglG,EAAK,GAAKG,IAI5BL,EAAQjoG,EAAE7B,MAAMsxD,GAAIzY,MAAMwwD,GAC1B,IAAI,IAAIsB,EAAS,EAAGA,GAAUb,EAAMvqG,QAAuD,KAAlCuqG,EAAMa,GAAQ36D,OAAO0S,OAAO,KAAvCioD,GAE9C,IADAb,EAAQA,EAAM9pG,MAAM2qG,GAChBr5C,EAAK,EAAGA,GAAMw4C,EAAMvqG,SAAU+xD,EAEjC,GAAgB,KADhBzvD,EAAIioG,EAAMx4C,GAAIthB,QACTzwC,OAAL,CAGA,GAFAwqG,EAAOloG,EAAE05B,MAAMo2D,GAASzkF,EAAMokD,EAAI3wD,EAAE,EAAGgwD,EAAG,EAC1C9uD,EAAI,OAAuB,KAAdA,EAAE7B,MAAM,EAAE,GAAQ,IAAI,IAAM6B,EAC9B,MAARkoG,GAAgC,IAAhBA,EAAKxqG,OAAc,CAErC,IADA2N,EAAM,EAAGiX,EAAE4lF,EAAK,GACZppG,EAAE,EAAGA,GAAKwjB,EAAE5kB,WACXoxD,EAAGxsC,EAAE2iC,WAAWnmD,GAAG,IAAM,GAAKgwD,EAAK,MADdhwD,EAEzBuM,EAAM,GAAGA,EAAMyjD,EAGhBs5C,IADE/8F,CAEH,OAAS+8F,EACT,IAAItpG,EAAI,EAAGA,GAAKkB,EAAEtC,QAAoC,KAApBsC,EAAEilD,WAAWnmD,KAAnBA,GAO5B,KAPmEA,GACnE1B,EAAMurE,GAAY3oE,EAAE7B,MAAM,EAAEW,IAAI,IACxBsR,IAAGhT,EAAIgT,EAAIi/D,GAAY,CAACj/D,EAAE+3F,EAAK,EAAG93F,EAAE+3F,KAE5C9+F,EAAK,CAACoT,EAAE,IAEqB,OAAzBwrF,GAHJ5lF,EAAItiB,EAAE7B,MAAMW,IAGD46B,MAAMkuE,KAAsD,KAAZM,EAAK,KAAW5+F,EAAE8B,EAAE89D,GAAYg/B,EAAK,KAC7Fn8C,EAAKg9C,YAAa,CACpB,GAA6B,OAAzBb,EAAK5lF,EAAEoX,MAAMmuE,KAAsD,KAAZK,EAAK,IAI/D,GAFA5+F,EAAEqW,EAAEupD,GAAYgB,GAASg+B,EAAK,KAAKtuE,QAAQ,QAAS,MAChDmyB,EAAKs2C,OAAM/4F,EAAEqW,EAAIi+E,GAAMt0F,EAAEqW,IACeuoF,EAAK,GAAGlrE,QAAQ,gBAC3D1zB,EAAE43B,GAAK5e,EAAEoX,MAAMiuE,IAAW,IAAI,GAC3Br+F,EAAE43B,EAAElE,QAAQ,MAAO,GAAI8lE,EAAOn/F,KAAK,CAACssE,GAAkB3mE,EAAE43B,GAAI53B,EAAE43B,SAC3D,GAA4CgnE,EAAK,GAAGlrE,QAAQ,eAAgB,EAAI,CAEtFgrE,EAAOr/B,GAAYu/B,EAAK,IACxB,IAAIc,EAAO9/B,GAAYgB,GAASg+B,EAAK,KACjCn8C,EAAKs2C,OAAM2G,EAAOpL,GAAMoL,IAC5BrG,EAAQ9xF,SAASm3F,EAAKhpF,GAAI,KAAO,CAACgpF,EAAMgB,EAAM5rG,EAAIgT,EACnD,OACU83F,EAAK5lF,EAAEoX,MAAM,gBAEpBipE,GADHqF,EAAOr/B,GAAYu/B,EAAK,KACRlpF,MAAK1V,EAAEqW,EAAIg+E,GAAmBgF,EAAQqF,EAAKhpF,IAAI,GAAI2jF,EAAQqF,EAAKhpF,IAAI,GAAe5hB,EAAIgT,IAGxG,IAAI64F,EAAOn5B,GAAY1yE,EAAIgT,GAC3B,IAAItR,EAAI,EAAGA,EAAIgkG,EAAOplG,SAAUoB,EAC5BmqG,EAAK74F,GAAK0yF,EAAOhkG,GAAG,GAAG2N,EAAE2D,GAAK64F,EAAK74F,GAAK0yF,EAAOhkG,GAAG,GAAG+N,EAAEuD,GACtD64F,EAAK54F,GAAKyyF,EAAOhkG,GAAG,GAAG2N,EAAE4D,GAAK44F,EAAK54F,GAAKyyF,EAAOhkG,GAAG,GAAG+N,EAAEwD,IACzD/G,EAAE43B,EAAI4hE,EAAOhkG,GAAG,GACpB,CAEA,GAAY,MAAT1B,EAAIsf,QAAqB/e,IAAR2L,EAAE8B,EACrB,GAAG9B,EAAEqW,GAAKrW,EAAE43B,EACX53B,EAAE8B,EAAI,EAAG9B,EAAEoT,EAAI,QACT,KAAI60D,EAAY,SAClBjoE,EAAEoT,EAAI,GAAG,MAEVpT,EAAEoT,EAAItf,EAAIsf,GAAK,IAIpB,OAHG6mE,EAAM92E,EAAE4D,EAAI+3F,IAAM7kB,EAAM92E,EAAE4D,EAAI+3F,GAC9B7kB,EAAM12E,EAAEwD,EAAI+3F,IAAM7kB,EAAM12E,EAAEwD,EAAI+3F,GAE1B9+F,EAAEoT,GACR,IAAK,IACJ,GAAU,IAAPpT,EAAE8B,GAAkB,MAAP9B,EAAE8B,EAAW,CAC5B,IAAImmE,EAAY,SAChBjoE,EAAEoT,EAAI,GACP,MAAOpT,EAAE8B,EAAIkjC,WAAWhlC,EAAE8B,GAC1B,MACD,IAAK,IACJ,QAAiB,IAAP9B,EAAE8B,EAAkB,CAC7B,IAAImmE,EAAY,SAChBjoE,EAAEoT,EAAI,GACP,MACCqrF,EAAOlE,GAAKhzF,SAASvH,EAAE8B,EAAG,KAC1B9B,EAAE8B,EAAI28F,EAAKrrF,EACXpT,EAAE8G,EAAI23F,EAAK33F,EACR27C,EAAK8kC,WAAUvnF,EAAER,EAAIi/F,EAAKj/F,GAE9B,MACD,IAAK,MACJQ,EAAEoT,EAAI,IACNpT,EAAE8B,EAAU,MAAL9B,EAAE8B,EAAW8+D,GAAS5gE,EAAE8B,GAAK,GACjC2gD,EAAK8kC,WAAUvnF,EAAER,EAAIygE,GAAWjgE,EAAE8B,IACrC,MACD,IAAK,YACJ88F,EAAO5lF,EAAEoX,MAAMguE,GACfp+F,EAAEoT,EAAI,IACK,MAARwrF,IAAiBH,EAAOpX,GAASuX,EAAK,MACxC5+F,EAAE8B,EAAI28F,EAAKrrF,EACRqvC,EAAK8kC,WAAUvnF,EAAER,EAAIi/F,EAAKj/F,IACvBQ,EAAE8B,EAAI,GACb,MACD,IAAK,IAAK9B,EAAE8B,EAAIu+D,GAAargE,EAAE8B,GAAI,MACnC,IAAK,IACD2gD,EAAKylB,UAAWloE,EAAE8B,EAAIg7D,GAAU98D,EAAE8B,EAAG,IACjC9B,EAAE8B,EAAIq6D,GAAQW,GAAU98D,EAAE8B,EAAG,IAAK9B,EAAEoT,EAAI,KAC/C,MAED,IAAK,IACAqvC,IAA0B,IAAlBA,EAAK2/B,WAAoBpiF,EAAE6Z,EAAI7Z,EAAE8B,GAC7C9B,EAAE8B,EAAIuoE,GAAMrqE,EAAE8B,GAgBhB,GAbAi5F,EAAQC,EAAS,EACjBrmB,EAAK,KACFoqB,QAAuB1qG,IAAVP,EAAIqP,GAEV,OADTwxE,EAAK6a,EAAO8B,OAAOx9F,EAAIqP,MAEJ,MAAfwxE,EAAG7N,WAAkBi0B,EAAQpmB,EAAG7N,UAChCrkB,EAAKg1B,YACS,MAAb9C,EAAGirB,SAAgB5E,EAASrmB,EAAGirB,SAIrC9E,GAAY96F,EAAG+6F,EAAOC,EAAQv4C,EAAM8sC,EAAQC,GACzC/sC,EAAKylB,WAAa62B,GAAoB,KAAP/+F,EAAEoT,GAAYk0C,GAAYxF,GAAUi5C,MAAW/6F,EAAEoT,EAAI,IAAKpT,EAAE8B,EAAIy6D,GAAQv8D,EAAE8B,IACzGhO,EAAI+rG,IAAMp9C,EAAKq9C,OAAQ,CACzB,IAAID,GAAMp9C,EAAKq9C,OAAOC,MAAM,KAAKjsG,EAAI+rG,GAAG,GACrCA,GAAiB,UAAXA,EAAGp9F,OAAkBzC,EAAE6hB,GAAI,EACrC,CACA,GAAG2lD,EAAO,CACT,IAAIw4B,EAAKx5B,GAAY1yE,EAAIgT,GACrB3D,EAAE68F,EAAGl5F,KAAI3D,EAAE68F,EAAGl5F,GAAK,IACvB3D,EAAE68F,EAAGl5F,GAAGk5F,EAAGj5F,GAAK/G,CACjB,MAAOmD,EAAErP,EAAIgT,GAAK9G,CAvHC,CAlBwB,CAxB7B,CAmKhB,CACGnG,EAAKzF,OAAS,IAAG+O,EAAE,SAAWtJ,EAClC,CAAG,CAzLmC,GAmatC,IAAIomG,GAAiBv2B,GA4IrB,SAASw2B,GAAmBpiG,GAG3B,MAAO,CAFIkrE,GAAoBlrE,GACnB6rE,GAAW7rE,GACF,IACtB,CAgIA,IAAIqiG,GAAqBz2B,GAkFzB,IAAI02B,GAAgB,CAAC,OAAO,QAAQ,MAAM,SAAS,SAAS,UAqnB5D,SAASC,GAAYviG,EAAkBlE,EAAiB6oD,EAAM8pB,EAAM+Y,EAAIgb,GACvE,IAAIhqF,EAAqBgqF,GAAU,CAAC,QAAQ,SAC5C,IAAIxiG,EAAM,OAAOwiG,EAGjB,IAAI1+E,EAAI,EAAG81B,EAAI,EAAGrsC,EAAM,IACpB83E,EAAW,CAAChgF,EAAG,CAAC2D,EAAE,IAASC,EAAE,KAAUxD,EAAG,CAACuD,EAAE,EAAGC,EAAE,IAgBtD,OAbCjJ,EAAKsyB,MAAM,yCAAyC,IAAI+D,QAAQ,SAASosE,GACzE,IAAIlyD,EA/BN,SAAqBvwC,GACpB,IAEIuY,EAFAhL,EAA+B,GAC/B5Q,EAAMqD,EAAKsyB,MAAM,kBAIpBtyB,EAAKsyB,MAAM,sCAAsC,IAAI+D,QAAQ,SAAS25D,GACtE,IAAIzlF,EAAIylF,EAAG19D,MAAM,+CACb/nB,IACJgD,GAAKhD,EAAE,IAAM5N,GAAO4N,EAAE,GAAKA,EAAE,GAC9B,GAGA,IAAIm4F,EAAK5gC,IAAa9hE,EAAKsyB,MAAM,6CAA+C,CAAC,GAAG,YAAY,IAIhG,OAFCtyB,EAAKsyB,MAAM,wBAAwB,IAAI+D,QAAQ,SAASyD,GAAKvhB,EAAIuhB,EAAEtH,QAAQ,SAAS,GAAK,GAEnF,CAACjlB,EAAKm1F,EAAInqF,EAClB,CAacoqF,CAAYF,GACxBpd,EAAShgF,EAAE2D,EAAIq8E,EAAShgF,EAAE4D,EAAI,EAC9Bo8E,EAAS5/E,EAAEwD,EAAI6a,EACfvW,EAAM86D,GAAWvkD,GACjBysB,EAAM,GAAGla,QAAQ,SAASr0B,EAAEtK,GAC3B8gB,EAAGjL,EAAM66D,GAAW1wE,IAAM,CAAC4d,EAAE,IAAKtR,EAAEhC,EAAGua,EAAEg0B,EAAM,IAC/CqJ,EAAIliD,CACL,GACG2tF,EAAS5/E,EAAEuD,EAAI4wC,IAAGyrC,EAAS5/E,EAAEuD,EAAI4wC,KAClC91B,CACH,GACGA,EAAI,IAAGtL,EAAG,QAAUowD,GAAayc,IAC7B7sE,CACR,CAwGA,IAAIoqF,GAAa,CAChB,CAAC,qBAA+B,EAAO,QACvC,CAAC,wBAA+B,EAAO,QACvC,CAAC,cAA+B,EAAO,QACvC,CAAC,sBAA+B,EAAO,QACvC,CAAC,WAA+B,IAChC,CAAC,YAA+B,EAAO,QACvC,CAAC,sBAA+B,EAAQ,OACxC,CAAC,iBAA+B,EAAO,QACvC,CAAC,sBAA+B,EAAO,QACvC,CAAC,qBAA+B,EAAO,QACvC,CAAC,gBAA+B,EAAO,QACvC,CAAC,yBAA+B,EAAO,QACvC,CAAC,0BAA+B,EAAO,QACvC,CAAC,8BAA+B,EAAO,QACvC,CAAC,qBAA+B,EAAO,QACvC,CAAC,cAA+B,OAChC,CAAC,wBAA+B,EAAO,QACvC,CAAC,cAAe,YAIbC,GAAY,CACf,CAAC,YAA+B,EAAQ,OACxC,CAAC,0BAA+B,EAAO,QACvC,CAAC,aAA+B,EAAQ,OACxC,CAAC,aAA+B,EAAO,QACvC,CAAC,wBAA+B,EAAO,QACvC,CAAC,iBAA+B,EAAO,QACvC,CAAC,sBAA+B,EAAO,QACvC,CAAC,WAA+B,IAAQ,OACxC,CAAC,aAA+B,YAK7BC,GAAW,GAKXC,GAAY,CACf,CAAC,gBAAiB,QAClB,CAAC,WAAY,QACb,CAAC,aAAc,QACf,CAAC,iBAAkB,QACnB,CAAC,iBAAkB,SACnB,CAAC,gBAAiB,QAClB,CAAC,UAAW,SACZ,CAAC,eAAgB,OACjB,CAAC,eAAgB,SACjB,CAAC,UAAW,OAyBb,SAASC,GAAoB7qG,EAAQ8qG,GACpC,IAAI,IAAItrG,EAAI,EAAGA,GAAKQ,EAAO7B,SAAUqB,EACpC,IADyC,IAAIokB,EAAI5jB,EAAOR,GAChDD,EAAE,EAAGA,GAAKurG,EAAS3sG,SAAUoB,EAAG,CAAE,IAAI6kB,EAAI0mF,EAASvrG,GAC1D,GAAc,MAAXqkB,EAAEQ,EAAE,IAAaR,EAAEQ,EAAE,IAAMA,EAAE,QAC3B,OAAOA,EAAE,IACd,IAAK,OAA6B,iBAAXR,EAAEQ,EAAE,MAAiBR,EAAEQ,EAAE,IAAMgmD,GAAaxmD,EAAEQ,EAAE,MAAM,MAC7E,IAAK,MAA4B,iBAAXR,EAAEQ,EAAE,MAAiBR,EAAEQ,EAAE,IAAM9S,SAASsS,EAAEQ,EAAE,IAAK,KAExE,CAEF,CACA,SAAS2mF,GAAc/qG,EAAQ8qG,GAC9B,IAAI,IAAIvrG,EAAI,EAAGA,GAAKurG,EAAS3sG,SAAUoB,EAAG,CAAE,IAAI6kB,EAAI0mF,EAASvrG,GAC5D,GAAmB,MAAhBS,EAAOokB,EAAE,IAAapkB,EAAOokB,EAAE,IAAMA,EAAE,QACrC,OAAOA,EAAE,IACb,IAAK,OAAkC,iBAAhBpkB,EAAOokB,EAAE,MAAiBpkB,EAAOokB,EAAE,IAAMgmD,GAAapqE,EAAOokB,EAAE,MAAM,MAC5F,IAAK,MAAiC,iBAAhBpkB,EAAOokB,EAAE,MAAiBpkB,EAAOokB,EAAE,IAAM9S,SAAStR,EAAOokB,EAAE,IAAK,KAExF,CACD,CAEA,SAAS4mF,GAAkB3b,GAC1B0b,GAAc1b,EAAG4b,QAASR,IAC1BM,GAAc1b,EAAG6b,OAAQN,IAEzBC,GAAoBxb,EAAG8b,OAAQT,IAC/BG,GAAoBxb,EAAGje,OAAQu5B,IAE/BpG,GAAS13C,SAAWud,GAAailB,EAAG4b,QAAQp+C,SAC7C,CASA,IAAIu+C,GAAwB,UAAW3zD,MAAM,IA8B7C,IAAI4zD,GAAY,gBA6ShB,SAASC,GAAoBzjG,EAAM1J,GAClC,IAAI2+C,EAAI,CAAA,EAIR,OAHAj1C,EAAKwtD,WAAW,GAChBvY,EAAEyuD,OAAS1jG,EAAKwtD,WAAW,GAC3BxtD,EAAKC,GAAK3J,EAAS,EACZ2+C,CACR,CA4OA,SAAS0uD,GAAS3jG,EAAMlE,EAAiB6oD,GACxC,MAAoB,SAAjB7oD,EAAK/E,OAAM,GApNf,SAAsBiJ,EAAM2kD,GAC3B,IAAI6iC,EAAK,CAAE1W,WAAW,CAAA,EAAIsyB,QAAQ,CAAA,EAAIE,OAAO,GAAI/5B,OAAO,GAAI85B,OAAO,CAAA,EAAIO,MAAO,IAC1E3yC,EAA0B,GAC1Bg3B,GAAO,EAEPtjC,IAAMA,EAAO,CAAA,GACjBA,EAAKmjB,KAAO,GAEZ,IAAI+7B,EAAQ,GACR1J,EAAY,CAAC,IAkGjB,OAjGAA,EAAS7wB,WAAa,GACtB6wB,EAASC,IAAM,GAEfjzB,GAAe,IAAU,CAAEnlE,EAAE,gBAAiBuW,EAAEkrF,IAEhD38B,GAAa9mE,EAAM,SAAmB0oB,EAAKkxB,EAAGstB,GAC7C,OAAOA,GACN,KAAK,IACJizB,EAAS7wB,WAAW/sE,KAAKmsB,EAAI5sB,MAC7B0rF,EAAGje,OAAOhtE,KAAKmsB,GAAM,MAEtB,SACC8+D,EAAG4b,QAAU16E,EAAK,MAEnB,KAAK,GACY,MAAbA,EAAIo7E,QAAen/C,EAAK01C,IAAM3xE,EAAIo7E,OACrCp7E,EAAIq7E,IAAMrJ,GAAkBhyE,EAAIs7E,IAAK,EAAM,KAAM7J,EAAUx1C,UACpDA,EAAK01C,WACL3xE,EAAIs7E,IACXH,EAAMtnG,KAAKmsB,GACX,MACD,KAAK,KAeL,SAGA,KAAK,KACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,SAIA,UACA,KAAK,KACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,KACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,IACL,KAAK,IACL,KAAK,KACL,UACA,KAAK,IACL,UACA,KAAK,IACL,UACA,KAAK,KACL,KAAK,KACL,KAAK,IACL,SACA,KAAK,KACL,KAAK,IACL,KAAK,KAYL,KAAK,GAA8B,MA5DnC,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACAyxE,EAAS,GAAG7jG,OACX6jG,EAAS59F,KAAK,CAAC2qE,EAAIx+C,IADAyxE,EAAS,GAAK,CAACjzB,EAAIx+C,GAE3CyxE,EAASA,EAAS7jG,OAAS,GAAG8jG,IAAM,GACpC,MACD,KAAK,IACmB,IAApBD,EAAS7jG,SAAgB6jG,EAAS,GAAK,GAAIA,EAAS,GAAGC,IAAM,IAChED,EAASA,EAAS7jG,OAAS,GAAG8jG,IAAMD,EAASA,EAAS7jG,OAAS,GAAG8jG,IAAIhqE,OAAO1H,GAC7EyxE,EAASC,IAAMD,EAASC,IAAIhqE,OAAO1H,GACnC,MAuCD,KAAK,GAIL,KAAK,GACJuoC,EAAM10D,KAAK2qE,GAAK+gB,GAAO,EAAM,MAH9B,KAAK,GAIL,KAAK,GACJh3B,EAAM7V,MAAO6sC,GAAO,EAAO,MAI5B,QACC,GAAGruC,EAAEzB,QACA,IAAI8vC,GAAStjC,EAAK+e,KAAgC,IAAzBzS,EAAMA,EAAM36D,OAAO,IAA0D,IAAzB26D,EAAMA,EAAM36D,OAAO,GAAiC,MAAM,IAAI2B,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAE9L,EAAGgvD,GAEHw+C,GAAkB3b,GAGlBA,EAAGqc,MAAQA,EAEVrc,EAAY2S,SAAWA,EACjB3S,CACR,CAwGoCyc,CAAcjkG,EAAe2kD,GA/hBjE,SAAsB3kD,EAAM2kD,GAC3B,IAAI3kD,EAAM,UAAU/H,MAAM,uBAC1B,IAAIuvF,EAAY,CAAE1W,WAAW,CAAA,EAAIsyB,QAAQ,CAAA,EAAIE,OAAO,GAAI/5B,OAAO,GAAI85B,OAAO,CAAA,EAAIQ,MAAM,GAAID,MAAO,IAC3F3b,GAAO,EAAO2b,EAAQ,QACtBM,EAAQ,CAAA,EAAIC,EAAU,EAmJ1B,GAlJAnkG,EAAKwyB,QAAQ4uC,GAAU,SAAgBxoE,EAAGqL,GACzC,IAAIuE,EAAY+4D,GAAY3oE,GAC5B,OAAO+oE,GAASn5D,EAAE,KACjB,IAAK,QAOL,IAAK,cAIL,IAAK,iBAAkB,IAAK,iBAG5B,IAAK,eAEL,IAAK,iBAeL,IAAK,gBAGL,IAAK,sBAEL,IAAK,wBAGL,IAAK,aAAc,IAAK,cAAe,IAAK,eAG5C,IAAK,kBAGL,IAAK,UAAW,IAAK,WAAY,IAAK,YAWtC,IAAK,WAGL,IAAK,kBAAmB,IAAK,oBAE7B,IAAK,iBAGL,IAAK,sBAAuB,IAAK,wBAAyB,IAAK,uBAE/D,IAAK,qBAGL,IAAK,kBAgBL,IAAK,iBAKL,IAAK,YAGL,IAAK,WAGL,IAAK,wBAAyB,IAAK,yBAA0B,IAAK,uBAElE,IAAK,sBAAuB,IAAK,wBAGjC,IAAK,gBAAiB,IAAK,iBAAkB,IAAK,eAElD,IAAK,cAGL,IAAK,cAAe,IAAK,gBAGzB,IAAK,iBAAkB,IAAK,kBAAmB,IAAK,mBAEpD,IAAK,gBAGL,IAAK,iBAAkB,IAAK,mBAG5B,IAAK,kBAAmB,IAAK,oBAG7B,IAAK,sBAAuB,IAAK,qBAAsB,IAAK,uBAE5D,IAAK,oBAGL,IAAK,UAAW,IAAK,WAAY,IAAK,YAAa,IAAK,YAMxD,IAAK,UAML,IAAK,eAAgB,MAtIrB,IAAK,YACD5P,EAAE05B,MAAMkxE,MAAYI,EAAQ,QAAUhrG,EAAE05B,MAAM,WAAW,IAC5Dk1D,EAAGoc,MAAQp7F,EAAEo7F,GACb,MAID,IAAK,sBAAuBp7F,EAAE,GAAIg/E,EAAG1W,WAAatoE,EAAG,MASrD,IAAK,cACL,IAAK,gBACJo6F,GAAWvsE,QAAQ,SAASta,GAC3B,GAAc,MAAXvT,EAAEuT,EAAE,IACP,OAAOA,EAAE,IACR,IAAK,OAAQyrE,EAAG4b,QAAQrnF,EAAE,IAAMwmD,GAAa/5D,EAAEuT,EAAE,KAAM,MACvD,IAAK,MAAOyrE,EAAG4b,QAAQrnF,EAAE,IAAMtS,SAASjB,EAAEuT,EAAE,IAAK,IAAK,MACtD,QAASyrE,EAAG4b,QAAQrnF,EAAE,IAAMvT,EAAEuT,EAAE,IAElC,GACGvT,EAAE03F,WAAU1Y,EAAG4b,QAAQjD,SAAWr9B,GAASt6D,EAAE03F,WAChD,MAWD,IAAK,gBAAiB,IAAK,yBAA0B13F,EAAE,GAAIg/E,EAAG8b,OAAO/mG,KAAKiM,GAAI,MAM9E,IAAK,SACJ,OAAOA,EAAEyoD,OACR,IAAK,SAAUzoD,EAAE47F,OAAS,EAAG,MAC7B,IAAK,aAAc57F,EAAE47F,OAAS,EAAG,MACjC,QAAS57F,EAAE47F,OAAS,SAEd57F,EAAEyoD,MACTzoD,EAAE1M,KAAOgmE,GAAYgB,GAASt6D,EAAE1M,cACzB0M,EAAE,GAAIg/E,EAAGje,OAAOhtE,KAAKiM,GAAI,MAejC,IAAK,iBAAkB,IAAK,gBAyD5B,IAAK,OAKL,IAAK,oBACL,IAAK,qBAAsBy/E,GAAK,EAAM,MA9DtC,IAAK,kBAyDL,IAAK,SAML,IAAK,sBAAuBA,GAAK,EAAO,MA7DxC,IAAK,gBACJic,EAAQ,CAAA,GACF3rB,KAAOzV,GAASt6D,EAAE1M,MACrB0M,EAAEotF,UAASsO,EAAMG,QAAU77F,EAAEotF,SAC7BptF,EAAE87F,eAAcJ,EAAMJ,OAASt7F,EAAE87F,cACjC/hC,GAAa/5D,EAAE84E,QAAQ,OAAM4iB,EAAME,QAAS,GAC/CD,EAAUlgG,EAAMrL,EAAEtC,OACjB,MACF,IAAK,iBACJ4tG,EAAMH,IAAMjiC,GAAYgB,GAAS9iE,EAAKjJ,MAAMotG,EAASlgG,KACrDujF,EAAGqc,MAAMtnG,KAAK2nG,GACb,MAIF,IAAK,UACL,IAAK,mBAAoB17F,EAAE,GAAIg/E,EAAG6b,OAAS76F,EAAG,MAkD9C,QAAS,IAAIy/E,GAAQtjC,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM,gBAAkBuQ,EAAE,GAAK,gBAEzE,OAAO5P,CACR,IACoC,IAAjCqrE,GAAWruC,QAAQ4xD,EAAGoc,OAAe,MAAM,IAAI3rG,MAAM,sBAAwBuvF,EAAGoc,OAInF,OAFAT,GAAkB3b,GAEXA,CACR,CAoYQ+c,CAAcvkG,EAAe2kD,EACrC,CAEA,SAAS6/C,GAASxkG,EAAMlE,EAAiBmI,EAAgB0gD,EAAM8pB,EAAM+Y,EAAIiK,EAAQC,GAChF,MAAoB,SAAjB51F,EAAK/E,OAAM,GAx1Cf,SAAsBiJ,EAAM+yD,EAAO9uD,EAAKwqE,EAAM+Y,EAAkBiK,EAAQC,GACvE,IAAI1xF,EAAM,OAAOA,EACjB,IAAI2kD,EAAOoO,GAAS,CAAA,EAChB0b,IAAMA,EAAO,CAAC,MAAM,CAAA,IAExB,IAEI6K,EAKAt6E,EAAKkD,EAAG20E,EAAIj9B,EAAG91B,EAAGosC,EAAMywC,EAAMn4C,EAAImf,EAPlCtiE,EAAmBs/C,EAAK+kB,MAAQ,GAAK,CAAA,EAGrC2b,EAAW,CAAChgF,EAAG,CAAC2D,EAAE,IAASC,EAAE,KAAUxD,EAAG,CAACuD,EAAE,EAAGC,EAAE,IAGlDg/E,GAAO,EAAO5rB,GAAM,EAEpBkjC,EAA0B,GAC9B56C,EAAKmjB,KAAO,GACZnjB,EAAK,QAAU,EAEf,IAAI8/C,EAAK,EAAGC,GAAK,EAEbhJ,EAAoC,GACpCH,EAAU,CAAA,EACVpB,EAAWx1C,EAAKw1C,UAAmB3S,EAAe2S,UAAa,CAAC,IAIpE,GAHAA,EAASoB,QAAUA,EACnBpB,EAASuB,OAASA,EAClBvB,EAAS7wB,WAAake,EAAGle,YAAcke,EAAGje,OAAOr7C,IAAI,SAASt1B,GAAK,OAAOA,EAAEkD,IAAM,IAC9E6oD,EAAKw1C,WACRx1C,EAAKw1C,SAAWA,EACb3S,EAAGqc,OAAO,IAAI,IAAInsG,EAAI,EAAGA,EAAI8vF,EAAGqc,MAAMvtG,SAAUoB,EAAGyiG,EAAS,GAAGziG,EAAE,GAAK8vF,EAAGqc,MAAMnsG,GAGnF,IAKIqqG,EALAvhB,EAA6B,GAAID,EAA6B,GAC9Due,GAAU,EAyPd,GAvPA33B,GAAe,IAAU,CAAEnlE,EAAE,eAAgBuW,EAAE6pF,IAI/Ct7B,GAAa9mE,EAAM,SAAkB0oB,EAAKi8E,EAAIz9B,GAC7C,IAAG7K,EACH,OAAO6K,GACN,SACCoS,EAAM5wD,EAAK,MACZ,KAAK,EACJ1pB,EAAM0pB,EACHi8B,EAAKy2B,WAAaz2B,EAAKy2B,WAAap8E,EAAIgK,IAAGqzD,GAAI,GAClD7T,EAAK4f,GAAWxuB,EAAI56C,EAAIgK,GACxB27C,EAAK,QAAU3lD,EAAIgK,GAChB0f,EAAI44D,QAAU54D,EAAI84D,KAAoB,MAAb94D,EAAIqxD,SAC5BrxD,EAAI84D,MAAK94D,EAAI+4D,IAAMC,GAAMh5D,EAAI84D,MAChCjB,EAAQ73D,EAAI1f,GAAK0f,GAElB,MAED,OACA,KAAK,EACL,KAAK,EACL,KAAK,EACL,OACA,KAAK,EACL,OACA,KAAK,EACL,QACA,KAAK,GACL,KAAK,GACL,KAAK,GACL,QACA,KAAK,GACL,QACA,KAAK,GACL,QAEC,OADAxmB,EAAK,CAACoT,EAAEoT,EAAI,IACLA,EAAI,IACV,IAAK,IAAKxmB,EAAE8B,EAAI0kB,EAAI,GAAI,MACxB,IAAK,IAAKi4E,EAAOlE,GAAK/zE,EAAI,IAAKxmB,EAAE8B,EAAI28F,EAAKrrF,EAAGpT,EAAE8G,EAAI23F,EAAK33F,EAAG,MAC3D,IAAK,IAAK9G,EAAE8B,IAAI0kB,EAAI,GAAmB,MACvC,IAAK,IAAKxmB,EAAE8B,EAAI0kB,EAAI,IAAyB,IAAlBi8B,EAAK2/B,WAAoBpiF,EAAE6Z,EAAImtD,GAAKhnE,EAAE8B,IAAI,MACrE,IAAK,MAAO9B,EAAEoT,EAAI,IAAKpT,EAAE8B,EAAI0kB,EAAI,GAAI,MACrC,IAAK,KAAMxmB,EAAEoT,EAAI,IAAKpT,EAAE8B,EAAI0kB,EAAI,GAAGpT,EAMpC,IAJIuhE,EAAK6a,EAAO8B,OAAO9qE,EAAI,GAAGuiD,aAAa+xB,GAAY96F,EAAE20E,EAAG7N,SAAS,KAAKrkB,EAAM8sC,EAAQC,GACxF5tE,GAAgB,GAAZ4E,EAAI,GAAGzf,EAAU6a,EAAI,EAAI4E,EAAI,GAAGzf,EACjC07C,EAAK+kB,OAAarkE,EAAEu0C,KAAIv0C,EAAEu0C,GAAK,IAAIv0C,EAAEu0C,GAAG91B,GAAK5hB,GAC3CmD,EAAEgjE,GAAWvkD,GAAK0kC,GAAMtmD,EAC1ByiD,EAAKg9C,YAAa,CAEpB,IADA+C,GAAK,EACDD,EAAK,EAAGA,EAAK/I,EAAOplG,SAAUmuG,EAAI,CACrC,IAAIG,EAAMlJ,EAAO+I,GACdzlG,EAAIgK,GAAK47F,EAAI,GAAGv/F,EAAE2D,GAAKhK,EAAIgK,GAAK47F,EAAI,GAAGn/F,EAAEuD,GACxC8a,GAAK8gF,EAAI,GAAGv/F,EAAE4D,GAAK6a,GAAK8gF,EAAI,GAAGn/F,EAAEwD,IACnC/G,EAAE43B,EAAI8uC,GAAag8B,EAAI,IAAKF,GAAK,EAEpC,EACIA,GAAMh8E,EAAIpyB,OAAS,IAAG4L,EAAEqW,EAAImQ,EAAI,GACrC,CAMA,GAJG28D,EAAShgF,EAAE2D,EAAIhK,EAAIgK,IAAGq8E,EAAShgF,EAAE2D,EAAIhK,EAAIgK,GACzCq8E,EAAShgF,EAAE4D,EAAI6a,IAAGuhE,EAAShgF,EAAE4D,EAAI6a,GACjCuhE,EAAS5/E,EAAEuD,EAAIhK,EAAIgK,IAAGq8E,EAAS5/E,EAAEuD,EAAIhK,EAAIgK,GACzCq8E,EAAS5/E,EAAEwD,EAAI6a,IAAGuhE,EAAS5/E,EAAEwD,EAAI6a,GACjC6gC,EAAKylB,WAAayM,GAAa,KAAP30E,EAAEoT,GAAYk0C,GAAYxF,GAAU6yB,EAAG7N,WAAY,CAC7E,IAAI67B,EAAKngD,GAAoBxiD,EAAE8B,GAAO6gG,IAAM3iG,EAAEoT,EAAI,IAAKpT,EAAE8B,EAAI,IAAIs+B,KAAKuiE,EAAGr8F,EAAGq8F,EAAG9iG,EAAE,EAAE8iG,EAAG3pF,EAAE2pF,EAAGlpF,EAAEkpF,EAAG5xE,EAAE4xE,EAAG1uD,EAAE0uD,EAAGjnF,GAC3G,CACGmkF,IACY,UAAXA,EAAGp9F,OAAkBzC,EAAE6hB,GAAI,GAC9Bg+E,OAAK,GAGN,MAED,KAAK,EACL,QACC,IAAIp9C,EAAKwlB,YAAc8d,EAAM,MAC7B/lF,EAAK,CAACoT,EAAE,IAAItR,OAAE,GACd8f,GAAgB,GAAZ4E,EAAI,GAAGzf,EAAU6a,EAAI,EAAI4E,EAAI,GAAGzf,EACjC07C,EAAK+kB,OAAarkE,EAAEu0C,KAAIv0C,EAAEu0C,GAAK,IAAIv0C,EAAEu0C,GAAG91B,GAAK5hB,GAC3CmD,EAAEgjE,GAAWvkD,GAAK0kC,GAAMtmD,EAC1BmjF,EAAShgF,EAAE2D,EAAIhK,EAAIgK,IAAGq8E,EAAShgF,EAAE2D,EAAIhK,EAAIgK,GACzCq8E,EAAShgF,EAAE4D,EAAI6a,IAAGuhE,EAAShgF,EAAE4D,EAAI6a,GACjCuhE,EAAS5/E,EAAEuD,EAAIhK,EAAIgK,IAAGq8E,EAAS5/E,EAAEuD,EAAIhK,EAAIgK,GACzCq8E,EAAS5/E,EAAEwD,EAAI6a,IAAGuhE,EAAS5/E,EAAEwD,EAAI6a,GACjCi+E,IACY,UAAXA,EAAGp9F,OAAkBzC,EAAE6hB,GAAI,GAC9Bg+E,OAAK,GAGN,MAED,SACCxC,EAAOhjG,KAAKmsB,GAAM,MAEnB,KAAK,GACJq5E,IAAOp9C,EAAKq9C,QAAQ,CAAA,GAAIC,MAAM,IAAIv5E,EAAI,GACrC,MAEF,KAAK,IACJ,IAAIgmD,EAAMD,EAAK,OAAO/lD,EAAIo8E,OAQ1B,IAPGp2B,GACFhmD,EAAIkmD,OAASF,EAAIE,OACdlmD,EAAIq9C,MAAKr9C,EAAIkmD,QAAU,IAAIlmD,EAAIq9C,KAClCr9C,EAAIi3E,IAAMjxB,GACY,IAAbhmD,EAAIo8E,QACbp8E,EAAIkmD,OAAS,IAAMlmD,EAAIq9C,KAEpBnsB,EAAElxB,EAAIq8E,IAAI1/F,EAAE2D,EAAE4wC,GAAGlxB,EAAIq8E,IAAIt/F,EAAEuD,IAAI4wC,EAAG,IAAI91B,EAAE4E,EAAIq8E,IAAI1/F,EAAE4D,EAAE6a,GAAG4E,EAAIq8E,IAAIt/F,EAAEwD,IAAI6a,EACrE6gC,EAAK+kB,OACHrkE,EAAEu0C,KAAIv0C,EAAEu0C,GAAK,IACbv0C,EAAEu0C,GAAG91B,KAAIze,EAAEu0C,GAAG91B,GAAK,CAACxO,EAAE,IAAItR,OAAEzN,IAChC8O,EAAEu0C,GAAG91B,GAAG7jB,EAAIyoB,IAEZwnC,EAAO+X,GAAY,CAACh/D,EAAE6a,EAAE9a,EAAE4wC,IACtBv0C,EAAE6qD,KAAO7qD,EAAE6qD,GAAQ,CAAC56C,EAAE,IAAItR,OAAEzN,IAChC8O,EAAE6qD,GAAMjwD,EAAIyoB,GAGd,MAED,KAAK,IACJ,IAAIi8B,EAAKg9C,YAAa,MACtBjG,EAAOn/F,KAAKmsB,IACZi/C,EAAShjB,EAAK+kB,MAAQrkE,EAAEu0C,GAAG91B,GAAKze,EAAEgjE,GAAWvkD,GAAK0kC,IAC7CjwC,EAAImiF,GAAkBhyE,EAAI,GAAI28D,EAAU,CAACr8E,EAAEhK,EAAIgK,EAAGC,EAAE6a,GAAIq2E,EAAUx1C,GACvEgjB,EAAK7tC,EAAI8uC,GAAalgD,EAAI,IAC1B,MACD,KAAK,IACJ,IAAIi8B,EAAKg9C,YAAa,MACtBpG,EAAQtzB,GAAYv/C,EAAI,GAAGrjB,IAAMqjB,EAAI,IACrCi/C,EAAQhjB,EAAK+kB,MAAQrkE,EAAEu0C,GAAG91B,GAAKze,EAAEgjE,GAAWvkD,GAAK0kC,IAC5CjwC,EAAImiF,GAAkBhyE,EAAI,GAAI28D,EAAU,CAACr8E,EAAEhK,EAAIgK,EAAGC,EAAE6a,GAAIq2E,EAAUx1C,GACvE,MAGD,KAAK,GACJ,IAAIA,EAAKg1B,WAAY,MACrB,KAAMjxD,EAAIjjB,GAAKijB,EAAIrjB,GAClBm7E,EAAQ93D,EAAIjjB,KAAO,CAAEitB,MAAOhK,EAAI3M,EAAE,IAAKulE,UAAuB,EAAZ54D,EAAImmB,OAAekrC,MAAOrxD,EAAIqxD,OAC5E+kB,IAAWA,GAAU,EAAMnP,GAAcjnE,EAAI3M,EAAE,MACnDwlE,GAAYf,EAAQ93D,EAAIjjB,EAAE,IAE3B,MAED,SACCJ,EAAE,eAAiB,CAAEi0E,IAAI1Q,GAAalgD,IACtC,MAED,KAAK,IACJrjB,EAAE,YAAcqjB,EAChB,MAED,KAAK,IACA8+D,EAAGje,OAAOtlE,KAAMujF,EAAGje,OAAOtlE,GAAO,IAClCykB,EAAI5sB,OAAM0rF,EAAGje,OAAOtlE,GAAKk8F,SAAWz3E,EAAI5sB,OACxC4sB,EAAIs8E,OAASt8E,EAAI4b,QAAMj/B,EAAE,YAAc,CAAE2/F,MAAOt8E,EAAIs8E,MAAO1gE,KAAM5b,EAAI4b,OACxE,MAED,KAAK,IACAkjD,EAAG+W,QAAO/W,EAAG+W,MAAQ,CAAC,CAAA,IACtB/W,EAAG+W,MAAM,KAAI/W,EAAG+W,MAAM,GAAK,CAAA,GAC5B71E,EAAIk2E,MAAKpX,EAAG+W,MAAM,GAAGK,KAAM,GAC9B,MAED,SAGA,QACA,KAAK,KAGL,KAAK,IAEL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,UACA,KAAK,KACL,SACA,KAAK,KACL,SACA,KAAK,KACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,KACL,SACA,KAAK,IACL,UACA,KAAK,IACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,IACL,UACA,KAAK,IACL,UACA,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,KACL,KAAK,IACL,KAAK,KACL,KAAK,KACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,IACL,KAAK,KACL,KAAK,IACL,KAAK,IACL,KAAK,KACL,KAAK,GACL,KAAK,KACL,UACC,MAED,QAIA,KAAK,GACY3W,GAAO,EAAM,MAH9B,KAAK,GAIL,KAAK,GACSA,GAAO,EAAO,MAE5B,QACC,GAAG0c,EAAGxsD,QACD,IAAI8vC,GAAQtjC,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAEnF,EAAGgvD,UAEIA,EAAKw1C,gBACLx1C,EAAK,SAERt/C,EAAE,UAAYggF,EAAShgF,EAAE2D,EAAI,KAAWswE,IAAQA,EAAI7zE,EAAEuD,EAAI,GAAKswE,EAAI7zE,EAAEwD,EAAI,GAAKqwE,EAAIj0E,EAAE2D,EAAI,GAAKswE,EAAIj0E,EAAE4D,EAAI,MAAK5D,EAAE,QAAUujE,GAAa0Q,GAAO+L,IAC7I1gC,EAAKy2B,WAAa/1E,EAAE,QAAS,CAC/B,IAAI46F,EAASp3B,GAAkBxjE,EAAE,SAC9Bs/C,EAAKy2B,YAAc6kB,EAAOx6F,EAAEuD,IAC9Bi3F,EAAOx6F,EAAEuD,EAAI27C,EAAKy2B,UAAY,EAC3B6kB,EAAOx6F,EAAEuD,EAAIq8E,EAAS5/E,EAAEuD,IAAGi3F,EAAOx6F,EAAEuD,EAAIq8E,EAAS5/E,EAAEuD,GACnDi3F,EAAOx6F,EAAEuD,EAAIi3F,EAAO56F,EAAE2D,IAAGi3F,EAAO56F,EAAE2D,EAAIi3F,EAAOx6F,EAAEuD,GAC/Ci3F,EAAOx6F,EAAEwD,EAAIo8E,EAAS5/E,EAAEwD,IAAGg3F,EAAOx6F,EAAEwD,EAAIo8E,EAAS5/E,EAAEwD,GACnDg3F,EAAOx6F,EAAEwD,EAAIg3F,EAAO56F,EAAE4D,IAAGg3F,EAAO56F,EAAE4D,EAAIg3F,EAAOx6F,EAAEwD,GAClD5D,EAAE,YAAcA,EAAE,QAClBA,EAAE,QAAUujE,GAAaq3B,GAE3B,CAIA,OAHGV,EAAOjpG,OAAS,IAAG+O,EAAE,WAAak6F,GAClC/e,EAAQlqF,OAAS,IAAG+O,EAAE,SAAWm7E,GACjCD,EAAQjqF,OAAS,IAAG+O,EAAE,SAAWk7E,GAC7Bl7E,CACR,CAgjCoC4/F,CAAcjlG,EAAe2kD,EAAM1gD,EAAKwqE,EAAM+Y,EAAIiK,EAAQC,GACtFoM,GAAc99F,EAAe2kD,EAAM1gD,EAAKwqE,EAAM+Y,EAAIiK,EAAQC,EAClE,CAEA,SAASwT,GAASllG,EAAMlE,EAAiBmI,EAAgB0gD,EAAM8pB,EAAM+Y,EAAIiK,EAAQC,GAChF,MAAoB,SAAjB51F,EAAK/E,OAAM,GA5vBf,SAAsBiJ,EAAM2kD,EAAM1gD,EAAgBwqE,EAAM+Y,GACvD,IAAIxnF,EAAM,OAAOA,EACbyuE,IAAMA,EAAO,CAAC,MAAM,KACxB,IAAIppE,EAAI,CAAC,QAAQ,QAAS,UAAU,KAAM,OAAO,IAE7C4iF,GAAO,EAuCX,OAtCAnhB,GAAa9mE,EAAM,SAAkB0oB,EAAKkxB,EAAGstB,GAC5C,OAAOA,GAEN,KAAK,IACJ7hE,EAAE,QAAUqjB,EAAK,MAElB,KAAK,IACA8+D,EAAGje,OAAOtlE,KAAMujF,EAAGje,OAAOtlE,GAAO,CAAA,GAClCykB,EAAI5sB,OAAM0rF,EAAGje,OAAOtlE,GAAKk8F,SAAWz3E,EAAI5sB,MAC3C,MAED,KAAK,IACL,KAAK,IACL,SACA,KAAK,IACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,KAOL,KAAK,GAEL,KAAK,GACS,MAPd,KAAK,GACJmsF,GAAO,EAAM,MACd,KAAK,GACJA,GAAO,EAAO,MAMf,QACC,GAAGruC,EAAEzB,EAAI,QACJ,GAAGyB,EAAEzB,EAAI,QACT,IAAI8vC,GAAQtjC,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAEnF,EAAGgvD,GAEA8pB,EAAK,OAAOppE,EAAE,WAAUA,EAAE,WAAaopE,EAAK,OAAOppE,EAAE,UACjDA,CACR,CA+sBoC8/F,CAAcnlG,EAAe2kD,EAAM1gD,EAAKwqE,EAAM+Y,GAhyBlF,SAAsBxnF,EAAkB2kD,EAAM1gD,EAAgBwqE,EAAM+Y,GACnE,IAAIxnF,EAAM,OAAOA,EAEbyuE,IAAMA,EAAO,CAAC,MAAM,KACxB,IACI1sE,EADAsD,EAAK,CAAC,QAAQ,QAAS,UAAU,KAAM,OAAO,IAI9C64F,EAAUl+F,EAAKsyB,MAAMqrE,IAOzB,OANGO,GAASC,GAAqBD,EAAQ,GAAI74F,EAAGmiF,EAAIvjF,IAGhDlC,EAAI/B,EAAKsyB,MAAM,2BAA0BjtB,EAAE,QAAUtD,EAAE,IAExD0sE,EAAK,OAAOppE,EAAE,WAAUA,EAAE,WAAaopE,EAAK,OAAOppE,EAAE,UACjDA,CACR,CAixBQ+/F,CAAcplG,EAAe2kD,EAAM1gD,EAAKwqE,EAAM+Y,EACtD,CAYA,SAAS6d,GAAUrlG,EAAMlE,EAAiB21F,EAAQ9sC,GACjD,MAAoB,SAAjB7oD,EAAK/E,OAAM,GAlsMf,SAAuBiJ,EAAMyxF,EAAQ9sC,GACpC,IAAI+sC,EAAS,CACbA,UAAoB,IACpB,IAAI,IAAIlpF,KAAKw7C,GAAW0tC,EAAOC,UAAUnpF,GAAKw7C,GAAUx7C,GAExDkpF,EAAO8B,OAAS,GAChB9B,EAAOI,MAAQ,GACf,IAAI7gC,EAA0B,GAC1Bg3B,GAAO,EAmDX,OAlDAnhB,GAAa9mE,EAAM,SAAoB0oB,EAAKkxB,EAAGstB,GAC9C,OAAOA,GACN,KAAK,GACJwqB,EAAOC,UAAUjpE,EAAI,IAAMA,EAAI,GAAIsiC,GAAStiC,EAAI,GAAIA,EAAI,IACxD,MACD,KAAK,GACJgpE,EAAOI,MAAMv1F,KAAKmsB,GACI,MAAnBA,EAAIyJ,MAAMsgE,OAAiBhB,GAAUA,EAAOiB,eAAiBjB,EAAOiB,cAAcC,YACpFjqE,EAAIyJ,MAAMm2D,IAAMsG,GAAS6C,EAAOiB,cAAcC,UAAUjqE,EAAIyJ,MAAMsgE,OAAOnK,IAAK5/D,EAAIyJ,MAAM28D,MAAQ,IAEjG,MACD,KAAK,KACL,KAAK,GAEL,KAAK,GAOL,QACA,KAAK,IACL,KAAK,IACL,KAAK,IAGL,KAAK,KACL,KAAK,KACL,KAAK,KACL,KAAK,IACL,KAAK,KACL,KAAK,KACJ,MAjBD,KAAK,GAC0B,KAA3B79B,EAAMA,EAAM36D,OAAS,IACvBo7F,EAAO8B,OAAOj3F,KAAKmsB,GAEpB,MAeD,KAAK,GACJu/D,GAAO,EAAM,MACd,KAAK,GACJA,GAAO,EAAO,MACf,KAAK,GACJh3B,EAAM10D,KAAK2qE,GAAK+gB,GAAO,EAAM,MAC9B,KAAK,GACJh3B,EAAM7V,MAAO6sC,GAAO,EAAO,MAE5B,QACC,GAAGruC,EAAEzB,EAAI,EAAG8Y,EAAM10D,KAAK2qE,QAClB,GAAGttB,EAAEzB,EAAI,EAAG8Y,EAAM7V,WAClB,IAAI6sC,GAAStjC,EAAK+e,KAAgC,IAAzBzS,EAAMA,EAAM36D,OAAO,GAAgC,MAAM,IAAI2B,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAEzI,GACO+7F,CACR,CAsoMoC4T,CAAetlG,EAAeyxF,EAAQ9sC,GAClEwsC,GAAenxF,EAAeyxF,EAAQ9sC,EAC9C,CAMA,SAAS4gD,GAAUvlG,EAAMlE,EAAiB6oD,GACzC,MAAoB,SAAjB7oD,EAAK/E,OAAM,GA92Of,SAAuBiJ,EAAM2kD,GAC5B,IAAIt/C,EAAa,GACb4iF,GAAO,EAoBX,OAnBAnhB,GAAa9mE,EAAM,SAAoB0oB,EAAKkxB,EAAGstB,GAC9C,OAAOA,GACN,KAAK,IACJ7hE,EAAEmgG,MAAQ98E,EAAI,GAAIrjB,EAAEogG,OAAS/8E,EAAI,GAAI,MACtC,KAAK,GACJrjB,EAAE9I,KAAKmsB,GAAM,MACd,KAAK,IACJ,OAAO,EAER,KAAK,GACJu/D,GAAO,EAAM,MACd,KAAK,GACJA,GAAO,EAAO,MAEf,QAEC,GADGruC,EAAEzB,GACD8vC,GAAQtjC,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAE9E,GACO0P,CACR,CAu1OoCqgG,CAAe1lG,EAAe2kD,GA75OlE,SAAuB3kD,EAAiB2kD,GACvC,IAAIt/C,EAAa,GAAaohD,EAAK,GACnC,IAAIzmD,EAAM,OAAOqF,EAEjB,IAAIsgG,EAAM3lG,EAAKsyB,MAAMo3D,IACrB,GAAGic,EAAK,CACPl/C,EAAKk/C,EAAI,GAAGnzE,QAAQm3D,GAAM,IAAI/5C,MAAMg6C,IACpC,IAAI,IAAIlyF,EAAI,EAAGA,GAAK+uD,EAAGnwD,SAAUoB,EAAG,CACnC,IAAIu9C,EAAIs0C,GAAS9iC,EAAG/uD,GAAGqvC,OAAQ4d,GACvB,MAAL1P,IAAW5vC,EAAEA,EAAE/O,QAAU2+C,EAC7B,CACA0wD,EAAMpkC,GAAYokC,EAAI,IAAKtgG,EAAEmgG,MAAQG,EAAI5vF,MAAO1Q,EAAEogG,OAASE,EAAIC,WAChE,CACA,OAAOvgG,CACR,CAg5OQwgG,CAAe7lG,EAAe2kD,EACtC,CAEA,SAASmhD,GAAW9lG,EAAMlE,EAAiB6oD,GAC1C,MAAoB,SAAjB7oD,EAAK/E,OAAM,GA5jKf,SAA4BiJ,EAAM2kD,GACjC,IAAI5hC,EAA4B,GAC5BgjF,EAA4B,GAC5B98F,EAAI,CAAA,EACJg/E,GAAO,EAgCX,OA/BAnhB,GAAa9mE,EAAM,SAAqB0oB,EAAKkxB,EAAGstB,GAC/C,OAAOA,GACN,KAAK,IACJ6+B,EAAQxpG,KAAKmsB,GAAM,MACpB,KAAK,IACJzf,EAAIyf,EAAK,MACV,KAAK,IACJzf,EAAEqM,EAAIoT,EAAIpT,EAAGrM,EAAEvH,EAAIgnB,EAAIhnB,EAAGuH,EAAED,EAAI0f,EAAI1f,EAAG,MACxC,KAAK,IAGJ,GAFAC,EAAE4sF,OAASkQ,EAAQ98F,EAAE+8F,gBACb/8F,EAAW+8F,QAChBrhD,EAAKy2B,WAAanyE,EAAE87F,KAAOpgD,EAAKy2B,WAAanyE,EAAE87F,IAAI/7F,EAAG,MACrDC,EAAEqM,IAAGrM,EAAEqM,EAAI,WACRrM,EAAE87F,IAAKhiF,EAAIxmB,KAAK0M,GAAI,MAE5B,UAOA,KAAK,GACL,KAAK,GAAyB,MAL9B,KAAK,GACJg/E,GAAO,EAAM,MACd,KAAK,GACJA,GAAO,EAAO,MAKf,QACC,GAAGruC,EAAEzB,YACI8vC,GAAQtjC,EAAK+e,IAAK,UAAUzrE,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAEnF,GACOotB,CACR,CAuhKoCkjF,CAAoBjmG,EAAe2kD,GAxwKvE,SAA4B3kD,EAAiB2kD,GAE5C,GAAG3kD,EAAKsyB,MAAM,2BAA4B,MAAO,GACjD,IAAIyzE,EAA4B,GAC5BG,EAAoC,GACpCC,EAAUnmG,EAAKsyB,MAAM,mDACtB6zE,GAAWA,EAAQ,IAAIA,EAAQ,GAAGv2D,MAAM,mBAAmBvZ,QAAQ,SAASz9B,GAC9E,GAAS,KAANA,GAAyB,KAAbA,EAAEmuC,OAAjB,CACA,IAAIz9B,EAAI1Q,EAAE05B,MAAM,8BACbhpB,GAAGy8F,EAAQxpG,KAAK+M,EAAE,GAFW,CAGjC,GACA,IAAI88F,EAAUpmG,EAAKsyB,MAAM,2DAiBzB,OAhBG8zE,GAAWA,EAAQ,IAAIA,EAAQ,GAAGx2D,MAAM,oBAAoBvZ,QAAQ,SAASz9B,GAC/E,GAAS,KAANA,GAAyB,KAAbA,EAAEmuC,OAAjB,CACA,IAAIg7D,EAAKnpG,EAAE05B,MAAM,2BACjB,GAAIyvE,EAAJ,CACA,IAAIv5F,EAAI+4D,GAAYwgC,EAAG,IACnBnM,EAA0B,CAAEC,OAAQrtF,EAAE69F,UAAYN,EAAQv9F,EAAE69F,WAAa,eAAgB/sB,IAAK9wE,EAAE8wE,IAAKgtB,KAAM99F,EAAE89F,MAC7G3+B,EAAOe,GAAYlgE,EAAE8wE,KACzB,KAAG30B,EAAKy2B,WAAaz2B,EAAKy2B,WAAazT,EAAK3+D,GAA5C,CACA,IAAIu9F,EAAY3tG,EAAE05B,MAAM,6CACpBymE,IAAOwN,KAAeA,EAAU,IAAMhd,GAASgd,EAAU,KAAO,CAACv9F,EAAE,GAAGsM,EAAE,GAAG5T,EAAE,IACjFk0F,EAAQ5sF,EAAI+vF,EAAG/vF,EACJ,WAAR+vF,EAAG/vF,IAAgB+vF,EAAGzjF,EAAIyjF,EAAGr3F,EAAI,IACpCk0F,EAAQtgF,GAAKyjF,EAAGzjF,GAAG,IAAIkd,QAAQ,QAAQ,MAAMA,QAAQ,MAAM,MACxDmyB,EAAK8kC,WAAUmM,EAAQl0F,EAAIq3F,EAAGr3F,GACjCwkG,EAAY3pG,KAAKq5F,EAP8B,CAJvC,CAFwB,CAcjC,GACOsQ,CACR,CA4uKQM,CAAoBxmG,EAAe2kD,EAC3C,CAEA,SAAS8hD,GAASzmG,EAAMlE,EAAiB6oD,GACxC,MAAoB,SAAjB7oD,EAAK/E,OAAM,GAh8Kf,SAAsBiJ,GACrB,IAAI+iB,EAAM,GAYV,OAVA+jD,GAAa9mE,EAAM,SAAmB0oB,EAAKkxB,EAAGstB,GAC7C,GACM,KADCA,EAELnkD,EAAIxmB,KAAKmsB,QAGT,IAAGkxB,EAAEzB,EACsB,MAAM,IAAIlgD,MAAM,uBAAyBivE,EAAGvxE,SAAS,IAEnF,GACOotB,CACR,CAk7KoC2jF,CAAc1mG,GAl+KlD,SAAsBA,GACrB,IAAIkb,EAAI,GACR,IAAIlb,EAAM,OAAOkb,EACjB,IAAIxjB,EAAI,EAWR,OAVCsI,EAAKsyB,MAAM8uC,KAAW,IAAI/qC,QAAQ,SAASz9B,GAC3C,IAAI4P,EAAI+4D,GAAY3oE,GACpB,OAAO4P,EAAE,IACR,IAAK,QAEL,IAAK,aAAc,IAAK,cAAe,IAAK,eAAgB,MAE5D,IAAK,YAAaA,EAAE,GAAOA,EAAE9Q,EAAGA,EAAI8Q,EAAE9Q,EAAQ8Q,EAAE9Q,EAAIA,EAAGwjB,EAAE3e,KAAKiM,GAEhE,GACO0S,CACR,CAo9KQyrF,CAAc3mG,EACtB,CAEA,SAAS4mG,GAAY5mG,EAAM0uE,EAAK5yE,EAAiB6oD,GAChD,GAAoB,SAAjB7oD,EAAK/E,OAAM,GAAc,OA76K7B,SAAyBiJ,EAAM0uE,EAAK5yE,EAAiBi3D,GACpD,IAAI/yD,EAAM,OAAOA,EACjB,IAAI2kD,EAAOoO,GAAS,CAAA,EAEhBk1B,GAAO,EAEXnhB,GAAa9mE,EAAM,SAAqB0oB,EAAKkxB,EAAGstB,GAE/C,OAAOA,GACN,KAAK,IACL,SACA,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,KAAK,IACL,SACA,KAAK,IACL,KAAK,IACL,KAAK,IACJ,MAED,KAAK,GACJ+gB,GAAO,EAAM,MACd,KAAK,GACJA,GAAO,EAAO,MAEf,QACC,GAAGruC,EAAEzB,QACA,IAAI8vC,GAAQtjC,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAEnF,EAAGgvD,EACJ,CAm4KoCkiD,CAAiB7mG,EAAe0uE,EAAK5yE,EAAM6oD,EAE/E,CAEA,SAASmiD,GAAa9mG,EAAMlE,EAAiB6oD,GAC5C,MAAoB,SAAjB7oD,EAAK/E,OAAM,GAnoLf,SAA0BiJ,EAAMlE,EAAMi3D,GACpC,IAAIhwC,EAAM,CAAEgkF,MAAO,GAAI9E,KAAM,GAAI9U,MAAO,IACpCxoC,EAAOoO,GAAS,CAAA,EAChB9B,EAAQ,GACRg3B,GAAO,EACP+e,EAAW,EAkCf,OAjCAlgC,GAAa9mE,EAAM,SAAS0oB,EAAKkxB,EAAGstB,GAClC,OAAQA,GACN,KAAK,IACHnkD,EAAIgkF,MAAMxqG,KAAK,CAAET,KAAM4sB,EAAI5sB,OAC3B,MACF,KAAK,GACH4sB,EAAI2N,QAAQ,SAASrtB,GACH,GAAZg+F,EACFjkF,EAAIk/E,KAAK1lG,KAAK,CAAEoI,KAAMoe,EAAIgkF,MAAM/9F,EAAE,GAAK,GAAGlN,KAAMxD,MAAO0Q,EAAE,KACtC,GAAZg+F,GACPjkF,EAAIoqE,MAAM5wF,KAAK,CAAEoI,KAAMoe,EAAIgkF,MAAM/9F,EAAE,GAAK,GAAGlN,KAAMxD,MAAO0Q,EAAE,IAC9D,GACA,MACF,KAAK,IACHg+F,EAAWt+E,EAAM,EAAI,EACrB,MACF,KAAK,IACHs+E,EAAW,EACX,MACF,KAAK,GACH/1C,EAAM10D,KAAK2qE,GACX+gB,GAAO,EACP,MACF,KAAK,GACHh3B,EAAM7V,MACN6sC,GAAO,EACP,MACF,QACE,GAAIruC,EAAEzB,QACC,IAAK8vC,GAAQtjC,EAAK+e,KAAkC,IAA3BzS,EAAMA,EAAM36D,OAAS,GACnD,MAAM,IAAI2B,MAAM,uBAAyBivE,EAAGvxE,SAAS,KAE7D,GACOotB,CACT,CA2lLoCkkF,CAAkBjnG,EAAelE,EAAM6oD,GAlkL3E,SAA0B3kD,EAAMlE,EAAM6oD,GACpC,IAAI5hC,EAAM,CAAEgkF,MAAO,GAAI9E,KAAM,GAAI9U,MAAO,IACxC,IAAKntF,EACH,OAAO+iB,EACT,IAEImkF,EAFAjf,GAAO,EACP+e,EAAW,EAyEf,OAvEAhnG,EAAKwyB,QAAQ4uC,GAAU,SAASxoE,GAC9B,IAAI4P,EAAI+4D,GAAY3oE,GACpB,OAAQ+oE,GAASn5D,EAAE,KACjB,IAAK,QAEL,IAAK,YACL,IAAK,cAEL,IAAK,iBACL,IAAK,mBAKL,IAAK,kBAOL,IAAK,oBAEL,IAAK,OAEL,IAAK,QAQL,IAAK,QAcL,IAAK,UACL,IAAK,WACL,IAAK,YACL,IAAK,YACH,MAxCF,IAAK,gBACHua,EAAIgkF,MAAMxqG,KAAK,CAAET,KAAM0M,EAAE1M,OACzB,MAGF,IAAK,kBACH,IAAK,IAAInE,EAAI,EAAGA,EAAIorB,EAAIgkF,MAAMzwG,SAAUqB,EAClCorB,EAAIgkF,MAAMpvG,GAAGmE,MAAQ0M,EAAE1M,OACzBorG,EAAWnkF,EAAIgkF,MAAMpvG,IACzB,MAOF,IAAK,MACa,GAAZqvG,EACFjkF,EAAIk/E,KAAK1lG,KAAK,CAAEoI,KAAMoe,EAAIgkF,MAAMv+F,EAAE8M,EAAI,GAAGxZ,KAAMxD,OAAQkQ,EAAExE,IACtC,GAAZgjG,GACPjkF,EAAIoqE,MAAM5wF,KAAK,CAAEoI,KAAMoe,EAAIgkF,MAAMv+F,EAAE8M,EAAI,GAAGxZ,KAAMxD,OAAQkQ,EAAExE,IAC5D,MAGF,IAAK,gBACHgjG,EAAW,EACX,MACF,IAAK,kBAML,IAAK,mBACHA,EAAW,EACX,MALF,IAAK,iBACHA,EAAW,EACX,MASF,IAAK,OACH/e,GAAO,EACP,MACF,IAAK,SACHA,GAAO,EACP,MACF,IAAK,OACH,IAAKif,EACH,MACGA,EAASC,UACZD,EAASC,QAAU,IACrBD,EAASC,QAAQ5qG,MAAMiM,EAAE9Q,GACzB,MACF,QACE,IAAKuwF,GAAQtjC,EAAK+e,IAChB,MAAM,IAAIzrE,MAAM,gBAAkBuQ,EAAE,GAAK,gBAE/C,OAAO5P,CACT,GACOmqB,CACT,CAo/KQqkF,CAAkBpnG,EAAelE,EAAM6oD,EAC/C,CAmCA,IAwCI0iD,GAxCAC,GAAW,kDACXC,GAAU,qDACd,SAASC,GAAiBxxG,EAAgBwrE,GACzC,IAAIimC,EAAQzxG,EAAI45C,MAAM,OAClBrzB,EAAa,GACjB,GAD6CA,EAAE,GAAKkrF,EAAM,GACtC,IAAjBA,EAAMnxG,OAAc,OAAOimB,EAC9B,IAA+B/T,EAAG7Q,EAAMD,EAApCqK,EAAI/L,EAAIs8B,MAAMg1E,IAClB,GAAGvlG,EAAG,IAAIrK,EAAI,EAAGA,GAAKqK,EAAEzL,SAAUoB,GAGJ,KAAzBC,GAFJ6Q,EAAIzG,EAAErK,GAAG46B,MAAMi1E,KAEP,GAAG3xE,QAAQ,MAAcrZ,EAAE/T,EAAE,IAAMA,EAAE,GAAGzR,MAAM,EAAEyR,EAAE,GAAGlS,OAAO,GAInEimB,EAFuB,WAApB/T,EAAE,GAAGzR,MAAM,EAAE,GAAqB,QAAQyR,EAAE,GAAGzR,MAAM,GAC/CyR,EAAE,GAAGzR,MAAMY,EAAE,IACf6Q,EAAE,GAAGzR,MAAM,EAAEyR,EAAE,GAAGlS,OAAO,GAGlC,OAAOimB,CACR,CACA,SAASmrF,GAAoB1xG,GAC5B,IACIumB,EAAI,CAAA,EACR,GAAoB,IAFRvmB,EAAI45C,MAAM,OAEbt5C,OAAc,OAAOimB,EAC9B,IAA+B/T,EAAG7Q,EAAMD,EAApCqK,EAAI/L,EAAIs8B,MAAMg1E,IAClB,GAAGvlG,EAAG,IAAIrK,EAAI,EAAGA,GAAKqK,EAAEzL,SAAUoB,GAGJ,KAAzBC,GAFJ6Q,EAAIzG,EAAErK,GAAG46B,MAAMi1E,KAEP,GAAG3xE,QAAQ,MAAcrZ,EAAE/T,EAAE,IAAMA,EAAE,GAAGzR,MAAM,EAAEyR,EAAE,GAAGlS,OAAO,GAInEimB,EAFuB,WAApB/T,EAAE,GAAGzR,MAAM,EAAE,GAAqB,QAAQyR,EAAE,GAAGzR,MAAM,GAC/CyR,EAAE,GAAGzR,MAAMY,EAAE,IACf6Q,EAAE,GAAGzR,MAAM,EAAEyR,EAAE,GAAGlS,OAAO,GAGlC,OAAOimB,CACR,CAaA,SAASorF,GAAkBC,EAAW/7E,EAAKg1B,EAAIn4B,GAC9C,IAAIm/E,EAAen/E,EACnB,QAAQm4B,EAAG,GAAGvuB,MAAM,qBAAqB,CAAC,GAAG,KAAK,IACjD,IAAK,UAAWu1E,EAAOtlC,GAAa75C,GAAM,MAC1C,IAAK,KAAM,IAAK,MAAOm/E,EAAOp+F,SAASif,EAAK,IAAK,MACjD,IAAK,KAAM,IAAK,QAASm/E,EAAO3gE,WAAWxe,GAAM,MACjD,IAAK,OAAQ,IAAK,cAAem/E,EAAO7oC,GAAUt2C,GAAM,MACxD,IAAK,KAAM,IAAK,SAAU,IAAK,QAAS,IAAK,OAAQ,IAAK,aAAc,MACxE,QAAS,MAAM,IAAIzwB,MAAM,gBAAkB4oD,EAAG,IAE/C+mD,EAAU9lC,GAAYj2C,IAAQg8E,CAC/B,CAEA,SAASC,GAAiBngC,EAAe+6B,EAAIztD,GAC5C,GAAc,MAAX0yB,EAAKryD,EAAR,CACA,IAAI2/B,IAAoB,IAAfA,EAAEqvC,SAAoB,IAChB,MAAX3c,EAAKryD,EAAaqyD,EAAK5rD,EAAI4rD,EAAK5rD,GAAKmtD,GAAKvB,EAAK3jE,GACnC,YAAP0+F,EACO,MAAX/6B,EAAKryD,GACI,EAAPqyD,EAAK3jE,KAAS2jE,EAAK3jE,EAAG2jE,EAAK5rD,EAAI4rD,EAAK3jE,EAAErO,SAAS,IAC9CgyE,EAAK5rD,EAAIgqC,GAAgB4hB,EAAK3jE,GAE/B2jE,EAAK5rD,EAAIqqC,GAAYuhB,EAAK3jE,GAE3B2jE,EAAK5rD,GA9BSuxB,EA8BOo1D,GAAI,UA9BH3sG,EA8Bc4xE,EAAK3jE,EA5BpC,aADPuiD,EAAM8gD,GAAc/5D,IAAWw0B,GAAYx0B,IAClB8Y,GAAYrwD,GAClCswD,GAAWE,EAAKxwD,GA4BvB,CAAE,MAAM0P,GAAK,GAAGwvC,EAAEyuB,IAAK,MAAMj+D,CAAG,CA/BjC,IAAqB6nC,EAAQv3C,EACxBwwD,EA+BJ,IACC,IAAIhqC,EAAI8qF,GAAc3E,IAAKA,GAAI,UAE/B,GADGztD,EAAEsvC,SAAQ5c,EAAKprD,EAAIA,GACnB04B,EAAEm1B,WAAuB,KAAVzC,EAAKryD,GAAYk0C,GAAYjtC,GAAI,CAClD,IAAIsoF,EAAKngD,GAAoBijB,EAAK3jE,GAAO6gG,IAAMl9B,EAAKryD,EAAI,IAAKqyD,EAAK3jE,EAAI,IAAIs+B,KAAKuiE,EAAGr8F,EAAGq8F,EAAG9iG,EAAE,EAAE8iG,EAAG3pF,EAAE2pF,EAAGlpF,EAAEkpF,EAAG5xE,EAAE4xE,EAAG1uD,EAAE0uD,EAAGjnF,GACpH,CACD,CAAE,MAAMnY,GAAK,GAAGwvC,EAAEyuB,IAAK,MAAMj+D,CAAG,CAlBb,CAmBpB,CAEA,SAASsiG,GAAmBrW,EAAQsW,EAAMrjD,GACzC,GAAGA,EAAKg1B,YACJquB,EAAKC,SAAU,CACjB,IAAI/xD,EAAI8xD,EAAKC,SACV/xD,EAAEniB,UAASmiB,EAAE48C,YAAc7C,GAAmB/5C,EAAEniB,UAAYmiB,EAAEniB,QAClE,CAED29D,EAAOsW,EAAKE,IAAMF,CACnB,CAGA,SAASG,GAAgBzsC,EAAKjV,EAAIzmD,EAAM2nE,EAAc7lD,EAAM4vE,EAAQ0W,EAAMppG,EAAK08F,EAAQzmD,GACtF,IAAIytD,EAAK,UAAW2F,EAAM1gC,EAAK2gC,QAASnyD,EAAI,GAAIlB,EAAIA,GAAK,CAAA,EACzD,IAAIszD,EAAY,GACZ7wG,EAAI,EAGR,SAFWnB,IAAR8xG,GAAqBrpG,IAAKqpG,EAAMrpG,EAAIspG,cAC5B/xG,IAAR8xG,GAAqBD,IAAMC,EAAMD,EAAKE,cACnB/xG,IAAhBm7F,EAAO2W,KACT3W,EAAO2W,GAAK3F,KAAIA,EAAKhR,EAAO2W,GAAK3F,IACjChR,EAAO2W,GAAKJ,UAAUM,EAAUhsG,KAAKm1F,EAAO2W,GAAKJ,UAChDvW,EAAO2W,GAAKz0E,SAChBy0E,EAAM3W,EAAO2W,GAAKz0E,OAEnB,OAAO5zB,EAAK2uE,MACX,IAAK,UACJhH,EAAKryD,EAAI,IACTqyD,EAAK3jE,EAAIu+D,GAAa7G,GACtB,MACD,IAAK,SACJiM,EAAKryD,EAAI,IAAKqyD,EAAK3+D,EAAIo5D,GAAYN,GAAYpG,IAC/CiM,EAAK3jE,EAAK03D,EAAI9lC,QAAQ,QAAYksC,GAAYrb,GAAIiV,GAAKlpC,QAAQ,SAAU,IAAMm1C,EAAK3+D,EACpF,MACD,IAAK,WACgB,KAAjB0yD,EAAI3kE,OAAM,KAAY2kE,GAAO,KAChCiM,EAAK3jE,GAAKg7D,GAAUtD,GAAO,IAAIp5B,KAAKA,KAAKkmE,IAAI,KAAM,GAAI,MAAI,MACxD7gC,EAAK3jE,GAAM2jE,EAAK3jE,EAAG2jE,EAAK3jE,EAAI89D,GAAYpG,GACnCiM,EAAK3jE,EAAE,KAAI2jE,EAAK3jE,EAAI2jE,EAAK3jE,EAAG,GAChC0+F,GAAY,WAANA,IAAiBA,EAAK,cAEjC,IAAK,cACUnsG,IAAXoxE,EAAK3jE,IAAiB2jE,EAAK3jE,GAAG03D,GAC7BiM,EAAKryD,IAAGqyD,EAAKryD,EAAI,KACrB,MACD,IAAK,QAASqyD,EAAKryD,EAAI,IAAKqyD,EAAK3jE,EAAIuoE,GAAM7Q,IAAwB,IAAfzmB,EAAEqvC,WAAoB3c,EAAK5rD,EAAI2/C,GAAK,MACxF,QACW,IAAPA,GAAmB,IAANjV,EAAYkhB,EAAKryD,EAAI,KAC9BqyD,EAAKryD,EAAI,IAAKqyD,EAAK3jE,EAAIo+D,GAAY3b,GAAIiV,IAIhD,GADAosC,GAAiBngC,EAAM+6B,EAAIztD,IACN,IAAlBA,EAAE0sD,YACJ,GAAGh6B,EAAK8gC,QAAS,CAChB,IAAIvS,EAAOp0B,GAAY6F,EAAK8gC,SAEH,IAAtBvS,EAAKr4C,WAAW,KAAkBq4C,EAAOA,EAAKn/F,MAAM,IACvD4wE,EAAKpvD,EAAI2oE,GAASgV,EAAMp0E,UACjB6lD,EAAK8gC,QACU,MAAnB9gC,EAAK+gC,WAAoB/gC,EAAK7tC,EAAIonD,GAAS,QAASp/D,GAC/C6lD,EAAK+gC,aACZ/gC,EAAK7tC,EAAIonD,GAASvZ,EAAK+gC,WAAY5mF,GACnC45E,EAAOn/F,KAAK,CAACssE,GAAkBlB,EAAK7tC,GAAI6tC,EAAK7tC,IAE/C,MACC,IAAIpiC,EAAI,EAAGA,EAAIgkG,EAAOplG,SAAUoB,EAC5BoqB,EAAK9Y,GAAK0yF,EAAOhkG,GAAG,GAAG2N,EAAE2D,GAAK8Y,EAAK9Y,GAAK0yF,EAAOhkG,GAAG,GAAG+N,EAAEuD,GACtD8Y,EAAK7Y,GAAKyyF,EAAOhkG,GAAG,GAAG2N,EAAE4D,GAAK6Y,EAAK7Y,GAAKyyF,EAAOhkG,GAAG,GAAG+N,EAAEwD,IACzD0+D,EAAK7tC,EAAI4hE,EAAOhkG,GAAG,IAGrBu9C,EAAE0kC,aACJ4uB,EAAUlyE,QAAQ,SAASz9B,IACtBu9C,EAAE28C,aAAel6F,EAAEk6F,cAAa38C,EAAE28C,YAAcl6F,EAAEk6F,YACvD,GACAnrB,EAAKtiE,EAAI8wC,QAEU5/C,IAAjBoxE,EAAK2gC,UAAuB3gC,EAAKsO,KAAOtO,EAAK2gC,QACjD,CAEA,SAASK,GAAmB/S,GAC3BA,EAAQtgF,EAAIsgF,EAAQ5xF,GAAK,GACzB4xF,EAAQtgF,EAAIsgF,EAAQtgF,EAAEkd,QAAQ,QAAQ,MAAMA,QAAQ,MAAM,MAC1DojE,EAAQ5xF,EAAI4xF,EAAQ75E,EAAI65E,EAAQ3f,UAAO1/E,CACxC,CAGA,SAASqyG,GAAe1tF,EAAG63C,GAC1B,IAAIpO,EAAOoO,GAAS,CAAA,EACpB9H,KACA,IAAIluD,EAAMqkD,GAAM0iB,GAAe5oD,IACf,UAAbypC,EAAKhgD,MAAiC,SAAbggD,EAAKhgD,MAAgC,UAAbggD,EAAKhgD,OAEnD5H,EAAM+lE,GAAS/lE,IAErB,IA0BI8rG,EA1BAC,EAAU/rG,EAAIhG,MAAM,EAAG,MAAM6uC,cAAemjE,GAAS,EAEzD,IAA2B,MAD3BD,EAAUA,EAAQt2E,QAAQ,SAAU,KACxBoD,QAAQ,MAAe/9B,KAAK0C,IAA4B,KAAvBuuG,EAAQlzE,QAAQ,KAAoC,KAArBkzE,EAAQlzE,QAAQ,MAAa,CAAE,IAAIozE,EAAK1pC,GAAI3a,GAA2B,OAApBqkD,EAAGrkG,KAAO,SAAiB4+E,GAAI/H,YAAYz+E,EAAKisG,EAAK,CAEpL,IAD+B,GAA5BF,EAAQlzE,QAAQ,UAAgB,CAAC,OAAQ,QAAS,OAAQ,OAAQ,SAAU,QAAS,OAAOS,QAAQ,SAASrgC,GAAU8yG,EAAQlzE,QAAQ,IAAM5/B,IAAQ,IAAG+yG,GAAS,EAAM,GACvKA,EAAQ,OAshHZ,SAA0BhsG,EAAgB4nD,GACzC,IAAIs5C,EAAOlhG,EAAIu1B,MAAM,sCACrB,IAAI2rE,GAAuB,GAAfA,EAAK3nG,OAAa,MAAM,IAAI2B,MAAM,wCAC9C,GAAkB,GAAfgmG,EAAK3nG,OAAa,OAAO6yE,GAAkB8/B,GAAchL,EAAK,GAAIt5C,GAAOA,GAC5E,IAAI6iC,EAqwGG,CAAEle,WAAY,GAAIC,OAAQ,IAnwGjC,OADA00B,EAAK5nE,QAAQ,SAAShxB,EAAGpB,GAAOilG,GAAkB1hB,EAAIyhB,GAAc5jG,EAAGs/C,GAAO,SAAW1gD,EAAI,GAAK,GAC3FujF,CACR,CA7hHmB2hB,CAAiBpsG,EAAK4nD,GAExC0iD,GAAiB,CAChB,iBAAkB,UAClB,eAAgBrjD,GAAU,IAC1B,YAAa,sBACb,cAAeA,GAAU,IACzB,aAAcA,GAAU,IACxB,YAAaA,GAAU,IACvB,cAAeA,GAAU,IACzB,aAAcA,GAAU,IACxBolD,SAAY,uCACZC,MAASrlD,GAAU,GACnBslD,SAAYtlD,GAAU,GACtBulD,QAAWvlD,GAAU,IACrBwlD,WAAcxlD,GAAU,IACxB,SAAU,qBACV,aAAc,0BACd,SAAU,sBAKX,IAAgBniD,EAYAumG,EAZZn3C,EAAQ,GAERoY,EAAS,CAAA,EAAIogC,EAA+B,GAAIC,EAA0B/kD,EAAK+kB,MAAQ,GAAK,CAAA,EAAKigC,EAAY,GAC7GhiC,EAAQ,GAAa3oE,EAAM,CAAA,EAC3B4qG,EAAOpC,GAAiB,2BAA4BqC,EAAO,EAC3D5gG,EAAI,EAAGD,EAAI,EACXq8E,EAAqB,CAAChgF,EAAG,CAAC2D,EAAE,IAASC,EAAE,KAAUxD,EAAG,CAACuD,EAAE,EAAGC,EAAE,IAC5DyoF,EAAS,GAAIsW,EAAO,CAAA,EACpBvhD,EAAK,GAAIqjD,EAAO,EAChBvK,EAA0B,GAC1BpuB,EAAQ,CAAA,EAAIy2B,EAAY,CAAA,EAAImC,EAAO,EAAGlpD,EAAK,GAC3C40C,EAA8B,GAAIG,EAAuB,CAAA,EACzDoU,EAAQ,GAAUlL,GAAU,EAC5BpD,EAAoC,GACpCnb,EAA6B,GAAI2gB,EAAS,CAAA,EAAIx5C,EAAK,EAAGc,EAAK,EAC3DyhD,EAA0B,CAAE1gC,OAAO,GAAI65B,QAAQ,CAACp+C,UAAS,IAAmBklD,EAAU,CAAA,EAC1FnmC,GAAUvlC,UAAY,EACtBzhC,EAAMA,EAAIy1B,QAAQ,sBAAsB,IAExC,IADA,IAAI23E,EAAU,GACPtB,EAAK9kC,GAAU/8B,KAAKjqC,WAAe8rG,EAAG,IAAMsB,EAAUtB,EAAG,IAAIjjE,eACnE,IAAK,OACJ,GAAc,QAAXukE,EAAmB,CACrB,GAAW,MAARtB,EAAG,IAAU,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,UAC/C,MAAjCosG,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,IAAY26D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IACjE,KACD,CACA,GAAG53C,EAAMA,EAAM36D,OAAO,GAAG,GAAI,MAClB,MAARuyG,EAAG,GAAUV,GAAgBprG,EAAIhG,MAAM8yG,EAAMhB,EAAGvwG,OAAQmuD,EAAImjD,EAA6C,WAAvC34C,EAAMA,EAAM36D,OAAO,GAAG,GAA2Bs/F,EAAQjuB,EAAM,CAAC1+D,EAAEA,EAAED,EAAEA,GAAI0oF,EAAQsY,EAAM/gG,GAAIjK,EAAK08F,EAAQ/2C,IACvK8B,EAAK,GAAImjD,EAAOpC,GAAiBqB,EAAG,IAAKgB,EAAOhB,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,QACxE,MACD,IAAK,OACJ,GAAW,MAARuyG,EAAG,GAkBL,GAjBGpT,EAASn/F,OAAS,IAAGqxE,EAAK1+D,EAAIwsF,KAC5B9wC,EAAKy2B,WAAaz2B,EAAKy2B,UAAYpyE,SAAiBzS,IAAXoxE,EAAK3jE,IAC/C2gD,EAAK+kB,OACHggC,EAAS1gG,KAAI0gG,EAAS1gG,GAAK,IAC/B0gG,EAAS1gG,GAAGC,GAAK0+D,GACX+hC,EAASrhC,GAAWp/D,GAAKm/D,GAAWp/D,IAAM2+D,GAE/CA,EAAKyiC,OACPziC,EAAK1nE,EAAK,CAAC2uE,OAAO9M,GAAY6F,EAAKyiC,OAChCziC,EAAK0iC,gBAAe1iC,EAAK1nE,EAAE4/F,QAAUl4B,EAAK0iC,sBACtC1iC,EAAKyiC,YAAaziC,EAAK0iC,gBAE5B1iC,EAAK2iC,aAAe3iC,EAAK4iC,aAC3B7iD,EAAKz+C,GAAmC,EAA9BQ,SAASk+D,EAAK2iC,YAAY,KACpC9hD,EAAKx/C,GAAiC,EAA5BS,SAASk+D,EAAK4iC,UAAU,KAClChL,EAAOhjG,KAAK,CAAC8I,EAAE,CAAC4D,EAAEA,EAAED,EAAEA,GAAGvD,EAAE,CAACwD,EAAEy+C,EAAG1+C,EAAEw/C,MAEhC7D,EAAKwlB,WACJ,GAAGxC,EAAK2iC,aAAe3iC,EAAK4iC,UAAW,CAE3C,IAAI,IAAIC,EAAMvhG,EAAGuhG,GAAO9iD,IAAM8iD,EAC7B,IAAI,IAAIC,EAAMzhG,EAAGyhG,GAAOjiD,IAAMiiD,GAC1BD,EAAMvhG,GAAKwhG,EAAMzhG,KAChB27C,EAAK+kB,OACHggC,EAASe,KAAMf,EAASe,GAAO,IACnCf,EAASe,GAAKD,GAAO,CAACl1F,EAAE,MAClBo0F,EAASrhC,GAAWmiC,GAAOpiC,GAAWqiC,IAAQ,CAACn1F,EAAE,MAI3DrM,EAAIy+C,EAAK,CACV,OACOz+C,OAfmB0+D,EAAK2iC,YAAarhG,EAAIy+C,EAAK,IAAUz+C,OAiB/D0+D,EAAO+/B,GAAoBmB,EAAG,KACtBhc,QAAO5jF,GAAK0+D,EAAKklB,MAAQ,GAC9B5jF,EAAIo8E,EAAShgF,EAAE4D,IAAGo8E,EAAShgF,EAAE4D,EAAIA,GACjCA,EAAIo8E,EAAS5/E,EAAEwD,IAAGo8E,EAAS5/E,EAAEwD,EAAIA,GACb,OAApB4/F,EAAG,GAAG9xG,aAAsBkS,EAC/BwsF,EAAW,GAEZ,MACD,IAAK,MACO,MAARoT,EAAG,IAAgC,OAApBA,EAAG,GAAG9xG,OAAM,IAC1BiS,EAAIq8E,EAAShgF,EAAE2D,IAAGq8E,EAAShgF,EAAE2D,EAAIA,GACjCA,EAAIq8E,EAAS5/E,EAAEuD,IAAGq8E,EAAS5/E,EAAEuD,EAAIA,GACb,OAApB6/F,EAAG,GAAG9xG,OAAM,KACdiI,EAAMwoG,GAAiBqB,EAAG,KACnBhc,QAAO7jF,GAAKhK,EAAI6tF,MAAQ,GAEhC5jF,EAAI,IAAKD,KAEThK,EAAMwoG,GAAiBqB,EAAG,KACnBhc,QAAO7jF,GAAKhK,EAAI6tF,MAAQ,GAC/BqU,EAAS,CAAA,GACe,KAArBliG,EAAI0rG,eAAwB1rG,EAAI2rG,UAClCzJ,EAAOzf,IAAMh4E,SAASzK,EAAI2rG,OAAQ,IAAKzJ,EAAO1f,IAAMa,GAAM6e,EAAOzf,KACjElB,EAAQv3E,GAAKk4F,GAEG,KAAdliG,EAAIolG,SAAiBlD,EAAO5f,QAAS,EAAMf,EAAQv3E,GAAKk4F,IAE5D,MACD,IAAK,YACJ,GAAW,MAAR2H,EAAG,GAAS,CACd,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,MACxEgtG,EAAWltG,KAAKotG,GACbtkB,EAAShgF,EAAE2D,GAAKq8E,EAAS5/E,EAAEuD,GAAKq8E,EAAShgF,EAAE4D,GAAKo8E,EAAS5/E,EAAEwD,IAC7DygG,EAAS,QAAU9gC,GAAayc,GAC7B1gC,EAAKy2B,WAAaz2B,EAAKy2B,WAAaiK,EAAS5/E,EAAEuD,IACjD0gG,EAAS,YAAcA,EAAS,QAChCrkB,EAAS5/E,EAAEuD,EAAI27C,EAAKy2B,UAAY,EAChCsuB,EAAS,QAAU9gC,GAAayc,KAG/Bka,EAAOjpG,SAAQozG,EAAS,WAAanK,GACrCyK,EAAM1zG,OAAS,IAAGozG,EAAS,SAAWM,GACtCzpB,EAAQjqF,OAAS,IAAGozG,EAAS,SAAWnpB,GAC3ClX,EAAOsgC,GAAaD,CACrB,MACCrkB,EAAW,CAAChgF,EAAG,CAAC2D,EAAE,IAASC,EAAE,KAAUxD,EAAG,CAACuD,EAAE,EAAGC,EAAE,IAClDD,EAAIC,EAAI,EACRgoD,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IACnBhnG,EAAM2lG,GAAiBqB,EAAG,IAC1Bc,EAAY7nC,GAAYjgE,EAAI02E,MAC5BmxB,EAAY/kD,EAAK+kB,MAAQ,GAAK,GAC9B61B,EAAS,GACT7D,EAAS,GACTnb,EAAU,GACV2pB,EAAU,CAACpuG,KAAK6tG,EAAWvF,OAAO,GAClC6F,EAAS1gC,OAAOhtE,KAAK2tG,GAEtB,MACD,IAAK,QACJ,GAAW,MAARrB,EAAG,IAAU,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,cAC7D,MAAnBosG,EAAG,GAAG9xG,UAAmB,MAEhCk6D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IACnBmB,EAAQ,GAAIlL,GAAU,CACvB,CACA,MAED,IAAK,QACO,MAAR+J,EAAG,GAAUd,GAAmBrW,EAAQsW,EAAMrjD,GAC5CqjD,EAAOR,GAAiBqB,EAAG,IAChC,MAED,IAAK,eACJb,EAAKtF,GAAK5gC,GAAY0lC,GAAiBqB,EAAG,IAAI+B,QAAU,WACrDvD,GAAcW,EAAKtF,MAAKsF,EAAKtF,GAAK2E,GAAcW,EAAKtF,KACxD,IAAI,IAAImI,EAAS,EAAa,KAAVA,GAA8B7mD,GAAU6mD,IAAW7C,EAAKtF,KAArCmI,GACvC,GAAa,KAAVA,EAAiB,IAAIA,EAAS,GAAgB,KAAVA,IAAmBA,EAAQ,GAAwB,MAArB7mD,GAAU6mD,GAAiB,CAAE7/C,GAASg9C,EAAKtF,GAAImI,GAAS,KAAO,CACpI,MAED,IAAK,SACJ,GAA2C,UAAxC55C,EAAMA,EAAM36D,OAAO,GAAG,GAA2B,MAIpD,IAHA8xG,EAAOZ,GAAiBqB,EAAG,KACnBzE,SAAUgE,EAAK9mB,QAAS,SAAa8mB,EAAKhE,QAC/CgE,EAAK0C,QAAO1C,EAAKlmB,IAAMz4E,SAAS2+F,EAAK0C,MAAO,MAC3ChM,GAAWsJ,EAAKlmB,IAAM,GAAI,CAC7B4c,GAAU,EAAMzP,GAlyON,EAmyOV,IAAI,IAAI0b,EAAO,EAAGA,EAAOf,EAAM1zG,SAAUy0G,EAASf,EAAMe,IAAOxpB,GAAYyoB,EAAMe,GAClF,CACGjM,GAASvd,GAAY6mB,GACxB4B,EAAO5B,EAAKvb,MAAM,GAAGmd,EAAM1zG,QAAW8xG,EACtC,IAAI,IAAI1wG,EAAI,EAAGA,GAAK0wG,EAAK4C,OAAQtzG,EAAGsyG,EAAMA,EAAM1zG,QAAUgpE,GAAI8oC,GAC9D,MAED,IAAK,aACJ,GAAW,MAARS,EAAG,GAAU,MACZoB,EAASpG,QAAOoG,EAASpG,MAAQ,IACrC,IAAIoH,EAAc1pC,GAAYsnC,EAAG,IAC7BqC,EAAgC,CACnC3yB,KAAM0yB,EAAY1yB,KAClBwrB,IAAK7iB,GAAS+pB,EAAYE,SAASp0G,MAAM,GAAI,CAACiS,EAAE,EAAGC,EAAE,KAEnDghG,EAAS1gC,OAAOjzE,OAAO,IAAG40G,EAAapH,MAAMmG,EAAS1gC,OAAOjzE,OAAO,GAC7C2zG,EAASpG,MAAMtnG,KAAK2uG,GAC9C,MAED,IAAK,YACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,IACL,IAAK,KACL,IAAK,KACL,IAAK,KACL,IAAK,MACL,IAAK,MACL,IAAK,OACL,IAAK,YAEL,IAAK,UACL,IAAK,SAUL,IAAK,aA0BL,IAAK,aA6BL,IAAK,OAUL,IAAK,gBAwBL,IAAK,OAAwB,MAlG7B,IAAK,OACJ,GAAuB,OAApBrC,EAAG,GAAG9xG,UAAoB,MACb,MAAR8xG,EAAG,GAAUpiD,GAAM1pD,EAAIhG,MAAM+yG,EAAMjB,EAAGvwG,OACzCwxG,EAAOjB,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,OAC7B,MACD,IAAK,WACJ,IAAIquD,EAAKg1B,WAAY,MACrBquB,EAAKC,SAAWT,GAAiBqB,EAAG,IACpC,MAGD,IAAK,SACL,IAAK,QACL,IAAK,cACL,IAAK,UACL,IAAK,WACL,IAAK,UACL,IAAK,WACL,IAAK,UACL,IAAK,aACL,IAAK,YACL,IAAK,cACL,IAAK,UACL,IAAK,WACL,IAAK,YACL,IAAK,gBACL,IAAK,UACL,IAAK,gBACL,IAAK,aACL,IAAK,WACL,IAAK,UACJ,GAAuB,OAApBA,EAAG,GAAG9xG,OAAM,GAAc,MACb,MAAR8xG,EAAG,GAAU33B,GAAcC,EAAOg5B,EAASptG,EAAIhG,MAAMgzG,EAAMlB,EAAGvwG,QACjEyxG,EAAOlB,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,OAC7B,MAGD,IAAK,SACL,IAAK,WACJ,GAAW,MAARuyG,EAAG,IAAU,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,WACnFw0D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IACxB,MAED,IAAK,UACJ,GAAW,MAARA,EAAG,GAAS,CACd,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,MACxEksG,GAAmB/S,GACnBH,EAASl5F,KAAKq5F,EACf,MACC3kC,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IAEnBjT,EAAW,CAACtsF,GADZzH,EAAM2lG,GAAiBqB,EAAG,KACR34B,QAEnB,MAED,IAAK,aACJ,GAAW,MAAR24B,EAAG,IAAU,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,WACnF,GAAoC,MAAjCosG,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,GAAY,CAC7C,IAAI80G,EAAa5D,GAAiBqB,EAAG,IACrCa,EAAS,eAAiB,CAAEpwB,IAAI4H,GAASkqB,EAAWC,OAAO74E,QAAQ,MAAM,KACzEy+B,EAAM10D,KAAK,CAACssG,EAAG,IAAI,GACpB,CACA,MAID,IAAK,iBACJ,GAAW,MAARA,EAAG,IACL,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,UAEpC,MAAjCosG,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,IAAY26D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IAE7D,MAID,IAAK,mBACL,IAAK,qBACL,IAAK,2BACL,IAAK,yBACL,IAAK,aACL,IAAK,aACL,IAAK,QACL,IAAK,UACL,IAAK,aACL,IAAK,aACL,IAAK,UACL,IAAK,SACL,IAAK,wBACL,IAAK,eACL,IAAK,YACL,IAAK,gBACL,IAAK,kBACL,IAAK,mBACJ,GAAW,MAARA,EAAG,IAAU,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,MAAM,IAAI5wG,MAAM,cAAc4J,EAAIpF,KAAK,UAC/C,MAAjCosG,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,IAAY26D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IACjE,MAID,QAEC,GAAmB,GAAhB53C,EAAM36D,QAAwB,YAATuyG,EAAG,GAAkB,OAAOyC,GAAWvuG,EAAK4nD,GAEpE,GAAmB,GAAhBsM,EAAM36D,QAAwB,OAATuyG,EAAG,GAAsB,OAAOyC,GAAWvuG,EAAK4nD,GAExE,IAAIxhB,GAAO,EACX,OAAO8tB,EAAMA,EAAM36D,OAAO,GAAG,IAE5B,IAAK,yBAA4D,OAAOuyG,EAAG,IAC1E,IAAK,WACL,IAAK,4BACL,IAAK,qBACL,IAAK,uBACL,IAAK,SACL,IAAK,QACL,IAAK,QACL,IAAK,MACL,IAAK,mBACL,IAAK,sBAAsD,MAC3D,QAAS1lE,GAAO,EACf,MAGF,IAAK,mBAAgD,OAAO0lE,EAAG,IAC9D,IAAK,UACL,IAAK,iBACL,IAAK,qBACL,IAAK,QACL,IAAK,UACL,IAAK,YACL,IAAK,WACL,IAAK,kBAA8C,MACnD,QAAS1lE,GAAO,EACf,MAGF,IAAK,gBAA0C,OAAO0lE,EAAG,IACxD,IAAK,WAEJoB,EAAS7G,QAAQp+C,UAAW,EAC5B,MACD,IAAK,eACL,IAAK,cACL,IAAK,aACL,IAAK,aACL,IAAK,WACL,IAAK,mBACL,IAAK,gBACL,IAAK,iBACL,IAAK,cACL,IAAK,kBACL,IAAK,oBACL,IAAK,UACL,IAAK,YACL,IAAK,aACL,IAAK,kBACL,IAAK,iBACL,IAAK,MACL,IAAK,yBACL,IAAK,sBACL,IAAK,YACL,IAAK,gBACL,IAAK,YACL,IAAK,OACL,IAAK,MACL,IAAK,QACL,IAAK,iBACL,IAAK,cACL,IAAK,WACL,IAAK,gBACL,IAAK,MACL,IAAK,aACL,IAAK,UACL,IAAK,WACL,IAAK,UACL,IAAK,aACL,IAAK,UACL,IAAK,QACL,IAAK,OACL,IAAK,MACL,IAAK,gBACL,IAAK,iBACL,IAAK,2BACL,IAAK,SACL,IAAK,cACL,IAAK,qBAAoD,MACzD,QAAS7hB,GAAO,EACf,MAGF,IAAK,kBAA8C,OAAO0lE,EAAG,IAC5D,IAAK,aACL,IAAK,SACL,IAAK,QAA0B,MAC/B,QAAS1lE,GAAO,EACf,MAGF,IAAK,mBAAgD,OAAO0lE,EAAG,IAC9D,IAAK,UACJ,GAAuB,OAApBA,EAAG,GAAG9xG,OAAM,YACC,MAAR8xG,EAAG,GAAU,OAAO9rG,EAAIhG,MAAMgzG,EAAMlB,EAAGvwG,QAC9C,IAAK,cAAe4xG,EAAQ9F,OAAS,EAAG,MACxC,IAAK,kBAAmB8F,EAAQ9F,OAAS,OAErC2F,EAAOlB,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,OAC7B,MACD,IAAK,SACAozG,EAAS,aAAa/M,GAAgB+M,EAAS,YAAY,CAAA,EAAI,QAC/D5vG,OAAOynE,GAAYsnC,EAAG,IAAI0C,UAAS7B,EAAS,YAAYhuD,QAAU6lB,GAAYsnC,EAAG,IAAI0C,QACzF,MACD,IAAK,SACA7B,EAAS,aAAa/M,GAAgB+M,EAAS,YAAY,CAAA,EAAI,QAC/D5vG,OAAOynE,GAAYsnC,EAAG,IAAI0C,UAAS7B,EAAS,YAAY3M,QAAUx7B,GAAYsnC,EAAG,IAAI0C,QACzF,MACD,IAAK,cACJ,IAAIC,EAAcjqC,GAAYsnC,EAAG,IAC7Ba,EAAS,aAAa/M,GAAgB+M,EAAS,YAAY,CAAA,EAAG,QAC9D5vG,OAAO0xG,EAAYC,OAAM/B,EAAS,YAAYt/E,KAAOohF,EAAYC,KACjE3xG,OAAO0xG,EAAYE,QAAOhC,EAAS,YAAYplE,MAAQknE,EAAYE,MACnE5xG,OAAO0xG,EAAYG,SAAQjC,EAAS,YAAYnlE,OAASinE,EAAYG,OACrE7xG,OAAO0xG,EAAYI,UAASlC,EAAS,YAAYtiE,QAAUokE,EAAYI,QAC3E,MACD,IAAK,qBACA3B,EAAS1L,QAAO0L,EAAS1L,MAAQ,IACjC0L,EAAS1L,MAAM,KAAI0L,EAAS1L,MAAM,GAAK,CAAA,GAC3C0L,EAAS1L,MAAM,GAAGK,KAAM,EACxB,MAED,IAAK,cACL,IAAK,gBAEL,IAAK,kBACL,IAAK,gBAGL,IAAK,wBAGL,IAAK,YACL,IAAK,YACL,IAAK,mBACL,IAAK,sBAEL,IAAK,WACL,IAAK,QACL,IAAK,cACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,SACL,IAAK,SACL,IAAK,YACL,IAAK,WACL,IAAK,iBACL,IAAK,kBACL,IAAK,mBACL,IAAK,mBACL,IAAK,uBACL,IAAK,qBACL,IAAK,iBACL,IAAK,aACL,IAAK,gBACL,IAAK,oBACL,IAAK,YACL,IAAK,iBACL,IAAK,iBACL,IAAK,iBACL,IAAK,gBACL,IAAK,WACL,IAAK,WACL,IAAK,YACL,IAAK,iBACL,IAAK,OACL,IAAK,cACL,IAAK,YACL,IAAK,YACL,IAAK,cACL,IAAK,kBACL,IAAK,kBACL,IAAK,kBACL,IAAK,kBACL,IAAK,wBACL,IAAK,mBACL,IAAK,gBACL,IAAK,gBAKL,IAAK,gBACL,IAAK,uBACL,IAAK,qBAKL,IAAK,gBACL,IAAK,oBACL,IAAK,mBACL,IAAK,iBACL,IAAK,sBACL,IAAK,gBACL,IAAK,sBACL,IAAK,aACL,IAAK,gBACL,IAAK,YACL,IAAK,kBAA8C,MArBnD,IAAK,2BACA8K,EAAS,cAAaA,EAAS,YAAc,CAAA,GACjDA,EAAS,YAAY1E,OAAQ,EAC7B,MAID,IAAK,8BACA0E,EAAS,cAAaA,EAAS,YAAc,CAAA,GACjDA,EAAS,YAAYplE,MAAO,EAC5B,MAYD,QAASnB,GAAO,EACf,MAGF,IAAK,aAAoC,IAAK,aAAoC,OAAO0lE,EAAG,IAC3F,IAAK,uBACL,IAAK,4BACL,IAAK,mBACL,IAAK,WACL,IAAK,aACL,IAAK,cACL,IAAK,aACL,IAAK,yBACL,IAAK,mBACL,IAAK,WACL,IAAK,YACL,IAAK,WACL,IAAK,YACL,IAAK,aACL,IAAK,cACL,IAAK,cACL,IAAK,aACL,IAAK,mBACL,IAAK,OACL,IAAK,WACL,IAAK,WACL,IAAK,aACL,IAAK,yBACL,IAAK,WACL,IAAK,YACL,IAAK,gBACL,IAAK,aACL,IAAK,sBACL,IAAK,SACL,IAAK,WACL,IAAK,YACL,IAAK,gBACL,IAAK,WACL,IAAK,oBACL,IAAK,iBACL,IAAK,cACL,IAAK,iBACL,IAAK,cACL,IAAK,cACL,IAAK,kBACL,IAAK,qBACL,IAAK,oBACL,IAAK,uBACL,IAAK,wBACL,IAAK,cAAsC,MAC3C,QAAS1lE,GAAO,EACf,MAGF,IAAK,aAAoC,OAAO0lE,EAAG,IAClD,IAAK,YACL,IAAK,WACL,IAAK,YACL,IAAK,WACL,IAAK,WACL,IAAK,SACL,IAAK,SAA4B,MACjC,QAAS1lE,GAAO,EACf,MAGF,IAAK,aAAoC,OAAO0lE,EAAG,IAClD,IAAK,mBACL,IAAK,sBACL,IAAK,gBACL,IAAK,eAAwC,MAC7C,QAAS1lE,GAAO,EACf,MAGF,IAAK,aAAoC,OAAO0lE,EAAG,IAClD,IAAK,KACL,IAAK,iBACL,IAAK,oBACL,IAAK,cACL,IAAK,YACL,IAAK,qBACL,IAAK,iBACL,IAAK,YACL,IAAK,aACL,IAAK,aACL,IAAK,cACL,IAAK,cACL,IAAK,WACL,IAAK,SACL,IAAK,aACL,IAAK,iBACL,IAAK,qBACL,IAAK,qBACL,IAAK,SACL,IAAK,SACL,IAAK,UACL,IAAK,oBACL,IAAK,uBACL,IAAK,iBACL,IAAK,YACL,IAAK,aACL,IAAK,MACL,IAAK,QACL,IAAK,iBACL,IAAK,kBACL,IAAK,qBAAoD,MACzD,QAAS1lE,GAAO,EACf,MAEF,IAAK,iBACL,OAAO0lE,EAAG,IACT,IAAK,QAEL,IAAK,OACL,IAAK,MACL,IAAK,MACL,IAAK,OACL,IAAK,aACL,IAAK,QACL,IAAK,gBACL,IAAK,QACL,IAAK,aACL,IAAK,eACL,IAAK,aACL,IAAK,eACL,IAAK,aACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,WACL,IAAK,SACL,IAAK,SACL,IAAK,SAEL,IAAK,gBAA0C,MAC/C,QAAS1lE,GAAO,EACf,MAEF,IAAK,UACL,IAAK,wBACL,OAAO0lE,EAAG,IACT,IAAK,QACL,IAAK,OACL,IAAK,MACL,IAAK,MACL,IAAK,OACL,IAAK,aACL,IAAK,QACL,IAAK,gBACL,IAAK,QACL,IAAK,aACL,IAAK,eACL,IAAK,aACL,IAAK,gBACL,IAAK,eACL,IAAK,aACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,YACL,IAAK,WACL,IAAK,SACL,IAAK,SACL,IAAK,SAA4B,MACjC,QAAS1lE,GAAO,EACf,MAGF,IAAK,UAA8B,IAAK,SAA4B,IAAK,OAAwB,OAAO0lE,EAAG,IAC1G,IAAK,MACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,UACL,IAAK,WACL,IAAK,YACL,IAAK,cACL,IAAK,gBAEL,IAAK,SACL,IAAK,UACL,IAAK,cACL,IAAK,WACL,IAAK,MACL,IAAK,YACL,IAAK,UAEL,IAAK,MAAsB,MAC3B,QAAS1lE,GAAO,EACf,MAGF,IAAK,YAAkC,MAEvC,QAASA,GAAO,EAEjB,GAAGA,EAAM,MAET,GAAG0lE,EAAG,GAAGv2E,MAAM,YAAa,MAC5B,IAAI2+B,EAAMA,EAAM36D,OAAO,GAAG,GAAI,KAAM,qBAAuBuyG,EAAG,GAAK,IAAM53C,EAAMx0D,KAAK,KACpF,GAA4D,6BAAzDw0D,EAAMA,EAAM36D,OAAO,GAAG,GAA+D,CACvF,GAAuB,OAApBuyG,EAAG,GAAG9xG,OAAM,GAAc,MACb,MAAR8xG,EAAG,GAAUlB,GAAkBC,EAAWuC,EAAStpD,EAAI9jD,EAAIhG,MAAMgzG,EAAMlB,EAAGvwG,SAC3EuoD,EAAKgoD,EAAIkB,EAAOlB,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,QACxC,KACD,CACA,GAAGquD,EAAK+e,IAAK,KAAM,qBAAuBmlC,EAAG,GAAK,IAAM53C,EAAMx0D,KAAK,KAErE,IAAIsmB,EAAO,GAOX,OANI4hC,EAAKknD,YAAelnD,EAAKmnD,YAAW/oF,EAAIwmD,OAASF,GACrDtmD,EAAIumD,WAAamgC,EACjB1mF,EAAIknF,SAAWA,EACflnF,EAAIgpF,IAAMzsC,GAAItb,IACdjhC,EAAIouD,MAAQA,EACZpuD,EAAI6kF,UAAYA,EACT7kF,CACR,CAEA,SAASipF,GAAWhsG,EAA0B2kD,GAE7C,OADAsnD,GAActnD,EAAKA,GAAM,CAAA,GAClBA,EAAKhgD,MAAM,UACjB,IAAK,SAAU,OAAOikG,GAAe9mD,GAAc9hD,GAAO2kD,GAC1D,IAAK,SAAU,IAAK,SAAU,IAAK,OAAQ,OAAOikD,GAAe5oG,EAAM2kD,GACvE,IAAK,QAAS,OAAOikD,GAAe/lD,GAAI7iD,GAAO2kD,GAGjD,CA2TA,SAASunD,GAAct0E,GACtB,IAAI5zB,EAAI,CAAA,EACJixC,EAAIrd,EAAIy5B,QASZ,GALApc,EAAEh1C,EAAI,GAEN+D,EAAEmoG,aAAel3D,EAAEuY,WAAW,EAAG,cACjCxpD,EAAEooG,oBAv/aH,SAA2Cn3D,GAAK,OAAO62B,GAA8B72B,EAAG,EAAI,CAu/anEo3D,CAAkCp3D,GAEvDA,EAAE3+C,OAAS2+C,EAAEh1C,GAAK,EAAG,OAAO+D,EAE/B,IAAIjC,EAAekzC,EAAEuY,WAAW,GAChC,OAAQ,GAALzrD,GAAUA,EAAI,GAAWiC,GAC5BixC,EAAEh1C,GAAG,EAAG+D,EAAEsoG,UAAYr3D,EAAEuY,WAAW,EAAG,cAEnCvY,EAAE3+C,OAAS2+C,EAAEh1C,GAAK,GAEZ,cADT8B,EAAIkzC,EAAEuY,WAAW,IADcxpD,GAG/BA,EAAEuoG,uBAjgbH,SAA8Ct3D,GAAK,OAAO62B,GAA8B72B,EAAG,EAAI,CAigbnEu3D,CAAqCv3D,GAGxD,IADRlzC,EAAIkzC,EAAEuY,WAAW,KACJzrD,EAAI,GAAWiC,GAC5BixC,EAAEh1C,GAAG,OAAG+D,EAAEyoG,UAAYx3D,EAAEuY,WAAW,EAAG,aACvC,CAUA,IAAIk/C,GAAc,CAAE,GAAQ,KAAQ,KAAQ,KAAQ,MACpD,SAASC,GAAMC,EAAYhzD,EAAGtG,EAAMh9C,EAAmBquD,GACtD,IAAI1kD,EAAI3J,EACJ0sD,EAAO,GACP9nC,EAAIo4B,EAAKv8C,MAAMu8C,EAAKrzC,EAAEqzC,EAAKrzC,EAAEA,GACjC,GAAG0kD,GAAQA,EAAKrC,KAAOqC,EAAKrC,IAAIqrC,QAAUzyE,EAAE5kB,OAAS,EAAG,OAAOs2G,GAC/D,KAAK,EAAQ,KAAK,IAAQ,KAAK,KAAQ,KAAK,KAAiB,KAAK,GAAuB,KAAK,IAAuB,KAAK,IAA2B,KAAK,IAAsB,KAAK,IAAsB,KAAK,IAAsB,QAEtO,KAAK,IACJ,MACD,QACCjoD,EAAKrC,IAAIqrC,OAAOzyE,GAEjB8nC,EAAKzmD,KAAK2e,GACVo4B,EAAKrzC,GAAKA,EAGV,IAFA,IAAI4sG,EAASzoC,GAAe9wB,EAAKA,EAAKrzC,GAAIg2B,EAAO62E,GAAcD,GAC3Dt8E,EAAQ,EACE,MAAR0F,GAAgBy2E,GAAY92E,QAAQi3E,IAAU,GACnD5sG,EAAImkE,GAAe9wB,EAAKA,EAAKrzC,EAAE,GAC/BswB,EAAQ+iB,EAAKrzC,EAAI,EACJ,MAAV4sG,EAAoCt8E,GAAS,EAC9B,MAAVs8E,GAA8B,MAAVA,IAC3Bt8E,GAAS,IAEVrV,EAAIo4B,EAAKv8C,MAAMw5B,EAAM+iB,EAAKrzC,EAAE,EAAEA,GAC9B+iD,EAAKzmD,KAAK2e,GACVo4B,EAAKrzC,GAAK,EAAEA,EACZg2B,EAAQ62E,GAAcD,EAASzoC,GAAe9wB,EAAMA,EAAKrzC,IAE1D,IAAIsJ,EAAKw5C,GAAQC,GACjBuK,GAAUhkD,EAAG,GACb,IAAIwjG,EAAK,EAAGxjG,EAAE08D,KAAO,GACrB,IAAI,IAAItuE,EAAI,EAAGA,EAAIqrD,EAAK1sD,SAAUqB,EAAK4R,EAAE08D,KAAK1pE,KAAKwwG,GAAKA,GAAM/pD,EAAKrrD,GAAGrB,OACtE,GAAGiT,EAAEjT,OAASA,EAAQ,KAAM,gBAAkBs2G,EAAWj3G,SAAS,IAAM,eAAiB4T,EAAEjT,OAAS,MAAQA,EAC5G,OAAOsjD,EAAErhC,EAAEhP,EAAGA,EAAEjT,OAAQquD,EACzB,CAEA,SAASqoD,GAAe9qG,EAAWyiD,EAAoBK,GACtD,GAAW,MAAR9iD,EAAEoT,GACDpT,EAAE6mE,GAAN,CACA,IAAIk0B,EAAQ,EACZ,IACCA,EAAQ/6F,EAAEqa,GAAKra,EAAE6mE,GAAGC,UAAY,EAC7BrkB,EAAK4/B,SAAQriF,EAAEqa,EAAIynC,GAAUi5C,GACjC,CAAE,MAAMx3F,GAAK,GAAGk/C,EAAK+e,IAAK,MAAMj+D,CAAG,CACnC,IAAIk/C,IAA0B,IAAlBA,EAAK2/B,SAAoB,IACzB,MAARpiF,EAAEoT,EAAapT,EAAE6Z,EAAI7Z,EAAE6Z,GAAKmtD,GAAKhnE,EAAE8B,GACpB,IAAVi5F,GAAwB,WAATA,EACX,MAAR/6F,EAAEoT,GACI,EAAJpT,EAAE8B,KAAS9B,EAAE8B,EAAG9B,EAAE6Z,EAAI7Z,EAAE8B,EAAErO,SAAS,IAClCuM,EAAE6Z,EAAIgqC,GAAgB7jD,EAAE8B,GAEzB9B,EAAE6Z,EAAIqqC,GAAYlkD,EAAE8B,GAErB9B,EAAE6Z,EAAIsqC,GAAW42C,EAAM/6F,EAAE8B,EAAG,CAACghD,WAAWA,EAAUgF,OAAQrF,GAAQA,EAAKqF,QAC7E,CAAE,MAAMvkD,GAAK,GAAGk/C,EAAK+e,IAAK,MAAMj+D,CAAG,CACnC,GAAGk/C,EAAKylB,WAAa6yB,GAAgB,KAAP/6F,EAAEoT,GAAYk0C,GAAYxF,GAAUi5C,IAAUtwE,OAAOswE,IAAS,CAC3F,IAAI4H,EAAKngD,GAAoBxiD,EAAE8B,GAAO6gG,IAAM3iG,EAAEoT,EAAI,IAAKpT,EAAE8B,EAAI,IAAIs+B,KAAKuiE,EAAGr8F,EAAGq8F,EAAG9iG,EAAE,EAAE8iG,EAAG3pF,EAAE2pF,EAAGlpF,EAAEkpF,EAAG5xE,EAAE4xE,EAAG1uD,EAAE0uD,EAAGjnF,GAC3G,CAnBU,CAoBX,CAEA,SAASqvF,GAAUvkF,EAAKutD,EAAM3gE,GAC7B,MAAQ,CAACtR,EAAE0kB,EAAKutD,KAAKA,EAAM3gE,EAAEA,EAC9B,CAGA,SAAS43F,GAAe55D,EAAM18C,GAC7B,IAUIu2G,EAA0BzlD,EAAa0lD,EAAMC,EAAMC,EAGnDC,EACAC,EA8DA/b,EA5EAjK,EAAM,CAAC7iC,KAAK,CAAA,GACZ4kB,EAAS,CAAA,EAETxmD,EAAsBnsB,EAAQ8yE,MAAQ,GAAK,CAAA,EAC3C+jC,EAAY,GACZ/yF,EAAmB,CAAA,EACnBgzF,EAAe,KACf/H,EAAe,GACfgI,EAAY,GACZC,EAAW,CAAA,EACDC,EAAY,GACtBtS,EAAU,CAAA,EACVG,EAAoC,GAGpCoS,EAAM,GACNC,EAA8C,GAC9C9D,EAA0B,CAAE1gC,OAAO,GAAI65B,QAAQ,CAACp+C,UAAS,GAAQu5C,MAAM,CAAC,CAAA,IAAgB2L,EAAU,CAAA,EAClG8D,EAAU,SAAgBxb,GAC7B,OAAGA,EAAM,EAAUlmB,GAAOkmB,GACvBA,EAAM,IAAWub,EAAQvb,EAAI,IACzBlmB,GAAOkmB,EACf,EAUIyb,EAAU,SAAiBtmC,EAAcrrE,EAAc1F,GAC1D,KAAGs3G,EAAa,GACbt3G,EAAQwkF,WAAazT,EAAK3+D,GAAKpS,EAAQwkF,WAA1C,CAUA,GATGxkF,EAAQ+iF,YAAcr9E,EAAKysE,IAAMzsE,EAAKysE,GAAG/oE,MAZpB,SAAa2nE,EAAMrrE,EAAc1F,GACzD,IAII0e,EAJA64F,EAAM7xG,EAAKysE,GAAG/oE,KACdmuG,GAAQA,EAAIrb,aAAgBl8F,GAAYA,EAAQ+iF,aACpDr9E,EAAK+I,EAAK,GACV/I,EAAK+I,EAAEytF,YAAcqb,EAAIrb,aAErBx9E,EAAIq5E,GAAQqf,EAAQG,EAAIC,aAAc9xG,EAAK+I,EAAE2tF,QAAU,CAAC1K,IAAIhzE,KAC5DA,EAAIq5E,GAAQqf,EAAQG,EAAIE,aAAc/xG,EAAK+I,EAAE0tF,QAAU,CAACzK,IAAIhzE,IACjE,CAImDg5F,CAAmB3mC,EAAMrrE,EAAM1F,UAC1E0F,EAAK25E,YAAa35E,EAAKysE,GAC9BokC,EAAWxlC,EACXkmC,EAAY5lC,GAAYN,GACpBjtD,GAAUA,EAAMrV,GAAMqV,EAAMjV,IAAGiV,EAAQ,CAACrV,EAAE,CAAC2D,EAAE,EAAEC,EAAE,GAAGxD,EAAE,CAACuD,EAAE,EAAEC,EAAE,KAC9D0+D,EAAK3+D,EAAI0R,EAAMrV,EAAE2D,IAAG0R,EAAMrV,EAAE2D,EAAI2+D,EAAK3+D,GACrC2+D,EAAK1+D,EAAIyR,EAAMrV,EAAE4D,IAAGyR,EAAMrV,EAAE4D,EAAI0+D,EAAK1+D,GACrC0+D,EAAK3+D,EAAI,EAAI0R,EAAMjV,EAAEuD,IAAG0R,EAAMjV,EAAEuD,EAAI2+D,EAAK3+D,EAAI,GAC7C2+D,EAAK1+D,EAAI,EAAIyR,EAAMjV,EAAEwD,IAAGyR,EAAMjV,EAAEwD,EAAI0+D,EAAK1+D,EAAI,GAC7CrS,EAAQ+qG,aAAerlG,EAAKic,EAC9B,IAAI,IAAIg2F,EAAM,EAAGA,EAAM7S,EAAOplG,SAAUi4G,EACvC,KAAG7S,EAAO6S,GAAK,GAAGlpG,EAAE4D,EAAI0+D,EAAK1+D,GAAKyyF,EAAO6S,GAAK,GAAGlpG,EAAE2D,EAAI2+D,EAAK3+D,GACzD0yF,EAAO6S,GAAK,GAAG9oG,EAAEwD,EAAI0+D,EAAK1+D,GAAKyyF,EAAO6S,GAAK,GAAG9oG,EAAEuD,EAAI2+D,EAAK3+D,GAA5D,CACA1M,EAAKw9B,EAAI8uC,GAAa8yB,EAAO6S,GAAK,IAC/B7S,EAAO6S,GAAK,GAAGlpG,EAAE4D,GAAK0+D,EAAK1+D,GAAKyyF,EAAO6S,GAAK,GAAGlpG,EAAE2D,GAAK2+D,EAAK3+D,UAAU1M,EAAKic,EAC1Ejc,EAAKic,IAAGjc,EAAKic,EAAI,GAAKmiF,GAAkBgB,EAAO6S,GAAK,GAAI7zF,EAAOitD,EAAMwyB,EAAUx1C,IAClF,KAJ+D,CAQ7D/tD,EAAQ8yE,OACN3mD,EAAI4kD,EAAK3+D,KAAI+Z,EAAI4kD,EAAK3+D,GAAK,IAC/B+Z,EAAI4kD,EAAK3+D,GAAG2+D,EAAK1+D,GAAK3M,GAChBymB,EAAI8qF,GAAavxG,CAxB4B,CA0BtD,EACIqoD,EAAQ,CACXrC,KAAK,EACL81B,MAAO,EACP+M,OAAQ,GACRoW,QAASA,EACTG,OAAQA,EACR8S,QAAS,GACTC,SAAU,GACV3mC,KAAM,EACNkT,SAAU,EACV0zB,UAAW,EACX/0B,aAAc/iF,KAAaA,EAAQ+iF,WACnCjW,MAAO9sE,KAAaA,EAAQ+3G,KAE1B/3G,EAAQw1F,WAAUznC,EAAKynC,SAAWx1F,EAAQw1F,UAE7C,IAAImT,EAA0B,GAC1BqP,EAAU,GACVpuB,EAA6B,GAAID,EAA6B,GAC9Due,GAAU,EACV3E,EAAY,GAChBA,EAAS7wB,WAAa3kB,EAAKwgC,OAC3BgV,EAASoB,QAAU52C,EAAK42C,QACxBpB,EAASuB,OAAS/2C,EAAK+2C,OACvBvB,EAASa,MAAQ,GACjBb,EAASC,IAAM,GACf,IAIIyU,EAJAC,EAAU,EACVZ,EAAa,EACba,EAAW,EAAGC,EAAkC,GAChDC,EAAkB,GAItBtqD,EAAKq2B,SAAW,KAChBl6B,GAAO,MAEP,IADA,IAAIouD,GAAgB,EACd57D,EAAKrzC,EAAIqzC,EAAKh9C,OAAS,GAAG,CAC/B,IAAI+O,EAAIiuC,EAAKrzC,EACT2sG,EAAat5D,EAAKka,WAAW,GACjC,GAAkB,IAAfo/C,GAAgC,KAAZkC,EAA8B,MACrD,IAAIx4G,EAAUg9C,EAAKrzC,IAAMqzC,EAAKh9C,OAAS,EAAIg9C,EAAKka,WAAW,GACvD5T,EAAIkzD,GAAcF,GAGtB,GAAGhzD,GAAKA,EAAErhC,EAAG,CACZ,GAAG3hB,EAAQi1G,YACK,MAAZiD,GAAuD,MAAflC,EAAmD,MAG/F,GADAkC,EAAUlC,EACC,IAARhzD,EAAE5wC,GAAkB,IAAP4wC,EAAE5wC,EAAS,CAC1B,IAAI+vF,EAAKzlD,EAAKka,WAAW,GACzB,GAD6Bl3D,GAAU,GACnCquD,EAAKrC,KAAOy2C,IAAO6T,KAAoB,IAAH7T,IAAU,EAAIA,GAAI,KAAQ6T,EAAY,MAAM,IAAI30G,MAAM,gBAAkB8gG,EAAK,KAAO6T,GAClH,IAAPhzD,EAAE5wC,IACJsqC,EAAKrzC,GAAK,GAAI3J,GAAU,GAE1B,CAEA,IAAIoyB,EAAe,CAAA,EAInB,GAHoCA,EAAlB,KAAfkkF,EAA8ChzD,EAAErhC,EAAE+6B,EAAMh9C,EAAQquD,GACjDgoD,GAAMC,EAAYhzD,EAAGtG,EAAMh9C,EAAQquD,GAEpC,GAAdupD,QAAmB,CAAC,EAAQ,IAAQ,KAAQ,MAAQt4E,QAAQk5E,GAA6B,SAC5F,OAAOlC,GACN,KAAK,GAEJplB,EAAG7iC,KAAKwqD,SAAWlF,EAAS7G,QAAQp+C,SAAWt8B,EAAK,MACrD,SAAgC8+D,EAAG7iC,KAAKyqD,cAAe,EAAM,MAC7D,KAAK,GAGJ,GAFIzqD,EAAKrC,MAAKhP,EAAKrzC,EAAI,GACvB0kD,EAAKrC,IAAM55B,GACP9xB,EAAQw1F,SAAU,MAAM,IAAIn0F,MAAM,8BACtC,GAAgB,MAAbywB,EAAIiiE,MAAe,MAAM,IAAI1yF,MAAM,iCACtC,IAAIywB,EAAIiiE,MAAO,MAAM,IAAI1yF,MAAM,yBAC/B,MACD,KAAK,GAA0B0sD,EAAK8pD,SAAW/lF,EAAK,MACpD,KAAK,GACJ,IAAI2mF,EAAQ72G,OAAOkwB,GAEnB,OAAO2mF,GACN,WAAaA,EAAS,KAAM,MAC5B,WAAaA,EAAQ,IAAO,MAC5B,WAAaA,EAAS,KAEvBvuD,GAAO6D,EAAKq2B,SAAWq0B,GACvBH,GAAgB,EAChB,MACD,KAAK,IAAsBvqD,EAAK6pD,QAAU9lF,EAAK,MAC/C,QAA8Bi8B,EAAK+pD,UAAYhmF,EAAK,MACpD,KAAK,IAAyB8+D,EAAG7iC,KAAiB,WAAIj8B,EAAK,MAC3D,QAA6B8+D,EAAG7iC,KAAgB,UAAIj8B,EAAK,MACzD,KAAK,GAAwB8+D,EAAG7iC,KAAgB,UAAIj8B,EAAK,MACzD,KAAK,GAAuB8+D,EAAG7iC,KAAe,SAAIj8B,EAAK,MACvD,KAAK,GAAuB8+D,EAAG7iC,KAAe,SAAIj8B,EAAK,MACvD,KAAK,GAA4B8+D,EAAG7iC,KAAoB,cAAIj8B,EAAK,MACjE,KAAK,GAA6B8+D,EAAG7iC,KAAqB,eAAIj8B,EAAK,MACnE,KAAK,GAA0Bi8B,EAAK2qD,YAAc5mF,EAAK,MACvD,UAAwC8+D,EAAG7iC,KAAK4qD,SAAW7mF,EAAK,MAChE,KAAK,IACDA,EAAI8mF,UAASzsF,EAAI,SAAW,UAC3B2F,EAAI+mF,UAAS1sF,EAAI,cAAgBA,EAAI,YAAc,KAAKiiF,OAAQ,GAChEt8E,EAAIgnF,UAAS3sF,EAAI,cAAgBA,EAAI,YAAc,CAAA,IAAKuhB,MAAO,GACnE,MACD,KAAK,IACJwpE,EAAIvxG,KAAKmsB,GAAM,MAChB,SACCyxE,EAAS59F,KAAK,CAACmsB,IACfyxE,EAASA,EAAS7jG,OAAO,GAAG8jG,IAAM,GAClC,MACD,KAAK,GAAQ,KAAK,IACjBD,EAASA,EAAS7jG,OAAO,GAAGiG,KAAKmsB,GACjC,MACD,KAAK,GAAQ,KAAK,IACjBmmF,EAAY,CACXt2B,KAAM7vD,EAAI6vD,KACVwrB,IAAKrJ,GAAkBhyE,EAAIowD,KAAKp+D,EAAM,KAAKy/E,EAASx1C,IAElDj8B,EAAIkwD,KAAO,IAAGi2B,EAAS/K,MAAQp7E,EAAIkwD,KAAO,GAC7CuhB,EAASa,MAAMz+F,KAAKsyG,GAChB1U,EAAS,KAAMA,EAAS,GAAK,GAAIA,EAAS,GAAGC,IAAM,IACvDD,EAASA,EAAS7jG,OAAO,GAAGiG,KAAKmsB,GAClB,yBAAZA,EAAI6vD,MAAmC7vD,EAAIkwD,KAAO,GACjDlwD,EAAIowD,MAAQpwD,EAAIowD,KAAK,IAAMpwD,EAAIowD,KAAK,GAAG,IAA2B,aAArBpwD,EAAIowD,KAAK,GAAG,GAAG,KAC9Dm2B,EAAgBvmF,EAAIkwD,KAAO,GAAK,CAAEU,IAAK1Q,GAAalgD,EAAIowD,KAAK,GAAG,GAAG,GAAG,MACxE,MACD,KAAK,GAA0Bn0B,EAAKgrD,YAAcjnF,EAAK,MACvD,KAAK,GACkB,GAAnByxE,EAAS7jG,SAAe6jG,EAAS,GAAK,GAAIA,EAAS,GAAGC,IAAM,IAC/DD,EAASA,EAAS7jG,OAAS,GAAG8jG,IAAMD,EAASA,EAAS7jG,OAAS,GAAG8jG,IAAIhqE,OAAO1H,GAAMyxE,EAASC,IAAMD,EAASC,IAAIhqE,OAAO1H,GAAM,MAC7H,KAAK,KAEJ,GAAGi8B,EAAKmjB,KAAO,EAAG,MACH,MAAZ+mC,IAAkBA,EAASxK,QAAU37E,EAAI,IAC5C,MACD,QAA2B3F,EAAI,YAAc2F,EAAK,MAClD,KAAK,GAAkC,IAARA,GAAai8B,EAAK+e,KAAKv6D,QAAQyR,MAAM,sBAAwB8N,GAAM,MAClG,KAAK,IACJ+kF,EAAU/kF,EAAIk+C,KAAOl+C,EACrBi8B,EAAKwgC,OAAO5oF,KAAKmsB,EAAI5sB,MACpB,MACF,KAAK,GACJ,KAAKoyG,EAAY,MACjB,GAAGxzF,EAAMjV,EAAG,CACX,GAAGiV,EAAMjV,EAAEuD,EAAI,GAAK0R,EAAMjV,EAAEwD,EAAI,EAAG,CAGlC,GAFAyR,EAAMjV,EAAEuD,IAAK0R,EAAMjV,EAAEwD,IACrB8Z,EAAI,QAAU6lD,GAAaluD,GACxB9jB,EAAQwkF,WAAaxkF,EAAQwkF,WAAa1gE,EAAMjV,EAAEuD,EAAG,CACvD,IAAI4mG,EAAQl1F,EAAMjV,EAAEuD,EACpB0R,EAAMjV,EAAEuD,EAAIpS,EAAQwkF,UAAY,EAChCr4D,EAAI,YAAcA,EAAI,QACtBA,EAAI,QAAU6lD,GAAaluD,GAC3BA,EAAMjV,EAAEuD,EAAI4mG,CACb,CACAl1F,EAAMjV,EAAEuD,IAAK0R,EAAMjV,EAAEwD,GACtB,CACGs2F,EAAOjpG,OAAS,IAAGysB,EAAI,WAAaw8E,GACpCqP,EAAQt4G,OAAS,IAAGysB,EAAI,YAAc6rF,GACtCpuB,EAAQlqF,OAAS,IAAGysB,EAAI,SAAWy9D,GACnCD,EAAQjqF,OAAS,IAAGysB,EAAI,SAAWw9D,GACtC0pB,EAAS1gC,OAAOhtE,KAAK2tG,EACtB,CACiB,KAAdyD,EAAkBC,EAAW7qF,EAAUwmD,EAAOokC,GAAa5qF,EAC9DA,EAAQnsB,EAAQ8yE,MAAQ,GAAK,CAAA,EAC5B,MACF,KAAK,EAAQ,SAAa,KAAK,KAAQ,KAAK,KAiB3C,GAhBiB,IAAd/kB,EAAKmjB,OAAYnjB,EAAKmjB,KAAO,CACxB,EAAc,EACd,IAAc,EACd,KAAc,GACpB8kC,IAAe,CACT,IAAc,EACd,IAAc,EACd,KAAc,EACd,KAAc,EACd,KAAc,EACd,EAAc,EACd,EAAc,GACpBlkF,EAAIsuD,UAAY,GAClBryB,EAAKkrD,UAA2B,GAAfnnF,EAAIsuD,QACH,GAAftuD,EAAIsuD,SAA0B,MAAVtuD,EAAIwhC,KAAgBvF,EAAKmjB,KAAO,EAAGonC,GAAgB,EAAMpuD,GAAO6D,EAAKq2B,SAAW,QACvF,GAAbr2B,EAAKmjB,MAA4B,GAAfp/C,EAAIsuD,SAA0B,IAAVtuD,EAAIwhC,KAAUvF,EAAKmjB,KAAO,GAChEomC,IAAc,MAKjB,GAJAnrF,EAAQnsB,EAAQ8yE,MAAQ,GAAK,CAAA,EAE1B/kB,EAAKmjB,KAAO,IAAMonC,IAAiBA,GAAgB,EAAMpuD,GAAO6D,EAAKq2B,SAAWpkF,EAAQokF,UAAY,OAEpGr2B,EAAKmjB,KAAO,GAAoB,GAAfp/C,EAAIsuD,SAA0B,MAAVtuD,EAAIwhC,GAAc,CACxC,KAAdyjD,IAAkBA,EAAY,UACjCjzF,EAAQ,CAACrV,EAAE,CAAC2D,EAAE,EAAEC,EAAE,GAAGxD,EAAE,CAACuD,EAAE,EAAEC,EAAE,IAE9B,IAAI6mG,EAAU,CAAClpC,IAAKtzB,EAAKrzC,EAAI3J,EAAQwF,KAAK6xG,GAC1CF,EAAUqC,EAAQlpC,KAAOkpC,EACzBnrD,EAAKwgC,OAAO5oF,KAAKoxG,EAClB,MACKA,GAAaF,EAAUpoG,IAAM,CAACvJ,KAAK,KAAKA,KAChC,IAAV4sB,EAAIwhC,KAAYnnC,EAAI,SAAW,SACrB,IAAV2F,EAAIwhC,KAAYnnC,EAAI,SAAW,SAClCw8E,EAAS,GACTqP,EAAU,GACVjqD,EAAK+2C,OAASA,EAAS,GACvBlb,EAAU,GAAID,EAAU,GACxBue,GAAU,EACVoL,EAAU,CAAC9F,QAAQqJ,EAAUpoG,IAAI,CAACm3B,GAAG,IAAIA,GAAI1gC,KAAK6xG,GACjD,MACF,KAAK,IAAqB,OAA4B,KAAK,EACvC,SAAhB5qF,EAAI,WAAwBnsB,EAAQ8yE,OAAS3mD,EAAI2F,EAAI1f,IAAI,IAAI0f,EAAIzf,GAAI8Z,EAAIklD,GAAY,CAACh/D,EAAEyf,EAAIzf,EAAGD,EAAE0f,EAAI1f,SAAQ0f,EAAIzf,EACpHskG,EAAY,CAACt3B,KAAMvtD,EAAIutD,KAAMlN,GAAI+kC,EAAIplF,EAAIutD,OAAO,GAAIjyE,EAAE0kB,EAAIA,IAAKpT,EAAE,KAC9Dy5F,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEyf,EAAIzf,EAAGD,EAAE0f,EAAI1f,GAAIukG,EAAU32G,GACrC,MACF,KAAK,EAAQ,KAAK,IACjB22G,EAAY,CAACt3B,KAAMvtD,EAAIutD,KAAMlN,GAAI+kC,EAAIplF,EAAIutD,MAAOjyE,EAAE0kB,EAAIA,IAAKpT,EAAEoT,EAAIpT,GAC9Dy5F,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEyf,EAAIzf,EAAGD,EAAE0f,EAAI1f,GAAIukG,EAAU32G,GACrC,MACF,KAAK,IACJ22G,EAAY,CAACt3B,KAAMvtD,EAAIutD,KAAMlN,GAAI+kC,EAAIplF,EAAIutD,MAAOjyE,EAAE0kB,EAAIqnF,MAAOz6F,EAAE,KAC5Dy5F,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEyf,EAAIzf,EAAGD,EAAE0f,EAAI1f,GAAIukG,EAAU32G,GACrC,MACF,KAAK,IACJ,IAAI,IAAIe,EAAI+wB,EAAIzf,EAAGtR,GAAK+wB,EAAI5E,IAAKnsB,EAAG,CACnC,IAAIs+E,EAAOvtD,EAAIsnF,MAAMr4G,EAAE+wB,EAAIzf,GAAG,GAC9BskG,EAAW,CAACt3B,KAAKA,EAAMlN,GAAG+kC,EAAI73B,GAAOjyE,EAAE0kB,EAAIsnF,MAAMr4G,EAAE+wB,EAAIzf,GAAG,GAAIqM,EAAE,KAC7Dy5F,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEtR,EAAGqR,EAAE0f,EAAI1f,GAAIukG,EAAU32G,EACnC,CACC,MACF,KAAK,EAAQ,KAAK,IAAQ,KAAK,KAC9B,GAAc,UAAX8xB,EAAIA,IAAiB,CAAEglF,EAAehlF,EAAK,KAAO,CAGrD,IAFA6kF,EAAWN,GAAUvkF,EAAIA,IAAKA,EAAIi/C,KAAKsO,KAAMvtD,EAAIg+B,KACxCqiB,GAAK+kC,EAAIP,EAASt3B,MACxBr/E,EAAQ+qG,YAAa,CACvB,IAAIrlB,EAAK5zD,EAAIu4D,QACb,GAAG3E,GAAMA,EAAG,IAAMA,EAAG,GAAG,IAAqB,UAAfA,EAAG,GAAG,GAAG,GAAgB,CACtD,IAAI2zB,GAAM3zB,EAAG,GAAG,GAAG,GAAG,GAAI4zB,GAAM5zB,EAAG,GAAG,GAAG,GAAG,GACxC6zB,GAAMloC,GAAY,CAACj/D,EAAEinG,GAAKhnG,EAAEinG,KAC7B3U,EAAQ4U,IAAM5C,EAASh1F,EAAI,GAAGmiF,GAAkBhyE,EAAIu4D,QAAQvmE,EAAMgO,EAAIi/C,KAAKwyB,EAAUx1C,GACnF4oD,EAASzzE,IAAMljC,EAAQ8yE,OAAS3mD,EAAIktF,KAAM,IAAIC,IAAMntF,EAAIotF,MAAS,CAAA,GAAIr2E,CAC3E,MAAOyzE,EAASh1F,EAAI,GAAGmiF,GAAkBhyE,EAAIu4D,QAAQvmE,EAAMgO,EAAIi/C,KAAKwyB,EAAUx1C,EAC/E,CACGoqD,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQvlF,EAAIi/C,KAAM4lC,EAAU32G,GAC5B82G,EAAehlF,EACd,MACF,OAAa,KAAK,IACjB,IAAGglF,EAWI,MAAM,IAAIz1G,MAAM,iCAVtBy1G,EAAahlF,IAAMA,GACnB6kF,EAAWN,GAAUvkF,EAAKglF,EAAa/lC,KAAKsO,KAAM,MACzClN,GAAK+kC,EAAIP,EAASt3B,MACxBr/E,EAAQ+qG,cACV4L,EAASh1F,EAAI,GAAGmiF,GAAkBgT,EAAazsB,QAASvmE,EAAOgzF,EAAa/lC,KAAMwyB,EAAUx1C,IAE1FoqD,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQP,EAAa/lC,KAAM4lC,EAAU32G,GACrC82G,EAAe,KAEf,MACF,KAAK,GAAQ,KAAK,IACjBhS,EAAOn/F,KAAKmsB,GACZ,IAAI0nF,GAAcnoC,GAAYv/C,EAAI,GAAGrjB,GAErC,GADAqiD,EAAK9wD,EAAQ8yE,OAAS3mD,EAAI2F,EAAI,GAAGrjB,EAAE2D,IAAI,IAAI0f,EAAI,GAAGrjB,EAAE4D,GAAK8Z,EAAIqtF,IAC1Dx5G,EAAQ+qG,aAAej6C,EAAI,CAC7B,IAAIgmD,EAAc,MAClB,IAAI0C,KAAgB1oD,EAAI,MACxBA,EAAGnvC,EAAI,GAAGmiF,GAAkBhyE,EAAI,GAAIhO,EAAOgO,EAAI,GAAIyxE,EAAUx1C,GAC7D+C,EAAG5tB,EAAI8uC,GAAalgD,EAAI,GACzB,CACC,MACF,KAAK,KACJ,IAAI9xB,EAAQ+qG,YAAa,MACzB,GAAGkM,EAAW,CAEb,IAAIH,EAAc,MAClBnS,EAAQtzB,GAAYylC,EAAa/lC,OAAQj/C,EAAI,KAC7Cg/B,EAAK9wD,EAAQ8yE,OAAS3mD,EAAI2qF,EAAa/lC,KAAK3+D,IAAI,IAAI0kG,EAAa/lC,KAAK1+D,GAAK8Z,EAAIklD,GAAYylC,EAAa/lC,SACnG,IAAIpvD,EAAI,GAAGmiF,GAAkBhyE,EAAI,GAAIhO,EAAOyyF,EAAUhT,EAAUx1C,EACtE,CACC,MACF,KAAK,IACJ4oD,EAASN,GAAUtH,EAAIj9E,EAAI2nF,MAAM/6F,EAAGoT,EAAIutD,KAAM,KAC3C0vB,EAAIj9E,EAAI2nF,MAAM3uG,IAAG6rG,EAAS7rG,EAAIikG,EAAIj9E,EAAI2nF,MAAM3uG,GAC/C6rG,EAASxkC,GAAK+kC,EAAIP,EAASt3B,MACxB84B,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEyf,EAAIzf,EAAGD,EAAE0f,EAAI1f,GAAIukG,EAAU32G,GACtC,MACD,KAAK,IAAuBA,EAAQuzE,aACnCojC,EAAY,CAACt3B,KAAMvtD,EAAIutD,KAAMlN,GAAI+kC,EAAIplF,EAAIutD,MAAO3gE,EAAE,KAC/Cy5F,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEyf,EAAIzf,EAAGD,EAAE0f,EAAI1f,GAAIukG,EAAU32G,IACrC,MACF,KAAK,IAAuB,GAAGA,EAAQuzE,WACtC,IAAI,IAAImmC,GAAK5nF,EAAIzf,EAAGqnG,IAAM5nF,EAAI5E,IAAKwsF,GAAI,CACtC,IAAIC,GAAQ7nF,EAAIutD,KAAKq6B,GAAG5nF,EAAIzf,GAC5BskG,EAAW,CAACt3B,KAAKs6B,GAAOxnC,GAAG+kC,EAAIyC,IAAQj7F,EAAE,KACtCy5F,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEqnG,GAAItnG,EAAE0f,EAAI1f,GAAIukG,EAAU32G,EACpC,CACC,MACF,KAAK,IACL,KAAK,IAAoB,KAAK,GAC7B22G,EAASN,GAAUvkF,EAAIA,IAAKA,EAAIutD,KAAM,MAC7BlN,GAAK+kC,EAAIP,EAASt3B,MACxB84B,EAAW,IAAGxB,EAAShxF,EAAIyyF,EAAezB,EAASt3B,MAAM,EAAK,KACjE+2B,GAAeO,EAAU32G,EAAS4wF,EAAG7iC,KAAKwqD,UAC1ClB,EAAQ,CAAChlG,EAAEyf,EAAIzf,EAAGD,EAAE0f,EAAI1f,GAAIukG,EAAU32G,GACtC,MAED,KAAK,EAAQ,KAAK,IACC,IAAfs3G,IAAkBxzF,EAAQgO,GAC5B,MACF,KAAK,IACJi9E,EAAMj9E,EACL,MACF,KAAK,KACJ,GAAgB,GAAbi8B,EAAKmjB,KAAW,CAClBknC,EAAcD,KAAcrmF,EAAI,GAChC,IAAI,IAAI8nF,GAAQ,EAAGA,GAAQzB,EAAW,KAAiB/qD,GAAUwsD,KAAU9nF,EAAI,KAAlC8nF,IAC1CA,IAAS,KAAKxlD,GAAStiC,EAAI,GAAIqmF,EAAW,IAC9C,MACK/jD,GAAStiC,EAAI,GAAIA,EAAI,IACzB,MACF,KAAK,GACJsmF,EAAcD,KAAcrmF,EAC5B,IAAI,IAAI+nF,GAAQ,EAAGA,GAAQ1B,EAAW,KAAiB/qD,GAAUysD,KAAU/nF,IAA9B+nF,IAC1CA,IAAS,KAAKzlD,GAAStiC,EAAKqmF,EAAW,KACzC,MAEF,KAAK,IAAyBxP,EAASA,EAAOnvE,OAAO1H,GAAM,MAE3D,KAAK,GAAkBkmF,EAAQlmF,EAAIgoF,IAAI,IAAM/rD,EAAKgsD,QAAUjoF,EAAK,MACjE,KAAK,IAAkBi8B,EAAKgsD,QAAQC,IAAMloF,EAAK,MAC/C,KAAK,IAAqBi8B,EAAKgsD,QAAQE,OAASnoF,EAAK,MAErD,KAAK,IACJ,IAAI4kF,EAAO5kF,EAAI,GAAGrjB,EAAE2D,EAAGskG,GAAQ5kF,EAAI,GAAGjjB,EAAEuD,IAAKskG,EAC5C,IAAID,EAAO3kF,EAAI,GAAGrjB,EAAE4D,EAAGokG,GAAQ3kF,EAAI,GAAGjjB,EAAEwD,IAAKokG,GAC5C3lD,EAAK9wD,EAAQ8yE,OAAS3mD,EAAIuqF,IAAO,IAAID,GAAQtqF,EAAIklD,GAAY,CAACh/D,EAAEokG,EAAKrkG,EAAEskG,QAChE5lD,EAAGznD,EAAIyoB,EAAI,IAEnB,MACF,KAAK,KACJ,IAAI4kF,EAAO5kF,EAAI,GAAGrjB,EAAE2D,EAAGskG,GAAQ5kF,EAAI,GAAGjjB,EAAEuD,IAAKskG,EAC5C,IAAID,EAAO3kF,EAAI,GAAGrjB,EAAE4D,EAAGokG,GAAQ3kF,EAAI,GAAGjjB,EAAEwD,IAAKokG,GAC5C3lD,EAAK9wD,EAAQ8yE,OAAS3mD,EAAIuqF,IAAO,IAAID,GAAQtqF,EAAIklD,GAAY,CAACh/D,EAAEokG,EAAKrkG,EAAEskG,OAC9D5lD,EAAGznD,IAAGynD,EAAGznD,EAAE4/F,QAAUn3E,EAAI,IAEnC,MACF,KAAK,GACJ,GAAGi8B,EAAKmjB,MAAQ,GAAKnjB,EAAKmjB,MAAQ,EAAG,MACrCpgB,EAAK9wD,EAAQ8yE,OAAS3mD,EAAI2F,EAAI,GAAG1f,IAAI,IAAI0f,EAAI,GAAGzf,GAAK8Z,EAAIklD,GAAYv/C,EAAI,KACzE,IAAIooF,GAAUlC,EAAQlmF,EAAI,IACtBg/B,IACA9wD,EAAQ8yE,OACN3mD,EAAI2F,EAAI,GAAG1f,KAAI+Z,EAAI2F,EAAI,GAAG1f,GAAK,IACnC0+C,EAAK3kC,EAAI2F,EAAI,GAAG1f,GAAG0f,EAAI,GAAGzf,GAAM,CAACqM,EAAE,MAEnCoyC,EAAK3kC,EAAIklD,GAAYv/C,EAAI,KAAQ,CAACpT,EAAE,KAErCoF,EAAMjV,EAAEuD,EAAInR,KAAK6C,IAAIggB,EAAMjV,EAAEuD,EAAG0f,EAAI,GAAG1f,GACvC0R,EAAMrV,EAAE2D,EAAInR,KAAK0C,IAAImgB,EAAMrV,EAAE2D,EAAG0f,EAAI,GAAG1f,GACvC0R,EAAMjV,EAAEwD,EAAIpR,KAAK6C,IAAIggB,EAAMjV,EAAEwD,EAAGyf,EAAI,GAAGzf,GACvCyR,EAAMrV,EAAE4D,EAAIpR,KAAK0C,IAAImgB,EAAMrV,EAAE4D,EAAGyf,EAAI,GAAGzf,IAEpCy+C,EAAGz+C,IAAGy+C,EAAGz+C,EAAI,IACjBmkG,EAAO,CAAC9jG,EAAEof,EAAI,GAAGpT,EAAEw7F,GAAQF,IAAIt7F,GAC/BoyC,EAAGz+C,EAAE1M,KAAK6wG,GACT,MACF,KAAK,KAAoB/X,GAAayY,EAAIplF,EAAIutD,MAAOvtD,EAAIwzC,KAAM,MAC/D,KAAK,IACJ,IAAIvX,EAAKg1B,WAAY,MACrB,KAAMjxD,EAAIjjB,GAAKijB,EAAIrjB,GAClBm7E,EAAQ93D,EAAIjjB,KAAO,CAAEitB,MAAOhK,EAAI3M,EAAE,IAAKg+D,MAAQrxD,EAAIqxD,OAAS,EAAIuH,UAAuB,EAAZ54D,EAAImmB,QAC3EiwD,IAAWA,GAAU,EAAMnP,GAAcjnE,EAAI3M,EAAE,MACnDwlE,GAAYf,EAAQ93D,EAAIjjB,EAAE,IAE1B,MACF,KAAK,IACJ,IAAIy7F,GAAS,CAAA,EACG,MAAbx4E,EAAIqxD,QAAiBwG,EAAQ73D,EAAI1f,GAAKk4F,GAAQA,GAAOnnB,MAAQrxD,EAAIqxD,OACjErxD,EAAI44D,SAAUf,EAAQ73D,EAAI1f,GAAKk4F,GAAQA,GAAO5f,QAAS,GACvD54D,EAAI84D,MACNjB,EAAQ73D,EAAI1f,GAAKk4F,GACjBA,GAAO1f,IAAM94D,EAAI84D,IAAK0f,GAAOzf,IAAMC,GAAMh5D,EAAI84D,MAE7C,MACF,QACA,KAAK,GACL,KAAK,GACL,KAAK,GACAz+D,EAAI,aAAa45E,GAAgB55E,EAAI,YAAc,CAAA,GACvDA,EAAI,YAAa,CAAC,GAAM,OAAQ,GAAK,QAAS,GAAK,MAAO,GAAK,UAAW6pF,IAAelkF,EACzF,MACD,KAAK,IACA3F,EAAI,aAAa45E,GAAgB55E,EAAI,YAAc,CAAA,GACvDA,EAAI,YAAY24B,OAAShzB,EAAIgzB,OAC7B34B,EAAI,YAAYg6E,OAASr0E,EAAIq0E,OAC7B,MACD,SAEIr0E,EAAIk2E,MAAKqL,EAAS1L,MAAM,GAAGK,KAAM,GACpC,MACD,KAAK,IAAsBmP,EAAUrlF,EAAK,MAC1C,KAAK,KAAoB+oE,EAAS/oE,EAAK,MACvC,KAAK,IAAsB8kF,EAAU9kF,EAAK,MAC1C,KAAK,IAEAilF,EACCzD,EAAQ/J,SAAWz3E,GAAOwhF,EAAQpuG,KADxBmuG,EAAS7G,QAAQjD,SAAWz3E,GAAO,eAIrD,MACKkxB,GAAGzwC,QAAQyR,MAAM,iCAAmCgyF,EAAWj3G,SAAS,KAC5E29C,EAAKrzC,GAAK3J,CAEZ,CAkBA,OAjBAkxF,EAAGle,WAAW7lC,GAAKgqE,GAAW1iG,KAAK,SAASzB,EAAEC,GAAK,OAAO/Q,OAAO8Q,GAAK9Q,OAAO+Q,EAAI,GAAG2kB,IAAI,SAASt1B,GAAG,OAAO60G,EAAU70G,GAAGkD,IAAK,GACzHlF,EAAQi1G,aAAYrkB,EAAGje,OAAOA,IAC9Bie,EAAGle,WAAWhzE,QAAUs3G,EAAS,SACpCpmB,EAAGle,WAAW/sE,KAAK,UAEhBirF,EAAGje,SAAQie,EAAGje,OAAe,OAAIqkC,IAE9BpmB,EAAGomB,SAASA,EAChBpmB,EAAGje,QAAQ0lC,EAAgB54E,QAAQ,SAASrtB,EAAEtR,GAAK8vF,EAAGje,OAAOie,EAAGle,WAAW5xE,IAAI,eAAiBsR,CAAG,GACtGw+E,EAAGupB,QAAUpL,EACbne,EAAGukB,IAAMzsC,GAAItb,IACVW,EAAKrC,MAAKklC,EAAGwpB,WAAarsD,EAAKrC,KAC/BmvC,IAAQjK,EAAGypB,OAASxf,GACvBjK,EAAG0pB,SAAW,CAAA,OACC36G,IAAZi3G,IAAuBhmB,EAAG0pB,SAASC,QAAU3D,GAC7CrT,EAASa,MAAM1kG,OAAS,IAAG2zG,EAASpG,MAAQ1J,EAASa,OACxDxT,EAAGyiB,SAAWA,EACPziB,CACR,CAGA,IAAI4pB,GACC,mCADDA,GAEE,mCAgDN,SAASC,GAAal/C,EAAav7D,GAKnC,IAAI06G,EAAuB5kC,EAeP6kC,EAEhBhwF,EAhBJ,GALI3qB,IAASA,EAAU,IACvBq1G,GAAcr1G,GACdmqD,KACGnqD,EAAQokF,UAAUp6B,GAAShqD,EAAQokF,UAEnC7oB,EAAI7D,UAAW,CACjB,GAAG3B,GAAI5V,KAAKob,EAAK,eAAgB,MAAM,IAAIl6D,MAAM,8BACjDq5G,EAAU3kD,GAAI5V,KAAKob,EAAK,YACxBua,EAAK/f,GAAI5V,KAAKob,EAAK,cAAgBxF,GAAI5V,KAAKob,EAAK,QAClD,KAAO,CACN,OAAOv7D,EAAQ+N,MACd,IAAK,SAAUwtD,EAAMvP,GAAId,GAAcqQ,IAAO,MAC9C,IAAK,SAAUA,EAAMvP,GAAIuP,GAAM,MAC/B,IAAK,SAAU,MACf,IAAK,QAAal4D,MAAMi+B,QAAQi6B,KAAMA,EAAMl4D,MAAMpE,UAAUkB,MAAMd,KAAKk8D,IAExE5E,GAAU4E,EAAK,GACfua,EAAM,CAACrb,QAASc,EACjB,CAKA,GADGm/C,GAA0BpF,GAAcoF,GACxC16G,EAAQk1G,YAAcl1G,EAAQi1G,WAAY0F,EAAa,CAAA,MACd,CAC3C,IAAIp5D,EAAI4J,GAAU,SAAW,QAC7B,GAAG2qB,GAAMA,EAAGrb,QAASkgD,EAAYrE,GAAexgC,EAAGrb,QAASz6D,QAEvD,IAAI2qB,EAAMorC,GAAI5V,KAAKob,EAAK,wBAA0B5wC,EAAM8vC,QAASkgD,EAAY3sB,GAAIpJ,YAAYj6D,EAAM8vC,SAAUz6D,EAAQ+N,KAAOwzC,EAAGvhD,QAE/H,MAAI2qB,EAAMorC,GAAI5V,KAAKob,EAAK,yBAA0B5wC,EAAM8vC,QAExD,MAAI9vC,EAAMorC,GAAI5V,KAAKob,EAAK,SAAW5wC,EAAM8vC,QAAe,IAAIp5D,MAAM,wCACxDA,MAAM,+BAHiDs5G,EAAY3sB,GAAIpJ,YAAYj6D,EAAM8vC,SAAUz6D,EAAQ+N,KAAOwzC,EAAGvhD,GAGjF,CAChDA,EAAQ46G,SAAWr/C,EAAI7D,WAAa3B,GAAI5V,KAAKob,EAAK,+BAA8Bo/C,EAAUE,OAx7N9F,SAAsBt/C,GACpB,IAAIu/C,EAAS/kD,GAAIiQ,MAAMY,QAAQ,CAAEtP,KAAM,MAOvC,OANAiE,EAAI7D,UAAUj4B,QAAQ,SAASn0B,EAAGxK,GAChC,GAAoB,MAAhBwK,EAAEnL,OAAM,IAAgBmL,EAAEowB,MAAM,oBAApC,CAEA,IAAIq/E,EAAUzvG,EAAEswB,QAAQ,UAAW,KAAKA,QAAQ,4BAA6B,IAC7Em6B,GAAIiQ,MAAMtB,QAAQo2C,EAAQC,EAASx/C,EAAI9D,UAAU32D,GAAG25D,QAFlD,CAGJ,GACO1E,GAAI0Q,MAAMq0C,EACnB,CA+6NuGE,CAAaz/C,GACpH,CAEA,IAAImd,EAAQ,CAAA,EAMZ,OALGnd,EAAI7D,WApFP,SAAyB6D,EAAsBmd,EAAOr6B,GAErD,IAAI48D,EAAMllD,GAAI5V,KAAKob,EAAK,gCACxB,GAAG0/C,GAAOA,EAAItxG,KAAO,EAAG,IACvB,IAAIuxG,EAAal+B,GAAwBi+B,EAAK5lC,GAAkBmlC,IAChE,IAAI,IAAIl2F,KAAK42F,EAAYxiC,EAAMp0D,GAAK42F,EAAW52F,EAChD,CAAE,MAAMzV,GAAI,GAAGwvC,EAAEyuB,IAAK,MAAMj+D,CAAa,CAGzC,IAAIssG,EAAKplD,GAAI5V,KAAKob,EAAK,wBACvB,GAAG4/C,GAAMA,EAAGxxG,KAAO,EAAG,IACrB,IAAIyxG,EAAUp+B,GAAwBm+B,EAAI7lC,GAAcklC,IACxD,IAAI,IAAI/rG,KAAK2sG,EAAwB,MAAZ1iC,EAAMjqE,KAAYiqE,EAAMjqE,GAAK2sG,EAAQ3sG,GAC/D,CAAE,MAAMI,GAAI,GAAGwvC,EAAEyuB,IAAK,MAAMj+D,CAAa,CAEtC6pE,EAAM2iC,cAAgB3iC,EAAM4iC,gBAC9B/iC,GAAiBG,EAAM2iC,aAAc3iC,EAAM4iC,cAAe5iC,EAAOr6B,UAC1Dq6B,EAAM2iC,oBAAqB3iC,EAAM4iC,cAE1C,CAiEkBC,CAAwBhgD,EAA+Bmd,EAAO14E,GAEhF26G,EAAUpgC,MAAQogC,EAAU3J,UAAYt4B,EACrC14E,EAAQw7G,YAAWb,EAAUp/C,IAAMA,GAE/Bo/C,CACP,CAuBA,IAAIpqC,GAAiB,CACb,EAAe,CAAuB5uD,EAt1H9C,SAAyBvY,EAAM1J,GAC9B,IAAIimB,EAAK,CAAA,EACLmxC,EAAM1tD,EAAKC,EAAI3J,EACnBimB,EAAEvT,EAAIhJ,EAAKwtD,WAAW,GACtBxtD,EAAKC,GAAK,EACV,IAAIi3E,EAAQl3E,EAAKwtD,WAAW,GAC5BxtD,EAAKC,GAAK,EACV,IAAI4uC,EAAQ7uC,EAAKwtD,WAAW,GAK5B,OAJAxtD,EAAKC,EAAIytD,EACE,EAAR7e,IAActyB,EAAEw9D,MAAgB,EAARlrC,GAChB,GAARA,IAActyB,EAAE+kE,QAAS,GACjB,GAARzyC,IAActyB,EAAEilE,IAAMtK,EAAQ,IAC1B36D,CACR,GA00HQ,EAAe,CAA0BhE,EA/uHjD,SAA4BvY,GAE3B,MAAO,CADIgrE,GAAehrE,GAE3B,GA6uHQ,EAAe,CAAuBuY,EA3nH9C,SAAyBvY,GAGxB,MAAO,CAFIgrE,GAAehrE,GACdurE,GAAevrE,GACN,IACtB,GAwnHQ,EAAe,CAA0BuY,EAvsHjD,SAA4BvY,GAG3B,MAAO,CAFIgrE,GAAehrE,GACbA,EAAKwtD,WAAW,GACP,IACvB,GAosHQ,EAAe,CAAyBj1C,EAhuHhD,SAA2BvY,GAG1B,MAAO,CAFIgrE,GAAehrE,GACdA,EAAKwtD,WAAW,GACP,IACtB,GA6tHQ,EAAe,CAAyBj1C,EAtpHhD,SAA2BvY,GAG1B,MAAO,CAFIgrE,GAAehrE,GACd6rE,GAAW7rE,GACF,IACtB,GAmpHQ,EAAe,CAAuBuY,EAhmH9C,SAAyBvY,GAGxB,MAAO,CAFIgrE,GAAehrE,GACduqE,GAAmBvqE,GACV,MACtB,GA6lHQ,EAAe,CAAyBuY,EAhrHhD,SAA2BvY,GAG1B,MAAO,CAFIgrE,GAAehrE,GACfA,EAAKwtD,WAAW,GACP,IACrB,GA6qHQ,EAAe,CAA2Bj1C,EA1hHlD,SAA6BvY,EAAM1J,EAAQquD,GAC1C,IAAI0X,EAAMr8D,EAAKC,EAAI3J,EACfqxE,EAAOqD,GAAehrE,GAC1B2nE,EAAK3+D,EAAI27C,EAAK,QACd,IACI1P,EAAI,CAAC0yB,EADG4C,GAAmBvqE,GACT,OACtB,GAAG2kD,EAAKg9C,YAAa,CACpB3hG,EAAKC,GAAK,EACV,IAAIghF,EAAUmb,GAA4Bp8F,EAAMq8D,EAAMr8D,EAAKC,EAAG0kD,GAC9D1P,EAAE,GAAKylD,GAAkBzZ,EAAS,EAAetZ,EAAMhjB,EAAKw1C,SAAUx1C,EACvE,MACK3kD,EAAKC,EAAIo8D,EACd,OAAOpnB,CACR,GA8gHQ,EAAe,CAAwB18B,EA3iH/C,SAA0BvY,EAAM1J,EAAQquD,GACvC,IAAI0X,EAAMr8D,EAAKC,EAAI3J,EACfqxE,EAAOqD,GAAehrE,GAC1B2nE,EAAK3+D,EAAI27C,EAAK,QACd,IACI1P,EAAI,CAAC0yB,EADGkE,GAAW7rE,GACD,KACtB,GAAG2kD,EAAKg9C,YAAa,CACpB3hG,EAAKC,GAAK,EACV,IAAIghF,EAAUmb,GAA4Bp8F,EAAMq8D,EAAMr8D,EAAKC,EAAG0kD,GAC9D1P,EAAE,GAAKylD,GAAkBzZ,EAAS,EAAetZ,EAAMhjB,EAAKw1C,SAAUx1C,EACvE,MACK3kD,EAAKC,EAAIo8D,EACd,OAAOpnB,CACR,GA+hHQ,GAAe,CAAyB18B,EA5kHhD,SAA2BvY,EAAM1J,EAAQquD,GACxC,IAAI0X,EAAMr8D,EAAKC,EAAI3J,EACfqxE,EAAOqD,GAAehrE,GAC1B2nE,EAAK3+D,EAAI27C,EAAK,QACd,IACI1P,EAAI,CAAC0yB,EADG3nE,EAAKwtD,WAAW,GACN,KACtB,GAAG7I,EAAKg9C,YAAa,CACpB3hG,EAAKC,GAAK,EACV,IAAIghF,EAAUmb,GAA4Bp8F,EAAMq8D,EAAMr8D,EAAKC,EAAG0kD,GAC9D1P,EAAE,GAAKylD,GAAkBzZ,EAAS,EAAetZ,EAAMhjB,EAAKw1C,SAAUx1C,EACvE,MACK3kD,EAAKC,EAAIo8D,EACd,OAAOpnB,CACR,GAgkHQ,GAAe,CAA0B18B,EA7jHjD,SAA4BvY,EAAM1J,EAAQquD,GACzC,IAAI0X,EAAMr8D,EAAKC,EAAI3J,EACfqxE,EAAOqD,GAAehrE,GAC1B2nE,EAAK3+D,EAAI27C,EAAK,QACd,IACI1P,EAAI,CAAC0yB,EADG3nE,EAAKwtD,WAAW,GACN,KACtB,GAAG7I,EAAKg9C,YAAa,CACpB3hG,EAAKC,GAAK,EACV,IAAIghF,EAAUmb,GAA4Bp8F,EAAMq8D,EAAMr8D,EAAKC,EAAG0kD,GAC9D1P,EAAE,GAAKylD,GAAkBzZ,EAAS,EAAetZ,EAAMhjB,EAAKw1C,SAAUx1C,EACvE,MACK3kD,EAAKC,EAAIo8D,EACd,OAAOpnB,CACR,GAijHQ,GAAe,CAA2B18B,EAlvHlD,SAA6BvY,GAE5B,MAAO,CADIkrE,GAAoBlrE,GAEhC,GAgvHQ,GAAe,CAAwBuY,EA3nH/C,SAA0BvY,GAGzB,MAAO,CAFIkrE,GAAoBlrE,GACnBurE,GAAevrE,GACN,IACtB,GAwnHQ,GAAe,CAA2BuY,EAvsHlD,SAA6BvY,GAG5B,MAAO,CAFIkrE,GAAoBlrE,GAClBA,EAAKwtD,WAAW,GACP,IACvB,GAosHQ,GAAe,CAA0Bj1C,EAhuHjD,SAA4BvY,GAG3B,MAAO,CAFIkrE,GAAoBlrE,GACnBA,EAAKwtD,WAAW,GACP,IACtB,GA6tHQ,GAAe,CAA0Bj1C,EAAE6pF,IAC3C,GAAe,CAAwB7pF,EAhmH/C,SAA0BvY,GAGzB,MAAO,CAFIkrE,GAAoBlrE,GACnBuqE,GAAmBvqE,GACV,MACtB,GA6lHQ,GAAe,CAA0BuY,EAhrHjD,SAA4BvY,GAG3B,MAAO,CAFIkrE,GAAoBlrE,GACpBA,EAAKwtD,WAAW,GACP,IACrB,GA6qHQ,GAAe,CAAwBj1C,EAAEqyD,IACzC,GAAe,GACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,GACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,GACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAyBzyB,EAAE,GAC1C,GAAe,CAAuBA,GAAE,GACxC,GAAe,CAAwBA,EAAE,GACzC,GAAe,CAAsBA,GAAE,GACvC,GAAe,CAAqB5/B,EA7xE5C,SAAuBvY,EAAM1J,EAAQquD,GACpC,IAAI0X,EAAMr8D,EAAKC,EAAI3J,EACnB0J,EAAKC,GAAK,EACVD,EAAKC,GAAK,EACV,IAAI24E,EAAO54E,EAAKwtD,WAAW,GACvB1xD,EAAOuvE,GAAuBrrE,GAC9BihF,EAAUob,GAA4Br8F,EAAM,EAAG2kD,GAC/CixC,EAAUxqB,GAA2BprE,GAOzCA,EAAKC,EAAIo8D,EACT,IAAIt5C,EAAO,CAACw1D,KAAKz8E,EAAMkoG,IAAI/iB,GAG3B,OAFGrI,EAAO,YAAW71D,EAAI+gF,MAAQlrB,GAC9Bgd,IAAS7yE,EAAIshF,QAAUzO,GACnB7yE,CACR,GA2wEQ,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAqBxK,EA55Q5C,SAAuBvY,EAAM1J,EAAmBquD,GAC/C,IAAI5hC,EAAO,CAAA,EAEXA,EAAI0qC,GAAKztD,EAAKwtD,WAAW,GAAK,GAE9B,IAAI6kD,EAl4LL,SAAyBryG,GACxB,IAAIkb,EAAIlb,EAAKwtD,WAAW,GAYxB,OAXAxtD,EAAKC,IACK,CACTqyG,MAAW,EAAJp3F,EACPq3F,QAAa,EAAJr3F,EACTs3F,WAAgB,EAAJt3F,EACZu3F,WAAgB,EAAJv3F,EACZw3F,SAAc,GAAJx3F,EACVy3F,QAAa,GAAJz3F,EACT03F,UAAe,GAAJ13F,EACX23F,QAAa,IAAJ33F,EAGX,CAo3La43F,CAAgB9yG,GAW5B,OAVGqyG,EAAME,UAASxvF,EAAIivE,OAAS,GAC5BqgB,EAAMO,YAAW7vF,EAAImvE,SAAW,GAChCmgB,EAAMQ,UAAS9vF,EAAIovE,OAAS,GAC5BkgB,EAAMM,UAAS5vF,EAAImlE,OAAS,GAC5BmqB,EAAMK,WAAU3vF,EAAIolE,QAAU,GAC9BkqB,EAAMI,aAAY1vF,EAAIqlE,OAAS,GAGvB,MADDpoF,EAAKwtD,WAAW,KACPzqC,EAAIgvE,KAAO,GAEvB/xF,EAAKwtD,WAAW,IAEtB,KAAK,EAAGzqC,EAAIqvE,UAAY,cAAe,MACvC,KAAK,EAAGrvE,EAAIqvE,UAAY,YAGzB,IAAIH,EAAYjyF,EAAKwtD,WAAW,GAChB,GAAbykC,IAAgBlvE,EAAIkvE,UAAYA,GAEnC,IAAI1J,EAASvoF,EAAKwtD,WAAW,GAC1B+6B,EAAS,IAAGxlE,EAAIwlE,OAASA,GAE5B,IAAIwqB,EAAW/yG,EAAKwtD,WAAW,GAM/B,OALGulD,EAAW,IAAGhwF,EAAIiwF,QAAUD,GAE/B/yG,EAAKC,IACL8iB,EAAIoP,MA99LL,SAAwBnyB,GACvB,IAAI+iB,EAAM,CAAA,EAINkwF,EAHIjzG,EAAKwtD,WAAW,KAGD,EAEnBl1D,EAAQ0H,EAAKwtD,WAAW,GACxB0lD,EAAMlzG,EAAKwtD,WAAW,EAAG,KACzB2lD,EAAKnzG,EAAKwtD,WAAW,GACrB4lD,EAAKpzG,EAAKwtD,WAAW,GACrB6lD,EAAKrzG,EAAKwtD,WAAW,GAGzB,OAFAxtD,EAAKC,IAEGgzG,GACP,KAAK,EAAGlwF,EAAIuvE,KAAO,EAAG,MACtB,KAAK,EACJvvE,EAAIzqB,MAAQA,EACZ,IAAIk6F,EAAMlmB,GAAOh0E,GAEbk6F,IAAKzvE,EAAIulE,IAAMqG,GAAQ6D,IAC3B,MACD,KAAK,EAEJzvE,EAAIulE,IAAMqG,GAAQ,CAACwkB,EAAIC,EAAIC,IAC3B,MACD,KAAK,EAAGtwF,EAAI0vE,MAAQn6F,EAIrB,OAFW,GAAP46G,IAAUnwF,EAAI+rE,KAAOokB,EAAM,EAAIA,EAAM,MAAQA,EAAM,OAEhDnwF,CACR,CA+7LauwF,CAAetzG,GAEpBA,EAAKwtD,WAAW,IAEtB,KAAK,EAAGzqC,EAAIsvE,OAAS,QAAS,MAC9B,KAAK,EAAGtvE,EAAIsvE,OAAS,QAKtB,OAFAtvE,EAAIjnB,KAAOyuE,GAAmBvqE,GAEvB+iB,CACR,GAk3QQ,GAAe,CAAoBxK,EA56Q3C,SAAsBvY,EAAM1J,GAG3B,MAAO,CAFQ0J,EAAKwtD,WAAW,GACf+c,GAAmBvqE,GAEpC,GAy6QQ,GAAe,CAAqBuY,EAAEw7E,IACtC,GAAe,CAAuBx7E,EAAEy7E,IACxC,GAAe,CAAmBz7E,EAtyQ1C,SAAqBvY,EAAM1J,GAC1B,IAAIo3D,EAAM1tD,EAAKC,EAAI3J,EACfi9G,EAAavzG,EAAKwtD,WAAW,GAC7BgmD,EAAOxzG,EAAKwtD,WAAW,GAE3B,OADAxtD,EAAKC,EAAIytD,EACF,CAACuoB,KAAKs9B,EAAYvqC,SAASwqC,EACnC,GAiyQQ,GAAe,GACf,GAAe,CAAyBj7F,EAzidhD,SAAuBvY,GACtB,OAAOA,EAAKwtD,WAAW,EAAG,IAC3B,GAwidQ,GAAe,CAAA,EACf,GAAe,CAAmBj1C,EA3qP1C,SAAsBvY,GAGpB,IAFA,IAAI+iB,EAAM,GACNivC,EAAMhyD,EAAKwtD,WAAW,GACnBwE,KAAQ,GACbjvC,EAAIxmB,KAAK,CAACyD,EAAKwtD,WAAW,GAAIxtD,EAAKwtD,WAAW,KAChD,OAAOzqC,CACT,GAsqPQ,GAAe,CAAyBo1B,EAAE,GAC1C,GAAe,CAAuBA,GAAE,GACxC,GAAe,CAAyBA,EAAE,GAC1C,GAAe,CAAuBA,GAAE,GACxC,GAAe,CAA8BA,EAAE,GAC/C,GAAe,CAA4BA,GAAE,GAC7C,GAAe,GACf,GAAe,CAAA,EACf,GAAe,CAAwB5/B,EAAEmhE,IACzC,GAAe,CAA4BnhE,EA7pHnD,SAA8BvY,GAG7B,MAAO,CAFIgrE,GAAehrE,GACd4qE,GAAc5qE,GACL,KACtB,GA0pHQ,GAAe,CAA+BuY,EA3+OtD,SAAiCvY,GAChC,IAAI+iB,EAAM,CAAA,EACVA,EAAIrrB,EAAIsI,EAAKwtD,WAAW,GACxB,IAAIma,EAAO,CAAA,EACXA,EAAK3+D,EAAIhJ,EAAKwtD,WAAW,GACzBma,EAAK1+D,EAAIjJ,EAAKwtD,WAAW,GACzBzqC,EAAI/Z,EAAIi/D,GAAYN,GACpB,IAAI94B,EAAQ7uC,EAAKwtD,WAAW,GAG5B,OAFW,EAAR3e,IAAa9rB,EAAI9iB,EAAI,KACb,EAAR4uC,IAAa9rB,EAAIzZ,EAAI,KACjByZ,CACR,GAi+OQ,GAAe,CAAqBxK,EAl6G5C,WACA,GAk6GQ,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,GACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA2B4/B,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,EAAG5/B,EAAEsuD,GAAW3kE,EAAE,GAC7D,IAAe,CAAwBi2C,MACvC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA4BA,EAAE,EAAG5/B,EAh/GxD,SAA8BvY,GAC7B,IAAIuY,EAAIvY,EAAKwtD,WAAW,GAExB,OADAxtD,EAAKC,GAAK,GACH,CAAE2+F,IAAS,GAAJrmF,EACf,GA6+GQ,IAAe,CAA0B4/B,GAAE,GAC3C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,MAC5C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAuB5/B,EAj2H9C,SAAyBvY,EAAM1J,GAC9B,IAAIimB,EAAI,CAAA,EACJhE,EAAIvY,EAAKA,EAAKC,GAMlB,QANwBD,EAAKC,EAC7Bsc,EAAEyoF,QAAc,GAAJzsF,GACZgE,EAAE+nB,OAAc,IAAJ/rB,GAEZvY,EAAKC,GAAK,GACVsc,EAAEzgB,KAAOqvE,GAAmBnrE,GACrBuc,CACR,GAy1HQ,IAAe,CAAsBhE,EAAE4pF,GAAgBjgG,EAAE,IACzD,IAAe,CAAqBqW,EAzjH5C,WACA,GAyjHQ,IAAe,CAAA,EACf,IAAe,CAAuBA,EA/3E9C,SAAyBvY,EAAM1J,GAC9B,IAAI2+C,EAAiB,CAAA,EACjBpG,EAAQ7uC,EAAKwtD,WAAW,GAC5BvY,EAAEw+D,oBAAsBzzG,EAAKwtD,WAAW,GACxC,IAAIkmD,EAAWp9G,EAAS,EAAKi0E,GAAmBvqE,GAAQ,GAiBxD,OAhBG0zG,EAAQp9G,OAAS,IAAG2+C,EAAEkrD,SAAWuT,GACpCz+D,EAAE0+D,wBAAkC,MAAR9kE,GAC5BoG,EAAE2+D,cAAwB,GAAR/kE,GAClBoG,EAAE4+D,sBAAgC,KAARhlE,GAC1BoG,EAAE+P,YAAsB,EAARnW,GAChBoG,EAAE6+D,iBAA2B,EAARjlE,GACrBoG,EAAE8+D,sBAAgC,KAARllE,GAC1BoG,EAAE++D,qBAA+B,GAARnlE,GACzBoG,EAAEg/D,gBAA0B,KAARplE,GACpBoG,EAAEi/D,yBAAmC,OAARrlE,GAC7BoG,EAAEk/D,0BAAoC,IAARtlE,GAC9BoG,EAAEm/D,8BAAwC,EAARvlE,GAClCoG,EAAEo/D,qBAA+B,GAARxlE,GACzBoG,EAAEq/D,YAAc,CAAC,MAAO,eAAgB,QAASzlE,GAAS,GAAM,GAChEoG,EAAEs/D,wBAAkC,MAAR1lE,GAC5BoG,EAAEu/D,YAAc,CAAC,UAAW,QAAS,UAAW3lE,GAAS,EAAK,GACvDoG,CACR,GA02EQ,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAyB18B,EAp5EhD,SAA2BvY,EAAM1J,GAChC,IAAIimB,EAAI,CAAA,EAKR,OAJAA,EAAE6nF,OAASpkG,EAAKwtD,WAAW,GAC3BjxC,EAAEk4F,OAASz0G,EAAKwtD,WAAW,GAC3BjxC,EAAEm4F,SAAWppC,GAAYtrE,GACzBuc,EAAEzgB,KAAOyuE,GAAmBvqE,GACrBuc,CACR,GA84EQ,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAyB47B,EAAE,EAAG5/B,EA/7SrD,SAA2BvY,GAC1B,MAAO,CAACA,EAAKwtD,WAAW,GAAIxtD,EAAKwtD,WAAW,GAC7C,GA87SQ,IAAe,CAAuBrV,MACtC,IAAe,CAA6BA,EAAE,EAAG5/B,EAAEqzD,IACnD,IAAe,CAA2BzzB,MAC1C,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA0B5/B,EAAE8pF,IAC3C,IAAe,CAAgClqD,EAAE,GACjD,IAAe,CAA8BA,MAC7C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,MAC5C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,MAC1C,IAAe,CAAuCA,EAAE,GACxD,IAAe,CAAqCA,GAAE,GACtD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,MAChD,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,MACzC,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,MAC3C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,MACzC,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAAA,EACf,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,MACxC,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,MACvC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,MAC1C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,MAC5C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,MAC5C,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAAwB5/B,EAz5P/C,SAA0BvY,EAAM1J,GAC9B,MAAO,CACLu4C,MAAO7uC,EAAKwtD,WAAW,GACvBtf,QAASluC,EAAKwtD,WAAW,GACzB1xD,KAAMyuE,GAAmBvqE,GAE7B,GAo5PQ,IAAe,CAA6Bm4C,GAAE,GAC9C,IAAe,CAA2B5/B,EAv3PlD,SAA6BvY,GAE3B,OADAA,EAAKC,GAAK,EACmB,GAAtBD,EAAKwtD,WAAW,EACzB,EAo3PyErV,EAAE,GACnE,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA2B5/B,EAAE+yD,IAC5C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA6BnzB,EAAE,GAC9C,IAAe,CAAA,EACf,IAAe,CAA4B5/B,EAAE4gE,IAC7C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA2BhhC,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,MACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,MAChD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,MAC3C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAwB5/B,EAr0H/C,SAA0BvY,EAAM1J,EAAQquD,GACvC,IAAI0X,EAAMr8D,EAAKC,EAAI3J,EACfyuG,EAAMp5B,GAAU3rE,GAChB20G,EAAc30G,EAAKwtD,WAAW,GAC9BvY,EAAI,CAAC8vD,GACT,GADe9vD,EAAE,GAAK0/D,EACnBhwD,EAAKg9C,YAAa,CACpB,IAAI1gB,EAAUkb,GAA6Bn8F,EAAMq8D,EAAMr8D,EAAKC,EAAG0kD,GAC/D1P,EAAE,GAAKgsC,CACR,MAAOjhF,EAAKC,EAAIo8D,EAChB,OAAOpnB,CACR,GA4zHQ,IAAe,CAAwB18B,EAzzH/C,SAA0BvY,EAAM1J,EAAQquD,GACvC,IAAI0X,EAAMr8D,EAAKC,EAAI3J,EAEf2+C,EAAI,CADE22B,GAAmB5rE,IAE7B,GAAG2kD,EAAKg9C,YAAa,CACpB,IAAI1gB,EAAUqb,GAA8Bt8F,EAAMq8D,EAAMr8D,EAAKC,EAAG0kD,GAChE1P,EAAE,GAAKgsC,EACPjhF,EAAKC,EAAIo8D,CACV,MAAOr8D,EAAKC,EAAIo8D,EAChB,OAAOpnB,CACR,GAgzHQ,IAAe,CAAA,EACf,IAAe,CAAoCkD,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,MAC7C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA2CA,EAAE,GAC5D,IAAe,CAAyCA,GAAE,GAC1D,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,MAC1C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAA,EACf,IAAe,CAAwB5/B,EA30H/C,SAA0BvY,GACzB,IAAI48F,EAAW,CAAA,EAEf,OADA0F,GAAcjsE,QAAQ,SAAS90B,GAAKq7F,EAAQr7F,GAAKsqE,GAAW7rE,EAAU,GAC/D48F,CACR,GAw0HQ,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAkCzkD,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA0B5/B,EAnrIjD,WACA,GAmrIQ,IAAe,CAAyB4/B,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAwBA,EAAE,GACzC,IAAe,CAAsBA,GAAE,GACvC,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,CAAsB5/B,EAt6H7C,SAAwBvY,EAAM1J,GAC7B,IAAI+lE,EAAMr8D,EAAKC,EAAI3J,EACfyuG,EAAMn5B,GAAmB5rE,GACzB8kG,EAAQ15B,GAA2BprE,GACnC+lE,EAAMwE,GAAmBvqE,GACzB4/F,EAAUr1B,GAAmBvqE,GAC7BigD,EAAUsqB,GAAmBvqE,GACjCA,EAAKC,EAAIo8D,EACT,IAAIpnB,EAAK,CAAC8vD,IAAIA,EAAKD,MAAMA,EAAO/+B,IAAIA,EAAK9lB,QAAQA,GAEjD,OADG2/C,IAAS3qD,EAAE4qD,QAAUD,GACjB3qD,CACR,GA45HQ,IAAe,CAA0BkD,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,MACxC,IAAe,CAAA,EACf,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,MAC1C,IAAe,CAAyBA,EAAE,GAC1C,IAAe,CAAuBA,GAAE,GACxC,IAAe,GACf,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,GACf,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,MAC1C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,MAC5C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,MAC3C,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAwB5/B,EAAE+yD,IACzC,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAiCnzB,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,MAC7C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAA,EACf,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAA,EACf,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAA,EACf,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,GAAE,GAC7C,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,GAAE,GAC1C,IAAe,CAAiCA,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAA,EACf,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,MACzC,IAAe,CAAA,EACf,IAAe,CAA2BA,EAAE,GAC5C,IAAe,CAAyBA,MACxC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAA0BA,EAAE,GAC3C,IAAe,CAAwBA,GAAE,GACzC,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,MAC1C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,GACf,IAAe,CAAkCA,EAAE,GACnD,IAAe,CAAgCA,GAAE,GACjD,IAAe,CAA8BA,EAAE,GAC/C,IAAe,CAA4BA,MAC3C,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,CAA8B5/B,EAAEu9E,IAC/C,IAAe,CAAiC39C,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAA6BA,EAAE,EAAG5/B,EAtmPzD,SAA+BvY,GAC9B,IAAI+iB,EAAM,CAAA,EACVA,EAAIijF,QAAUhmG,EAAKwtD,WAAW,GAC9B,IAAIu3C,EAAMn5B,GAAmB5rE,GAI7B,OAHA+iB,EAAIgiF,IAAMA,EAAI1/F,EACd0d,EAAIu2D,IAAMrR,GAAY88B,EAAI1/F,GAC1BrF,EAAKC,GAAK,GACH8iB,CACR,GA+lPQ,IAAe,CAA2Bo1B,GAAE,GAC5C,IAAe,CAA4B5/B,EAAEwyD,IAC7C,IAAe,CAAgC5yB,EAAE,GACjD,IAAe,CAAA,EACf,IAAe,CAA8BA,GAAE,GAC/C,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAA2BA,GAAE,GAC5C,IAAe,CAAqCA,EAAE,GACtD,IAAe,CAAA,EACf,IAAe,CAAmCA,GAAE,GACpD,IAAe,CAA2CA,EAAE,GAC5D,IAAe,CAAmCA,EAAE,GACpD,IAAe,CAAA,EACf,IAAe,CAAiCA,GAAE,GAClD,IAAe,CAAuB5/B,EAh0G9C,SAAyBvY,EAAM1J,GAG9B,OAFA0J,EAAKC,GAAK,GAEH,CAAEnE,KADEyuE,GAAmBvqE,GAE/B,GA6zGQ,IAAe,GACf,IAAe,CAAiCm4C,EAAE,GAClD,IAAe,CAA+BA,GAAE,GAChD,IAAe,CAAgCA,EAAE,GACjD,IAAe,CAA8BA,MAC7C,IAAe,CAAoCA,EAAE,GACrD,IAAe,CAAkCA,GAAE,GACnD,IAAe,GACf,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAAA,EACf,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAAA,EACf,IAAe,CAA6BA,EAAE,GAC9C,IAAe,CAAA,EACf,IAAe,CAA2BA,GAAE,GAC5C,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAA+BA,EAAE,GAChD,IAAe,CAA6BA,GAAE,GAC9C,IAAe,CAA4BA,EAAE,GAC7C,IAAe,CAA0BA,GAAE,GAC3C,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAA,EACf,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,MAC/C,KAAe,CAAA,EACf,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,MACjD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAA6CA,EAAE,GAC9D,KAAe,CAA2CA,MAC1D,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAAA,EACf,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAAuB5/B,EAx9H9C,WACA,GAw9HQ,KAAe,CAA6B4/B,EAAE,GAC9C,KAAe,CAAA,EACf,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAAA,EACf,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA2BA,EAAE,GAC5C,KAAe,CAAyBA,GAAE,GAC1C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,MACjD,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,MACjD,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,MACzC,KAAe,CAAA,EACf,KAAe,CAAyCA,EAAE,GAC1D,KAAe,CAAuCA,MACtD,KAAe,CAA2CA,EAAE,GAC5D,KAAe,CAAyCA,GAAE,GAC1D,KAAe,CAA0CA,EAAE,GAC3D,KAAe,CAAwCA,GAAE,GACzD,KAAe,CAAyCA,EAAE,GAC1D,KAAe,CAAuCA,GAAE,GACxD,KAAe,CAAwCA,EAAE,GACzD,KAAe,CAAsCA,GAAE,GACvD,KAAe,GACf,KAAe,CAA2CA,EAAE,GAC5D,KAAe,CAAA,EACf,KAAe,CAAyCA,GAAE,GAC1D,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,MACpD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAA+CA,EAAE,GAChE,KAAe,CAA6CA,GAAE,GAC9D,KAAe,CAA6BA,EAAE,GAC9C,KAAe,CAA2BA,GAAE,GAC5C,KAAe,GACf,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,GAAE,GAC3C,KAAe,CAA6BA,EAAE,GAC9C,KAAe,CAA2BA,GAAE,GAC5C,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,GAAE,GAC7C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAA,EACf,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,MAC9C,KAAe,CAAA,EACf,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAA8CA,EAAE,GAC/D,KAAe,CAA4CA,GAAE,GAC7D,KAAe,CAA4CA,EAAE,GAC7D,KAAe,CAA0CA,GAAE,GAC3D,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,GACf,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAAyCA,EAAE,GAC1D,KAAe,CAAuCA,GAAE,GACxD,KAAe,CAAA,EACf,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,MAC7C,KAAe,CAA2BA,GAAE,GAC5C,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,GAAE,GACjD,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA6BA,EAAE,GAC9C,KAAe,CAA2BA,MAC1C,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAAA,EACf,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,GAAE,GAC3C,KAAe,CAAA,EACf,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAA4CA,EAAE,GAC7D,KAAe,CAA0CA,GAAE,GAC3D,KAAe,CAAA,EACf,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAA8BA,EAAE,GAC/C,KAAe,CAA4BA,MAC3C,KAAe,CAA2BA,EAAE,GAC5C,KAAe,CAAyBA,GAAE,GAC1C,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,GAAE,GAClD,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAA0CA,EAAE,GAC3D,KAAe,CAAwCA,GAAE,GACzD,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAA,EACf,KAAe,CAAgDA,EAAE,GACjE,KAAe,CAA8CA,GAAE,GAC/D,KAAe,CAAA,EACf,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAiCA,MAChD,KAAe,CAAA,EACf,KAAe,CAA6CA,EAAE,GAC9D,KAAe,CAA2CA,MAC1D,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAA2CA,EAAE,GAC5D,KAAe,CAAyCA,GAAE,GAC1D,KAAe,CAAA,EACf,KAAe,CAA4BA,EAAE,GAC7C,KAAe,CAA0BA,MACzC,KAAe,CAAA,EACf,KAAe,CAAqCA,EAAE,GACtD,KAAe,CAAmCA,GAAE,GACpD,KAAe,CAAA,EACf,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,GAAE,GAC9C,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,MAC/C,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,MAC7C,KAAe,CAAA,EACf,KAAe,CAA+BA,EAAE,GAChD,KAAe,CAA6BA,MAC5C,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,GACf,KAAe,CAAwCA,EAAE,GACzD,KAAe,CAAsCA,GAAE,GACvD,KAAe,CAAA,EACf,KAAe,CAAgCA,EAAE,GACjD,KAAe,CAA8BA,GAAE,GAC/C,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAmCA,EAAE,GACpD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAwCA,EAAE,GACzD,KAAe,CAAsCA,GAAE,GACvD,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,MACpD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,MACjD,KAAe,CAAoCA,EAAE,GACrD,KAAe,CAAkCA,GAAE,GACnD,KAAe,CAAiCA,EAAE,GAClD,KAAe,CAA+BA,GAAE,GAChD,KAAe,CAAA,EACf,KAAe,CAAsCA,EAAE,GACvD,KAAe,CAAoCA,GAAE,GACrD,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,MACpD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAuCA,EAAE,GACxD,KAAe,CAAqCA,MACpD,KAAe,CAAA,EACf,KAAe,CAAkCA,EAAE,GACnD,KAAe,CAAgCA,MAC/C,KAAe,CAAA,EACf,KAAe,CAAA,EACf,MAAe,CAAEn2C,EAAE,KAIvB8qG,GAAgB,CAEZ,EAAe,CAAqBv0F,EAAEsjF,IACtC,GAAe,CAAiBtjF,EAAEg8D,IAClC,GAAe,CAAuBh8D,EAAEi8D,IACxC,GAAe,CAAsBj8D,EAAEi8D,IACvC,GAAe,CAA2Bj8D,EAAEo7D,IAC5C,GAAe,CAAyBp7D,EAAEo7D,IAC1C,GAAe,CAAuBp7D,EAAEszD,IACxC,GAAe,CAAsBtzD,EAAEo7D,IACvC,GAAe,CAAqBp7D,EAAEo7D,IACtC,GAAe,CAAsBp7D,EAAEi8D,IACvC,GAAe,CAAoBj8D,EAAEo/D,IACrC,GAAe,CAAoBp/D,EAAEo/D,IACrC,GAAe,CAAyBp/D,EAAE4gE,IAC1C,GAAe,CAAiB5gE,EAAEkgE,IAClC,GAAe,CAAwBlgE,EAAEo7D,IACzC,GAAe,GACf,GAAe,CAAA,EACf,GAAe,CAAkBp7D,EAtjZzC,SAAoB+6B,EAAMh9C,EAAQquD,GAEjC,OAZD,SAAsBrR,EAAMh9C,EAAQquD,GACnC,KAAGA,EAAKmjB,KAAO,GAAf,CACA,IAAI9oE,EAAMs0C,EAAKka,WAAW,GAAIjgD,EAAM+lC,EAAKka,WAAW,GAChD3e,EAAQyE,EAAKka,WAAW,GAAIonD,EAAQthE,EAAKka,WAAW,GACpDqnD,EAAWz/B,GAAuB9hC,EAAM,EAAGqR,GAE/C,OADGA,EAAKmjB,KAAO,GAAGx0B,EAAKka,WAAW,GAC3B,CAAC,CAACxkD,EAAEhK,EAAIiK,EAAEsE,GAAMsnG,EAAUD,EAAO/lE,GACzC,CAKQimE,CAAaxhE,EAAMh9C,EAAQquD,EACnC,GAojZQ,GAAe,GACf,GAAe,CAAsBpsC,EAAEo7D,IACvC,GAAe,CAAwBp7D,EAAEq/D,IACzC,GAAe,CAAwBr/D,EAAEszD,IACzC,GAAe,CAAyBtzD,EAAEszD,IAC1C,GAAe,CAAuBtzD,EAAEszD,IACxC,GAAe,CAA0BtzD,EAAEszD,IAC3C,GAAe,CAAyBtzD,EAAEo7D,IAC1C,GAAe,CAAuBp7D,EAAEo7D,IACxC,GAAe,CAAsBp7D,EAn3T7C,SAAwB+6B,EAAMh9C,EAAmBquD,GAChD,IAAI1P,EAAK,CAAE05B,KAAMhqB,EAAKmjB,MAAQ,EAAIx0B,EAAKka,WAAW,GAAK,GAGvD,OAFGvY,EAAE05B,KAAMif,GAAqBt6C,EAAMh9C,EAAO,EAAG2+C,GAC3Co4C,GAAqB/5C,EAAMqR,EAAKmjB,KAAiCnjB,EAAM1P,GACrEA,CACR,GA+2TQ,GAAe,CAAkB18B,EA/8ZzC,SAAoB+6B,EAAMh9C,EAAQquD,GACjC,IAAI1P,EAAY,CACf8/D,SAAUzhE,EAAKka,WAAW,GAC1BwnD,GAAI1hE,EAAKka,WAAW,IAErB,OAAQ7I,GAAQA,EAAKmjB,MAAS,GAC7B,KAAK,EAAG,MACR,OAAQ,KAAK,EAAGx0B,EAAKrzC,GAAK,EAAG,MAC7B,QAASqzC,EAAKrzC,GAAK,GAGpB,OADAg1C,EAAEn5C,KAAO64E,GAA2BrhC,EAAM,EAAGqR,GACtC1P,CACR,GAo8ZQ,GAAe,CAAuB18B,EAAEi8D,IACxC,GAAe,CAAA,EACf,GAAe,CAAqBj8D,EA5/Z5C,SAAuB+6B,GAItB,MAAO,CAAE2hE,IAAK,CAHJ3hE,EAAKka,WAAW,GAAUla,EAAKka,WAAW,IAG1B0nD,IAAK,CAHgC5hE,EAAKka,WAAW,GAAWla,EAAKka,WAAW,IAG7Di9B,MAFjCn3C,EAAKka,WAAW,GAE+B2nD,OAFjB7hE,EAAKka,WAAW,GAGzD4nD,SAHyE9hE,EAAKka,WAAW,GAGpE6nD,SAFR/hE,EAAKka,WAAW,GAEW8nD,SAFKhiE,EAAKka,WAAW,GAG/D,GAu/ZQ,GAAe,CAAoBj1C,EAAEo7D,IACrC,GAAe,CAAkBp7D,EAx9ZzC,WACA,GAw9ZQ,GAAe,CAAsBA,EAAEi8D,IACvC,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAyBj8D,EAAEi8D,IAC1C,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,GACf,GAAe,CAAyBj8D,EAhpahD,SAA2B+6B,EAAMh9C,EAAQquD,GACxC,GAAGA,EAAKrC,IAAyB,OAAlBhP,EAAKrzC,GAAK3J,EAAe,GACxC,IAAI2J,EAAIqzC,EAAKrzC,EAETs1G,EAAWngC,GAAuB9hC,EAAM,EAAGqR,GAE/C,OADArR,EAAKka,WAAWl3D,EAAS2J,EAAIqzC,EAAKrzC,GAC3Bs1G,CACR,GA0oaQ,GAAe,CAAiBh9F,EA7jZxC,SAAmB+6B,EAAMh9C,EAAQquD,GAChC,GAAGA,GAAQA,EAAKmjB,KAAO,EAAG,OAuB3B,SAAwBx0B,EAAMh9C,EAAQquD,GACrCrR,EAAKrzC,GAAK,EACV,IAAIy2E,EAAKpjC,EAAKka,WAAW,GACrB36B,EAAKygB,EAAKka,WAAW,GACrB6kD,EAAQ/+D,EAAKka,WAAW,GAC5Bla,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACV3J,GAAU,GACV,IAAIk/G,EAAM,GAEV,OADAA,EAAIj5G,MAAMi9E,GAAc9C,IAAK7P,IAAWvzB,EAAMh9C,EAAQquD,IAC/C,CAAE+rD,IAAK,CAAC79E,EAAI6jD,EAAI27B,GAAQ73B,GAAGg7B,EACnC,CA1CkCC,CAAeniE,EAAMh9C,EAAQquD,GAC9D,IAAI+rD,EAAMj6B,GAAYnjC,GAClBkiE,EA7pBL,SAAuBliE,EAAMh9C,GAG5B,IAFA,IAAIo3D,EAAMpa,EAAKrzC,EAAI3J,EACfk/G,EAAM,GACJliE,EAAKrzC,EAAIytD,GAAK,CACnB,IAAI8sB,EAAKlnC,EAAKka,WAAW,GACzBla,EAAKrzC,GAAG,EACR,IACCu1G,EAAIj5G,KAAKq6E,GAAM4D,GAAIlnC,EAAMoa,EAAMpa,EAAKrzC,GACrC,CAAE,MAAMwF,GAAmB,OAAd6tC,EAAKrzC,EAAIytD,EAAY8nD,CAAK,CACxC,CAEA,OADGliE,EAAKrzC,GAAKytD,IAAKpa,EAAKrzC,EAAIytD,GACpB8nD,CACR,CAipBWE,CAAcpiE,EAAMh9C,EAAO,GAAIo6G,EAAI,IAC7C,MAAO,CAAEA,IAAKA,EAAKl2B,GAAGg7B,EACvB,GAyjZQ,GAAe,CAAA,EACf,GAAe,CAA4Bj9F,EAAEo7D,IAC7C,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAwBp7D,EAAEo7D,IACzC,IAAe,CAAqBp7D,EAAEmhE,IACtC,IAAe,CAAkBnhE,EAzxZzC,SAAoB+6B,GACnBA,EAAKrzC,GAAK,EACV,IAAI8iB,EAAM,CAACuwB,EAAKka,WAAW,GAAIla,EAAKka,WAAW,IAG/C,GAFc,IAAXzqC,EAAI,IAAUA,EAAI,KACP,IAAXA,EAAI,IAAUA,EAAI,KAClBA,EAAI,GAAK,GAAKA,EAAI,GAAK,EAAG,MAAM,IAAI9qB,MAAM,gBAAkB8qB,EAAItmB,KAAK,MACxE,OAAOsmB,CACR,GAmxZQ,IAAe,CAAoBxK,EAroa3C,SAAsB+6B,EAAMh9C,EAAQquD,GACnC,IAAI9V,EAAQ8V,GAAqB,GAAbA,EAAKmjB,MAAuB,GAAVxxE,EAAcg9C,EAAKka,WAAW,IAAMla,EAAKrzC,GAAK3J,EAAQ,GAC5F,MAAO,CAAEk5G,QAAiB,GAAR3gE,EAAc4gE,OAAgB,GAAR5gE,EAAc6gE,OAAgB,IAAR7gE,EAC/D,GAmoaQ,IAAe,CAAqBt2B,EAAEi8D,IACtC,IAAe,CAAqBj8D,EAAEo7D,IACtC,IAAe,CAAqBp7D,EAAEo7D,IACtC,IAAe,CAAyBp7D,EAnoahD,SAA2B+6B,EAAMh9C,EAAQquD,GACxC,IAAIiiB,EAAMtzB,EAAKka,WAAW,GACtB8zB,EAA8B,EAArBhuC,EAAKka,WAAW,GACzBtD,EAAK5W,EAAKka,WAAW,GACzB,OAAOtD,GACN,OAAQA,EAAK,YAAa,MAC1B,KAAK,EAAGA,EAAK,aAAc,MAC3B,OAAQA,EAAK,aAAc,MAC3B,KAAK,EAAGA,EAAK,YAEd,IAAIpuD,EAAO64E,GAA2BrhC,EAAM,EAAGqR,GAE/C,OADmB,IAAhB7oD,EAAKxF,SAAcwF,EAAO,UACtB,CAAE8qE,IAAIA,EAAKpqC,GAAG8kD,EAAQp3B,GAAGA,EAAIpuD,KAAKA,EAC1C,GAunaQ,IAAe,CAAA,EACf,IAAe,CAAqByc,EA/8Y5C,SAAuB+6B,GACtB,IAAep4B,EAAX+5B,EAAI,CAAC,EAAE,GAGX,OAFA/5B,EAAIo4B,EAAKka,WAAW,GAAIvY,EAAE,GAAKk3B,GAAYjxD,IAAMA,EACjDA,EAAIo4B,EAAKka,WAAW,GAAIvY,EAAE,GAAKk3B,GAAYjxD,IAAMA,EAC1C+5B,CACR,GA28YQ,IAAe,CAAqB18B,EAAEi8D,IACtC,IAAe,CAAA,EACf,IAAe,CAAqBj8D,EA57Y5C,SAAuB+6B,GAGtB,IAFA,IAAIqiE,EAAMriE,EAAKka,WAAW,GACtBvY,EAAI,GACF0gE,KAAM,GAAG1gE,EAAE14C,KAAKw5E,GAAcziC,IACpC,OAAO2B,CACR,GAw7YQ,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAiC18B,EAAEi8D,IAClD,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAiBj8D,EAAE0hE,IAClC,IAAe,CAAmB1hE,EAv5Y1C,SAAqB+6B,EAAMh9C,GAC1B,IAAI2+C,EAAI,GACR,OAAG3+C,EAAS,KACZg9C,EAAKrzC,GAAK,GACVg1C,EAAEyG,OAASmwB,GAAWv4B,GACtB2B,EAAE8nD,OAASlxB,GAAWv4B,GACtBA,EAAKrzC,GAAK,GAJag1C,CAMxB,GAg5YQ,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAmB18B,EAx5Z1C,SAAqB+6B,EAAMh9C,GAI1B,IAHA,IAAI6B,EAASm7C,EAAKrzC,EAAI3J,EAAS,EAC3Bs/G,EAAKtiE,EAAKka,WAAW,GAAIjgD,EAAM+lC,EAAKka,WAAW,GAC/CqoD,EAAS,GACPviE,EAAKrzC,EAAI9H,GAAQ09G,EAAOt5G,KAAK45E,GAAY7iC,IAC/C,GAAGA,EAAKrzC,IAAM9H,EAAQ,MAAM,IAAIF,MAAM,oBACtC,IAAI69G,EAAUxiE,EAAKka,WAAW,GAC9B,GAAGqoD,EAAOv/G,QAAUw/G,EAAUvoG,EAAM,EAAG,MAAM,IAAItV,MAAM,yBACvD,MAAO,CAAC+Q,EAAE4sG,EAAI3sG,EAAEsE,EAAKuW,EAAEgyF,EAAS9F,MAAM6F,EACvC,GAg5ZQ,IAAe,CAAsBt9F,EA94Z7C,SAAwB+6B,EAAMh9C,GAI7B,IAHA,IAAI6B,EAASm7C,EAAKrzC,EAAI3J,EAAS,EAC3Bs/G,EAAKtiE,EAAKka,WAAW,GAAIjgD,EAAM+lC,EAAKka,WAAW,GAC/CuoD,EAAQ,GACNziE,EAAKrzC,EAAI9H,GAAQ49G,EAAMx5G,KAAK+2C,EAAKka,WAAW,IAClD,GAAGla,EAAKrzC,IAAM9H,EAAQ,MAAM,IAAIF,MAAM,uBACtC,IAAI69G,EAAUxiE,EAAKka,WAAW,GAC9B,GAAGuoD,EAAMz/G,QAAUw/G,EAAUvoG,EAAM,EAAG,MAAM,IAAItV,MAAM,4BACtD,MAAO,CAAC+Q,EAAE4sG,EAAI3sG,EAAEsE,EAAKuW,EAAEgyF,EAAS7/B,KAAK8/B,EACtC,GAs4ZQ,IAAe,CAAiBx9F,EAAEg8D,IAClC,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAoBh8D,EAAEo7D,IACrC,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAsBp7D,EAAEi8D,IACvC,IAAe,CAAA,EACf,IAAe,CAA6Bj8D,EAAEo7D,IAC9C,IAAe,CAAA,EACf,IAAe,CAAgBp7D,EA/2ZvC,SAAkB+6B,EAAMh9C,EAAQquD,GAC/B,IAAI1P,EAAI,CAAA,EAKR,OAJAA,EAAE01B,KAAOr3B,EAAKka,WAAW,GAAIvY,EAAE+zB,SAAW11B,EAAKka,WAAW,GAAIvY,EAAEpG,MAAQyE,EAAKka,WAAW,GACxFvY,EAAE+gE,OAAU/gE,EAAEpG,OAAS,EAAK,EAE5BoG,EAAEj1C,KAjDH,SAA2BszC,EAAMh9C,EAAQm8B,EAAOkyB,GAC/C,IAAI1P,EAAI,GACJ3rC,EAAIgqC,EAAKka,WAAW,GAAIjkD,EAAI+pC,EAAKka,WAAW,GAC5CvkD,EAAIqqC,EAAKka,WAAW,GAAItyC,EAAIo4B,EAAKka,WAAW,GAGhD,OAFAvY,EAAE69C,YAAc1mB,GAAenjE,GAAK,IAEhC07C,EAAKg1B,YACT1kC,EAAEghE,IAAU,EAAJ3sG,EACR2rC,EAAEihE,MAAS5sG,GAAK,EAAK,EACrB2rC,EAAEkhE,KAAQ7sG,GAAK,EAAK,EACpB2rC,EAAEmhE,UAAa9sG,GAAK,EAAK,EACzB2rC,EAAEohE,KAAQ/sG,GAAK,EAAK,IACpB2rC,EAAEqhE,QAAWhtG,GAAK,GAAM,GACxB2rC,EAAEshE,aAAgBjtG,GAAK,GAAM,EAC7B2rC,EAAEuhE,WAAcltG,GAAK,GAAM,EAC3B2rC,EAAEwhE,QAAWntG,GAAK,GAAM,EACxB2rC,EAAEyhE,QAAWptG,GAAK,GAAM,EACxB2rC,EAAE0hE,QAAWrtG,GAAK,GAAM,EACxB2rC,EAAE2hE,QAAWttG,GAAK,GAAM,EACxB2rC,EAAE4hE,QAAWvtG,GAAK,GAAM,EACxB2rC,EAAE6hE,SAAYxtG,GAAK,GAAM,EAEzB2rC,EAAE8hE,OAAa,GAAJxtG,EACX0rC,EAAE+hE,QAAWztG,GAAK,EAAK,GACvB0rC,EAAEgiE,MAAS1tG,GAAK,EAAK,GACrB0rC,EAAEiiE,SAAY3tG,GAAK,GAAM,GACzB0rC,EAAEkiE,QAAW5tG,GAAK,GAAM,IACxB0rC,EAAEmiE,SAAY7tG,GAAK,GAAM,IACzB0rC,EAAEoiE,UAAa9tG,GAAK,GAAM,EAE1B0rC,EAAEqiE,OAAa,IAAJruG,EACXgsC,EAAEsiE,UAAatuG,GAAK,EAAK,IACzBgsC,EAAEuiE,QAAWvuG,GAAK,GAAM,IACxBgsC,EAAEwiE,OAAUxuG,GAAK,GAAM,GAEvBgsC,EAAEm5D,QAAc,IAAJlzF,EACZ+5B,EAAEo5D,QAAWnzF,GAAK,EAAK,IACvB+5B,EAAEyiE,UAAax8F,GAAK,GAAM,EACnB+5B,GAhCqBA,CAiC7B,CAUU0iE,CAAkBrkE,EAAMh9C,EAAQ2+C,EAAE+gE,OAAQrxD,GAC5C1P,CACR,GAy2ZQ,IAAe,CAA0B18B,EA1tajD,SAA4B+6B,EAAMh9C,GACjC,OAAc,IAAXA,GACCg9C,EAAKka,WAAW,GADI,IAGzB,GAutaQ,IAAe,CAA0Bj1C,EAAEg8D,IAC3C,IAAe,GACf,IAAe,CAAwBh8D,EA/oZ/C,SAA0B+6B,EAAMh9C,GAG/B,IAFA,IAAIipG,EAA0B,GAC1BqY,EAAOtkE,EAAKka,WAAW,GACpBoqD,KAAQrY,EAAOhjG,KAAK65E,GAAY9iC,IACvC,OAAOisD,CACR,GA2oZQ,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAiBhnF,EA/qaxC,SAAmB+6B,EAAMh9C,GAKxB,IAJA,IAAI+lE,EAAM/oB,EAAKrzC,EAAI3J,EACf07D,EAAM1e,EAAKka,WAAW,GACtBqqD,EAAOvkE,EAAKka,WAAW,GACvBivC,EAAgB,GACZ/kG,EAAI,EAAGA,GAAKmgH,GAAQvkE,EAAKrzC,EAAIo8D,IAAO3kE,EAC3C+kG,EAAKlgG,KAAKs4E,GAAkCvhC,IAG7C,OADAmpD,EAAK+I,MAAQxzC,EAAKyqC,EAAKgJ,OAASoS,EACzBpb,CACR,GAsqaQ,IAAe,CAAsBlkF,EAvha7C,SAAwB+6B,GACvB,IAAIq0B,EAAOqO,GAAc1iC,GAEzB,OADAq0B,EAAK0oC,KAAO/8D,EAAKka,WAAW,GACrBma,CACR,GAohaQ,IAAe,CAAoBpvD,EA1pa3C,SAAsB+6B,EAAMh9C,GAC3B,IAAIwhH,EAAS,GAGb,OAFAA,EAAOC,KAAOzkE,EAAKka,WAAW,GAC9Bla,EAAKrzC,GAAK3J,EAAO,EACVwhH,CACR,GAspaQ,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAqBv/F,EAAEk8D,IACtC,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAsBl8D,EAAEo7D,IACvC,IAAe,CAAiBp7D,EAAEg8D,IAClC,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAqBh8D,EA31Z5C,SAAuB+6B,EAAMh9C,EAAQquD,GACpC,IAAI0X,EAAM/oB,EAAKrzC,EAAI3J,EACf0hH,EAAO1kE,EAAKka,WAAW,GACvBonB,EAAMthC,EAAKka,WAAW,GAE1B,GADA7I,EAAKyzB,MAAQxD,EACH,MAAPA,GAAwB,OAAPA,EAAe,MAAO,CAACA,EAAKojC,GAChD,GAAGpjC,EAAM,GAAQA,EAAK,IAAM,MAAM,IAAI38E,MAAM,4BAA4B28E,GAIxE,IAHA,IAAIqjC,EAAW/iC,GAA2B5hC,EAAMshC,GAE5CsjC,EAAO,GACL77C,EAAM/oB,EAAKrzC,GAAGi4G,EAAK37G,KAAK44E,GAAsB7hC,IACpD,MAAO,CAACshC,EAAKojC,EAAMC,EAAUC,EAC9B,GAg1ZQ,IAAe,CAAsB3/F,EAAEo7D,IACvC,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAiBp7D,EAhpZxC,SAAmB+6B,EAAMh9C,EAAQquD,GAChC,IAAIt/C,EAAIiuC,EAAKrzC,EACTk4G,EAAQ,GACb,IACC7kE,EAAKrzC,GAAK,EACV,IAAIy2E,GAAM/xB,EAAKgsD,SAAS,CAACD,IAAI,CAAC,EAAE,KAAKA,IAAI,IAEL,GAAjC,CAAC,EAAE,EAAE,EAAE,GAAG,GAAG,IAAI96E,QAAQ8gD,GAAWpjC,EAAKrzC,GAAK,EAv9BlD,SAA2BqzC,GAC1B,IAAIzE,EAAQyE,EAAKka,WAAW,GAC5Bla,EAAKrzC,IACL,IAAIm4G,EAAQ9kE,EAAKka,WAAW,GAE5B,OADAla,EAAKrzC,GAAK,EACH,CAAC4uC,EAAOupE,EAChB,CAk9BoBC,CAAkB/kE,GACrC,IAAIglE,EAAUhlE,EAAKka,WAAW,GACbla,EAAKka,WAAW,GACbgnB,GAAYlhC,GAChC,IAAIx2C,EAAMw2C,EAAKka,WAAW,GAC1Bla,EAAKrzC,GAAKnD,EAGV,IAAI,IAAIpF,EAAI,EAAGA,EAAI47C,EAAK2yB,KAAK3vE,OAAO,IAAKoB,EAAG,CAC3C,GAAG47C,EAAKrzC,EAAEoF,GAAKiuC,EAAK2yB,KAAKvuE,GAAI,MAAM,IAAIO,MAAM,4BAC7C,IAAImyF,EAAM92C,EAAKA,EAAKrzC,GAGpB,IADAk4G,GADQjjC,GAA2B5hC,EAAMA,EAAK2yB,KAAKvuE,EAAE,GAAG47C,EAAK2yB,KAAKvuE,GAAG,IAE5DpB,SAAW8zF,EAAMkuB,EAAU,EAAEA,GAAU,KACjD,CACA,GAAGH,EAAM7hH,SAAWgiH,GAAWH,EAAM7hH,SAAmB,EAARgiH,EAC/C,MAAM,IAAIrgH,MAAM,YAAcqgH,EAAU,OAASH,EAAM7hH,QAWxD,OARAg9C,EAAKrzC,EAAIoF,EAAI/O,EAQN,CAAEgf,EAAG6iG,EACb,CAAE,MAAM1yG,GAA0B,OAArB6tC,EAAKrzC,EAAIoF,EAAI/O,EAAe,CAAEgf,EAAG6iG,EAAS,CACvD,GA4mZQ,IAAe,CAAwB5/F,EAAEo7D,IACzC,IAAe,CAAmBp7D,EA1mZ1C,SAAqB+6B,EAAMh9C,GAC1B,IAAIgjF,EAAMlD,GAAY9iC,GACtBA,EAAKrzC,GAAK,GACV,IAAIw/F,EA57BL,SAAyBnsD,EAAMh9C,GAC9B,IAAI+lE,EAAM/oB,EAAKrzC,EAAI3J,EACfiiH,EAAOjlE,EAAKka,WAAW,GAC3B,GAAY,IAAT+qD,EAAY,MAAM,IAAItgH,MAAM,+BAAiCsgH,GAChE,IAAI1pE,EAAQyE,EAAKka,WAAW,GAC5Bla,EAAKrzC,GAAK,EACV,IAAIu4G,EAAaC,EAAiBC,EAASC,EAAoBrS,EAAMsS,EAAdC,EAAI,GAChD,GAARhqE,IAAgB2pE,EAAc3iC,GAAsBviC,EAAYA,EAAKrzC,IAC7D,IAAR4uC,IAAgB4pE,EAAkB5iC,GAAsBviC,EAAYA,EAAKrzC,IACpD,KAApB4uC,IAA4B6pE,EAAU7iC,GAAsBviC,EAAYA,EAAKrzC,IACzD,IAAZ,IAAR4uC,KAA4B8pE,EAAatjC,GAAuB/hC,EAAYA,EAAKrzC,IAC1E,EAAR4uC,IAAgBgqE,EAAMhjC,GAAsBviC,EAAYA,EAAKrzC,IACrD,GAAR4uC,IAAgBy3D,EAAOhzD,EAAKka,WAAW,KAC/B,GAAR3e,IAAgB+pE,EAAWxnC,GAAe99B,IAC7CA,EAAKrzC,EAAIo8D,EACT,IAAIlkE,EAASsgH,GAAiBC,GAASC,GAAY,GAChDxgH,GAAU0gH,IAAK1gH,GAAQ,IAAI0gH,GAC1B1gH,IAAQA,EAAS,IAAM0gH,GACf,EAARhqE,GAAuC,KAApB12C,EAAOshD,OAAO,IAAiC,KAApBthD,EAAOshD,OAAO,KAAWthD,EAAS,UAAYA,GAChG,IAAI4qB,EAAO,CAAC6rD,OAAOz2E,GAInB,OAHGmuG,IAAMvjF,EAAIujF,KAAOA,GACjBsS,IAAU71F,EAAI2f,KAAOk2E,GACrBJ,IAAaz1F,EAAI88E,QAAU2Y,GACvBz1F,CACR,CAo6Ba+1F,CAAgBxlE,EAAMh9C,EAAO,IACzC,MAAO,CAACgjF,EAAKmmB,EACd,GAsmZQ,IAAe,CAAA,EACf,IAAe,CAAsBlnF,EAAE48D,IACvC,IAAe,CAAA,EACf,IAAe,CAA0B58D,EAAEi8D,IAC3C,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAwBj8D,EAAEg8D,IACzC,IAAe,CAAsBh8D,EAxqa7C,SAAwB+6B,GAEvB,OADAA,EAAKka,WAAW,GACTla,EAAKka,WAAW,EACxB,EAqqa+DxkD,EAAE,GACzD,IAAe,CAAqBuP,EAAEg8D,IACtC,IAAe,CAAwBh8D,EAAEi/D,IACzC,IAAe,CAAmBj/D,EAAEyhE,IACpC,IAAe,CAAoBzhE,EAh4Z3C,SAAsB+6B,EAAMh9C,EAAQquD,GAChCA,EAAKkrD,WAA0B,GAAblrD,EAAKmjB,OAAWnjB,EAAKmjB,KAAO,GACjD,IAAIH,EAAOqO,GAAc1iC,GACrBylE,EAAOltC,GAAWv4B,GAEtB,OADAq0B,EAAKj/C,IAAMqwF,EACJpxC,CACR,GA23ZQ,IAAe,CAAmBpvD,EArka1C,SAAqB+6B,EAAMh9C,EAAQquD,GAC/BA,EAAKkrD,WAA0B,GAAblrD,EAAKmjB,OAAWnjB,EAAKmjB,KAAO,GACpCx0B,EAAKrzC,EAAlB,IACI0nE,EAAOqO,GAAc1iC,GACT,GAAbqR,EAAKmjB,MAAWx0B,EAAKrzC,IACxB,IAAIlD,EAAMo4E,GAAsB7hC,EAAeA,EAAKrzC,EAAG0kD,GAEvD,OADAgjB,EAAKj/C,IAAM3rB,EACJ4qE,CACR,GA8jaQ,IAAe,CAAqBpvD,EAAEk/D,IACtC,IAAe,CAAoBl/D,EAAE2hE,IACrC,IAAe,CAAiB3hE,EA9saxC,SAAmB+6B,GAClB,IAAI/2B,EAAK,CAAA,EACTA,EAAEvT,EAAIsqC,EAAKka,WAAW,GACtBjxC,EAAEtT,EAAIqqC,EAAKka,WAAW,GACtBjxC,EAAEy1C,IAAM1e,EAAKka,WAAW,GAAKjxC,EAAEtT,EAC/B,IAAIiuE,EAAQ5jC,EAAKka,WAAW,GAC5Bla,EAAKrzC,GAAK,EACV,IAAI4uC,EAAQyE,EAAKka,WAAW,GAM5B,OALAla,EAAKrzC,GAAK,EACC,EAAR4uC,IAActyB,EAAEw9D,MAAgB,EAARlrC,GAEhB,GAARA,IAActyB,EAAE+kE,QAAS,GACjB,GAARzyC,IAActyB,EAAEilE,IAAMtK,EAAQ,IAC1B36D,CACR,GAisaQ,IAAe,CAAA,EACf,IAAe,CAAmBhE,EAAE8gE,IACpC,IAAe,CAA8B9gE,EAAE0+D,IAC/C,IAAe,CAAA,EACf,IAAe,CAAqB1+D,EA5oa5C,SAAuB+6B,EAAMh9C,EAAQquD,GACpC,OAAGA,GAAQA,EAAKmjB,MAAQ,GAAKnjB,EAAKmjB,KAAO,EAAU,CAAA,EAE5C,CAAE82B,IAAS,GADVtrD,EAAKka,WAAW,GAEzB,GAyoaQ,IAAe,CAAgBj1C,EAlhavC,SAAkB+6B,GACjB,IAAIsiE,EAAKtiE,EAAKka,WAAW,GAAIjgD,EAAM+lC,EAAKka,WAAW,GAC/CwiD,EAAQ75B,GAAY7iC,GACxB,MAAO,CAACtqC,EAAE4sG,EAAI3sG,EAAEsE,EAAK0oE,KAAK+5B,EAAM,GAAID,MAAMC,EAAM,GACjD,GA+gaQ,IAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAoBz3F,EA5ja3C,SAAsB+6B,EAAMh9C,EAAQquD,GAGnC,MAAO,CAFQrR,EAAKka,WAAW,GAClB4nB,GAAuB9hC,EAAM,EAAGqR,GAE9C,GAyjaQ,KAAe,CAAA,EACf,KAAe,CAAqBpsC,EAtxZ5C,SAAuB+6B,EAAMh9C,EAAQquD,GACpC,IAAI20B,EAAM/C,GAAWjjC,GACrBA,EAAKrzC,IACL,IAAI+4G,EAAO1lE,EAAKka,WAAW,GAE3B,MAAO,CAACouC,GAA0BtoD,EADlCh9C,GAAU,EACsCquD,GAAOq0D,EAAM1/B,EAC9D,GAixZQ,KAAe,CAA0B/gE,EApnZjD,SAA4B+6B,EAAMh9C,GACjCg9C,EAAKka,WAAW,GAChB,IAAI8rB,EAAMlD,GAAY9iC,GAClB2lE,EAAY3lE,EAAKka,YAAYl3D,EAAO,IAAI,EAAG,aAE/C,MAAO,CAACgjF,EADR2/B,EAAYA,EAAUzmF,QAAQ2wB,GAAK,IAEpC,GA+mZQ,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAiB5qC,EAAEw+D,IAClC,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAqB/tE,EAAE,IACtC,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAqBuP,EAAEg8D,IACtC,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAmBh8D,EApnZ1C,SAAqB+6B,GACpBA,EAAKrzC,GAAK,EACV,IAAIg1C,EAAI,CAACikE,KAAK,EAAGC,IAAI,GAGrB,OAFAlkE,EAAEikE,KAAO5lE,EAAKka,WAAW,GACzBvY,EAAEkkE,IAAM7lE,EAAKka,WAAW,GACjBvY,CACR,EA8mZyDjsC,EAAE,IACnD,KAAe,CAAmBuP,EAlwR1C,SAAqB+6B,EAAMh9C,GAChBg9C,EAAKrzC,EACfqzC,EAAKrzC,GAAK,EACV,IAAIg2E,EAAO3iC,EAAKka,WAAW,GAC3Bla,EAAKrzC,GAAK,EAGV,IAFA,IAAIm5G,EAAQ9lE,EAAKka,WAAW,GACxB0O,EAAc,GACZk9C,KAAU,GAAGl9C,EAAI3/D,KAAK24F,GAAc5hD,EAAUA,EAAKrzC,IACzD,MAAO,CAACg2E,KAAKA,EAAM/Z,IAAIA,EACxB,EAyvRyDlzD,EAAE,IACnD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAsBuP,EAAEo7D,GAAW3qE,EAAE,IACpD,KAAe,CAAA,EACf,KAAe,CAAyBA,EAAE,IAC1C,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAqBuP,EAt2Z5C,SAAuB+6B,EAAMh9C,EAAQquD,GACpC,KAAGA,EAAKmjB,KAAO,GAAf,CACA,IAAI2R,EAAUnmC,EAAKka,WAAW,GAC1B6rD,EAAa/lE,EAAKka,WAAW,GAGjC,MAAO,CAFI0nB,GAA2B5hC,EAAMmmC,EAAS90B,GACvCuwB,GAA2B5hC,EAAM+lE,EAAY10D,GAJb,CAA1BrR,EAAKrzC,GAAK3J,CAM/B,EA+1Z6D0S,EAAE,IACvD,KAAe,GACf,KAAe,CAAmBuP,EAj1R1C,SAAqB+6B,EAAMh9C,EAAQquD,GAClC,IAAI0X,EAAM/oB,EAAKrzC,EAAI3J,EAEnB,GAAsB,SADDg9C,EAAKka,WAAW,GAErC,GAAI7I,EAAKg1B,WAAT,CACA,IAEItZ,EAFArgE,EAAOszC,EAAKv8C,MAAMu8C,EAAKrzC,GAC3BqzC,EAAKrzC,EAAIo8D,EACA,IAAMgE,EAAMU,GAAS/gE,EAAM,CAAC2E,KAAM,SAAW,CAAE,MAAMc,GAAK,MAAQ,CAC3E,IAAI6zG,EAAW74C,GAAUJ,EAAK,0BAA0B,GACxD,GAAIi5C,EACJ,OAAO5kB,GAAgB4kB,EAAU30D,EANY,MAAtBrR,EAAKrzC,EAAIo8D,CAOjC,EAs0RyDrzD,EAAE,IACnD,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAyBuP,EA70ZhD,SAA2B+6B,GAI1B,MAAO,CAHkC,IAAvBA,EAAKka,WAAW,GACe,IAAvBla,EAAKka,WAAW,GACnBla,EAAKka,WAAW,GAExC,EAw0ZqExkD,EAAE,IAC/D,KAAe,CAA8BuP,EAAEg8D,IAC/C,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAkCh8D,EAzxazD,SAAoC+6B,GACnC,IAAIoI,EApSL,SAAyBpI,GACxB,IAAIylD,EAAKzlD,EAAKka,WAAW,GACrB3e,EAAQyE,EAAKka,WAAW,GAE5B,OADAla,EAAKrzC,GAAK,EACH,CAAC0E,KAAMo0F,EAAIlqD,MAAOA,EAC1B,CA+Rc0qE,CAAgBjmE,GAC7B,GAAkB,MAAfoI,EAAO/2C,KAAgB,MAAM,IAAI1M,MAAM,yBAA2ByjD,EAAO/2C,MAE5E,OAAoB,IADL2uC,EAAKka,WAAW,EAEhC,GAqxaQ,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAmBj1C,EAAEi8D,IACpC,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAsBj8D,EA/oZ7C,SAAwB+6B,EAAMh9C,EAAQquD,GACrC,IAAImb,EAAM,CAAC04B,MAAK,GAChB,GAAgB,GAAb7zC,EAAKmjB,KAA+B,OAAlBx0B,EAAKrzC,GAAK3J,EAAewpE,EAC9C,IAAI5kD,EAAIo4B,EAAKka,WAAW,GAExB,OAF4Bla,EAAKrzC,GAAK,EAC9B,GAAJib,IAAW4kD,EAAI04B,MAAO,GACnB14B,CACR,GA0oZQ,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAwBvnD,EA5tZ/C,SAA0B+6B,GAGzB,IAFA,IAAIqiE,EAAMriE,EAAKka,WAAW,GACtBvY,EAAI,GACF0gE,KAAM,GAAG1gE,EAAE14C,KAAKw5E,GAAcziC,IACpC,OAAO2B,CACR,GAwtZQ,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EAEf,EAAe,CAAwB18B,EAAEi/D,IACzC,EAAe,CAAA,EACf,EAAe,CAAsBj/D,EAlnZ7C,SAAwB+6B,GACvB,IAAIq0B,EAAOqO,GAAc1iC,KACvBA,EAAKrzC,EACP,IAAItD,EAAM22C,EAAKka,WAAW,GAG1B,OAFAma,EAAKryD,EAAI,IACTqyD,EAAKj/C,IAAM/rB,EACJgrE,CACR,GA4mZQ,EAAe,CAAsBpvD,EAloZ7C,SAAwB+6B,GACvB,IAAIq0B,EAAOqO,GAAc1iC,KACvBA,EAAKrzC,EACP,IAAItD,EAAMkvE,GAAWv4B,GAGrB,OAFAq0B,EAAKryD,EAAI,IACTqyD,EAAKj/C,IAAM/rB,EACJgrE,CACR,GA4nZQ,EAAe,CAAsBpvD,EA7oZ7C,SAAwB+6B,EAAMh9C,EAAQquD,GAClCA,EAAKkrD,WAA0B,GAAblrD,EAAKmjB,OAAWnjB,EAAKmjB,KAAO,GACjD,IAAIH,EAAOqO,GAAc1iC,KACvBA,EAAKrzC,EACP,IAAIlD,EAAMq4E,GAAuB9hC,EAAMh9C,EAAUquD,GAGjD,OAFAgjB,EAAKryD,EAAI,MACTqyD,EAAKj/C,IAAM3rB,EACJ4qE,CACR,GAsoZQ,EAAe,CAAqBpvD,EAAEk/D,IACtC,EAAe,CAAoBl/D,EAvmZ3C,SAA2B+6B,GAC1B,IAAIshC,EAAMthC,EAAKka,WAAW,GAC1B,OAAW,IAARonB,GAAathC,EAAKrzC,IAAY,IAC1BqzC,EAAKka,WAAWonB,EAAK,YAC7B,GAomZQ,EAAe,CAAA,EACf,EAAe,CAAiBr8D,EAAEw+D,IAClC,GAAe,CAAA,EACf,GAAe,CAAyBx+D,EAAEi8D,IAC1C,GAAe,CAAyBj8D,EAAEg/D,IAC1C,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAAmBh/D,EAAE8gE,IACpC,GAAe,CAAA,EACf,GAAe,CAA8B9gE,EAAE0+D,IAK/C,GAAe,CAA2B1+D,EA/mZlD,SAA6B+6B,EAAMh9C,GAClCg9C,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK,EACVqzC,EAAKrzC,GAAK3J,EAAS,EACpB,GAgnZQ,GAAe,CAAA,EAcf,GAAe,CAAA,EACf,GAAe,CAAA,EACf,GAAe,CAA0BiiB,EAAEi8D,IAC3C,GAAe,CAAA,EACf,GAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAoBj8D,EApsZ3C,SAAsB+6B,GACrB,IAAIujC,EAAKvjC,EAAKka,WAAW,GACrBgsD,EAAMlmE,EAAKka,WAAW,GACtBisD,EAAMnmE,EAAKka,WAAW,GACtBvY,EAAI,CAACsR,IAAIswB,EAAI2iC,IAAIA,EAAK18G,IAAI28G,EAAKz5G,KAAKszC,EAAKv8C,MAAMu8C,EAAKrzC,EAAEqzC,EAAKrzC,EAAEw5G,IAEjE,OADAnmE,EAAKrzC,GAAKw5G,EACHxkE,CACR,GA8rZQ,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EAKf,IAAe,CAAA,EAEf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EAIf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAqB18B,EAxpZ5C,SAAuB+6B,EAAMh9C,EAAQquD,GACpC,IAAI0X,EAAM/oB,EAAKrzC,EAAI3J,EACfqxE,EAAOqO,GAAc1iC,GACrBshC,EAAMthC,EAAKka,WAAW,GACtBzwD,EAAMm4E,GAA2B5hC,EAAMshC,EAAKjwB,GAIhD,OAHArR,EAAKrzC,EAAIo8D,EACTsL,EAAKryD,EAAI,MACTqyD,EAAKj/C,IAAM3rB,EACJ4qE,CACR,GAgpZQ,IAAe,CAAA,EACf,IAAe,GACf,IAAe,CAAA,EACf,IAAe,CAAA,EACf,IAAe,CAAqBpvD,EAAEsjF,IACtC,IAAe,CAAiBtjF,EAAEw+D,IAClC,IAAe,CAAiBx+D,EAAEkgE,IAClC,IAAe,CAAwBlgE,EAAEq/D,IACzC,IAAe,CAAA,EACf,IAAe,GACf,KAAe,CAAqBr/D,EAAEsjF,IACtC,KAAe,CAAiBtjF,EAAEw+D,IAClC,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAA,EACf,KAAe,GACf,KAAe,CAAwB/tE,EAAE,IAEzC,MAAe,CAAA,GAGvB,SAASo+E,GAAezL,EAAiBh3E,EAAiBktD,EAASv7D,GAClE,IAAIgf,EAAe3Q,EACnB,IAAG7K,MAAMwb,GAAT,CACA,IAAIxY,GAAiB+0D,GAAS,IAAIv7D,QAAU,EACxC2+C,EAAI0mC,EAAG1lD,KAAK,GAChBgf,EAAEmY,YAAY,EAAG93C,GACjB2/B,EAAEmY,YAAY,EAAGtwD,GACOA,EAAM,GAAK0oE,GAAO3T,IAAU8pB,EAAGp/E,KAAKs1D,EAL/C,CAMd,CAyYA,SAASo3C,GAAclsG,EAAgBg2D,GACtC,IAAIpO,EAAOoO,GAAS,CAAA,EAEhB4W,EAAmBhlB,EAAK+kB,MAAS,GAAe,CAAA,EAEhDu0B,GADJlhG,EAAMA,EAAIy1B,QAAQ,cAAe,KACVF,MAAM,WAC7B,IAAI2rE,EAAM,MAAM,IAAIhmG,MAAM,wCAC1B,IAAIyhH,EAAgB38G,EAAIu1B,MAAM,aAC1B56B,EAAeumG,EAAK3lG,MAAOX,EAAe+hH,GAASA,EAAMphH,OAASyE,EAAIzG,OACtEyF,EAAO6jE,GAAY7iE,EAAIhG,MAAMW,EAAGC,GAAI,iBAAkB,QACtDiiD,GAAI,EAAI91B,EAAI,EAAGk+D,EAAK,EAAGpU,EAAK,EAC5BlzD,EAAkB,CAACrV,EAAE,CAAC2D,EAAE,IAAUC,EAAE,KAAUxD,EAAE,CAACuD,EAAE,EAAEC,EAAE,IACvDs2F,EAA0B,GAC9B,IAAI7nG,EAAI,EAAGA,EAAIqE,EAAKzF,SAAUoB,EAAG,CAChC,IAAIsH,EAAMjD,EAAKrE,GAAGqvC,OACd4yE,EAAK36G,EAAIjI,MAAM,EAAE,GAAG6uC,cACxB,GAAS,OAAN+zE,GACH,GAAS,OAANA,GAAqB,OAANA,EAAlB,CACA,IAAI9Y,EAAQ7hG,EAAI4wC,MAAM,cACtB,IAAIj4C,EAAI,EAAGA,EAAIkpG,EAAMvqG,SAAUqB,EAAG,CACjC,IAAIgwE,EAAOk5B,EAAMlpG,GAAGovC,OACpB,GAAI4gC,EAAKr1C,MAAM,WAAf,CAGA,IAFA,IAAIvwB,EAAI4lE,EAAMjgB,EAAK,EAEE,KAAf3lD,EAAE03C,OAAO,KAAciO,EAAK3lD,EAAE6zB,QAAQ,OAAQ,GAAI7zB,EAAIA,EAAEhL,MAAM2wD,EAAG,GACvE,IAAI,IAAIkyD,EAAO,EAAGA,EAAOra,EAAOjpG,SAAUsjH,EAAM,CAC/C,IAAIpa,EAAmBD,EAAOqa,GAC3Bpa,EAAOn6F,EAAE4D,GAAK6a,GAAK07E,EAAOn6F,EAAE2D,EAAI4wC,GAAKA,GAAK4lD,EAAO/5F,EAAEuD,IAAK8a,EAAI07E,EAAO/5F,EAAEwD,EAAI,EAAG2wG,GAAO,EACvF,CACA,IAAI5jH,EAAMurE,GAAYoG,EAAK5wE,MAAM,EAAG4wE,EAAK/xC,QAAQ,OACjDg4C,EAAK53E,EAAI6jH,SAAW7jH,EAAI6jH,QAAU,IAC9B73B,GAAMhsF,EAAI8jH,SAAS,GAAKlsC,EAAG,IAAG2xB,EAAOhjG,KAAK,CAAC8I,EAAE,CAAC2D,EAAE4wC,EAAE3wC,EAAE6a,GAAGre,EAAE,CAACuD,EAAE4wC,GAAKooC,GAAI,GAAK,EAAG/4E,EAAE6a,EAAI8pD,EAAK,KAC5F,IAAImsC,EAAgB/jH,EAAIsf,GAAKtf,EAAI,WAAa,GAE9C,GAAI+L,EAAEzL,OAIN,GAHAyL,EAAIkhE,GAAWlhE,GACZ2Y,EAAMrV,EAAE2D,EAAI4wC,IAAGl/B,EAAMrV,EAAE2D,EAAI4wC,GAAMl/B,EAAMjV,EAAEuD,EAAI4wC,IAAGl/B,EAAMjV,EAAEuD,EAAI4wC,GAC5Dl/B,EAAMrV,EAAE4D,EAAI6a,IAAGpJ,EAAMrV,EAAE4D,EAAI6a,GAAMpJ,EAAMjV,EAAEwD,EAAI6a,IAAGpJ,EAAMjV,EAAEwD,EAAI6a,GAC3D/hB,EAAEzL,OAAN,CACA,IAAI2+C,EAAa,CAAC3/B,EAAE,IAAKtR,EAAEjC,GACxB4iD,EAAKiN,MAAQ7vD,EAAEglC,OAAOzwC,QAAgB,KAANyjH,IACrB,SAANh4G,EAAckzC,EAAI,CAAC3/B,EAAE,IAAKtR,GAAE,GACtB,UAANjC,EAAekzC,EAAI,CAAC3/B,EAAE,IAAKtR,GAAE,GAC5BlK,MAAMylE,GAASx9D,IACfjI,MAAM4lE,GAAU39D,GAAGmjD,aAC3BjQ,EAAK,CAAC3/B,EAAE,IAAKtR,EAAEg7D,GAAUj9D,IACrB4iD,EAAKylB,YAAWn1B,EAAK,CAAC3/B,EAAE,IAAKtR,EAAEq6D,GAAQppB,EAAEjxC,KAC7CixC,EAAE14B,EAAIooC,EAAKqF,QAAUhG,GAAU,KAJH/O,EAAI,CAAC3/B,EAAE,IAAKtR,EAAEu7D,GAASx9D,KAMjD4iD,EAAK+kB,OAAaC,EAAG/vB,KAAI+vB,EAAG/vB,GAAK,IAAI+vB,EAAG/vB,GAAG91B,GAAKmxB,GAC9C00B,EAAG1B,GAAY,CAACj/D,EAAE4wC,EAAG3wC,EAAE6a,KAAOmxB,EACnCnxB,GAAK8pD,CAb8B,MAAnB9pD,GAAK8pD,OAJL9pD,GAAK8pD,CAbM,CA+B5B,OApCA,CAAuB,KAAHh0B,EAAM+K,EAAKy2B,WAAaz2B,EAAKy2B,WAAaxhC,EAAG,GAAIA,EAAG,KAAO,CAAE91B,EAAI,CAAa,CAqCnG,CAGA,OAFA6lD,EAAG,QAAUf,GAAaluD,GACvB6kF,EAAOjpG,SAAQqzE,EAAG,WAAa41B,GAC3B51B,CACR,CACA,SAASqwC,GAAcrwC,EAAkB3gE,EAAa4wC,EAAc3E,GAGnE,IAFA,IAAIhiB,EAAsB02C,EAAG,YAAa,GACtC3D,EAAuB,GACnBliD,EAAI9a,EAAE3D,EAAE4D,EAAG6a,GAAK9a,EAAEvD,EAAEwD,IAAK6a,EAAG,CAEnC,IADA,IAAIk+D,EAAK,EAAGpU,EAAK,EACTj2E,EAAI,EAAGA,EAAIs7B,EAAE38B,SAAUqB,EAC9B,KAAGs7B,EAAEt7B,GAAG0N,EAAE2D,EAAI4wC,GAAK3mB,EAAEt7B,GAAG0N,EAAE4D,EAAI6a,GAC3BmP,EAAEt7B,GAAG8N,EAAEuD,EAAI4wC,GAAK3mB,EAAEt7B,GAAG8N,EAAEwD,EAAI6a,GAA9B,CACA,GAAGmP,EAAEt7B,GAAG0N,EAAE2D,EAAI4wC,GAAK3mB,EAAEt7B,GAAG0N,EAAE4D,EAAI6a,EAAG,CAAEk+D,GAAK,EAAI,KAAO,CACnDA,EAAK/uD,EAAEt7B,GAAG8N,EAAEuD,EAAIiqB,EAAEt7B,GAAG0N,EAAE2D,EAAI,EAAG4kE,EAAK36C,EAAEt7B,GAAG8N,EAAEwD,EAAIgqB,EAAEt7B,GAAG0N,EAAE4D,EAAI,EAAG,MAE7D,KAAG+4E,EAAK,GAAR,CACA,IAAIO,EAAQta,GAAY,CAACj/D,EAAE4wC,EAAE3wC,EAAE6a,IAC3B6jD,EAAO1yB,EAAEy0B,OAASC,EAAG/vB,IAAI,IAAI91B,GAAK6lD,EAAG4Y,GAErCxmE,EAAK4rD,GAAkB,MAAVA,EAAK3jE,IAAe2jE,EAAKjmE,GAAKygE,GAAWwF,EAAK5rD,IAAMktD,GAAYtB,GAAOA,EAAK5rD,IAAM,MAAQ,GACvGrD,EAAM,CAAA,EACPspE,EAAK,IAAGtpE,EAAGohG,QAAU93B,GACrBpU,EAAK,IAAGl1D,EAAGmhG,QAAUjsC,GACrB34B,EAAEglE,SAAUl+F,EAAI,gCAAkCA,EAAI,UACjD4rD,IACPjvD,EAAG,UAAYivD,GAAQA,EAAKryD,GAAK,IACpB,MAAVqyD,EAAK3jE,IAAW0U,EAAG,UAAYivD,EAAK3jE,GAC1B,MAAV2jE,EAAKprD,IAAW7D,EAAG,UAAYivD,EAAKprD,GACpCorD,EAAK1nE,GAAyC,MAAnC0nE,EAAK1nE,EAAE2uE,QAAU,KAAKn1B,OAAO,KAAW19B,EAAI,YAAc4rD,EAAK1nE,EAAE2uE,OAAQ,KAAO7yD,EAAI,SAEnGrD,EAAGma,IAAMoiB,EAAEpiB,IAAM,OAAS,IAAM0vD,EAChCvc,EAAGzpE,KAAKsnE,GAAU,KAAM9nD,EAAGrD,GAhBhB,CAiBZ,CAEA,MADe,OACGstD,EAAGvpE,KAAK,IAAM,OACjC,CAgCA,SAASy9G,GAAcvwC,EAAkB5oD,EAAuBgyC,GAC/D,IAAIpO,EAAOoO,GAAS,CAAA,EAEhBonD,EAAO,EAAGC,EAAO,EACrB,GAAkB,MAAfz1D,EAAKzG,OACP,GAAyB,iBAAfyG,EAAKzG,OAAoBi8D,EAAOx1D,EAAKzG,WAC1C,CACJ,IAAI4rB,EAAgD,iBAAfnlB,EAAKzG,OAAqBwqB,GAAY/jB,EAAKzG,QAAUyG,EAAKzG,OAC/Fi8D,EAAOrwC,EAAQ9gE,EAAGoxG,EAAOtwC,EAAQ7gE,CAClC,CAGD,IAAIlN,EAA+CglB,EAAMs5F,qBAAqB,MAC1Ej/B,EAAYvjF,KAAK0C,IAAIoqD,EAAKy2B,WAAW,IAAUr/E,EAAKzF,QACpDokB,EAAkB,CAACrV,EAAE,CAAC2D,EAAE,EAAEC,EAAE,GAAGxD,EAAE,CAACuD,EAAEmxG,EAAKlxG,EAAEmxG,IAC/C,GAAGzwC,EAAG,QAAS,CACd,IAAII,EAAmBpB,GAAagB,EAAG,SACvCjvD,EAAMrV,EAAE2D,EAAInR,KAAK0C,IAAImgB,EAAMrV,EAAE2D,EAAG+gE,EAAO1kE,EAAE2D,GACzC0R,EAAMrV,EAAE4D,EAAIpR,KAAK0C,IAAImgB,EAAMrV,EAAE4D,EAAG8gE,EAAO1kE,EAAE4D,GACzCyR,EAAMjV,EAAEuD,EAAInR,KAAK6C,IAAIggB,EAAMjV,EAAEuD,EAAG+gE,EAAOtkE,EAAEuD,GACzC0R,EAAMjV,EAAEwD,EAAIpR,KAAK6C,IAAIggB,EAAMjV,EAAEwD,EAAG8gE,EAAOtkE,EAAEwD,IAC9B,GAARkxG,IAAYz/F,EAAMjV,EAAEuD,EAAImxG,EAAOpwC,EAAOtkE,EAAEuD,EAAI,EAChD,CACA,IAAIu2F,EAA0B,GAAIqa,EAAO,EACrCr5B,EAA6B5W,EAAG,WAAaA,EAAG,SAAW,IAC3DC,EAAK,EAAGhwB,EAAI,EAAGiwB,EAAK,EAAG/lD,EAAI,EAAGk+D,EAAK,EAAGpU,EAAK,EAE/C,IADIjE,EAAG,WAAUA,EAAG,SAAW,IACzBC,EAAK7tE,EAAKzF,QAAUsjD,EAAIwhC,IAAaxR,EAAI,CAC9C,IAAI5qE,EAA8BjD,EAAK6tE,GACvC,GAAI0wC,GAAsBt7G,GAAM,CAC/B,GAAI2lD,EAAK1E,QAAS,SAClBsgC,EAAQ3mC,GAAK,CAAC0nC,QAAQ,EACvB,CACA,IAAIi5B,EAAiDv7G,EAAI07C,SACzD,IAAImvB,EAAK/lD,EAAI,EAAG+lD,EAAK0wC,EAAKjkH,SAAUuzE,EAAI,CACvC,IAAIhX,EAA+B0nD,EAAK1wC,GACxC,IAAIllB,EAAK1E,UAAWq6D,GAAsBznD,GAA1C,CACA,IAAI7uD,EAAgB6uD,EAAI2nD,aAAa,UAAY3nD,EAAI4nD,aAAa,UAAY5nD,EAAI2nD,aAAa,KAAO3nD,EAAI4nD,aAAa,KAAOx3C,GAAWpQ,EAAI6nD,WACzIn+F,EAAgBs2C,EAAI4nD,aAAa,WAAa5nD,EAAI4nD,aAAa,KACnE,IAAIb,EAAO,EAAGA,EAAOra,EAAOjpG,SAAUsjH,EAAM,CAC3C,IAAI73G,EAAcw9F,EAAOqa,GACtB73G,EAAEsD,EAAE4D,GAAK6a,EAAIs2F,GAAQr4G,EAAEsD,EAAE2D,EAAI4wC,EAAIugE,GAAQvgE,EAAIugE,GAAQp4G,EAAE0D,EAAEuD,IAAK8a,EAAI/hB,EAAE0D,EAAEwD,EAAE,EAAImxG,EAAMR,GAAO,EAC7F,CAEAhsC,GAAM/a,EAAI4nD,aAAa,YAAc,IAC/Bz4B,GAAOnvB,EAAI4nD,aAAa,YAAc,GAAK,GAAK7sC,EAAG,IAAG2xB,EAAOhjG,KAAK,CAAC8I,EAAE,CAAC2D,EAAE4wC,EAAIugE,EAAKlxG,EAAE6a,EAAIs2F,GAAM30G,EAAE,CAACuD,EAAE4wC,EAAIugE,GAAQn4B,GAAI,GAAK,EAAG/4E,EAAE6a,EAAIs2F,GAAQxsC,GAAI,GAAK,KACvJ,IAAI34B,EAAa,CAAC3/B,EAAE,IAAKtR,EAAEA,GACvB+1G,EAAgBlnD,EAAI4nD,aAAa,WAAa5nD,EAAI4nD,aAAa,MAAQ,GACnE,MAALz2G,IACa,GAAZA,EAAE1N,OAAa2+C,EAAE3/B,EAAIykG,GAAM,IACtBp1D,EAAKiN,KAA0B,GAAnB5tD,EAAE+iC,OAAOzwC,QAAqB,KAANyjH,IAC9B,SAAN/1G,EAAcixC,EAAI,CAAC3/B,EAAE,IAAKtR,GAAE,GACtB,UAANA,EAAeixC,EAAI,CAAC3/B,EAAE,IAAKtR,GAAE,GAC5BlK,MAAMylE,GAASv7D,IACflK,MAAM4lE,GAAU17D,GAAGkhD,aAC3BjQ,EAAK,CAAC3/B,EAAE,IAAKtR,EAAEg7D,GAAUh7D,IACrB2gD,EAAKylB,YAAWn1B,EAAK,CAAC3/B,EAAE,IAAKtR,EAAEq6D,GAAQppB,EAAEjxC,KAC7CixC,EAAE14B,EAAIooC,EAAKqF,QAAUhG,GAAU,KAJH/O,EAAI,CAAC3/B,EAAE,IAAKtR,EAAEu7D,GAASv7D,WAO1CzN,IAAR0+C,EAAE14B,GAAwB,MAALA,IAAW04B,EAAE14B,EAAIA,GAGzC,IAAItc,EAAI,GAAI06G,EAAQ9nD,EAAIwnD,qBAAqB,KAC7C,GAAGM,GAASA,EAAMrkH,OAAQ,IAAI,IAAIskH,EAAQ,EAAGA,EAAQD,EAAMrkH,UAAoBqkH,EAAMC,GAAOJ,aAAa,SAC/C,MAAzDv6G,EAAI06G,EAAMC,GAAOH,aAAa,SAAchhE,OAAO,MADiBmhE,GAGlE36G,GAAoB,KAAfA,EAAEw5C,OAAO,KAAWxE,EAAEh1C,EAAK,CAAE2uE,OAAQ3uE,IAC1C0kD,EAAK+kB,OAAaC,EAAG/vB,EAAIugE,KAAOxwC,EAAG/vB,EAAIugE,GAAQ,IAAIxwC,EAAG/vB,EAAIugE,GAAMr2F,EAAIs2F,GAAQnlE,GAC1E00B,EAAG1B,GAAY,CAACh/D,EAAE6a,EAAIs2F,EAAMpxG,EAAE4wC,EAAIugE,KAAUllE,EAC9Cv6B,EAAMjV,EAAEwD,EAAI6a,EAAIs2F,IAAM1/F,EAAMjV,EAAEwD,EAAI6a,EAAIs2F,GACzCt2F,GAAK8pD,CAnC2C,CAoCjD,GACEh0B,CACH,CAKA,OAJG2lD,EAAOjpG,SAAQqzE,EAAG,YAAcA,EAAG,YAAc,IAAIv5C,OAAOmvE,IAC/D7kF,EAAMjV,EAAEuD,EAAInR,KAAK6C,IAAIggB,EAAMjV,EAAEuD,EAAG4wC,EAAI,EAAIugE,GACxCxwC,EAAG,QAAUf,GAAaluD,GACvBk/B,GAAKwhC,IAAWzR,EAAG,YAAcf,IAAcluD,EAAMjV,EAAEuD,EAAIjN,EAAKzF,OAAOszE,EAAGhwB,EAAE,EAAIugE,EAAKz/F,KACjFivD,CACR,CAEA,SAASkxC,GAAgB95F,EAAuBgyC,GAG/C,OAAOmnD,IAFInnD,GAAS,CAAA,GACQ2W,MAAS,GAAe,CAAA,EAC3B3oD,EAAOgyC,EACjC,CAMA,SAASunD,GAAsB3sG,GAC9B,IAAIsyC,EAAqB,GACrB66D,EAOL,SAAyCntG,GAExC,OAAGA,EAAQotG,cAAcC,aAA6E,mBAAvDrtG,EAAQotG,cAAcC,YAAYC,iBAAwCttG,EAAQotG,cAAcC,YAAYC,iBAE5H,mBAArBA,iBAAwCA,iBAC3C,IACR,CAbwCC,CAAgCvtG,GAGvE,OAFGmtG,IAAoB76D,EAAU66D,EAAmBntG,GAASwtG,iBAAiB,YAC1El7D,IAASA,EAAUtyC,EAAQ8kB,OAAS9kB,EAAQ8kB,MAAMwtB,SACnC,SAAZA,CACR,CAWA,SAASm7D,GAAaj/C,GAErB,IAAIk/C,EAAQl/C,EACV3pC,QAAQ,YAAa,KAAKuU,OAAOvU,QAAQ,MAAO,KAChDA,QAAQ,cAAc,KACtBA,QAAQ,6BAA8B,SAASy0B,EAAGC,GAAM,OAAOjtD,MAAMwP,SAASy9C,EAAG,IAAI,GAAGzqD,KAAK,IAAM,GACnG+1B,QAAQ,qBAAqB,MAC7BA,QAAQ,uBAAuB,MAGjC,MAAO,CAFCsvC,GAAYu5C,EAAM7oF,QAAQ,WAAW,KAG9C,CAEA,IAAI8oF,GAAqB,CAExBC,IAAe,CAAC,IAAO,MACvBC,MAAe,CAAC,IAAO,MACvBC,KAAe,CAAC,IAAO,MACvBC,MAAe,CAAC,IAAO,MACvBC,QAAe,CAAC,IAAO,MACvBC,QAAe,CAAC,IAAO,MACvB,QAAe,CAAC,MAAO,SACvB,cAAe,CAAC,MAAO,QACvBC,IAAe,CAAC,IAAO,MAEvBC,QAAe,CAAC,OAAQ,oBAIzB,SAASC,GAAkB7gG,EAAc63C,GACvC,IAG+BlxD,EAC3B7L,EAEAgmH,EACAC,EAGApT,EAAIt+F,EAVJo6C,EAAOoO,GAAS,CAAA,EAEhBh2D,EAAM+mE,GAAe5oD,GACrB+1C,EAAuB,GAEvBirD,EAAQ,CAACpgH,KAAK,IAAKqgH,EAAK,GAAIpS,EAAO,EAGnCxgC,EAAS,CAAA,EAAID,EAA+B,GAC5CK,EAAKhlB,EAAK+kB,MAAS,GAAe,CAAA,EAElC0yC,EAAQ,CAACrmH,MAAM,IACfsmH,EAAQ,GAAIC,EAAW,EACvBC,EAAQ,GACR3iE,GAAI,EAAI91B,KAAQpJ,EAAQ,CAACrV,EAAG,CAAC2D,EAAE,IAAQC,EAAE,KAAWxD,EAAG,CAACuD,EAAE,EAAGC,EAAE,IAC/DuzG,EAAS,EACTC,EAAoB,CAAA,EACpBld,EAA0B,GAAImd,EAAS,CAAA,EACvCn8B,EAA6B,GAAIo8B,EAAU,EAAGC,EAAU,EACxDlhB,EAAoC,GACpChvB,EAAK,CAACm3B,MAAM,IACZgZ,EAAQ,CAAA,EACRC,EAA4B,CAAC,GAAI,IACjCrnB,EAA8B,GAAIG,EAAuB,CAAA,EACzDmnB,EAAU,GAAIC,EAAa,EAC3BC,GAAS,EAAOC,GAAU,EAC1BxlH,EAAI,EAGR,IAFAqsE,GAAUvlC,UAAY,EACtBzhC,EAAMA,EAAIy1B,QAAQ,sBAAsB,IAAIA,QAAQ,+BAA+B,IAC5Eq2E,EAAK9kC,GAAU/8B,KAAKjqC,WAAe8rG,EAAG,GAAGA,EAAG,GAAGr2E,QAAQ,OAAO,KAEpE,IAAK,QAAS,IAAK,MACP,MAARq2E,EAAG,IACFnuF,EAAMjV,EAAEwD,GAAKyR,EAAMrV,EAAE4D,GAAKyR,EAAMjV,EAAEuD,GAAK0R,EAAMrV,EAAE2D,EAAG2gE,EAAG,QAAUf,GAAaluD,GAC1EivD,EAAG,QAAU,QACfhlB,EAAKy2B,UAAY,GAAKz2B,EAAKy2B,WAAa1gE,EAAMjV,EAAEuD,IAClD2gE,EAAG,YAAcA,EAAG,QACpBjvD,EAAMjV,EAAEuD,EAAI27C,EAAKy2B,UAAY,EAC7BzR,EAAG,QAAUf,GAAaluD,IAExB6kF,EAAOjpG,SAAQqzE,EAAG,WAAa41B,GAC/Bhf,EAAQjqF,SAAQqzE,EAAG,SAAW4W,GACjCy7B,EAAQlgH,KAAOkgH,EAAQ,OAASA,EAAQlgH,KACrB,oBAAT0Y,MAAsBA,KAAKC,UAAUunG,GAC/C1yC,EAAW/sE,KAAKy/G,EAAQlgH,MACxBytE,EAAOyyC,EAAQlgH,MAAQ6tE,EACvBuzC,GAAU,GAE8B,MAAjCrU,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,KACjC0lH,EAAUz6C,GAAYsnC,EAAG,IAAI,GAC7BjvD,EAAI91B,GAAI,EACRpJ,EAAMrV,EAAE2D,EAAI0R,EAAMrV,EAAE4D,EAAI,IAAUyR,EAAMjV,EAAEuD,EAAI0R,EAAMjV,EAAEwD,EAAI,EAC1D0gE,EAAKhlB,EAAK+kB,MAAS,GAAe,CAAA,EAAa61B,EAAS,GACxDhf,EAAU,GACV28B,GAAU,GAEX,MAED,IAAK,kBACS,MAAVrU,EAAG,KAAc2T,IAAeA,EACnC,MACD,IAAK,YAAa,IAAK,IACtB,GAAa,MAAV3T,EAAG,GAAY,CAAEjvD,GAAG+iE,EAASA,EAAU,EAAG,KAAO,CAKpD,IAJAV,EAAS16C,GAAYsnC,EAAG,IAAI,IAClB,MAAOjvD,EAAIqiE,EAAO,MAAQ,GAAgB,GAALriE,IAASA,EAAI,IAC5D+iE,GAAWV,EAAO,yBAA2B,GAEhC,GAAI,IAAIvkH,EAAI,EAAGA,EAAIilH,IAAWjlH,EAAM8kH,EAAS,IAAGj8B,EAAQ3mC,EAAIliD,GAAK,CAACqiF,MAAOyiC,IACtF14F,GAAI,EAAI,MACT,IAAK,qBACS,MAAV+kF,EAAG,MAAc/kF,EACjB6gC,EAAKwlB,aACJxlB,EAAK+kB,OAAaC,EAAG/vB,KAAI+vB,EAAG/vB,GAAK,IAAI+vB,EAAG/vB,GAAG91B,GAAK,CAACxO,EAAE,MACjDq0D,EAAG1B,GAAY,CAACj/D,EAAE4wC,EAAE3wC,EAAE6a,KAAO,CAACxO,EAAE,MAEtC+mG,EAAQ,GAAIE,EAAQ,GACpB,MACD,IAAK,aAAc,IAAK,KACvB,GAAoC,MAAjC1T,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,KAC1BwtB,EACFs4F,EAAO76C,GAAYsnC,EAAG,IAAI,GAC1B+T,EAAUnzG,SAAS2yG,EAAK,4BAA4B,IAAK,IACzD7xG,EAAK,CAAC+K,EAAE,IAAKtR,EAAE,MACZo4G,EAAKn7B,SAA+B,GAApBt8B,EAAKg9C,cAAsBp3F,EAAEgO,EAAIgkF,GAAmBz6B,GAAYs6C,EAAKn7B,WAC7C,WAAvCm7B,EAAK,SAAWA,EAAK,iBACxB7xG,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAI89D,GAAYs6C,EAAK,iBAAmB,IAClDz3D,EAAK+kB,OACHC,EAAG/vB,KAAI+vB,EAAG/vB,GAAK,IACnB+vB,EAAG/vB,GAAG91B,GAAKvZ,GAEXo/D,EAAG1B,GAAY,CAACj/D,EAAE4wC,EAAE3wC,EAAE6a,KAAOvZ,GAG/BuZ,GAAI84F,EAAQ,OACN,GAAW,MAAR/T,EAAG,GAAU,CAEtBwT,EAAQ,GAAIC,EAAW,EAAGC,EAAQ,GAClCK,EAAU,EACV,IAAIO,EAAOR,EAAU/iE,EAAI+iE,EAAU,EAAI/iE,EAQvC,KAXE91B,EAIKpJ,EAAMjV,EAAEwD,IAAGyR,EAAMjV,EAAEwD,EAAI6a,GAC3BA,EAAIpJ,EAAMrV,EAAE4D,IAAGyR,EAAMrV,EAAE4D,EAAI6a,GAC3B81B,EAAIl/B,EAAMrV,EAAE2D,IAAG0R,EAAMrV,EAAE2D,EAAI4wC,GAC3BujE,EAAOziG,EAAMjV,EAAEuD,IAAG0R,EAAMjV,EAAEuD,EAAIm0G,GAEjC1nB,EAAW,GAAIG,EAAW,CAAA,EAC1BrrF,EAAK,CAAC+K,GAFN8mG,EAAO76C,GAAYsnC,EAAG,IAAI,IAEb,SAAWuT,EAAK,cAAep4G,EAAE,MAC3C2gD,EAAKg9C,YASP,GARGya,EAAKn7B,UAASm7B,EAAKn7B,QAAUnf,GAAYs6C,EAAKn7B,UAC9Cm7B,EAAK,kCAAoCA,EAAK,gCAGhDM,EAAS,CAACr3G,EAAG,CAAC2D,EAAE4wC,EAAE3wC,EAAE6a,GAAIre,EAAE,CAACuD,EAAE4wC,GAFxBnwC,SAAS2yG,EAAK,8BAA8B,KAAO,GAEpB,EAAEnzG,EAAE6a,GADnCra,SAAS2yG,EAAK,iCAAiC,KAAO,GACZ,IAC/C7xG,EAAEuvB,EAAI8uC,GAAa8zC,GACnBhhB,EAAOn/F,KAAK,CAACmgH,EAAQnyG,EAAEuvB,KAErBsiF,EAAKn7B,QAAS12E,EAAEgO,EAAIgkF,GAAmB6f,EAAKn7B,kBACtCvpF,EAAI,EAAGA,EAAIgkG,EAAOplG,SAAUoB,EACjCkiD,GAAK8hD,EAAOhkG,GAAG,GAAG2N,EAAE2D,GAAK4wC,GAAK8hD,EAAOhkG,GAAG,GAAG+N,EAAEuD,GAC5C8a,GAAK43E,EAAOhkG,GAAG,GAAG2N,EAAE4D,GAAK6a,GAAK43E,EAAOhkG,GAAG,GAAG+N,EAAEwD,IAC/CsB,EAAEuvB,EAAI4hE,EAAOhkG,GAAG,IAapB,QAXG0kH,EAAK,2BAA6BA,EAAK,0BAGzCM,EAAS,CAACr3G,EAAG,CAAC2D,EAAE4wC,EAAE3wC,EAAE6a,GAAIre,EAAE,CAACuD,EAAE4wC,GAFxBnwC,SAAS2yG,EAAK,uBAAuB,KAAO,GAEb,EAAEnzG,EAAE6a,GADnCra,SAAS2yG,EAAK,0BAA0B,KAAO,GACL,IAC/C7c,EAAOhjG,KAAKmgH,IAIVN,EAAK,6BAA4BQ,EAAUnzG,SAAS2yG,EAAK,2BAA4B,KAGjF7xG,EAAE+K,GACR,IAAK,UAAW/K,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAIu+D,GAAa65C,EAAK,kBAAmB,MACtE,IAAK,QACL,IAAK,aACL,IAAK,WAAY7xG,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAIkjC,WAAWk1E,EAAKrmH,OAAQ,MAC1D,IAAK,OAAQwU,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAIg7D,GAAUo9C,EAAK,eACxCz3D,EAAKylB,YAAa7/D,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAIq6D,GAAQ9zD,EAAEvG,IACjDuG,EAAEgS,EAAI,SAAU,MACjB,IAAK,OAAQhS,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAI26D,GAAay9C,EAAK,eAAe,MAC3Dz3D,EAAKylB,YAAa7/D,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAIy6D,GAAQl0D,EAAEvG,IAChDuG,EAAEgS,EAAI,WAAY,MACnB,IAAK,SAAUhS,EAAE+K,EAAI,IAAK/K,EAAEvG,EAAIkjC,WAAWk1E,EAAK,SAAU,MAC1D,QACC,GAAW,WAAR7xG,EAAE+K,GAA0B,SAAR/K,EAAE+K,GAAiB/K,EAAE+K,EAGrC,UAAUrd,MAAM,0BAA4BsS,EAAE+K,GAFpD/K,EAAE+K,EAAI,IACqB,MAAxB8mG,EAAK,kBAA2BC,EAAQv6C,GAAYs6C,EAAK,iBAAkBG,EAAQ,IAG1F,KAAO,CAWN,GAVAU,GAAS,EACE,MAAR1yG,EAAE+K,IACJ/K,EAAEvG,EAAIq4G,GAAS,GACZE,EAAMjmH,SAAQiU,EAAEqvC,EAAI2iE,GACvBU,EAAqB,GAAZX,GAEPO,EAAKjuC,SAAQrkE,EAAEtK,EAAI48G,GACnBpnB,EAASn/F,OAAS,IAAKiU,EAAEtB,EAAIwsF,EAAUA,EAAW,IAClD4mB,IAA2B,IAAlB13D,EAAK2/B,WAAoB/5E,EAAEwR,EAAIsgG,GACxCY,IAAU1yG,EAAE+K,EAAI,WAAY/K,EAAEvG,KAC7Bi5G,GAAUt4D,EAAKwlB,eACbxlB,EAAKy2B,WAAaz2B,EAAKy2B,WAAaxhC,GACxC,IAAI,IAAIwjE,EAAM,EAAGA,EAAMT,IAAWS,EAAK,CAEtC,GADAR,EAAUnzG,SAAS2yG,EAAK,4BAA4B,IAAK,IACtDz3D,EAAK+kB,MAGP,IAFIC,EAAG/vB,EAAIwjE,KAAMzzC,EAAG/vB,EAAIwjE,GAAO,IAC/BzzC,EAAG/vB,EAAIwjE,GAAKt5F,GAAY,GAAPs5F,EAAW7yG,EAAI+0D,GAAI/0D,KAC5BqyG,EAAU,GAAGjzC,EAAG/vB,EAAIwjE,GAAKt5F,EAAI84F,GAAWt9C,GAAI/0D,QAGpD,IADAo/D,EAAG1B,GAAY,CAACj/D,EAAE4wC,EAAIwjE,EAAIn0G,EAAE6a,KAAOvZ,IAC3BqyG,EAAU,GAAGjzC,EAAG1B,GAAY,CAACj/D,EAAE4wC,EAAIwjE,EAAIn0G,EAAE6a,EAAI84F,KAAat9C,GAAI/0D,GAEpEmQ,EAAMjV,EAAEwD,GAAK6a,IAAGpJ,EAAMjV,EAAEwD,EAAI6a,EAChC,CAIFA,IADA84F,EAAUnzG,SAAS2yG,EAAK,4BAA4B,IAAK,KAC5C,EAAGQ,EAAU,EAC1BryG,EAAI,GACJ8xG,EAAQ,GAAIE,EAAQ,EACrB,CACAM,EAAQ,CAAA,EACR,MAGD,IAAK,WACL,IAAK,mBAAoB,IAAK,SAC9B,IAAK,cAAe,IAAK,KACzB,IAAK,UACL,IAAK,SACL,IAAK,kBACL,IAAK,gBACJ,GAAW,MAARhU,EAAG,IAAU,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,KAAM,cAAchnG,MAC5B,MAAjCgnG,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,IAAY26D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IACjE,MAED,IAAK,aACJ,GAAW,MAARA,EAAG,GAAS,CACd,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,KAAM,cAAchnG,EACrD+zF,EAAQtgF,EAAI+mG,EACTE,EAAMjmH,SAAes/F,EAAoBh8C,EAAI2iE,GAChD3mB,EAAQtsF,EAAIyzG,EACZtnB,EAASl5F,KAAKq5F,EACf,KACyC,MAAjCiT,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,IAAa26D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IAClEkU,EAAU,GAAIC,EAAa,EAC3BX,EAAQ,GAAIC,EAAW,EAAGC,EAAQ,GAClC,MAED,IAAK,UACO,MAAR1T,EAAG,GAAYkU,EAAUhgH,EAAIhG,MAAMimH,EAAWnU,EAAGvwG,OAC/C0kH,EAAanU,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,OACnC,MAGD,IAAK,OAAQ,IAAK,MAClB,IAAK,WACL,IAAK,kBACL,IAAK,0BACL,IAAK,wBACL,IAAK,wBACL,IAAK,SACL,IAAK,QACL,IAAK,WACL,IAAK,QACL,IAAK,oBACL,IAAK,aACL,IAAK,OACL,IAAK,YACL,IAAK,kBACL,IAAK,QACJ,GAAW,MAARuyG,EAAG,IAAU,IAAIhnG,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,KAAM,cAAchnG,MAC5B,MAAjCgnG,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,IAAY26D,EAAM10D,KAAK,CAACssG,EAAG,IAAI,IACjEwT,EAAQ,GAAIC,EAAW,EAAGC,EAAQ,GAClC,MAED,IAAK,oBAEL,IAAK,kBAEL,IAAK,iBAeL,IAAK,SACL,IAAK,YACL,IAAK,mBAEL,IAAK,gBACL,IAAK,cACL,IAAK,QAEL,IAAK,MACL,IAAK,YAEL,IAAK,uBACL,IAAK,mBACL,IAAK,0BACL,IAAK,uBACL,IAAK,wBAUL,IAAK,WAoBL,IAAK,gBACL,IAAK,UACL,IAAK,aAqBL,IAAK,eACL,IAAK,kBACL,IAAK,gBAEL,IAAK,OAAQ,IAAK,OAElB,IAAK,QACL,IAAK,eACL,IAAK,oBACL,IAAK,aAEL,IAAK,qBACL,IAAK,uBACL,IAAK,gBAEL,IAAK,YAEL,IAAK,qBACL,IAAK,uBACL,IAAK,oBACL,IAAK,cACL,IAAK,eACL,IAAK,mBACL,IAAK,OACL,IAAK,UACL,IAAK,cAEL,IAAK,MACL,IAAK,aACL,IAAK,OAQL,IAAK,IAUL,IAAK,OAEL,IAAK,SACL,IAAK,QAAS,IAAK,KACnB,IAAK,OACL,IAAK,cAGL,IAAK,eACL,IAAK,WAEL,IAAK,YACL,IAAK,sBACL,IAAK,qBACL,IAAK,eACL,IAAK,gBACL,IAAK,kBACL,IAAK,SACL,IAAK,aACL,IAAK,YACL,IAAK,mBAEL,IAAK,0BACL,IAAK,0BACL,IAAK,wBAGL,IAAK,mBACL,IAAK,kBACL,IAAK,kBACL,IAAK,eACL,IAAK,kBACL,IAAK,eACL,IAAK,uBACL,IAAK,aACL,IAAK,iBACL,IAAK,oBACL,IAAK,gBACL,IAAK,cACL,IAAK,qBACL,IAAK,iBACL,IAAK,2BACL,IAAK,cACL,IAAK,kBACL,IAAK,UACL,IAAK,YACL,IAAK,gBACL,IAAK,aAGL,IAAK,iBAGL,IAAK,kBACL,IAAK,gBACL,IAAK,aACL,IAAK,YACL,IAAK,qBACL,IAAK,eACL,IAAK,mBACL,IAAK,iBAIL,IAAK,cAIL,IAAK,cACL,IAAK,aACL,IAAK,OAGL,IAAK,oBACL,IAAK,YACL,IAAK,YACL,IAAK,oBAGL,IAAK,mBACL,IAAK,oBACL,IAAK,iBACL,IAAK,mBACL,IAAK,mBACL,IAAK,uBACL,IAAK,sBACL,IAAK,qBACL,IAAK,oBACL,IAAK,0BACL,IAAK,uBACL,IAAK,yBACL,IAAK,6BACL,IAAK,oBACL,IAAK,mBACL,IAAK,0BAIL,IAAK,OAIL,IAAK,uBACL,IAAK,sBACL,IAAK,WACL,IAAK,aAGL,IAAK,aACL,IAAK,WAeL,IAAK,mBACL,IAAK,yBACL,IAAK,+BAAgC,MA9PrC,IAAK,eACL,IAAK,mBACL,IAAK,aACL,IAAK,aACJ,GAAW,MAAR1T,EAAG,IAEL,GADA4T,EAAkBP,EAAMpgH,MAAQqgH,GAC5Bt6G,EAAIovD,EAAM7V,OAAO,KAAKytD,EAAG,GAAI,KAAM,cAAchnG,MACX,MAAjCgnG,EAAG,GAAGpvD,OAAOovD,EAAG,GAAGvyG,OAAO,KACnC6lH,EAAK,GACLD,EAAQ36C,GAAYsnC,EAAG,IAAI,GAC3B53C,EAAM10D,KAAK,CAACssG,EAAG,IAAI,KAClB,MAmBH,IAAK,SAUL,IAAK,MACL,IAAK,QACL,IAAK,OACL,IAAK,MACL,IAAK,cACL,IAAK,eACL,IAAK,UACL,IAAK,QACL,IAAK,UACL,IAAK,UACL,IAAK,QACJ,OAAO53C,EAAMA,EAAM36D,OAAO,GAAG,IAC5B,IAAK,aACL,IAAK,aACJN,EAAMurE,GAAYsnC,EAAG,IAAI,GACzBsT,GAAMb,GAAmBzS,EAAG,IAAgB,SAAZ7yG,EAAIy8B,MAAe,EAAE,GACrD,MAKH,IAAK,OACJ,GAAuB,OAApBo2E,EAAG,GAAG9xG,OAAM,GAAc,SACb,MAAR8xG,EAAG,GAAU,OAAO53C,EAAMA,EAAM36D,OAAO,GAAG,IACjD,IAAK,eACL,IAAK,aACL,IAAK,aACJ6lH,GAAMp/G,EAAIhG,MAAMgzG,EAAMlB,EAAGvwG,YAGtByxG,EAAOlB,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,OAC7B,MAED,IAAK,cAEJwmH,EAAOtgB,IADPxmG,EAAMurE,GAAYsnC,EAAG,IAAI,IACA,uBACzB,IAAIwU,EAAU,CAAC9kC,KAAKviF,EAAI8F,KAAMioG,IAAI+Y,EAAK,GAAK,IAAMA,EAAK,IACpDI,IAASG,EAAOvZ,MAAQx6B,EAAWhzE,QACtCo2E,EAAGm3B,MAAMtnG,KAAK8gH,GACd,MAgCD,IAAK,IAAK,IAAK,MACd,GAAG,CAAC,iBAAiBznF,QAAQq7B,EAAMA,EAAM36D,OAAO,GAAG,KAAM,EAAI,MAC7D,GAAW,MAARuyG,EAAG,IAAcuT,GAASA,EAAK,gBAGd76C,GAAYsnC,EAAG,IAAI,GAAQyT,EAAWzT,EAAGvwG,MAAQuwG,EAAG,GAAGvyG,WAHvB,CACnD,IAAIgnH,EAAMlC,GAAar+G,EAAIhG,MAAMulH,EAASzT,EAAGvwG,QAC7C+jH,GAASA,EAAM/lH,OAAS,EAAI+lH,EAAQ,KAAO,IAAMiB,EAAI,EACtD,CACA,MAGD,IAAK,iBACJ,GAAW,MAARzU,EAAG,GAAU,MAChB,IAECt/B,GADAuzC,EAAOtgB,GAAcj7B,GAAYsnC,EAAG,IAAI,0BAC5B,IAAI,eAAiB,CAAEvvB,IAAIwjC,EAAK,GAC7C,CAAE,MAAMr3G,GAAI,CACZ,MAiHD,IAAK,IACJ,GAAY,MAATojG,EAAG,GAAW,CAEhB,KADAgU,EAAOt7C,GAAYsnC,EAAG,IAAI,IACjB0U,KAAM,MACfV,EAAKjuC,OAAS9M,GAAY+6C,EAAKU,aAAcV,EAAKU,KACtB,KAAzBV,EAAKjuC,OAAOn1B,OAAO,IAAaojE,EAAKjuC,OAAOh5C,QAAQ,SACtDknF,EAAOtgB,GAAcqgB,EAAKjuC,OAAO73E,MAAM,IACvC8lH,EAAKjuC,OAAS,IAAMkuC,EAAK,GAAK,IAAMA,EAAK,IAChCD,EAAKjuC,OAAOt8C,MAAM,iBAAgBuqF,EAAKjuC,OAASiuC,EAAKjuC,OAAO73E,MAAM,GAC7E,CACA,MAMD,QAAS,OAAO8xG,EAAG,IAClB,IAAK,MACL,IAAK,WACL,IAAK,SACL,IAAK,OACL,IAAK,YACL,IAAK,QACL,IAAK,SACL,IAAK,SACL,IAAK,QACL,IAAK,OACL,IAAK,KACL,IAAK,KACJ,MACD,QAAS,GAAGlkD,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM4wG,IAGxC,IAAI9lF,EAAoB,CACvBwmD,OAAQA,EACRD,WAAYA,EACZ2gC,SAAUv9B,GAGX,OADG/nB,EAAKknD,mBAA0B9oF,EAAgBwmD,OAC3CxmD,CACT,CAEA,SAASy6F,GAAUn9C,EAAiB1b,GACnCA,EAAOA,GAAS,GACbyb,GAAeC,EAAK,0BAn7fxB,SAAwBnlD,EAAGypC,GAI1B,IAHA,IACIkkD,EACA4U,EAFA1gH,EAAM+mE,GAAe5oD,GAGlB2tF,EAAK9kC,GAAU/8B,KAAKjqC,WAAc8rG,EAAG,IAC3C,IAAK,WAAY,MACjB,IAAK,aAEJ,GAAiB,MADjB4U,EAAQl8C,GAAYsnC,EAAG,IAAI,IAClB/rC,MATC,mDASc2gD,EAAM94G,KAAiB,MAAM,IAAI1M,MAAM,0CAC/D,MACD,IAAK,kBACL,IAAK,YACL,IAAK,uBACL,IAAK,iBACJ,MAAM,IAAIA,MAAM,8BACjB,QAAS,GAAG0sD,GAAQA,EAAK+e,IAAK,MAAMmlC,EAEtC,CAk6fkD6U,CAAen9C,GAAWF,EAAK,yBAA0B1b,GAC1G,IAAI0M,EAAUoP,GAAUJ,EAAK,eAC7B,IAAIhP,EAAS,MAAM,IAAIp5D,MAAM,yCAC7B,IAAIuvF,EAAKu0B,GAAkBj5C,GAASzR,GAAU1M,GAE9C,OADGyb,GAAeC,EAAK,cAAamnB,EAAGrW,MAAQlC,GAAiB1O,GAAWF,EAAK,cACzEmnB,CACR,CACA,SAAS8jB,GAAWtrG,EAAiB2kD,GACpC,OAAOo3D,GAAkB/7G,EAAM2kD,EAChC,CA2SA,SAASg5D,GAAe7mH,GACtB,OAAO,IAAI8mH,SAAS9mH,EAAM+8C,OAAQ/8C,EAAMg9C,WAAYh9C,EAAMi9C,WAC5D,CACA,SAAS8pE,GAAMC,GACb,MAA6B,oBAAfrqE,aAA6B,IAAIA,aAAcC,OAAOoqE,GAAMh7C,GAASjgB,GAAIi7D,GACzF,CAcA,SAASC,GAASC,GAChB,IAAIlhH,EAAMkhH,EAAIvuF,OAAO,SAASse,EAAKn1C,GACjC,OAAOm1C,EAAMn1C,EAAEtC,MACjB,EAAG,GACCysB,EAAM,IAAI6wB,WAAW92C,GACrBymB,EAAM,EAKV,OAJAy6F,EAAI3nF,QAAQ,SAASynF,GACnB/6F,EAAI7jB,IAAI4+G,EAAIv6F,GACZA,GAAOu6F,EAAGxnH,MACZ,GACOysB,CACT,CACA,SAASk7F,GAAOrlH,GAGd,OAAoC,WADpCA,GAAS,WADTA,GAAKA,GAAK,EAAI,cACSA,GAAK,EAAI,aACnBA,GAAK,GAAK,aAA0B,EACnD,CAiBA,SAASslH,GAAelqE,EAAK7e,GAC3B,IAAIl1B,EAAIk1B,EAAMA,EAAI,GAAK,EACnBkkC,EAAe,IAATrlB,EAAI/zC,GACdk+G,EACE,GAAInqE,EAAI/zC,MAAQ,IAAK,CAEnB,GADAo5D,IAAiB,IAATrlB,EAAI/zC,KAAa,EACrB+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EAER,GADA9kD,IAAiB,IAATrlB,EAAI/zC,KAAa,GACrB+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EAER,GADA9kD,IAAiB,IAATrlB,EAAI/zC,KAAa,GACrB+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EAGR,GAFA9kD,IAAiB,IAATrlB,EAAI/zC,IAAYpI,KAAKob,IAAI,EAAG,MAClChT,EACE+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EAGR,GAFA9kD,IAAiB,IAATrlB,EAAI/zC,IAAYpI,KAAKob,IAAI,EAAG,MAClChT,EACE+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EAGR,GAFA9kD,IAAiB,IAATrlB,EAAI/zC,IAAYpI,KAAKob,IAAI,EAAG,MAClChT,EACE+zC,EAAI/zC,KAAO,IACb,MAAMk+G,CACV,CAGF,OAFIhpF,IACFA,EAAI,GAAKl1B,GACJo5D,CACT,CAsCA,SAAS+kD,GAAcpqE,GACrB,IAAI/zC,EAAI,EAAGo+G,EAAe,IAATrqE,EAAI/zC,GACrBk+G,EACE,GAAInqE,EAAI/zC,MAAQ,IAAK,CAEnB,GADAo+G,IAAiB,IAATrqE,EAAI/zC,KAAa,EACrB+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EAER,GADAE,IAAiB,IAATrqE,EAAI/zC,KAAa,GACrB+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EAER,GADAE,IAAiB,IAATrqE,EAAI/zC,KAAa,GACrB+zC,EAAI/zC,KAAO,IACb,MAAMk+G,EACRE,IAAiB,IAATrqE,EAAI/zC,KAAa,EAC3B,CACF,OAAOo+G,CACT,CACA,SAASC,GAActqE,GAErB,IADA,IAAIjxB,EAAM,GAAIoS,EAAM,CAAC,GACdA,EAAI,GAAK6e,EAAI19C,QAAQ,CAC1B,IAKIksB,EALAe,EAAM4R,EAAI,GACVx4B,EAAMuhH,GAAelqE,EAAK7e,GAC1BxwB,EAAa,EAANhI,EAEPG,EAAM,EAEV,GAAW,IAHXH,EAAM9E,KAAKC,MAAM6E,EAAM,IAIrB,MACF,OAAQgI,GACN,OAGI,IADA,IAAI1E,EAAIk1B,EAAI,GACL6e,EAAI7e,EAAI,OAAS,MAExB3S,EAAMwxB,EAAIj9C,MAAMkJ,EAAGk1B,EAAI,IAEzB,MACF,KAAK,EACHr4B,EAAM,EACN0lB,EAAMwxB,EAAIj9C,MAAMo+B,EAAI,GAAIA,EAAI,GAAKr4B,GACjCq4B,EAAI,IAAMr4B,EACV,MACF,KAAK,EACHA,EAAM,EACN0lB,EAAMwxB,EAAIj9C,MAAMo+B,EAAI,GAAIA,EAAI,GAAKr4B,GACjCq4B,EAAI,IAAMr4B,EACV,MACF,OACEA,EAAMohH,GAAelqE,EAAK7e,GAC1B3S,EAAMwxB,EAAIj9C,MAAMo+B,EAAI,GAAIA,EAAI,GAAKr4B,GACjCq4B,EAAI,IAAMr4B,EACV,MAGF,QACE,MAAM,IAAI7E,MAAM,WAAWm4B,OAAOzrB,EAAM,eAAeyrB,OAAOzzB,EAAK,eAAeyzB,OAAO7M,IAE7F,IAAIvf,EAAI,CAAEhE,KAAMwiB,EAAK7d,KAAMA,GACX,MAAZoe,EAAIpmB,GACNomB,EAAIpmB,GAAO,CAACqH,GAEZ+e,EAAIpmB,GAAKJ,KAAKyH,EAClB,CACA,OAAO+e,CACT,CAeA,SAASw7F,GAAMv+G,EAAM+mE,GACnB,OAAgB,MAAR/mE,OAAe,EAASA,EAAKkuB,IAAI,SAAShT,GAChD,OAAO6rD,EAAG7rD,EAAElb,KACd,KAAO,EACT,CAkDA,SAASw+G,GAAmB75G,EAAMqvC,GAChC,GAAY,GAARrvC,EACF,UAAU1M,MAAM,gCAAgCm4B,OAAOzrB,IAIzD,IAHA,IAAIwwB,EAAM,CAAC,GACPkkC,EAAM6kD,GAAelqE,EAAK7e,GAC1BspF,EAAS,GACNtpF,EAAI,GAAK6e,EAAI19C,QAAQ,CAC1B,IAAIN,EAAoB,EAAdg+C,EAAI7e,EAAI,IAClB,GAAW,GAAPn/B,EAAJ,CAqBE,IAAIi8D,EAAS,EAAG37D,EAAS,EAgBzB,GAfW,GAAPN,GACFM,EAAkC,GAAxB09C,EAAI7e,EAAI,KAAO,EAAI,GAC7B88B,GAA0B,IAAhBje,EAAI7e,EAAI,QAAgB,EAClC88B,GAAUje,EAAI7e,EAAI,QAElB7+B,EAAgC,GAAtB09C,EAAI7e,EAAI,OAAS,GAChB,GAAPn/B,GACFi8D,EAASje,EAAI7e,EAAI,IAAM6e,EAAI7e,EAAI,GAAK,IAAM,EAC1CA,EAAI,IAAM,IAEV88B,GAAUje,EAAI7e,EAAI,IAAM6e,EAAI7e,EAAI,GAAK,IAAM,EAAI6e,EAAI7e,EAAI,GAAK,IAAM,GAAK6e,EAAI7e,EAAI,GAAK,IAAM,MAAQ,EAClGA,EAAI,IAAM,IAGdspF,EAAS,CAACV,GAASU,IACL,GAAVxsD,EACF,MAAM,IAAIh6D,MAAM,oBAClB,GAAIg6D,EAASwsD,EAAO,GAAGnoH,OACrB,MAAM,IAAI2B,MAAM,gCAClB,GAAI3B,GAAU27D,EAGZ,IAFAwsD,EAAOliH,KAAKkiH,EAAO,GAAG1nH,OAAOk7D,IAC7B37D,GAAU27D,EACH37D,GAAUmoH,EAAOA,EAAOnoH,OAAS,GAAGA,QACzCmoH,EAAOliH,KAAKkiH,EAAOA,EAAOnoH,OAAS,IACnCA,GAAUmoH,EAAOA,EAAOnoH,OAAS,GAAGA,OAGxCmoH,EAAOliH,KAAKkiH,EAAO,GAAG1nH,OAAOk7D,GAASA,EAAS37D,GACjD,KAlDA,CACE,IAAIwG,EAAMk3C,EAAI7e,EAAI,OAAS,EAC3B,GAAIr4B,EAAM,KACNA,MACC,CACH,IAAImM,EAAInM,EAAM,GACdA,EAAMk3C,EAAI7e,EAAI,IACVlsB,EAAI,IACNnM,GAAOk3C,EAAI7e,EAAI,GAAK,IAAM,GACxBlsB,EAAI,IACNnM,GAAOk3C,EAAI7e,EAAI,GAAK,IAAM,IACxBlsB,EAAI,IACNnM,GAAOk3C,EAAI7e,EAAI,GAAK,IAAM,IAC5Br4B,KAAS,EACTA,IACAq4B,EAAI,IAAMlsB,CACZ,CACAw1G,EAAOliH,KAAKy3C,EAAIj9C,MAAMo+B,EAAI,GAAIA,EAAI,GAAKr4B,IACvCq4B,EAAI,IAAMr4B,CAgCZ,CACF,CACA,IAAIm4C,EAAI8oE,GAASU,GACjB,GAAIxpE,EAAE3+C,QAAU+iE,EACd,MAAM,IAAIphE,MAAM,sBAAsBm4B,OAAO6kB,EAAE3+C,OAAQ,QAAQ85B,OAAOipC,IACxE,OAAOpkB,CACT,CAgHA,SAASypE,GAAkB1qE,EAAK2xD,EAAKgZ,GACnC,IAwBIpsC,EAxBAqsC,EAAKjB,GAAe3pE,GACpBnF,EAAQ+vE,EAAGC,UAAU,GAAG,GACxBC,EAAc,GACdj+C,GAAO,EAAIqkB,GAAO,EAAI65B,EAAOl7G,IAAKm7G,EAAOn7G,IAAKqmD,EAAK,IAAI5nB,KAAK,KAAM,EAAG,GAsBzE,OArBY,EAARuM,IACFkwE,EA/YJ,SAA0B/qE,EAAKie,GAG7B,IAFA,IAAI90D,GAA0B,IAAnB62C,EAAIie,EAAS,MAAc,EAAIje,EAAIie,EAAS,KAAO,EAC1DgtD,EAA8B,EAAnBjrE,EAAIie,EAAS,IACnBt6D,EAAIs6D,EAAS,GAAIt6D,GAAKs6D,IAAUt6D,EACvCsnH,EAAsB,IAAXA,EAAiBjrE,EAAIr8C,GAClC,OAA2B,IAAnBq8C,EAAIie,EAAS,KAAagtD,EAAWA,GAAYpnH,KAAKob,IAAI,GAAI9V,EAAM,KAC9E,CAyYW+hH,CAAiBlrE,EAAK8qE,GAC7BA,GAAe,IAEL,EAARjwE,IACFmwE,EAAOJ,EAAGO,WAAWL,GAAa,GAClCA,GAAe,GAEL,EAARjwE,IACFqb,EAAGwU,QAAQxU,EAAGzE,UAA+C,IAAnCm5D,EAAGO,WAAWL,GAAa,IACrDA,GAAe,GAEL,EAARjwE,IACFq2C,EAAO05B,EAAGC,UAAUC,GAAa,GACjCA,GAAe,GAEL,GAARjwE,IACFgyB,EAAO+9C,EAAGC,UAAUC,GAAa,GACjCA,GAAe,GAGT9qE,EAAI,IACV,KAAK,EACH,MACF,KAAK,EA0BL,QACEu+B,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG+6G,GACnB,MAzBF,KAAK,EACHxsC,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG2hG,EAAIzgB,IACvB,MACF,KAAK,EACH3S,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGkmD,GACnB,MACF,KAAK,EACHqoB,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGg7G,EAAO,GAC1B,MACF,KAAK,EACHzsC,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGg7G,EAAO,OAC1B,MACF,OACEzsC,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG,GACnB,MACF,KAAK,EAED,KAAI68D,GAAO,GAGT,UAAU5oE,MAAM,yBAAyBm4B,OAAO4jB,EAAI,GAAI,OAAO5jB,OAAe,GAARye,EAAY,OAAOze,OAAO4jB,EAAIj9C,MAAM,EAAG,KAF7Gw7E,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG26G,EAAK99C,IAI5B,MAIF,QACE,MAAM,IAAI5oE,MAAM,yBAAyBm4B,OAAO4jB,EAAI,GAAI,OAAO5jB,OAAe,GAARye,EAAY,OAAOze,OAAO4jB,EAAIj9C,MAAM,EAAG,KAEjH,OAAOw7E,CACT,CA6DA,SAAS6sC,GAAmBprE,EAAK2xD,EAAKgZ,GACpC,OAAQ3qE,EAAI,IACV,KAAK,EACL,KAAK,EACL,KAAK,EACL,KAAK,EACH,OA9LN,SAA2BA,EAAK2xD,EAAKgZ,EAAM36G,GACzC,IAqBIuuE,EArBAqsC,EAAKjB,GAAe3pE,GACpBnF,EAAQ+vE,EAAGC,UAAU,GAAG,GACxBC,GAAe96G,EAAI,EAAI,GAAK,GAA4C,EAAvCi6G,GAAOpvE,GAAS7qC,EAAI,EAAI,KAAO,MAChE68D,GAAO,EAAIqkB,GAAO,EAAI85B,EAAOn7G,IAAKqmD,EAAK,IAAI5nB,KAAK,KAAM,EAAG,GAmB7D,OAlBY,IAARuM,IACFgyB,EAAO+9C,EAAGC,UAAUC,GAAa,GACjCA,GAAe,GAEjBA,GAAwD,EAAzCb,GAAOpvE,GAAS7qC,EAAI,EAAI,MAAQ,OACnC,GAAR6qC,IACFq2C,EAAO05B,EAAGC,UAAUC,GAAa,GACjCA,GAAe,GAEL,GAARjwE,IACFmwE,EAAOJ,EAAGO,WAAWL,GAAa,GAClCA,GAAe,GAEL,GAARjwE,IACFqb,EAAGwU,QAAQxU,EAAGzE,UAA+C,IAAnCm5D,EAAGO,WAAWL,GAAa,IACrDA,GAAe,GAGT9qE,EAAI,IACV,KAAK,EACH,MACF,KAAK,EACHu+B,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGg7G,GACnB,MACF,KAAK,EACHzsC,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG2hG,EAAIzgB,IACvB,MACF,OACE3S,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGkmD,GACnB,MACF,KAAK,EACHqoB,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGg7G,EAAO,GAC1B,MACF,OACEzsC,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGg7G,EAAO,OAC1B,MACF,KAAK,EACHzsC,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG,GACnB,MACF,OAEI,GAAI68D,GAAO,EACT0R,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG26G,EAAK99C,SACrB,GAAIqkB,GAAO,EACd3S,EAAM,CAAEj9D,EAAG,IAAKtR,EAAG2hG,EAAIzgB,QACpB,IAAKprF,MAAMklH,GAGd,MAAM,IAAI/mH,MAAM,yBAAyBm4B,OAAO4jB,EAAIj9C,MAAM,EAAG,KAF7Dw7E,EAAM,CAAEj9D,EAAG,IAAKtR,EAAGg7G,EAE8C,CAErE,MACF,QACE,MAAM,IAAI/mH,MAAM,yBAAyBm4B,OAAO4jB,EAAIj9C,MAAM,EAAG,KAEjE,OAAOw7E,CACT,CAkIa8sC,CAAkBrrE,EAAK2xD,EAAKgZ,EAAM3qE,EAAI,IAC/C,OACE,OAAO0qE,GAAkB1qE,EAAK2xD,EAAKgZ,GACrC,QACE,MAAM,IAAI1mH,MAAM,+BAA+Bm4B,OAAO4jB,EAAI,KAEhE,CACA,SAASsrE,GAAoBtrE,GAE3B,OAAOkqE,GADEI,GAActqE,GACE,GAAG,GAAGh0C,KACjC,CAMA,SAASu/G,GAAwBtsF,EAAGi7B,GAClC,IAAIsxD,EAAKlB,GAAcpwD,EAAKluD,MACxB2E,EAAOy5G,GAAcoB,EAAG,GAAG,GAAGx/G,MAC9BwL,EAAUg0G,EAAG,GACbx/G,EAAO,GAwBX,OAvBCwL,GAAW,IAAI6qB,QAAQ,SAASilB,GAC/B,IAAIpC,EAAKolE,GAAchjE,EAAMt7C,MACzB6rB,EAAMuyF,GAAcllE,EAAG,GAAG,GAAGl5C,QAAU,EAC3C,OAAQ2E,GACN,OACE3E,EAAK6rB,GAAOgyF,GAAM3kE,EAAG,GAAG,GAAGl5C,MAC3B,MACF,KAAK,EAED,IACIy/G,EAAMnB,GADDrrF,EAAEqsF,GAAoBpmE,EAAG,GAAG,GAAGl5C,OAAO,GACpBA,MACvB0/G,EAASzsF,EAAEqsF,GAAoBG,EAAI,GAAG,GAAGz/G,OAAO,GAChD2/G,EAAQvB,GAAcsB,EAAO19E,KAAK,GAAG,GAAGhiC,MAC5C,GAAa,MAAT2/G,EACF,MAAM,IAAI1nH,MAAM,gCAAgCm4B,OAAOuvF,IACzD,IAAIC,EAAStB,GAAcoB,EAAO1/G,MAClCA,EAAK6rB,GAAO+zF,EAAO,GAAG1xF,IAAI,SAASt1B,GACjC,OAAOilH,GAAMjlH,EAAEoH,KACjB,GAAGvD,KAAK,IAIhB,GACOuD,CACT,CAiCA,SAAS6/G,GAAe5sF,EAAGi7B,GACzB,IAAI4xD,EACAN,EAAKlB,GAAcpwD,EAAKluD,MACxBuiB,GAAiD,OAArCu9F,EAAW,MAANN,OAAa,EAASA,EAAG,SAAc,EAASM,EAAG,IAAM1B,GAAcoB,EAAG,GAAG,GAAGx/G,QAAU,EAAI,EAAI,EAAI,KACvHqoD,EAAKk2D,GAAMiB,EAAG,GAAI,SAAS1B,GAC7B,OArCJ,SAA+BA,EAAIn5G,GACjC,IAAIm7G,EAAIC,EAAIC,EAAInb,EAAIv7E,EAAIgzD,EAAI2jC,EAAIC,EAAI/nF,EAAIm4E,EAAI6P,EAAIC,EAAIC,EAAI5jC,EAKpD6jC,EAAiBC,EAJjBf,EAAKlB,GAAcR,GACnBlkE,EAAIwkE,GAAcoB,EAAG,GAAG,GAAGx/G,QAAU,EACrCgyD,EAAMosD,GAAcoB,EAAG,GAAG,GAAGx/G,QAAU,EACvCwgH,GAAgE,OAA/CT,EAAqB,OAAfD,EAAKN,EAAG,SAAc,EAASM,EAAG,SAAc,EAASC,EAAG//G,OAASo+G,GAAcoB,EAAG,GAAG,GAAGx/G,MAAQ,IAAK,EAEpI,IAAqD,OAA/C6kG,EAAqB,OAAfmb,EAAKR,EAAG,SAAc,EAASQ,EAAG,SAAc,EAASnb,EAAG7kG,OAAiB,GAAR2E,EAC/E27G,EAAkE,OAA/ChkC,EAAqB,OAAfhzD,EAAKk2F,EAAG,SAAc,EAASl2F,EAAG,SAAc,EAASgzD,EAAGt8E,KACrFugH,EAA+D,OAA/CL,EAAqB,OAAfD,EAAKT,EAAG,SAAc,EAASS,EAAG,SAAc,EAASC,EAAGlgH,SAC7E,MAAqD,OAA/CswG,EAAqB,OAAfn4E,EAAKqnF,EAAG,SAAc,EAASrnF,EAAG,SAAc,EAASm4E,EAAGtwG,OAAiB,GAAR2E,EAItF,KAAM,wBAAwByrB,OAAOzrB,EAAM,iBAH3C27G,EAAkE,OAA/CF,EAAqB,OAAfD,EAAKX,EAAG,WAAuBW,EAAG,SAAc,EAASC,EAAGpgH,KACrFugH,EAA+D,OAA/C9jC,EAAqB,OAAf4jC,EAAKb,EAAG,SAAc,EAASa,EAAG,SAAc,EAAS5jC,EAAGz8E,IAEvB,CAI7D,IAHA,IAAI0yB,EAAQ8tF,EAAe,EAAI,EAC3BC,EAAuB9C,GAAe2C,GACtCnZ,EAAU,GACLrjF,EAAI,EAAGA,EAAIw8F,EAAgBhqH,OAAS,IAAKwtB,EAAG,CACnD,IAAIP,EAAMk9F,EAAqBC,UAAc,EAAJ58F,GAAO,GAC5CP,EAAM,OACR4jF,EAAQ5qG,KAAK,CAACunB,EAAGP,GACrB,CACA,GAAI4jF,EAAQ7wG,QAAU07D,EACpB,KAAM,YAAY5hC,OAAO4hC,EAAK,kBAAkB5hC,OAAO+2E,EAAQ7wG,QACjE,IAAIuqG,EAAQ,GACZ,IAAK/8E,EAAI,EAAGA,EAAIqjF,EAAQ7wG,OAAS,IAAKwtB,EACpC+8E,EAAMsG,EAAQrjF,GAAG,IAAMy8F,EAAalzF,SAAS85E,EAAQrjF,GAAG,GAAK4O,EAAOy0E,EAAQrjF,EAAI,GAAG,GAAK4O,GAG1F,OAFIy0E,EAAQ7wG,QAAU,IACpBuqG,EAAMsG,EAAQA,EAAQ7wG,OAAS,GAAG,IAAMiqH,EAAalzF,SAAS85E,EAAQA,EAAQ7wG,OAAS,GAAG,GAAKo8B,IAC1F,CAAEknB,EAAGA,EAAGinD,MAAOA,EACxB,CAMW8f,CAAsB7C,EAAIv7F,EACnC,GACA,MAAO,CACLq+F,MAAOxC,GAAcoB,EAAG,GAAG,GAAGx/G,QAAU,EACxCA,KAAMqoD,EAAG54B,OAAO,SAASse,EAAKn1C,GAQ5B,OAPKm1C,EAAIn1C,EAAEghD,KACT7L,EAAIn1C,EAAEghD,GAAK,IACbhhD,EAAEioG,MAAMxqE,QAAQ,SAASsxC,EAAM7jD,GAC7B,GAAIiqB,EAAIn1C,EAAEghD,GAAG91B,GACX,MAAM,IAAI7rB,MAAM,oBAAoBm4B,OAAOx3B,EAAEghD,EAAG,OAAOxpB,OAAOtM,IAChEiqB,EAAIn1C,EAAEghD,GAAG91B,GAAK6jD,CAChB,GACO55B,CACT,EAAG,IAEP,CAmCA,SAAS8yE,GAA2B5tF,EAAGi7B,GACrC,IACInrC,EAAM,CAAE,OAAQ,MAChB+9F,EAAW7tF,EAAEqsF,GAFRhB,GAAcpwD,EAAKluD,MAEY,GAAG,GAAGA,OAC1C2/G,EAAQvB,GAAc0C,EAAS,GAAG9+E,KAAK,GAAG,GAAGhiC,MACjD,GAAa,MAAT2/G,EACF,UAAU1nH,MAAM,gCAAgCm4B,OAAOuvF,IAEzD,OA1CF,SAAqC1sF,EAAGi7B,EAAMyb,GAC5C,IAAIm2C,EACAN,EAAKlB,GAAcpwD,EAAKluD,MACxB0a,EAAQ,CAAErV,EAAG,CAAE2D,EAAG,EAAGC,EAAG,GAAKxD,EAAG,CAAEuD,EAAG,EAAGC,EAAG,IAE/C,GADAyR,EAAMjV,EAAEuD,GAAKo1G,GAAcoB,EAAG,GAAG,GAAGx/G,QAAU,GAAK,EAC/C0a,EAAMjV,EAAEuD,EAAI,EACd,MAAM,IAAI/Q,MAAM,sBAAsBm4B,OAAOovF,EAAG,GAAG,GAAGx/G,OAExD,GADA0a,EAAMjV,EAAEwD,GAAKm1G,GAAcoB,EAAG,GAAG,GAAGx/G,QAAU,GAAK,EAC/C0a,EAAMjV,EAAEwD,EAAI,EACd,MAAM,IAAIhR,MAAM,sBAAsBm4B,OAAOovF,EAAG,GAAG,GAAGx/G,OACxD2pE,EAAG,QAAUf,GAAaluD,GAC1B,IAAIqmG,EAAQzC,GAAckB,EAAG,GAAG,GAAGx/G,MAC/B2lG,EAAM4Z,GAAwBtsF,EAAGA,EAAEqsF,GAAoByB,EAAM,GAAG,GAAG/gH,OAAO,IAC1E2+G,GAA4B,OAAnBmB,EAAKiB,EAAM,UAAe,EAASjB,EAAG,IAAMP,GAAwBtsF,EAAGA,EAAEqsF,GAAoByB,EAAM,IAAI,GAAG/gH,OAAO,IAAM,GAChIghH,EAAO1C,GAAcyC,EAAM,GAAG,GAAG/gH,MACjC4pE,EAAK,EACTo3C,EAAK,GAAG3qF,QAAQ,SAAS/gB,GACvB,IAAI2rG,EAAK3C,GAAchpG,EAAEtV,MACrBs5E,EAAMrmD,EAAEqsF,GAAoB2B,EAAG,GAAG,GAAGjhH,OAAO,GAC5C2/G,EAAQvB,GAAc9kC,EAAIt3C,KAAK,GAAG,GAAGhiC,MACzC,GAAa,MAAT2/G,EACF,MAAM,IAAI1nH,MAAM,gCAAgCm4B,OAAOuvF,IACzD,IAAIuB,EAAQrB,GAAe5sF,EAAGqmD,GAC9B4nC,EAAMlhH,KAAKq2B,QAAQ,SAASr3B,EAAK46C,GAC/B56C,EAAIq3B,QAAQ,SAAS2d,EAAKlwB,GACxB,IAAIosC,EAAO+X,GAAY,CAAEj/D,EAAG4gE,EAAKhwB,EAAG3wC,EAAG6a,IACnCtB,EAAM48F,GAAmBprE,EAAK2xD,EAAKgZ,GACnCn8F,IACFmnD,EAAGzZ,GAAQ1tC,EACf,EACF,GACAonD,GAAMs3C,EAAMN,KACd,EACF,CAQEO,CAA4BluF,EAAG6tF,EAAS,GAAI/9F,GACrCA,CACT,CAkBA,SAASq+F,GAAyBnuF,EAAGi7B,GACnC,IAAInrC,EAklDE,CAAEumD,WAAY,GAAIC,OAAQ,IApkDhC,GAZgBg1C,GADPD,GAAcpwD,EAAKluD,MACH,GAAIs/G,IACnBjpF,QAAQ,SAAS9S,GACzB0P,EAAE1P,GAAK8S,QAAQ,SAASt0B,GAEtB,GAAa,GADDq8G,GAAcr8G,EAAEigC,KAAK,GAAG,GAAGhiC,MACvB,CACd,IAAIqhH,EAzBZ,SAA+BpuF,EAAGi7B,GAChC,IAAI4xD,EACAN,EAAKlB,GAAcpwD,EAAKluD,MACxB+iB,EAAM,CACRjnB,MAAuB,OAAfgkH,EAAKN,EAAG,SAAc,EAASM,EAAG,IAAMjC,GAAM2B,EAAG,GAAG,GAAGx/G,MAAQ,GACvEqpE,OAAQ,IAUV,OARgBk1C,GAAMiB,EAAG,GAAIF,IACnBjpF,QAAQ,SAAS9S,GACzB0P,EAAE1P,GAAK8S,QAAQ,SAASt0B,GAET,KADDq8G,GAAcr8G,EAAEigC,KAAK,GAAG,GAAGhiC,OAErC+iB,EAAIsmD,OAAO9sE,KAAKskH,GAA2B5tF,EAAGlxB,GAClD,EACF,GACOghB,CACT,CASoBu+F,CAAsBruF,EAAGlxB,GACrCs/G,EAAMh4C,OAAOhzC,QAAQ,SAAS+yC,EAAOnlE,GACnCilG,GAAkBnmF,EAAKqmD,EAAc,GAAPnlE,EAAWo9G,EAAMvlH,KAAOulH,EAAMvlH,KAAO,IAAMmI,GAAK,EAChF,EACF,CACF,EACF,GAC6B,GAAzB8e,EAAIumD,WAAWhzE,OACjB,UAAU2B,MAAM,sBAClB,OAAO8qB,CACT,CACA,SAASw+F,GAAkBpvD,GACzB,IAAI2tD,EAAIC,EAAIC,EAAInb,EACZ5xE,EAAI,CAAA,EAAI/nB,EAAU,GAyBtB,GAxBAinD,EAAI7D,UAAUj4B,QAAQ,SAASn0B,GAC7B,GAAIA,EAAEowB,MAAM,WACV,MAAM,IAAIr6B,MAAM,kCACpB,GACAk6D,EAAI9D,UAAUh4B,QAAQ,SAAShxB,GAC7B,GAAKA,EAAEvJ,KAAKw2B,MAAM,UAAlB,CAEA,IAAI2iB,EAMAusE,EALJ,IACEvsE,EA/aN,SAA6BjB,GAG3B,IAFA,IAAIjxB,EAAM,GACN9iB,EAAI,EACDA,EAAI+zC,EAAI19C,QAAQ,CACrB,IAAIgf,EAAI0+B,EAAI/zC,KACRnD,EAAMk3C,EAAI/zC,GAAK+zC,EAAI/zC,EAAI,IAAM,EAAI+zC,EAAI/zC,EAAI,IAAM,GACnDA,GAAK,EACL8iB,EAAIxmB,KAAKiiH,GAAmBlpG,EAAG0+B,EAAIj9C,MAAMkJ,EAAGA,EAAInD,KAChDmD,GAAKnD,CACP,CACA,GAAImD,IAAM+zC,EAAI19C,OACZ,UAAU2B,MAAM,sCAClB,OAAO8lH,GAASh7F,EAClB,CAkaU0+F,CAAoBp8G,EAAEgsD,QAC5B,CAAE,MAAO5rD,GACP,OAAO0D,QAAQoJ,IAAI,MAAQlN,EAAEgsD,QAAQ/6D,OAAS,KAAOmP,EAAE0+B,SAAW1+B,GACpE,CAEA,IACE+7G,EAviBN,SAAwBxtE,GAGtB,IAFA,IAAI8rE,EACA/8F,EAAM,GAAIoS,EAAM,CAAC,GACdA,EAAI,GAAK6e,EAAI19C,QAAQ,CAC1B,IAAIwG,EAAMohH,GAAelqE,EAAK7e,GAC1BsvE,EAAK6Z,GAActqE,EAAIj9C,MAAMo+B,EAAI,GAAIA,EAAI,GAAKr4B,IAClDq4B,EAAI,IAAMr4B,EACV,IAAI0lB,EAAM,CACRqQ,GAAIurF,GAAc3Z,EAAG,GAAG,GAAGzkG,MAC3B0hH,SAAU,IAEZjd,EAAG,GAAGpuE,QAAQ,SAAS9sB,GACrB,IAAIo4G,EAAKrD,GAAc/0G,EAAEvJ,MACrBg1G,EAAKoJ,GAAcuD,EAAG,GAAG,GAAG3hH,MAChCwiB,EAAIk/F,SAASnlH,KAAK,CAChBylC,KAAM2/E,EACN3hH,KAAMg0C,EAAIj9C,MAAMo+B,EAAI,GAAIA,EAAI,GAAK6/E,KAEnC7/E,EAAI,IAAM6/E,CACZ,IACoB,OAAf8K,EAAKrb,EAAG,SAAc,EAASqb,EAAG,MACrCt9F,EAAIo/F,MAAQxD,GAAc3Z,EAAG,GAAG,GAAGzkG,QAAU,EAAI,GACnD+iB,EAAIxmB,KAAKimB,EACX,CACA,OAAOO,CACT,CA8gBgB8+F,CAAe5sE,EAC3B,CAAE,MAAOxvC,GACP,OAAO0D,QAAQoJ,IAAI,OAAS9M,EAAE0+B,SAAW1+B,GAC3C,CACA+7G,EAAQnrF,QAAQ,SAASyrF,GACvB7uF,EAAE6uF,EAAOjvF,IAAMivF,EAAOJ,SACtBx2G,EAAQ3O,KAAKulH,EAAOjvF,GACtB,EAhBE,CAiBJ,IACK3nB,EAAQ5U,OACX,UAAU2B,MAAM,wBAClB,IAAI8pH,GAAiJ,OAArIld,EAA2G,OAArGmb,EAAyE,OAAnED,EAAyC,OAAnCD,EAAU,MAAL7sF,OAAY,EAASA,EAAE,SAAc,EAAS6sF,EAAG,SAAc,EAASC,EAAG/9E,WAAgB,EAASg+E,EAAG,SAAc,EAASnb,EAAG,GAAG7kG,OAAmD,GAA1Co+G,GAAcnrF,EAAE,GAAG,GAAG+O,KAAK,GAAG,GAAGhiC,OAAcizB,EAAE,GAAG,GAaxO,GAZK8uF,GACH72G,EAAQmrB,QAAQ,SAASpyB,GACvBgvB,EAAEhvB,GAAKoyB,QAAQ,SAAS2rF,GAEtB,GAAa,GADD5D,GAAc4D,EAAKhgF,KAAK,GAAG,GAAGhiC,QAAU,EACpC,CACd,GAAK+hH,EAGH,MAAM,IAAI9pH,MAAM,+BAFhB8pH,EAAUC,CAGd,CACF,EACF,IACGD,EACH,MAAM,IAAI9pH,MAAM,6BAClB,OAAOmpH,GAAyBnuF,EAAG8uF,EACrC,CAyUA,SAAS9V,GAActnD,GAVvB,IAAuBs+C,KAWT,CACb,CAAC,UAAU,GACX,CAAC,YAAY,GACb,CAAC,eAAe,GAChB,CAAC,cAAc,GACf,CAAC,YAAY,GACb,CAAC,aAAa,GAEd,CAAC,cAAc,GACf,CAAC,YAAa,EAAG,KAEjB,CAAC,YAAY,GACb,CAAC,cAAc,GACf,CAAC,aAAa,GACd,CAAC,aAAa,GACd,CAAC,WAAW,GAEZ,CAAC,WAAW,IACZ,CAAC,OAAO,IA5BD,SAAkBt+C,GACxB,IAAI,IAAIjtD,EAAI,EAAGA,GAAKurG,EAAS3sG,SAAUoB,EAAG,CACzC,IAAIwjB,EAAI+nF,EAASvrG,QACCnB,IAAfouD,EAAKzpC,EAAE,MAAmBypC,EAAKzpC,EAAE,IAAMA,EAAE,IAChC,MAATA,EAAE,KAAYypC,EAAKzpC,EAAE,IAAM1iB,OAAOmsD,EAAKzpC,EAAE,KAC7C,CACD,GAuBEypC,EACH,CA8BA,SAASs9D,GAAiB5hD,EAAKvD,EAAiBolD,EAAqB94C,EAAOnlE,EAAgBk+G,EAAW94C,EAAQ+4C,EAAkBz9D,EAAM6iC,EAAIiK,EAAQC,GAClJ,IACCywB,EAAU/4C,GAAOmF,GAAW9N,GAAUJ,EAAK6hD,GAAU,GAAOplD,GAC5D,IACI2M,EADAzpE,EAAOugE,GAAWF,EAAKvD,GAE3B,OAAOslD,GACN,IAAK,QAAU34C,EAAM+6B,GAASxkG,EAAM88D,EAAM74D,EAAK0gD,EAAMw9D,EAAU/4C,GAAQoe,EAAIiK,EAAQC,GAAS,MAC5F,IAAK,QACJ,KADcjoB,EAAMy7B,GAASllG,EAAM88D,EAAM74D,EAAK0gD,EAAMw9D,EAAU/4C,GAAQoe,MAC1D/d,EAAI,WAAY,MAC5B,IAAI44C,EAAQrhD,GAAayI,EAAI,WAAWmF,OAAQ9R,GAC5CwlD,EAASh0C,GAAc+zC,GACvBE,EAjvWR,SAAuBviH,EAAMyuE,GAC5B,IAAIzuE,EAAM,MAAO,KAYjB,IAAI6yB,GAAM7yB,EAAKsyB,MAAM,iCAAiC,CAAC,GAAG,KAAK,GAE/D,OAAOm8C,EAAK,OAAO57C,GAAI+7C,MACxB,CAiuWe4zC,CAAc/hD,GAAUJ,EAAKgiD,GAAO,GAAO9zC,GAAW9N,GAAUJ,EAAKiiD,GAAQ,GAAOD,IAC3FI,EAASzhD,GAAauhD,EAAMF,GAC5BK,EAASp0C,GAAcm0C,GAC3Bh5C,EAAM84B,GAAY9hC,GAAUJ,EAAKoiD,GAAQ,GAAOA,EAAQ99D,EAAM4pB,GAAW9N,GAAUJ,EAAKqiD,GAAQ,GAAOD,GAASj7B,EAAI/d,GACpH,MACD,IAAK,QAz5LgB3tE,EAy5LeghE,EAAiBqlD,EAAU/4C,GAx5L9DttE,EAAK/E,OAAM,GAw5LG0yE,EA91VuF,CAAC,QAAQ,SA81VnB,MAC5F,IAAK,SAAUA,EAr5LlB,SAAkBzpE,EAAMlE,GACvB,OAAGA,EAAK/E,OAAM,GA78J0F,CAAC,QAAQ,SA+8JlH,CAk5LwB4rH,CAAS3iH,EAAM88D,EAAM74D,EAAK0gD,EAAMw9D,EAAU/4C,IAA6B,MAC5F,QAAS,UAAUnxE,MAAM,2BAA6BmqH,GAEvD/4C,EAAOD,GAASK,EAGhB,IAAIm5C,EAAY,GACbT,GAAaA,EAAU/4C,IAAQ3lC,GAAK0+E,EAAU/4C,IAAQ/yC,QAAQ,SAASr0B,GACzE,IAAIqgH,EAAQ,GACZ,GAAGF,EAAU/4C,GAAOpnE,GAAG2sE,MAAQlC,GAAKU,KAAM,CACzCk1C,EAAQrhD,GAAamhD,EAAU/4C,GAAOpnE,GAAG4sE,OAAQ9R,GACjD,IAAI24B,EAAWqQ,GAAWvlC,GAAWF,EAAKgiD,GAAO,GAAOA,EAAO19D,GAC/D,IAAI8wC,IAAaA,EAASn/F,OAAQ,OAClCk/F,GAAsB/rB,EAAKgsB,GAAU,EACtC,CACG0sB,EAAU/4C,GAAOpnE,GAAG2sE,MAAQlC,GAAK0B,QACnCk0C,EAAQrhD,GAAamhD,EAAU/4C,GAAOpnE,GAAG4sE,OAAQ9R,GACjD8lD,EAAYA,EAAUxyF,OAjlW1B,SAAyBpwB,EAAiB2kD,GACzC,IAAI5hC,EAAM,GACNklE,GAAO,EAAO2N,EAAU,CAAA,EAAIitB,EAAO,EAiCvC,OAhCA7iH,EAAKwyB,QAAQ4uC,GAAU,SAAmBxoE,EAAGqL,GAC5C,IAAIuE,EAAY+4D,GAAY3oE,GAC5B,OAAO+oE,GAASn5D,EAAE,KACjB,IAAK,QAGL,IAAK,oBACL,IAAK,sBAgBL,IAAK,UAAW,IAAK,WAAY,IAAK,YAAa,IAAK,YAAa,MAbrE,IAAK,mBAAoBotF,EAAU,CAACC,OAAQrtF,EAAEs6G,SAAUxc,KAAM99F,EAAEqqB,GAAIymD,IAAK9wE,EAAE8wE,IAAKnhC,EAAG,GAAI,MACvF,IAAK,qBAAsC,MAAby9C,EAAQtgF,GAAWyN,EAAIxmB,KAAKq5F,GAAU,MAEpE,IAAK,SAAU,IAAK,QAASitB,EAAO5+G,EAAMrL,EAAEtC,OAAQ,MACpD,IAAK,UAAWs/F,EAAQtgF,EAAItV,EAAKjJ,MAAM8rH,EAAM5+G,GAAKuuB,QAAQ,QAAS,MAAMA,QAAQ,MAAO,MAAO,MAG/F,IAAK,YAAa,IAAK,aAQvB,IAAK,OAAQy1D,GAAK,EAAM,MAPxB,IAAK,cAQL,IAAK,SAAUA,GAAK,EAAO,MAE3B,QAAS,IAAIA,GAAQtjC,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM,gBAAkBuQ,EAAE,GAAK,yBAEzE,OAAO5P,CACR,GACOmqB,CACR,CA6iWiCggG,CAAgBxiD,GAAWF,EAAKgiD,GAAO,GAAO19D,IAE7E,GACGi+D,GAAaA,EAAUtsH,QAAQk/F,GAAsB/rB,EAAKm5C,GAAW,EAAMj+D,EAAKgxC,QAAU,GAC9F,CAAE,MAAMlwF,GAAK,GAAGk/C,EAAK+e,IAAK,MAAMj+D,CAAG,CA/6LpC,IAAwB3J,CAg7LxB,CAEA,SAASknH,GAAkBpqH,GAA2B,MAAsB,KAAfA,EAAE6gD,OAAO,GAAY7gD,EAAE7B,MAAM,GAAK6B,CAAG,CAElG,SAASq1D,GAAUoS,EAAa1b,GAM/B,GALAsG,KAEAghD,GADAtnD,EAAOA,GAAQ,CAAA,GAIZyb,GAAeC,EAAK,yBAA0B,OAAOm9C,GAAUn9C,EAAK1b,GAEvE,GAAGyb,GAAeC,EAAK,kBAAmB,OAAOm9C,GAAUn9C,EAAK1b,GAEhE,GAAGyb,GAAeC,EAAK,sBAAuB,CAC7C,GAAwB,oBAAdzsB,WAA2B,MAAM,IAAI37C,MAAM,oDACrD,QAA+B,IAArBspH,GAAkC,CAC3C,GAAGlhD,EAAIhS,UAAW,OAAOkzD,GAAkBlhD,GAC3C,IAAI4iD,EAAOt2D,GAAIiQ,MAAMY,UAErB,OADAkD,GAAWL,GAAKhqC,QAAQ,SAAS5wB,GAAKk7D,GAAasiD,EAAMx9G,EA7xmB5D,SAAmB46D,EAAKrS,GACb,OAAOmS,GAAWG,GAAWD,EAAKrS,GAG7C,CAyxmB+Dk1D,CAAU7iD,EAAK56D,GAAK,GACzE87G,GAAkB0B,EAC1B,CACA,MAAM,IAAIhrH,MAAM,2BACjB,CACA,IAAImoE,GAAeC,EAAK,uBAAwB,CAC/C,GAAGD,GAAeC,EAAK,gBAAiB,MAAM,IAAIpoE,MAAM,+BACxD,GAAGmoE,GAAeC,EAAK,aAAc,MAAM,IAAIpoE,MAAM,+BACrD,UAAUA,MAAM,uBACjB,CAEA,IAGIoxE,EAAQ85C,EAHR33G,EAAUk1D,GAAWL,GACrB+iD,EA5njBL,SAAkBpjH,GACjB,IAAIkxD,EATI,CACPmyD,UAAU,GAAIh6C,OAAO,GAAIi6C,OAAO,GAAIC,QAAQ,GAAIC,OAAO,GACvD/0C,KAAK,GAAIguB,KAAK,GAAIhH,SAAS,GAAIguB,iBAAiB,GAAIC,MAAM,GAC1DC,UAAU,GAAIC,SAAS,GAAIC,UAAU,GAAIpyB,OAAO,GAAIC,OAAO,GAC3DoyB,WAAW,GAAIC,IAAK,GAAIC,SAAU,GAAIthC,SAAU,GAAIiT,OAAO,GAC3DsuB,KAAK,GAAIrgB,MAAO,IAKjB,IAAI5jG,IAASA,EAAKsyB,MAAO,OAAO4+B,EAChC,IAAIgzD,EAAQ,CAAA,EAYZ,IAXClkH,EAAKsyB,MAAM8uC,KAAW,IAAI/qC,QAAQ,SAASz9B,GAC3C,IAAI4P,EAAI+4D,GAAY3oE,GACpB,OAAO4P,EAAE,GAAGgqB,QAAQ6uC,GAAQ,MAC3B,IAAK,QAAS,MACd,IAAK,SAAUnQ,EAAG0yC,MAAQp7F,EAAE,SAAWA,EAAE,GAAG8pB,MAAM,YAAY,CAAC,GAAG,KAAK,IAAM,MAC7E,IAAK,WAAY4xF,EAAM17G,EAAE27G,WAAa37G,EAAE47G,YAAa,MACrD,IAAK,iBAC8B7tH,IAA/B26D,EAAGsb,GAAQhkE,EAAE47G,eAA6BlzD,EAAGsb,GAAQhkE,EAAE47G,cAAc7nH,KAAKiM,EAAE67G,UAGlF,GACGnzD,EAAG0yC,QAAU5/B,GAAU,MAAM,IAAI/rE,MAAM,sBAAwBi5D,EAAG0yC,OAMrE,OALA1yC,EAAGozD,UAAYpzD,EAAG4yD,WAAWxtH,OAAS,EAAI46D,EAAG4yD,WAAW,GAAK,GAC7D5yD,EAAGy0C,IAAMz0C,EAAGurC,KAAKnmG,OAAS,EAAI46D,EAAGurC,KAAK,GAAK,GAC3CvrC,EAAGz+B,MAAQy+B,EAAGwgC,OAAOp7F,OAAS,EAAI46D,EAAGwgC,OAAO,GAAK,GACjDxgC,EAAG+xC,SAAWihB,SACPhzD,EAAG4yD,WACH5yD,CACR,CAsmjBWqzD,CAAU9jD,GAAUJ,EAAK,wBAC/BmkD,GAAO,EAMX,GAJ4B,IAAzBpB,EAAIC,UAAU/sH,QAEbiqE,GAAWF,EADd8iD,EAAU,mBACiB,IAAOC,EAAIC,UAAU9mH,KAAK4mH,GAE1B,IAAzBC,EAAIC,UAAU/sH,OAAc,CAE9B,IAAIiqE,GAAWF,EADf8iD,EAAU,mBACiB,GAAO,MAAM,IAAIlrH,MAAM,2BAClDmrH,EAAIC,UAAU9mH,KAAK4mH,GACnBqB,GAAO,CACR,CACiC,OAA9BpB,EAAIC,UAAU,GAAGtsH,OAAM,KAAcytH,GAAO,GAE/C,IAAI/yB,EAAU,CAAA,EACVC,EAAU,CAAA,EACd,IAAI/sC,EAAKknD,aAAelnD,EAAKmnD,UAAW,CAEvC,GADArP,GAAO,GACJ2mB,EAAIzd,IAAK,IAAMlJ,GAAK8I,GAAUhlC,GAAWF,EAAK2iD,GAAkBI,EAAIzd,MAAOyd,EAAIzd,IAAKhhD,EAAO,CAAE,MAAMl/C,GAAK,GAAGk/C,EAAK+e,IAAK,MAAMj+D,CAAG,CAE9Hk/C,EAAKg1B,YAAcypC,EAAI3xB,OAAOn7F,SAAQm7F,EAr9L3C,SAAqBzxF,EAAiBlE,EAAiB6oD,GACtD,OAAO+vC,GAAgB10F,EAAM2kD,EAC9B,CAm9LoD8/D,CAAYhkD,GAAUJ,EAAK+iD,EAAI3xB,OAAO,GAAGj/D,QAAQ,MAAM,KAAK,IAAO,GAAG4wF,EAAI3xB,OAAO,GAAI9sC,IAEpIy+D,EAAI3wF,QAAOi/D,EAAS2T,GAAU9kC,GAAWF,EAAK2iD,GAAkBI,EAAI3wF,QAAS2wF,EAAI3wF,MAAOg/D,EAAQ9sC,GACpG,CAEsBy+D,EAAIM,MAAMx1F,IAAI,SAASw2F,GAC5C,IACYn2C,GAAW9N,GAAUJ,EAAKiO,GAAc00C,GAAkB0B,KAASA,GAC9E,OAAO9d,GAAYrmC,GAAWF,EAAK2iD,GAAkB0B,IAAQj2C,EAAMi2C,EAAM//D,EAC1E,CAAE,MAAMl/C,GAAI,CACb,GAEA,IAAI+hF,EAAKmc,GAASpjC,GAAWF,EAAK2iD,GAAkBI,EAAIC,UAAU,KAAMD,EAAIC,UAAU,GAAI1+D,GAEtF2qB,EAAQ,CAAA,EAAIq1C,EAAW,GAExBvB,EAAIO,UAAUrtH,UAChBquH,EAAWpkD,GAAWF,EAAK2iD,GAAkBI,EAAIO,UAAU,KAAK,MACnDr0C,EAAQL,GAAiB01C,IACX,IAAxBvB,EAAIQ,SAASttH,SACfquH,EAAWpkD,GAAWF,EAAK2iD,GAAkBI,EAAIQ,SAAS,KAAK,KAnxiBlE,SAAyB5jH,EAAMkC,EAAGyiD,GACjC,IAAIp6C,EAAI,CAAA,EAAQrI,IAAGA,EAAI,CAAA,GACvBlC,EAAO8iE,GAAS9iE,GAEhBqtE,GAAUh3C,QAAQ,SAAS9d,GAC1B,IAAImjD,GAAO17D,EAAKsyB,MAAMywC,GAASxqD,EAAE,MAAM,IAAI,GAC3C,OAAOA,EAAE,IACR,IAAK,SAAamjD,IAAKx5D,EAAEqW,EAAE,IAAMupD,GAAYpG,IAAM,MACnD,IAAK,OAAQx5D,EAAEqW,EAAE,IAAc,SAARmjD,EAAgB,MACvC,IAAK,MACJ,IAAIwT,EAAMlvE,EAAKsyB,MAAM,IAAImU,OAAO,IAAMluB,EAAE,GAAK,uBAA0BA,EAAE,GAAK,MAC3E22D,GAAOA,EAAI54E,OAAS,IAAGiU,EAAEgO,EAAE,IAAM22D,EAAI,IAG3C,GAEG3kE,EAAE0nG,cAAgB1nG,EAAE2nG,eAAe/iC,GAAiB5kE,EAAE0nG,aAAc1nG,EAAE2nG,cAAehwG,EAAGyiD,EAG5F,CAiwiBgBigE,CAAgBD,EAAUr1C,EAAO3qB,IAIhD,IAAIk/D,EAAY,CAAA,EACZl/D,EAAKknD,aAAclnD,EAAKmnD,WACE,IAAzBsX,EAAIS,UAAUvtH,SACjBquH,EAAWlkD,GAAUJ,EAAK2iD,GAAkBI,EAAIS,UAAU,KAAK,MAClDA,EA3uiBhB,SAA0B7jH,EAAiB2kD,GAC1C,IAAIziD,EAAI,CAAA,EAAIpG,EAAO,GACfiG,EAAI/B,EAAKsyB,MAAMu9C,IACnB,GAAG9tE,EAAG,IAAI,IAAIrK,EAAI,EAAGA,GAAKqK,EAAEzL,SAAUoB,EAAG,CACxC,IAAIkB,EAAImJ,EAAErK,GAAI8Q,EAAI+4D,GAAY3oE,GAC9B,OAAO4P,EAAE,IACR,IAAK,QACL,IAAK,cAAe,MACpB,IAAK,YAAa1M,EAAOgmE,GAAYt5D,EAAE1M,MAAO,MAC9C,IAAK,cAAeA,EAAO,KAAM,MACjC,QAAS,GAA0B,IAAtBlD,EAAEg9B,QAAQ,QAAe,CACrC,IAAIivF,EAAOjsH,EAAEg3C,MAAM,KACfjrC,EAAOkgH,EAAK,GAAG9tH,MAAM,GAAIolE,EAAO0oD,EAAK,GAEzC,OAAOlgH,GACN,IAAK,QAAS,IAAK,OAAQ,IAAK,SAehC,IAAK,KAAM,IAAK,QACfzC,EAAEpG,GAAQgmE,GAAY3F,GACtB,MAdD,IAAK,OACJj6D,EAAEpG,GAAQymE,GAAapG,GACvB,MACD,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,IAAK,KAAM,IAAK,MAAO,IAAK,OAC5Dj6D,EAAEpG,GAAQ2N,SAAS0yD,EAAM,IACzB,MACD,IAAK,KAAM,IAAK,KAAM,IAAK,UAC1Bj6D,EAAEpG,GAAQorC,WAAWi1B,GACrB,MACD,IAAK,WAAY,IAAK,OACrBj6D,EAAEpG,GAAQkjE,GAAU7C,GACpB,MAID,QACC,GAAqB,KAAlBx3D,EAAK5N,OAAM,GAAY,MACvB4tD,EAAK+e,KAA0B,oBAAZv6D,SAAyBA,QAAQC,KAAK,aAAcxQ,EAAG+L,EAAMkgH,GAEtF,SAA2B,OAAjBjsH,EAAE7B,MAAM,EAAE,SACb,GAAG4tD,EAAK+e,IAAK,UAAUzrE,MAAMW,GAEtC,CACA,OAAOsJ,CACR,CAisiB4B4iH,CAAiBH,EAAUhgE,IAItD,IAAI5hC,EAAO,CAAA,EACX,IAAG4hC,EAAKknD,YAAclnD,EAAKmnD,aACvBtkB,EAAGje,OAAQF,EAASme,EAAGje,OAAOr7C,IAAI,SAAet1B,GAAI,OAAOA,EAAEkD,IAAM,GAC/DwzE,EAAME,YAAcF,EAAMhG,WAAWhzE,OAAS,IAAG+yE,EAAOiG,EAAMhG,YACnE3kB,EAAKmnD,YAAa/oF,EAAIouD,MAAQ7B,EAAOvsD,EAAI6kF,UAAYic,GACrDl/D,EAAKknD,iBAAgC,IAAXxiC,IAAwBtmD,EAAIumD,WAAaD,GACnE1kB,EAAKknD,WAAa9oF,EAAIumD,WAAa3kB,EAAKmnD,WAAW,OAAO/oF,EAE9DsmD,EAAS,CAAA,EAET,IAAI07C,EAAO,CAAA,EACRpgE,EAAKqgE,UAAY5B,EAAIkB,YAAWS,EAAKte,GAASlmC,GAAWF,EAAK2iD,GAAkBI,EAAIkB,YAAYlB,EAAIkB,YAEvG,IAEIxnD,EAAMolD,EAFNxqH,EAAE,EACFyqH,EAAa,CAAA,EAIZ8C,EAAWz9B,EAAGje,OAClB+F,EAAME,WAAay1C,EAAS3uH,OAC5Bg5E,EAAMhG,WAAa,GACnB,IAAI,IAAI3xE,EAAI,EAAGA,GAAKstH,EAAS3uH,SAAUqB,EACtC23E,EAAMhG,WAAW3xE,GAAKstH,EAASttH,GAAGmE,KAIpC,IAAIopH,EAAQV,EAAO,MAAQ,MACvBW,EAAU/B,EAAIC,UAAU,GAAG/5D,YAAY,KACvC87D,GAAchC,EAAIC,UAAU,GAAGtsH,MAAM,EAAGouH,EAAQ,GAAK,SAAW/B,EAAIC,UAAU,GAAGtsH,MAAMouH,EAAQ,GAAK,SAAS3yF,QAAQ,MAAM,IAC3H4tC,GAAeC,EAAK+kD,KAAaA,EAAa,qBAAuBF,EAAQ,SACjF,IAAIG,EAAS92C,GAAW9N,GAAUJ,EAAK+kD,GAAY,GAAOA,EAAW5yF,QAAQ,UAAW,SAEpF4wF,EAAI1gC,UAAY,IAAIpsF,QAAU,IAEjCquD,EAAKq9C,OAAS8E,GAAavmC,GAAWF,EAAK2iD,GAAkBI,EAAI1gC,SAAS,KAAK0gC,EAAI1gC,SAAS,GAAG/9B,KAG5Fy+D,EAAIztB,QAAU,IAAIr/F,QAAU,IAC/BquD,EAAKgxC,OAppWP,SAA0B31F,EAAiB2kD,GAC1C,IAAI5hC,EAAM,GACNklE,GAAO,EAwBX,OAvBAjoF,EAAKwyB,QAAQ4uC,GAAU,SAAmBxoE,GACzC,IAAI4P,EAAY+4D,GAAY3oE,GAC5B,OAAO+oE,GAASn5D,EAAE,KACjB,IAAK,QAGL,IAAK,cACL,IAAK,gBAIL,IAAK,YAGL,IAAK,UAAW,IAAK,WAAY,IAAK,YAAa,IAAK,YAAa,MAJrE,IAAK,UAAWua,EAAIxmB,KAAK,CAACT,KAAM0M,EAAE88G,YAAazyF,GAAIrqB,EAAEqqB,KAAO,MAM5D,IAAK,OAAQo1D,GAAK,EAAM,MACxB,IAAK,SAAUA,GAAK,EAAO,MAE3B,QAAS,IAAIA,GAAQtjC,EAAK+e,IAAK,MAAM,IAAIzrE,MAAM,gBAAkBuQ,EAAE,GAAK,yBAEzE,OAAO5P,CACR,GACOmqB,CACR,CAynWgBwiG,CAAiBhlD,GAAWF,EAAK2iD,GAAkBI,EAAIztB,OAAO,KAAKhxC,IAG/E0gE,IAAQA,EA7KZ,SAA2BA,EAAQh8C,GAClC,IAAIg8C,EAAQ,OAAO,EACnB,IACCA,EAASh8C,EAAOn7C,IAAI,SAAcnS,GAAkC,OAAzBA,EAAE8W,KAAI9W,EAAE8W,GAAK9W,EAAE24F,UAAiB,CAAC34F,EAAEjgB,KAAMupH,EAAO,OAAOtpG,EAAE8W,IAAI+7C,QAVlF5sE,EAUyGqjH,EAAO,OAAOtpG,EAAE8W,IAAI87C,KATjJlC,GAAKoB,GAAGj4C,QAAQ5zB,IAAK,EAAW,QACrBA,GAAKyqE,GAAKmB,GAAW,QACrB5rE,GAAKyqE,GAAKqB,GAAW,SACrB9rE,GAAKyqE,GAAKsB,GAAW,QAC3B/rE,GAAKA,EAAE1L,OAAU0L,EAAI,UAL9B,IAAwBA,CAUqI,EAC5J,CAAE,MAAMyD,GAAK,WAAa,CAC1B,OAAQ4/G,GAA4B,IAAlBA,EAAO/uH,OAAsB+uH,EAAP,IACzC,CAuKqBG,CAAkBH,EAAQ79B,EAAGje,SAGjD,IAAIk8C,EAASllD,GAAWF,EAAI,2BAA0B,GAAO,EAAE,EAC/DqlD,EAAQ,IAAIhuH,EAAI,EAAGA,GAAK43E,EAAME,aAAc93E,EAAG,CAC9C,IAAI0qH,EAAQ,QAWZ,GAVGiD,GAAUA,EAAO3tH,IACnBolE,EAAO,MAASuoD,EAAO3tH,GAAG,GAAI86B,QAAQ,YAAa,IAC/C4tC,GAAeC,EAAKvD,KAAOA,EAAOuoD,EAAO3tH,GAAG,IAC5C0oE,GAAeC,EAAKvD,KAAOA,EAAOsoD,EAAW5yF,QAAQ,aAAa,IAAM6yF,EAAO3tH,GAAG,IACtF0qH,EAAQiD,EAAO3tH,GAAG,IAGlBolE,GADAA,EAAO,uBAAuBplE,EAAE,EAAE+tH,GAAO,IAAMP,GACnC1yF,QAAQ,WAAW,UAEhC0vF,EAAWplD,EAAKtqC,QAAQ,qBAAsB,oBAC3CmyB,GAAuB,MAAfA,EAAK0kB,OAAgB,cAAc1kB,EAAK0kB,QAClD,IAAK,SAAU,GAAG3xE,GAAKitD,EAAK0kB,OAAQ,SAASq8C,EAAQ,MACrD,IAAK,SAAU,GAAGp2C,EAAMhG,WAAW5xE,GAAGkuC,eAAiB+e,EAAK0kB,OAAOzjC,cAAe,SAAS8/E,EAAQ,MACnG,QAAS,GAAGzrH,MAAMi+B,SAAWj+B,MAAMi+B,QAAQysB,EAAK0kB,QAAS,CAExD,IADA,IAAIs8C,GAAU,EACNC,EAAM,EAAGA,GAAOjhE,EAAK0kB,OAAO/yE,SAAUsvH,EACf,iBAApBjhE,EAAK0kB,OAAOu8C,IAAoBjhE,EAAK0kB,OAAOu8C,IAAQluH,IAAGiuH,EAAQ,GAC3C,iBAApBhhE,EAAK0kB,OAAOu8C,IAAoBjhE,EAAK0kB,OAAOu8C,GAAKhgF,eAAiB0pC,EAAMhG,WAAW5xE,GAAGkuC,gBAAe+/E,EAAU,GAE1H,IAAIA,EAAS,SAASD,CACvB,EAEDzD,GAAiB5hD,EAAKvD,EAAMolD,EAAU5yC,EAAMhG,WAAW5xE,GAAIA,EAAGyqH,EAAW94C,EAAQ+4C,EAAOz9D,EAAM6iC,EAAIiK,EAAQC,EAC3G,CAiCA,OA/BA3uE,EAAO,CACN0qF,UAAW2V,EACXnZ,SAAUziB,EACVrW,MAAO7B,EACPs4B,UAAWic,EACXgC,KAAMd,EACNx7C,OAAQF,EACRC,WAAYgG,EAAMhG,WAClBynC,QAAStU,GACTqpB,OAAQp0B,EACRuf,OAAQxf,EACRsa,IAAKzsC,GAAItb,KAEPW,GAAQA,EAAKytD,YACZ/xC,EAAI5P,OACN1tC,EAAI0gB,KAAOj4B,EACXuX,EAAI0tC,MAAQ4P,EAAI5P,QAEhB1tC,EAAI0gB,KAAO,GACX1gB,EAAI0tC,MAAQ,GACZ4P,EAAI/R,UAAUj4B,QAAQ,SAASn0B,EAAG+B,GACjC/B,EAAIA,EAAEswB,QAAQ,kBAAmB,IACjCzP,EAAI0gB,KAAKlnC,KAAK2F,GACd6gB,EAAI0tC,MAAMvuD,GAAKm+D,EAAIhS,UAAUpqD,EAC9B,KAGC0gD,GAAQA,EAAK6sD,UACZ4R,EAAIW,IAAIztH,OAAS,EAAGysB,EAAI0uF,OAASlxC,GAAWF,EAAI2iD,GAAkBI,EAAIW,IAAI,KAAI,GACzEX,EAAIngB,UAvkWD,yCAukWamgB,EAAIngB,SAAS8iB,MAAgBhjG,EAAI0uF,OAASlxC,GAAWF,EAAK,qBAAoB,KAEhGt9C,CACR,CAGA,SAASijG,GAAc7zD,EAAKY,GAC3B,IA/4amCzf,EAC/B2B,EA84aA0P,EAAOoO,GAAS,GAChBx6C,EAAI,WAAYvY,EAAO2sD,GAAI5V,KAAKob,EAAK55C,GACzC,IAEyB,GADzBA,EAAI,yBACJvY,EAAO2sD,GAAI5V,KAAKob,EAAK55C,MAAiBvY,EAAKqxD,QAAS,MAAM,IAAIp5D,MAAM,mCAAqCsgB,GAKhF,GAx5aU+6B,EAo5aUtzC,EAAKqxD,SAn5a9Cpc,EAAI,CAAA,GACNpiB,GAAKygB,EAAKka,WAAW,EAAG,QAC1BvY,EAAE2E,EAAIkwC,GAAoBx2C,EAAM,GAChC2B,EAAEx9B,EAAIqyE,GAAoBx2C,EAAM,GAChC2B,EAAE8D,EAAI+wC,GAAoBx2C,EAAM,GAk5ahC/6B,EAAI,8BACJvY,EAAO2sD,GAAI5V,KAAKob,EAAK55C,MAAiBvY,EAAKqxD,QAAS,UAAUp5D,MAAM,mCAAqCsgB,GACzG,IAAI0tG,EAh4aL,SAA4B3yE,GAC3B,IAAI2B,EAAI,GACR3B,EAAKrzC,GAAK,EAEV,IADA,IAAI+xD,EAAM1e,EAAKka,WAAW,GACpBwE,KAAQ,GAAG/c,EAAE14C,KAAK0tF,GAAwB32C,IAChD,OAAO2B,CACR,CA03aWixE,CAAmBlmH,EAAKqxD,SAClC,GAAkB,IAAf40D,EAAI3vH,QAAwC,IAAxB2vH,EAAI,GAAG/7B,MAAM5zF,QAAsC,IAAtB2vH,EAAI,GAAG/7B,MAAM,GAAG50E,GAA2B,8BAAhB2wG,EAAI,GAAGnqH,MAA8D,qBAAtBmqH,EAAI,GAAG/7B,MAAM,GAAGlmF,EAC7I,MAAM,IAAI/L,MAAM,+BAAiCsgB,GAIzB,GADzBA,EAAI,yDACJvY,EAAO2sD,GAAI5V,KAAKob,EAAK55C,MAAiBvY,EAAKqxD,QAAS,MAAM,IAAIp5D,MAAM,mCAAqCsgB,GACzG,IAAI4tG,EA93aL,SAAmC7yE,GAClC,IAAI2B,EAAsB,GAC1B3B,EAAKrzC,GAAK,EAEV,IADA,IAAI+xD,EAAM1e,EAAKka,WAAW,GACpBwE,KAAQ,GAAG/c,EAAE14C,KAAK+2C,EAAKka,WAAW,EAAG,SAC3C,OAAOvY,CACR,CAw3aYmxE,CAA0BpmH,EAAKqxD,SAC1C,GAAkB,GAAf80D,EAAK7vH,QAA0B,6BAAX6vH,EAAK,GAC3B,MAAM,IAAIluH,MAAM,+BAAiCsgB,GAIzB,GADzBA,EAAI,kEACJvY,EAAO2sD,GAAI5V,KAAKob,EAAK55C,MAAiBvY,EAAKqxD,QAAS,MAAM,IAAIp5D,MAAM,mCAAqCsgB,GAC3F4xE,GAAcnqF,EAAKqxD,QACjC,CAAE,MAAM5rD,GAAI,CAGa,GADzB8S,EAAI,oBACJvY,EAAO2sD,GAAI5V,KAAKob,EAAK55C,MAAiBvY,EAAKqxD,QAAS,MAAM,IAAIp5D,MAAM,mCAAqCsgB,GACzG,IAAI8tG,EAt0aL,SAA8B/yE,GAC7B,IAAIgyC,EAAOwE,GAAoBx2C,GAC/B,OAAOgyC,EAAK0E,OACX,KAAK,EAAM,MAAO,CAAC1E,EAAK0E,MAAOoB,GAAiB93C,IAChD,KAAK,EAAM,MAAO,CAACgyC,EAAK0E,MAAOqB,MAC/B,KAAK,EAAM,MAAO,CAAC/F,EAAK0E,MAAOsB,GAAiBh4C,IAEjD,MAAM,IAAIr7C,MAAM,iDAAmDqtF,EAAK0E,MACzE,CA8zaas8B,CAAqBtmH,EAAKqxD,SAIb,GADzB94C,EAAI,sBACJvY,EAAO2sD,GAAI5V,KAAKob,EAAK55C,MAAiBvY,EAAKqxD,QAAS,MAAM,IAAIp5D,MAAM,mCAAqCsgB,GAIzG,GAAe,GAAZ8tG,EAAM,IAAuC,oBAAlBE,cAA+B,OAAOA,cAAcF,EAAM,GAAIrmH,EAAKqxD,QAAS1M,EAAKynC,UAAY,GAAIznC,GAG/H,GAAe,GAAZ0hE,EAAM,IAAuC,oBAAlBG,cAA+B,OAAOA,cAAcH,EAAM,GAAIrmH,EAAKqxD,QAAS1M,EAAKynC,UAAY,GAAIznC,GAC/H,MAAM,IAAI1sD,MAAM,6BACjB,CAgTA,SAAS0sF,GAAUpsE,EAAc08B,GAChC,IAAIr8C,EAAI,GACR,QAAQq8C,GAAG,CAAA,GAAItwC,MAAQ,UACtB,IAAK,SAGL,IAAK,QAAU,MAAO,CAAC4T,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,GAAIA,EAAE,IAFnE,IAAK,SAAU3f,EAAIkpD,GAAcvpC,EAAExhB,MAAM,EAAE,KAAM,MACjD,IAAK,SAAU6B,EAAI2f,EAAG,MAEtB,QAAS,MAAM,IAAItgB,MAAM,sBAAwBg9C,GAAKA,EAAEtwC,MAAQ,cAEjE,MAAO,CAAC/L,EAAEilD,WAAW,GAAIjlD,EAAEilD,WAAW,GAAIjlD,EAAEilD,WAAW,GAAIjlD,EAAEilD,WAAW,GAAIjlD,EAAEilD,WAAW,GAAIjlD,EAAEilD,WAAW,GAAIjlD,EAAEilD,WAAW,GAAIjlD,EAAEilD,WAAW,GAC7I,CAeA,SAAS4oE,GAAezmH,EAAiBi1C,GACxC,IAAIv9C,EAAI,EACRu5B,EAAM,KAAMv5B,EAAIsI,EAAK1J,eAAe0J,EAAK69C,WAAWnmD,IACnD,KAAK,GAAM,KAAK,GAAM,KAAK,KAAQA,EAAG,MACtC,KAAK,GAAM,OAAOs0G,GAAWhsG,EAAKjJ,MAAMW,GAAGu9C,GAC3C,QAAS,MAAMhkB,EAEhB,OAAOsyD,GAAI/H,YAAYx7E,EAAMi1C,EAC9B,CA4BA,SAASyxE,GAAS1mH,EAAMkb,EAAG+5B,EAAGl4C,GAC7B,OAAGA,GAAOk4C,EAAEtwC,KAAO,SAAiB4+E,GAAI/H,YAAYx7E,EAAMi1C,IACnDsuC,GAAI/H,YAAYtgE,EAAG+5B,EAC3B,CAEA,SAAS0xE,GAAS3mH,EAAkB2kD,GACnC5D,KACA,IAAI9L,EAAI0P,GAAM,CAAA,EACd,GAA0B,oBAAhB/T,aAA+B5wC,aAAgB4wC,YAAa,OAAO+1E,GAAS,IAAI/yE,WAAW5zC,KAAQi1C,EAAIqqB,GAAIrqB,IAAMtwC,KAAO,QAASswC,IAClH,oBAAfrB,YAA8B5zC,aAAgB4zC,aAAeqB,EAAEtwC,OAAMswC,EAAEtwC,KAAuB,oBAATiiH,KAAuB,SAAW,SACjI,IAAc5kH,EAAVkZ,EAAIlb,EAAqBjD,GAAM,EAOnC,GANGk4C,EAAE0kC,aAAc1kC,EAAEsvC,QAAS,EAAMtvC,EAAEk1B,YAAa,GACnDuyB,GAAW,CAAA,EACRznD,EAAE+U,SAAQ0yC,GAAS1yC,OAAS/U,EAAE+U,QAC7B/U,EAAEtwC,OAAMswC,EAAEtwC,KAAQo9C,IAAWC,OAAOiB,SAASjjD,GAAS,SAAW,UACxD,QAAVi1C,EAAEtwC,OAAkBswC,EAAEtwC,KAAOo9C,GAAU,SAAW,SAAU7mC,EA3moBhE,SAAqB4hD,GAEpB,GAAmB,oBAAT8pD,KAAsB,OAAOA,KAAKzpD,aAAaL,GAEzD,GAAgB,oBAAN/nB,GAAqC,oBAAT8xE,MAA0C,oBAAXC,OAAwB,IAE5F,IAAIC,EAASF,KAAK/pD,GAAOiqD,EAAOC,KAAK,KAAMD,EAAOxzE,SAAW,SAC7D,IAAIvzC,EAAO+mH,EAAO7pD,OAClB,OAD0B6pD,EAAOE,QAC1BjnH,CACR,CAAE,MAAMyF,GAAK,IAAIA,EAAE0+B,UAAY1+B,EAAE0+B,QAAQ7R,MAAM,YAAa,MAAM7sB,CAAG,CACrE,MAAM,IAAIxN,MAAM,sBAAwB6kE,EACzC,CAgmoBoEoqD,CAAYlnH,GAAgC,oBAAf4zC,YAA+BmO,KAAS9M,EAAEtwC,KAAO,UACpI,UAAVswC,EAAEtwC,OAAoB5H,GAAM,EAAMk4C,EAAEtwC,KAAO,SAAUswC,EAAE+lC,SAAW,MAAO9/D,EApB7E,SAAiBlb,GAChB,OAAQA,EAAKsyB,MAAM,gBAAyB+sC,GAAUr/D,GAAjBA,CACtC,CAkBiFmnH,CAAQnnH,IAC3E,SAAVi1C,EAAEtwC,MAAyC,oBAAfivC,YAA8B5zC,aAAgB4zC,YAAqC,oBAAhBhD,YAA6B,CAE9H,IAAIw2E,EAAG,IAAIx2E,YAAY,GAAIy2E,EAAG,IAAIzzE,WAAWwzE,GAE7C,GAFkDC,EAAGC,IAAI,OAErDD,EAAGC,IAAgC,OAA1BryE,EAAEqqB,GAAIrqB,IAAMtwC,KAAK,QAAgBgiH,GAAS7jE,GAAK5nC,GAAI+5B,EACjE,CACA,QAAQjzC,EAAI2iF,GAAUzpE,EAAG+5B,IAAI,IAC5B,KAAK,IAAM,GAAY,MAATjzC,EAAE,IAAwB,KAATA,EAAE,IAAwB,MAATA,EAAE,IAAwB,MAATA,EAAE,IAAwB,MAATA,EAAE,IAAwB,KAATA,EAAE,IAAwB,MAATA,EAAE,GAAa,OAzErI,SAAkBmwD,EAAsBxN,GACvC,OAAGgI,GAAI5V,KAAKob,EAAK,oBAA4B6zD,GAAc7zD,EAAKxN,GACzD0sD,GAAal/C,EAAKxN,EAC1B,CAsE4I4iE,CAAS56D,GAAIuQ,KAAKhiD,EAAG+5B,GAAIA,GAAI,MACvK,KAAK,EAAM,GAAGjzC,EAAE,IAAM,EAAM,OAAOqvG,GAAan2F,EAAG+5B,GAAI,MACvD,KAAK,GAAM,OAAO+2D,GAAW9wF,EAAG+5B,GAChC,KAAK,GACJ,GAAY,KAATjzC,EAAE,IAAwB,KAATA,EAAE,IAAwB,IAATA,EAAE,GAAa,MAAM,IAAI/J,MAAM,wCACpE,GAAY,KAAT+J,EAAE,GAAa,OAz7drB,SAAoBkZ,EAAGypC,GACtB,IAAI1P,EAAI0P,GAAQ,CAAA,EAAI6iE,IAAYvyE,EAAEyuB,IAAKzuB,EAAEyuB,KAAM,EAC/C,IACC,IAAI3gD,EAAM45D,GAAKnB,YAAYtgE,EAAG+5B,GAE9B,OADAA,EAAEyuB,IAAM8jD,EACDzkG,CACR,CAAE,MAAMtd,GAEP,GADAwvC,EAAEyuB,IAAM8jD,GACJ/hH,EAAE0+B,QAAQ7R,MAAM,uBAAyBk1F,EAAS,MAAM/hH,EAC5D,OAAO89E,GAAI/H,YAAYtgE,EAAGypC,EAC3B,CACD,CA86d4B8iE,CAAWvsG,EAAG+5B,GACvC,MACD,KAAK,GAAM,GAAY,KAATjzC,EAAE,IAAwB,KAATA,EAAE,IAAwB,KAATA,EAAE,GAAa,OAAOwgF,GAAIhH,YAAYtgE,EAAG+5B,GAAI,MAC7F,KAAK,GAAM,OAAiB,KAATjzC,EAAE,IAAeA,EAAE,GAAK,GAAQA,EAAE,GAAK,EA5E5D,SAAkBhC,EAAkB2kD,GACnC,IAASzpC,EAAIlb,EACTi1C,EAAI0P,GAAM,CAAA,EAGd,OAFI1P,EAAEtwC,OAAMswC,EAAEtwC,KAAQo9C,IAAWC,OAAOiB,SAASjjD,GAAS,SAAW,UAE9DiuD,GADD8S,GAAS7lD,EAAG+5B,GACIA,EACvB,CAsEoEyyE,CAASxsG,EAAG+5B,GAAKyxE,GAAS1mH,EAAMkb,EAAG+5B,EAAGl4C,GACxG,KAAK,IAAM,OAAgB,KAATiF,EAAE,GAAcgqG,GAAW9wF,EAAG+5B,GAAKyxE,GAAS1mH,EAAMkb,EAAG+5B,EAAGl4C,GAC1E,KAAK,IACJ,GAAY,MAATiF,EAAE,GAAe,OA/CvB,SAAoBhC,EAAkBi1C,GACrC,IAAI/5B,EAAIlb,EAIR,MAHa,UAAVi1C,EAAEtwC,OAAkBuW,EAAI4mC,GAAc5mC,IACzCA,EAAIimC,GAASyb,MAAMlpB,OAAO,KAAMx4B,EAAEnkB,MAAM,GAAI,OAC5Ck+C,EAAEtwC,KAAO,SACF8hH,GAAevrG,EAAG+5B,EAC1B,CAyC8B0yE,CAAWzsG,EAAG+5B,GACpC,GAAY,IAATjzC,EAAE,IAAwB,IAATA,EAAE,IAAwB,IAATA,EAAE,GAAa,OAAO4iF,GAAIpJ,YAAYtgE,EAAG+5B,GACnF,MACD,KAAK,EACJ,GAAY,IAATjzC,EAAE,GAAa,CACjB,GAAGA,EAAE,IAAM,GAAiB,IAATA,EAAE,GAAa,OAAO4iF,GAAIpJ,YAAYtgE,EAAG+5B,GAC5D,GAAY,IAATjzC,EAAE,KAAyB,IAATA,EAAE,IAAwB,IAATA,EAAE,IAAc,OAAO4iF,GAAIpJ,YAAYtgE,EAAG+5B,EACjF,CACA,MACD,KAAK,EAAM,KAAK,IAAM,KAAK,IAAM,KAAK,IAAM,OAAOmlC,GAAIoB,YAAYtgE,EAAG+5B,GACtE,SAAW,GAAY,KAATjzC,EAAE,IAAwB,MAATA,EAAE,IAAwB,MAATA,EAAE,GAAa,OAAOqsF,GAAI7S,YAAYtgE,EAAG+5B,GAAI,MAC7F,KAAK,GAAM,KAAK,GAAM,QAAW,OAxEnC,SAA4Bj1C,EAAkBi1C,GAC7C,IAAIl4C,EAAM,GAAIu1E,EAAQqS,GAAU3kF,EAAMi1C,GACtC,OAAOA,EAAEtwC,MACR,IAAK,SAAU5H,EAAM+kD,GAAc9hD,GAAO,MAC1C,IAAK,SAAUjD,EAAMiD,EAAM,MAC3B,IAAK,SAAUjD,EAAMiD,EAAKrK,SAAS,UAAW,MAC9C,IAAK,QAASoH,EAAMmiE,GAAOl/D,GAAO,MAClC,QAAS,MAAM,IAAI/H,MAAM,qBAAuBg9C,EAAEtwC,MAInD,OAFe,KAAZ2tE,EAAM,IAA0B,KAAZA,EAAM,IAA0B,KAAZA,EAAM,KAAYv1E,EAAM+lE,GAAS/lE,IAC5Ek4C,EAAEtwC,KAAO,SACF8hH,GAAe1pH,EAAKk4C,EAC5B,CA4D0C2yE,CAAmB1sG,EAAG+5B,GAC9D,KAAK,IAAM,GAAY,KAATjzC,EAAE,IAAwB,KAATA,EAAE,IAAwB,KAATA,EAAE,GAAa,MAAM,IAAI/J,MAAM,uCAEhF,OAAGkiF,GAAuBvkD,QAAQ5zB,EAAE,QAAYA,EAAE,IAAM,IAAMA,EAAE,IAAM,GAAWo4E,GAAIoB,YAAYtgE,EAAG+5B,GAC7FyxE,GAAS1mH,EAAMkb,EAAG+5B,EAAGl4C,EAC7B,CA8MA,SAAS8qH,GAAcz+C,EAAqBpgE,EAAa4wC,EAAc7wC,EAAwB2yC,EAAmB0uC,EAAoB1gB,EAAmBz0B,GACxJ,IAAIuT,EAAK4f,GAAWxuB,GAChBkuE,EAAS7yE,EAAE6yE,OAAQl2D,EAAM3c,EAAE2c,MAAQh8D,OAAOC,UAAUwtC,eAAeptC,KAAKg/C,EAAG,OAC3E8yE,GAAU,EACV/oH,EAA0B,IAAX08C,EAAgB,GAAK,CAAA,EACxC,GAAc,IAAXA,EACF,GAAG9lD,OAAOoF,eAAgB,IAAMpF,OAAOoF,eAAegE,EAAK,aAAc,CAACjJ,MAAM6jD,EAAGouE,YAAW,GAAS,CAAE,MAAMviH,GAAKzG,EAAIipH,WAAaruE,CAAG,MACnI56C,EAAIipH,WAAaruE,EAEvB,IAAI8vB,GAASN,EAAMxvB,GAAI,IAAK,IAAI91B,EAAI9a,EAAE3D,EAAE4D,EAAG6a,GAAK9a,EAAEvD,EAAEwD,IAAK6a,EAAG,CAC3D,IAAI4E,EAAMghD,EAAQN,EAAMxvB,GAAG91B,GAAKslD,EAAMrgE,EAAK+a,GAAK0kC,GAChD,QAAWjyD,IAARmyB,QAA+BnyB,IAAVmyB,EAAIpT,EAA5B,CAKA,IAAItR,EAAI0kB,EAAI1kB,EACZ,OAAO0kB,EAAIpT,GACV,IAAK,IAAK,GAAQ,MAALtR,EAAW,MAAO,SAC/B,IAAK,IAAKA,EAAU,GAALA,EAAS,UAAO,EAAS,MACxC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,MACxC,QAAS,MAAM,IAAI/L,MAAM,qBAAuBywB,EAAIpT,GAErD,GAAa,MAAV80E,EAAItmE,GAAY,CAClB,GAAQ,MAAL9f,EACF,GAAY,KAAT0kB,EAAIpT,GAAkB,OAANtR,EAAYhF,EAAIorF,EAAItmE,IAAM,UACxC,QAAcvtB,IAAXuxH,EAAsB9oH,EAAIorF,EAAItmE,IAAMgkG,MACvC,KAAGl2D,GAAa,OAAN5tD,EACV,SADsBhF,EAAIorF,EAAItmE,IAAM,IACpC,MAEL9kB,EAAIorF,EAAItmE,IAAM8tC,IAAkB,MAAVlpC,EAAIpT,GAAwB,MAAVoT,EAAIpT,IAA8B,IAAjB2/B,EAAEizE,YAAyBlkH,EAAIilE,GAAYvgD,EAAI1kB,EAAEixC,GAEnG,MAALjxC,IAAW+jH,GAAU,EACzB,CAlBA,KAJA,CACC,QAAcxxH,IAAXuxH,EAAsB,SACZ,MAAV19B,EAAItmE,KAAc9kB,EAAIorF,EAAItmE,IAAMgkG,EAEpC,CAmBD,CACA,MAAO,CAAE9oH,IAAKA,EAAK+oH,QAASA,EAC7B,CAGA,SAASlsC,GAAczS,EAAqBzkB,GAC3C,GAAY,MAATykB,GAAkC,MAAjBA,EAAM,QAAiB,MAAO,GAClD,IAAI1gD,EAAM,CAACpT,EAAE,IAAItR,EAAE,GAAI03C,EAAS,EAAGuW,EAAS,EAAGm4B,EAAqB,GAAIpmF,EAAE,EAAG2mD,EAAG,GAC5E3hD,EAAI,CAAC3D,EAAE,CAAC2D,EAAE,EAAEC,EAAE,GAAGxD,EAAE,CAACuD,EAAE,EAAEC,EAAE,IAC1BgsC,EAAI0P,GAAQ,CAAA,EACZjqC,EAAmB,MAAXu6B,EAAEv6B,MAAgBu6B,EAAEv6B,MAAQ0uD,EAAM,QAK9C,OAJgB,IAAbn0B,EAAEyG,OAAcA,EAAS,EACP,MAAbzG,EAAEyG,OAAgBA,EAAS,EAC3BzhD,MAAMi+B,QAAQ+c,EAAEyG,QAASA,EAAS,EACtB,MAAZzG,EAAEyG,SAAgBA,EAAS,UACrBhhC,GACb,IAAK,SAAU1R,EAAI6/D,GAAkBnuD,GAAQ,MAC7C,IAAK,UAAU1R,EAAI6/D,GAAkBO,EAAM,UAAY/jE,EAAE2D,EAAI0R,EAAO,MACpE,QAAS1R,EAAI0R,EAEXghC,EAAS,IAAGuW,EAAS,GACxB,IAAIzJ,EAAK4f,GAAWp/D,EAAE3D,EAAE2D,GACpBD,EAAyB,GACzBga,EAAqB,GACrBolG,EAAO,EAAGrqG,EAAU,EACpB4rD,EAAQzvE,MAAMi+B,QAAQkxC,GACtBxvB,EAAI5wC,EAAE3D,EAAE2D,EAAG8a,EAAI,EACfskG,EAAa,CAAA,EACd1+C,IAAUN,EAAMxvB,KAAIwvB,EAAMxvB,GAAK,IAClC,IAAI4mC,EAA6BvrC,EAAEozE,YAAcj/C,EAAM,UAAY,GAC/DmX,EAA6BtrC,EAAEozE,YAAcj/C,EAAM,UAAY,GACnE,IAAItlD,EAAI9a,EAAE3D,EAAE4D,EAAG6a,GAAK9a,EAAEvD,EAAEwD,IAAK6a,EAC5B,KAAK08D,EAAQ18D,IAAI,CAAA,GAAIw9D,OAGrB,OAFAv4E,EAAK+a,GAAKukD,GAAWvkD,GACrB4E,EAAMghD,EAAQN,EAAMxvB,GAAG91B,GAAKslD,EAAMrgE,EAAK+a,GAAK0kC,GACrC9M,GACN,KAAK,EAAG0uC,EAAItmE,GAAKA,EAAI9a,EAAE3D,EAAE4D,EAAG,MAC5B,KAAK,EAAGmhF,EAAItmE,GAAK/a,EAAK+a,GAAI,MAC1B,KAAK,EAAGsmE,EAAItmE,GAAKmxB,EAAEyG,OAAO53B,EAAI9a,EAAE3D,EAAE4D,GAAI,MACtC,QAIC,GAHU,MAAPyf,IAAaA,EAAM,CAAC3M,EAAG,UAAWzG,EAAG,MACxCq1C,EAAK3mD,EAAIilE,GAAYvgD,EAAK,KAAMusB,GAChCn3B,EAAUsqG,EAAWpkH,IAAM,EAEtB,CACJ,GAAK2mD,EAAK3mD,EAAI,IAAO8Z,UAAoBsqG,EAAWz9D,IAAMy9D,EAAWpkH,GAAK8Z,EAC1EsqG,EAAWz9D,GAAM,CAClB,MAJay9D,EAAWpkH,GAAK,EAK7BomF,EAAItmE,GAAK6mC,EAGZ,IAAK/Q,EAAI5wC,EAAE3D,EAAE2D,EAAIipD,EAAQrY,GAAK5wC,EAAEvD,EAAEuD,IAAK4wC,EACtC,KAAK2mC,EAAQ3mC,IAAI,CAAA,GAAI0nC,OAArB,CACA,IAAItiF,EAAM6oH,GAAcz+C,EAAOpgE,EAAG4wC,EAAG7wC,EAAM2yC,EAAQ0uC,EAAK1gB,EAAOz0B,KAC3C,IAAhBj2C,EAAI+oH,UAAkC,IAAXrsE,GAA+B,IAAhBzG,EAAEqzE,UAAwBrzE,EAAEqzE,cAAYvlG,EAAIolG,KAAUnpH,EAAIA,IAF3E,CAK9B,OADA+jB,EAAIzsB,OAAS6xH,EACNplG,CACR,CAEA,IAAIwlG,GAAO,KACX,SAASC,GAAap/C,EAAqBpgE,EAAa4wC,EAAc7wC,EAAwB6jD,EAAeg8B,EAAe9E,EAAe7uC,GAG1I,IAFA,IAAI8yE,GAAU,EACV/oH,EAAwB,GAAIypH,EAAM,GAAIjgE,EAAK4f,GAAWxuB,GAClD91B,EAAI9a,EAAE3D,EAAE4D,EAAG6a,GAAK9a,EAAEvD,EAAEwD,IAAK6a,EAChC,GAAK/a,EAAK+a,GAAV,CACA,IAAI4E,EAAMusB,EAAEy0B,OAASN,EAAMxvB,IAAI,IAAI91B,GAAIslD,EAAMrgE,EAAK+a,GAAK0kC,GACvD,GAAU,MAAP9/B,EAAa+/F,EAAM,QACjB,GAAY,MAAT//F,EAAI1kB,EAAW,CACtB+jH,GAAU,EACVU,EAAM,IAAIxzE,EAAEizE,YAAuB,KAATx/F,EAAIpT,EAAWoT,EAAI1kB,EAAIilE,GAAYvgD,EAAK,KAAMusB,IACxE,IAAI,IAAIv9C,EAAI,EAAGgwD,EAAK,EAAGhwD,IAAM+wH,EAAInyH,SAAUoB,EAAG,IAAIgwD,EAAK+gE,EAAI5qE,WAAWnmD,MAAQk1D,GAAMlF,IAAOkhC,GAAa,KAAPlhC,GAAazS,EAAEyzE,YAAa,CAACD,EAAM,IAAOA,EAAIj2F,QAAQ+1F,GAAM,MAAQ,IAAM,KAAO,CACxK,MAAPE,IAAaA,EAAM,OACvB,MAAmB,MAAT//F,EAAInQ,GAAcmQ,EAAIoR,EAGzB2uF,EAAM,IAFZV,GAAU,GACVU,EAAM,IAAM//F,EAAInQ,GAAUqd,QAAQ,MAAQ,IAAG6yF,EAAM,IAAMA,EAAIj2F,QAAQ+1F,GAAM,MAAQ,MAGpFvpH,EAAIzC,KAAKksH,EAbK,CAef,OAAmB,IAAhBxzE,EAAEqzE,WAAuBP,EAAgB,KACrC/oH,EAAIvC,KAAKqnF,EACjB,CAEA,SAAS6kC,GAAav/C,EAAqBzkB,GAC1C,IAAI5hC,EAAwB,GACxBkyB,EAAY,MAAR0P,EAAe,GAAKA,EAC5B,GAAY,MAATykB,GAAkC,MAAjBA,EAAM,QAAiB,MAAO,GAClD,IAAIpgE,EAAI6/D,GAAkBO,EAAM,SAC5B0a,OAAcvtF,IAAT0+C,EAAE6uC,GAAmB7uC,EAAE6uC,GAAK,IAAKl3B,EAAKk3B,EAAGjmC,WAAW,GACzDmkC,OAAczrF,IAAT0+C,EAAE+sC,GAAmB/sC,EAAE+sC,GAAK,KAAM4G,EAAK5G,EAAGnkC,WAAW,GAC1D+qE,EAAW,IAAIniF,QAAY,KAAJq9C,EAAU,MAAQA,GAAI,MAC7C9kF,EAAM,GAAI+J,EAAyB,GACvCksC,EAAEy0B,MAAQzvE,MAAMi+B,QAAQkxC,GAGxB,IAFA,IAAIoX,EAA6BvrC,EAAEozE,YAAcj/C,EAAM,UAAY,GAC/DmX,EAA6BtrC,EAAEozE,YAAcj/C,EAAM,UAAY,GAC3DtlD,EAAI9a,EAAE3D,EAAE4D,EAAG6a,GAAK9a,EAAEvD,EAAEwD,IAAK6a,GAAU08D,EAAQ18D,IAAI,CAAA,GAAIw9D,SAASv4E,EAAK+a,GAAKukD,GAAWvkD,IAEzF,IADA,IAAI/H,EAAI,EACA69B,EAAI5wC,EAAE3D,EAAE2D,EAAG4wC,GAAK5wC,EAAEvD,EAAEuD,IAAK4wC,GAC3B2mC,EAAQ3mC,IAAI,CAAA,GAAI0nC,QAEX,OADVtiF,EAAMwpH,GAAap/C,EAAOpgE,EAAG4wC,EAAG7wC,EAAM6jD,EAAIg8B,EAAI9E,EAAI7uC,MAE/CA,EAAE4zE,QAAO7pH,EAAMA,EAAIwzB,QAAQo2F,EAAS,MACpC5pH,IAAwB,IAAhBi2C,EAAEqzE,YAAsBvlG,EAAIxmB,MAAMwf,IAAMimE,EAAK,IAAMhjF,IAG/D,cADOi2C,EAAEy0B,MACF3mD,EAAItmB,KAAK,GACjB,CA4CA,SAASqsH,GAAer/C,EAAoBs/C,EAAmBpkE,GAC9D,IAWIgjB,EAXA1yB,EAAI0P,GAAQ,CAAA,EACZsN,IAAWhd,EAAE+zE,WACbr/C,EAAmBF,GAAQ,CAAA,EAC3BG,EAAK,EAAGC,EAAK,EACjB,GAAGF,GAAkB,MAAZ10B,EAAEiJ,OACV,GAAsB,iBAAZjJ,EAAEiJ,OAAoB0rB,EAAK30B,EAAEiJ,WAClC,CACJ,IAAI4rB,EAA6C,iBAAZ70B,EAAEiJ,OAAqBwqB,GAAYzzB,EAAEiJ,QAAUjJ,EAAEiJ,OACtF0rB,EAAKE,EAAQ9gE,EAAG6gE,EAAKC,EAAQ7gE,CAC9B,CAGD,IAAIyR,EAAmB,CAACrV,EAAG,CAAC4D,EAAE,EAAGD,EAAE,GAAIvD,EAAG,CAACwD,EAAE4gE,EAAI7gE,EAAE4gE,EAAKm/C,EAAGzyH,OAAS,EAAI27D,IACxE,GAAG0X,EAAG,QAAS,CACd,IAAII,EAASlB,GAAkBc,EAAG,SAClCjvD,EAAMjV,EAAEwD,EAAIpR,KAAK6C,IAAIggB,EAAMjV,EAAEwD,EAAG8gE,EAAOtkE,EAAEwD,GACzCyR,EAAMjV,EAAEuD,EAAInR,KAAK6C,IAAIggB,EAAMjV,EAAEuD,EAAG+gE,EAAOtkE,EAAEuD,OACtC4gE,IAAYA,EAAKG,EAAOtkE,EAAEuD,EAAI,EAAG0R,EAAMjV,EAAEuD,EAAI4gE,EAAKm/C,EAAGzyH,OAAS,EAAI27D,EACtE,SACI2X,IAAYA,EAAK,EAAGlvD,EAAMjV,EAAEuD,EAAI+/G,EAAGzyH,OAAS,EAAI27D,GAEpD,IAAIm4B,EAAwBn1C,EAAEyG,QAAU,GAAI53B,EAAI,EAEhDilG,EAAG1yF,QAAQ,SAAU4yF,EAAIrvE,GACxBnW,GAAKwlF,GAAI5yF,QAAQ,SAAS90B,IACA,IAArBuiB,EAAEsmE,EAAIx0D,QAAQr0B,MAAW6oF,EAAItmE,EAAEsmE,EAAI9zF,QAAUiL,GACjD,IAAIyC,EAAIilH,EAAG1nH,GACP+T,EAAI,IACJiH,EAAI,GACJ+8D,EAAMrR,GAAY,CAACh/D,EAAE4gE,EAAK/lD,EAAE9a,EAAE4gE,EAAKhwB,EAAIqY,IAC3C0V,EAAOuhD,GAAiBv/C,EAAI2P,IACzBt1E,GAAkB,iBAANA,GAAoBA,aAAas+B,MAGhC,iBAALt+B,EAAesR,EAAI,IACT,kBAALtR,EAAgBsR,EAAI,IACf,iBAALtR,EAAesR,EAAI,IAC1BtR,aAAas+B,MACpBhtB,EAAI,IACA2/B,EAAEm1B,YAAa90D,EAAI,IAAKtR,EAAIq6D,GAAQr6D,IACxCuY,EAAK04B,EAAE+U,QAAUhG,GAAU,KAEd,OAANhgD,GAAcixC,EAAEi1B,YAAa50D,EAAI,IAAKtR,EAAI,GAC9C2jE,GAEHA,EAAKryD,EAAIA,EAAGqyD,EAAK3jE,EAAIA,SACd2jE,EAAK5rD,SAAU4rD,EAAK/tB,EACxBr9B,IAAGorD,EAAKprD,EAAIA,IAJNotD,EAAG2P,GAAO3R,EAAQ,CAACryD,EAAEA,EAAGtR,EAAEA,GAMjCuY,IAAGorD,EAAKprD,EAAIA,IAjBfotD,EAAG2P,GAAOt1E,CAmBZ,EACD,GACA0W,EAAMjV,EAAEwD,EAAIpR,KAAK6C,IAAIggB,EAAMjV,EAAEwD,EAAG4gE,EAAKugB,EAAI9zF,OAAS,GAClD,IAAI0zE,EAAM5B,GAAWwB,GACrB,GAAG3X,EAAQ,IAAInuC,EAAI,EAAGA,EAAIsmE,EAAI9zF,SAAUwtB,EAAG6lD,EAAGtB,GAAWvkD,EAAI+lD,GAAMG,GAAO,CAAC10D,EAAE,IAAKtR,EAAEomF,EAAItmE,IAExF,OADA6lD,EAAG,QAAUf,GAAaluD,GACnBivD,CACR,CAIA,SAASu/C,GAAiBv/C,EAAkB/vB,EAAG91B,GAE9C,GAAe,iBAAL81B,EAAe,CAExB,GAAG3/C,MAAMi+B,QAAQyxC,GAAK,CACrB,IAAIw/C,EAAKzgD,GAAY9uB,GAErB,OADI+vB,EAAGw/C,EAAGngH,KAAI2gE,EAAGw/C,EAAGngH,GAAK,IAClB2gE,EAAGw/C,EAAGngH,GAAGmgH,EAAGlgH,KAAO0gE,EAAGw/C,EAAGngH,GAAGmgH,EAAGlgH,GAAK,CAACqM,EAAE,KAC/C,CACA,OAAOq0D,EAAG/vB,KAAO+vB,EAAG/vB,GAAK,CAACtkC,EAAE,KAC7B,CAEA,OAAgC4zG,GAAiBv/C,EAAI1B,GAAtC,iBAALruB,EAAuDA,EAEzB,CAAC5wC,EAAE4wC,EAAE3wC,EAAE6a,GAAG,IACnD,CAeA,SAASslG,KACR,MAAO,CAAE9/C,WAAY,GAAIC,OAAQ,GAClC,CAGA,SAAS2/B,GAAkB1hB,EAAiB7d,EAAkB7tE,EAAkButH,GAC/E,IAAI3xH,EAAI,EACR,IAAIoE,EAAM,KAAMpE,GAAK,WAAkC8vF,EAAGle,WAAW1zC,QAAQ95B,EAAO,QAAUpE,KAA/DA,EAAGoE,OAAOvF,GACzC,IAAIuF,GAAQ0rF,EAAGle,WAAWhzE,QAAU,MAAQ,MAAM,IAAI2B,MAAM,uBAC5D,GAAGoxH,GAAQ7hC,EAAGle,WAAW1zC,QAAQ95B,IAAS,EAAG,CAC5C,IAAIiG,EAAIjG,EAAKw2B,MAAM,gBACnB56B,EAAIqK,IAAMA,EAAE,IAAM,EAClB,IAAImsD,EAAOnsD,GAAKA,EAAE,IAAMjG,EACxB,MAAMpE,EAAGA,GAAK,QAA0D,GAA1C8vF,EAAGle,WAAW1zC,QAAQ95B,EAAOoyD,EAAOx2D,KAA1CA,GACzB,CAEA,GA1nPD,SAAuBsK,GACtB,GAAGA,EAAE1L,OAAS,GAA6B,MAAM,IAAI2B,MAAM,sCAE3DsrG,GAASltE,QAAQ,SAASptB,GACzB,OAAGjH,EAAE4zB,QAAQ3sB,GACH,MAAM,IAAIhR,MAAM,2CAE3B,EAED,CAgnPCqxH,CAAcxtH,GACX0rF,EAAGle,WAAW1zC,QAAQ95B,IAAS,EAAG,MAAM,IAAI7D,MAAM,wBAA0B6D,EAAO,qBAItF,OAFA0rF,EAAGle,WAAW/sE,KAAKT,GACnB0rF,EAAGje,OAAOztE,GAAQ6tE,EACX7tE,CACR,CA0BA,SAASytH,GAAmB5hD,EAAexvE,EAAmBynG,GAO7D,OANIznG,GAGHwvE,EAAK1nE,EAAK,CAAE2uE,OAAQz2E,GACjBynG,IAASj4B,EAAK1nE,EAAE4/F,QAAUD,WAHtBj4B,EAAK1nE,EAKN0nE,CACR,CA0BA,IAAI/K,GAAgB,CACnByL,WAAYA,GACZD,WAAYA,GACZH,YAAaA,GACbW,aAAcA,GACdJ,WAAYA,GACZF,WAAYA,GACZkhD,WAjxnBD,SAAoBp2D,GAAqC,OAAOA,EAAK5gC,QAAQ,sBAAsB,SAASod,MAAM,IAAM,EAkxnBvH84B,YAAaA,GACbC,aAAcA,GACdM,YAAaA,GACbO,cAAeA,GACfs/C,eAAgBA,GAChB5O,cAAeA,GACf5vC,aAAcA,GACdm/C,cAjID,SAAuBV,EAAmBpkE,GAAsB,OAAOmkE,GAAe,KAAMC,EAAIpkE,EAAO,EAkItG+kE,eAAgB7O,GAChB8O,cAvvGD,SAAuB5oG,EAAuB4jC,GAC7C,OAAOwkB,GAAkB0xC,GAAgB95F,EAAO4jC,GAAOA,EACxD,EAsvGCgkE,aAAcA,GACdiB,aA3OD,SAAsBxgD,EAAqBzkB,GAGkB,OAFxDA,IAAMA,EAAO,IAAIA,EAAKm/B,GAAK,KAAMn/B,EAAKq9B,GAAK,KACvC2mC,GAAav/C,EAAOzkB,EAI7B,EAsOCk3B,cAAeA,GACfguC,cAh2GD,SAAuBlgD,EAAkBhlB,GACxC,IAAI1P,EAAI0P,GAAQ,CAAA,EACZjJ,EAAqB,MAAZzG,EAAEyG,OAAiBzG,EAAEyG,OAnBlB,sFAoBZqhD,EAAqB,MAAZ9nD,EAAE8nD,OAAiB9nD,EAAE8nD,OAnBpB,iBAoBVh6E,EAAwB,CAAC24B,GACzB1yC,EAAI2/D,GAAagB,EAAG,SACxB10B,EAAEy0B,MAAQzvE,MAAMi+B,QAAQyxC,GACxB5mD,EAAIxmB,KAZL,SAA4BotE,EAAkB/vB,EAAa3E,GAE1D,MAD4B,GACjBx4C,KAAK,IAAM,UAAYw4C,GAAKA,EAAEpiB,GAAK,QAAUoiB,EAAEpiB,GAAK,IAAM,IAAM,GAC5E,CASUi3F,CAAmBngD,EAAI3gE,EAAGisC,IACnC,IAAI,IAAI2E,EAAI5wC,EAAE3D,EAAE2D,EAAG4wC,GAAK5wC,EAAEvD,EAAEuD,IAAK4wC,EAAG72B,EAAIxmB,KAAKy9G,GAAcrwC,EAAI3gE,EAAG4wC,EAAG3E,IAErE,OADAlyB,EAAIxmB,KAAK,WAAawgG,GACfh6E,EAAItmB,KAAK,GACjB,EAs1GCstH,kBAtOD,SAA2B3gD,GAC1B,IAAYxwE,EAAR4P,EAAI,GAAOkgB,EAAI,GACnB,GAAY,MAAT0gD,GAAkC,MAAjBA,EAAM,QAAiB,MAAO,GAClD,IAAgFtlD,EAA5E9a,EAAI6/D,GAAkBO,EAAM,SAAU5gB,EAAK,GAAIz/C,EAAyB,GACxEihH,EAAyB,GACzBtgD,EAAQzvE,MAAMi+B,QAAQkxC,GAC1B,IAAItlD,EAAI9a,EAAE3D,EAAE4D,EAAG6a,GAAK9a,EAAEvD,EAAEwD,IAAK6a,EAAG/a,EAAK+a,GAAKukD,GAAWvkD,GACrD,IAAI,IAAI81B,EAAI5wC,EAAE3D,EAAE2D,EAAG4wC,GAAK5wC,EAAEvD,EAAEuD,IAAK4wC,EAEhC,IADA4O,EAAK4f,GAAWxuB,GACZ91B,EAAI9a,EAAE3D,EAAE4D,EAAG6a,GAAK9a,EAAEvD,EAAEwD,IAAK6a,EAI5B,GAHAtb,EAAIO,EAAK+a,GAAK0kC,EAEd9/B,EAAM,QACGnyB,KAFTqC,EAAI8wE,GAASN,EAAMxvB,IAAI,IAAI91B,GAAKslD,EAAM5gE,IAEtC,CACK,GAAU,MAAP5P,EAAEkhC,EAAW,CAEpB,GADAtxB,EAAI5P,EAAEkhC,GACFlhC,EAAE2f,EAAG,SACTmQ,EAAM9vB,EAAE2f,GACa,GAAlB/P,EAAEotB,QAAQ,OAAYptB,EAAIA,EAAI,IAAMA,EACxC,CACA,GAAU,MAAP5P,EAAE2f,EAAWmQ,EAAM9vB,EAAE2f,MACnB,IAAU,KAAP3f,EAAE0c,EAAU,SACf,GAAU,KAAP1c,EAAE0c,GAAmB,MAAP1c,EAAEoL,EAAW0kB,EAAM,GAAK9vB,EAAEoL,OAC3C,GAAU,KAAPpL,EAAE0c,EAAUoT,EAAM9vB,EAAEoL,EAAI,OAAS,aACpC,QAAWzN,IAARqC,EAAEmjB,EAAiB2M,EAAM,IAAM9vB,EAAEmjB,MACpC,SAAWxlB,IAARqC,EAAEoL,EAAiB,SACP0kB,EAAL,KAAP9vB,EAAE0c,EAAgB,IAAM1c,EAAEoL,EACvB,GAAGpL,EAAEoL,CAAC,EACjBgmH,EAAKA,EAAK1zH,QAAUkS,EAAI,IAAMkgB,CAT9B,CAYF,OAAOshG,CACR,EAuMCC,0BAA2BpuC,GAC3BquC,eAAgBhB,GAChBE,SAAUA,GACVlgB,kBAAmBA,GACnBihB,0BApFD,SAAmC3iC,EAAiB4iC,EAAsBC,GACrE7iC,EAAGyiB,WAAUziB,EAAGyiB,SAAW,CAAA,GAC3BziB,EAAGyiB,SAAS1gC,SAAQie,EAAGyiB,SAAS1gC,OAAS,IAE7C,IAAItlE,EAxCL,SAAsBujF,EAAiB4iC,GACtC,GAAgB,iBAANA,EAAgB,CACzB,GAAGA,GAAM,GAAK5iC,EAAGle,WAAWhzE,OAAS8zH,EAAI,OAAOA,EAChD,MAAM,IAAInyH,MAAM,uBAAyBmyH,EAC1C,CAAO,GAAgB,iBAANA,EAAgB,CAChC,IAAInmH,EAAMujF,EAAGle,WAAW1zC,QAAQw0F,GAChC,GAAGnmH,GAAM,EAAI,OAAOA,EACpB,MAAM,IAAIhM,MAAM,2BAA6BmyH,EAAK,IACnD,CAAO,UAAUnyH,MAAM,sBAAwBmyH,EAAK,IACrD,CA+BWE,CAAa9iC,EAAI4iC,GAI3B,OAFI5iC,EAAGyiB,SAAS1gC,OAAOtlE,KAAMujF,EAAGyiB,SAAS1gC,OAAOtlE,GAAO,IAEhDomH,GACN,OAAQ,OAAQ,OAAQ,MACxB,QAAS,MAAM,IAAIpyH,MAAM,gCAAkCoyH,GAG5D7iC,EAAGyiB,SAAS1gC,OAAOtlE,GAAKmgG,OAASimB,CAClC,EAuECE,uBApED,SAAgC5iD,EAAephB,GAE9C,OADAohB,EAAKprD,EAAIgqC,EACFohB,CACR,EAkEC4hD,mBAAoBA,GACpBiB,uBAvDD,SAAgC7iD,EAAejtD,EAAkBklF,GAAuB,OAAO2pB,GAAmB5hD,EAAM,IAAMjtD,EAAOklF,EAAU,EAwD9I6qB,iBArDD,SAA0B9iD,EAAexL,EAAiB05B,GACrDluB,EAAK1+D,IAAG0+D,EAAK1+D,EAAI,IACrB0+D,EAAK1+D,EAAE1M,KAAK,CAAC+Y,EAAE6mD,EAAM7yD,EAAEusF,GAAQ,WAChC,EAmDC60B,wBAhDD,SAAiC/gD,EAAkBjvD,EAAOumE,EAAoB0pC,GAG7E,IAFA,IAAI7qB,EAAsB,iBAATplF,EAAoBA,EAAQmuD,GAAkBnuD,GAC3DkwG,EAAyB,iBAATlwG,EAAoBA,EAAQkuD,GAAaluD,GACrDk/B,EAAIkmD,EAAIz6F,EAAE2D,EAAG4wC,GAAKkmD,EAAIr6F,EAAEuD,IAAK4wC,EAAG,IAAI,IAAI91B,EAAIg8E,EAAIz6F,EAAE4D,EAAG6a,GAAKg8E,EAAIr6F,EAAEwD,IAAK6a,EAAG,CAC/E,IAAI6jD,EAAOuhD,GAAiBv/C,EAAI/vB,EAAG91B,GACnC6jD,EAAKryD,EAAI,IACTqyD,EAAK7tC,EAAI8wF,SACFjjD,EAAK3jE,EACT41C,GAAKkmD,EAAIz6F,EAAE2D,GAAK8a,GAAKg8E,EAAIz6F,EAAE4D,IAC7B0+D,EAAKpvD,EAAI0oE,EACN0pC,IAAShjD,EAAK5jD,GAAI,GAEvB,CACA,OAAO4lD,CACR,EAmCC7U,OAAQ,CACP+1D,cAAe,EACfC,aAAc,EACdC,kBAAmB,IC/3vBd,SAASC,GAAe5hD,EAAOxyE,GACpC,MAAMq0H,cAAEA,GAAkBr0H,EACpBoJ,EAAOopE,EAAMppE,KAAKjJ,MAAM,GACxBm0H,EAAgBlrH,EAAK+Y,QACrBoyG,EAAgBnrH,EAAK+Y,QACrB4oB,EAAY,GAClB,IAAK,IAAIhqC,EAAI,EAAGA,EAAIqI,EAAK1J,OAAQqB,IAAK,CACpC,IAAKszH,EAAe,CAClB,IAAIG,GAAoB,EACxB,IAAK,IAAI1zH,EAAI,EAAGA,EAAIwzH,EAAc50H,OAAQoB,SACrBnB,IAAfyJ,EAAKrI,GAAGD,KACV0zH,GAAoB,GAGxB,GAAIA,EACF,QAEJ,CACA,IAAK,IAAI1zH,EAAI,EAAGA,EAAIwzH,EAAc50H,OAAQoB,IACxCiqC,EAAUplC,KAAK,CACbq2B,MAAOs4F,EAAcxzH,GACrBmqC,MAAOspF,EAAczzH,GACrBsI,KAAM,KAER2hC,EAAUjqC,GAAGsI,KAAKzD,KAAKyD,EAAKrI,GAAGD,GAEnC,CACA,OAAOiqC,CACT,CAEO,SAAS0pF,GAAeC,EAAQ3pF,GACrC,IAAK,IAAIjqC,EAAI,EAAGA,EAAI4zH,EAAOh1H,OAAQoB,IAAK,CACtC,MAAM6zH,EAAiB5pF,EAAU/rC,OAAO6tC,KAAK9B,GAAWjqC,IACxD,GAAK6zH,IAIHD,EAAO5zH,GAAGk7B,QAAU24F,EAAe34F,OACnC04F,EAAO5zH,GAAGmqC,QAAU0pF,EAAe1pF,OAEnC,MAAM,IAAI5pC,MACR,UAAUP,YAAY6zH,EAAe34F,YAAY24F,EAAe1pF,QAGtE,CACF,CC7CO,SAAS2pF,GAAkBrvH,GAChC,IAAKA,GAAQ6lC,MAAMhU,MAAO,OAC1B,IAAK7xB,GAAQ6lC,MAAMypF,WAAY,OAE/B,MAAMz9F,EAAQ7xB,EAAO6lC,KAAKhU,MAC1B,IAAI09F,EAAmB,EACvB,MAAM1tG,EAAW,CACfjoB,MAAOoG,EAAO6lC,KAAKypF,WAAW11H,MAC9B8rC,MAAO1lC,EAAO6lC,KAAKypF,WAAW5pF,OAEhC,IAAK,IAAI1T,KAAQH,EAAO,CACtB,GAAIhQ,EAAS6jB,QAAU1T,EAAKw9F,SAAS9pF,MACnC,MAAM,IAAI5pC,MAAM,yDAElB+lB,EAASjoB,OAASo4B,EAAKw9F,SAAS51H,MAChC21H,GAAoBv9F,EAAKy9F,gBAC3B,CACA59F,EAAMzxB,KAAK,CACTqvH,iBAAkBF,EAClBC,SAAU3tG,EACVwnB,KAAM,YAEV,CCjBO,SAASqmF,GAAqB1vD,EAAO,IAC1C,IAAIhgE,EAAS,IAAI2vH,IACb9zE,EAAQmkB,EAAKvsB,MAAM,WACnBhd,EAAQ,GACZ,IAAK,IAAIt2B,KAAQ07C,EACf,GAAI17C,EAAKY,WAAW,KAAM,CAExB,IAAI6zB,EAAe50B,EAAOE,IAAIu2B,IAAU,GACpC7B,IAAcA,GAAgB,MAC9Bz0B,EAAKY,WAAW,QAAOZ,EAAOA,EAAKwhD,UAAU,IACjD/sB,GAAgBz0B,EAChBH,EAAO+C,IAAI0zB,EAAO7B,EACpB,MAEE6B,EAAQt2B,EAAKk2B,QAAQ,KAAM,IAG/B,OAAOr2B,CACT,CChBO,SAASyzC,GAAMlB,EAAQ93C,EAAU,IACtC,MAAMmE,OAAEA,EAAS,GAAMnE,GACjBm1H,YAAEA,EAAWlqF,MAAEA,GAAU6M,EAAOpc,MACpC,oDACA,MACA05F,OAEF,MAAO,CACLj2H,MAAOyC,OAAOuzH,GAAehxH,EAC7B8mC,MAAOA,EAAMkF,OAEjB,CCZO,SAASklF,GAAWC,GACzB,IAAIlqF,EAAO,CAAA,EAWX,OAVIkqF,EAAe7vH,IAAI,YACrB2lC,EAAK6xB,OAASq4D,EAAe7vH,IAAI,WAE/B6vH,EAAe7vH,IAAI,mBACrB2lC,EAAKmqF,OAST,SAAqBhwD,GACnB,IAAKA,EAAM,MAAO,CAAA,EAClB,IAAIgwD,EAAS,CAAA,EACTn0E,EAAQmkB,EAAKvsB,MAAM,MACvB,IAAK,IAAItzC,KAAQ07C,EACf,GAAI17C,EAAKnG,SAAS,KAAM,CACtB,IAAI8kF,EAAS3+E,EAAKszC,MAAM,IAAK,GACzBhd,EAAQqoD,EAAO,GAAGl0C,OAAOnB,cACzB7vC,EAAQklF,EAAO,GAAGl0C,OACtB,OAAQnU,GACN,IAAK,SACHu5F,EAAOC,KAAOx8E,GAAM75C,GACpB,MACF,IAAK,WACHo2H,EAAOv5F,GAAS78B,EAItB,MACEo2H,EAAO3mF,KAAOlpC,EAAKyqC,OAGvB,OAAOolF,CACT,CAhCkBE,CAAYH,EAAe7vH,IAAI,mBAE/C2lC,EAAKsqF,aAAe18E,GAAMs8E,EAAe7vH,IAAI,kBACzC6vH,EAAe75E,IAAI,aACrBrQ,EAAKhU,MA8BT,SAAsBmuC,GACpB,IAAIl8C,EAAU,GACV9jB,EAAS,CAAA,EACT67C,EAAQmkB,EAAKvsB,MAAM,MACvB,IAAK,IAAIl4C,EAAI,EAAGA,EAAIsgD,EAAM1hD,OAAQoB,IAAK,CACrC,IAAI4E,EAAO07C,EAAMtgD,GACb60H,EAAWv0E,EAAMtgD,EAAI,GAEzB,GADA4E,EAAOA,EAAKk2B,QAAQ,OAAQ,IACxBl2B,EAAKnG,SAAS,QAAS,CAGzB,GAFAgG,EAAS,CAAA,EACT8jB,EAAQ1jB,KAAKJ,IACRG,EAAKnG,SAAS,KACjB,MAAM,IAAI8B,MAAM,gDAElBkE,EAAOyvH,iBACLpzH,OAAO8D,EAAKk2B,QAAQ,iBAAkB,QAAS,IACjDr2B,EAAOwvH,SAAW/7E,GAAM28E,EAAU,CAAExxH,QAAQ,GAC9C,MAAWuB,EAAKY,WAAW,QACzBf,EAAOqpC,KAAOlpC,EAAKk2B,QAAQ,OAAQ,IAAIuU,OAC9BzqC,EAAKY,WAAW,cACzBf,EAAOpD,KAAO62C,GAAMtzC,EAAKk2B,QAAQ,aAAc,KACtCl2B,EAAKY,WAAW,eACzBf,EAAOnD,GAAK42C,GAAMtzC,EAAKk2B,QAAQ,cAAe,KACrCl2B,EAAKY,WAAW,YACzBf,EAAOqwH,YAAc58E,GAAMtzC,EAAKk2B,QAAQ,WAAY,KAC3Cl2B,EAAKY,WAAW,kBACzBf,EAAOswH,gBAAkB78E,GAAMtzC,EAAKk2B,QAAQ,eAAgB,KAEhE,CACA,OAAOvS,CACT,CA5DiBysG,CAAaR,EAAe7vH,IAAI,aAExC2lC,CACT,CCnBO,SAAS2qF,GAAsBxwH,GACpC,GAAuC,OAAnCA,EAAO6lC,KAAKsqF,aAAazqF,MAE3B,YADA1lC,EAAO6lC,KAAKypF,WAAatvH,EAAO6lC,KAAKsqF,cAIvC,GAAuC,MAAnCnwH,EAAO6lC,KAAKsqF,aAAazqF,MAAe,OAC5C,GAAI1lC,EAAO6lC,KAAKhU,OAAO13B,OAAS,EAAG,OAEnC,MAAMs2H,EAAYzwH,EAAO6lC,KAAKhU,MAAM,GAEpC,GAAiC,OAA7B4+F,EAAUjB,SAAS9pF,MAAgB,OACvC,GAAIhqC,KAAKQ,IAAIu0H,EAAUjB,SAAS51H,OAAS,KAAQ,OAEjDoG,EAAO6lC,KAAKypF,WAAa,CACvB11H,MAAO62H,EAAUjB,SAAS51H,MAAQ62H,EAAUhB,iBAC5C/pF,MAAO+qF,EAAUjB,SAAS9pF,OAI5B,MAAMgrF,EAAQ1wH,EAAO6lC,KAAKypF,WAAW11H,MAAQoG,EAAO6lC,KAAKsqF,aAAav2H,MAEhE+2H,EAAc3wH,EAAOwlC,UAAU,KAAK3hC,KAC1C7D,EAAOwlC,UAAUn5B,EAAI,CACnBoqB,MAAO,SACPiP,MAAO1lC,EAAO6lC,KAAKypF,WAAW5pF,MAC9B7hC,KAAM,IAER,IAAK,IAAItI,EAAI,EAAGA,EAAIo1H,EAAYx2H,OAAQoB,IACtCyE,EAAOwlC,UAAUn5B,EAAExI,KAAKzD,KAAKuwH,EAAYp1H,GAAKm1H,EAElD,CC/BO,SAASE,GAAiB5wD,EAAO,IACtC,IAAInkB,EAAQmkB,EAAKvsB,MAAM,MAAMvmB,OAAQ/sB,GAAoC,KAA3BA,EAAKk2B,QAAQ,KAAM,KAC7Dr2B,EAAS,CAAEmP,YAAa,IAI5B,IAAK,IAAI5T,EAAI,EAAGA,EAAIsgD,EAAM1hD,OAAQoB,IAAK,CACrC,IAAIujF,EAASjjC,EAAMtgD,GAAGqvC,OAAO6I,MAAM,SACnC,GAAU,IAANl4C,EAAS,CACXyE,EAAOkzC,OAAS4rC,EAChB9+E,EAAO6D,KAAO,IAAI/F,MAAMghF,EAAO3kF,QAC/B,IAAK,IAAIqB,EAAI,EAAGA,EAAIsjF,EAAO3kF,OAAQqB,IACjCwE,EAAOmP,YAAY2vE,EAAOtjF,IAAMA,EAChCwE,EAAO6D,KAAKrI,GAAK,EAErB,MAAO,GAAU,IAAND,EACTyE,EAAO0lC,MAAQ,IAAI5nC,MAAMkC,EAAOkzC,OAAO/4C,OAAS2kF,EAAO3kF,QACvD6F,EAAO0lC,MAAQ1lC,EAAO0lC,MAAMzR,OAC1B6qD,EAAO/sD,IAAKgtD,GAAUA,EAAM1oD,QAAQ,SAAU,UAE3C,CACL,GAAIyoD,EAAO3kF,SAAW6F,EAAOkzC,OAAO/4C,OAClC,MAAM,IAAI2B,MAAM,gCAAiCgjF,GAEnD,IAAK,IAAItjF,EAAI,EAAGA,EAAIsjF,EAAO3kF,OAAQqB,IAAK,CACtC,IAAI5B,EAAQyC,OAAOyiF,EAAOtjF,IAC1B,GAAImC,MAAM/D,GACR,MAAM,IAAIkC,MAAM,2BAA4BgjF,EAAOtjF,IAErDwE,EAAO6D,KAAKrI,GAAG4E,KAAKxG,EACtB,CACF,CACF,CACA,OAAOoG,CACT,CChCgB,IAAIs3C,YAAY,aCMhC,MAAM9R,GAAY,CAChB,MAAO,CAAEg4B,KAAM,IAAK/mC,MAAO,QAC3B,QAAS,CAAE+mC,KAAM,IAAK/mC,MAAO,wBAC7B,QAAS,CAAE+mC,KAAM,IAAK/mC,MAAO,0BAC7B,WAAY,CAAE+mC,KAAM,IAAK/mC,MAAO,UAChC,WAAY,CAAE+mC,KAAM,IAAK/mC,MAAO,SAChC,UAAW,CAAE+mC,KAAM,IAAK/mC,MAAO,YAuDjC,SAASo6F,GAAyBd,GAChC,IAAItrC,EAASsrC,EAAe7vH,IAAI,gBAC5BtG,EAAQ,GAAG6qF,EAAO5gF,KAAK4gF,EAAO5gF,KAAK1J,OAAS,GAAG,MAAMsqF,EAAO/+C,MAC9D++C,EAAO5gF,KAAK1J,OAAS,GACrBk8B,QAAQ,SAAU,MACpB05F,EAAehtH,IAAI,gBAAiBnJ,EACtC,CCrEO,SAASk3H,GAAyB35E,EAAM18C,EAAU,IACvD,MAAMq0H,cAAEA,GAAgB,GAAUr0H,EAC5Bs2H,ECND,SAA6B55E,GAClC,MAAM65E,EAAWjwD,GAAK5pB,EAAM,CAAE3uC,KAAM,UAE9B0kE,EAAS,GACT+jD,EAAaD,EAAS7jD,WAC5B,IAAK,MAAM+jD,KAAaD,EAAY,CAClC,MAAMhkD,EAAQ,CACZikD,YACArtH,KAAM48D,GAAMif,cAAcsxC,EAAS5jD,OAAO8jD,GAAY,CACpD3xE,OAAQ,KAGP0tB,EAAMppE,KAAK1J,QAChB+yE,EAAO9sE,KAAK6sE,EACd,CACA,OAAOC,CACT,CDVoBikD,CAAoBh6E,GAEhC+1B,EAAS,GACf,IAAK,IAAIkkD,KAAYL,EACQ,YAAvBK,EAASF,WACbhkD,EAAO9sE,KAAK,CACVT,KAAMyxH,EAASF,UACf1rF,UAAW6rF,GAAa,CAACD,GAAW,CAAEtC,oBAI1C,MAAO,CACLjpF,KAAMyrF,GAAQP,GACdvrF,UAAW6rF,GAAaN,EAAW,CAAEjC,kBACrC5hD,SAEJ,CAEA,SAASokD,GAAQpkD,GACf,MAAMD,EAAQC,EAAOtyB,KAAMqyB,GAA8B,YAApBA,EAAMikD,WAC3C,IAAKjkD,EACH,MAAO,CAAA,EAET,MAAMpnC,EAAO,CAAA,EACb,IAAK,IAAI0rF,KAAStkD,EAAMppE,KACtBgiC,EAAK0rF,EAAM,IAAMA,EAAM,GAEzB,OAAO1rF,CACT,CAEA,SAASwrF,GAAankD,EAAQzyE,GAC5B,MAAMq0H,cAAEA,GAAkBr0H,EAC1ByyE,EAASA,EAAOhgD,OAAQ+/C,GAA8B,YAApBA,EAAMikD,WAExC,MAAM1rF,EAAY,CAChBrsB,EAAG,CACDwhC,OAAQ,IACRlkB,MAAO,OACPiP,MAAO,MACP7hC,KAAM,IAERpH,EAAG,CACDk+C,OAAQ,IACRlkB,MAAO,cACPiP,MAAO,KACP7hC,KAAM,IAERwI,EAAG,CACDsuC,OAAQ,IACRlkB,MAAO,SACPiP,MAAO,KACP7hC,KAAM,IAERuc,EAAG,CACDu6B,OAAQ,IACRlkB,MAAO,SACPiP,MAAO,IACP7hC,KAAM,KAIV,IAAK,IAAIopE,KAASC,EAAQ,CACxB,MAAMiiD,EAASN,GAAe5hD,EAAO,CAAE6hD,kBACvCI,GAAeC,EAAQ3pF,GAEvBA,EAAUrsB,EAAEtV,KAAO2hC,EAAUrsB,EAAEtV,KAAKowB,OAAOk7F,EAAO,GAAGtrH,MACrD2hC,EAAU/oC,EAAEoH,KAAO2hC,EAAU/oC,EAAEoH,KAAKowB,OAAOk7F,EAAO,GAAGtrH,MACrD2hC,EAAUn5B,EAAExI,KAAO2hC,EAAUn5B,EAAExI,KAAKowB,OAAOk7F,EAAO,GAAGtrH,MACrD2hC,EAAUplB,EAAEvc,KAAO2hC,EAAUplB,EAAEvc,KAAKowB,OAAOk7F,EAAO,GAAGtrH,KACvD,CACA,OAAO2hC,CACT,wBE7EA,MAAMgsF,EAAgB,gLAEhBC,EAAa,IAAMD,EAAgB,MADxBA,EAAgB,gDAC0B,KACrDE,EAAY,IAAIpnF,OAAO,IAAMmnF,EAAa,KAuBhD/qF,EAAAirF,QAAkB,SAAS9pH,GACzB,YAAoB,IAANA,CAChB,EAEA6+B,EAAAkrF,cAAwB,SAASn2F,GAC/B,OAAmC,IAA5BhiC,OAAO6tC,KAAK7L,GAAKthC,MAC1B,EAOAusC,EAAA++E,MAAgB,SAASzpH,EAAQmR,EAAG0kH,GAClC,GAAI1kH,EAAG,CACL,MAAMm6B,EAAO7tC,OAAO6tC,KAAKn6B,GACnBxM,EAAM2mC,EAAKntC,OACjB,IAAK,IAAIoB,EAAI,EAAGA,EAAIoF,EAAKpF,IAErBS,EAAOsrC,EAAK/rC,IADI,WAAds2H,EACgB,CAAE1kH,EAAEm6B,EAAK/rC,KAET4R,EAAEm6B,EAAK/rC,GAGjC,CACA,EAKAmrC,EAAAorF,SAAmB,SAASjqH,GAC1B,OAAI6+B,EAAQirF,QAAQ9pH,GACXA,EAEA,EAEX,EAKA6+B,EAAAqrF,OA9Ce,SAASx/E,GACtB,MAAMpc,EAAQu7F,EAAU7mF,KAAK0H,GAC7B,QAAO,MAAEpc,EACX,EA4CAuQ,EAAAsrF,cA/DsB,SAASz/E,EAAQ0/E,GACrC,MAAM5qD,EAAU,GAChB,IAAIlxC,EAAQ87F,EAAMpnF,KAAK0H,GACvB,KAAOpc,GAAO,CACZ,MAAM+7F,EAAa,GACnBA,EAAWC,WAAaF,EAAM5vF,UAAYlM,EAAM,GAAGh8B,OACnD,MAAMwG,EAAMw1B,EAAMh8B,OAClB,IAAK,IAAIgC,EAAQ,EAAGA,EAAQwE,EAAKxE,IAC/B+1H,EAAW9xH,KAAK+1B,EAAMh6B,IAExBkrE,EAAQjnE,KAAK8xH,GACb/7F,EAAQ87F,EAAMpnF,KAAK0H,EACvB,CACE,OAAO80B,CACT,EAkDA3gC,EAAA+qF,WAAqBA,OCmPK,IAAInnF,OAAO,0DAA2D,KC1ShG,SAAS8nF,GAASpvD,EAAKvoE,EAAS43H,EAAOC,GACnC,IAAIC,EAAS,GACTC,GAAuB,EAE3B,IAAK,IAAIj3H,EAAI,EAAGA,EAAIynE,EAAI7oE,OAAQoB,IAAK,CACjC,MAAMk3H,EAASzvD,EAAIznE,GACbm3H,EAAUC,GAASF,GACzB,QAAer4H,IAAZs4H,EAAuB,SAE1B,IAAIE,EAAW,GAIf,GAHwBA,EAAH,IAAjBP,EAAMl4H,OAAyBu4H,EACnB,GAAGL,KAASK,IAExBA,IAAYj4H,EAAQo4H,aAAc,CAClC,IAAIC,EAAUL,EAAOC,GAChBK,GAAWH,EAAUn4H,KACtBq4H,EAAUr4H,EAAQu4H,kBAAkBN,EAASI,GAC7CA,EAAUG,GAAqBH,EAASr4H,IAExC+3H,IACAD,GAAUD,GAEdC,GAAUO,EACVN,GAAuB,EACvB,QACZ,CAAe,GAAIE,IAAYj4H,EAAQy4H,cAAe,CACtCV,IACAD,GAAUD,GAEdC,GAAU,YAAYE,EAAOC,GAAS,GAAGj4H,EAAQo4H,mBACjDL,GAAuB,EACvB,QACZ,CAAe,GAAIE,IAAYj4H,EAAQ04H,gBAAiB,CAC5CZ,GAAUD,EAAc,UAAOG,EAAOC,GAAS,GAAGj4H,EAAQo4H,sBAC1DL,GAAuB,EACvB,QACZ,CAAe,GAAmB,MAAfE,EAAQ,GAAY,CAC3B,MAAMU,EAASC,GAAYZ,EAAO,MAAOh4H,GACnC64H,EAAsB,SAAZZ,EAAqB,GAAKJ,EAC1C,IAAIiB,EAAiBd,EAAOC,GAAS,GAAGj4H,EAAQo4H,cAChDU,EAA2C,IAA1BA,EAAep5H,OAAe,IAAMo5H,EAAiB,GACtEhB,GAAUe,EAAU,IAAIZ,IAAUa,IAAiBH,MACnDZ,GAAuB,EACvB,QACZ,CACQ,IAAIgB,EAAgBlB,EACE,KAAlBkB,IACAA,GAAiB/4H,EAAQg5H,UAE7B,MACMC,EAAWpB,EAAc,IAAII,IADpBW,GAAYZ,EAAO,MAAOh4H,KAEnCk5H,EAAWvB,GAASK,EAAOC,GAAUj4H,EAASm4H,EAAUY,IAChB,IAA1C/4H,EAAQm5H,aAAan6F,QAAQi5F,GACzBj4H,EAAQo5H,qBAAsBtB,GAAUmB,EAAW,IAClDnB,GAAUmB,EAAW,KACjBC,GAAgC,IAApBA,EAASx5H,SAAiBM,EAAQq5H,kBAEhDH,GAAYA,EAAS55H,SAAS,KACrCw4H,GAAUmB,EAAW,IAAIC,IAAWrB,MAAgBI,MAEpDH,GAAUmB,EAAW,IACjBC,GAA4B,KAAhBrB,IAAuBqB,EAAS35H,SAAS,OAAS25H,EAAS35H,SAAS,OAChFu4H,GAAUD,EAAc73H,EAAQg5H,SAAWE,EAAWrB,EAEtDC,GAAUoB,EAEdpB,GAAU,KAAKG,MAVfH,GAAUmB,EAAW,KAYzBlB,GAAuB,CAC/B,CAEI,OAAOD,CACX,CAEA,SAASI,GAASl3F,GACd,MAAM6L,EAAO7tC,OAAO6tC,KAAK7L,GACzB,IAAK,IAAIlgC,EAAI,EAAGA,EAAI+rC,EAAKntC,OAAQoB,IAAK,CAClC,MAAMm0B,EAAM4X,EAAK/rC,GACjB,GAAIkgC,EAAIyL,eAAexX,IACX,OAARA,EAAc,OAAOA,CACjC,CACA,CAEA,SAAS2jG,GAAYU,EAASt5H,GAC1B,IAAIu5H,EAAU,GACd,GAAID,IAAYt5H,EAAQw5H,iBACpB,IAAK,IAAIC,KAAQH,EAAS,CACtB,IAAIA,EAAQ7sF,eAAegtF,GAAO,SAClC,IAAIC,EAAU15H,EAAQ25H,wBAAwBF,EAAMH,EAAQG,IAC5DC,EAAUlB,GAAqBkB,EAAS15H,IACxB,IAAZ05H,GAAoB15H,EAAQ45H,0BAC5BL,GAAW,IAAIE,EAAK3qF,OAAO9uC,EAAQ65H,oBAAoBn6H,UAEvD65H,GAAW,IAAIE,EAAK3qF,OAAO9uC,EAAQ65H,oBAAoBn6H,YAAYg6H,IAEnF,CAEI,OAAOH,CACX,CAEA,SAASjB,GAAWV,EAAO53H,GAEvB,IAAIi4H,GADJL,EAAQA,EAAM9oF,OAAO,EAAG8oF,EAAMl4H,OAASM,EAAQo4H,aAAa14H,OAAS,IACjDovC,OAAO8oF,EAAMllE,YAAY,KAAO,GACpD,IAAK,IAAIhxD,KAAS1B,EAAQ85H,UACtB,GAAI95H,EAAQ85H,UAAUp4H,KAAWk2H,GAAS53H,EAAQ85H,UAAUp4H,KAAW,KAAOu2H,EAAS,OAAO,EAElG,OAAO,CACX,CAEA,SAASO,GAAqBuB,EAAW/5H,GACrC,GAAI+5H,GAAaA,EAAUr6H,OAAS,GAAKM,EAAQg6H,gBAC7C,IAAK,IAAIl5H,EAAI,EAAGA,EAAId,EAAQssE,SAAS5sE,OAAQoB,IAAK,CAC9C,MAAMm5H,EAASj6H,EAAQssE,SAASxrE,GAChCi5H,EAAYA,EAAUn+F,QAAQq+F,EAAOzC,MAAOyC,EAAOnoG,IAC/D,CAEI,OAAOioG,CACX,CCnIA,MAAMG,GDMN,SAAeC,EAAQn6H,GACnB,IAAI63H,EAAc,GAIlB,OAHI73H,EAAQ02C,QAAU12C,EAAQg5H,SAASt5H,OAAS,IAC5Cm4H,EAXI,MAaDF,GAASwC,EAAQn6H,EAAS,GAAI63H,EACzC,ECXMuC,GCHN,SAA+BZ,GAC3B,MAAgC,mBAArBA,EACAA,EAEPn2H,MAAMi+B,QAAQk4F,GACNa,IACJ,IAAK,MAAMC,KAAWd,EAAkB,CACpC,GAAuB,iBAAZc,GAAwBD,IAAaC,EAC5C,OAAO,EAEX,GAAIA,aAAmBzqF,QAAUyqF,EAAQ5pF,KAAK2pF,GAC1C,OAAO,CAE3B,GAGW,KAAM,CACjB,EDZME,GAAiB,CACrBV,oBAAqB,KACrBW,qBAAqB,EACrBpC,aAAc,QACdoB,kBAAkB,EAClBf,eAAe,EACf/hF,QAAQ,EACRsiF,SAAU,KACVK,mBAAmB,EACnBD,sBAAsB,EACtBQ,2BAA2B,EAC3BrB,kBAAmB,SAAStjG,EAAKviB,GAC/B,OAAOA,CACX,EACEinH,wBAAyB,SAASU,EAAU3nH,GAC1C,OAAOA,CACX,EACE+nH,eAAe,EACf/B,iBAAiB,EACjBS,aAAc,GACd7sD,SAAU,CACR,CAAEkrD,MAAO,IAAI3nF,OAAO,IAAK,KAAM/d,IAAK,SACpC,CAAE0lG,MAAO,IAAI3nF,OAAO,IAAK,KAAM/d,IAAK,QACpC,CAAE0lG,MAAO,IAAI3nF,OAAO,IAAK,KAAM/d,IAAK,QACpC,CAAE0lG,MAAO,IAAI3nF,OAAO,IAAM,KAAM/d,IAAK,UACrC,CAAE0lG,MAAO,IAAI3nF,OAAO,IAAM,KAAM/d,IAAK,WAEvCkoG,iBAAiB,EACjBF,UAAW,GAGXY,cAAc,GAGhB,SAASC,GAAQ36H,GACfkJ,KAAKlJ,QAAUhB,OAAO2tC,OAAO,CAAA,EAAI4tF,GAAgBv6H,IACX,IAAlCkJ,KAAKlJ,QAAQw5H,kBAA6BtwH,KAAKlJ,QAAQw6H,oBACzDtxH,KAAK0xH,YAAc,WACjB,OAAO,CACb,GAEI1xH,KAAK2xH,mBAAqBT,GAAsBlxH,KAAKlJ,QAAQw5H,kBAC7DtwH,KAAK4xH,cAAgB5xH,KAAKlJ,QAAQ65H,oBAAoBn6H,OACtDwJ,KAAK0xH,YAAcA,IAGrB1xH,KAAK6xH,qBAAuBA,GAExB7xH,KAAKlJ,QAAQ02C,QACfxtC,KAAK8xH,UAAYA,GACjB9xH,KAAK+xH,WAAa,MAClB/xH,KAAKu8C,QAAU,OAEfv8C,KAAK8xH,UAAY,WACf,MAAO,EACb,EACI9xH,KAAK+xH,WAAa,IAClB/xH,KAAKu8C,QAAU,GAEnB,CAmHA,SAASs1E,GAAsBjhF,EAAQ7kB,EAAKkuD,EAAO+3C,GACjD,MAAM31H,EAAS2D,KAAKiyH,IAAIrhF,EAAQqpC,EAAQ,EAAG+3C,EAAO1hG,OAAOvE,IACzD,YAA0Ct1B,IAAtCm6C,EAAO5wC,KAAKlJ,QAAQo4H,eAA8D,IAA/Bp5H,OAAO6tC,KAAKiN,GAAQp6C,OAClEwJ,KAAKkyH,iBAAiBthF,EAAO5wC,KAAKlJ,QAAQo4H,cAAenjG,EAAK1vB,EAAOg0H,QAASp2C,GAE9Ej6E,KAAKmyH,gBAAgB91H,EAAOusB,IAAKmD,EAAK1vB,EAAOg0H,QAASp2C,EAEjE,CAuFA,SAAS63C,GAAU73C,GACjB,OAAOj6E,KAAKlJ,QAAQg5H,SAASt0H,OAAOy+E,EACtC,CAEA,SAASy3C,GAAY11H,GACnB,SAAIA,EAAKoB,WAAW4C,KAAKlJ,QAAQ65H,sBAAwB30H,IAASgE,KAAKlJ,QAAQo4H,eACtElzH,EAAK4pC,OAAO5lC,KAAK4xH,cAI5B,CErRM,SAAUQ,GAAkBC,GAChC,MAAM1hF,EAAW,IAAIJ,GAEfpwB,ERQD,SAA+BkyG,GAGpC,IAAIlyG,EAAU,GAEd,MAAM0uB,EAJO0E,GAAa8+E,GAIPviF,MAAM,mBACzB,IAAK,MAAMwiF,KAAQzjF,EACjB,GAAIyjF,EAAKl1H,WAAW,eAAgB,CAClC,IACIm1H,EADAnG,EAAiBL,GAAqBuG,GAEtClG,EAAe75E,IAAI,kBACrBggF,EAAoBtF,GAClBb,EAAe7vH,IAAI,iBAErB6vH,EAAehtH,IAAI,eAAgBmzH,IAGrCrF,GAAyBd,GAEzB,MAAMlsH,EAAO,CAAA,EACb,IAAK,IAAItI,EAAI,EAAGA,EAAI26H,EAAkBxwF,MAAMvrC,OAAQoB,IAAK,CACvD,MAAMo4C,EACJuiF,EAAkBhjF,QAAUgjF,EAAkBhjF,OAAO33C,GACjDmqC,EAAQwwF,EAAkBxwF,OAASwwF,EAAkBxwF,MAAMnqC,GAC3D46H,EAAaD,EAAkBryH,MAAQqyH,EAAkBryH,KAAKtI,GAC9Dq3C,EAAWpN,GAAU,GAAGmO,KAAgBjO,KAC1CkN,GAAYA,EAAS4qB,OACvB35D,EAAK+uC,EAAS4qB,MAAQ,CACpB93B,QACA7hC,KAAMsyH,EACN1/F,MAAOmc,EAASnc,OAGtB,CAEA,IAAIz2B,EAAS,CACX6lC,KAAMiqF,GAAWC,GACjBvqF,UAAW3hC,EACX41C,KAAM,CACJ7T,SAAU,QAId4qF,GAAsBxwH,GACtBqvH,GAAkBrvH,GAElB8jB,EAAQ1jB,KAAKJ,EACf,CAEF,OAAO8jB,CACT,CQ1DyBsyG,CAAsBJ,GAGvCh2H,EAAS8jB,EAAQ82B,KACpB56C,GACCA,EAAOwlC,WAAWn5B,IACY,OAA7BrM,EAAOwlC,UAAUn5B,EAAEq5B,OAA+C,MAA7B1lC,EAAOwlC,UAAUn5B,EAAEq5B,QAGvD2wF,EAAW,CAAExwF,KAAM7lC,EAAO6lC,MAOhC,OALAyO,EAASO,aAAa70C,EAAOwlC,UAAW,CACtCI,SAAU,MACVC,KAAM,IAAK7lC,EAAO6lC,KAAMwwF,cAGnB/hF,CACT,CCrBM,SAAUgiF,GAAYN,GAC1B,MACMn6E,EADO3E,GAAa8+E,EAAa,CAAE5+E,SAAU,cAChC3D,MAAM,SAASvmB,OAAOlS,SACnCm0G,EAAS,CACbtpF,KAAM,CAAA,EACNL,UAAW,CACT/oC,EAAG,CACDoH,KAAM,GACN4yB,MAAO,0BACPgsB,aAAa,GAEfp2C,EAAG,CACDxI,KAAM,GACN4yB,MAAO,cACPgsB,aAAa,GAEftpC,EAAG,CACDtV,KAAM,GACN4yB,MAAO,aACPgsB,aAAa,KAInB,IAAI8zE,GAAS,EACb,IAAK,MAAMp2H,KAAQ07C,EACjB,GAAI06E,EAAQ,CACV,MAAOC,EAAajwF,EAAMpG,GAAUhgC,EACjCszC,MAAM,KACN1hB,IAAI11B,OAAO0uC,YACdokF,EAAO3pF,UAAU/oC,EAAEoH,KAAKzD,KAAKo2H,GAC7BrH,EAAO3pF,UAAUn5B,EAAExI,KAAKzD,KAAK+/B,GAC7BgvF,EAAO3pF,UAAUrsB,EAAEtV,KAAKzD,KAAKmmC,EAC/B,MAAO,GAAIpmC,EAAKY,WAAW,MACzBw1H,GAAS,MACJ,CACL,MAAM1G,EAAS,8BAA8BhlF,KAAK1qC,IAAO0vH,OACzD,IAAKA,EAAQ,MAAM,IAAI/zH,MAAM,6BAC7B,MAAM26B,MAAEA,EAAK78B,MAAEA,GAAUi2H,EACzBV,EAAOtpF,KAAKpP,GAAS78B,CACvB,CAGF,MAAMq2H,EAAO5zH,OAAO0uC,WAAWokF,EAAOtpF,KAAK,oBAC3CspF,EAAO3pF,UAAUn5B,EAAExI,KAAOsrH,EAAO3pF,UAAUn5B,EAAExI,KAAKkuB,IAAKx2B,GAC7CA,EAAI,IAAO00H,GAErB,MAAM37E,EAAW,IAAIJ,GAMrB,OALAI,EAASO,aAAas6E,EAAO3pF,UAAW,CACtCK,KAAMspF,EAAOtpF,KACbD,SAAU,QAGL0O,CACT,CCvDM,SAAUmiF,GAAsBt/E,GACpC,MAAMu/E,EA6BR,SAAqBv/E,GACnB,MAAMn3C,EAAkB,CACtBu/C,OAAQ,CAAA,EACRo3E,YAAa,CACXl9E,KAAM,GACNm9E,MAAO,IAETh2B,OAAQ,IAEJ5gC,EAAO9oB,GAAaC,GACpB0E,EAAQmkB,EAAKvsB,MAAM,SAEzB,IAAIojF,EAA2B,SAC3BC,EAA0B,CAC5BpgG,GAAI,EAEJqgG,YAAa,GACbvxF,UAAW,IAETwxF,EAAoD,GAExD,IAAK,IAAIz7H,EAAI,EAAGA,EAAIsgD,EAAM1hD,OAAQoB,IAAK,CACrC,MAAM4E,EAAO07C,EAAMtgD,GACnB,GAAI4E,EAAKY,WAAW,iBAClB81H,EAAiB,mBAWnB,OAPqB,gBAAnBA,GACA12H,EAAKY,WAAW,OAChBf,EAAO22H,YAAYC,MAAMz8H,OAAS,IAElC08H,EAAiB,iBAGXA,GACN,IAAK,SACH,CACE,MAAOnnG,KAAQunG,GAAQ92H,EAAKszC,MAAM,KAAK1hB,IAAK7oB,GAAMA,EAAE0hC,QAC9ChxC,EAAQq9H,EAAK32H,KAAK,KACpBovB,GAAO91B,EAAMO,OAAS,IACxB6F,EAAOu/C,OAAO7vB,GAAO91B,EAEzB,CACA,MACF,IAAK,cACH,GAAIuG,EAAKg2B,MAAM,UAAW,CAExB,MAAMA,EAAQh2B,EAAKg2B,MAAM,kBACrBA,GACFn2B,EAAO22H,YAAYC,MAAMx2H,KAAK,CAC5Bs2B,GAAIr6B,OAAOiR,SAAS6oB,EAAM,GAAI,IAC9BM,MAAOt2B,EAAKk2B,QAAQ,KAAM,KAAKuU,OAC/BmsF,YAAa,GACbvxF,UAAW,IAGjB,KAAO,CACL,GAAoB,KAAhBrlC,EAAKyqC,OAAe,SACxB5qC,EAAO22H,YAAYl9E,KAAKr5C,KAAKD,EAAK1C,WAAW,KAAM,MACrD,CACA,MACF,IAAK,gBACH,CACE,MAAMypB,KAAEA,EAAI6vG,YAAEA,GAAgBG,GAAqB/2H,EAAMH,GACzD82H,EAAc5vG,EACd4vG,EAAYC,YAAcA,EAC1BF,EAAiB,YACnB,CACA,MACF,IAAK,aACHG,EAAcG,GAAgBh3H,EAAM07C,EAAMtgD,EAAI,IAC9CA,IACAs7H,EAAiB,OACjBC,EAAYtxF,UAAYQ,gBAAgBgxF,GACxC,MACF,IAAK,OACH,GAAoB,KAAhB72H,EAAKyqC,OAAe,CACtBisF,EAAiB,UACjB,QACF,CACA,GAAI12H,EAAKg2B,MAAM,aAAc,CAE3B,MAAM4gG,YAAEA,EAAW7vG,KAAEA,GAASgwG,GAAqB/2H,EAAMH,GACzD82H,EAAc5vG,EACd4vG,EAAYtxF,UAAYQ,gBAAgBgxF,GACxCF,EAAYC,YAAcA,CAC5B,KAAO,CACL,MAAMK,EAAYj3H,EACfszC,MAAM,MACN1hB,IAAK7oB,GAAMA,EAAE0hC,QACb7Y,IAAI11B,QACP,GAAI+6H,EAAUj9H,SAAW28H,GAAatxF,UAAUrrC,OAC9C,MAAM,IAAI2B,MACR,gCAAgCg7H,GAAapgG,gBAAgBogG,GAAatxF,UAAUrrC,eAAei9H,EAAUj9H,UAGjH,IAAK,IAAIqB,EAAI,EAAGA,EAAI47H,EAAUj9H,OAAQqB,IACpCs7H,GAAatxF,UAAUhqC,GAAGqI,KAAKzD,KAAKg3H,EAAU57H,GAElD,CACA,MACF,IAAK,UACH,GAAoB,KAAhB2E,EAAKyqC,OACP,SAEFisF,EAAiB,SACjB,MACF,IAAK,SACH72H,EAAO4gG,QAAU,GAAGzgG,MAM1B,CACA,OAAOH,CACT,CAlJmBq3H,CAAYlgF,GAC7B,OAAOu/E,CACT,CAkJA,SAASQ,GAAqB/2H,EAAcH,GAC1C,MAAMm2B,EAAQh2B,EAAKg2B,MAAM,oBACzB,IAAKA,EACH,MAAM,IAAIr6B,MAAM,2CAA2CqE,KAE7D,MAAMu2B,EAAKr6B,OAAOiR,SAAS6oB,EAAM,GAAI,IAE/BjP,EAAOlnB,EAAO22H,YAAYC,MAAMh8E,KAAM1xC,GAAMA,EAAEwtB,KAAOA,GAC3D,IAAKxP,EACH,MAAM,IAAIprB,MAAM,iDAAiD46B,KAEnE,MAAO,CACLA,KACAqgG,YAAa5gG,EAAM,GAAGyU,OACtB1jB,OAEJ,CAOA,SAASiwG,GACPh3H,EACAiwH,GAEA,MAAMkH,EAAiBn3H,EAAKszC,MAAM,MAAM1hB,IAAK7oB,GAAMA,EAAE0hC,QAC/C2sF,EAAkBnH,EAAS38E,MAAM,MAAM1hB,IAAK7oB,GAAMA,EAAE0hC,QACpDwE,EAAqB,GAC3B,IAAK,IAAI7zC,EAAI,EAAGA,EAAI+7H,EAAen9H,OAAQoB,IAAK,CAC9C,IAAIi8H,EAAiBF,EAAe/7H,GAChCA,EAAIg8H,EAAgBp9H,QAAiC,KAAvBo9H,EAAgBh8H,KAChDi8H,GAAkB,IAAID,EAAgBh8H,MAExC6zC,EAAShvC,KAAKo3H,EAChB,CACA,OAAOpoF,EAASrd,IAAK0E,IAAK,CAAQA,QAAO5yB,KAAM,KACjD,CCjLM,SAAU4zH,GAAgBzB,GAC9B,MAAMh2D,EAAO9oB,GAAa8+E,GACpB1hF,EAAW,IAAIJ,GACfi7E,EAASsH,GAAsBz2D,GAE/Bn6B,EAAgC,IACjCspF,EAAO5vE,OACVm4E,UAAWvI,EAAOwH,YAAYl9E,KAC9Bk9E,YAAaxH,EAAOwH,YAAYC,MAAM7kG,IAAK7K,GAASA,EAAKuP,OACzDmqE,OAAQuuB,EAAOvuB,QAGXp7D,EAAY2pF,EAAOwH,YAAYC,MAAM,GAAGpxF,UAC9C,IAAK,IAAIjqC,EAAI,EAAGA,EAAI4zH,EAAOwH,YAAYC,MAAMz8H,OAAQoB,IAAK,CACxD,MAAMo8H,EAAexI,EAAOwH,YAAYC,MAAMr7H,GAAGiqC,UACjD,IAAK,IAAIhqC,EAAI,EAAGA,EAAIgqC,EAAUrrC,OAAQqB,IAChCgqC,EAAUhqC,GAAGqI,MAAQ8zH,EAAan8H,GAAGqI,OACvC2hC,EAAUhqC,GAAGqI,KAAO2hC,EAAUhqC,GAAGqI,KAAKowB,OAAO0jG,EAAan8H,GAAGqI,MAGnE,CA2CA,OAzCAywC,EAASO,aACP,CACEp4C,EAAG,CACDoH,KACE2hC,EAAUoV,KAAM/yC,GAAMA,EAAE4uB,MAAM11B,WAAW,wBACrC8C,MAAQ,GACd4yB,MAAO,oBAETpqB,EAAG,CACDxI,KACE2hC,EAAUoV,KAAM/yC,GAAMA,EAAE4uB,MAAM11B,WAAW,yBACrC8C,MAAQ,GACd4yB,MAAO,gBAGX,CACEmP,SAAU,MACVD,MAAQE,EAAK,cAA2B,GACxCA,SAGJyO,EAASO,aACP,CACEp4C,EAAG,CACDoH,KAAM2hC,EAAUoV,KAAM/yC,GAAMA,EAAE4uB,MAAM11B,WAAW,UAAU8C,MAAQ,GACjE4yB,MAAO,cAETpqB,EAAG,CACDxI,KACE2hC,EAAUoV,KAAM/yC,GAAMA,EAAE4uB,MAAM11B,WAAW,yBACrC8C,MAAQ,GACd4yB,MAAO,gBAGX,CACEmP,SAAU,MACVD,MAAQE,EAAK,cAA2B,GACxCA,SAIGyO,CACT,CLXA8gF,GAAQ17H,UAAUk+H,MAAQ,SAASC,GACjC,OAAGl0H,KAAKlJ,QAAQy6H,cACPP,GAAmBkD,EAAMl0H,KAAKlJ,UAElCqD,MAAMi+B,QAAQ87F,IAASl0H,KAAKlJ,QAAQq9H,eAAiBn0H,KAAKlJ,QAAQq9H,cAAc39H,OAAS,IAC1F09H,EAAO,CACL,CAACl0H,KAAKlJ,QAAQq9H,eAAiBD,IAG5Bl0H,KAAKiyH,IAAIiC,EAAM,EAAG,IAAItrG,IAEjC,EAEA6oG,GAAQ17H,UAAUk8H,IAAM,SAASiC,EAAMj6C,EAAO+3C,GAC5C,IAAI3B,EAAU,GACVznG,EAAM,GACV,MAAM8lG,EAAQsD,EAAOr1H,KAAK,KAC1B,IAAK,IAAIovB,KAAOmoG,EACd,GAAIp+H,OAAOC,UAAUwtC,eAAeptC,KAAK+9H,EAAMnoG,GAC/C,QAAyB,IAAdmoG,EAAKnoG,GAEV/rB,KAAK0xH,YAAY3lG,KACnBnD,GAAO,SAEJ,GAAkB,OAAdsrG,EAAKnoG,GAEV/rB,KAAK0xH,YAAY3lG,IAEVA,IAAQ/rB,KAAKlJ,QAAQy4H,cAD9B3mG,GAAO,GAGa,MAAXmD,EAAI,GACbnD,GAAO5oB,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAM,IAAM/rB,KAAK+xH,WAEtDnpG,GAAO5oB,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAM,IAAM/rB,KAAK+xH,gBAGnD,GAAImC,EAAKnoG,aAAgByW,KAC9B5Z,GAAO5oB,KAAKkyH,iBAAiBgC,EAAKnoG,GAAMA,EAAK,GAAIkuD,QAC5C,GAAyB,iBAAdi6C,EAAKnoG,GAAmB,CAExC,MAAMwkG,EAAOvwH,KAAK0xH,YAAY3lG,GAC9B,GAAIwkG,IAASvwH,KAAK2xH,mBAAmBpB,EAAM7B,GACzC2B,GAAWrwH,KAAKo0H,iBAAiB7D,EAAM,GAAK2D,EAAKnoG,SAC5C,IAAKwkG,EAEV,GAAIxkG,IAAQ/rB,KAAKlJ,QAAQo4H,aAAc,CACrC,IAAImF,EAASr0H,KAAKlJ,QAAQu4H,kBAAkBtjG,EAAK,GAAKmoG,EAAKnoG,IAC3DnD,GAAO5oB,KAAKsvH,qBAAqB+E,EAC3C,MACUzrG,GAAO5oB,KAAKkyH,iBAAiBgC,EAAKnoG,GAAMA,EAAK,GAAIkuD,EAG3D,MAAW,GAAI9/E,MAAMi+B,QAAQ87F,EAAKnoG,IAAO,CAEnC,MAAMuoG,EAASJ,EAAKnoG,GAAKv1B,OACzB,IAAI+9H,EAAa,GACbC,EAAc,GAClB,IAAK,IAAI38H,EAAI,EAAGA,EAAIy8H,EAAQz8H,IAAK,CAC/B,MAAMyrC,EAAO4wF,EAAKnoG,GAAKl0B,GACvB,QAAoB,IAATyrC,QAEJ,GAAa,OAATA,EACK,MAAXvX,EAAI,GAAYnD,GAAO5oB,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAM,IAAM/rB,KAAK+xH,WACpEnpG,GAAO5oB,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAM,IAAM/rB,KAAK+xH,gBAEtD,GAAoB,iBAATzuF,EAChB,GAAGtjC,KAAKlJ,QAAQ06H,aAAa,CAC3B,MAAMn1H,EAAS2D,KAAKiyH,IAAI3uF,EAAM22C,EAAQ,EAAG+3C,EAAO1hG,OAAOvE,IACvDwoG,GAAcl4H,EAAOusB,IACjB5oB,KAAKlJ,QAAQw6H,qBAAuBhuF,EAAKC,eAAevjC,KAAKlJ,QAAQw6H,uBACvEkD,GAAen4H,EAAOg0H,QAEpC,MACYkE,GAAcv0H,KAAK6xH,qBAAqBvuF,EAAMvX,EAAKkuD,EAAO+3C,QAG5D,GAAIhyH,KAAKlJ,QAAQ06H,aAAc,CAC7B,IAAIX,EAAY7wH,KAAKlJ,QAAQu4H,kBAAkBtjG,EAAKuX,GACpDutF,EAAY7wH,KAAKsvH,qBAAqBuB,GACtC0D,GAAc1D,CAC1B,MACY0D,GAAcv0H,KAAKkyH,iBAAiB5uF,EAAMvX,EAAK,GAAIkuD,EAG/D,CACSj6E,KAAKlJ,QAAQ06H,eACd+C,EAAav0H,KAAKmyH,gBAAgBoC,EAAYxoG,EAAKyoG,EAAav6C,IAElErxD,GAAO2rG,CACb,MAEM,GAAIv0H,KAAKlJ,QAAQw6H,qBAAuBvlG,IAAQ/rB,KAAKlJ,QAAQw6H,oBAAqB,CAChF,MAAMmD,EAAK3+H,OAAO6tC,KAAKuwF,EAAKnoG,IACtBxO,EAAIk3G,EAAGj+H,OACb,IAAK,IAAIqB,EAAI,EAAGA,EAAI0lB,EAAG1lB,IACrBw4H,GAAWrwH,KAAKo0H,iBAAiBK,EAAG58H,GAAI,GAAKq8H,EAAKnoG,GAAK0oG,EAAG58H,IAEpE,MACQ+wB,GAAO5oB,KAAK6xH,qBAAqBqC,EAAKnoG,GAAMA,EAAKkuD,EAAO+3C,GAI9D,MAAO,CAAC3B,QAASA,EAASznG,IAAKA,EACjC,EAEA6oG,GAAQ17H,UAAUq+H,iBAAmB,SAASjD,EAAUvoG,GAGtD,OAFAA,EAAM5oB,KAAKlJ,QAAQ25H,wBAAwBU,EAAU,GAAKvoG,GAC1DA,EAAM5oB,KAAKsvH,qBAAqB1mG,GAC5B5oB,KAAKlJ,QAAQ45H,2BAAqC,SAAR9nG,EACrC,IAAMuoG,EACD,IAAMA,EAAW,KAAOvoG,EAAM,GAC9C,EAWA6oG,GAAQ17H,UAAUo8H,gBAAkB,SAASvpG,EAAKmD,EAAKskG,EAASp2C,GAC9D,GAAW,KAARrxD,EACD,MAAc,MAAXmD,EAAI,GAAoB/rB,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAMskG,EAAS,IAAMrwH,KAAK+xH,WAE1E/xH,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAMskG,EAAUrwH,KAAK00H,SAAS3oG,GAAO/rB,KAAK+xH,WAE9E,CAEH,IAAI4C,EAAY,KAAO5oG,EAAM/rB,KAAK+xH,WAC9B6C,EAAgB,GAQpB,MANc,MAAX7oG,EAAI,KACL6oG,EAAgB,IAChBD,EAAY,KAITtE,GAAuB,KAAZA,QAAmBznG,EAAIkN,QAAQ,MAEH,IAAjC91B,KAAKlJ,QAAQ04H,iBAA6BzjG,IAAQ/rB,KAAKlJ,QAAQ04H,iBAA4C,IAAzBoF,EAAcp+H,OAClGwJ,KAAK8xH,UAAU73C,GAAS,UAAOrxD,UAAW5oB,KAAKu8C,QAGpDv8C,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAMskG,EAAUuE,EAAgB50H,KAAK+xH,WACnEnpG,EACA5oB,KAAK8xH,UAAU73C,GAAS06C,EAPjB30H,KAAK8xH,UAAU73C,GAAS,IAAOluD,EAAMskG,EAAUuE,EAAgB,IAAMhsG,EAAM+rG,CAS1F,CACA,EAEAlD,GAAQ17H,UAAU2+H,SAAW,SAAS3oG,GACpC,IAAI2oG,EAAW,GAQf,WAPG10H,KAAKlJ,QAAQm5H,aAAan6F,QAAQ/J,GAC/B/rB,KAAKlJ,QAAQo5H,uBAAsBwE,EAAW,KAElDA,EADO10H,KAAKlJ,QAAQq5H,kBACT,IAEA,MAAMpkG,IAEZ2oG,CACT,EAcAjD,GAAQ17H,UAAUm8H,iBAAmB,SAAStpG,EAAKmD,EAAKskG,EAASp2C,GAC/D,IAAmC,IAA/Bj6E,KAAKlJ,QAAQy4H,eAA2BxjG,IAAQ/rB,KAAKlJ,QAAQy4H,cAC/D,OAAOvvH,KAAK8xH,UAAU73C,GAAS,YAAYrxD,OAAY5oB,KAAKu8C,QACxD,IAAqC,IAAjCv8C,KAAKlJ,QAAQ04H,iBAA6BzjG,IAAQ/rB,KAAKlJ,QAAQ04H,gBACvE,OAAOxvH,KAAK8xH,UAAU73C,GAAS,UAAOrxD,UAAY5oB,KAAKu8C,QACnD,GAAc,MAAXxwB,EAAI,GACX,OAAQ/rB,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAMskG,EAAS,IAAMrwH,KAAK+xH,WAC7D,CACH,IAAIlB,EAAY7wH,KAAKlJ,QAAQu4H,kBAAkBtjG,EAAKnD,GAGpD,OAFAioG,EAAY7wH,KAAKsvH,qBAAqBuB,GAEpB,KAAdA,EACK7wH,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAMskG,EAAUrwH,KAAK00H,SAAS3oG,GAAO/rB,KAAK+xH,WAExE/xH,KAAK8xH,UAAU73C,GAAS,IAAMluD,EAAMskG,EAAU,IAClDQ,EACD,KAAO9kG,EAAM/rB,KAAK+xH,UAE1B,CACA,EAEAN,GAAQ17H,UAAUu5H,qBAAuB,SAASuB,GAChD,GAAGA,GAAaA,EAAUr6H,OAAS,GAAKwJ,KAAKlJ,QAAQg6H,gBACnD,IAAK,IAAIl5H,EAAE,EAAGA,EAAEoI,KAAKlJ,QAAQssE,SAAS5sE,OAAQoB,IAAK,CACjD,MAAMm5H,EAAS/wH,KAAKlJ,QAAQssE,SAASxrE,GACrCi5H,EAAYA,EAAUn+F,QAAQq+F,EAAOzC,MAAOyC,EAAOnoG,IACzD,CAEE,OAAOioG,CACT,EM/QgB,IAAIl9E,YAAY,oCCMiF5Q,QAAqC,SAAS75B,IAAI,IAA0FkS,EAAtFlZ,EAAE,oBAAoB2yH,KAAKA,KAAK,oBAAoB5nG,OAAOA,YAAO,IAAS/qB,EAAEA,EAAE,CAAA,EAASqD,GAAGrD,EAAE4yH,YAAY5yH,EAAE6yH,YAAYvrH,EAAEtH,EAAE8yH,iBAAgB,EAAG7/E,EAAE,CAAA,EAAGvzC,EAAE,EAAEsC,EAAE,CAAA,EAAG,SAAS4Z,EAAEnY,GAAG3F,KAAKi1H,QAAQ,KAAKj1H,KAAKk1H,WAAU,EAAGl1H,KAAKm1H,YAAW,EAAGn1H,KAAKo1H,SAAQ,EAAGp1H,KAAKq1H,OAAO,KAAKr1H,KAAKs1H,WAAW,EAAEt1H,KAAKu1H,aAAa,GAAGv1H,KAAKw1H,UAAU,EAAEx1H,KAAKy1H,OAAO,EAAEz1H,KAAK01H,WAAW,KAAK11H,KAAK21H,cAAa,EAAG31H,KAAK41H,iBAAiB,CAAC11H,KAAK,GAAG21H,OAAO,GAAG3zF,KAAK,CAAA,GAAI,SAASv8B,GAAG,IAAI6P,EAAE/L,EAAE9D,GAAG6P,EAAEsgH,UAAUnsH,SAAS6L,EAAEsgH,WAAWnwH,EAAE4d,MAAM5d,EAAEowH,QAAQvgH,EAAEsgH,UAAU,MAAM91H,KAAKi1H,QAAQ,IAAIr9H,EAAE4d,IAAIxV,KAAKi1H,QAAQe,SAASh2H,MAAMi2H,QAAQzgH,CAAC,EAAErf,KAAK6J,KAAK2F,GAAG3F,KAAKk2H,WAAW,SAAS1gH,EAAE7P,GAAG,IAAI/N,EAAE+R,SAAS3J,KAAKi2H,QAAQE,kBAAkB,EAAE,GAAGn2H,KAAK21H,cAAc,EAAE/9H,EAAE,CAAC,IAAI+N,EAAE3F,KAAKi2H,QAAQG,QAAQzwH,IAAIuD,EAAElJ,KAAKi2H,QAAQI,WAAW,IAAI1wH,EAAE3F,KAAKi1H,QAAQqB,iBAAiB9gH,EAAEtM,IAAIsM,EAAE,IAAIA,EAAEs6B,MAAMnqC,GAAG1O,MAAMW,IAAI+E,KAAKgJ,EAAE,CAAC3F,KAAK21H,cAAch+G,EAAE3X,KAAKi2H,QAAQM,wBAAmB,KAAUrtH,EAAElJ,KAAKi2H,QAAQM,iBAAiB/gH,MAAMA,EAAEtM,GAAGlJ,KAAK21H,cAAa,EAAG31H,KAAKo1H,SAAQ,EAAOx9H,EAAEoI,KAAKu1H,aAAa//G,EAAxB,IAA0BtM,GAAGlJ,KAAKu1H,aAAa,GAAGv1H,KAAKi1H,QAAQjuF,MAAMpvC,EAAEoI,KAAKs1H,YAAYt1H,KAAKk1H,YAAY,IAAIl1H,KAAKi1H,QAAQuB,WAAWx2H,KAAKi1H,QAAQwB,UAAU,CAAgO,GAA/NjhH,EAAEtM,EAAEg5B,KAAKw0F,OAAU12H,KAAKk1H,YAAYl1H,KAAKu1H,aAAa39H,EAAEomD,UAAUxoC,EAAExV,KAAKs1H,YAAYt1H,KAAKs1H,WAAW9/G,GAAGtM,GAAGA,EAAEhJ,OAAOF,KAAKw1H,WAAWtsH,EAAEhJ,KAAK1J,QAA3HoB,EAAmIoI,KAAKk1H,WAAWl1H,KAAKi2H,QAAQU,SAAS32H,KAAKw1H,WAAWx1H,KAAKi2H,QAAQU,QAAYntH,EAAEtH,EAAE6yH,YAAY,CAAC50G,QAAQjX,EAAE0tH,SAAS1yH,EAAE2yH,UAAUC,SAASl/H,SAAS,GAAG+f,EAAE3X,KAAKi2H,QAAQF,SAASpwH,EAAE,CAAC,GAAG3F,KAAKi2H,QAAQF,MAAM7sH,EAAElJ,KAAKi1H,SAASj1H,KAAKi1H,QAAQuB,UAAUx2H,KAAKi1H,QAAQwB,UAAU,YAAYz2H,KAAKo1H,SAAQ,GAAIp1H,KAAK41H,iBAAiB1sH,OAAE,CAAM,CAAC,OAAOlJ,KAAKi2H,QAAQ1yG,MAAMvjB,KAAKi2H,QAAQF,QAAQ/1H,KAAK41H,iBAAiB11H,KAAKF,KAAK41H,iBAAiB11H,KAAKowB,OAAOpnB,EAAEhJ,MAAMF,KAAK41H,iBAAiBC,OAAO71H,KAAK41H,iBAAiBC,OAAOvlG,OAAOpnB,EAAE2sH,QAAQ71H,KAAK41H,iBAAiB1zF,KAAKh5B,EAAEg5B,MAAMliC,KAAKm1H,aAAav9H,IAAI+f,EAAE3X,KAAKi2H,QAAQc,WAAW7tH,GAAGA,EAAEg5B,KAAKu0F,UAAUz2H,KAAKi2H,QAAQc,SAAS/2H,KAAK41H,iBAAiB51H,KAAKq1H,QAAQr1H,KAAKm1H,YAAW,GAAIv9H,GAAGsR,GAAGA,EAAEg5B,KAAKs0F,QAAQx2H,KAAK01H,aAAaxsH,CAAC,CAAClJ,KAAKo1H,SAAQ,CAAE,EAAEp1H,KAAKg3H,WAAW,SAASrxH,GAAGgS,EAAE3X,KAAKi2H,QAAQn7G,OAAO9a,KAAKi2H,QAAQn7G,MAAMnV,GAAG6D,GAAGxJ,KAAKi2H,QAAQn7G,OAAO5Y,EAAE6yH,YAAY,CAAC6B,SAAS1yH,EAAE2yH,UAAU/7G,MAAMnV,EAAEmxH,UAAS,GAAI,CAAC,CAAC,SAASr+G,EAAE9S,GAAG,IAAIuD,GAAGvD,EAAEA,GAAG,CAAA,GAAImwH,YAAYnwH,EAAEmwH,UAAU5xH,EAAE+yH,iBAAiBn5G,EAAE3nB,KAAK6J,KAAK2F,GAAG3F,KAAK01H,WAAWnwH,EAAE,WAAWvF,KAAKk3H,aAAal3H,KAAKm3H,cAAc,EAAE,WAAWn3H,KAAKk3H,YAAY,EAAEl3H,KAAKo3H,OAAO,SAASzxH,GAAG3F,KAAKq1H,OAAO1vH,EAAE3F,KAAK01H,YAAY,EAAE11H,KAAKk3H,WAAW,WAAW,GAAGl3H,KAAKk1H,UAAUl1H,KAAKm3H,mBAAmB,CAAC,GAAGjuH,EAAE,IAAImuH,eAAer3H,KAAKi2H,QAAQqB,kBAAkBpuH,EAAEouH,gBAAgBt3H,KAAKi2H,QAAQqB,iBAAiB/xH,IAAI2D,EAAEquH,OAAO7uH,EAAE1I,KAAKm3H,aAAan3H,MAAMkJ,EAAEsuH,QAAQ9uH,EAAE1I,KAAKy3H,YAAYz3H,OAAOkJ,EAAEg+G,KAAKlnH,KAAKi2H,QAAQyB,oBAAoB,OAAO,MAAM13H,KAAKq1H,QAAQ9vH,GAAGvF,KAAKi2H,QAAQ0B,uBAAuB,CAAC,IAAIhyH,EAAE6P,EAAExV,KAAKi2H,QAAQ0B,uBAAuB,IAAIhyH,KAAK6P,EAAEtM,EAAE0uH,iBAAiBjyH,EAAE6P,EAAE7P,GAAG,CAAC,IAAI/N,EAAEoI,KAAKi2H,QAAQH,YAAYl+H,EAAEoI,KAAKy1H,OAAOz1H,KAAKi2H,QAAQH,UAAU,EAAE5sH,EAAE0uH,iBAAiB,QAAQ,SAAS53H,KAAKy1H,OAAO,IAAI79H,IAAI,IAAIsR,EAAE2uH,KAAK73H,KAAKi2H,QAAQyB,oBAAoB,CAAC,MAAM/xH,GAAG3F,KAAKy3H,YAAY9xH,EAAE0+B,QAAQ,CAAC9+B,GAAG,IAAI2D,EAAE4uH,QAAQ93H,KAAKy3H,aAAa,CAAC,EAAEz3H,KAAKm3H,aAAa,WAAW,IAAIjuH,EAAE6uH,aAAa7uH,EAAE4uH,OAAO,KAAK,KAAK5uH,EAAE4uH,OAAO93H,KAAKy3H,eAAez3H,KAAKy1H,QAAQz1H,KAAKi2H,QAAQH,WAAW5sH,EAAE8uH,aAAaxhI,OAAOwJ,KAAKk1H,WAAWl1H,KAAKi2H,QAAQH,WAAW91H,KAAKy1H,QAAQ,CAAC9vH,GAAG,QAAQA,EAAEA,EAAEsyH,kBAAkB,kBAAkBtuH,SAAShE,EAAEq4C,UAAUr4C,EAAE6jD,YAAY,KAAK,KAAI,EAAhG,CAAoGtgD,GAAGlJ,KAAKk2H,WAAWhtH,EAAE8uH,eAAe,EAAEh4H,KAAKy3H,YAAY,SAAS9xH,GAAGA,EAAEuD,EAAEgvH,YAAYvyH,EAAE3F,KAAKg3H,WAAW,IAAI7+H,MAAMwN,GAAG,CAAC,CAAC,SAASxF,EAAEwF,IAAIA,EAAEA,GAAG,IAAImwH,YAAYnwH,EAAEmwH,UAAU5xH,EAAEi0H,gBAAgBr6G,EAAE3nB,KAAK6J,KAAK2F,GAAG,IAAI/N,EAAEsR,EAAEhH,EAAE,oBAAoBk2H,WAAWp4H,KAAKo3H,OAAO,SAASzxH,GAAG3F,KAAKq1H,OAAO1vH,EAAEuD,EAAEvD,EAAE1O,OAAO0O,EAAE0yH,aAAa1yH,EAAE2yH,SAASp2H,IAAItK,EAAE,IAAIwgI,YAAYb,OAAO7uH,EAAE1I,KAAKm3H,aAAan3H,MAAMpI,EAAE4/H,QAAQ9uH,EAAE1I,KAAKy3H,YAAYz3H,OAAOpI,EAAE,IAAI2gI,eAAev4H,KAAK01H,YAAY,EAAE11H,KAAK01H,WAAW,WAAW11H,KAAKk1H,WAAWl1H,KAAKi2H,QAAQU,WAAW32H,KAAKw1H,UAAUx1H,KAAKi2H,QAAQU,UAAU32H,KAAKk3H,YAAY,EAAEl3H,KAAKk3H,WAAW,WAAW,IAAIvxH,EAAE3F,KAAKq1H,OAAO7/G,GAAGxV,KAAKi2H,QAAQH,YAAYtgH,EAAEzd,KAAK0C,IAAIuF,KAAKy1H,OAAOz1H,KAAKi2H,QAAQH,UAAU91H,KAAKq1H,OAAO50H,MAAMkF,EAAEuD,EAAE/S,KAAKwP,EAAE3F,KAAKy1H,OAAOjgH,IAAI5d,EAAE4gI,WAAW7yH,EAAE3F,KAAKi2H,QAAQxiF,WAAWvxC,GAAGlC,KAAKm3H,aAAa,CAAC9+H,OAAO,CAACgE,OAAOmZ,IAAI,EAAExV,KAAKm3H,aAAa,SAASxxH,GAAG3F,KAAKy1H,QAAQz1H,KAAKi2H,QAAQH,UAAU91H,KAAKk1H,WAAWl1H,KAAKi2H,QAAQH,WAAW91H,KAAKy1H,QAAQz1H,KAAKq1H,OAAO50H,KAAKT,KAAKk2H,WAAWvwH,EAAEtN,OAAOgE,OAAO,EAAE2D,KAAKy3H,YAAY,WAAWz3H,KAAKg3H,WAAWp/H,EAAEkjB,MAAM,CAAC,CAAC,SAAS3R,EAAExD,GAAG,IAAI/N,EAAEkmB,EAAE3nB,KAAK6J,KAAK2F,EAAEA,GAAG,CAAA,GAAI3F,KAAKo3H,OAAO,SAASzxH,GAAG,OAAO/N,EAAE+N,EAAE3F,KAAK01H,YAAY,EAAE11H,KAAK01H,WAAW,WAAW,IAAI/vH,EAAE6P,EAAE,IAAIxV,KAAKk1H,UAAU,OAAOvvH,EAAE3F,KAAKi2H,QAAQH,UAAUl+H,EAAE+N,GAAG6P,EAAE5d,EAAEomD,UAAU,EAAEr4C,GAAG/N,EAAEomD,UAAUr4C,KAAK6P,EAAE5d,EAAE,IAAIoI,KAAKk1H,WAAWt9H,EAAEoI,KAAKk2H,WAAW1gH,EAAE,CAAC,CAAC,SAASpT,EAAEuD,GAAGmY,EAAE3nB,KAAK6J,KAAK2F,EAAEA,GAAG,CAAA,GAAI,IAAI6P,EAAE,GAAG5d,GAAE,EAAGsR,GAAE,EAAGlJ,KAAKy4H,MAAM,WAAW36G,EAAE/nB,UAAU0iI,MAAM/3H,MAAMV,KAAK9F,WAAW8F,KAAKq1H,OAAOoD,OAAO,EAAEz4H,KAAK04H,OAAO,WAAW56G,EAAE/nB,UAAU2iI,OAAOh4H,MAAMV,KAAK9F,WAAW8F,KAAKq1H,OAAOqD,QAAQ,EAAE14H,KAAKo3H,OAAO,SAASzxH,GAAG3F,KAAKq1H,OAAO1vH,EAAE3F,KAAKq1H,OAAOsD,GAAG,OAAO34H,KAAK44H,aAAa54H,KAAKq1H,OAAOsD,GAAG,MAAM34H,KAAK64H,YAAY74H,KAAKq1H,OAAOsD,GAAG,QAAQ34H,KAAK84H,aAAa,EAAE94H,KAAK+4H,iBAAiB,WAAW7vH,GAAG,IAAIsM,EAAEhf,SAASwJ,KAAKk1H,WAAU,EAAG,EAAEl1H,KAAK01H,WAAW,WAAW11H,KAAK+4H,mBAAmBvjH,EAAEhf,OAAOwJ,KAAKk2H,WAAW1gH,EAAEyD,SAASrhB,GAAE,CAAE,EAAEoI,KAAK44H,YAAYlwH,EAAE,SAAS/C,GAAG,IAAI6P,EAAE/Y,KAAK,iBAAiBkJ,EAAEA,EAAEA,EAAE9P,SAASmK,KAAKi2H,QAAQxiF,WAAW77C,IAAIA,GAAE,EAAGoI,KAAK+4H,mBAAmB/4H,KAAKk2H,WAAW1gH,EAAEyD,SAAS,CAAC,MAAMtT,GAAG3F,KAAK84H,aAAanzH,EAAE,CAAC,EAAE3F,MAAMA,KAAK84H,aAAapwH,EAAE,SAAS/C,GAAG3F,KAAKg5H,iBAAiBh5H,KAAKg3H,WAAWrxH,EAAE,EAAE3F,MAAMA,KAAK64H,WAAWnwH,EAAE,WAAW1I,KAAKg5H,iBAAiB9vH,GAAE,EAAGlJ,KAAK44H,YAAY,GAAG,EAAE54H,MAAMA,KAAKg5H,eAAetwH,EAAE,WAAW1I,KAAKq1H,OAAO4D,eAAe,OAAOj5H,KAAK44H,aAAa54H,KAAKq1H,OAAO4D,eAAe,MAAMj5H,KAAK64H,YAAY74H,KAAKq1H,OAAO4D,eAAe,QAAQj5H,KAAK84H,aAAa,EAAE94H,KAAK,CAAC,SAASpI,EAAEqK,GAAG,IAAIC,EAAEqD,EAAEiE,EAAEgM,EAAE2/B,EAAEp9C,KAAKob,IAAI,EAAE,IAAIvR,GAAGuzC,EAAEr3B,EAAE,mDAAmD1C,EAAE,qNAAqNxjB,EAAEoI,KAAKkJ,EAAE,EAAEuP,EAAE,EAAEtY,GAAE,EAAGwF,GAAE,EAAGwD,EAAE,GAAG/G,EAAE,CAAClC,KAAK,GAAG21H,OAAO,GAAG3zF,KAAK,CAAA,GAAI,SAASx5B,EAAE/C,GAAG,MAAM,WAAW1D,EAAEi3H,eAAe,KAAKvzH,EAAEhJ,KAAK,IAAIsqC,OAAO,IAAIthC,EAAEnP,QAAQ,IAAImP,EAAE,GAAGnP,MAAM,CAAC,SAAS0iB,IAAI,GAAG9W,GAAGoH,IAAI/H,EAAE,YAAY,wBAAwB,6DAA6DyC,EAAEi1H,iBAAiB,KAAK3vH,GAAE,GAAIvH,EAAEi3H,iBAAiB92H,EAAElC,KAAKkC,EAAElC,KAAKqpB,OAAO,SAAS5jB,GAAG,OAAO+C,EAAE/C,EAAE,IAAIwyC,IAAI,CAAC,GAAG/1C,EAAE,GAAGjI,MAAMi+B,QAAQh2B,EAAElC,KAAK,IAAI,CAAC,IAAI,IAAIyF,EAAE,EAAEwyC,KAAKxyC,EAAEvD,EAAElC,KAAK1J,OAAOmP,IAAIvD,EAAElC,KAAKyF,GAAG4wB,QAAQ/gB,GAAGpT,EAAElC,KAAKwO,OAAO,EAAE,EAAE,MAAMtM,EAAElC,KAAKq2B,QAAQ/gB,GAAG,SAASA,EAAE7P,EAAE6P,GAAGmC,EAAE1V,EAAEm3H,mBAAmBzzH,EAAE1D,EAAEm3H,gBAAgBzzH,EAAE6P,IAAIrM,EAAE1M,KAAKkJ,EAAE,CAAC,CAAC,SAAS/N,EAAE+N,EAAE6P,GAAG,IAAI,IAAI5d,EAAEqK,EAAE25C,OAAO,CAAA,EAAG,GAAG1yC,EAAE,EAAEA,EAAEvD,EAAEnP,OAAO0S,IAAI,CAAC,IAAIhH,EAAEgH,EAAE3D,EAAEI,EAAEuD,GAAG3D,EAAE,EAAEI,EAAE6P,IAAI,CAAC7P,IAAI1D,EAAEo3H,4BAAuB,IAASp3H,EAAEk3C,cAAcxzC,KAAK1D,EAAEk3C,cAAcxzC,GAAG1D,EAAEo3H,sBAAsB1zH,KAAI,KAAM1D,EAAEk3C,cAAcxzC,IAAI1D,EAAEk3C,gBAAvI,CAAwJxzC,GAAG,SAAS6P,GAAG,SAASA,GAAG,UAAUA,GAAG,UAAUA,IAAI,CAAC7P,IAAI,GAAGmY,EAAE0pB,KAAK7hC,KAAIA,EAAEyhC,WAAWzhC,GAAM/D,EAAE+D,GAAGA,EAAEwvC,GAAE,OAAO,CAAG,EAAzD,CAA2D3/B,GAAG4xB,WAAW5xB,GAAG4F,EAAEosB,KAAKhyB,GAAG,IAAIgtB,KAAKhtB,GAAG,KAAKA,EAAE,KAAKA,GAAGA,EAAvU,CAA0UtT,EAAED,EAAE25C,OAAO1yC,GAAGC,EAAE3S,OAAO,iBAAiB2S,EAAED,GAAGhH,EAAEqD,EAAEtD,EAAE+gB,UAAU/gB,EAAE+gB,UAAUzd,EAAErD,GAAGqD,GAAG,mBAAmBrD,GAAGtK,EAAEsK,GAAGtK,EAAEsK,IAAI,GAAGtK,EAAEsK,GAAGzF,KAAK8I,IAAI3N,EAAEsK,GAAGqD,CAAC,CAAC,OAAOtD,EAAE25C,SAAS1yC,EAAEC,EAAE3S,OAAOiL,EAAE,gBAAgB,gBAAgB,6BAA6B0H,EAAE3S,OAAO,sBAAsB0S,EAAEuP,EAAEjD,GAAGtM,EAAEC,EAAE3S,QAAQiL,EAAE,gBAAgB,eAAe,4BAA4B0H,EAAE3S,OAAO,sBAAsB0S,EAAEuP,EAAEjD,IAAI5d,CAAC,CAAC,IAAIsR,EAAE9G,IAAIH,EAAE25C,QAAQ35C,EAAEk3C,eAAel3C,EAAE+gB,aAAa9Z,EAAE,GAAG9G,EAAElC,KAAK1J,QAAQ2D,MAAMi+B,QAAQh2B,EAAElC,KAAK,KAAKkC,EAAElC,KAAKkC,EAAElC,KAAKkuB,IAAIx2B,GAAGsR,EAAE9G,EAAElC,KAAK1J,QAAQ4L,EAAElC,KAAKtI,EAAEwK,EAAElC,KAAK,GAAG+B,EAAE25C,QAAQx5C,EAAE8/B,OAAO9/B,EAAE8/B,KAAKi5C,OAAOhyE,GAAGsP,GAAGvP,EAAE,CAAC,SAASivC,IAAI,OAAOl2C,EAAE25C,QAAQ,IAAIzyC,EAAE3S,MAAM,CAAC,SAASiL,EAAEkE,EAAE6P,EAAE5d,EAAEsR,GAAGvD,EAAE,CAACd,KAAKc,EAAEk0D,KAAKrkD,EAAE6uB,QAAQzsC,YAAYsR,IAAIvD,EAAEzG,IAAIgK,GAAG9G,EAAEyzH,OAAOp5H,KAAKkJ,EAAE,CAACgS,EAAE1V,EAAEshB,QAAQ/N,EAAEvT,EAAEshB,KAAKthB,EAAEshB,KAAK,SAAS5d,GAAGvD,EAAEuD,EAAEwyC,IAAIj/B,KAAKA,IAAI,IAAI9W,EAAElC,KAAK1J,SAAS0S,GAAGvD,EAAEzF,KAAK1J,OAAOyL,EAAE00H,SAASztH,EAAEjH,EAAE00H,QAAQpxH,EAAE+zH,SAASl3H,EAAElC,KAAKkC,EAAElC,KAAK,GAAGsV,EAAEpT,EAAExK,KAAK,GAAGoI,KAAKgnC,MAAM,SAASrhC,EAAE6P,EAAE5d,GAAG,IAAIsR,EAAEjH,EAAEo0H,WAAW,IAAiyB,OAA1xBp0H,EAAEm0H,UAAUn0H,EAAEm0H,QAAQp2H,KAAKs2H,iBAAiB3wH,EAAEuD,IAAIM,GAAE,EAAGvH,EAAEs3H,UAAU5hH,EAAE1V,EAAEs3H,aAAat3H,EAAEs3H,UAAUt3H,EAAEs3H,UAAU5zH,GAAGvD,EAAE8/B,KAAKq3F,UAAUt3H,EAAEs3H,aAAarwH,EAAE,EAAEvD,EAAE6P,EAAE5d,EAAEsR,EAAEhH,KAAK,IAAIqD,EAAEiE,EAAE2rC,EAAEvzC,EAAEM,EAAEA,GAAG,CAAC,IAAI,KAAK,IAAI,IAAIgC,EAAEs1H,WAAWt1H,EAAEu1H,UAAU,IAAI,IAAI37G,EAAE,EAAEA,EAAE5b,EAAE1L,OAAOsnB,IAAI,CAAC,IAAI,IAAI1C,EAAE3C,EAAEvW,EAAE4b,GAAG3d,EAAE,EAAEgJ,EAAE,EAAE/G,EAAE,EAAE8W,GAAGi8B,OAAE,EAAO,IAAID,EAAE,CAACygD,SAASzsF,EAAEqwH,UAAU9gH,EAAE29G,QAAQ5gH,EAAEmhH,QAAQ,KAAK3vF,MAAMrhC,IAAIwyC,EAAE,EAAEA,EAAEj/B,EAAEhZ,KAAK1J,OAAO2hD,IAAIvgD,GAAG8Q,EAAEwQ,EAAEhZ,KAAKi4C,IAAI/1C,KAAwB+G,GAAnBiS,EAAElC,EAAEhZ,KAAKi4C,GAAG3hD,YAAY,IAAS2+C,EAAEA,EAAE/5B,EAAE,EAAEA,IAAIjb,GAAGpI,KAAKQ,IAAI6iB,EAAE+5B,GAAGA,EAAE/5B,IAAI,EAAElC,EAAEhZ,KAAK1J,SAAS2S,GAAG+P,EAAEhZ,KAAK1J,OAAO4L,SAAI,IAASoH,GAAGrJ,GAAGqJ,UAAK,IAAS5H,GAAGA,EAAEuH,IAAI,KAAKA,IAAIK,EAAErJ,EAAEoF,EAAEkT,EAAE7W,EAAEuH,EAAE,CAAC,MAAM,CAACuwH,cAAcz3H,EAAEs3H,UAAUh0H,GAAGo0H,cAAcp0H,EAAG,EAAxd,CAA0dI,EAAE1D,EAAEm0H,QAAQn0H,EAAEi3H,eAAej3H,EAAE0zF,SAAS1zF,EAAE23H,oBAAoBF,WAAWz3H,EAAEs3H,UAAUrwH,EAAEywH,eAAenwH,GAAE,EAAGvH,EAAEs3H,UAAUr1H,EAAEi1H,kBAAkB/2H,EAAE8/B,KAAKq3F,UAAUt3H,EAAEs3H,WAA5wBrwH,EAAuxBO,EAAExH,GAAWA,EAAE00H,SAAS10H,EAAE25C,QAAQ1yC,EAAEytH,UAAUz0H,EAAEyD,EAAEJ,EAAE,IAAI2vC,EAAEhsC,GAAG9G,EAAEmD,EAAEyhC,MAAM9kC,EAAEsT,EAAE5d,GAAGshB,IAAI/Y,EAAE,CAAC+hC,KAAK,CAACs0F,QAAO,IAAKp0H,GAAG,CAAC8/B,KAAK,CAACs0F,QAAO,GAAI,EAAEx2H,KAAKw2H,OAAO,WAAW,OAAOr2H,CAAC,EAAEH,KAAKy4H,MAAM,WAAWt4H,GAAE,EAAGoF,EAAE+zH,QAAQp3H,EAAEyV,EAAE1V,EAAE8zH,OAAO,GAAG7zH,EAAE87C,UAAUz4C,EAAEs0H,eAAe,EAAE75H,KAAK04H,OAAO,WAAW9gI,EAAEo+H,SAASZ,SAASj1H,GAAE,EAAGvI,EAAEo+H,SAASE,WAAWh0H,GAAE,IAAK43H,WAAWliI,EAAE8gI,OAAO,EAAE,EAAE14H,KAAKy2H,QAAQ,WAAW,OAAO9wH,CAAC,EAAE3F,KAAKs5H,MAAM,WAAW3zH,GAAE,EAAGJ,EAAE+zH,QAAQl3H,EAAE8/B,KAAKu0F,SAAQ,EAAG9+G,EAAE1V,EAAE80H,WAAW90H,EAAE80H,SAAS30H,GAAGF,EAAE,EAAE,EAAElC,KAAKs2H,iBAAiB,SAAS3wH,EAAE6P,GAAG7P,EAAEA,EAAEq4C,UAAU,EAAE,SAAaxoC,EAAE,IAAImxB,OAAOle,EAAEjT,GAAG,UAAUiT,EAAEjT,GAAG,MAArC,IAA2C5d,GAAG+N,EAAEA,EAAE+sB,QAAQld,EAAE,KAAKs6B,MAAM,MAA4D,GAAtCnqC,EAAE,GAAlB6P,EAAE7P,EAAEmqC,MAAM,OAAYt5C,QAAQgf,EAAE,GAAGhf,OAAOoB,EAAE,GAAGpB,OAAU,IAAIoB,EAAEpB,QAAQmP,EAAE,MAAM,KAAK,IAAI,IAAIuD,EAAE,EAAEhH,EAAE,EAAEA,EAAEtK,EAAEpB,OAAO0L,IAAI,OAAOtK,EAAEsK,GAAG,IAAIgH,IAAI,OAAOA,GAAGtR,EAAEpB,OAAO,EAAE,OAAO,IAAI,CAAC,CAAC,SAASiyB,EAAE9iB,GAAG,OAAOA,EAAE+sB,QAAQ,sBAAsB,OAAO,CAAC,SAASwiB,EAAElxB,GAAG,IAAIqyB,GAAGryB,EAAEA,GAAG,CAAA,GAAIu1G,UAAU5jF,EAAE3xB,EAAEoyG,QAAQt9H,EAAEkrB,EAAE2xE,SAASv/C,EAAEpyB,EAAET,KAAKQ,EAAEC,EAAE2yG,QAAQt+E,EAAEr0B,EAAE+1G,SAAS91G,EAAE,KAAK1G,GAAE,EAAGyc,EAAE,MAAMhW,EAAEqyG,UAAU,IAAIryG,EAAEqyG,UAAUx+H,EAAEmiC,EAAE,YAAYhW,EAAEg2G,aAAaniI,EAAEmsB,EAAEg2G,aAAa,iBAAiB3jF,IAAG,EAAGnyC,EAAE+1H,eAAenkG,QAAQugB,MAAMA,EAAE,KAAKv9C,IAAIu9C,EAAE,MAAM,IAAIl+C,MAAM,wCAAuC,IAAKW,EAAEA,EAAE,KAAK,iBAAiBA,IAAG,EAAGoL,EAAE+1H,eAAenkG,QAAQh9B,MAAMA,GAAE,GAAI,OAAO68C,GAAG,OAAOA,GAAG,SAASA,IAAIA,EAAE,MAAM,IAAIl5B,EAAE,EAAE0W,GAAE,EAAGnzB,KAAKgnC,MAAM,SAASpvC,EAAE4d,EAAEtM,GAAG,GAAG,iBAAiBtR,EAAE,MAAM,IAAIO,MAAM,0BAA0B,IAAI+J,EAAEtK,EAAEpB,OAAOmP,EAAE0wC,EAAE7/C,OAAO+O,EAAEowC,EAAEn/C,OAAOgT,EAAE1Q,EAAEtC,OAAO2+C,EAAEx9B,EAAEy+B,GAAGx0C,EAAE,GAAGkc,EAAE,GAAG1C,EAAE,GAAG3C,EAAEgE,EAAE,EAAE,IAAI7kB,EAAE,OAAOqkB,IAAI,GAAGo8B,IAAG,IAAKA,IAAG,IAAKzgD,EAAEk+B,QAAQkE,GAAG,CAAC,IAAI,IAAI75B,EAAEvI,EAAEk4C,MAAM6F,GAAGxsC,EAAE,EAAEA,EAAEhJ,EAAE3J,OAAO2S,IAAI,CAAC,GAAGiS,EAAEjb,EAAEgJ,GAAGsT,GAAGrB,EAAE5kB,OAAO2S,IAAIhJ,EAAE3J,OAAO,EAAEimB,GAAGk5B,EAAEn/C,YAAY,GAAG0S,EAAE,OAAO+S,IAAI,IAAInjB,GAAGsiB,EAAE4iC,UAAU,EAAEx0C,KAAK1Q,EAAE,CAAC,GAAGq8C,GAAG,GAAGvzC,EAAE,GAAGH,EAAE2Z,EAAE00B,MAAMuG,IAAIyD,IAAI3mB,EAAE,OAAOlX,SAASxa,EAAE2Z,EAAE00B,MAAMuG,IAAI,GAAGtyB,GAAGA,GAAG5a,EAAE,OAAOvH,EAAEA,EAAE3K,MAAM,EAAE8sB,GAAG9H,GAAE,EAAG,CAAC,CAAC,OAAOA,GAAG,CAAC,IAAI,IAAI7Z,EAAExK,EAAEk+B,QAAQugB,EAAE55B,GAAGvD,EAAEthB,EAAEk+B,QAAQ6f,EAAEl5B,GAAG07B,EAAE,IAAIxR,OAAOle,EAAE5wB,GAAG4wB,EAAEuR,GAAG,KAAK/3B,EAAErK,EAAEk+B,QAAQkE,EAAEvd,KAAK,GAAG7kB,EAAE6kB,KAAKud,EAAE,IAAI/3B,EAAEwa,EAAEA,MAAM,CAAC,SAASxa,EAAErK,EAAEk+B,QAAQkE,EAAE/3B,EAAE,IAAI,OAAOiH,GAAG4U,EAAErhB,KAAK,CAACoI,KAAK,SAASg1D,KAAK,gBAAgBx1B,QAAQ,4BAA4BnlC,IAAI0C,EAAEpL,OAAOgC,MAAMikB,IAAIy4B,IAAI,GAAGjzC,IAAIC,EAAE,EAAE,OAAOgzC,EAAEt9C,EAAEomD,UAAUvhC,EAAExa,GAAGywB,QAAQylB,EAAEne,IAAI,GAAGA,IAAIniC,GAAGD,EAAEqK,EAAE,KAAKpK,EAAEoK,SAAS,GAAG+3B,IAAIniC,GAAG,IAAIoK,GAAGrK,EAAEqK,EAAE,KAAKpK,EAAE,EAAC,IAAKuK,GAAGA,EAAEH,EAAE,IAAIG,EAAExK,EAAEk+B,QAAQugB,EAAEp0C,EAAE,IAAI,IAAIyG,EAAExE,GAAE,KAAMgV,OAAOA,GAAGA,EAAEjX,EAAE,EAAErK,EAAEk+B,QAAQ6f,EAAE1zC,EAAE,GAAGiX,GAAG9W,EAAErK,KAAK0C,IAAI2H,EAAE8W,IAAI,GAAGthB,EAAEguC,OAAO3jC,EAAE,EAAEyG,EAAE/C,KAAK0wC,EAAE,CAACj7B,EAAE3e,KAAK7E,EAAEomD,UAAUvhC,EAAExa,GAAGywB,QAAQylB,EAAEne,IAAIpiC,EAAE6kB,EAAExa,EAAE,EAAEyG,EAAE/C,KAAKq0B,IAAI/3B,EAAErK,EAAEk+B,QAAQkE,EAAEvd,IAAIra,EAAExK,EAAEk+B,QAAQugB,EAAE55B,GAAGvD,EAAEthB,EAAEk+B,QAAQ6f,EAAEl5B,GAAG,KAAK,CAAQ,GAAP/T,EAAExE,EAAEgV,GAAMthB,EAAEomD,UAAU/7C,EAAE,EAAEyG,EAAEzG,EAAE,EAAEyG,EAAEnD,KAAKowC,EAAE,CAAC,GAAGv6B,EAAE3e,KAAK7E,EAAEomD,UAAUvhC,EAAExa,GAAGywB,QAAQylB,EAAEne,IAAIvwB,EAAExH,EAAE,EAAEyG,EAAEnD,GAAGnD,EAAExK,EAAEk+B,QAAQugB,EAAE55B,GAAGxa,EAAErK,EAAEk+B,QAAQkE,EAAEvd,GAAG04B,IAAI2E,IAAI3mB,GAAG,OAAOlX,IAAI,GAAG8H,GAAGniB,EAAEpL,QAAQutB,EAAE,OAAO9H,GAAE,GAAI,KAAK,CAAC6B,EAAErhB,KAAK,CAACoI,KAAK,SAASg1D,KAAK,gBAAgBx1B,QAAQ,8CAA8CnlC,IAAI0C,EAAEpL,OAAOgC,MAAMikB,IAAIxa,GAAG,CAAC,MAAM,GAAGnJ,GAAG,IAAIsiB,EAAE5kB,QAAQoB,EAAEomD,UAAUvhC,EAAEA,EAAEjT,KAAK1Q,EAAE,CAAC,IAAG,IAAKogB,EAAE,OAAO+C,IAAIQ,EAAEvD,EAAE3T,EAAE2T,EAAEthB,EAAEk+B,QAAQ6f,EAAEl5B,GAAGra,EAAExK,EAAEk+B,QAAQugB,EAAE55B,EAAE,MAAM,IAAG,IAAKra,IAAIA,EAAE8W,IAAG,IAAKA,GAAGkC,EAAE3e,KAAK7E,EAAEomD,UAAUvhC,EAAEra,IAAIqa,EAAEra,EAAEuD,EAAEvD,EAAExK,EAAEk+B,QAAQugB,EAAE55B,OAAO,CAAC,IAAG,IAAKvD,EAAE,MAAM,GAAGkC,EAAE3e,KAAK7E,EAAEomD,UAAUvhC,EAAEvD,IAAIzP,EAAEyP,EAAE3T,GAAG4vC,IAAI2E,IAAI3mB,GAAG,OAAOlX,IAAI,GAAG8H,GAAGniB,EAAEpL,QAAQutB,EAAE,OAAO9H,GAAE,EAAG,CAAC,OAAOi5B,IAAI,SAASzzC,EAAEkE,GAAG/D,EAAEnF,KAAKkJ,GAAG8S,EAAEgE,CAAC,CAAC,SAASvY,EAAEyB,GAAG,IAAI6P,EAAE,EAAE,OAAS,IAAK7P,IAAIA,EAAE/N,EAAEomD,UAAU/7C,EAAE,EAAE0D,KAAK,KAAKA,EAAEshC,OAAOthC,EAAEnP,OAAOgf,CAAC,CAAC,SAAS0/B,EAAEvvC,GAAG,OAAOuD,aAAavD,IAAIA,EAAE/N,EAAEomD,UAAUvhC,IAAIrB,EAAE3e,KAAKkJ,GAAG8W,EAAEva,EAAET,EAAE2Z,GAAG+5B,GAAG2E,KAAK79B,GAAG,CAAC,SAASxS,EAAE9D,GAAG8W,EAAE9W,EAAElE,EAAE2Z,GAAGA,EAAE,GAAGlC,EAAEthB,EAAEk+B,QAAQ6f,EAAEl5B,EAAE,CAAC,SAASR,EAAEtW,GAAG,GAAGqe,EAAE43B,SAASpmC,GAAG5T,EAAEpL,SAAS+mB,EAAE,CAAC,IAAIhY,EAAE3D,EAAE,GAAG4H,EAAE1T,OAAOsuC,OAAO,MAAM+Q,EAAE,IAAI7C,IAAI/sC,GAAG,IAAIrD,GAAE,EAAG,IAAI,IAAIgH,EAAE,EAAEA,EAAE3D,EAAE/O,OAAO0S,IAAI,CAAC,IAAItR,EAAE2N,EAAE2D,GAAG,GAAGM,EAAE5R,EAAE+f,EAAEqM,EAAEo1G,iBAAiBp1G,EAAEo1G,gBAAgBxhI,EAAEsR,GAAGtR,GAAG,CAAC,IAAI+N,EAAE6P,EAAEhM,EAAE5R,GAAG,KAAK+N,EAAE/N,EAAE,IAAI4d,EAAEA,IAAI2/B,EAAE5C,IAAI5sC,KAAKwvC,EAAErrC,IAAInE,GAAGJ,EAAE2D,GAAGvD,EAAE6D,EAAE5R,KAAKsK,GAAE,GAAI+hB,EAAE,OAAOA,EAAE,GAAGA,GAAGte,GAAG/N,CAAC,MAAM4R,EAAE5R,GAAG,EAAE2N,EAAE2D,GAAGtR,EAAEu9C,EAAErrC,IAAIlS,EAAE,CAACsK,GAAGmH,QAAQC,KAAK,wCAAwCiU,GAAE,CAAE,CAAC,MAAM,CAACrd,KAAK0B,EAAEi0H,OAAO/3G,EAAEokB,KAAK,CAACq3F,UAAUljF,EAAE6jF,UAAUvkF,EAAE8gF,QAAQtjG,EAAEgnG,YAAYx0H,EAAE+wH,OAAOj+G,GAAGjD,GAAG,GAAG4kH,eAAen2G,GAAG,CAAC,SAAS61B,IAAI1D,EAAEn6B,KAAKra,EAAE,GAAGkc,EAAE,EAAE,CAAC,EAAE9d,KAAKs5H,MAAM,WAAWnmG,GAAE,CAAE,EAAEnzB,KAAK65H,aAAa,WAAW,OAAOp9G,CAAC,CAAC,CAAC,SAASvD,EAAEvT,GAAG,IAAI6P,EAAE7P,EAAEzF,KAAKtI,EAAEu9C,EAAE3/B,EAAEohH,UAAU1tH,GAAE,EAAG,GAAGsM,EAAEsF,MAAMljB,EAAEyiI,UAAU7kH,EAAEsF,MAAMtF,EAAE04C,WAAW,GAAG14C,EAAE2K,SAAS3K,EAAE2K,QAAQjgB,KAAK,CAAC,IAAIgC,EAAE,CAACo3H,MAAM,WAAWpwH,GAAE,EAAGivC,EAAE3iC,EAAEohH,SAAS,CAAC12H,KAAK,GAAG21H,OAAO,GAAG3zF,KAAK,CAACu0F,SAAQ,IAAK,EAAEgC,MAAMx2H,EAAEy2H,OAAOz2H,GAAG,GAAG0V,EAAE/f,EAAE0iI,UAAU,CAAC,IAAI,IAAI/0H,EAAE,EAAEA,EAAEiQ,EAAE2K,QAAQjgB,KAAK1J,SAASoB,EAAE0iI,SAAS,CAACp6H,KAAKsV,EAAE2K,QAAQjgB,KAAKqF,GAAGswH,OAAOrgH,EAAE2K,QAAQ01G,OAAO3zF,KAAK1sB,EAAE2K,QAAQ+hB,MAAMhgC,IAAIgH,GAAG3D,YAAYiQ,EAAE2K,OAAO,MAAMxI,EAAE/f,EAAE2iI,aAAa3iI,EAAE2iI,UAAU/kH,EAAE2K,QAAQje,EAAEsT,EAAE04C,aAAa14C,EAAE2K,QAAQ,CAAC3K,EAAEshH,WAAW5tH,GAAGivC,EAAE3iC,EAAEohH,SAASphH,EAAE2K,QAAQ,CAAC,SAASg4B,EAAExyC,EAAE6P,GAAG,IAAI5d,EAAEu9C,EAAExvC,GAAGgS,EAAE/f,EAAE4iI,eAAe5iI,EAAE4iI,aAAahlH,GAAG5d,EAAE6iI,mBAAmBtlF,EAAExvC,EAAE,CAAC,SAAS1D,IAAI,MAAM,IAAI9J,MAAM,mBAAmB,CAAC,SAASsR,EAAE9D,GAAG,GAAG,iBAAiBA,GAAG,OAAOA,EAAE,OAAOA,EAAE,IAAI6P,EAAE5d,EAAEuC,MAAMi+B,QAAQzyB,GAAG,GAAG,CAAA,EAAG,IAAI6P,KAAK7P,EAAE/N,EAAE4d,GAAG/L,EAAE9D,EAAE6P,IAAI,OAAO5d,CAAC,CAAC,SAAS8Q,EAAE/C,EAAE6P,GAAG,OAAO,WAAW7P,EAAEjF,MAAM8U,EAAEtb,UAAU,CAAC,CAAC,SAASyd,EAAEhS,GAAG,MAAM,mBAAmBA,CAAC,CAAC,OAAOzB,EAAE8iC,MAAM,SAASrhC,EAAE6P,GAAG,IAAI5d,GAAG4d,EAAEA,GAAG,CAAA,GAAI2jC,gBAAe,EAA0C,GAAvCxhC,EAAE/f,KAAK4d,EAAE6jH,sBAAsBzhI,EAAEA,EAAE,IAAO4d,EAAE2jC,cAAcvhD,EAAE4d,EAAEwN,YAAYrL,EAAEnC,EAAEwN,YAAYxN,EAAEwN,WAAWxN,EAAEklH,SAASx2H,EAAEy2H,kBAAkB,OAAO/iI,EAAE,KAAKsM,EAAE02H,kBAAkB,iBAAiBj1H,GAAGA,EAAE,CAACA,GAAG,QAAQA,EAAEo4C,WAAW,GAAGp4C,EAAEA,EAAE1O,MAAM,GAAtC,CAA0C0O,GAAG/N,EAAE,IAAI4d,EAAEqlH,SAASpiH,EAAEtP,GAAGqM,KAAI,IAAK7P,EAAEm1H,UAAUnjH,EAAEhS,EAAEy3D,OAAOzlD,EAAEhS,EAAEgzH,IAAI/gI,EAAE,IAAIwK,EAAEoT,IAAItT,EAAE6kH,MAAMphH,aAAaohH,MAAMphH,aAAa7P,UAAU8B,EAAE,IAAIuI,EAAEqV,IAAI5d,EAAEw/H,OAAOzxH,IAAI/N,EAAE,MAAM,IAAI+N,EAAE,QAAQzB,EAAEy2H,oBAAoBh1H,EAAE,MAAM,IAAIA,EAAEzD,EAAE64H,KAAK74H,EAAE84H,WAAW,KAAKxlH,EAAEtM,EAAErT,WAAW,OAAOqO,EAAE+2H,WAAW/2H,EAAE+2H,SAASt1H,EAAEu1H,gBAAgB,IAAIC,KAAK,CAAC,yOAAyO,IAAI3lH,EAAE,QAAQ,CAAC3Q,KAAK,qBAAsB,EAAlY,IAAuYc,EAAE,IAAIzD,EAAEk5H,OAAOz1H,IAAI01H,UAAUniH,EAAEvT,EAAEotB,GAAGnxB,IAAIuzC,EAAExvC,EAAEotB,IAAIptB,EAAG,EAAte,IAA2e20H,SAAS9kH,EAAE+N,KAAK3rB,EAAE2iI,UAAU/kH,EAAEugH,MAAMn+H,EAAE4iI,aAAahlH,EAAEuhH,SAASn/H,EAAEyiI,UAAU7kH,EAAEsF,MAAMtF,EAAE+N,KAAK5L,EAAEnC,EAAE+N,MAAM/N,EAAEugH,MAAMp+G,EAAEnC,EAAEugH,OAAOvgH,EAAEuhH,SAASp/G,EAAEnC,EAAEuhH,UAAUvhH,EAAEsF,MAAMnD,EAAEnC,EAAEsF,cAActF,EAAEklH,OAAO9iI,EAAEm9H,YAAY,CAACl+H,MAAM8O,EAAE21H,OAAO9lH,EAAEohH,SAASh/H,EAAEm7B,IAAI,EAAE7uB,EAAEq3H,QAAQ,SAAS51H,EAAE6P,GAAG,IAAItT,GAAE,EAAGi2C,GAAE,EAAGl2C,EAAE,IAAIyG,EAAE,OAAOnD,EAAE,IAAIiE,EAAEjE,EAAEA,EAAE3N,GAAE,EAAGsR,EAAE,KAAKisC,GAAE,EAAGvzC,GAAG,MAAM,GAAG,iBAAiB4T,EAAE,CAAC,GAAG,iBAAiBA,EAAE+jH,WAAWr1H,EAAE+1H,eAAe1wG,OAAO,SAAS5jB,GAAG,OAAM,IAAK6P,EAAE+jH,UAAUzjG,QAAQnwB,EAAE,GAAGnP,SAASyL,EAAEuT,EAAE+jH,WAAW,kBAAkB/jH,EAAEgmH,QAAQ,mBAAmBhmH,EAAEgmH,SAASrhI,MAAMi+B,QAAQ5iB,EAAEgmH,UAAUt5H,EAAEsT,EAAEgmH,QAAQ,kBAAkBhmH,EAAE0jH,gBAAgB,iBAAiB1jH,EAAE0jH,iBAAiBthI,EAAE4d,EAAE0jH,gBAAgB,iBAAiB1jH,EAAE4gH,UAAU1tH,EAAE8M,EAAE4gH,SAAS,iBAAiB5gH,EAAE6gH,YAAY9wH,EAAEiQ,EAAE6gH,WAAW,kBAAkB7gH,EAAEomC,SAASzD,EAAE3iC,EAAEomC,QAAQzhD,MAAMi+B,QAAQ5iB,EAAEtZ,SAAS,CAAC,GAAG,IAAIsZ,EAAEtZ,QAAQ1F,OAAO,MAAM,IAAI2B,MAAM,2BAA2B+Q,EAAEsM,EAAEtZ,OAAO,UAAUsZ,EAAEwkH,aAAaxwH,EAAEgM,EAAEwkH,WAAWz0H,GAAGiQ,EAAEimH,0BAA0B90F,OAAOwO,EAAE3/B,EAAEimH,eAAe,kBAAkBjmH,EAAEimH,gBAAgBjmH,EAAEimH,iBAAiBtmF,EAAE,kBAAkB,CAAE,EAAjvB,GAAqvB,IAAIxO,OAAOle,EAAEljB,GAAG,MAA4C,GAAtC,iBAAiBI,IAAIA,EAAE+O,KAAKsyB,MAAMrhC,IAAOxL,MAAMi+B,QAAQzyB,GAAG,CAAC,IAAIA,EAAEnP,QAAQ2D,MAAMi+B,QAAQzyB,EAAE,IAAI,OAAOmY,EAAE,KAAKnY,EAAE/N,GAAG,GAAG,iBAAiB+N,EAAE,GAAG,OAAOmY,EAAE5U,GAAGpT,OAAO6tC,KAAKh+B,EAAE,IAAIA,EAAE/N,EAAE,MAAM,GAAG,iBAAiB+N,EAAE,MAAM,iBAAiBA,EAAEzF,OAAOyF,EAAEzF,KAAKwU,KAAKsyB,MAAMrhC,EAAEzF,OAAO/F,MAAMi+B,QAAQzyB,EAAEzF,QAAQyF,EAAEw1E,SAASx1E,EAAEw1E,OAAOx1E,EAAEu8B,MAAMv8B,EAAEu8B,KAAKi5C,QAAQjyE,GAAGvD,EAAEw1E,SAASx1E,EAAEw1E,OAAOhhF,MAAMi+B,QAAQzyB,EAAEzF,KAAK,IAAIyF,EAAEw1E,OAAO,iBAAiBx1E,EAAEzF,KAAK,GAAGpK,OAAO6tC,KAAKh+B,EAAEzF,KAAK,IAAI,IAAI/F,MAAMi+B,QAAQzyB,EAAEzF,KAAK,KAAK,iBAAiByF,EAAEzF,KAAK,KAAKyF,EAAEzF,KAAK,CAACyF,EAAEzF,QAAQ4d,EAAEnY,EAAEw1E,QAAQ,GAAGx1E,EAAEzF,MAAM,GAAGtI,GAAG,MAAM,IAAIO,MAAM,0CAA0C,SAAS2lB,EAAEnY,EAAE6P,EAAE5d,GAAG,IAAIsR,EAAE,GAAGhH,GAAG,iBAAiByD,IAAIA,EAAE+O,KAAKsyB,MAAMrhC,IAAI,iBAAiB6P,IAAIA,EAAEd,KAAKsyB,MAAMxxB,IAAIrb,MAAMi+B,QAAQzyB,IAAI,EAAEA,EAAEnP,QAAQ+O,GAAGpL,MAAMi+B,QAAQ5iB,EAAE,IAAI,GAAGtT,GAAGi2C,EAAE,CAAC,IAAI,IAAI3uC,EAAE,EAAEA,EAAE7D,EAAEnP,OAAOgT,IAAI,EAAEA,IAAIN,GAAGjH,GAAGiH,GAAGzH,EAAEkE,EAAE6D,GAAGA,GAAG,EAAEgM,EAAEhf,SAAS0S,GAAGR,EAAE,CAAC,IAAI,IAAIysC,EAAE,EAAEA,EAAE3/B,EAAEhf,OAAO2+C,IAAI,CAAC,IAAIvzC,GAAGM,EAAEyD,EAAE6P,EAAE2/B,IAAI3+C,OAAOsnB,GAAE,EAAG1C,EAAElZ,EAAE,IAAIpM,OAAO6tC,KAAKnuB,EAAE2/B,IAAI3+C,OAAO,IAAIgf,EAAE2/B,GAAG3+C,OAAO,GAAGoB,IAAIsK,IAAI4b,EAAE,WAAWlmB,EAAE,KAAK4d,EAAE2/B,GAAGx4C,KAAK,IAAIsqC,OAAO,IAAIzxB,EAAE2/B,GAAG3+C,QAAQ,IAAIgf,EAAE2/B,GAAG,GAAG3+C,QAAQ,WAAWoB,GAAGsK,EAAE,CAAC,IAAI,IAAIuW,EAAE,GAAGtY,EAAE,EAAEA,EAAEyB,EAAEzB,IAAI,CAAC,IAAIgJ,EAAE5D,EAAEI,EAAExF,GAAGA,EAAEsY,EAAEhc,KAAK+Y,EAAE2/B,GAAGhsC,GAAG,CAAC2U,EAAE,KAAKrF,EAAE9b,KAAK,IAAIsqC,MAAM,CAAC,IAAInpB,EAAE,CAAC,IAAI,IAAI1b,EAAE,EAAEA,EAAER,EAAEQ,IAAI,CAAC,EAAEA,IAAIgZ,IAAIlS,GAAGjH,GAAG,IAAIiX,EAAEhX,GAAGqD,EAAEI,EAAEvD,GAAGA,EAAE8G,GAAGzH,EAAE+T,EAAE2/B,GAAGj8B,GAAG9W,EAAE,CAAC+yC,EAAE3/B,EAAEhf,OAAO,KAAKoB,GAAG,EAAEgK,IAAIwZ,KAAKlS,GAAGR,EAAE,CAAC,CAAC,OAAOQ,CAAC,CAAC,SAASzH,EAAEkE,EAAE6P,GAAG,IAAI5d,EAAEsR,EAAE,OAAO,MAAMvD,EAAE,GAAGA,EAAE5J,cAAcymC,KAAK9tB,KAAKC,UAAUhP,GAAG1O,MAAM,EAAE,KAAKiS,GAAE,EAAGisC,GAAG,iBAAiBxvC,GAAGwvC,EAAE3N,KAAK7hC,KAAKA,EAAE,IAAIA,EAAEuD,GAAE,GAAItR,EAAE+N,EAAE9P,WAAW68B,QAAQ9wB,EAAE4H,IAAIN,EAAEA,IAAG,IAAKhH,GAAG,mBAAmBA,GAAGA,EAAEyD,EAAE6P,IAAIrb,MAAMi+B,QAAQl2B,IAAIA,EAAEsT,IAAI,EAAE7P,EAAE6P,KAAK,IAAI,IAAI5d,EAAE,EAAEA,EAAE4d,EAAEhf,OAAOoB,IAAI,IAAG,EAAG+N,EAAEmwB,QAAQtgB,EAAE5d,IAAI,OAAM,EAAG,OAAM,CAAG,EAA5E,CAA8EA,EAAEsM,EAAE+1H,kBAAiB,EAAGriI,EAAEk+B,QAAQ7zB,IAAI,MAAMrK,EAAE+hD,OAAO,IAAI,MAAM/hD,EAAE+hD,OAAO/hD,EAAEpB,OAAO,IAAI+O,EAAE3N,EAAE2N,EAAE3N,EAAE,CAAC,EAAEsM,EAAEs1H,WAAW3sG,OAAOu0B,aAAa,IAAIl9C,EAAEu1H,SAAS5sG,OAAOu0B,aAAa,IAAIl9C,EAAEw3H,gBAAgB,SAASx3H,EAAE+1H,eAAe,CAAC,KAAK,KAAK,IAAI/1H,EAAEw3H,iBAAiBx3H,EAAEy2H,mBAAmBp1H,KAAKrD,EAAEk5H,OAAOl3H,EAAE02H,kBAAkB,EAAE12H,EAAEi0H,eAAe,SAASj0H,EAAE+yH,gBAAgB,QAAQ/yH,EAAEi1H,iBAAiB,IAAIj1H,EAAEy3H,OAAOzmF,EAAEhxC,EAAE03H,aAAahkI,EAAEsM,EAAE23H,gBAAgBpjH,EAAEvU,EAAE43H,aAAa37H,EAAE+D,EAAE63H,eAAe5yH,EAAEjF,EAAE83H,uBAAuB55H,EAAEF,EAAE+5H,UAAU7gH,EAAElZ,EAAE+5H,QAAQzhG,GAAGwM,MAAM,SAASmO,GAAG,IAAIv9C,EAAEu9C,EAAEmmF,QAAQ,CAAA,EAAG15H,EAAE,GAAG,OAAO5B,KAAKk8H,KAAK,SAASv2H,GAAG,GAAK,UAAUyV,EAAEpb,MAAMgsC,KAAK,WAAWvZ,eAAe,SAASrX,EAAEpb,MAAMuwH,KAAK,QAAQzqF,gBAAe5jC,EAAEk2H,aAAcp4H,KAAK2wD,OAAO,IAAI3wD,KAAK2wD,MAAMn6D,OAAO,OAAM,EAAG,IAAI,IAAIgf,EAAE,EAAEA,EAAExV,KAAK2wD,MAAMn6D,OAAOgf,IAAI5T,EAAEnF,KAAK,CAACyxD,KAAKluD,KAAK2wD,MAAMn7C,GAAG2mH,UAAUn8H,KAAKo8H,eAAehhH,EAAEi3E,OAAO,CAAA,EAAGz6F,IAAI,GAAG+N,IAAI3F,KAAK,SAAS2F,IAAI,GAAG,IAAI/D,EAAEpL,OAAOmhB,EAAEw9B,EAAE4hF,WAAW5hF,EAAE4hF,eAAe,CAAC,IAAIpxH,EAAE6P,EAAE5d,EAAEsR,EAAEhH,EAAEN,EAAE,GAAG,GAAG+V,EAAEw9B,EAAEknF,QAAQ,CAAC,IAAI92H,EAAE4vC,EAAEknF,OAAOn6H,EAAEgsD,KAAKhsD,EAAEi6H,WAAW,GAAG,iBAAiB52H,EAAE,CAAC,GAAG,UAAUA,EAAE+2H,OAAO,OAAO32H,EAAE,aAAa6P,EAAEtT,EAAEgsD,KAAKt2D,EAAEsK,EAAEi6H,UAAUjzH,EAAE3D,EAAEg3H,YAAY5kH,EAAEw9B,EAAEr6B,QAAQq6B,EAAEr6B,MAAM,CAAC9e,KAAK2J,GAAG6P,EAAE5d,EAAEsR,IAAI,GAAG,SAAS3D,EAAE+2H,OAAO,YAAYx+G,IAAI,iBAAiBvY,EAAE+1H,SAASp5H,EAAEk6H,eAAehhH,EAAEi3E,OAAOnwF,EAAEk6H,eAAe72H,EAAE+1H,QAAQ,MAAM,GAAG,SAAS/1H,EAAE,YAAYuY,GAAG,CAAC,IAAItU,EAAEtH,EAAEk6H,eAAerF,SAAS70H,EAAEk6H,eAAerF,SAAS,SAASpxH,GAAGgS,EAAEnO,IAAIA,EAAE7D,EAAEzD,EAAEgsD,KAAKhsD,EAAEi6H,WAAWr+G,GAAG,EAAE5Z,EAAE8iC,MAAM9kC,EAAEgsD,KAAKhsD,EAAEk6H,eAAe,CAAC,CAAC,SAASt+G,IAAIlc,EAAE8M,OAAO,EAAE,GAAG/I,GAAG,CAAC,GAAG6D,IAAItH,EAAEm5H,UAAU,SAAS11H,GAAGA,EAAEA,EAAEzF,UAAK,IAASgE,EAAE2yH,WAAWlxH,IAAIzB,EAAE2yH,UAAUlxH,EAAEixH,UAAU,iBAAiBjxH,EAAE9O,MAAMqL,EAAE6yH,YAAY,CAAC6B,SAAS1yH,EAAE2yH,UAAU12G,QAAQjc,EAAE8iC,MAAMrhC,EAAE9O,MAAM8O,EAAE21H,QAAQxE,UAAS,KAAM50H,EAAE6kH,MAAMphH,EAAE9O,iBAAiBkwH,MAAMphH,EAAE9O,iBAAiBf,UAAU6P,EAAEzB,EAAE8iC,MAAMrhC,EAAE9O,MAAM8O,EAAE21H,UAAUp5H,EAAE6yH,YAAY,CAAC6B,SAAS1yH,EAAE2yH,UAAU12G,QAAQxa,EAAEmxH,UAAS,GAAI,IAAIr+G,EAAE1iB,UAAUD,OAAOsuC,OAAOtmB,EAAE/nB,YAAYgG,YAAY0c,GAAGtY,EAAEpK,UAAUD,OAAOsuC,OAAOtmB,EAAE/nB,YAAYgG,YAAYoE,GAAGgJ,EAAEpT,UAAUD,OAAOsuC,OAAOj7B,EAAEpT,YAAYgG,YAAYoN,GAAG/G,EAAErM,UAAUD,OAAOsuC,OAAOtmB,EAAE/nB,YAAYgG,YAAYqG,EAAE8B,CAAC,CAAvwlBsR,wBCM1H,SAAUgnH,GAAmBnK,GACjC,MAAMh2D,EAAO9oB,GAAa8+E,GACpB7G,EAASiR,GAAKz1F,MAAMq1B,EAAM,CAC9B68D,gBAAgB,EAChBt9E,QAAQ,EACRzC,eAAe,IACdj5C,KAEGywC,EAAW,IAAIJ,GA2BrB,OA1BAI,EAASO,aACP,CACEp4C,EAAG,CACDoH,KAAMsrH,EAAOp9F,IAAKhT,GAAWA,EAAE,uBAC/B0X,MAAO,0BACPgsB,aAAa,GAEfp2C,EAAG,CACDxI,KAAMsrH,EAAOp9F,IAAKhT,GAAWA,EAAE,wBAC/B0X,MAAO,cACPgsB,aAAa,GAEf18C,EAAG,CACDlC,KAAMsrH,EAAOp9F,IAAKhT,GAAWA,EAAE,wBAC/B0X,MAAO,2BACPgsB,aAAa,GAEftpC,EAAG,CACDtV,KAAMsrH,EAAOp9F,IAAKhT,GAAWA,EAAEshH,MAC/B5pG,MAAO,aACPgsB,aAAa,IAGjB,CAAE7c,SAAU,QAGP0O,CACT,CC7CM,SAAUgsF,GAAmBtK,GACjC,IAAIh2D,EAAO9oB,GAAa8+E,GACxBh2D,EAAOA,EAAKviE,WAAW,UAAW,IAClC,MAAM8iI,EAAYvgE,EAAKvsB,MAAM,MAAMvmB,OAAQ/sB,GAAS,YAAYgrC,KAAKhrC,IAC/DqgI,EAAexgE,EAClBvsB,MAAM,MACNvmB,OAAQ/sB,GAAS,WAAW0qC,KAAK1qC,IACjC4xB,IAAK5xB,GAASA,EAAKszC,MAAM,OAAO1hB,IAAI11B,SAEjCwpC,EA6BR,SAAmBgW,GACjB,MAAMhW,EAAY,CAAEyzD,SAAU,GAAIq9B,YAAa,IAC/C,IAAK,MAAOp7H,EAAG4E,KAAS07C,EAAMxsC,UAC5B,GAAI,cAAcw7B,KAAK1qC,GACrB0lC,EAAK46F,WAAaC,GAAUvgI,QACvB,GAAI,cAAc0qC,KAAK1qC,GAC5B0lC,EAAK86F,iBAAmBD,GAAUvgI,QAC7B,GAAI,UAAU0qC,KAAK1qC,GACxB0lC,EAAK+6F,WAAaF,GAAUvgI,QACvB,GAAI,QAAQ0qC,KAAK1qC,GACtB0lC,EAAK1F,OAAS9jC,OAAO0uC,WAAW21F,GAAUvgI,IAC1C0lC,EAAKg7F,WAAaH,GAAUvgI,EAAM,QAC7B,GAAI,qBAAqB0qC,KAAK1qC,GACnC0lC,EAAKyzD,SAASl5F,KAAKsgI,GAAUvgI,SACxB,GAAI,UAAU0qC,KAAK1qC,GACxB0lC,EAAK6xB,OAASgpE,GAAUvgI,QACnB,GAAI,QAAQ0qC,KAAK1qC,GACtB0lC,EAAK66D,KAAOggC,GAAUvgI,QACjB,GAAI,QAAQ0qC,KAAK1qC,GACtB0lC,EAAKgsB,KAAO6uE,GAAUvgI,QACjB,GAAI,QAAQ0qC,KAAK1qC,GACtB0lC,EAAK6iB,KAAOg4E,GAAUvgI,QACjB,GAAI,QAAQ0qC,KAAK1qC,GACtB0lC,EAAKU,KAAOm6F,GAAUvgI,QACjB,GAAI,aAAa0qC,KAAK1qC,GAC3B0lC,EAAK8wF,YAAYv2H,KAAKsgI,GAAUvgI,SAC3B,GAAI,YAAY0qC,KAAK1qC,GAC1B0lC,EAAKi7F,SAAWJ,GAAUvgI,QACrB,GAAI,eAAe0qC,KAAK1qC,GAC7B0lC,EAAKk7F,YAAcL,GAAUvgI,QACxB,GAAI,YAAY0qC,KAAK1qC,GAC1B0lC,EAAKm7F,SAAWN,GAAUvgI,QACrB,GAAI,aAAa0qC,KAAK1qC,GAC3B0lC,EAAKo7F,UAAYP,GAAUvgI,QACtB,GAAI,YAAY0qC,KAAK1qC,GAC1B0lC,EAAKq7F,SAAWR,GAAUvgI,QACrB,GAAI,WAAW0qC,KAAK1qC,GAAO,CAChC0lC,EAAKs7F,UAAY5lI,EAAI,EACrB,KACF,CAGF,OAAOsqC,CACT,CAxEeu7F,CAAUb,GAGjBc,EAAYb,EAAatzG,OAAQ/sB,GAASA,EAAK,GAAK,GAE1D0lC,EAAKy7F,iBAAmB,GACxBz7F,EAAK07F,gBAAkB,GAEvB,MAAMvhI,EAAc,CAClB6lC,OACAhiC,KAAM,CACJ0iC,KAAM,GACNpG,OAAQ,GACRq2F,YAAa,KASjB,OANAx2H,EAAO6D,KAAK0iC,KAAO86F,EAAUtvG,IAAK+sD,GAAWA,EAAO,IACpD9+E,EAAO6D,KAAK2yH,YAAc6K,EAAUtvG,IAAK+sD,GAAWA,EAAO,IAC3D9+E,EAAO6D,KAAKs8B,OAASkhG,EAAUtvG,IAAK+sD,GAAWA,EAAO,IACtD9+E,EAAO6lC,KAAKy7F,iBAAmBD,EAAUtvG,IAAK+sD,GAAWA,EAAO,IAChE9+E,EAAO6lC,KAAK07F,gBAAkBF,EAAUtvG,IAAK+sD,GAAWA,EAAO,IAExD9+E,CACT,CAEA,SAAS0gI,GAAUnuF,EAAgBtL,EAAO,GACxC,OAAOsL,EAAOkB,MAAM,MAAMxM,GAAM5Q,QAAQ,sBAAuB,KACjE,CChCM,SAAUmrG,GAAkBxL,GAChC,MAAMh2D,EAAO9oB,GAAa8+E,GACpB1hF,EAAW,IAAIJ,GACfi7E,EAASmR,GAAmBtgE,GAuBlC,OArBA1rB,EAASO,aACP,CACEp4C,EAAG,CACDoH,KAAMsrH,EAAOtrH,KAAK2yH,YAClB/zE,aAAa,EACbhsB,MAAO,4BAETpqB,EAAG,CACDxI,KAAMsrH,EAAOtrH,KAAKs8B,OAClBsiB,aAAa,EACbhsB,MAAO,eAETtd,EAAG,CACDtV,KAAMsrH,EAAOtrH,KAAK0iC,KAClBkc,aAAa,EACbhsB,MAAO,eAGX,CAAEmP,SAAU,MAAOD,MAAOwpF,EAAOtpF,KAAK+6F,WAAY/6F,KAAMspF,EAAOtpF,OAG1DyO,CACT,CC7BM,SAAUmtF,GAAuBzL,GACrC,MAAM1hF,EAAW,IAAIJ,GACfi7E,EAAS2B,GAAyBkF,GAExC1hF,EAASO,aAAas6E,EAAO3pF,UAAW,CACtCI,SAAU,MACVD,MAAOwpF,EAAOtpF,KAAK,eACnBA,KAAM,IACDspF,EAAOtpF,KACVwwF,SAAU,CACRxwF,KAAM,CACJ6xB,OAAQ,YAMhB,IAAK,MAAMuV,KAASkiD,EAAOjiD,OACzB54B,EAASO,aAAao4B,EAAMznC,UAAW,CACrCI,SAAU,MACVD,MAAOwpF,EAAOtpF,KAAK,eACnBA,KAAM,IACDspF,EAAOtpF,KACVwwF,SAAU,CACRxwF,KAAM,CACJ6xB,OAAQuV,EAAMttE,UAOxB,OAAO20C,CACT","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,172,173]}