{"version":3,"file":"dsc-spectrum.umd.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/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/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/dsc/taInstruments/dscParseTAInstrumentsXLS.js","../node_modules/physical-chemistry-parser/src/utils/getAllSheetsFromXLS.js","../node_modules/physical-chemistry-parser/src/hgPorosimetry/thermoFinnigan/hgParseThermoFinnigan.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","../node_modules/tga-spectrum/lib/from/parser/parsePerkinElmerAscii.js","../node_modules/physical-chemistry-parser/src/xrf/panalytical/xrfParserPanalytical.js","../node_modules/papaparse/papaparse.min.js","../node_modules/common-spectrum/lib/from/fromJcamp.js","../lib/from/fromPerkinElmer.js","../lib/from/fromPerkinElmerCSV.js","../lib/from/fromTAInstrumentsExcel.js","../node_modules/common-spectrum/lib/to/toJcamp.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","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 { 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","import { getAllSheetsFromXLS } from '../../utils/getAllSheetsFromXLS';\nimport {\n  checkVariables,\n  parseDataSheet,\n} from '../../utils/taInstrumentsUtilities.js';\n\nexport function dscParseTAInstrumentsXLS(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: 'Heat Flow (Normalized)',\n      units: 'W/g',\n      data: [],\n    },\n  };\n\n  for (let sheet of sheets) {\n    const parsed = parseDataSheet(sheet, { keepUndefined });\n    checkVariables(parsed, variables);\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  }\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","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","'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","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","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 { 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","import { ensureString } from 'ensure-string';\nimport { parsePerkinElmerAscii } from 'tga-spectrum';\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 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        t: {\n            data: variables.find((v) => v.label.startsWith('Time'))?.data || [],\n            label: 'Time [min]',\n        },\n        x: {\n            data: variables.find((v) => v.label.startsWith('Sample Temperature'))\n                ?.data || [],\n            label: 'Sample Temperature [°C]',\n        },\n        y: {\n            data: variables.find((v) => v.label.startsWith('Unsubtracted Heat Flow'))\n                ?.data || [],\n            label: 'Heat Flow [mW]',\n        },\n    }, {\n        dataType: 'DSC',\n        title: meta['Sample ID'] || '',\n        meta,\n    });\n    return analysis;\n}\n//# sourceMappingURL=fromPerkinElmer.js.map","import { ensureString } from 'ensure-string';\nimport Papa from 'papaparse';\nimport { Analysis } from '../index.js';\n/**\n * @param text\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 Heat Flow']),\n            label: 'Heat Flow [mW]',\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: 'DSC' });\n    return analysis;\n}\n//# sourceMappingURL=fromPerkinElmerCSV.js.map","import { Analysis } from 'common-spectrum';\nimport { dscParseTAInstrumentsXLS } from 'physical-chemistry-parser';\nexport function fromTAInstrumentsExcel(blob) {\n    const analysis = new Analysis();\n    const parsed = dscParseTAInstrumentsXLS(blob);\n    analysis.pushSpectrum(parsed.variables, {\n        dataType: 'DSC',\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: 'DSC',\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","import { toJcamps } from './toJcamps.js';\nexport function toJcamp(analysis, options = {}) {\n    return toJcamps(analysis, options).join('\\n');\n}\n//# sourceMappingURL=toJcamp.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","module","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","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","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","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","entry","payload","MSSZ","new_buf","cnt","offset","__readUInt32LE","cfb","CLSID","nm","rebuild_cfb","seed_cfb","gc","_file","pop","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","children","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","dscParseTAInstrumentsXLS","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","parsePerkinElmerAscii","sections","methodSteps","steps","currentSection","currentStep","description","dataHeaders","rest","parseDataBlockHeader","parseDataHeader","dataParts","getSections","nextLine","firstLineParts","secondLineParts","combinedHeader","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","jcamp","converted","ge","debug","flatten","datatable","dataClass","jcampDX","jcampCS","shiftOffsetNum","vartype","varform","page","sampleDescription","be","currentSpectrum","addJcamp","arrayBuffer","stepsInfo","stepVariable","Papa","Time","cheminfo"],"mappings":"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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,EAAI7vC,IAAI,SAASt1B,GAAK,MAAO,CAAEA,GAAG,GAAI,IAAKA,GAAG,EAAG,IAAM,IAAFA,EAAQ,EAAI,CAIrJ,IA4FIsyE,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,SACA,QACA,QACA,MACA,QACA,MACA,QACA,SACA,SACA,QACA,QAGA,SACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,EACA,KAKGnD,GAAO,CACH,EAAa,SACb,EAAa,UACb,GAAa,UACb,GAAa,QACb,GAAa,SACb,GAAa,QACb,GAAa,OACb,GAAa,gBACb,IAAa,SAGjBqD,GAAQ,CACX,SAAiB,EACjB,UAAiB,EACjB,UAAiB,GACjB,QAAiB,GACjB,SAAiB,GACjB,QAAiB,GACjB,OAAiB,GACjB,gBAAiB,GACjB,QAAiB,KAOdC,GAAgC,CAEnC,6EAA8E,YAC9E,uDAAwD,YACxD,0DAA2D,YAC3D,uDAAwD,YACxD,gFAAiF,YAGjF,4EAA6E,SAC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CnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,cAAeuW,EAAEitE,GACpC,IAAe,CAAExjF,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EAAE,MACnB,IAAe,CAAEA,EA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CL,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,IAAK,eACL,IAAK,oBACL,IAAK,uBACL,IAAK,cACL,IAAK,WACL,IAAK,WACL,IAAK,aACL,IAAK,aACL,IAAK,eACL,IAAK,eACL,IAAK,cACL,IAAK,qBACL,IAAK,yBACL,IAAK,mBACL,IAAK,WACL,IAAK,iBACL,IAAK,iBACL,IAAK,eACL,IAAK,YACL,IAAK,mBACL,IAAK,mBACL,IAAK,iBACL,IAAK,kBACL,IAAK,oBACL,IAAK,mBACL,IAAK,cACL,IAAK,gBACL,IAAK,WACL,IAAK,YACL,IAAK,cACL,IAAK,cACL,IAAK,mBACL,IAAK,oBACL,IAAK,iBACL,IAAK,YACL,IAAK,SACL,IAAK,SACL,IAAK,gBACL,IAAK,mBACL,IAAK,iBACL,IAAK,WACL,IAAK,gBACL,IAAK,gBACL,IAAK,cACL,IAAK,iBACL,IAAK,iBACL,IAAK,oBACL,IAAK,sBACL,IAAK,aACL,IAAK,cACL,IAAK,cACL,IAAK,oBACL,IAAK,eACL,IAAK,gBACL,IAAK,qBAEHJ,GAAO,CACT,EAAG,QACH,EAAG,KACH,EAAG,OACH,EAAG,UACH,EAAG,MACH,EAAG,UACH,EAAG,MACH,EAAG,MACH,EAAG,MACH,EAAG,SACH,GAAI,KACJ,GAAI,MACJ,GAAI,QACJ,GAAI,SACJ,GAAI,QACJ,GAAI,MACJ,GAAI,MACJ,GAAI,MACJ,GAAI,OACJ,GAAI,KACJ,GAAI,OACJ,GAAI,MACJ,GAAI,KACJ,GAAI,QACJ,GAAI,MACJ,GAAI,MACJ,GAAI,OACJ,GAAI,QACJ,GAAI,SACJ,GAAI,QACJ,GAAI,OACJ,GAAI,MACJ,GAAI,MACJ,GAAI,QACJ,GAAI,OACJ,GAAI,QACJ,GAAI,MACJ,GAAI,KACJ,GAAI,MACJ,GAAI,MACJ,GAAI,SACJ,GAAI,OACJ,GAAI,WACJ,GAAI,OACJ,GAAI,OACJ,GAAI,SACJ,GAAI,MACJ,GAAI,OACJ,GAAI,OACJ,GAAI,SACJ,GAAI,QACJ,GAAI,SACJ,GAAI,SACJ,GAAI,OACJ,GAAI,OACJ,GAAI,SACJ,GAAI,KACJ,GAAI,KACJ,GAAI,OACJ,GAAI,MACJ,GAAI,OACJ,GAAI,OACJ,GAAI,MACJ,GAAI,OACJ,GAAI,QACJ,GAAI,OACJ,GAAI,OACJ,GAAI,MACJ,GAAI,QACJ,GAAI,OACJ,GAAI,UACJ,GAAI,OACJ,GAAI,SACJ,GAAI,SACJ,GAAI,MACJ,GAAI,QACJ,GAAI,OACJ,GAAI,UACJ,GAAI,SACJ,GAAI,SACJ,GAAI,SACJ,GAAI,WACJ,GAAI,SACJ,GAAI,YACJ,GAAI,QACJ,GAAI,OACJ,GAAI,OACJ,GAAI,OACJ,GAAI,WACJ,GAAI,SACJ,GAAI,QACJ,GAAI,UACJ,GAAI,SACJ,GAAI,YACJ,GAAI,cACJ,GAAI,YACJ,GAAI,SACJ,GAAI,QACJ,GAAI,OACJ,GAAI,OACJ,IAAK,SACL,IAAK,UACL,IAAK,UACL,IAAK,QACL,IAAK,QACL,IAAK,QACL,IAAK,cACL,IAAK,WACL,IAAK,YACL,IAAK,MACL,IAAK,OACL,IAAK,OACL,IAAK,QACL,IAAK,QACL,IAAK,SACL,IAAK,OACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,UACL,IAAK,aACL,IAAK,OACL,IAAK,QACL,IAAK,YACL,IAAK,OACL,IAAK,OACL,IAAK,QACL,IAAK,SACL,IAAK,WACL,IAAK,UACL,IAAK,IACL,IAAK,IACL,IAAK,QACL,IAAK,SACL,IAAK,QACL,IAAK,UACL,IAAK,QACL,IAAK,WACL,IAAK,SACL,IAAK,OACL,IAAK,YACL,IAAK,YACL,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,UACL,IAAK,UACL,IAAK,UACL,IAAK,WACL,IAAK,WACL,IAAK,OACL,IAAK,UACL,IAAK,WACL,IAAK,cACL,IAAK,iBACL,IAAK,gBACL,IAAK,iBACL,IAAK,WACL,IAAK,cACL,IAAK,iBACL,IAAK,iBACL,IAAK,aACL,IAAK,QACL,IAAK,UACL,IAAK,WACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,OACL,IAAK,SACL,IAAK,aACL,IAAK,MACL,IAAK,QACL,IAAK,QACL,IAAK,OACL,IAAK,WACL,IAAK,UACL,IAAK,OACL,IAAK,UACL,IAAK,YACL,IAAK,UACL,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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","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,166]}