loom-browser 0.0.5 → 0.0.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/loom-data-worker.js +10458 -0
- package/dist/loom-data-worker.min.js +2 -0
- package/dist/loom-data-worker.min.js.map +1 -0
- package/dist/loom-react.esm.js +1276 -318
- package/dist/loom-react.esm.min.js +1 -1
- package/dist/loom-react.esm.min.js.map +1 -1
- package/dist/loom-worker.js +10591 -0
- package/dist/loom-worker.min.js +2 -0
- package/dist/loom-worker.min.js.map +1 -0
- package/dist/loom.esm.js +8513 -7651
- package/dist/loom.esm.min.js +1 -1
- package/dist/loom.esm.min.js.map +1 -1
- package/dist/loom.js +8516 -7651
- package/dist/loom.min.js +1 -1
- package/dist/loom.min.js.map +1 -1
- package/dist/tsconfig.src.tsbuildinfo +1 -1
- package/dist/types/bigwig/index.d.ts +2 -5
- package/dist/types/dataSourceWorkerProvider.d.ts +79 -0
- package/dist/types/dataSources/bigWigDataSource.d.ts +1 -3
- package/dist/types/dataSources/featureSourceFactory.d.ts +1 -2
- package/dist/types/dataSources/gtxDataSource.d.ts +1 -3
- package/dist/types/dataSources/memoryDataSource.d.ts +32 -0
- package/dist/types/dataSources/textFeatureSource.d.ts +0 -4
- package/dist/types/genomeBrowser.d.ts +56 -1
- package/dist/types/gtx/index.d.ts +1 -4
- package/dist/types/headlessGenomeBrowser.d.ts +72 -3
- package/dist/types/index.d.ts +11 -4
- package/dist/types/mainThreadDataSourceProvider.d.ts +19 -0
- package/dist/types/react/GenomeBrowserContext.d.ts +3 -0
- package/dist/types/react/LoomBrowser.d.ts +15 -1
- package/dist/types/react/tracks/BedTrack.d.ts +8 -3
- package/dist/types/react/tracks/WigTrack.d.ts +6 -3
- package/dist/types/react/ui/Navbar.d.ts +4 -1
- package/dist/types/session.d.ts +0 -3
- package/dist/types/svgFeatureOverlay.d.ts +27 -0
- package/dist/types/tabix/index.d.ts +0 -3
- package/dist/types/trackRegistry.d.ts +1 -4
- package/dist/types/tracks/annotation/annotationRenderer.d.ts +4 -1
- package/dist/types/tracks/annotation/annotationTrackCanvas.d.ts +9 -6
- package/dist/types/tracks/axis/axisRenderer.d.ts +2 -8
- package/dist/types/tracks/axis/index.d.ts +1 -1
- package/dist/types/tracks/baseTrackCanvas.d.ts +7 -1
- package/dist/types/tracks/interaction/interactionRenderer.d.ts +4 -1
- package/dist/types/tracks/trackLabel.d.ts +22 -0
- package/dist/types/tracks/wig/wigTrackCanvas.d.ts +2 -0
- package/dist/types/types.d.ts +22 -1
- package/dist/types/worker/dataSourceRegistry.d.ts +33 -0
- package/dist/types/worker/dataSourceWorkerScript.d.ts +13 -0
- package/dist/types/worker/unifiedWorkerScript.d.ts +17 -0
- package/dist/types/worker/webDataSourceWorkerProvider.d.ts +59 -0
- package/dist/types/worker/webUnifiedWorkerProvider.d.ts +64 -0
- package/dist/types/worker/webWorkerPool.d.ts +64 -0
- package/dist/types/worker/workerPoolScript.d.ts +17 -0
- package/dist/types/workerDataSource.d.ts +32 -0
- package/dist/types/workerProvider.d.ts +10 -3
- package/package.json +3 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loom-data-worker.min.js","sources":["../node_modules/@gmod/bbi/esm/bigint-polyfill/pure.js","../node_modules/@gmod/bbi/esm/bigint-polyfill/polyfill.js","../node_modules/generic-filehandle2/esm/remoteFile.js","../node_modules/generic-filehandle2/esm/browser.js","../node_modules/@gmod/abortable-promise-cache/esm/AggregateAbortController.js","../node_modules/@gmod/abortable-promise-cache/esm/AggregateStatusReporter.js","../node_modules/@gmod/abortable-promise-cache/esm/AbortablePromiseCache.js","../node_modules/@jbrowse/quick-lru/esm/index.js","../node_modules/@gmod/bbi/esm/range.js","../node_modules/@gmod/bbi/esm/wasm/inflate-wasm-inlined.js","../node_modules/@gmod/bbi/esm/unzip.js","../node_modules/@gmod/bbi/esm/util.js","../node_modules/@gmod/bbi/esm/block-view.js","../node_modules/@gmod/bbi/esm/bbi.js","../node_modules/@gmod/bbi/esm/bigwig.js","../node_modules/@gmod/bbi/esm/bigbed.js","../../src/io/binaryParser.ts","../../src/bigwig/index.ts","../../src/tracks/wig/wigSummary.ts","../../src/locusUtils.ts","../../src/dataSources/bigWigDataSource.ts","../../src/io/rangeReader.ts","../../src/gtx/zstdWasmInlined.ts","../../src/gtx/zstdWasm.ts","../../src/gtx/gtxReader.ts","../../src/gtx/fetchCoordinator.ts","../../src/gtx/index.ts","../../src/dataSources/gtxDataSource.ts","../../src/decode/exonUtils.ts","../../src/decode/ucsc.ts","../../src/data/ucscApi.ts","../../src/dataSources/geneDataSource.ts","../node_modules/tslib/tslib.es6.js","../../src/intervalTree.ts","../../src/featureCache.ts","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/utils/common.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/utils/strings.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/gzheader.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/adler32.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/crc32.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/inffast.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/inftrees.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/inflate.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/messages.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/zstream.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/inflate.js","../node_modules/@gmod/bgzf-filehandle/node_modules/pako-esm2/esm/zlib/constants.js","../node_modules/@gmod/bgzf-filehandle/esm/wasm/bgzf-wasm-inlined.js","../node_modules/@gmod/bgzf-filehandle/esm/unzip.js","../node_modules/@gmod/tabix/esm/chunk.js","../node_modules/@gmod/tabix/esm/indexFile.js","../node_modules/@gmod/tabix/esm/long.js","../node_modules/@gmod/tabix/esm/util.js","../node_modules/@gmod/tabix/esm/virtualOffset.js","../node_modules/@gmod/tabix/esm/csi.js","../node_modules/@gmod/tabix/esm/tbi.js","../node_modules/@gmod/tabix/esm/tabixIndexedFile.js","../../src/tabix/index.ts","../../src/decode/bed.ts","../../src/decode/gff.ts","../../src/decode/bedpe.ts","../../src/formats/featureParser.ts","../../src/decode/interact.ts","../../src/formats/formatDetection.ts","../../src/genome/chromSizes.ts","../../src/dataSources/textFeatureSource.ts","../../src/worker/dataSourceWorkerScript.ts","../../src/worker/dataSourceRegistry.ts"],"sourcesContent":["// from https://github.com/yume-chan/ya-webadb/blob/main/libraries/dataview-bigint-polyfill\n// license:MIT\n// needed for browsers including safari 14\nconst BigInt32 = BigInt(32);\nexport function getBigInt64(dataView, byteOffset, littleEndian) {\n const littleEndianMask = Number(!!littleEndian);\n const bigEndianMask = Number(!littleEndian);\n return ((BigInt(dataView.getInt32(byteOffset, littleEndian) * bigEndianMask +\n dataView.getInt32(byteOffset + 4, littleEndian) * littleEndianMask) <<\n BigInt32) |\n BigInt(dataView.getUint32(byteOffset, littleEndian) * littleEndianMask +\n dataView.getUint32(byteOffset + 4, littleEndian) * bigEndianMask));\n}\nexport function getBigUint64(dataView, byteOffset, littleEndian) {\n const a = dataView.getUint32(byteOffset, littleEndian);\n const b = dataView.getUint32(byteOffset + 4, littleEndian);\n const littleEndianMask = Number(!!littleEndian);\n const bigEndianMask = Number(!littleEndian);\n // This branch-less optimization is 77x faster than normal ternary operator.\n // and only 3% slower than native implementation\n // https://jsbench.me/p8kyhg1eqv/1\n return ((BigInt(a * bigEndianMask + b * littleEndianMask) << BigInt32) |\n BigInt(a * littleEndianMask + b * bigEndianMask));\n}\n//# sourceMappingURL=pure.js.map","// from https://github.com/yume-chan/ya-webadb/blob/main/libraries/dataview-bigint-polyfill\n// license:MIT\n// needed for browsers including safari 14\nimport { getBigInt64, getBigUint64 } from \"./pure.js\";\nif (!('getBigInt64' in DataView)) {\n DataView.prototype.getBigInt64 = function (byteOffset, littleEndian) {\n return getBigInt64(this, byteOffset, littleEndian);\n };\n}\nif (!('getBigUint64' in DataView)) {\n DataView.prototype.getBigUint64 = function (byteOffset, littleEndian) {\n return getBigUint64(this, byteOffset, littleEndian);\n };\n}\n//# sourceMappingURL=polyfill.js.map","function getMessage(e) {\n const r = typeof e === 'object' && e !== null && 'message' in e\n ? e.message\n : `${e}`;\n return r.replace(/\\.$/, '');\n}\nexport default class RemoteFile {\n constructor(source, opts = {}) {\n this.baseOverrides = {};\n this.url = source;\n const fetch = opts.fetch || globalThis.fetch.bind(globalThis);\n if (opts.overrides) {\n this.baseOverrides = opts.overrides;\n }\n this.fetchImplementation = fetch;\n }\n async fetch(input, init) {\n const wrapError = (e) => new Error(`${getMessage(e)} fetching ${input}`, { cause: e });\n let response;\n try {\n response = await this.fetchImplementation(input, init);\n }\n catch (e) {\n if (`${e}`.includes('Failed to fetch')) {\n // refetch to help work around a chrome bug (discussed in\n // generic-filehandle issue #72) in which the chrome cache returns a\n // CORS error for content in its cache. see also\n // https://github.com/GMOD/jbrowse-components/pull/1511\n console.warn(`generic-filehandle: refetching ${input} to attempt to work around chrome CORS header caching bug`);\n try {\n response = await this.fetchImplementation(input, {\n ...init,\n cache: 'reload',\n });\n }\n catch (e) {\n throw wrapError(e);\n }\n }\n else {\n throw wrapError(e);\n }\n }\n return response;\n }\n async read(length, position, opts = {}) {\n if (length === 0) {\n return new Uint8Array(0);\n }\n const { headers = {}, signal, overrides = {} } = opts;\n if (length < Infinity) {\n headers.range = `bytes=${position}-${position + length - 1}`;\n }\n else if (length === Infinity && position !== 0) {\n headers.range = `bytes=${position}-`;\n }\n const res = await this.fetch(this.url, {\n ...this.baseOverrides,\n ...overrides,\n headers: {\n ...this.baseOverrides.headers,\n ...overrides.headers,\n ...headers,\n },\n method: 'GET',\n redirect: 'follow',\n mode: 'cors',\n signal,\n });\n if (!res.ok) {\n throw new Error(`HTTP ${res.status} fetching ${this.url}`);\n }\n if ((res.status === 200 && position === 0) || res.status === 206) {\n // try to parse out the size of the remote file\n const contentRange = res.headers.get('content-range');\n const sizeMatch = /\\/(\\d+)$/.exec(contentRange || '');\n if (sizeMatch?.[1]) {\n this._stat = {\n size: parseInt(sizeMatch[1], 10),\n };\n }\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n const resData = res.bytes\n ? await res.bytes()\n : new Uint8Array(await res.arrayBuffer());\n return resData.byteLength <= length\n ? resData\n : resData.subarray(0, length);\n }\n throw new Error(res.status === 200\n ? `${this.url} fetch returned status 200, expected 206`\n : `HTTP ${res.status} fetching ${this.url}`);\n }\n async readFile(options = {}) {\n let encoding;\n let opts;\n if (typeof options === 'string') {\n encoding = options;\n opts = {};\n }\n else {\n encoding = options.encoding;\n const { encoding: _, ...rest } = options;\n opts = rest;\n }\n const { headers = {}, signal, overrides = {} } = opts;\n const res = await this.fetch(this.url, {\n ...this.baseOverrides,\n ...overrides,\n headers: {\n ...this.baseOverrides.headers,\n ...overrides.headers,\n ...headers,\n },\n method: 'GET',\n redirect: 'follow',\n mode: 'cors',\n signal,\n });\n if (!res.ok) {\n throw new Error(`HTTP ${res.status} fetching ${this.url}`);\n }\n if (encoding === 'utf8') {\n return res.text();\n }\n else if (encoding) {\n throw new Error(`unsupported encoding: ${encoding}`);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n return res.bytes ? res.bytes() : new Uint8Array(await res.arrayBuffer());\n }\n }\n async stat() {\n if (!this._stat) {\n await this.read(10, 0);\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!this._stat) {\n throw new Error(`unable to determine size of file at ${this.url}`);\n }\n }\n return this._stat;\n }\n async close() {\n return;\n }\n}\n//# sourceMappingURL=remoteFile.js.map","// Browser-specific exports that exclude Node.js-only modules\nexport * from \"./filehandle.js\";\nexport { default as BlobFile } from \"./blobFile.js\";\nexport { default as RemoteFile } from \"./remoteFile.js\";\nexport class LocalFile {\n readFile() {\n throw new Error('unimplemented');\n }\n read() {\n throw new Error('unimplemented');\n }\n close() {\n throw new Error('unimplemented');\n }\n}\n//# sourceMappingURL=browser.js.map","// eslint-disable-next-line @typescript-eslint/no-extraneous-class\nclass NullSignal {\n}\n/**\n * aggregates a number of abort signals, will only fire the aggregated\n * abort if all of the input signals have been aborted\n */\nexport default class AggregateAbortController {\n constructor() {\n this.signals = new Set();\n this.abortController = new AbortController();\n }\n /**\n * @param {AbortSignal} [signal] optional AbortSignal to add. if falsy,\n * will be treated as a null-signal, and this abortcontroller will no\n * longer be abortable.\n */\n //@ts-ignore\n addSignal(signal = new NullSignal()) {\n if (this.signal.aborted) {\n throw new Error('cannot add a signal, already aborted!');\n }\n // note that a NullSignal will never fire, so if we\n // have one this thing will never actually abort\n this.signals.add(signal);\n if (signal.aborted) {\n // handle the abort immediately if it is already aborted\n // for some reason\n this.handleAborted(signal);\n }\n else if (typeof signal.addEventListener === 'function') {\n signal.addEventListener('abort', () => {\n this.handleAborted(signal);\n });\n }\n }\n handleAborted(signal) {\n this.signals.delete(signal);\n if (this.signals.size === 0) {\n this.abortController.abort();\n }\n }\n get signal() {\n return this.abortController.signal;\n }\n abort() {\n this.abortController.abort();\n }\n}\n//# sourceMappingURL=AggregateAbortController.js.map","export default class AggregateStatusReporter {\n constructor() {\n this.callbacks = new Set();\n }\n addCallback(callback = () => { }) {\n this.callbacks.add(callback);\n if (this.currentMessage) {\n callback(this.currentMessage);\n }\n }\n callback(message) {\n this.currentMessage = message;\n for (const elt of this.callbacks) {\n elt(message);\n }\n }\n}\n//# sourceMappingURL=AggregateStatusReporter.js.map","import AggregateAbortController from \"./AggregateAbortController.js\";\nimport AggregateStatusReporter from \"./AggregateStatusReporter.js\";\nexport default class AbortablePromiseCache {\n constructor({ fill, cache, }) {\n if (typeof fill !== 'function') {\n throw new TypeError('must pass a fill function');\n }\n if (typeof cache !== 'object') {\n throw new TypeError('must pass a cache object');\n }\n if (typeof cache.get !== 'function' ||\n typeof cache.set !== 'function' ||\n typeof cache.delete !== 'function') {\n throw new TypeError('cache must implement get(key), set(key, val), and and delete(key)');\n }\n this.cache = cache;\n this.fillCallback = fill;\n }\n static isAbortException(exception) {\n return (\n // DOMException\n exception.name === 'AbortError' ||\n // standard-ish non-DOM abort exception\n //@ts-ignore\n exception.code === 'ERR_ABORTED' ||\n // stringified DOMException\n exception.message === 'AbortError: aborted' ||\n // stringified standard-ish exception\n exception.message === 'Error: aborted');\n }\n evict(key, entry) {\n if (this.cache.get(key) === entry) {\n this.cache.delete(key);\n }\n }\n fill(key, data, signal, statusCallback) {\n const aborter = new AggregateAbortController();\n const statusReporter = new AggregateStatusReporter();\n statusReporter.addCallback(statusCallback);\n const newEntry = {\n aborter: aborter,\n promise: this.fillCallback(data, aborter.signal, (message) => {\n statusReporter.callback(message);\n }),\n settled: false,\n statusReporter,\n get aborted() {\n return this.aborter.signal.aborted;\n },\n };\n newEntry.aborter.addSignal(signal);\n // remove the fill from the cache when its abortcontroller fires, if still in there\n newEntry.aborter.signal.addEventListener('abort', () => {\n if (!newEntry.settled) {\n this.evict(key, newEntry);\n }\n });\n // chain off the cached promise to record when it settles\n newEntry.promise\n .then(() => {\n newEntry.settled = true;\n }, () => {\n newEntry.settled = true;\n // if the fill throws an error (including abort) and is still in the cache, remove it\n this.evict(key, newEntry);\n })\n .catch((error) => {\n // this will only be reached if there is some kind of\n // bad bug in this library\n console.error(error);\n throw error;\n });\n this.cache.set(key, newEntry);\n }\n static checkSinglePromise(promise, signal) {\n // check just this signal for having been aborted, and abort the\n // promise if it was, regardless of what happened with the cached\n // response\n function checkForSingleAbort() {\n if (signal?.aborted) {\n throw Object.assign(new Error('aborted'), { code: 'ERR_ABORTED' });\n }\n }\n return promise.then(result => {\n checkForSingleAbort();\n return result;\n }, (error) => {\n checkForSingleAbort();\n throw error;\n });\n }\n has(key) {\n return this.cache.has(key);\n }\n /**\n * Callback for getting status of the pending async\n *\n * @callback statusCallback\n * @param {any} status, current status string or message object\n */\n /**\n * @param {any} key cache key to use for this request\n * @param {any} data data passed as the first argument to the fill callback\n * @param {AbortSignal} [signal] optional AbortSignal object that aborts the request\n * @param {statusCallback} a callback to get the current status of a pending async operation\n */\n get(key, data, signal, statusCallback) {\n if (!signal && data instanceof AbortSignal) {\n throw new TypeError('second get argument appears to be an AbortSignal, perhaps you meant to pass `null` for the fill data?');\n }\n const cacheEntry = this.cache.get(key);\n if (cacheEntry) {\n if (cacheEntry.aborted && !cacheEntry.settled) {\n // if it's aborted but has not realized it yet, evict it and redispatch\n this.evict(key, cacheEntry);\n return this.get(key, data, signal, statusCallback);\n }\n if (cacheEntry.settled) {\n // too late to abort, just return it\n return cacheEntry.promise;\n }\n // request is in-flight, add this signal to its list of signals,\n // or if there is no signal, the aborter will become non-abortable\n cacheEntry.aborter.addSignal(signal);\n cacheEntry.statusReporter.addCallback(statusCallback);\n return AbortablePromiseCache.checkSinglePromise(cacheEntry.promise, signal);\n }\n // if we got here, it is not in the cache. fill.\n this.fill(key, data, signal, statusCallback);\n return AbortablePromiseCache.checkSinglePromise(\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.cache.get(key).promise, signal);\n }\n /**\n * delete the given entry from the cache. if it exists and its fill request has\n * not yet settled, the fill will be signaled to abort.\n *\n * @param {any} key\n */\n delete(key) {\n const cachedEntry = this.cache.get(key);\n if (cachedEntry) {\n if (!cachedEntry.settled) {\n cachedEntry.aborter.abort();\n }\n this.cache.delete(key);\n }\n }\n /**\n * Clear all requests from the cache. Aborts any that have not settled.\n * @returns {number} count of entries deleted\n */\n clear() {\n // iterate without needing regenerator-runtime\n const keyIter = this.cache.keys();\n let deleteCount = 0;\n for (let result = keyIter.next(); !result.done; result = keyIter.next()) {\n this.delete(result.value);\n deleteCount += 1;\n }\n return deleteCount;\n }\n}\n//# sourceMappingURL=AbortablePromiseCache.js.map","var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n};\nvar __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n};\nvar _QuickLRU_instances, _QuickLRU_size, _QuickLRU_cache, _QuickLRU_oldCache, _QuickLRU_maxSize, _QuickLRU_maxAge, _QuickLRU_onEviction, _QuickLRU_emitEvictions, _QuickLRU_deleteIfExpired, _QuickLRU_getOrDeleteIfExpired, _QuickLRU_getItemValue, _QuickLRU_peek, _QuickLRU_set, _QuickLRU_moveToRecent, _QuickLRU_entriesAscending;\nexport default class QuickLRU extends Map {\n constructor(options = {}) {\n super();\n _QuickLRU_instances.add(this);\n _QuickLRU_size.set(this, 0);\n _QuickLRU_cache.set(this, new Map());\n _QuickLRU_oldCache.set(this, new Map());\n _QuickLRU_maxSize.set(this, void 0);\n _QuickLRU_maxAge.set(this, void 0);\n _QuickLRU_onEviction.set(this, void 0);\n if (!(options.maxSize && options.maxSize > 0)) {\n throw new TypeError('`maxSize` must be a number greater than 0');\n }\n if (typeof options.maxAge === 'number' && options.maxAge === 0) {\n throw new TypeError('`maxAge` must be a number greater than 0');\n }\n __classPrivateFieldSet(this, _QuickLRU_maxSize, options.maxSize, \"f\");\n __classPrivateFieldSet(this, _QuickLRU_maxAge, options.maxAge || Number.POSITIVE_INFINITY, \"f\");\n __classPrivateFieldSet(this, _QuickLRU_onEviction, options.onEviction, \"f\");\n }\n // For tests.\n get __oldCache() {\n return __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\");\n }\n get(key) {\n if (__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n const item = __classPrivateFieldGet(this, _QuickLRU_cache, \"f\").get(key);\n return __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_getItemValue).call(this, key, item);\n }\n if (__classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").has(key)) {\n const item = __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").get(key);\n if (!__classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, item)) {\n __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_moveToRecent).call(this, key, item);\n return item.value;\n }\n }\n }\n set(key, value, { maxAge = __classPrivateFieldGet(this, _QuickLRU_maxAge, \"f\") } = {}) {\n const expiry = typeof maxAge === 'number' && maxAge !== Number.POSITIVE_INFINITY\n ? Date.now() + maxAge\n : undefined;\n if (__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n __classPrivateFieldGet(this, _QuickLRU_cache, \"f\").set(key, {\n value,\n expiry,\n });\n }\n else {\n __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_set).call(this, key, { value, expiry });\n }\n return this;\n }\n has(key) {\n if (__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n return !__classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, __classPrivateFieldGet(this, _QuickLRU_cache, \"f\").get(key));\n }\n if (__classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").has(key)) {\n return !__classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").get(key));\n }\n return false;\n }\n peek(key) {\n if (__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n return __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_peek).call(this, key, __classPrivateFieldGet(this, _QuickLRU_cache, \"f\"));\n }\n if (__classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").has(key)) {\n return __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_peek).call(this, key, __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\"));\n }\n }\n expiresIn(key) {\n const item = __classPrivateFieldGet(this, _QuickLRU_cache, \"f\").get(key) ?? __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").get(key);\n if (item) {\n return item.expiry ? item.expiry - Date.now() : Number.POSITIVE_INFINITY;\n }\n }\n delete(key) {\n var _a;\n const deleted = __classPrivateFieldGet(this, _QuickLRU_cache, \"f\").delete(key);\n if (deleted) {\n __classPrivateFieldSet(this, _QuickLRU_size, (_a = __classPrivateFieldGet(this, _QuickLRU_size, \"f\"), _a--, _a), \"f\");\n }\n return __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").delete(key) || deleted;\n }\n clear() {\n __classPrivateFieldGet(this, _QuickLRU_cache, \"f\").clear();\n __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").clear();\n __classPrivateFieldSet(this, _QuickLRU_size, 0, \"f\");\n }\n resize(newSize) {\n if (!(newSize && newSize > 0)) {\n throw new TypeError('`maxSize` must be a number greater than 0');\n }\n const items = [...__classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_entriesAscending).call(this)];\n const removeCount = items.length - newSize;\n if (removeCount < 0) {\n __classPrivateFieldSet(this, _QuickLRU_cache, new Map(items), \"f\");\n __classPrivateFieldSet(this, _QuickLRU_oldCache, new Map(), \"f\");\n __classPrivateFieldSet(this, _QuickLRU_size, items.length, \"f\");\n }\n else {\n if (removeCount > 0) {\n __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_emitEvictions).call(this, items.slice(0, removeCount));\n }\n __classPrivateFieldSet(this, _QuickLRU_oldCache, new Map(items.slice(removeCount)), \"f\");\n __classPrivateFieldSet(this, _QuickLRU_cache, new Map(), \"f\");\n __classPrivateFieldSet(this, _QuickLRU_size, 0, \"f\");\n }\n __classPrivateFieldSet(this, _QuickLRU_maxSize, newSize, \"f\");\n }\n evict(count = 1) {\n const requested = count;\n if (!requested || requested <= 0) {\n return;\n }\n const items = [...__classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_entriesAscending).call(this)];\n const evictCount = Math.trunc(Math.min(requested, Math.max(items.length - 1, 0)));\n if (evictCount <= 0) {\n return;\n }\n __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_emitEvictions).call(this, items.slice(0, evictCount));\n __classPrivateFieldSet(this, _QuickLRU_oldCache, new Map(items.slice(evictCount)), \"f\");\n __classPrivateFieldSet(this, _QuickLRU_cache, new Map(), \"f\");\n __classPrivateFieldSet(this, _QuickLRU_size, 0, \"f\");\n }\n *keys() {\n for (const [key] of this) {\n yield key;\n }\n }\n *values() {\n for (const [, value] of this) {\n yield value;\n }\n }\n *[(_QuickLRU_size = new WeakMap(), _QuickLRU_cache = new WeakMap(), _QuickLRU_oldCache = new WeakMap(), _QuickLRU_maxSize = new WeakMap(), _QuickLRU_maxAge = new WeakMap(), _QuickLRU_onEviction = new WeakMap(), _QuickLRU_instances = new WeakSet(), _QuickLRU_emitEvictions = function _QuickLRU_emitEvictions(cache) {\n if (typeof __classPrivateFieldGet(this, _QuickLRU_onEviction, \"f\") !== 'function') {\n return;\n }\n for (const [key, item] of cache) {\n __classPrivateFieldGet(this, _QuickLRU_onEviction, \"f\").call(this, key, item.value);\n }\n }, _QuickLRU_deleteIfExpired = function _QuickLRU_deleteIfExpired(key, item) {\n if (typeof item.expiry === 'number' && item.expiry <= Date.now()) {\n if (typeof __classPrivateFieldGet(this, _QuickLRU_onEviction, \"f\") === 'function') {\n __classPrivateFieldGet(this, _QuickLRU_onEviction, \"f\").call(this, key, item.value);\n }\n return this.delete(key);\n }\n return false;\n }, _QuickLRU_getOrDeleteIfExpired = function _QuickLRU_getOrDeleteIfExpired(key, item) {\n const deleted = __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, item);\n if (!deleted) {\n return item.value;\n }\n }, _QuickLRU_getItemValue = function _QuickLRU_getItemValue(key, item) {\n return item.expiry ? __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_getOrDeleteIfExpired).call(this, key, item) : item.value;\n }, _QuickLRU_peek = function _QuickLRU_peek(key, cache) {\n const item = cache.get(key);\n return __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_getItemValue).call(this, key, item);\n }, _QuickLRU_set = function _QuickLRU_set(key, value) {\n var _a;\n __classPrivateFieldGet(this, _QuickLRU_cache, \"f\").set(key, value);\n __classPrivateFieldSet(this, _QuickLRU_size, (_a = __classPrivateFieldGet(this, _QuickLRU_size, \"f\"), _a++, _a), \"f\");\n if (__classPrivateFieldGet(this, _QuickLRU_size, \"f\") >= __classPrivateFieldGet(this, _QuickLRU_maxSize, \"f\")) {\n __classPrivateFieldSet(this, _QuickLRU_size, 0, \"f\");\n __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_emitEvictions).call(this, __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\"));\n __classPrivateFieldSet(this, _QuickLRU_oldCache, __classPrivateFieldGet(this, _QuickLRU_cache, \"f\"), \"f\");\n __classPrivateFieldSet(this, _QuickLRU_cache, new Map(), \"f\");\n }\n }, _QuickLRU_moveToRecent = function _QuickLRU_moveToRecent(key, item) {\n __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").delete(key);\n __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_set).call(this, key, item);\n }, _QuickLRU_entriesAscending = function* _QuickLRU_entriesAscending() {\n for (const item of __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\")) {\n const [key, value] = item;\n if (!__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n const deleted = __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, value);\n if (!deleted) {\n yield item;\n }\n }\n }\n for (const item of __classPrivateFieldGet(this, _QuickLRU_cache, \"f\")) {\n const [key, value] = item;\n const deleted = __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, value);\n if (!deleted) {\n yield item;\n }\n }\n }, Symbol.iterator)]() {\n for (const item of __classPrivateFieldGet(this, _QuickLRU_cache, \"f\")) {\n const [key, value] = item;\n const deleted = __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, value);\n if (!deleted) {\n yield [key, value.value];\n }\n }\n for (const item of __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\")) {\n const [key, value] = item;\n if (!__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n const deleted = __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, value);\n if (!deleted) {\n yield [key, value.value];\n }\n }\n }\n }\n *entriesDescending() {\n let items = [...__classPrivateFieldGet(this, _QuickLRU_cache, \"f\")];\n for (let i = items.length - 1; i >= 0; --i) {\n const item = items[i];\n const [key, value] = item;\n const deleted = __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, value);\n if (!deleted) {\n yield [key, value.value];\n }\n }\n items = [...__classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\")];\n for (let i = items.length - 1; i >= 0; --i) {\n const item = items[i];\n const [key, value] = item;\n if (!__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n const deleted = __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_deleteIfExpired).call(this, key, value);\n if (!deleted) {\n yield [key, value.value];\n }\n }\n }\n }\n *entriesAscending() {\n for (const [key, value] of __classPrivateFieldGet(this, _QuickLRU_instances, \"m\", _QuickLRU_entriesAscending).call(this)) {\n yield [key, value.value];\n }\n }\n get size() {\n if (!__classPrivateFieldGet(this, _QuickLRU_size, \"f\")) {\n return __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").size;\n }\n let oldCacheSize = 0;\n for (const key of __classPrivateFieldGet(this, _QuickLRU_oldCache, \"f\").keys()) {\n if (!__classPrivateFieldGet(this, _QuickLRU_cache, \"f\").has(key)) {\n oldCacheSize++;\n }\n }\n return Math.min(__classPrivateFieldGet(this, _QuickLRU_size, \"f\") + oldCacheSize, __classPrivateFieldGet(this, _QuickLRU_maxSize, \"f\"));\n }\n get maxSize() {\n return __classPrivateFieldGet(this, _QuickLRU_maxSize, \"f\");\n }\n get maxAge() {\n return __classPrivateFieldGet(this, _QuickLRU_maxAge, \"f\");\n }\n entries() {\n return this.entriesAscending();\n }\n forEach(callbackFunction, thisArgument = this) {\n for (const [key, value] of this.entriesAscending()) {\n callbackFunction.call(thisArgument, value, key, this);\n }\n }\n // eslint-disable-next-line @typescript-eslint/class-literal-property-style\n get [Symbol.toStringTag]() {\n return 'QuickLRU';\n }\n toString() {\n return `QuickLRU(${this.size}/${this.maxSize})`;\n }\n [Symbol.for('nodejs.util.inspect.custom')]() {\n return this.toString();\n }\n}\n//# sourceMappingURL=index.js.map","// Merges overlapping or adjacent byte ranges so that nearby R-tree nodes can\n// be fetched in a single read rather than many small reads\nexport function mergeRanges(ranges) {\n const sorted = [...ranges].sort((a, b) => a.min !== b.min ? a.min - b.min : a.max - b.max);\n const merged = [];\n let current = sorted[0];\n for (let i = 1; i < sorted.length; i++) {\n const nxt = sorted[i];\n if (nxt.min > current.max + 1) {\n merged.push(current);\n current = nxt;\n }\n else if (nxt.max > current.max) {\n current = { min: current.min, max: nxt.max };\n }\n }\n merged.push(current);\n return merged;\n}\n//# sourceMappingURL=range.js.map","/******/ // The require scope\n/******/ var __webpack_require__ = {};\n/******/\n/************************************************************************/\n/******/ /* webpack/runtime/define property getters */\n/******/ (() => {\n /******/ // define getter functions for harmony exports\n /******/ __webpack_require__.d = (exports, definition) => {\n /******/ for (var key in definition) {\n /******/ if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n /******/ }\n /******/ }\n /******/ \n };\n /******/ \n})();\n/******/\n/******/ /* webpack/runtime/hasOwnProperty shorthand */\n/******/ (() => {\n /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop));\n /******/ \n})();\n/******/\n/******/ /* webpack/runtime/make namespace object */\n/******/ (() => {\n /******/ // define __esModule on exports\n /******/ __webpack_require__.r = (exports) => {\n /******/ if (typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n /******/ }\n /******/ Object.defineProperty(exports, '__esModule', { value: true });\n /******/ \n };\n /******/ \n})();\n/******/\n/************************************************************************/\nvar __webpack_exports__ = {};\n// NAMESPACE OBJECT: ./src/wasm/inflate_wasm_bg.js\nvar src_wasm_inflate_wasm_bg_namespaceObject = {};\n__webpack_require__.r(src_wasm_inflate_wasm_bg_namespaceObject);\n__webpack_require__.d(src_wasm_inflate_wasm_bg_namespaceObject, {\n __wbg_Error_83742b46f01ce22d: () => (__wbg_Error_83742b46f01ce22d),\n __wbg_set_wasm: () => (__wbg_set_wasm),\n decompress_and_parse_bigwig: () => (decompress_and_parse_bigwig),\n decompress_and_parse_summary: () => (decompress_and_parse_summary),\n inflate_raw: () => (inflate_raw),\n inflate_raw_batch: () => (inflate_raw_batch),\n inflate_raw_unknown_size: () => (inflate_raw_unknown_size),\n parse_bigwig_block: () => (parse_bigwig_block),\n parse_summary_block: () => (parse_summary_block)\n});\n; // ./src/wasm/inflate_wasm_bg.wasm\nconst inflate_wasm_bg_namespaceObject = \"data:application/wasm;base64,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IGlzIMASIGJ1dCB0aGUgaW5kZXggaXMgwAAScmFuZ2Ugc3RhcnQgaW5kZXggwCIgb3V0IG9mIHJhbmdlIGZvciBzbGljZSBvZiBsZW5ndGggwAAQcmFuZ2UgZW5kIGluZGV4IMAiIG91dCBvZiByYW5nZSBmb3Igc2xpY2Ugb2YgbGVuZ3RoIMAAFmRlY29tcHJlc3Npb24gZmFpbGVkOiDAAMACOiDAAC9ydXN0Yy80YTRlZjQ5M2UzYTE0ODhjNmUzMjE1NzAyMzgwODRiMzg5NDhmNmRiL2xpYnJhcnkvYWxsb2Mvc3JjL2ZtdC5ycwAvcnVzdGMvNGE0ZWY0OTNlM2ExNDg4YzZlMzIxNTcwMjM4MDg0YjM4OTQ4ZjZkYi9saWJyYXJ5L2NvcmUvc3JjL2ZtdC9udW0ucnMAL2hvbWUvY2RpZXNoLy5jYXJnby9yZWdpc3RyeS9zcmMvaW5kZXguY3JhdGVzLmlvLTE5NDljZjhjNmI1YjU1N2Yvd2FzbS1iaW5kZ2VuLTAuMi4xMTQvc3JjL2V4dGVybnJlZi5ycwAvcnVzdGMvNGE0ZWY0OTNlM2ExNDg4YzZlMzIxNTcwMjM4MDg0YjM4OTQ4ZjZkYi9saWJyYXJ5L2FsbG9jL3NyYy9yYXdfdmVjL21vZC5ycwAvcnVzdC9kZXBzL2RsbWFsbG9jLTAuMi4xMS9zcmMvZGxtYWxsb2MucnMAL2hvbWUvY2RpZXNoLy5jYXJnby9yZWdpc3RyeS9zcmMvaW5kZXguY3JhdGVzLmlvLTE5NDljZjhjNmI1YjU1N2YvbGliZGVmbGF0ZXItMS4yNS4yL3NyYy9saWIucnMAALwCEAAKAAAAbAAAABkAAAC8AhAACgAAAGwAAAAnAAAAvAIQAAoAAABsAAAAOQAAALwCEAAKAAAAbAAAAEsAAAC8AhAACgAAAGAAAAAZAAAAvAIQAAoAAABgAAAAJwAAALwCEAAKAAAAYAAAADkAAAC8AhAACgAAAGAAAABLAAAAvAIQAAoAAABkAAAAGQAAALwCEAAKAAAAZAAAACcAAAC8AhAACgAAAGQAAAA5AAAAvAIQAAoAAABkAAAASwAAALwCEAAKAAAAQAAAAAsAAAC8AhAACgAAAFgAAAALAAAAvAIQAAoAAABJAAAAEwAAALwCEAAKAAAAUwAAACsAAAC8AhAACgAAAE0AAAAPAAAAvAIQAAoAAABKAAAAHAAAALwCEAAKAAAAOQAAAB0AAABkZWNvbXByZXNzaW9uIG91dHB1dCB0b28gbGFyZ2UAALwCEAAKAAAAJgEAABMAAAC8AhAACgAAAC0BAAAdAAAAvAIQAAoAAAAnAQAAHAAAALwCEAAKAAAAoAEAABMAAAC8AhAACgAAAKcBAAAdAAAAvAIQAAoAAAChAQAAHAAAAEJhZERhdGFJbnN1ZmZpY2llbnRTcGFjZYMBEABnAAAAfwAAABEAAACDARAAZwAAAIwAAAARAAAAbGliZGVmbGF0ZV9kZWZsYXRlX2RlY29tcHJlc3MgcmV0dXJuZWQgYW4gdW5rbm93biBlcnJvciB0eXBlOiB0aGlzIGlzIGFuIGludGVybmFsIGJ1ZyB0aGF0ICoqbXVzdCoqIGJlIGZpeGVkZwIQAF8AAAANAQAAFQAAAGxpYmRlZmxhdGVfYWxsb2NfZGVjb21wcmVzc29yIHJldHVybmVkIE5VTEw6IG91dCBvZiBtZW1vcnkAAGcCEABfAAAAnQAAABEAAAAMAAAAAgAAAAMAAAAAAAAAAAAAAAAAAAAQERIACAcJBgoFCwQMAw0CDgEPAAAAAAAAAAAAAAAAAAAAAAAAAAEAAAACAAAAAwAAAAQAAAAFAAAABgAAAAcAAAAIAAAACQAAAAoAAAALAAAADAAAAA0AAAAOAAAADwAAABAAAAARAAAAEgAAAAAAAAABAAAAAgAAAAMAAAAEAAEABQABAAcAAgAJAAIADQADABEAAwAZAAQAIQAEADEABQBBAAUAYQAGAIEABgDBAAcAAQEHAIEBCAABAggAAQMJAAEECQABBgoAAQgKAAEMCwABEAsAARgMAAEgDAABMA0AAUANAAFgDQABYA0AAWAAAACAAAABgAAAAoAAAAOAAAAEgAAABYAAAAaAAAAHgAAACIAAAAmAAAAKgAAAC4AAAAyAAAANgAAADoAAAA+AAAAQgAAAEYAAABKAAAATgAAAFIAAABWAAAAWgAAAF4AAABiAAAAZgAAAGoAAABuAAAAcgAAAHYAAAB6AAAAfgAAAIIAAACGAAAAigAAAI4AAACSAAAAlgAAAJoAAACeAAAAogAAAKYAAACqAAAArgAAALIAAAC2AAAAugAAAL4AAADCAAAAxgAAAMoAAADOAAAA0gAAANYAAADaAAAA3gAAAOIAAADmAAAA6gAAAO4AAADyAAAA9gAAAPoAAAD+AAABAgAAAQYAAAEKAAABDgAAARIAAAEWAAABGgAAAR4AAAEiAAABJgAAASoAAAEuAAABMgAAATYAAAE6AAABPgAAAUIAAAFGAAABSgAAAU4AAAFSAAABVgAAAVoAAAFeAAABYgAAAWYAAAFqAAABbgAAAXIAAAF2AAABegAAAX4AAAGCAAABhgAAAYoAAAGOAAABkgAAAZYAAAGaAAABngAAAaIAAAGmAAABqgAAAa4AAAGyAAABtgAAAboAAAG+AAABwgAAAcYAAAHKAAABzgAAAdIAAAHWAAAB2gAAAd4AAAHiAAAB5gAAAeoAAAHuAAAB8gAAAfYAAAH6AAAB/gAAAgIAAAIGAAACCgAAAg4AAAISAAACFgAAAhoAAAIeAAACIgAAAiYAAAIqAAACLgAAAjIAAAI2AAACOgAAAj4AAAJCAAACRgAAAkoAAAJOAAACUgAAAlYAAAJaAAACXgAAAmIAAAJmAAACagAAAm4AAAJyAAACdgAAAnoAAAJ+AAACggAAAoYAAAKKAAACjgAAApIAAAKWAAACmgAAAp4AAAKiAAACpgAAAqoAAAKuAAACsgAAArYAAAK6AAACvgAAAsIAAALGAAACygAAAs4AAALSAAAC1gAAAtoAAALeAAAC4gAAAuYAAALqAAAC7gAAAvIAAAL2AAAC+gAAAv4AAAMCAAADBgAAAwoAAAMOAAADEgAAAxYAAAMaAAADHgAAAyIAAAMmAAADKgAAAy4AAAMyAAADNgAAAzoAAAM+AAADQgAAA0YAAANKAAADTgAAA1IAAANWAAADWgAAA14AAANiAAADZgAAA2oAAANuAAADcgAAA3YAAAN6AAADfgAAA4IAAAOGAAADigAAA44AAAOSAAADlgAAA5oAAAOeAAADogAAA6YAAAOqAAADrgAAA7IAAAO2AAADugAAA74AAAPCAAADxgAAA8oAAAPOAAAD0gAAA9YAAAPaAAAD3gAAA+IAAAPmAAAD6gAAA+4AAAPyAAAD9gAAA/oAAAP+AAKAAAAAAAwAAAAQAAAAFAAAABgAAAAcAAAAIAAAACQAAAAoAAQALAAEADQABAA8AAQARAAIAEwACABcAAgAbAAIAHwADACMAAwArAAMAMwADADsABABDAAQAUwAEAGMABABzAAUAgwAFAKMABQDDAAUA4wAAAAIBAAACAQAAAgFtXcvWLFDrY3hBpldxG4u5I8o7SqZ3fJNCY0mvl2+yhAAAAAAIAAAABAAAAAUAAAAGAAAABwAAAAgAAAAJAAAADAAAAAQAAAAKAAAACwAAAAwAAAAAAAAACAAAAAQAAAANAAAADgAAAA8AAAAQAAAAEQAAABAAAAAEAAAAEgAAABMAAAAUAAAACAAAAAAAAAAIAAAABAAAABUAAABhc3NlcnRpb24gZmFpbGVkOiBwc2l6ZSA+PSBzaXplICsgbWluX292ZXJoZWFkAAA8AhAAKgAAALEEAAAJAAAAYXNzZXJ0aW9uIGZhaWxlZDogcHNpemUgPD0gc2l6ZSArIG1heF9vdmVyaGVhZAAAPAIQACoAAAC3BAAADQAAAAkAAAAMAAAABAAAABYAAABFcnJvcgAAABcAAAAMAAAABAAAABgAAAAZAAAAGgAAAAAAAAAAAAAAAQAAABsAAABhIGZvcm1hdHRpbmcgdHJhaXQgaW1wbGVtZW50YXRpb24gcmV0dXJuZWQgYW4gZXJyb3Igd2hlbiB0aGUgdW5kZXJseWluZyBzdHJlYW0gZGlkIG5vdAAA7gAQAEgAAACKAgAADgAAAGNhcGFjaXR5IG92ZXJmbG93AAAA6wEQAFAAAAAcAAAABQAAADAwMDEwMjAzMDQwNTA2MDcwODA5MTAxMTEyMTMxNDE1MTYxNzE4MTkyMDIxMjIyMzI0MjUyNjI3MjgyOTMwMzEzMjMzMzQzNTM2MzczODM5NDA0MTQyNDM0NDQ1NDY0NzQ4NDk1MDUxNTI1MzU0NTU1NjU3NTg1OTYwNjE2MjYzNjQ2NTY2Njc2ODY5NzA3MTcyNzM3NDc1NzY3Nzc4Nzk4MDgxODI4Mzg0ODU4Njg3ODg4OTkwOTE5MjkzOTQ5NTk2OTc5ODk5NwEQAEsAAABXAgAABQAAAFJlZkNlbGwgYWxyZWFkeSBib3Jyb3dlZABB2JvAAAsEBAAAAAApBG5hbWUBIgFjH19fd2JpbmRnZW5fYWRkX3RvX3N0YWNrX3BvaW50ZXIAPAlwcm9kdWNlcnMBDHByb2Nlc3NlZC1ieQIGd2FscnVzBjAuMjUuMgx3YXNtLWJpbmRnZW4HMC4yLjExNA==\";\n; // ./src/wasm/inflate_wasm_bg.js\n/**\n * Combined decompress + parse for BigWig blocks\n * Returns same format as parse_bigwig_block but handles multiple compressed blocks\n * @param {Uint8Array} inputs\n * @param {Uint32Array} input_offsets\n * @param {Uint32Array} input_lengths\n * @param {number} max_block_size\n * @param {number} req_start\n * @param {number} req_end\n * @returns {Uint8Array}\n */\nfunction decompress_and_parse_bigwig(inputs, input_offsets, input_lengths, max_block_size, req_start, req_end) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(inputs, wasm.__wbindgen_export);\n const len0 = WASM_VECTOR_LEN;\n const ptr1 = passArray32ToWasm0(input_offsets, wasm.__wbindgen_export);\n const len1 = WASM_VECTOR_LEN;\n const ptr2 = passArray32ToWasm0(input_lengths, wasm.__wbindgen_export);\n const len2 = WASM_VECTOR_LEN;\n wasm.decompress_and_parse_bigwig(retptr, ptr0, len0, ptr1, len1, ptr2, len2, max_block_size, req_start, req_end);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);\n if (r3) {\n throw takeObject(r2);\n }\n var v4 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export2(r0, r1 * 1, 1);\n return v4;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * Combined decompress + parse for summary blocks\n * @param {Uint8Array} inputs\n * @param {Uint32Array} input_offsets\n * @param {Uint32Array} input_lengths\n * @param {number} max_block_size\n * @param {number} req_chr_id\n * @param {number} req_start\n * @param {number} req_end\n * @returns {Uint8Array}\n */\nfunction decompress_and_parse_summary(inputs, input_offsets, input_lengths, max_block_size, req_chr_id, req_start, req_end) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(inputs, wasm.__wbindgen_export);\n const len0 = WASM_VECTOR_LEN;\n const ptr1 = passArray32ToWasm0(input_offsets, wasm.__wbindgen_export);\n const len1 = WASM_VECTOR_LEN;\n const ptr2 = passArray32ToWasm0(input_lengths, wasm.__wbindgen_export);\n const len2 = WASM_VECTOR_LEN;\n wasm.decompress_and_parse_summary(retptr, ptr0, len0, ptr1, len1, ptr2, len2, max_block_size, req_chr_id, req_start, req_end);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);\n if (r3) {\n throw takeObject(r2);\n }\n var v4 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export2(r0, r1 * 1, 1);\n return v4;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * @param {Uint8Array} input\n * @param {number} output_size\n * @returns {Uint8Array}\n */\nfunction inflate_raw(input, output_size) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(input, wasm.__wbindgen_export);\n const len0 = WASM_VECTOR_LEN;\n wasm.inflate_raw(retptr, ptr0, len0, output_size);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);\n if (r3) {\n throw takeObject(r2);\n }\n var v2 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export2(r0, r1 * 1, 1);\n return v2;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * @param {Uint8Array} inputs\n * @param {Uint32Array} input_offsets\n * @param {Uint32Array} input_lengths\n * @param {number} max_block_size\n * @returns {Uint8Array}\n */\nfunction inflate_raw_batch(inputs, input_offsets, input_lengths, max_block_size) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(inputs, wasm.__wbindgen_export);\n const len0 = WASM_VECTOR_LEN;\n const ptr1 = passArray32ToWasm0(input_offsets, wasm.__wbindgen_export);\n const len1 = WASM_VECTOR_LEN;\n const ptr2 = passArray32ToWasm0(input_lengths, wasm.__wbindgen_export);\n const len2 = WASM_VECTOR_LEN;\n wasm.inflate_raw_batch(retptr, ptr0, len0, ptr1, len1, ptr2, len2, max_block_size);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);\n if (r3) {\n throw takeObject(r2);\n }\n var v4 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export2(r0, r1 * 1, 1);\n return v4;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * @param {Uint8Array} input\n * @returns {Uint8Array}\n */\nfunction inflate_raw_unknown_size(input) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(input, wasm.__wbindgen_export);\n const len0 = WASM_VECTOR_LEN;\n wasm.inflate_raw_unknown_size(retptr, ptr0, len0);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);\n if (r3) {\n throw takeObject(r2);\n }\n var v2 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export2(r0, r1 * 1, 1);\n return v2;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * Parse a BigWig data block and return packed typed arrays\n * Block types: 1 = bedGraph, 2 = varstep, 3 = fixedstep\n *\n * Returns packed binary: [count: u32][starts: i32*count][ends: i32*count][scores: f32*count]\n * @param {Uint8Array} data\n * @param {number} req_start\n * @param {number} req_end\n * @returns {Uint8Array}\n */\nfunction parse_bigwig_block(data, req_start, req_end) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(data, wasm.__wbindgen_export);\n const len0 = WASM_VECTOR_LEN;\n wasm.parse_bigwig_block(retptr, ptr0, len0, req_start, req_end);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var v2 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export2(r0, r1 * 1, 1);\n return v2;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * Parse a BigWig summary block and return packed typed arrays\n * Summary blocks contain: chromId, start, end, validCnt, minScore, maxScore, sumData, sumSqData\n *\n * Returns: [count: u32][starts: i32*n][ends: i32*n][scores: f32*n][minScores: f32*n][maxScores: f32*n]\n * @param {Uint8Array} data\n * @param {number} req_chr_id\n * @param {number} req_start\n * @param {number} req_end\n * @returns {Uint8Array}\n */\nfunction parse_summary_block(data, req_chr_id, req_start, req_end) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(data, wasm.__wbindgen_export);\n const len0 = WASM_VECTOR_LEN;\n wasm.parse_summary_block(retptr, ptr0, len0, req_chr_id, req_start, req_end);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var v2 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export2(r0, r1 * 1, 1);\n return v2;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\nfunction __wbg_Error_83742b46f01ce22d(arg0, arg1) {\n const ret = Error(getStringFromWasm0(arg0, arg1));\n return addHeapObject(ret);\n}\nfunction addHeapObject(obj) {\n if (heap_next === heap.length)\n heap.push(heap.length + 1);\n const idx = heap_next;\n heap_next = heap[idx];\n heap[idx] = obj;\n return idx;\n}\nfunction dropObject(idx) {\n if (idx < 1028)\n return;\n heap[idx] = heap_next;\n heap_next = idx;\n}\nfunction getArrayU8FromWasm0(ptr, len) {\n ptr = ptr >>> 0;\n return getUint8ArrayMemory0().subarray(ptr / 1, ptr / 1 + len);\n}\nlet cachedDataViewMemory0 = null;\nfunction getDataViewMemory0() {\n if (cachedDataViewMemory0 === null || cachedDataViewMemory0.buffer.detached === true || (cachedDataViewMemory0.buffer.detached === undefined && cachedDataViewMemory0.buffer !== wasm.memory.buffer)) {\n cachedDataViewMemory0 = new DataView(wasm.memory.buffer);\n }\n return cachedDataViewMemory0;\n}\nfunction getStringFromWasm0(ptr, len) {\n ptr = ptr >>> 0;\n return decodeText(ptr, len);\n}\nlet cachedUint32ArrayMemory0 = null;\nfunction getUint32ArrayMemory0() {\n if (cachedUint32ArrayMemory0 === null || cachedUint32ArrayMemory0.byteLength === 0) {\n cachedUint32ArrayMemory0 = new Uint32Array(wasm.memory.buffer);\n }\n return cachedUint32ArrayMemory0;\n}\nlet cachedUint8ArrayMemory0 = null;\nfunction getUint8ArrayMemory0() {\n if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) {\n cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer);\n }\n return cachedUint8ArrayMemory0;\n}\nfunction getObject(idx) { return heap[idx]; }\nlet heap = new Array(1024).fill(undefined);\nheap.push(undefined, null, true, false);\nlet heap_next = heap.length;\nfunction passArray32ToWasm0(arg, malloc) {\n const ptr = malloc(arg.length * 4, 4) >>> 0;\n getUint32ArrayMemory0().set(arg, ptr / 4);\n WASM_VECTOR_LEN = arg.length;\n return ptr;\n}\nfunction passArray8ToWasm0(arg, malloc) {\n const ptr = malloc(arg.length * 1, 1) >>> 0;\n getUint8ArrayMemory0().set(arg, ptr / 1);\n WASM_VECTOR_LEN = arg.length;\n return ptr;\n}\nfunction takeObject(idx) {\n const ret = getObject(idx);\n dropObject(idx);\n return ret;\n}\nlet cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });\ncachedTextDecoder.decode();\nconst MAX_SAFARI_DECODE_BYTES = 2146435072;\nlet numBytesDecoded = 0;\nfunction decodeText(ptr, len) {\n numBytesDecoded += len;\n if (numBytesDecoded >= MAX_SAFARI_DECODE_BYTES) {\n cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });\n cachedTextDecoder.decode();\n numBytesDecoded = len;\n }\n return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len));\n}\nlet WASM_VECTOR_LEN = 0;\nlet wasm;\nfunction __wbg_set_wasm(val) {\n wasm = val;\n}\n; // ./crate/src/wrapper.js\nlet wrapper_wasm = null;\nlet initPromise = null;\nasync function init() {\n if (wrapper_wasm)\n return wrapper_wasm;\n if (!initPromise) {\n initPromise = (async () => {\n const response = await fetch(inflate_wasm_bg_namespaceObject);\n const bytes = await response.arrayBuffer();\n const { instance } = await WebAssembly.instantiate(bytes, {\n './inflate_wasm_bg.js': src_wasm_inflate_wasm_bg_namespaceObject,\n });\n wrapper_wasm = instance.exports;\n __wbg_set_wasm(wrapper_wasm);\n return wrapper_wasm;\n })();\n }\n return initPromise;\n}\nasync function inflateRaw(input, outputSize) {\n await init();\n return inflate_raw(input, outputSize);\n}\nasync function inflateRawUnknownSize(input) {\n await init();\n return inflate_raw_unknown_size(input);\n}\nasync function inflateRawBatch(inputs, inputOffsets, inputLengths, maxOutputSize) {\n await init();\n const packed = inflate_raw_batch(inputs, inputOffsets, inputLengths, maxOutputSize);\n const view = new DataView(packed.buffer, packed.byteOffset, packed.byteLength);\n const numBlocks = view.getUint32(0, true);\n const offsetsStart = 4;\n const dataStart = offsetsStart + (numBlocks + 1) * 4;\n const offsets = new Array(numBlocks + 1);\n for (let i = 0; i <= numBlocks; i++) {\n offsets[i] = view.getUint32(offsetsStart + i * 4, true);\n }\n const data = packed.subarray(dataStart);\n return { data, offsets };\n}\nfunction unpackBigWigFeatures(packed) {\n const view = new DataView(packed.buffer, packed.byteOffset, packed.byteLength);\n const count = view.getUint32(0, true);\n if (count === 0) {\n return {\n starts: new Int32Array(0),\n ends: new Int32Array(0),\n scores: new Float32Array(0),\n };\n }\n const startsOffset = 4;\n const endsOffset = startsOffset + count * 4;\n const scoresOffset = endsOffset + count * 4;\n return {\n starts: new Int32Array(packed.buffer, packed.byteOffset + startsOffset, count),\n ends: new Int32Array(packed.buffer, packed.byteOffset + endsOffset, count),\n scores: new Float32Array(packed.buffer, packed.byteOffset + scoresOffset, count),\n };\n}\nfunction unpackSummaryFeatures(packed) {\n const view = new DataView(packed.buffer, packed.byteOffset, packed.byteLength);\n const count = view.getUint32(0, true);\n if (count === 0) {\n return {\n starts: new Int32Array(0),\n ends: new Int32Array(0),\n scores: new Float32Array(0),\n minScores: new Float32Array(0),\n maxScores: new Float32Array(0),\n };\n }\n const startsOffset = 4;\n const endsOffset = startsOffset + count * 4;\n const scoresOffset = endsOffset + count * 4;\n const minScoresOffset = scoresOffset + count * 4;\n const maxScoresOffset = minScoresOffset + count * 4;\n return {\n starts: new Int32Array(packed.buffer, packed.byteOffset + startsOffset, count),\n ends: new Int32Array(packed.buffer, packed.byteOffset + endsOffset, count),\n scores: new Float32Array(packed.buffer, packed.byteOffset + scoresOffset, count),\n minScores: new Float32Array(packed.buffer, packed.byteOffset + minScoresOffset, count),\n maxScores: new Float32Array(packed.buffer, packed.byteOffset + maxScoresOffset, count),\n };\n}\nasync function decompressAndParseBigWig(inputs, inputOffsets, inputLengths, maxBlockSize, reqStart, reqEnd) {\n await init();\n const packed = decompress_and_parse_bigwig(inputs, inputOffsets, inputLengths, maxBlockSize, reqStart, reqEnd);\n return unpackBigWigFeatures(packed);\n}\nasync function decompressAndParseSummary(inputs, inputOffsets, inputLengths, maxBlockSize, reqChrId, reqStart, reqEnd) {\n await init();\n const packed = decompress_and_parse_summary(inputs, inputOffsets, inputLengths, maxBlockSize, reqChrId, reqStart, reqEnd);\n return unpackSummaryFeatures(packed);\n}\nexport { decompressAndParseBigWig, decompressAndParseSummary, inflateRaw, inflateRawBatch, inflateRawUnknownSize };\n//# sourceMappingURL=inflate-wasm-inlined.js.map","import { decompressAndParseBigWig, decompressAndParseSummary, inflateRawBatch, } from './wasm/inflate-wasm-inlined.js';\nexport async function unzipBatch(data, blocks, maxOutputSize) {\n const inputOffsets = new Uint32Array(blocks.length);\n const inputLengths = new Uint32Array(blocks.length);\n for (let i = 0; i < blocks.length; i++) {\n const block = blocks[i];\n inputOffsets[i] = block.offset;\n inputLengths[i] = block.length;\n }\n return inflateRawBatch(data, inputOffsets, inputLengths, maxOutputSize);\n}\nexport async function decompressAndParseBigWigBlocks(data, blocks, maxOutputSize, reqStart, reqEnd) {\n const inputOffsets = new Uint32Array(blocks.length);\n const inputLengths = new Uint32Array(blocks.length);\n for (let i = 0; i < blocks.length; i++) {\n const block = blocks[i];\n inputOffsets[i] = block.offset;\n inputLengths[i] = block.length;\n }\n return decompressAndParseBigWig(data, inputOffsets, inputLengths, maxOutputSize, reqStart, reqEnd);\n}\nexport async function decompressAndParseSummaryBlocks(data, blocks, maxOutputSize, reqChrId, reqStart, reqEnd) {\n const inputOffsets = new Uint32Array(blocks.length);\n const inputLengths = new Uint32Array(blocks.length);\n for (let i = 0; i < blocks.length; i++) {\n const block = blocks[i];\n inputOffsets[i] = block.offset;\n inputLengths[i] = block.length;\n }\n return decompressAndParseSummary(data, inputOffsets, inputLengths, maxOutputSize, reqChrId, reqStart, reqEnd);\n}\n//# sourceMappingURL=unzip.js.map","// sort blocks by file offset and\n// group blocks that are within 2KB of eachother\nexport function groupBlocks(blocks) {\n blocks.sort((b0, b1) => b0.offset - b1.offset);\n const blockGroups = [];\n let lastBlock;\n let lastBlockEnd;\n for (const block of blocks) {\n if (lastBlock && lastBlockEnd && block.offset - lastBlockEnd <= 2000) {\n lastBlock.length = block.offset + block.length - lastBlock.offset;\n lastBlock.blocks.push(block);\n lastBlockEnd = block.offset + block.length;\n }\n else {\n lastBlock = {\n blocks: [block],\n length: block.length,\n offset: block.offset,\n };\n blockGroups.push(lastBlock);\n lastBlockEnd = block.offset + block.length;\n }\n }\n return blockGroups;\n}\n//# sourceMappingURL=util.js.map","import AbortablePromiseCache from '@gmod/abortable-promise-cache';\nimport QuickLRU from '@jbrowse/quick-lru';\nimport { mergeRanges } from \"./range.js\";\nimport { decompressAndParseBigWigBlocks, decompressAndParseSummaryBlocks, unzipBatch, } from \"./unzip.js\";\nimport { groupBlocks } from \"./util.js\";\nconst decoder = new TextDecoder('utf8');\nconst CIR_TREE_MAGIC = 0x2468ace0;\nfunction coordFilter(s1, e1, s2, e2) {\n return s1 < e2 && e1 >= s2;\n}\nfunction parseSummaryBlock(b, startOffset, request) {\n const features = [];\n let offset = startOffset;\n const dataView = new DataView(b.buffer, b.byteOffset, b.length);\n while (offset < b.byteLength) {\n const chromId = dataView.getUint32(offset, true);\n offset += 4;\n const start = dataView.getUint32(offset, true);\n offset += 4;\n const end = dataView.getUint32(offset, true);\n offset += 4;\n const validCnt = dataView.getUint32(offset, true);\n offset += 4;\n const minScore = dataView.getFloat32(offset, true);\n offset += 4;\n const maxScore = dataView.getFloat32(offset, true);\n offset += 4;\n const sumData = dataView.getFloat32(offset, true);\n offset += 8;\n if (!request ||\n (chromId === request.chrId &&\n coordFilter(start, end, request.start, request.end))) {\n features.push({\n start,\n end,\n maxScore,\n minScore,\n summary: true,\n score: sumData / (validCnt || 1),\n });\n }\n }\n return features;\n}\nfunction parseBigBedBlock(data, startOffset, offset, request) {\n const items = [];\n let currOffset = startOffset;\n const dataView = new DataView(data.buffer, data.byteOffset, data.length);\n while (currOffset < data.byteLength) {\n const c2 = currOffset;\n const chromId = dataView.getUint32(currOffset, true);\n currOffset += 4;\n const start = dataView.getInt32(currOffset, true);\n currOffset += 4;\n const end = dataView.getInt32(currOffset, true);\n currOffset += 4;\n let i = currOffset;\n for (; i < data.length; i++) {\n if (data[i] === 0) {\n break;\n }\n }\n const b = data.subarray(currOffset, i);\n const rest = decoder.decode(b);\n currOffset = i + 1;\n if (!request ||\n (chromId === request.chrId &&\n coordFilter(start, end, request.start, request.end))) {\n items.push({\n start,\n end,\n rest,\n uniqueId: `bb-${offset + c2}`,\n });\n }\n }\n return items;\n}\nfunction parseBigWigBlock(buffer, startOffset, req) {\n const b = buffer.subarray(startOffset);\n const dataView = new DataView(b.buffer, b.byteOffset, b.length);\n const blockStart = dataView.getInt32(4, true);\n const itemStep = dataView.getUint32(12, true);\n const itemSpan = dataView.getUint32(16, true);\n const blockType = dataView.getUint8(20);\n const itemCount = dataView.getUint16(22, true);\n let offset = 24;\n const items = [];\n switch (blockType) {\n case 1: {\n for (let i = 0; i < itemCount; i++) {\n const start = dataView.getInt32(offset, true);\n offset += 4;\n const end = dataView.getInt32(offset, true);\n offset += 4;\n const score = dataView.getFloat32(offset, true);\n offset += 4;\n if (!req || coordFilter(start, end, req.start, req.end)) {\n items.push({ start, end, score });\n }\n }\n break;\n }\n case 2: {\n for (let i = 0; i < itemCount; i++) {\n const start = dataView.getInt32(offset, true);\n offset += 4;\n const score = dataView.getFloat32(offset, true);\n offset += 4;\n const end = start + itemSpan;\n if (!req || coordFilter(start, end, req.start, req.end)) {\n items.push({ score, start, end });\n }\n }\n break;\n }\n case 3: {\n for (let i = 0; i < itemCount; i++) {\n const score = dataView.getFloat32(offset, true);\n offset += 4;\n const start = blockStart + i * itemStep;\n const end = start + itemSpan;\n if (!req || coordFilter(start, end, req.start, req.end)) {\n items.push({ score, start, end });\n }\n }\n break;\n }\n }\n return items;\n}\nfunction parseBigWigBlockAsArrays(buffer, startOffset, req) {\n const dataView = new DataView(buffer.buffer, buffer.byteOffset + startOffset, buffer.length - startOffset);\n const blockStart = dataView.getInt32(4, true);\n const itemStep = dataView.getUint32(12, true);\n const itemSpan = dataView.getUint32(16, true);\n const blockType = dataView.getUint8(20);\n const itemCount = dataView.getUint16(22, true);\n const starts = new Int32Array(itemCount);\n const ends = new Int32Array(itemCount);\n const scores = new Float32Array(itemCount);\n if (!req) {\n switch (blockType) {\n case 1: {\n let offset = 24;\n for (let i = 0; i < itemCount; i++) {\n starts[i] = dataView.getInt32(offset, true);\n ends[i] = dataView.getInt32(offset + 4, true);\n scores[i] = dataView.getFloat32(offset + 8, true);\n offset += 12;\n }\n return { starts, ends, scores };\n }\n case 2: {\n let offset = 24;\n for (let i = 0; i < itemCount; i++) {\n const start = dataView.getInt32(offset, true);\n starts[i] = start;\n ends[i] = start + itemSpan;\n scores[i] = dataView.getFloat32(offset + 4, true);\n offset += 8;\n }\n return { starts, ends, scores };\n }\n case 3: {\n let offset = 24;\n for (let i = 0; i < itemCount; i++) {\n const start = blockStart + i * itemStep;\n starts[i] = start;\n ends[i] = start + itemSpan;\n scores[i] = dataView.getFloat32(offset, true);\n offset += 4;\n }\n return { starts, ends, scores };\n }\n }\n return { starts, ends, scores };\n }\n const reqStart = req.start;\n const reqEnd = req.end;\n let idx = 0;\n switch (blockType) {\n case 1: {\n let offset = 24;\n for (let i = 0; i < itemCount; i++) {\n const start = dataView.getInt32(offset, true);\n const end = dataView.getInt32(offset + 4, true);\n if (start < reqEnd && end >= reqStart) {\n starts[idx] = start;\n ends[idx] = end;\n scores[idx] = dataView.getFloat32(offset + 8, true);\n idx++;\n }\n offset += 12;\n }\n break;\n }\n case 2: {\n let offset = 24;\n for (let i = 0; i < itemCount; i++) {\n const start = dataView.getInt32(offset, true);\n const end = start + itemSpan;\n if (start < reqEnd && end >= reqStart) {\n starts[idx] = start;\n ends[idx] = end;\n scores[idx] = dataView.getFloat32(offset + 4, true);\n idx++;\n }\n offset += 8;\n }\n break;\n }\n case 3: {\n let offset = 24;\n for (let i = 0; i < itemCount; i++) {\n const start = blockStart + i * itemStep;\n const end = start + itemSpan;\n if (start < reqEnd && end >= reqStart) {\n starts[idx] = start;\n ends[idx] = end;\n scores[idx] = dataView.getFloat32(offset, true);\n idx++;\n }\n offset += 4;\n }\n break;\n }\n }\n if (idx < itemCount) {\n return {\n starts: starts.subarray(0, idx),\n ends: ends.subarray(0, idx),\n scores: scores.subarray(0, idx),\n };\n }\n return { starts, ends, scores };\n}\n/**\n * View into a subset of the data in a BigWig file.\n *\n * Adapted by Robert Buels and Colin Diesh from bigwig.js in the Dalliance\n * Genome Explorer by Thomas Down.\n */\nexport class BlockView {\n bbi;\n refsByName;\n rTreeOffset;\n uncompressBufSize;\n blockType;\n // R-tree index header cache - R-trees are spatial data structures used to\n // efficiently query genomic intervals by chromosome and position\n rTreePromise;\n featureCache = new AbortablePromiseCache({\n cache: new QuickLRU({ maxSize: 1000 }),\n fill: async ({ length, offset }, signal) => this.bbi.read(length, offset, { signal }),\n });\n constructor(bbi, refsByName, \n // Offset to the R-tree index in the file - this is part of the \"cirTree\"\n // (combined ID R-tree), which combines a B+ tree for chromosome names\n // with an R-tree for efficient spatial queries\n rTreeOffset, uncompressBufSize, blockType) {\n this.bbi = bbi;\n this.refsByName = refsByName;\n this.rTreeOffset = rTreeOffset;\n this.uncompressBufSize = uncompressBufSize;\n this.blockType = blockType;\n if (!(rTreeOffset >= 0)) {\n throw new Error('invalid rTreeOffset!');\n }\n }\n async _collectBlocks(chrName, start, end, opts) {\n const chrId = this.refsByName[chrName];\n if (chrId === undefined) {\n return undefined;\n }\n if (!this.rTreePromise) {\n this.rTreePromise = this.bbi.read(48, this.rTreeOffset, opts);\n }\n const buffer = await this.rTreePromise;\n const dataView = new DataView(buffer.buffer, buffer.byteOffset, buffer.length);\n const magic = dataView.getUint32(0, true);\n if (magic !== CIR_TREE_MAGIC) {\n throw new Error(`invalid cirTree magic: 0x${magic.toString(16)} (expected 0x${CIR_TREE_MAGIC.toString(16)}) at offset ${this.rTreeOffset}, file may be corrupt or unsupported`);\n }\n const rTreeBlockSize = dataView.getUint32(4, true);\n // Upper bound on size, based on a completely full leaf node.\n const maxRTreeBlockSpan = 4 + rTreeBlockSize * 32;\n const blockIntersectsQuery = (startChrom, startBase, endChrom, endBase) => (startChrom < chrId || (startChrom === chrId && startBase <= end)) &&\n (endChrom > chrId || (endChrom === chrId && endBase >= start));\n const blocks = [];\n let currentOffsets = [this.rTreeOffset + 48];\n while (currentOffsets.length > 0) {\n const spans = mergeRanges(currentOffsets.map(o => ({ min: o, max: o + maxRTreeBlockSpan })));\n const nextOffsets = [];\n for (const { min, max } of spans) {\n const length = max - min;\n const offset = min;\n const resultBuffer = await this.featureCache.get(`${length}_${offset}`, { length, offset }, opts?.signal);\n for (const element of currentOffsets) {\n if (min <= element && element <= max) {\n const data = resultBuffer.subarray(element - offset);\n const dv = new DataView(data.buffer, data.byteOffset, data.length);\n const isLeaf = dv.getUint8(0);\n const count = dv.getUint16(2, true);\n let nodeOffset = 4;\n if (isLeaf === 1) {\n for (let i = 0; i < count; i++) {\n const startChrom = dv.getUint32(nodeOffset, true);\n const startBase = dv.getUint32(nodeOffset + 4, true);\n const endChrom = dv.getUint32(nodeOffset + 8, true);\n const endBase = dv.getUint32(nodeOffset + 12, true);\n const blockOffset = Number(dv.getBigUint64(nodeOffset + 16, true));\n const blockSize = Number(dv.getBigUint64(nodeOffset + 24, true));\n nodeOffset += 32;\n if (blockIntersectsQuery(startChrom, startBase, endChrom, endBase)) {\n blocks.push({ offset: blockOffset, length: blockSize });\n }\n }\n }\n else if (isLeaf === 0) {\n for (let i = 0; i < count; i++) {\n const startChrom = dv.getUint32(nodeOffset, true);\n const startBase = dv.getUint32(nodeOffset + 4, true);\n const endChrom = dv.getUint32(nodeOffset + 8, true);\n const endBase = dv.getUint32(nodeOffset + 12, true);\n const childOffset = Number(dv.getBigUint64(nodeOffset + 16, true));\n nodeOffset += 24;\n if (blockIntersectsQuery(startChrom, startBase, endChrom, endBase)) {\n nextOffsets.push(childOffset);\n }\n }\n }\n }\n }\n }\n currentOffsets = nextOffsets;\n }\n return { blocks, chrId };\n }\n async readWigData(chrName, start, end, opts) {\n const collected = await this._collectBlocks(chrName, start, end, opts);\n if (!collected) {\n return [];\n }\n const { blocks, chrId } = collected;\n return this.readFeatures(blocks, {\n ...opts,\n request: { chrId, start, end },\n });\n }\n async readWigDataAsArrays(chrName, start, end, opts) {\n const collected = await this._collectBlocks(chrName, start, end, opts);\n const blocks = collected?.blocks ?? [];\n const request = collected\n ? { chrId: collected.chrId, start, end }\n : undefined;\n const optsWithReq = { ...opts, request };\n if (this.blockType === 'summary') {\n return this._readSummaryFeaturesAsArrays(blocks, optsWithReq);\n }\n return this._readBigWigFeaturesAsArrays(blocks, optsWithReq);\n }\n async readFeatures(blocks, opts = {}) {\n const { blockType, uncompressBufSize } = this;\n const { signal, request } = opts;\n const blockGroupsToFetch = groupBlocks(blocks);\n const allFeatures = [];\n for (const blockGroup of blockGroupsToFetch) {\n const data = await this.bbi.read(blockGroup.length, blockGroup.offset, {\n signal,\n });\n const groupOffset = blockGroup.offset;\n const subBlocks = blockGroup.blocks;\n let decompressedData;\n let decompressedOffsets;\n if (uncompressBufSize > 0) {\n const localBlocks = [];\n for (const block of subBlocks) {\n localBlocks.push({\n offset: block.offset - groupOffset,\n length: block.length,\n });\n }\n const result = await unzipBatch(data, localBlocks, uncompressBufSize);\n decompressedData = result.data;\n decompressedOffsets = result.offsets;\n }\n else {\n decompressedData = data;\n decompressedOffsets = [];\n for (const block of subBlocks) {\n decompressedOffsets.push(block.offset - groupOffset);\n }\n decompressedOffsets.push(data.length);\n }\n for (let i = 0; i < subBlocks.length; i++) {\n const start = decompressedOffsets[i];\n const end = decompressedOffsets[i + 1];\n const resultData = decompressedData.subarray(start, end);\n let features;\n switch (blockType) {\n case 'summary':\n features = parseSummaryBlock(resultData, 0, request);\n break;\n case 'bigwig':\n features = parseBigWigBlock(resultData, 0, request);\n break;\n case 'bigbed':\n features = parseBigBedBlock(resultData, 0, subBlocks[i].offset * (1 << 8), request);\n break;\n default:\n features = [];\n console.warn(`Don't know what to do with ${blockType}`);\n }\n for (const f of features) {\n allFeatures.push(f);\n }\n }\n }\n return allFeatures;\n }\n async _readBigWigFeaturesAsArrays(blocks, opts = {}) {\n const { uncompressBufSize } = this;\n const { signal, request } = opts;\n const blockGroupsToFetch = groupBlocks(blocks);\n const allStarts = [];\n const allEnds = [];\n const allScores = [];\n let totalCount = 0;\n for (const blockGroup of blockGroupsToFetch) {\n const { length, offset } = blockGroup;\n const data = await this.bbi.read(length, offset, { signal });\n const localBlocks = blockGroup.blocks.map(block => ({\n offset: block.offset - blockGroup.offset,\n length: block.length,\n }));\n if (uncompressBufSize > 0) {\n const result = await decompressAndParseBigWigBlocks(data, localBlocks, uncompressBufSize, request?.start ?? 0, request?.end ?? 0);\n if (result.starts.length > 0) {\n allStarts.push(result.starts);\n allEnds.push(result.ends);\n allScores.push(result.scores);\n totalCount += result.starts.length;\n }\n }\n else {\n for (const block of localBlocks) {\n const blockData = data.subarray(block.offset, block.offset + block.length);\n const result = parseBigWigBlockAsArrays(blockData, 0, request);\n if (result.starts.length > 0) {\n allStarts.push(result.starts);\n allEnds.push(result.ends);\n allScores.push(result.scores);\n totalCount += result.starts.length;\n }\n }\n }\n }\n if (allStarts.length === 0) {\n return {\n starts: new Int32Array(0),\n ends: new Int32Array(0),\n scores: new Float32Array(0),\n isSummary: false,\n };\n }\n if (allStarts.length === 1) {\n return {\n starts: allStarts[0],\n ends: allEnds[0],\n scores: allScores[0],\n isSummary: false,\n };\n }\n const starts = new Int32Array(totalCount);\n const ends = new Int32Array(totalCount);\n const scores = new Float32Array(totalCount);\n let offset = 0;\n for (let i = 0; i < allStarts.length; i++) {\n starts.set(allStarts[i], offset);\n ends.set(allEnds[i], offset);\n scores.set(allScores[i], offset);\n offset += allStarts[i].length;\n }\n return { starts, ends, scores, isSummary: false };\n }\n async _readSummaryFeaturesAsArrays(blocks, opts = {}) {\n const { uncompressBufSize } = this;\n const { signal, request } = opts;\n const blockGroupsToFetch = groupBlocks(blocks);\n const allStarts = [];\n const allEnds = [];\n const allScores = [];\n const allMinScores = [];\n const allMaxScores = [];\n let totalCount = 0;\n for (const blockGroup of blockGroupsToFetch) {\n const { length, offset } = blockGroup;\n const data = await this.bbi.read(length, offset, { signal });\n const localBlocks = blockGroup.blocks.map(block => ({\n offset: block.offset - blockGroup.offset,\n length: block.length,\n }));\n if (uncompressBufSize > 0) {\n const result = await decompressAndParseSummaryBlocks(data, localBlocks, uncompressBufSize, request?.chrId ?? 0, request?.start ?? 0, request?.end ?? 0);\n if (result.starts.length > 0) {\n allStarts.push(result.starts);\n allEnds.push(result.ends);\n allScores.push(result.scores);\n allMinScores.push(result.minScores);\n allMaxScores.push(result.maxScores);\n totalCount += result.starts.length;\n }\n }\n else {\n for (const block of localBlocks) {\n const blockData = data.subarray(block.offset, block.offset + block.length);\n const features = parseSummaryBlock(blockData, 0, request);\n if (features.length > 0) {\n const starts = new Int32Array(features.length);\n const ends = new Int32Array(features.length);\n const scores = new Float32Array(features.length);\n const minScores = new Float32Array(features.length);\n const maxScores = new Float32Array(features.length);\n for (let i = 0; i < features.length; i++) {\n const f = features[i];\n starts[i] = f.start;\n ends[i] = f.end;\n scores[i] = f.score ?? 0;\n minScores[i] = f.minScore ?? 0;\n maxScores[i] = f.maxScore ?? 0;\n }\n allStarts.push(starts);\n allEnds.push(ends);\n allScores.push(scores);\n allMinScores.push(minScores);\n allMaxScores.push(maxScores);\n totalCount += features.length;\n }\n }\n }\n }\n if (allStarts.length === 0) {\n return {\n starts: new Int32Array(0),\n ends: new Int32Array(0),\n scores: new Float32Array(0),\n minScores: new Float32Array(0),\n maxScores: new Float32Array(0),\n isSummary: true,\n };\n }\n if (allStarts.length === 1) {\n return {\n starts: allStarts[0],\n ends: allEnds[0],\n scores: allScores[0],\n minScores: allMinScores[0],\n maxScores: allMaxScores[0],\n isSummary: true,\n };\n }\n const starts = new Int32Array(totalCount);\n const ends = new Int32Array(totalCount);\n const scores = new Float32Array(totalCount);\n const minScores = new Float32Array(totalCount);\n const maxScores = new Float32Array(totalCount);\n let offset = 0;\n for (let i = 0; i < allStarts.length; i++) {\n starts.set(allStarts[i], offset);\n ends.set(allEnds[i], offset);\n scores.set(allScores[i], offset);\n minScores.set(allMinScores[i], offset);\n maxScores.set(allMaxScores[i], offset);\n offset += allStarts[i].length;\n }\n return {\n starts,\n ends,\n scores,\n minScores,\n maxScores,\n isSummary: true,\n };\n }\n}\n//# sourceMappingURL=block-view.js.map","import { LocalFile, RemoteFile } from 'generic-filehandle2';\nimport { BlockView } from \"./block-view.js\";\nconst BIG_WIG_MAGIC = -2003829722;\nconst BIG_BED_MAGIC = -2021002517;\nconst decoder = new TextDecoder('utf8');\nfunction getDataView(buffer) {\n return new DataView(buffer.buffer, buffer.byteOffset, buffer.length);\n}\nexport class BBI {\n bbi;\n headerP;\n renameRefSeqs;\n getHeader(opts) {\n if (!this.headerP) {\n this.headerP = this._getHeader(opts).catch((e) => {\n this.headerP = undefined;\n throw e;\n });\n }\n return this.headerP;\n }\n /*\n * @param filehandle - a filehandle from generic-filehandle2\n *\n * @param path - a Local file path as a string\n *\n * @param url - a URL string\n *\n * @param renameRefSeqs - an optional method to rename the internal reference\n * sequences using a mapping function\n */\n constructor(args) {\n const { filehandle, renameRefSeqs = s => s, path, url } = args;\n this.renameRefSeqs = renameRefSeqs;\n if (filehandle) {\n this.bbi = filehandle;\n }\n else if (url) {\n this.bbi = new RemoteFile(url);\n }\n else if (path) {\n this.bbi = new LocalFile(path);\n }\n else {\n throw new Error('no file given');\n }\n }\n async _getHeader(opts) {\n const header = await this._getMainHeader(opts);\n const chroms = await this._readChromosomeTree(header, opts);\n return {\n ...header,\n ...chroms,\n };\n }\n async _getMainHeader(opts, requestSize = 2000) {\n const b = await this.bbi.read(requestSize, 0, opts);\n const dataView = getDataView(b);\n let offset = 0;\n const magic = dataView.getInt32(offset, true);\n offset += 4;\n if (magic !== BIG_WIG_MAGIC && magic !== BIG_BED_MAGIC) {\n throw new Error('not a BigWig/BigBed file');\n }\n const version = dataView.getUint16(offset, true);\n offset += 2;\n const numZoomLevels = dataView.getUint16(offset, true);\n offset += 2;\n // Offset to the B+ tree that maps chromosome names to integer IDs\n const chromosomeTreeOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const unzoomedDataOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const unzoomedIndexOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const fieldCount = dataView.getUint16(offset, true);\n offset += 2;\n const definedFieldCount = dataView.getUint16(offset, true);\n offset += 2;\n const asOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const totalSummaryOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const uncompressBufSize = dataView.getUint32(offset, true);\n offset += 4;\n const extHeaderOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const zoomLevels = [];\n for (let i = 0; i < numZoomLevels; i++) {\n const reductionLevel = dataView.getUint32(offset, true);\n offset += 4;\n const reserved = dataView.getUint32(offset, true);\n offset += 4;\n const dataOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const indexOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n zoomLevels.push({\n reductionLevel,\n reserved,\n dataOffset,\n indexOffset,\n });\n }\n const fileType = magic === BIG_BED_MAGIC ? 'bigbed' : 'bigwig';\n // refetch header if it is too large on first pass,\n // 8*5 is the sizeof the totalSummary struct\n if (asOffset > requestSize || totalSummaryOffset > requestSize - 8 * 5) {\n return this._getMainHeader(opts, requestSize * 2);\n }\n let totalSummary;\n if (totalSummaryOffset) {\n const b2 = b.subarray(totalSummaryOffset);\n let offset = 0;\n const dataView = getDataView(b2);\n const basesCovered = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const scoreMin = dataView.getFloat64(offset, true);\n offset += 8;\n const scoreMax = dataView.getFloat64(offset, true);\n offset += 8;\n const scoreSum = dataView.getFloat64(offset, true);\n offset += 8;\n const scoreSumSquares = dataView.getFloat64(offset, true);\n totalSummary = {\n scoreMin,\n scoreMax,\n scoreSum,\n scoreSumSquares,\n basesCovered,\n };\n }\n else {\n throw new Error('no stats');\n }\n return {\n zoomLevels,\n magic,\n extHeaderOffset,\n numZoomLevels,\n fieldCount,\n totalSummary,\n definedFieldCount,\n uncompressBufSize,\n asOffset,\n chromosomeTreeOffset,\n totalSummaryOffset,\n unzoomedDataOffset,\n unzoomedIndexOffset,\n fileType,\n version,\n autoSql: asOffset\n ? decoder.decode(b.subarray(asOffset, b.indexOf(0, asOffset)))\n : '',\n };\n }\n // Reads the B+ tree that maps chromosome names to integer IDs\n // This is part of the \"cirTree\" (combined ID R-tree) structure, which uses\n // integer chromosome IDs instead of strings for more efficient spatial indexing\n async _readChromosomeTree(header, opts) {\n const refsByNumber = [];\n const refsByName = {};\n const chromosomeTreeOffset = header.chromosomeTreeOffset;\n const dataView = getDataView(await this.bbi.read(32, chromosomeTreeOffset, opts));\n const keySize = dataView.getUint32(8, true);\n const valSize = dataView.getUint32(12, true);\n // Recursively traverses the B+ tree to populate chromosome name-to-ID mappings\n const readBPlusTreeNode = async (currentOffset) => {\n const header = getDataView(await this.bbi.read(4, currentOffset));\n const isLeafNode = header.getUint8(0);\n const count = header.getUint16(2, true);\n // Leaf nodes contain the actual chromosome name-to-ID mappings\n if (isLeafNode) {\n const b = await this.bbi.read(count * (keySize + valSize), currentOffset + 4);\n const dataView = getDataView(b);\n let offset = 0;\n for (let n = 0; n < count; n++) {\n const keyEnd = b.indexOf(0, offset);\n const effectiveKeyEnd = keyEnd !== -1 && keyEnd < offset + keySize\n ? keyEnd\n : offset + keySize;\n const key = decoder.decode(b.subarray(offset, effectiveKeyEnd));\n offset += keySize;\n const refId = dataView.getUint32(offset, true);\n offset += 4;\n const refSize = dataView.getUint32(offset, true);\n offset += 4;\n refsByName[this.renameRefSeqs(key)] = refId;\n refsByNumber[refId] = { name: key, id: refId, length: refSize };\n }\n }\n else {\n // Non-leaf nodes contain pointers to child nodes\n const dataView = getDataView(await this.bbi.read(count * (keySize + 8), currentOffset + 4));\n const nextNodes = [];\n let offset = 0;\n for (let n = 0; n < count; n++) {\n offset += keySize;\n const childOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n nextNodes.push(readBPlusTreeNode(childOffset));\n }\n await Promise.all(nextNodes);\n }\n };\n await readBPlusTreeNode(chromosomeTreeOffset + 32);\n return {\n refsByName,\n refsByNumber,\n };\n }\n viewCache = new Map();\n getOrCreateBlockView(refsByName, rTreeOffset, uncompressBufSize, blockType) {\n const key = `${rTreeOffset}_${blockType}`;\n let view = this.viewCache.get(key);\n if (!view) {\n view = new BlockView(this.bbi, refsByName, rTreeOffset, uncompressBufSize, blockType);\n this.viewCache.set(key, view);\n }\n return view;\n }\n /*\n * fetches the \"unzoomed\" view of the bigwig data. this is the default for bigbed\n * @param abortSignal - a signal to optionally abort this operation\n */\n async getUnzoomedView(opts) {\n const { unzoomedIndexOffset, refsByName, uncompressBufSize, fileType } = await this.getHeader(opts);\n return this.getOrCreateBlockView(refsByName, unzoomedIndexOffset, uncompressBufSize, fileType);\n }\n async _getView(opts) {\n const { basesPerSpan, scale } = opts || {};\n const viewScale = basesPerSpan ? 1 / basesPerSpan : (scale ?? 1);\n return this.getView(viewScale, opts);\n }\n async getFeatures(refName, start, end, opts) {\n const view = await this._getView(opts);\n return view.readWigData(this.renameRefSeqs(refName), start, end, opts);\n }\n async getFeaturesAsArrays(refName, start, end, opts) {\n const view = await this._getView(opts);\n return view.readWigDataAsArrays(this.renameRefSeqs(refName), start, end, opts);\n }\n}\n//# sourceMappingURL=bbi.js.map","import { BBI } from \"./bbi.js\";\nexport class BigWig extends BBI {\n /**\n * Retrieves a BlockView of a specific zoomLevel\n *\n * @param scale - number\n *\n * @param opts - An object containing basesPerSpan (e.g. pixels per basepair)\n * or scale used to infer the zoomLevel to use\n */\n async getView(scale, opts) {\n const { zoomLevels, refsByName, uncompressBufSize } = await this.getHeader(opts);\n const basesPerPx = 1 / scale;\n const maxLevel = zoomLevels.length - 1;\n for (let i = maxLevel; i >= 0; i -= 1) {\n const zh = zoomLevels[i];\n if (zh && zh.reductionLevel <= 2 * basesPerPx) {\n return this.getOrCreateBlockView(refsByName, zh.indexOffset, uncompressBufSize, 'summary');\n }\n }\n return this.getUnzoomedView(opts);\n }\n}\n//# sourceMappingURL=bigwig.js.map","import AbortablePromiseCache from '@gmod/abortable-promise-cache';\nimport QuickLRU from '@jbrowse/quick-lru';\nimport { BBI } from \"./bbi.js\";\nconst decoder = new TextDecoder('utf8');\nfunction getTabField(str, fieldIndex) {\n if (fieldIndex < 0) {\n return undefined;\n }\n let start = 0;\n for (let i = 0; i < fieldIndex; i++) {\n start = str.indexOf('\\t', start);\n if (start === -1) {\n return undefined;\n }\n start++;\n }\n const end = str.indexOf('\\t', start);\n return end === -1 ? str.slice(start) : str.slice(start, end);\n}\n// Parses a null-terminated string key from a B+ tree node\nfunction parseKey(buffer, offset, keySize) {\n const keyEnd = buffer.indexOf(0, offset);\n const effectiveKeyEnd = keyEnd !== -1 && keyEnd < offset + keySize ? keyEnd : offset + keySize;\n return decoder.decode(buffer.subarray(offset, effectiveKeyEnd));\n}\n// Recursively traverses a B+ tree to search for a specific name in the BigBed extraIndex\n// B+ trees are balanced tree structures optimized for disk-based searches\nasync function readBPlusTreeNode(bbi, nodeOffset, blockSize, keySize, valSize, name, field, opts) {\n const len = 4 + blockSize * (keySize + valSize);\n const buffer = await bbi.read(len, nodeOffset, opts);\n const dataView = new DataView(buffer.buffer, buffer.byteOffset, buffer.length);\n const nodeType = dataView.getInt8(0);\n const cnt = dataView.getInt16(2, true);\n let offset = 4;\n // Non-leaf node (nodeType === 0): contains keys and child node pointers for navigation\n if (nodeType === 0) {\n const leafkeys = [];\n for (let i = 0; i < cnt; i++) {\n const key = parseKey(buffer, offset, keySize);\n offset += keySize;\n const dataOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n leafkeys.push({\n key,\n offset: dataOffset,\n });\n }\n // Binary search to find the appropriate child node\n let left = 0;\n let right = leafkeys.length - 1;\n let targetIndex = leafkeys.length - 1;\n while (left <= right) {\n const mid = Math.floor((left + right) / 2);\n const cmp = name.localeCompare(leafkeys[mid].key);\n if (cmp < 0) {\n targetIndex = mid - 1;\n right = mid - 1;\n }\n else {\n left = mid + 1;\n }\n }\n const childOffset = targetIndex >= 0 ? leafkeys[targetIndex].offset : leafkeys[0].offset;\n return readBPlusTreeNode(bbi, childOffset, blockSize, keySize, valSize, name, field, opts);\n }\n else if (nodeType === 1) {\n // Leaf node (nodeType === 1): contains actual key-value data\n const keys = [];\n for (let i = 0; i < cnt; i++) {\n const key = parseKey(buffer, offset, keySize);\n offset += keySize;\n const dataOffset = Number(dataView.getBigUint64(offset, true));\n offset += 8;\n const length = dataView.getUint32(offset, true);\n offset += 4;\n offset += 4; // skip reserved\n keys.push({\n key,\n offset: dataOffset,\n length,\n });\n }\n // Binary search for exact key match in sorted leaf node\n let left = 0;\n let right = keys.length - 1;\n while (left <= right) {\n const mid = Math.floor((left + right) / 2);\n const cmp = name.localeCompare(keys[mid].key);\n if (cmp === 0) {\n return { ...keys[mid], field };\n }\n else if (cmp < 0) {\n right = mid - 1;\n }\n else {\n left = mid + 1;\n }\n }\n return undefined;\n }\n}\nexport class BigBed extends BBI {\n readIndicesCache = new AbortablePromiseCache({\n cache: new QuickLRU({ maxSize: 1 }),\n fill: (args, signal) => this._readIndices({ ...args, signal }),\n });\n readIndices(opts = {}) {\n const { signal, ...rest } = opts;\n return this.readIndicesCache.get(JSON.stringify(rest), opts, signal);\n }\n /*\n * retrieve unzoomed view for any scale\n */\n async getView(_scale, opts) {\n return this.getUnzoomedView(opts);\n }\n /*\n * parse the bigbed extraIndex fields\n *\n *\n * @return a Promise for an array of Index data structure since there can be\n * multiple extraIndexes in a bigbed, see bedToBigBed documentation\n */\n async _readIndices(opts) {\n const { extHeaderOffset } = await this.getHeader(opts);\n const b = await this.bbi.read(64, extHeaderOffset);\n const dataView = new DataView(b.buffer, b.byteOffset, b.length);\n const count = dataView.getUint16(2, true);\n const dataOffset = Number(dataView.getBigUint64(4, true));\n // no extra index is defined if count==0\n if (count === 0) {\n return [];\n }\n const blocklen = 20;\n const len = blocklen * count;\n const buffer = await this.bbi.read(len, dataOffset);\n const indices = [];\n for (let i = 0; i < count; i += 1) {\n const b = buffer.subarray(i * blocklen);\n const dataView = new DataView(b.buffer, b.byteOffset, b.length);\n const type = dataView.getInt16(0, true);\n const fieldcount = dataView.getInt16(2, true);\n const dataOffset = Number(dataView.getBigUint64(4, true));\n const field = dataView.getInt16(16, true);\n indices.push({\n type,\n fieldcount,\n offset: dataOffset,\n field,\n });\n }\n return indices;\n }\n /*\n * perform a search in the bigbed extraIndex to find which blocks in the\n * bigbed data to look for the actual feature data\n *\n * @param name - the name to search for\n *\n * @param opts - a SearchOptions argument with optional signal\n *\n * @return a Promise for an array of bigbed block Loc entries\n */\n async searchExtraIndexBlocks(name, opts = {}) {\n const indices = await this.readIndices(opts);\n if (indices.length === 0) {\n return [];\n }\n const locs = indices.map(async (index) => {\n const { offset: offset2, field } = index;\n const b = await this.bbi.read(32, offset2, opts);\n const dataView = new DataView(b.buffer, b.byteOffset, b.length);\n const blockSize = dataView.getInt32(4, true);\n const keySize = dataView.getInt32(8, true);\n const valSize = dataView.getInt32(12, true);\n return readBPlusTreeNode(this.bbi, offset2 + 32, blockSize, keySize, valSize, name, field, opts);\n });\n const results = await Promise.all(locs);\n return results.filter((l) => l !== undefined);\n }\n /*\n * retrieve the features from the bigbed data that were found through the\n * lookup of the extraIndex note that there can be multiple extraIndex, see\n * the BigBed specification and the -extraIndex argument to bedToBigBed\n *\n * @param name - the name to search for\n *\n * @param opts - options object with optional AbortSignal\n *\n * @return array of Feature\n */\n async searchExtraIndex(name, opts = {}) {\n const blocks = await this.searchExtraIndexBlocks(name, opts);\n if (blocks.length === 0) {\n return [];\n }\n const view = await this.getUnzoomedView(opts);\n const results = await Promise.all(blocks.map(async (block) => {\n const features = await view.readFeatures([block], opts);\n return features.map(f => ({ ...f, field: block.field }));\n }));\n // field offset is adjusted by -3 to account for chrom, chromStart, chromEnd columns\n return results.flat().filter(f => {\n if (!f.rest) {\n return false;\n }\n const fieldIndex = (f.field || 0) - 3;\n return getTabField(f.rest, fieldIndex) === name;\n });\n }\n}\n//# sourceMappingURL=bigbed.js.map","/**\n * Binary data parser for reading structured binary data from a DataView.\n * Port of js/binary.ts, simplified for BigWig reading (no VPointer).\n */\nexport class BinaryParser {\n littleEndian: boolean\n position: number\n readonly view: DataView\n readonly length: number\n\n constructor(dataView: DataView, littleEndian: boolean = true) {\n this.littleEndian = littleEndian\n this.position = 0\n this.view = dataView\n this.length = dataView.byteLength\n }\n\n setPosition(position: number): void {\n this.position = position\n }\n\n available(): number {\n return this.length - this.position\n }\n\n remLength(): number {\n return this.length - this.position\n }\n\n getByte(): number {\n const retValue = this.view.getUint8(this.position)\n this.position++\n return retValue\n }\n\n getShort(): number {\n const retValue = this.view.getInt16(this.position, this.littleEndian)\n this.position += 2\n return retValue\n }\n\n getUShort(): number {\n const retValue = this.view.getUint16(this.position, this.littleEndian)\n this.position += 2\n return retValue\n }\n\n getInt(): number {\n const retValue = this.view.getInt32(this.position, this.littleEndian)\n this.position += 4\n return retValue\n }\n\n getUInt(): number {\n const retValue = this.view.getUint32(this.position, this.littleEndian)\n this.position += 4\n return retValue\n }\n\n getLong(): number {\n const b: number[] = []\n for (let i = 0; i < 8; i++) {\n b[i] = this.view.getUint8(this.position + i)\n }\n\n let value = 0\n if (this.littleEndian) {\n for (let i = 7; i >= 0; i--) {\n value = (value * 256) + b[i]\n }\n } else {\n for (let i = 0; i < 8; i++) {\n value = (value * 256) + b[i]\n }\n }\n this.position += 8\n return value\n }\n\n getString(len?: number): string {\n let s = ''\n let c: number\n while ((c = this.view.getUint8(this.position++)) !== 0) {\n s += String.fromCharCode(c)\n if (len && s.length === len) break\n }\n return s\n }\n\n getFixedLengthString(len: number): string {\n let s = ''\n for (let i = 0; i < len; i++) {\n const c = this.view.getUint8(this.position++)\n if (c > 0) {\n s += String.fromCharCode(c)\n }\n }\n return s\n }\n\n getFloat(): number {\n const retValue = this.view.getFloat32(this.position, this.littleEndian)\n this.position += 4\n return retValue\n }\n\n getDouble(): number {\n const retValue = this.view.getFloat64(this.position, this.littleEndian)\n this.position += 8\n return retValue\n }\n\n skip(n: number): number {\n this.position += n\n return this.position\n }\n}\n","/**\n * BigWig reader — public API.\n *\n * Thin wrapper around @gmod/bbi that preserves the existing public API.\n * All binary parsing, decompression, and zoom level selection is handled\n * by @gmod/bbi internally.\n */\n\nimport {BigWig} from '@gmod/bbi'\nimport {RemoteFile} from 'generic-filehandle2'\nimport type {WigFeature, WindowFunction, Locus} from '../types'\nimport type {Feature} from '@gmod/bbi'\n\n// Re-export BinaryParser from its new home for backward compatibility\nexport {BinaryParser} from '../io/binaryParser'\n\nexport interface FetchBigWigOptions {\n /** Resolution in base pairs per pixel. Used to select an appropriate zoom level. */\n bpPerPixel?: number\n /** Aggregation function for zoom-level data. Default: 'mean'. */\n windowFunction?: WindowFunction\n /** AbortSignal for cancelling in-flight HTTP requests. */\n signal?: AbortSignal\n}\n\n/** Header metadata from a BigWig file. */\nexport interface BigWigHeader {\n bwVersion: number\n nZoomLevels: number\n chromTreeOffset: number\n fullDataOffset: number\n fullIndexOffset: number\n fieldCount: number\n definedFieldCount: number\n autoSqlOffset: number\n totalSummaryOffset: number\n uncompressBuffSize: number\n extensionOffset: number\n}\n\n/** Summary statistics for the entire BigWig file. */\nexport interface BigWigTotalSummary {\n basesCovered: number\n minVal: number\n maxVal: number\n sumData: number\n sumSquares: number\n mean: number\n stddev: number\n}\n\n// ─── Internal helpers ─────────────────────────────────────────────────────────\n\n// Cache BigWig instances by URL to reuse parsed headers and trees\nconst readerCache = new Map<string, BigWig>()\n\nfunction getGmodReader(url: string): BigWig {\n let reader = readerCache.get(url)\n if (!reader) {\n reader = new BigWig({filehandle: new RemoteFile(url)})\n readerCache.set(url, reader)\n }\n return reader\n}\n\n/**\n * Convert @gmod/bbi Feature to our WigFeature, applying windowFunction\n * for summary data.\n */\nfunction featureToWig(f: Feature, chr: string, wf: WindowFunction): WigFeature | undefined {\n if (f.score === undefined && !f.summary) return undefined\n\n let value: number\n if (f.summary) {\n switch (wf) {\n case 'min': value = f.minScore ?? f.score ?? 0; break\n case 'max': value = f.maxScore ?? f.score ?? 0; break\n case 'mean':\n default: value = f.score ?? 0; break\n }\n } else {\n value = f.score ?? 0\n }\n\n return {chr, start: f.start, end: f.end, value}\n}\n\n// ─── Public API ───────────────────────────────────────────────────────────────\n\n/**\n * Thin wrapper around @gmod/bbi BigWig that preserves the legacy API.\n */\nexport class BigWigReader {\n private readonly bw: BigWig\n\n constructor(url: string) {\n this.bw = getGmodReader(url)\n }\n\n async loadHeader(signal?: AbortSignal): Promise<BigWigHeader> {\n const h = await this.bw.getHeader({signal})\n return {\n bwVersion: h.version,\n nZoomLevels: h.numZoomLevels,\n chromTreeOffset: h.chromosomeTreeOffset,\n fullDataOffset: h.unzoomedDataOffset,\n fullIndexOffset: h.unzoomedIndexOffset,\n fieldCount: h.fieldCount,\n definedFieldCount: h.definedFieldCount,\n autoSqlOffset: h.asOffset,\n totalSummaryOffset: h.totalSummaryOffset,\n uncompressBuffSize: h.uncompressBufSize,\n extensionOffset: h.extHeaderOffset,\n }\n }\n\n async getTotalSummary(signal?: AbortSignal): Promise<BigWigTotalSummary | undefined> {\n const h = await this.bw.getHeader({signal})\n const s = h.totalSummary\n if (!s) return undefined\n const mean = s.basesCovered > 0 ? s.scoreSum / s.basesCovered : 0\n const variance = s.basesCovered > 0\n ? (s.scoreSumSquares / s.basesCovered) - (mean * mean)\n : 0\n return {\n basesCovered: s.basesCovered,\n minVal: s.scoreMin,\n maxVal: s.scoreMax,\n sumData: s.scoreSum,\n sumSquares: s.scoreSumSquares,\n mean,\n stddev: Math.sqrt(Math.max(0, variance)),\n }\n }\n\n async readFeatures(\n chr: string,\n bpStart: number,\n bpEnd: number,\n bpPerPixel?: number,\n windowFunction: WindowFunction = 'mean',\n signal?: AbortSignal,\n ): Promise<WigFeature[]> {\n const opts: {signal?: AbortSignal; basesPerSpan?: number} = {signal}\n if (bpPerPixel && windowFunction !== 'none') {\n opts.basesPerSpan = bpPerPixel\n }\n\n const features = await this.bw.getFeatures(chr, bpStart, bpEnd, opts)\n const result: WigFeature[] = []\n for (const f of features) {\n const wig = featureToWig(f, chr, windowFunction)\n if (wig) result.push(wig)\n }\n return result\n }\n\n async readWGFeatures(\n chromNames: string[],\n bpPerPixel: number,\n windowFunction: WindowFunction = 'mean',\n signal?: AbortSignal,\n ): Promise<WigFeature[]> {\n const allFeatures: WigFeature[] = []\n for (const chr of chromNames) {\n try {\n const features = await this.readFeatures(\n chr, 0, Number.MAX_SAFE_INTEGER, bpPerPixel, windowFunction, signal,\n )\n allFeatures.push(...features)\n } catch {\n // Skip chromosomes that don't exist in the file\n }\n }\n return allFeatures\n }\n}\n\n/**\n * Fetch BigWig features for a genomic locus.\n */\nexport async function fetchBigWigFeatures(\n url: string,\n locus: Locus,\n options: FetchBigWigOptions = {},\n): Promise<WigFeature[]> {\n const reader = new BigWigReader(url)\n return reader.readFeatures(\n locus.chr,\n locus.start,\n locus.end,\n options.bpPerPixel,\n options.windowFunction ?? 'mean',\n options.signal,\n )\n}\n\n/**\n * Fetch BigWig features across all specified chromosomes for whole genome view.\n * Returns features with per-chromosome coordinates (caller transforms to genome-wide).\n */\nexport async function fetchBigWigWGFeatures(\n url: string,\n chromNames: string[],\n bpPerPixel: number,\n options: Pick<FetchBigWigOptions, 'windowFunction' | 'signal'> = {},\n): Promise<WigFeature[]> {\n const reader = new BigWigReader(url)\n return reader.readWGFeatures(\n chromNames,\n bpPerPixel,\n options.windowFunction ?? 'mean',\n options.signal,\n )\n}\n\n/** Clear the BigWig reader cache (useful for testing or memory management). */\nexport function clearBigWigCache(): void {\n readerCache.clear()\n}\n","/**\n * Resolution-aware data summarization for wig tracks.\n *\n * When zoomed out, many data points map to the same pixel. This module bins\n * features and applies a window function (mean, min, max) to produce one\n * summary value per pixel-width bin.\n *\n * Ported from js/feature/wigSummary.ts with strict types, no `any`.\n */\n\nimport type {WigFeature, WindowFunction} from '../../types'\n\nclass SummaryBinData {\n bin: number\n sumData: number\n count: number\n min: number\n max: number\n\n constructor(bin: number, feature: WigFeature) {\n this.bin = bin\n this.sumData = feature.value\n this.count = 1\n this.min = feature.value\n this.max = feature.value\n }\n\n add(feature: WigFeature): void {\n this.sumData += feature.value\n this.max = Math.max(feature.value, this.max)\n this.min = Math.min(feature.value, this.min)\n this.count++\n }\n}\n\n/**\n * Summarize wig features by binning into pixel-width windows and applying\n * a window function.\n *\n * Features must be sorted by position. Wig features cannot overlap.\n *\n * @param features - sorted array of wig features\n * @param startBP - start position in base pairs (left edge of viewport)\n * @param bpPerPixel - base pairs per pixel (bin size)\n * @param windowFunction - aggregation function: mean, min, max, or none\n * @returns summarized features (one per pixel-bin)\n */\nexport function summarizeWigData(\n features: WigFeature[],\n startBP: number,\n bpPerPixel: number,\n windowFunction: WindowFunction = 'mean',\n): WigFeature[] {\n if (bpPerPixel <= 1 || !features || features.length === 0 || windowFunction === 'none') {\n return features\n }\n\n const chr = features[0].chr\n const binSize = bpPerPixel\n const summaryFeatures: WigFeature[] = []\n\n const finishBin = (bin: SummaryBinData): void => {\n const start = startBP + bin.bin * binSize\n const end = start + binSize\n let value: number\n switch (windowFunction) {\n case 'mean':\n value = bin.sumData / bin.count\n break\n case 'max':\n value = bin.max\n break\n case 'min':\n value = bin.min\n break\n default:\n throw Error(`Unknown window function: ${windowFunction}`)\n }\n const description = `${windowFunction} of ${bin.count} values`\n summaryFeatures.push({chr, start, end, value, description})\n }\n\n let currentBinData: SummaryBinData | undefined\n for (const f of features) {\n let startBin = Math.floor((f.start - startBP) / binSize)\n const endBin = Math.floor((f.end - startBP) / binSize)\n\n if (currentBinData && startBin === currentBinData.bin) {\n currentBinData.add(f)\n startBin++\n }\n\n if (!currentBinData || endBin > currentBinData.bin) {\n if (currentBinData) {\n finishBin(currentBinData)\n }\n\n // Feature stretches across multiple bins\n if (endBin > startBin) {\n const end = startBP + endBin * binSize\n summaryFeatures.push({chr, start: f.start, end, value: f.value})\n }\n\n currentBinData = new SummaryBinData(endBin, f)\n }\n }\n if (currentBinData) {\n finishBin(currentBinData)\n }\n\n // Consolidate adjacent features with the same value\n if (summaryFeatures.length === 0) return summaryFeatures\n\n const consolidated: WigFeature[] = []\n let lastFeature = summaryFeatures[0]\n for (const f of summaryFeatures) {\n if (lastFeature.value === f.value && f.start <= lastFeature.end) {\n lastFeature = {...lastFeature, end: f.end}\n } else {\n consolidated.push(lastFeature)\n lastFeature = f\n }\n }\n consolidated.push(lastFeature)\n\n return consolidated\n}\n\n/**\n * Compute the min/max data range from a set of wig features.\n * Useful for autoscaling.\n */\nexport function computeWigDataRange(features: WigFeature[]): {min: number; max: number} {\n if (!features || features.length === 0) return {min: 0, max: 100}\n\n let min = Number.MAX_VALUE\n let max = -Number.MAX_VALUE\n for (const f of features) {\n if (!Number.isNaN(f.value)) {\n if (f.value < min) min = f.value\n if (f.value > max) max = f.value\n }\n }\n // All NaN — return default range\n if (min === Number.MAX_VALUE) return {min: 0, max: 100}\n // Ensure zero baseline (matching igv.js doAutoscale behavior)\n if (max > 0) min = Math.min(0, min)\n if (max < 0) max = 0\n\n return {min, max}\n}\n","/**\n * Locus parsing, formatting, and clamping utilities.\n */\n\nimport type {Locus} from './types'\nimport type {ChromSizes} from './genome/chromSizes'\nimport type {CumulativeOffsets} from './genome/chromSizes'\n\n/** Check if a locus represents whole genome view. */\nexport function isWholeGenomeView(locus: Locus): boolean {\n return locus.chr.toLowerCase() === 'all'\n}\n\n/**\n * Parse a locus string like \"chr17:7,668,000-7,688,000\" into a Locus object.\n * Accepts with or without commas. Also recognizes \"all\" / \"*\" for whole genome view\n * (requires cumulative offsets to compute end position).\n * Returns null if parsing fails.\n */\nexport function parseLocus(str: string, cumOffsets?: CumulativeOffsets): Locus | null {\n const trimmed = str.trim()\n if (trimmed.toLowerCase() === 'all' || trimmed === '*') {\n if (!cumOffsets) return null\n return {chr: 'all', start: 0, end: cumOffsets.totalLength}\n }\n const cleaned = trimmed.replace(/,/g, '')\n const match = cleaned.match(/^(\\S+):(\\d+)-(\\d+)$/)\n if (!match) return null\n const chr = match[1]\n const start = parseInt(match[2], 10)\n const end = parseInt(match[3], 10)\n if (isNaN(start) || isNaN(end) || end <= start) return null\n return {chr, start, end}\n}\n\n/**\n * Format a Locus object as a human-readable string with thousands separators.\n * e.g., { chr: 'chr17', start: 7668000, end: 7688000 } → \"chr17:7,668,000-7,688,000\"\n */\nexport function formatLocus(locus: Locus): string {\n if (isWholeGenomeView(locus)) return 'All Chromosomes'\n return `${locus.chr}:${Math.round(locus.start).toLocaleString()}-${Math.round(locus.end).toLocaleString()}`\n}\n\n/**\n * Format a base pair length as a human-readable string.\n * e.g., 20000 → \"20 kb\", 2500000 → \"2.5 Mb\", 500 → \"500 bp\"\n */\nexport function formatBpLength(bp: number): string {\n bp = Math.abs(bp)\n if (bp >= 1e9) {\n const val = bp / 1e9\n return `${val % 1 === 0 ? val.toFixed(0) : val.toFixed(1)} Gb`\n }\n if (bp >= 1e6) {\n const val = bp / 1e6\n return `${val % 1 === 0 ? val.toFixed(0) : val.toFixed(1)} Mb`\n }\n if (bp >= 1e3) {\n const val = bp / 1e3\n return `${val % 1 === 0 ? val.toFixed(0) : val.toFixed(1)} kb`\n }\n return `${Math.round(bp)} bp`\n}\n\n/**\n * Clamp a locus to valid chromosome bounds.\n *\n * Enforces:\n * - start >= 0\n * - end <= chromLength (if known)\n * - span <= chromLength (if known)\n *\n * Maintains viewport span when possible by shifting rather than shrinking.\n * Matches the behavior of js/referenceFrame.ts clampStart().\n */\nexport function clampLocus(locus: Locus, chromSizes?: ChromSizes, cumOffsets?: CumulativeOffsets): Locus {\n if (isWholeGenomeView(locus) && cumOffsets) {\n return {chr: 'all', start: Math.max(0, locus.start), end: Math.min(cumOffsets.totalLength, locus.end)}\n }\n let {chr, start, end} = locus\n const chromLength = chromSizes?.[chr]\n\n // Clamp span to chromosome length\n if (chromLength != null && end - start > chromLength) {\n start = 0\n end = chromLength\n }\n\n // Clamp left edge — shift right to keep span\n if (start < 0) {\n const shift = -start\n start = 0\n end += shift\n }\n\n // Clamp right edge — shift left to keep span\n if (chromLength != null && end > chromLength) {\n const shift = end - chromLength\n end = chromLength\n start = Math.max(0, start - shift)\n }\n\n return {chr, start, end}\n}\n","import type {DataSource, Locus, WigFeature, WindowFunction} from '../types'\nimport type {CumulativeOffsets} from '../genome/chromSizes'\nimport {fetchBigWigFeatures, fetchBigWigWGFeatures} from '../bigwig'\nimport {summarizeWigData} from '../tracks/wig/wigSummary'\nimport {isWholeGenomeView} from '../locusUtils'\n\nexport class BigWigDataSource implements DataSource<WigFeature> {\n private _windowFunction: WindowFunction\n private _cumulativeOffsets?: CumulativeOffsets\n private _resolveChromName?: (chr: string) => string\n\n constructor(private url: string, windowFunction: WindowFunction = 'mean') {\n this._windowFunction = windowFunction\n }\n\n get windowFunction(): WindowFunction { return this._windowFunction }\n\n /** Update the window function for future fetches. */\n setWindowFunction(wf: WindowFunction): void {\n this._windowFunction = wf\n }\n\n /** Set cumulative offsets for whole genome view coordinate transformation. */\n setCumulativeOffsets(offsets: CumulativeOffsets): void {\n this._cumulativeOffsets = offsets\n }\n\n /** Set a chromosome name resolver for alias resolution (e.g., \"1\" → \"chr1\"). */\n setChromNameResolver(resolver: (chr: string) => string): void {\n this._resolveChromName = resolver\n }\n\n async fetch(locus: Locus, bpPerPixel: number, signal: AbortSignal): Promise<WigFeature[]> {\n if (isWholeGenomeView(locus) && this._cumulativeOffsets) {\n return this.fetchWG(bpPerPixel, signal)\n }\n\n // Resolve chromosome alias before querying the BigWig reader\n const resolvedLocus = this._resolveChromName\n ? {...locus, chr: this._resolveChromName(locus.chr)}\n : locus\n\n const features = await fetchBigWigFeatures(this.url, resolvedLocus, {\n bpPerPixel,\n windowFunction: this._windowFunction,\n signal,\n })\n\n // Summarize to pixel resolution (matching igv.js wigTrack.getFeatures())\n if (bpPerPixel > 1 && this._windowFunction !== 'none' && features.length > 0) {\n return summarizeWigData(features, locus.start, bpPerPixel, this._windowFunction)\n }\n return features\n }\n\n /**\n * Fetch all chromosomes for whole genome view and transform to genome-wide coordinates.\n * Port of js/bigwig/bwSource.ts getWGValues().\n */\n private async fetchWG(bpPerPixel: number, signal: AbortSignal): Promise<WigFeature[]> {\n const offsets = this._cumulativeOffsets!\n const features = await fetchBigWigWGFeatures(\n this.url,\n offsets.chromosomeNames,\n bpPerPixel,\n {windowFunction: this._windowFunction, signal},\n )\n\n // Transform to genome-wide coordinates\n const wgFeatures: WigFeature[] = []\n for (const f of features) {\n const offset = offsets.offsets[f.chr]\n if (offset === undefined) continue\n wgFeatures.push({\n ...f,\n chr: 'all',\n start: offset + f.start,\n end: offset + f.end,\n })\n }\n wgFeatures.sort((a, b) => a.start - b.start)\n\n // Summarize at genome-wide scale\n if (bpPerPixel > 1 && this._windowFunction !== 'none' && wgFeatures.length > 0) {\n return summarizeWigData(wgFeatures, 0, bpPerPixel, this._windowFunction)\n }\n return wgFeatures\n }\n}\n","/**\n * HTTP range request reader using native fetch.\n * Replaces igvxhr + BufferedReader for BigWig file reading.\n *\n * Handles cross-origin 307/302 redirects that strip the Range header.\n * When a redirect causes the server to return 200 (full content) instead of\n * 206 (partial), we either retry against the final URL or slice the correct\n * bytes from the full response — matching igvxhr behavior.\n */\n\nexport interface ByteRange {\n start: number\n size: number\n}\n\n/**\n * Fetch a byte range from a URL as an ArrayBuffer.\n *\n * Handles two redirect failure modes:\n * 1. Cross-origin redirect strips Range header → server returns 200 (full file).\n * We retry directly against response.url (the final URL post-redirect).\n * 2. If retry still returns 200, we slice the requested bytes from the full\n * response (matching igvxhr's fallback behavior).\n *\n * On HTTP 416 (Range Not Satisfiable), fetches the actual file size via HEAD\n * and retries once with a clamped range.\n */\nexport async function fetchRange(url: string, range: ByteRange, signal?: AbortSignal): Promise<ArrayBuffer> {\n const end = range.start + range.size - 1\n const headers = {'Range': `bytes=${range.start}-${end}`}\n\n let response = await fetch(url, {headers, signal})\n\n // If redirected and Range was stripped (200 instead of 206), retry against final URL\n if (response.status === 200 && response.redirected && response.url && response.url !== url) {\n response = await fetch(response.url, {headers, signal})\n }\n\n if (response.status === 416) {\n const contentLength = await getContentLength(url, signal)\n const clampedSize = Math.min(range.size, contentLength - range.start)\n if (clampedSize <= 0) {\n throw new Error(`HTTP range request failed: 416 Range Not Satisfiable (file size: ${contentLength})`)\n }\n return fetchRange(url, {start: range.start, size: clampedSize}, signal)\n }\n\n if (!response.ok && response.status !== 206) {\n throw new Error(`HTTP range request failed: ${response.status} ${response.statusText}`)\n }\n\n // If we still got 200 (full file) despite retrying, slice the correct bytes\n // (matches igvxhr behavior: xhr.response.slice(range.start, range.start + range.size))\n if (response.status === 200) {\n const fullBuffer = await response.arrayBuffer()\n return fullBuffer.slice(range.start, range.start + range.size)\n }\n\n return response.arrayBuffer()\n}\n\n/**\n * Fetch the Content-Length of a URL via a HEAD request.\n * If redirected and Content-Length is missing, retries against the final URL.\n */\nexport async function getContentLength(url: string, signal?: AbortSignal): Promise<number> {\n let response = await fetch(url, {method: 'HEAD', signal})\n\n // If redirected and we didn't get Content-Length, retry against final URL\n if (response.redirected && response.url && response.url !== url) {\n const cl = response.headers.get('Content-Length')\n if (!cl) {\n response = await fetch(response.url, {method: 'HEAD', signal})\n }\n }\n\n if (!response.ok) {\n throw new Error(`HEAD request failed: ${response.status} ${response.statusText}`)\n }\n const cl = response.headers.get('Content-Length')\n if (!cl) throw new Error('No Content-Length header in HEAD response')\n return parseInt(cl, 10)\n}\n\n/**\n * Buffered reader that caches fetched data to minimize HTTP requests.\n * When a requested range is within the cached buffer, no fetch is needed.\n *\n * On HTTP 416, recovers by fetching the file's Content-Length and retrying,\n * matching js/bigwig/bufferedReader.ts behavior.\n */\nexport class BufferedRangeReader {\n private readonly url: string\n private readonly bufferSize: number\n private cachedRange: ByteRange\n private cachedData: ArrayBuffer | undefined\n private contentLength: number | undefined\n\n constructor(url: string, bufferSize: number = 512000) {\n this.url = url\n this.bufferSize = bufferSize\n this.cachedRange = {start: -1, size: -1}\n }\n\n async dataViewForRange(requestedRange: ByteRange, signal?: AbortSignal, retries: number = 0): Promise<DataView> {\n try {\n const hasData = (\n this.cachedData !== undefined &&\n this.cachedRange.start <= requestedRange.start &&\n (this.cachedRange.start + this.cachedRange.size) >= (requestedRange.start + requestedRange.size)\n )\n\n if (!hasData) {\n let bufferSize = requestedRange.size\n ? Math.max(this.bufferSize, requestedRange.size)\n : this.bufferSize\n\n if (this.contentLength) {\n bufferSize = Math.min(bufferSize, this.contentLength - requestedRange.start)\n }\n\n const loadRange: ByteRange = {start: requestedRange.start, size: bufferSize}\n this.cachedData = await fetchRange(this.url, loadRange, signal)\n this.cachedRange = loadRange\n }\n\n const bufferStart = requestedRange.start - this.cachedRange.start\n const len = this.cachedData!.byteLength\n return new DataView(this.cachedData!, bufferStart, len - bufferStart)\n } catch (e: unknown) {\n if (retries === 0 && e instanceof Error && e.message.includes('416')) {\n try {\n this.contentLength = await getContentLength(this.url, signal)\n return this.dataViewForRange(requestedRange, signal, retries + 1)\n } catch (e1) {\n console.error(e1)\n }\n }\n throw e\n }\n }\n\n async loadArrayBuffer(range: ByteRange, signal?: AbortSignal): Promise<ArrayBuffer> {\n return fetchRange(this.url, range, signal)\n }\n}\n","/**\n * Base64-inlined zstd WASM binary (from @bokuweb/zstd-wasm, MIT license).\n * Eliminates the need for bundlers to handle `new URL('./zstd.wasm', import.meta.url)`.\n */\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nconst ZSTD_WASM_BASE64 = `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AWohACAGIAhqIQYMAQsACwALQQAhAgNAIAIgBUZFBEAgBCACIAlqLQAAQQF0aiIAIAAvAQAiAEEBajsBACAQIABBAXRqIAIgBWo7AQAgAkEBaiECDAELCyADQR9rIQQgA0EQdCAFayIFQYCABGohCUEAIQZBACEAQQAhAgNAIAIgCkYNAQJAAkACQAJAAkAgASACQQF0ai8BACIDDgIAAgELIA0gAkEDdGogCTYCBAwDCyADQf//A0cNAQsgDSACQQN0aiIDIABBAWs2AgAgAyAFNgIEIABBAWohAAwBCyANIAJBA3RqIgcgACADwSIDazYCACAHIAQgA0EBa2dqIgdBEHQgAyAHdGs2AgQgACADaiEACyACQQFqIQIMAAsACyAGCxcAIAAgASACIANCgIDs/Mub741PELIBCxcAIAAgASACIANCgIDs/Mub741PELMBCxcAIAAgASACIANCgIDs/Mub741PELQBCxcAIAAgASACIANCgICA2Mub741PELIBCxcAIAAgASACIANCgICA2Mub741PELMBCxcAIAAgASACIANCgICA2Mub741PELQBC6EKAhd/An4jAEGAAmsiEyQAIAEgACgCBCIOayIIQQEgACgCuAF0IgRrIAAoAhAiEiAIIBJrIARLGyERIAAoAhghFyAAKAIMIRQgACgCCCEWQQYgACgCxAEiBCAEQQZPGyEYIAApA1AhGyAAKAIkIQsgACgCKCEJIAAoAlwhDAJAIAAoAtwBRQRAIABBLGohEAJ/IAggACgCHCIEa0GAA00EQEEYIAtrIQ8gCSEGIAwhByAODAELIAQgBEHgAGoiBSAEIAVLGyEPQRggC2shCiAOQQhqIQ0DQCAEIA9GRQRAIBAgBEEHcUECdGoiBigCACEFIAYgACgCUCAEIA1qKAAAQbHz3fF5bHMgCnY2AgAgCSAFQQJ2QcD///8DcSIVaiIGQT9BACAGLQAAIgdBP3FBAUYbIAdBAWtBP3FqIgc6AAAgBiAHaiAFOgAAIAwgFUECdGogB0ECdGogBDYCACAEQQFqIQQMAQsLQQggAUEBaiIFIA4gCEEgayIEaiIGa0EBaiIHIAdBCE8bQQAgBSAGTxsgBGohCkEYIAAoAiRrIQ8gACgCKCEGIAAoAlwhByAEIQUDQCAFIApPRQRAIBAgBUEHcUECdGogACgCUCAF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IAQgGWooAABBsfPd8XlscyAPdjYCACAGIAVBBHZB8P///wBxIhpqIgpBD0EAIAotAAAiDUEPcUEBRhsgDUEBa0EPcWoiDToAACAKIA1qIAU6AAAgByAaQQJ0aiANQQJ0aiAENgIAIARBAWohBAwBCwsgACAJNgIcIBAgCUEHcUECdGoiBCgCACEHIAQgG6cgCSAOaigACEGx893xeWxzQRggC2t2NgIADAELIAEoAAAhBCAAIAk2AhwgG6cgBEGx893xeWxzQRggC2t2IQcLIBIgESAXGyEQIBQgFmohDyAOIBRqIRJBASAYdCEGIAAgACgCWCAHajYCWCAHQf8BcUGBgoQIbCEKIAggB0EEdkHw////AHEiDWoiCy0AACEIQgAhG0EQIQQDQCALIARBBGsiBWooAAAgCnMiEUGAgYKEeHJBgYKECGsgEXJBgIGChHhxQYGBgQFsQRx2rSAbQgSGhCEbIARBB0sgBSEEDQALQQAhBSAbp0F/cyIEQf//A3EgCEEPcXYgBEEAIAhrQQ9xdHKtQv//A4MhGyAMIA1BAnRqIQwDQAJAIAZFIBtQcg0AIBunaCAIakEPcSIEBEAgDCAEQQJ0aigCACIEIBBJDQEgEyAFQQJ0aiAENgIAIAZBAWshBiAFQQFqIQULIBtCAX0gG4MhGwwBCwtBACEEIAsgCEEBa0EPcUEPQQAgCEEPcUEBRhtqIgY6AAAgBiALaiAHOgAAIAAgACgCHCIAQQFqNgIcIAwgBkECdGogADYCAEEDIQYgCUEDaiEMIAFBBGohByABQQNrIQkDQAJAIAQgBUYEQCAGIQAMAQsCQCAGAn8gFCATIARBAnRqKAIAIghNBEAgCCAOaiIAIAZqQQNrKAAAIAYgCWooAABHDQIgASAAIAIQBgwBCyAIIBZqIgAoAAAgASgAAEcNASAHIABBBGogAiAPIBIQBUEEagsiAE8NACADIAwgCGs2AgAgACIGIAFqIAJGDQELIARBAWohBAwBCwsgE0GAAmokACAACxcAIAAgASACIANCgIDs/Mub741PELUBCxcAIAAgASACIANCgIDs/Mub741PELYBCxcAIAAgASACIANCgIDs/Mub741PELcBCxcAIAAgASACIANCgICA2Mub741PELUBCxcAIAAgASACIANCgICA2Mub741PELYBCxcAIAAgASAC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DCAJEJIBIAEoAgwhBAJAIB4gByANaiIPTwRAIA0pAAAhIiAEIA0pAAg3AAggBCAiNwAAIAdBEUkNASANKQAQISIgASgCDCIEIA0pABg3ABggBCAiNwAQIAdBIUgNASANQRBqIQYgBCAHaiENIARBIGohBANAIAYpABAhIiAEIAYpABg3AAggBCAiNwAAIAYpACAhIiAEIAYpACg3ABggBCAiNwAQIAZBIGohBiAEQSBqIgQgDUkNAAsMAQsgBCANIA8gHhAHCyABIAEoAgwgB2o2AgwgASgCBCEEIAdBgIAETwRAIAFBATYCJCABIAQgASgCAGtBA3U2AigLIAQgDDYCACAEIAc7AQQgCUEDayIHQYCABE8EQCABQQI2AiQgASAEIAEoAgBrQQN1NgIoCyAEIAc7AQYgASAEQQhqNgIEIAkgD2oiDQUgByANagshDyAFQQFqIQUMAQsLIBFBAhCQAQwACwALvQEBAX8CQCAAKAIMIgZFDQAgACgCBCAGTw0AIAAoAhgiBiADTQRAIAMgBksEQCAAIAMgBmsQUgsgACADIAQQXyAAKAIYIQYLIAMgACgCFEkgAyAGT3INACAGIANrIgQgBUkNACACKAIAIgMEQCADQf8fSw0BIAQgASADQQN0akEEaygCAE0NAQsgACgCHCEAIAEgA0EDdGogBDYCBCABIAIoAgBBA3RqIABBA2o2AgAgAiACKAIAQQFqNgIACwtMACAEQQNxBEBBfw8LIAVBgCBJBEBBvn8PCyABKAIAQf4BTQRAIAAgASACIANBASAEEKkBDwsgAUH/ATYCACAAIAEgAiADIAQgBRAiC40CAgN/AX4gACACaiEEAkACQCACQQhOBEAgACABayICQXlIDQELA0AgACAETw0CIAAgAS0AADoAACAAQQFqIQAgAUEBaiEBDAALAAsCQAJAIAJBb0sNACAAIARBIGsiAksNACABKQAAIQYgACABKQAINwAIIAAgBjcAACACIABrIgVBEU4EQCAAQRBqIQAgASEDA0AgAykAECEGIAAgAykAGDcACCAAIAY3AAAgAykAICEGIAAgAykAKDcAGCAAIAY3ABAgA0EgaiEDIABBIGoiACACSQ0ACwsgASAFaiEBDAELIAAhAgsDQCACIARPDQEgAiABLQAAOgAAIAJBAWohAiABQQFqIQEMAAsACwuR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AAJ/IAIgACgClOsBBH8gACgC0OkBBUGAgAgLIgIgA2pBQGtLBEAgACABIAJqQSBqIgE2AvzrAUEBIQIgASADagwBCyADQYCABE0EQCAAIABBiOwBaiIBNgL86wFBACECIAEgA2oMAQsgACABIARqIgEgA2siAkHg/wNqIgQgAiAFGzYC/OsBQQIhAiADIARqQYCABGsgASAFGwshAyAAIAI2AoTsASAAIAM2AoDsAQtSAQN/AkAgACgCmOsBIgFFDQAgASgCACABKAK01QEiAiABKAK41QEiAxAUIAIEQCADIAEgAhEJAAwBCyABEBgLIABBADYCqOsBIABCADcDmOsBCyYAIANBGHQgAUEQdGogACAAQQh0IAJyIANBAUYbcq1CgYCAgBB+C0UBAX8CQCAAKAIkRQRAIABBARDQAUGIf0sNAQsgACgCDCICIAFqIgEgACgCFEsEQCAAQQE6ABxBAA8LIAAgATYCDAsgAgtPAQF/IAFFIAAgAhDQAUGIf0tyRQRAIAAoAhQgAWsiAyAAKAIMSQRAIABBAToAHEEADwsgACgCECADSwRAIAAgAzYCEAsgACADNgIUCyADC00BAX8CQCAAKAIkRQRAIAAoAggiAiABQQNqQfz/AXFqIgEgACgCBE0NAQsgAEEBOgAcQQAPCyAAIAE2AhAgACABNgIMIAAgATYCCCACC7oBAQF/IwBBEGsiCiQAIAogAzYCDCAIIApBDGogASACIAggCRAiGkEAIQMCfwJAAkACQAJAIAAOAgACAQsgBiAHIAggCigCDBBqIQMMAQsgAEF+cUECRw0AIAQgCCAKKAIMEGsiA0GIf0sNAQsgASACaiEAA0AgACABTUUEQCABIQggBQRAIAUgAS0AAGohCAsgAUEBaiEBIAMgCC0AAGohAwwBCwsgA0EDdgwBCyACQQpsCyAKQRBqJAALXAEEfyAAKAIEIAAoAgAiA2tBA3UhBANAIAIgBEZFBEAgASADIAJBA3RqLwEEaiEBIAAoAiggAkYEQCABQYCABGogASAAKAIkQQFGGyEBCyACQQFqIQIMAQsLIAELrAMBDH8jAEEQayIFJAAgACABKALoECABKALsECABQcABaiABQawbaiABKALQEiABKALUEhCeASICQYh/TQRAIAEoAtQSIQYgASgC0BIhAiABKALsECEHIAAoAhQh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IAAgBmogACAFaiATEAYhDCAGIANrIQgCQCAGIBRNBEAgAykAACEhIAEoAgwiBSADKQAINwAIIAUgITcAACAIQRFJDQEgAykAECEhIAEoAgwiByADKQAYNwAYIAcgITcAECAIQSFIDQEgA0EQaiEFIAcgCGohAyAHQSBqIQcDQCAFKQAQISEgByAFKQAYNwAIIAcgITcAACAFKQAgISEgByAFKQAoNwAYIAcgITcAECAFQSBqIQUgB0EgaiIHIANJDQALDAELIAEoAgwgAyADIAhqIBQQBwsgASABKAIMIAhqNgIMIAEoAgQhAyAIQYCABE8EQCABQQE2AiQgASADIAEoAgBrQQN1NgIoCyADIAk2AgAgAyAIOwEEIAAgDGoiAEEDayIFQYCABE8EQCABQQI2AiQgASADIAEoAgBrQQN1NgIoCyADIAU7AQYgASADQQhqNgIEIAQhByAAIAZqIgUhAyAFIBFLDQAgCyAQIBlqKAAAQbHz3fF5bCAPdkECdGogEEECajYCACALIAVBAmsiACgAAEGx893xeWwgD3ZBAnRqIAAgCms2AgBBACEHIARFDQADQAJAIAQhByAFIBFLDQAgBSgAACIAIAUgBGsoAABHDQAgBUEEaiIDIAMgBGsgExAGIQQgCyAAQbHz3fF5bCAPdkECdGogBSAKazYCACABKAIMIQACQCAFIBRNBEAgBSkAACEhIAAgBSkACDcACCAAICE3AAAMAQsgACAFIAUgFBAHCyABKAIEIgBBATYCACAAQQA7AQQgBEEBaiIGQYCABE8EQCABQQI2AiQgASAAIAEoAgBrQQN1NgIoCyADIARqIQUgACAGOwEGIAEgAEEIajYCBCAOIQQgByEODAELCyAFIQMMAAsACyATQSBrIQ9BwAAgBGutISIDQCAFIBdqIg1BAWoiDCARTw0GQQAgDmshFSAFQYABaiEQIAVBAWohCCALIAUpAABCgMaV/cub741PfiAiiKciAEECdGooAgAhBCAFKQABISEgFyEJAkADQAJAIAwhEiANIgYgFWoiDSgAACEUIAsgAEECdGogBSAKayIMNgIAICFCgMaV/cub741PfiAiiKchAAJAAkAgDgRAIAYoAAAgFEYNAQsCQAJAAkAgBCAWSQ0AIAUoAAAgBCAKaigAAEcNACAIIQYgBSEIDAELIAsgAEECdGoi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DSAEayEFIAYgBGshCEEBIQkgByEEDAMLIAkgEmohDCALIABBAnRqKAIAIQQgEikAACEhIAYgCWoiDSAQTwRAIBBBgAFqIRAgCUEBaiEJCyASIQggBiEFIAwgEUkNAQwHCwsgDiEEIAchDgsgACAIaiAAIAVqIBMQBiENIAggA2shBgJAIAggD00EQCADKQAAISEgASgCDCIFIAMpAAg3AAggBSAhNwAAIAZBEUkNASADKQAQISEgASgCDCIHIAMpABg3ABggByAhNwAQIAZBIUgNASADQRBqIQUgBiAHaiEDIAdBIGohBwNAIAUpABAhISAHIAUpABg3AAggByAhNwAAIAUpACAhISAHIAUpACg3ABggByAhNwAQIAVBIGohBSAHQSBqIgcgA0kNAAsMAQsgASgCDCADIAMgBmogDxAHCyABIAEoAgwgBmo2AgwgASgCBCEDIAZBgIAETwRAIAFBATYCJCABIAMgASgCAGtBA3U2AigLIAMgCTYCACADIAY7AQQgACANaiIAQQNrIgVBgIAETwRAIAFBAjYCJCABIAMgASgCAGtBA3U2AigLIAMgBTsBBiABIANBCGo2AgQgBCEHIAAgCGoiBSEDIAUgEUsNACALIAwgGWopAABCgICA2Mub741PfiAiiKdBAnRqIAxBAmo2AgAgCyAFQQJrIgApAABCgICA2Mub741PfiAiiKdBAnRqIAAgCms2AgBBACEHIARFDQADQAJAIAQhByAFIBFLDQAgBSgAACAFIARrKAAARw0AIAVBBGoiAyADIARrIBMQBiEEIAsgBSkAAEKAgIDYy5vvjU9+ICKIp0ECdGogBSAKazYCACABKAIMIQACQCAFIA9NBEAgBSkAACEhIAAgBSkACDcACCAAICE3AAAMAQsgACAFIAUgDxAHCyABKAIEIgBBATYCACAAQQA7AQQgBEEBaiIGQYCABE8EQCABQQI2AiQgASAAIAEoAgBrQQN1NgIoCyADIARqIQUgACAGOwEGIAEgAEEIajYCBCAOIQQgByEODAELCyAFIQMMAAsACyATQSBrIQ9BwAAgBGutISIDQCAFIBdqIg1BAWoiDCARTw0DQQAgDmshFSAFQYABaiEQIAVBAWohBiALIAUpAABCgMaV/cub741PfiAiiKciBEECdGooAgAhACAFKQABISEgFyEJAkADQAJAIAwhEiANIgggFWoiDSgAACEUIAsgBEECdGogBSAKayIMNgIAICFCgMaV/cub741PfiAiiKchBAJAAkAgDgRAIAgoAAAgFEYNAQsCQAJAIAUoAABB+jwgACAKaiAAIBZJIg0bKAAARyANckUEQCAGIQggBSEGDAELIAsgBEECdGoiBCgCACEAIAgpAAAgBCAGIAprIgw2AgBCgMaV/cub741PfiAiiKchBCAGKAAAQfo8IAAgCmogACAWSSIFGygAAEcgBXINAyAJQQVPDQELIAsgBEECdGogCCAKazYCAAsgBiAAIApqIgVrIghBA2ohCUEEIQADQCAFIBhNIAMgBk9yDQMgBkEBayIELQAAIAVBAWsiBy0AAEcNAyAAQQFqIQAgByEFIAQhBgwACwALIA1BAWstAAAhACAIQQFrLQAAIQUgCyAEQQJ0aiAGIAprNgIAQQVBBCAAIAVGIgQbIQAgDSAEayEFIAggBGshBkEBIQkgByEEDAMLIAkgEmohDCALIARBAnRqKAIAIQAgEikAACEhIAggCWoiDSAQTwRAIBBBgAFqIRAgCUEBaiEJCyASIQYgCCEFIAwgEUkNAQwGCwsgDiEEIAghDgsgACAGaiAAIAVqIBMQBiENIAYgA2shCAJAIAYgD00EQCADKQAAISEgASgCDCIFIAMpAAg3AAggBSAhNwAAIAhBEUkNASADKQAQISEgASgCDCIHIAMpABg3ABggByAhNwAQIAhBIUgNASADQRBqIQUgByAIaiEDIAdBIGohBwNAIAUpABAhISAHIAUpABg3AAggByAhNwAAIAUpACAhISAHIAUpACg3ABggByAhNwAQIAVBIGohBSAHQSBqIgcgA0kNAAsMAQsgASgCDCADIAMgCGogDxAHCyABIAEoAgwgCGo2AgwgASgCBCEDIAhBgIAETwRAIAFBATYCJCABIAMgASgCAGtBA3U2AigLIAMgCTYCACADIAg7AQQgACANaiIAQQNrIgVBgIAETwRAIAFBAjYCJCABIAMgASgCAGtBA3U2AigLIAMgBTsBBiABIANBCGo2AgQgBCEHIAAgBmoiBSEDIAUgEUsNACALIAwgGWopAABCgMaV/cub741PfiAiiKdBAnRqIAxBAmo2AgAgCyAFQQJrIgApAABCgMaV/cub741PfiAiiKdBAnRqIAAgCms2AgBBACEHIARFDQADQAJAIAQhByAFIBFLDQAgBSgAACAFIARrKAAARw0AIAVBBGoiAyADIARrIBMQBiEEIAsgBSkAAEKAxpX9y5vvjU9+ICKIp0ECdGogBSAKazYCACABKAIMIQACQCAFIA9NBEAgBSkAACEhIAAgBSkACDcACCAAICE3AAAMAQsgACAFIAUgDxAHCyABKAIEIgBBATYCACAAQQA7AQQgBEEBaiIGQYCABE8EQCABQQI2AiQgASAAIAEoAgBrQQN1NgIoCyADIARqIQUgACAGOwEGIAEgAEEIajYCBCAOIQQgByEODAELCyAFIQMMAAsACyATQSBrIQ9BwAAgBGutISIDQCAFIBdqIg1BAWoiDCARTw0CQQAgDmshFSAFQYABaiEQIAVBAWohBiALIAUpAABCgIDs/Mub741PfiAiiKciBEECdGooAgAhACAFKQABISEgFyEJAkADQAJAIAwhEiANIgggFWoiDSgAACEUIAsgBEECdGogBSAKayIMNgIAICFCgIDs/Mub741PfiAiiKchBAJAAkAgDgRAIAgoAAAgFEYNAQsCQAJAIAUoAABB+jwgACAKaiAAIBZJIg0bKAAARyANckUEQCAGIQggBSEGDAELIAsgBEECdGoiBCgCACEAIAgpAAAgBCAGIAprIgw2AgBCgIDs/Mub741PfiAiiKchBCAGKAAAQfo8IAAgCmogACAWSSIFGygAAEcgBXINAyAJQQVPDQELIAsgBEECdGogCCAKazYCAAsgBiAAIApqIgVrIghBA2ohCUEEIQADQCAFIBhNIAMgBk9yDQMgBkEBayIELQAAIAVBAWsiBy0AAEcNAyAAQQFqIQAgByEFIAQhBgwACwALIA1BAWstAAAhACAIQQFrLQAAIQUgCyAEQQJ0aiAGIAprNgIAQQVBBCAAIAVGIgQbIQAgDSAEayEFIAggBGshBkEBIQkgByEEDAMLIAkgEmohDCALIARBAnRqKAIAIQAgEikAACEhIAggCWoiDSAQTwRAIBBBgAFqIRAgCUEBaiEJCyASIQYgCCEFIAwgEUkNAQwFCwsgDiEEIAghDgsgACAGaiAAIAVqIBMQBiENIAYgA2shCAJAIAYgD00EQCADKQAAISEgASgCDCIFIAMpAAg3AAggBSAhNwAAIAhBEUkNASADKQAQISEgASgCDCIHIAMpABg3ABggByAhNwAQIAhBIUgNASADQRBqIQUgByAIaiEDIAdBIGohBwNAIAUpABAhISAHIAUpABg3AAggByAhNwAAIAUpACAhISAHIAUpACg3ABggByAhNwAQIAVBIGohBSAHQSBqIgcgA0kNAAsMAQsgASgCDCADIAMgCGogDxAHCyABIAEoAgwgCGo2AgwgASgCBCEDIAhBgIAETwRAIAFBATYCJCABIAMgASgCAGtBA3U2AigLIAMgCTYCACADIAg7AQQgACANaiIAQQNrIgVBgIAETwRAIAFBAjYCJCABIAMgASgCAGtBA3U2AigLIAMgBTsBBiABIANBCGo2AgQgBCEHIAAgBmoiBSEDIAUgEUsNACALIAwgGWopAABCgIDs/Mub741PfiAiiKdBAnRqIAxBAmo2AgAgCyAFQQJrIgApAABCgIDs/Mub741PfiAiiKdBAnRqIAAgCms2AgBBACEHIARFDQADQAJAIAQhByAFIBFLDQAgBSgAACAFIARrKAAARw0AIAVBBGoiAyADIARrIBMQBiEEIAsgBSkAAEKAgOz8y5vvjU9+ICKIp0ECdGogBSAKazYCACABKAIMIQACQCAFIA9NBEAgBSkAACEhIAAgBSkACDcACCAAICE3AAAMAQsgACAFIAUgDxAHCyABKAIEIgBBATYCACAAQQA7AQQgBEEBaiIGQYCABE8EQCABQQI2AiQgASAAIAEoAgBrQQN1NgIoCyADIARqIQUgACAGOwEGIAEgAEEIajYCBCAOIQQgByEODAELCyAFIQMMAAsACyATQSBrIQ9BwAAgBGutISIDQCAFIBdqIg1BAWoiDCARTw0BQQAgDmshFSAFQYABaiEQIAVBAWohBiALIAUpAABCgICA2Mub741PfiAiiKciBEECdGooAgAhACAFKQABISEgFyEJAkADQAJAIAwhEiANIgggFWoiDSgAACEUIAsgBEECdGogBSAKayIMNgIAICFCgICA2Mub741PfiAiiKchBAJAAkAgDgRAIAgoAAAgFEYNAQsCQAJAIAUoAABB+jwgACAKaiAAIBZJIg0bKAAARyANckUEQCAGIQggBSEGDAELIAsgBEECdGoiBCgCACEAIAgpAAAgBCAGIAprIgw2AgBCgICA2Mub741PfiAiiKchBCAGKAAAQfo8IAAgCmogACAWSSIFGygAAEcgBXINAyAJQQVPDQELIAsgBEECdGogCCAKazYCAAsgBiAAIApqIgVrIghBA2ohCUEEIQADQCAFIBhNIAMgBk9yDQMgBkEBayIELQAAIAVBAWsiBy0AAEcNAyAAQQFqIQAgByEFIAQhBgwACwALIA1BAWstAAAhACAIQQFrLQAAIQUgCyAEQQJ0aiAGIAprNgIAQQVBBCAAIAVGIgQbIQAgDSAEayEFIAggBGshBkEBIQkgByEEDAMLIAkgEmohDCALIARBAnRqKAIAIQAgEikAACEhIAggCWoiDSAQTwRAIBBBgAFqIRAgCUEBaiEJCyASIQYgCCEFIAwgEUkNAQwECwsgDiEEIAghDgsgACAGaiAAIAVqIBMQBiENIAYgA2shCAJAIAYgD00EQCADKQAAISEgASgCDCIFIAMpAAg3AAggBSAhNwAAIAhBEUkNASADKQAQISEgASgCDCIHIAMpABg3ABggByAhNwAQIAhBIUgNASADQRBqIQUgByAIaiEDIAdBIGohBwNAIAUpABAhISAHIAUpABg3AAggByAhNwAAIAUpACAhISAHIAUpACg3ABggByAhNwAQIAVBIGohBSAHQSBqIgcgA0kNAAsMAQsgASgCDCADIAMgCGogDxAHCyABIAEoAgwgCGo2AgwgASgCBCEDIAhBgIAETwRAIAFBATYCJCABIAMgASgCAGtBA3U2AigLIAMgCTYCACADIAg7AQQgACANaiIAQQNrIgVBgIAETwRAIAFBAjYCJCABIAMgASgCAGtBA3U2AigLIAMgBTsBBiABIANBCGo2AgQgBCEHIAAgBmoiBSEDIAUgEUsNACALIAwgGWopAABCgICA2Mub741PfiAiiKdBAnRqIAxBAmo2AgAgCyAFQQJrIgApAABCgICA2Mub741PfiAiiKdBAnRqIAAgCms2AgBBACEHIARFDQADQAJAIAQhByAFIBFLDQAgBSgAACAFIARrKAAARw0AIAVBBGoiAyADIARrIBMQBiEEIAsgBSkAAEKAgIDYy5vvjU9+ICKIp0ECdGogBSAKazYCACABKAIMIQACQCAFIA9NBEAgBSkAACEhIAAgBSkACDcACCAAICE3AAAMAQsgACAFIAUgDxAHCyABKAIEIgBBATYCACAAQQA7AQQgBEEBaiIGQYCABE8EQCABQQI2AiQgASAAIAEo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EWoiBSgAACABKAAARw0BIAwgBUEEaiACIBIgExAFQQRqCyIFIABNDQAgAyALIAZrNgIAIAUiACABaiACRg0DCyAGIA9NDQAgB0EBayEHIAkgBiAUcUECdGohBQwBCwsgACEFCyAFC/sJAiN/AX4jAEEQayIUJAACQCADIAEoAgQiCyABKAIcIgJqSQ0AIAMgC2shCgNAIAIgCk9FBEAgASACIAtqIAQgCiAJQQAQECACaiECDAELCyABIAo2AhxBASABKAIQIgIgAyABKAIEIhVrIg1BASABKAK4AXQiCmsgAiANIAJrIApLGyABKAIYGyIWIBZBAU0bISIgDUF/IAEoArwBQQFrdEF/cyIbayICQQAgAiANTRshHCABKAJcIAMpAAAgCH4iLUHAACABKALAAWutiKdBAnRqIiMoAgAhDCABKAK0ASISKAIAIh0gEigCBCIeayIXQX8gEigCvAFBAWt0QX9zIh9rIBIoAhAiGCAXIBhrIB9LGyEkIB4gFiAXayIZayElIA0gGCAZamshJiAGIAZBA2oiAiACIAZJGyEnIAEoAmQiKCANIBtxQQN0aiITQQRqIQ9B/x8gASgCzAEiAiACQf8fTxshKSADQQRqIRogB0EBayEKIBUgASgCDCIgaiEhIA0gIGshKiANQQlqIRBBASABKALEAXQhESASKALAASErIAYhAgNAIAIgJ0cEQCANAn8gAkEDRgRAIAUoAgBBAWsMAQsgBSACQQJ0aigCAAsiC2shBwJAAn8gKiALQQFrIixLBEAgByAWSQ0CIAMoAAAgAyALaygAAEcNAiAaIBogC2sgBBAGDAELICYgLE0gByAga0F8S3INASADKAAAIAcgJWoiBygAAEcNASAaIAdBBGogBCAdICEQBQtBBGoiByAKTQ0AIAAgDkEDdGoiCiAHNgIEIAogAiAGa0EBajYCACAOQQFqIQ4gByApSw0DIAciCiADaiAERg0DCyACQQFqIQIMAQsLICMgDTYCACANQQNqIQZBACEHQQAhBQJAAkACQAJAAkADQCARRSAMICJJcg0CIAogAyAFIAcgBSAHSRsiAmogDCAVaiINIAJqIAQQBiACaiICSQRAIAAgDkEDdGoiCiACNgIEIAogBiAMazYCACACIAxqIBAgAiAQIAxrSxshECAOQQFqIQ4gAiADaiAERiACQYAgS3INBSACIQoLICggDCAbcUEDdGohCwJAAkACQCACIA1qLQAAIAIgA2otAABJBEAgEyAMNgIAIAwgHEsNASAUQQxqIRMMBQsgDyAMNgIAIAwgHE0NAiALIQ8gAiEHDAELIAIhBSALQQRqIhMhCwsgEUEBayERIAsoAgAhDAwBCwsgFEEMaiEPCyAPQQA2AgAgE0EANgIADAELIA9BADYCACATQQA2AgAgEUUNAgsgFSAZaiEPIBIoAlwgLUHAACAra62Ip0ECdGohAiASKAJkIQ1BACEMQQAhBwNAIBFFDQIgAigCACIFIBhNDQIgCiADIAcgDCAHIAxJGyICaiAFIB5qIgsgAmogBCAdICEQBSACaiICSQRAIAAgDkEDdGoiCiACNgIEIAogBiAFIBlqIgprNgIAIAIgCmogECACIBAgCmtLGyEQIA5BAWohDiACQYAgSw0DIAIhCiACIANqIARGDQMLIAUgJE0NAiARQQFrIREgAiAHIAsgBSAPaiACIAVqIBdJGyACai0AACACIANqLQAASSILGyEHIAwgAiALGyEMIA0gBSAfcUEDdGogC0ECdGohAgwACwALIA9BADYCACATQQA2AgALIAEgEEEIazYCHAsgFEEQaiQAIA4LsgcBG38jAEEQayIUJAACQCADIAEoAgQiDSABKAIcIgJqSQ0AIAMgDWshCwNAIAIgC09FBEAgASACIA1qIAQgCyAJQQEQECACaiECDAELCyABIAs2AhxBASABKAIQIgIgAyABKAIEIhBrIgxBASABKAK4AXQiC2sgAiAMIAJrIAtLGyABKAIYGyIVIBVBAU0bIR0gDEF/IAEoArwBQQFrdEF/cyIZayICQQAgAiAMTRshGiAMIBVrIR4gBiAGQQNqIgIgAiAGSRshHyABKAJkIiAgDCAZcUEDdGoiEUEEaiESIAEoAlwgAykAACAIfkHAACABKALAAWutiKdBAnRqIiEoAgAhCkH/HyABKALMASICIAJB/x9PGyEiIANBBGohFiAHQQFrIQsgECABKAIMIg9qIRsgASgCCCIXIA9qIRwgDCAPayEjIAxBCWohE0EBIAEoAsQBdCEYIAYhAgNAIAIgH0cEQCAMAn8gAkEDRgRAIAUoAgBBAWsMAQsgBSACQQJ0aigCAAsiDWshBwJAAn8gIyANQQFrIiRLBEAgByAVSQ0CIAMoAAAgAyANaygAAEcNAiAWIBYgDWsgBBAGDAELIB4gJE0gByAPa0F8S3INASADKAAAIAcgF2oiBygAAEcNASAWIAdBBGogBCAcIBsQBQtBBGoiByALTQ0AIAAgDkEDdGoiCyAHNgIEIAsgAiAGa0EBajYCACAOQQFqIQ4gByAiSw0DIAciCyADaiAERg0DCyACQQFqIQIMAQsLICEgDDYCACAMQQNqIQxBACEHQQAhBQJAA0AgGEUgCiAdSXINASADIAUgByAFIAdJGyICaiEGAn8gDyACIApqTQRAIAYgCiAQaiACaiAEEAYgAmohAiAQDAELIBcgECAGIAogF2ogAmogBCAcIBsQBSACaiICIApqIA9JGwshBiACIAtLBEAgACAOQQN0aiILIAI2AgQgCyAMIAprNgIAIAIgCmogEyACIBMgCmtLGyETIA5BAWohDiACQYAgSw0CIAIhCyACIANqIARGDQILICAgCiAZcUEDdGohDQJAAkACQCAGIApqIAJqLQAAIAIgA2otAABJBEAgESAKNgIAIAogGksNASAUQQxqIREMBQsgEiAKNgIAIAogGk0NAiANIRIgAiEHDAELIAIhBSANQQRqIhEhDQsgGEEBayEYIA0oAgAhCgwBCwsgFEEMaiESCyASQQA2AgAgEUEANgIAIAEgE0EIazYCHAsgFEEQaiQAIA4LmwYBFH8jAEEQayITJAACQCADIAEoAgQiCiABKAIcIgJqSQ0AIAMgCmshCwNAIAIgC09FBEAgASACIApqIAQgCyAJQQAQECACaiECDAELCyABIAs2AhxBASABKAIQIgIgAyABKAIEIhdrIgxBASABKAK4AXQiC2sgAiAMIAJrIAtLGyABKAIYGyIPIA9BAU0bIRggDEF/IAEoArwBQQFrdEF/cyIUayICQQAgAiAMTRshFSAGIAZBA2oiAiACIAZJGyEZIAEoAmQiGiAMIBRxQQN0aiIQQQRqIREgASgCXCADKQAAIAh+QcAAIAEoAsABa62Ip0ECdGoiGygCACENQf8fIAEoAswBIgIgAkH/H08bIRwgA0EEaiEWIAdBAWshCyAMIAEoAgxrIR0gDEEJaiESQQEgASgCxAF0IQcgBiECA0AgAiAZRwRAAkACfyACQQNGBEAgBSgCAEEBawwBCyAFIAJBAnRqKAIACyIKQQFrIB1P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ASAJIBgpAgA3A3ggDCAlIAlB+ABqIAlBzAJqICQgDyAnICEQGiEKDAELIAMgGmohCyADIAxqIQggGCgCCCENIBopAAAhSyAMIBopAAg3AAggDCBLNwAAAkAgA0ERSQ0AIB8pAAAhSyAMIB8pAAg3ABggDCBLNwAQIANBEGtBEUgNACAMQSBqIQMgHyETA0AgEykAECFLIAMgEykAGDcACCADIEs3AAAgEykAICFLIAMgEykAKDcAGCADIEs3ABAgE0EgaiETIANBIGoiAyAISQ0ACwsgCCANayEDIAkgCzYCzAIgCCAPayANSQRAIA0gCCAna0sNDyAhICEgAyAPayILaiIDIBVqTwRAIAggAyAVEAoaDAILIAsgFWohFSAIIANBACALaxAKIAtrIQggDyEDCyANQRBPBEAgAykAACFLIAggAykACDcACCAIIEs3AAAgFUERSA0BIAggFWohCyAIQRBqIQgDQCADKQAQIUsgCCADKQAYNwAIIAggSzcAACADKQAgIUsgCCADKQAoNwAYIAggSzcAECADQSBqIQMgCEEgaiIIIAtJDQALDAELAkAgDUEHTQRAIAggAy0AADoAACAIIAMtAAE6AAEgCCADLQACOgACIAggAy0AAzoAAyAIIAMgDUECdCILQeDPAGooAgBqIgMoAAA2AAQgAyALQYDQAGooAgBrIQMMAQsgCCADKQAANwAACyAVQQlJDQAgCCAVaiENIAhBCGoiCyADQQhqIgNrQQ9MBEADQCALIAMpAAA3AAAgA0EIaiEDIAtBCGoiCyANSQ0ADAILAAsgAykAACFLIAsgAykACDcACCALIEs3AAAgFUEZSA0AIAhBGGohCANAIAMpABAhSyAIIAMpABg3AAggCCBLNwAAIAMpACAhSyAIIAMpACg3ABggCCBLNwAQIANBIGohAyAIQSBqIgggDUkNAAsLIApBiH9LBEAgCiEEDA4LIBggEDYCCCAYIA42AgQgGCAUNgIAICQhFwwDCyANQSBrIQgCQAJAIA0gF0sNACAMIBgoAgQiFiADaiIKaiAISw0AIApBIGogJSAMa00NAQsgCSAYKAIINgKQASAJIBgpAgA3A4gBIAwgJSAIIAlBiAFqIAlBzAJqIBcgDyAnICEQciEKDAILIAMgDGohCCAYKAIIIRMgCykAACFLIAwgCykACDcACCAM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SyAMIBMpABg3ABggDCBLNwAQIAhBEGtBEUgNACATQRBqIQMgDEEgaiEIA0AgAykAECFLIAggAykAGDcACCAIIEs3AAAgAykAICFLIAggAykAKDcAGCAIIEs3ABAgA0EgaiEDIAhBIGoiCCAKSQ0ACwsgCiANayEDIAkgCzYCzAIgCiAPayANSQRAIA0gCiAna0sNDSAhICEgAyAPayIIaiIDIBVqTwRAIAogAyAVEAoaDAMLIAggFWohFSAKIANBACAIaxAKIAhrIQogDyEDCyANQRBPBEAgAykAACFLIAogAykACDcACCAKIEs3AAAgFUERSA0CIAogFWohCyAKQRBqIQgDQCADKQAQIUsgCCADKQAYNwAIIAggSzcAACADKQAgIUsgCCADKQAoNwAYIAggSzcAECADQSBqIQMgCEEgaiIIIAtJDQALDAILAkAgDUEHTQRAIAogAy0AADoAACAKIAMtAAE6AAEgCiADLQACOgACIAogAy0AAzoAAyAKIAMgDUECdCIIQeDPAGooAgBqIgMoAAA2AAQgAyAIQYDQAGooAgBrIQMMAQsgCiADKQAANwAACyAVQQlJDQEgCiAVaiELIApBCGoiCCADQQhqIgNrQQ9MBEADQCAIIAMpAAA3AAAgA0EIaiEDIAhBCGoiCCALSQ0ADAMLAAsgAykAACFLIAggAykACDcACCAIIEs3AAAgFUEZSA0BIApBGGohCANAIAMpABAhSyAIIAMpABg3AAggCCBLNwAAIAMpACAhSyAIIAMpACg3ABggCCBLNwAQIANBIGohAyAIQSBqIgggC0kNAAsMAQsCQAJAIAkoAswCIgogDSgCACIDaiILIBdLDQAgDCANKAIEIhAgA2oiDmogHUsNACAOQSBqICUgDGtNDQELIAkgDSgCCDYCcCAJIA0pAgA3A2ggDCAlIAlB6ABqIAlBzAJqIBcgDyAnICEQGiEODAELIAMgDGohCCANKAIIIQ0gCikAACFLIAwgCikACDcACCAMIEs3AAACQCADQRFJDQAgCikAECFLIAwgCikAGDcAGCAMIEs3ABAgA0EQa0ERSA0AIApBEGohAyAMQSBqIQoDQCADKQAQIUsgCiADKQAYNwAIIAogSzcAACADKQAgIUsgCiADKQAoNwAYIAogSzcAECADQSBqIQMgCkEgaiIKIAhJDQALCyAI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a0EPTARAA0AgCCADKQAANwAAIANBCGohAyAIQQhqIgggDUkNAAwCCwALIAMpAAAhSyAIIAMpAAg3AAggCCBLNwAAIAxBGUgNACAKQRhqIQgDQCADKQAQIUsgCCADKQAYNwAIIAggSzcAACADKQAgIUsgCCADKQAoNwAYIAggSzcAECADQSBqIQMgCEEgaiIIIA1JDQALCyAEQYh/Sw0MIBFBAWshESAEIAtqIQsMAQsLIBFBAEwNCCADIA5HBEBBun8hBCADIA5rIgMgICALa0sNCyALIA4gAxBZIAMgC2ohCyAIIANrIQgLIAkgAEGI7AFqIgM2AswCIABBADYChOwBIABBiOwFaiEWIAkgCDYCqAEgCSAMNgKsASAJIBA2ArABAkACQAJAIAhBgIAESg0AIAsgCCAMaiIEaiAgQSBrSw0AIARBIGogICALa00NAQsgCSAJKAKwATYCMCAJIAkpA6gBNwMoIAsgICAJQShqIAlBzAJqIBYgDyAjIBoQGiEEDAELIAMgCGohDSAIIAtqIQogAykAACFLIAsgAykACDcACCALIEs3AAACQCAIQRFJDQAgACkAmOwBIUsgCyAAQaDsAWopAAA3ABggCyBLNwAQIAhBEGtBEUgNACAAQZjsAWohAyALQSBqIQgDQCADKQAQIUsgCCADKQAYNwAIIAggSzcAACADKQAgIUsgCCADKQAoNwAYIAggSzcAECADQSBqIQMgCEEgaiIIIApJDQALCyAKIBBrIQMgCSANNgLMAiAKIA9rIBBJBEAgECAKICNrSw0KIBogGiADIA9rIghqIgMgDGpPBEAgCiADIAwQChoMAgsgCiADQQAgCGsQCiAJIAggDGoiDDYCrAEgCGshCiAPIQMLIBBBEE8EQCADKQAAIUsgCiADKQAINwAIIAogSzcAACAMQRFIDQEgCiAMaiENIApBEGohCANAIAMpABAhSyAIIAMpABg3AAggCCBLNwAAIAMpACAhSyAIIAMpACg3ABggCCBLNwAQIANBIGohAyAIQSBqIgggDUkNAAsMAQsCQCAQQQdNBEAgCiADLQAAOgAAIAogAy0AAToAASAKIAMtAAI6AAIgCiADLQADOgADIAogAyAQQQJ0IghB4M8AaigCAGoiAygAADYABCADIAhBgNAAaigCAGshAwwBCyAKIAMpAAA3AAALIAko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ayIDNgLoASAJIAMoAAA2AuABDAELIAMgCSgC7AEiDkYNACAJIAQgAyAOayAEQQN2IgQgAyAEayAOSRsiBEEDdGs2AuQBIAkgAyAEayIDNgLoASAJIAMoAAA2AuABCyAJIAg2AqgBIAkgETYCrAEgCSAKNgKwAQJAAkACQCAJKALMAiIDIAhqIg4gFksNACALIAggEWoiBGogFUsNACAEQSBqICAgC2tNDQELIAkgCSgCsAE2AiAgCSAJKQOoATcDGCALICAgCUEYaiAJQcwCaiAWIA8gIyAaEBohBAwBCyAIIAtqIQwgAykAACFLIAsgAykACDcACCALIEs3AAACQCAIQRFJDQAgAykAECFLIAsgAykAGDcAGCALIEs3ABAgCEEQa0ERSA0AIANBEGohAyALQSBqIQgDQCADKQAQIUsgCCADKQAYNwAIIAggSzcAACADKQAgIUsgCCADKQAoNwAYIAggSzcAECADQSBqIQMgCEEgaiIIIAxJDQALCyAMIAprIQMgCSAONgLMAiAMIA9rIApJBEAgCiAMICNrSw0LIBogGiADIA9rIg5qIgMgEWpPBEAgDCADIBEQChoMAgsgDCADQQAgDmsQCiAJIA4gEWoiETYCrAEgDmshDCAPIQMLIApBEE8EQCADKQAAIUsgDCADKQAINwAIIAwgSzcAACARQRFIDQEgDCARaiEKIAxBEGohCANAIAMpABAhSyAIIAMpABg3AAggCCBLNwAAIAMpACAhSyAIIAMpACg3ABggCCBLNwAQIANBIGohAyAIQSBqIgggCkkNAAsMAQsCQCAKQQdNBEAgDCADLQAAOgAAIAwgAy0AAToAASAMIAMtAAI6AAIgDCADLQADOgADIAwgAyAKQQJ0IghB4M8AaigCAGoiAygAADYABCADIAhBgNAAaigCAGshAwwBCyAMIAMpAAA3AAALIAkoAqwBIg5BCUkNACAMIA5qIQogDEEIaiIIIANBCGoiA2tBD0wEQANAIAggAykAADcAACADQQhqIQMgCEEIaiIIIApJDQAMAgsACyADKQAAIUsgCCADKQAINwAIIAggSzcAACAOQRlIDQAgDEEYaiEIA0AgAykAECFLIAggAykAGDcACCAIIEs3AAAgAykAICFLIAggAykAKDcAGCAIIEs3ABAgA0EgaiEDIAhBIGoiCCAKSQ0ACwsg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AWoiB0H//wNLDQEMAgsCQAJAIAcgDkkNACAHIAtqIgcpAAAgIlINACAAQQhqIAdBCGogChAGQQhqIQUgACAHayEIA0AgACADTSAHIA9Ncg0CIABBAWsiBi0AACAHQQFrIgctAABHDQIgBUEBaiEFIAYhAAwACwALAkAgCSAUc0H/AXENACAJQQh2IgcgGU0NACAHIBJqIgkpAAAgIlINACAAQQhqIAlBCGogCiATIA8QBUEIaiEFIAwgByAWamshCANAIAkgGk0gACADTXINAiAAQQFrIgYtAAAgCUEBayIJLQAARw0CIAVBAWohBSAGIQAMAAsACwJAAkACQCAIIA5LBEAgCCALaiIHKAAAIAAoAABHDQEMAwsgDSAec0H/AXENACANQQh2IgggGU0NACAIIBJqIgcoAAAgACgAAEYNAQsgACAAIANrQQh1akEBaiEADAULIAggFmohCAsgFSAAKQABIiJC48iVvcub741PfiImICSIp0ECdGoiBigCACEFIBwgJiAliKciFEEGdkH8//8fcWooAgAhDSAGIBE2AgAgAEEBaiEGAkACQCAFIA5JDQAgBSALaiIJKQAAICJSDQAgAEEJaiAJQQhqIAoQBkEIaiEFIAYgCWshCANAIAkgD00gAyAGT3INAiAGQQFrIgAtAAAgCUEBayIJLQAARw0CIAVBAWohBSAAIQYMAAsACwJAIA0gFHNB/wFxDQAgDUEIdiINIBlNDQAgDSASaiIJKQAAICJSDQAgAEEJaiAJQQhqIAogEyAPEAVBCGohBSARIA0gFmprIQgDQCAJIBpNIAMgBk9yDQIgBkEBayIALQAAIAlBAWsiCS0AAEcNAiAFQQFqIQUgACEGDAALAAsgB0EEaiEGIABBBGohBSAIIA5JBEAgBSAGIAogEyAPEAVBBGohBSAMIAhrIQgDQCAAIANNIAcgGk1yDQMgAEEBayIGLQAAIAdBAWsiBy0AAEcNAyAFQQFqIQUgBiEADAALAAsgBSAGIAoQBkEEaiEFIAAgB2shCANAIAAgA00gByAPTXINAiAAQQFrIgYtAAAgB0EBayIHLQAARw0CIAVBAWohBSAGIQAMAAsACyAGIQALIAAgA2shBwJAIAAgEE0EQCADKQAAISIgASgCDCIGIAMpAAg3AAggBiAiNwAAIAdBEUkNASADKQAQISIgASgCDCIGIAMpABg3ABggBiAiNwAQIAdBIUgNASADQRBqIQMgBiAHaiEJIAZBIGohBgNAIAMpABAhIiAGIAMpABg3AAggBiAiNwAAIAMpACAhIiAGIAMpACg3ABggBiAiNwAQIANBIGohAyAGQSBqIgYgCUkNAAsMAQsgASgCDCADIAMgB2ogEBAHCyABIAEoAgwgB2o2AgwgASgCBCEDIAdBgIAETwRAIAFBATYCJCABIAMgASgCAGtBA3U2AigLIAMgCEEDajYCACADIAc7AQQgBCEGIAghBCAFQQNrIgdBgIAESQ0BCyABQQI2AiQgASADIAEoAgBrQQN1NgIoCyADIAc7AQYgASADQQhqNgIEIAAgBWoiAyEAIAMgGEsNACAVIAsgDEECaiIAaikAACIiQuPIlb3Lm++NT34gJIinQQJ0aiAANgIAIBUgA0ECayIIKQAAQuPIlb3Lm++NT34gJIinQQJ0aiAIIAtrNgIAIBcgIkKAxpX9y5vvjU9+ICOIp0ECdGogADYCACAXIANBAWsiACkAAEKAxpX9y5vvjU9+ICOIp0ECdGogACALazYCAANAAkAgBiEAIAMgGEsNACAdIAsgAyALayIIIABrIgYgDkkiBxsgBmohBSAGIA5rQXxLDQAgBSgAACADKAAARw0AIANBBGogBUEEaiAKIBMgCiAHGyAPEAUhBSABKAIMIQYCQCADIBBNBEAgAykAACEiIAYgAykACDcACCAGICI3AAAMAQsgBiADIAMgEBAHCyABKAIEIgZBATYCACAGQQA7AQQgBUEBaiIHQYCABE8EQCABQQI2AiQgASAGIAEoAgBrQQN1NgIoCyAGIAc7AQYgASAGQQhqNgIEIBcgAykAACIiQoDGlf3Lm++NT34gI4inQQJ0aiAINgIAIBUgIkLjyJW9y5vvjU9+ICSIp0ECdGogCDYCACADIAVqQQRqIQMgBCEGIAAhBAwBCwsgACEGIAMhAAwACwALAkAgDUUNAEEEIAV0IQdBACEAA0AgACAHTwRAQQQgCHQhB0EAIQADQCAAIAdPDQMgAEFAayEADAALAAUgAEFAayEADAELAAsACyAQIBJqIR0gCkEgayEQIAMgCSAMRmohAEE4IAhrrSEnQTggBWutISVBwAAgEWutISNBwAAgFGutISQDQCAAIBhPDQMgFSAAKQAAIiJC48iVvcub741PfiImICSIp0ECdGoiBSgCACEHIBcgIkKAgOz8y5vvjU9+IiggI4inQQJ0aiIMKAIAIQggHCAmICWIpyIUQQZ2Qfz//x9xaigCACEJIB8gKCAniKciHkEGdkH8//8fcWooAgAhDSAMIAAgC2siDDYCACAFIAw2AgACQAJAAkAgDEEBaiIRIARrIgUgDmtBfEsNACASIAUgFmtqIAUgC2ogBSAOSSIFGyIbKAAAIAAoAAFHDQAgAEEFaiAbQQRqIAogEyAKIAUbIA8QBSEHIABBAWoiACADayEIAkAgACAQTQRAIAMpAAAhIiABKAIMIgUgAykACDcACCAFICI3AAAgCEERSQ0BIAMpABAhIiABKAIMIgUgAykAGDcAGCAFICI3ABAgCEEhSA0BIANBEGohAyAFIAhqIQkgBUEgaiEFA0AgAykAECEiIAUgAykAGDcACCAFICI3AAAgAykAICEiIAUgAykAKDcAGCAFICI3ABAgA0EgaiEDIAVBIGoiBSAJSQ0ACwwBCyABKAIMIAMgAyAIaiAQEAcLIAEgASgCDCAIajYCDCABKAIEIQMgCEGAgARPBEAgAUEBNgIkIAEgAyABKAIAa0EDdTYCKAsgB0EEaiEFIANBATYCACADIAg7AQQgB0EBaiIHQf//A0sNAQwCCwJAAkAgByAOSQ0AIAcgC2oiBykAACAiUg0AIABBCGogB0EIaiAKEAZBCGohBSAAIAdrIQgDQCAAIANNIAcgD01yDQIgAEEBayIGLQAAIAdBAWsiBy0AAEcNAiAFQQFqIQUgBiEADAALAAsCQCAJIBRzQf8BcQ0AIAlBCHYiByAZTQ0AIAcgEmoiCSkAACAiUg0AIABBCGogCUEIaiAKIBMgDxAFQQhqIQUgDCAHIBZqayEIA0AgCSAaTSAAIANNcg0CIABBAWsiBi0AACAJQQFrIgktAABHDQIgBUEBaiEFIAYhAAwACwALAkACQAJAIAggDksEQCAIIAtqIgcoAAAgACgAAEcNAQwDCyANIB5zQf8BcQ0AIA1BCHYiCCAZTQ0AIAggEmoiBygAACAAKAAARg0BCyAAIAAgA2tBCHVqQQFqIQAMBQsgCCAWaiEICyAVIAApAAEiIkLjyJW9y5vvjU9+IiYgJIinQQJ0aiIGKAIAIQUgHCAmICWIpyIUQQZ2Qfz//x9xaigCACENIAYgETYCACAAQQFqIQYCQAJAIAUgDkkNACAFIAtqIgkpAAAgIlINACAAQQlqIAlBCGogChAGQQhqIQUgBiAJayEIA0AgCSAPTSADIAZPcg0CIAZBAWsiAC0AACAJQQFrIgktAABHDQIgBUEBaiEFIAAhBgwACwALAkAgDSAUc0H/AXENACANQQh2Ig0gGU0NACANIBJqIgkpAAAgIlINACAAQQlqIAlBCGogCiATIA8QBUEIaiEFIBEgDSAWamshCANAIAkgGk0gAyAGT3INAiAGQQFrIgAtAAAgCUEBayIJLQAARw0CIAVBAWohBSAAIQYMAAsACyAHQQRqIQYgAEEEaiEFIAggDkkEQCAFIAYgCiATIA8QBUEEaiEFIAwgCGshCANAIAAgA00gByAaTXINAyAAQQFrIgYtAAAgB0EBayIHLQAARw0DIAVBAWohBSAGIQAMAAsACyAFIAYgChAGQQRqIQUgACAHayEIA0AgACADTSAHIA9Ncg0CIABBAWsiBi0AACAHQQFrIgctAABHDQIgBUEBaiEFIAYhAAwACwALIAYhAAsgACADayEHAkAgACAQTQRAIAMpAAAhIiABKAIMIgYgAykACDcACCAGICI3AAAgB0ERSQ0BIAMpABAhIiABKAIMIgYgAykAGDcAGCAGICI3ABAgB0EhSA0BIANBEGohAyAGIAdqIQkgBkEgaiEGA0AgAykAECEiIAYgAykAGDcACCAGICI3AAAgAykAICEiIAYgAykAKDcAGCAGICI3ABAgA0EgaiEDIAZBIGoiBiAJSQ0ACwwBCyABKAIMIAMgAyAHaiAQEAcLIAEgASgCDCAHajYCDCABKAIEIQMgB0GAgARPBEAgAUEBNgIkIAEgAyABKAIAa0EDdTYCKAsgAyAIQQNqNgIAIAMgBzsBBCAEIQYgCCEEIAVBA2siB0GAgARJDQELIAFBAjYCJCABIAMgASgCAGtBA3U2AigLIAMgBzsBBiABIANBCGo2AgQgACAFaiIDIQAgAyAYSw0AIBUgCyAMQQJqIgBqKQAAIiJC48iVvcub741PfiAkiKdBAnRqIAA2AgAgFSADQQJrIggpAABC48iVvcub741PfiAkiKdBAnRqIAggC2s2AgAgFyAiQoCA7PzLm++NT34gI4inQQJ0aiAANgIAIBcgA0EBayIAKQAAQoCA7PzLm++NT34gI4inQQJ0aiAAIAtrNgIAA0ACQCAGIQAgAyAYSw0AIB0gCyADIAtrIgggAGsiBiAOSSIHGyAGaiEFIAYgDmtBfEsNACAFKAAAIAMoAABHDQAgA0EEaiAFQQRqIAogEyAKIAcbIA8QBSEFIAEoAgwhBgJAIAMgEE0EQCADKQAAISIgBiADKQAINwAIIAYgIjcAAAwBCyAGIAMgAyAQEAcLIAEoAgQiBkEBNgIAIAZBADsBBCAFQQFqIgdBgIAETwRAIAFBAjYCJCABIAYgASgCAGtBA3U2AigLIAYgBzsBBiABIAZBCGo2AgQgFyADKQAAIiJCgIDs/Mub741PfiAjiKdBAnRqIAg2AgAgFSAiQuPIlb3Lm++NT34gJIinQQJ0aiAINgIAIAMgBWpBBGohAyAEIQYgACEEDAELCyAAIQYgAyEADAALAAsCQCANRQ0AQQQgBXQhB0EAIQADQCAAIAdPBEBBBCAIdCEHQQAhAANAIAAgB08NAyAAQUBrIQAMAAsABSAAQUBrIQAMAQsACwALIBAgEmohHSAKQSBrIRAgAyAJIAxGaiEAQTggCGutISdBOCAFa60hJUHAACARa60hI0HAACAUa60hJANAIAAgGE8NAiAVIAApAAAiIkLjyJW9y5vvjU9+IiYgJIinQQJ0aiIFKAIAIQcgFyAiQoCAgNjLm++NT34iKCAjiKdBAnRqIgwoAgAhCCAcICYgJYinIhRBBnZB/P//H3FqKAIAIQkgHyAoICeIpyIeQQZ2Qfz//x9xaigCACENIAwgACALayIMNgIAIAUgDDYCAAJAAkACQCAMQQFqIhEgBGsiBSAOa0F8Sw0AIBIgBSAWa2ogBSALaiAFIA5JIgUbIhsoAAAgACgAAUcNACAAQQVqIBtBBGogCiATIAogBRsgDxAFIQcgAEEBaiIAIANrIQgCQCAAIBBNBEAgAykAACEiIAEoAgwiBSADKQAINwAIIAUgIjcAACAIQRFJDQEgAykAECEiIAEoAgwiBSADKQAYNwAYIAUgIjcAECAIQSFIDQEgA0EQaiEDIAUgCGohCSAFQSBqIQUDQCADKQAQISIgBSADKQAYNwAIIAUgIjcAACADKQAgISIgBSADKQAoNwAYIAUgIjcAECADQSBqIQMgBUEgaiIFIAlJDQALDAELIAEoAgwgAyADIAhqIBAQBwsgASABKAIMIAhqNgIMIAEoAgQhAyAIQYCABE8EQCABQQE2AiQgASADIAEoAgBrQQN1NgIoCyAHQQRqIQUgA0EBNgIAIAMgCDsBBCAHQQFqIgdB//8DSw0BDAILAkACQCAHIA5JDQAgByALaiIHKQAAICJSDQAgAEEIaiAHQQhqIAoQBkEIaiEFIAAgB2shCANAIAAgA00gByAPTXINAiAAQQFrIgYtAAAgB0EBayIHLQAARw0CIAVBAWohBSAGIQAMAAsACwJAIAkgFHNB/wFxDQAgCUEIdiIHIBlNDQAgByASaiIJKQAAICJSDQAgAEEIaiAJQQhqIAogEyAPEAVBCGohBSAMIAcgFmprIQgDQCAJIBpNIAAgA01yDQIgAEEBayIGLQAAIAlBAWsiCS0AAEcNAiAFQQFqIQUgBiEADAALAAsCQAJAAkAgCCAOSwRAIAggC2oiBygAACAAKAAARw0BDAMLIA0gHnNB/wFxDQAgDUEIdiIIIBlNDQAgCCASaiIHKAAAIAAoAABGDQELIAAgACADa0EIdWpBAWohAAwFCyAIIBZqIQgLIBUgACkAASIiQuPIlb3Lm++NT34iJiAkiKdBAnRqIgYoAgAhBSAcICYgJYinIhRBBnZB/P//H3FqKAIAIQ0gBiARNgIAIABBAWohBgJAAkAgBSAOSQ0AIAUgC2oiCSkAACAiUg0AIABBCWogCUEIaiAKEAZBCGohBSAGIAlrIQgDQCAJIA9NIAMgBk9yDQIgBkEBayIALQAAIAlBAWsiCS0AAEcNAiAFQQFqIQUgACEGDAALAAsCQCANIBRzQf8BcQ0AIA1BCHYiDSAZTQ0AIA0gEmoiCSkAACAiUg0AIABBCWogCUEIaiAKIBMgDxAFQQhqIQUgESANIBZqayEIA0AgCSAaTSADIAZPcg0CIAZBAWsiAC0AACAJQQFrIgktAABHDQIgBUEBaiEFIAAhBgwACwALIAdBBGohBiAAQQRqIQUgCCAOSQRAIAUgBiAKIBMgDxAFQQRqIQUgDCAIayEIA0AgACADTSAHIBpNcg0DIABBAWsiBi0AACAHQQFrIgctAABHDQMgBUEBaiEFIAYhAAwACwALIAUgBiAKEAZBBGohBSAAIAdrIQgDQCAAIANNIAcgD01yDQIgAEEBayIGLQAAIAdBAWsiBy0AAEcNAiAFQQFqIQUgBiEADAALAAsgBiEACyAAIANrIQcCQCAAIBBNBEAgAykAACEiIAEoAgwiBiADKQAINwAIIAYgIjcAACAHQRFJDQEgAykAECEiIAEoAgwiBiADKQAYNwAYIAYgIjcAECAHQSFIDQEgA0EQaiEDIAYgB2ohCSAGQSBqIQYDQCADKQAQISIgBiADKQAYNwAIIAYgIjcAACADKQAgISIgBiADKQAoNwAYIAYgIjcAECADQSBqIQMgBkEgaiIGIAlJDQALDAELIAEoAgwgAyADIAdqIBAQBwsgASABKAIMIAdqNgIMIAEoAgQhAyAHQYCABE8EQCABQQE2AiQgASADIAEoAgBrQQN1NgIoCyADIAhBA2o2AgAgAyAHOwEEIAQhBiAIIQQgBUEDayIHQYCABEkNAQsgAUECNgIkIAEgAyABKAIAa0EDdTYCKAsgAyAHOwEGIAEgA0EIajYCBCAAIAVqIgMhACADIBhLDQAgFSALIAxBAmoiAGopAAAiIkLjyJW9y5vvjU9+ICSIp0ECdGogADYCACAVIANBAmsiCCkAAELjyJW9y5vvjU9+ICSIp0ECdGogCCALazYCACAXICJCgICA2Mub741PfiAjiKdBAnRqIAA2AgAgFyADQQFrIgApAABCgICA2Mub741PfiAjiKdBAnRqIAAgC2s2AgADQAJAIAYhACADIBhLDQAgHSALIAMgC2siCCAAayIGIA5JIgcbIAZqIQUgBiAOa0F8Sw0AIAUoAAAgAygAAEcNACADQQRqIAVBBGogCiATIAogBxsgDxAFIQUgASgCDCEGAkAgAyAQTQRAIAMpAAAhIiAGIAMpAAg3AAggBiAiNwAADAELIAYgAyADIBAQBwsgASgCBCIGQQE2AgAgBkEAOwEEIAVBAWoiB0GAgARPBEAgAUECNgIkIAEgBiABKAIAa0EDdTYCKAsgBiAHOwEGIAEgBkEIajYCBCAXIAMpAAAiIkKAgIDYy5vvjU9+ICOIp0ECdGogCDYCACAVICJC48iVvcub741PfiAkiKdBAnRqIAg2AgAgAyAFakEEaiEDIAQhBiAAIQQMAQsLIAAhBiADIQAMAAsACyAQIBJqIR0gCkEgayEQQRggCGshHkEgIBFrIQ0gAyAJIAxGaiEAQTggBWutISJBwAAgFGutISQDQCAAIBhPDQEgFSAAKQAAIiNC48iVvcub741PfiIlICSIp0ECdGoiBSgCACEHIBcgI6dBsfPd8XlsIgwgDXZBAnRqIhQoAgAhCCAcICUgIoinIhtBBnZB/P//H3FqKAIAIQkgHyAMIB52IiBBBnZB/P//H3FqKAIAIREgFCAAIAtrIgw2AgAgBSAMNgIAAkACQAJAIAxBAWoiFCAEayIFIA5rQXxLDQAgEiAFIBZraiAFIAtqIAUgDkkiBRsiISgAACAAKAABRw0AIABBBWogIUEEaiAKIBMgCiAFGyAPEAUhByAAQQFqIgAgA2shCAJAIAAgEE0EQCADKQAAISMgASgCDCIFIAMpAAg3AAggBSAjNwAAIAhBEUkNASADKQAQISMgASgCDCIFIAMpABg3ABggBSAjNwAQIAhBIUgNASADQRBqIQMgBSAIaiEJIAVBIGohBQNAIAMpABAhIyAFIAMpABg3AAggBSAjNwAAIAMpACAhIyAFIAMpACg3ABggBSAjNwAQIANBIGohAyAFQSBqIgUgCUkNAAsMAQsgASgCDCADIAMgCGogEBAHCyABIAEoAgwgCGo2AgwgASgCBCEDIAhBgIAETwRAIAFBATYCJCABIAMgASgCAGtBA3U2AigLIAdBBGohBSADQQE2AgAgAyAIOwEEIAdBAWoiB0H//wNLDQEMAgsCQAJAIAcgDkkNACAHIAtqIgcpAAAgI1INACAAQQhqIAdBCGogChAGQQhqIQUgACAHayEIA0AgACADTSAHIA9Ncg0CIABBAWsiBi0AACAHQQFrIgctAABHDQIgBUEBaiEFIAYhAAwACwALAkAgCSAbc0H/AXENACAJQQh2IgcgGU0NACAHIBJqIgkpAAAgI1INACAAQQhqIAlBCGogCiATIA8QBUEIaiEFIAwgByAWamshCANAIAkgGk0gACADTXINAiAAQQFrIgYtAAAgCUEBayIJLQAARw0CIAVBAWohBSAGIQAMAAsACwJAAkACQCAIIA5LBEAgCCALaiIHKAAAIAAoAABHDQEMAwsgESAgc0H/AXENACARQQh2IgggGU0NACAIIBJqIgcoAAAgACgAAEYNAQsgACAAIANrQQh1akEBaiEADAULIAggFmohCAsgFSAAKQABIiNC48iVvcub741PfiIlICSIp0ECdGoiBigCACEFIBwgJSAiiKciG0EGdkH8//8fcWoo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A0EQaiEDIAUgB2ohCCAHQSBqIQcDQCADKQAQISIgByADKQAYNwAIIAcgIjcAACADKQAgISIgByADKQAoNwAYIAcgIjcAECADQSBqIQMgB0EgaiIHIAhJDQALDAELIAEoAgwgAyADIAVqIAsQBwsgASABKAIMIAVqNgIMIAEoAgQhAyAFQYCABE8EQCABQQE2AiQgASADIAEoAgBrQQN1NgIoCyAJQQRqIQcgA0EBNgIAIAMgBTsBBCAJQQFqIghB//8DTQ0DDAELAkAgCkH/AXEEQCAAKAAAIQUMAQsgACgAACEFIBhBCHYiGCAeTQ0AIBYgGGoiCigAACAFRyAOIBFJcg0AIABBBGogCkEEaiAMIBcgExAFQQRqIQcDQAJAIAAgA00gCiAaTXINACAAQQFrIgYtAAAgCkEBayIKLQAARw0AIAdBAWohByAGIQAMAQsLIAAgA2shBgJAIAAgC00EQCADKQAAISIgASgCDCIFIAMpAAg3AAggBSAiNwAAIAZBEUkNASADKQAQISIgASgCDCIFIAMpABg3ABggBSAiNwAQIAZBIUgNASADQRBqIQMgBSAGaiEJIAVBIGohCANAIAMpABAhIiAIIAMpABg3AAggCCAiNwAAIAMpACAhIiAIIAMpACg3ABggCCAiNwAQIANBIGohAyAIQSBqIgggCUkNAAsMAQsgASgCDCADIAMgBmogCxAHCyABIAEoAgwgBmo2AgwgASgCBCEDIAZBgIAETwRAIAFBATYCJCABIAMgASgCAGtBA3U2AigLIAMgFSAYIBtqayIFQQNqNgIAIAMgBjsBBCAEIQYgBSEEIAdBA2siCEH//wNLDQEMAwsgBUH6PCANIBFqIgggDiARSyIKGygAAEcgCnJFBEAgAEEEaiAIQQRqIAwQBkEEaiEHIAAgCGshBQNAAkAgACADTSAIIBNNcg0AIABBAWsiBi0AACAIQQFrIggtAABHDQAgB0EBaiEHIAYhAAwBCwsgACADayEGAkAgACALTQRAIAMpAAAhIiABKAIMIgkgAykACDcACCAJICI3AAAgBkERSQ0BIAMpABAhIiABKAIMIgkgAykAGDcAGCAJICI3ABAgBkEhSA0BIANBEGohAyAGIAlqIQogCUEgaiEIA0AgAykAECEiIAggAykAGDcACCAIICI3AAAgAykAICEiIAggAykA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IARBABBWGiABQQA2AiQgASABKAIANgIEIAEgASgCCDYCDCAAIAAoAgwgBGoiBjYCDCAAIAY2AhwgACAGNgIQIAAgACgCBCAEazYCBAsgACABIAIgAyAEQQAQViAFQRBqJAALEAAgACABIAIgAyAEQQAQVgshACAAIAEgAiADIAQgBSAGIAdCgIDs/Mub741PQQYQuwELIQAgACABIAIgAyAEIAUgBiAHQoCAgNjLm++NT0EFELsBC/8JASN/IwBBEGsiEiQAAkAgAyABKAIEIgkgASgCHCICakkNACADIAlrIQgDQCACIAhPRQRAIAEgAiAJaiAEIAhBBEEAEBAgAmohAgwBCwsgASAINgIcQQEgASgCECICIAMgASgCBCITayILQQEgASgCuAF0IghrIAIgCyACayAISxsgASgCGBsiFCAUQQFNGyEgIAtBfyABKAK8AUEBa3RBf3MiGWsiAkEAIAIgC00bIRogASgCXCADKAAAQbHz3fF5bEEgIAEoAsABa3ZBAnRqIiEoAgAhCiABKAK0ASIQKAIAIhsgECgCBCIcayIVQX8gECgCvAFBAWt0QX9zIh1rIBAoAhAiFiAVIBZrIB1LGyEiIBwgFCAVayIXayEjIAsgFiAXamshJCAGIAZBA2oiAiACIAZJGyElIAEoAmQiJiALIBlxQQN0aiIRQQRqIQ1B/x8gASgCzAEiAiACQf8fTxshJyADQQRqIRggB0EBayEIIBMgASgCDCIeaiEfIAsgHmshKCALQQlqIQ5BASABKALEAXQhDyAQKALAASEpIAYhAgNAIAIgJUcEQCALAn8gAkEDRgRAIAUoAgBBAWsMAQsgBSACQQJ0aigCAAsiCWshBwJAAn8gKCAJQQFrIipLBEAgByAUSQ0CIAMoAAAgAyAJaygAAEcNAiAYIBggCWsgBBAGDAELICQgKk0gByAea0F8S3INASADKAAAIAcgI2oiBygAAEcNASAYIAdBBGogBCAbIB8QBQtBBGoiByAITQ0AIAAgDEEDdGoiCCAHNgIEIAggAiAGa0EBajYCACAMQQFqIQwgByAnSw0DIAciCCADaiAERg0DCyACQQFqIQIMAQsLICEgCzYCACALQQNqIQZBACEHQQAhBQJAAkACQAJAAkADQCAPRSAKICBJcg0CIAggAyAFIAcgBSAHSRsiAmogCiATaiILIAJqIAQQBiACaiICSQRAIAAgDEEDdGoiCCACNgIEIAggBiAKazYCACACIApqIA4gAiAOIAprSxshDiAMQQFqIQwgAiADaiAERiACQYAgS3INBSACIQgLICYgCiAZcUEDdGohCQJAAkACQCACIAtqLQAAIAIgA2otAABJBEAgESAKNgIAIAogGksNASASQQxqIREMBQsgDSAKNgIAIAogGk0NAiAJIQ0gAiEHDAELIAIhBSAJQQRqIhEhCQsgD0EBayEPIAkoAgAhCgwBCwsgEkEMaiENCyANQQA2AgAgEUEANgIADAELIA1BADYCACARQQA2AgAgD0UNAgsgECgCXCADKAAAQbHz3fF5bEEgIClrdkECdGohAiATIBdqIQ0gECgCZCELQQAhCkEAIQcDQCAPRQ0CIAIoAgAiBSAWTQ0CIAggAyAHIAogByAKSRsiAmogBSAcaiIJIAJqIAQgGyAfEAUgAmoiAkkEQCAAIAxBA3RqIgggAjYCBCAIIAYgBSAXaiIIazYCACACIAhqIA4gAiAOIAhrSxshDiAMQQFqIQwgAkGAIEsNAyACIQggAiADaiAERg0DCyAFICJNDQIgD0EBayEPIAIgByAJIAUgDWogAiAFaiAVSRsgAmotAAAgAiADai0AAEkiCRshByAKIAIgCRshCiALIAUgHXFBA3RqIAlBAnRqIQIMAAsACyANQQA2AgAgEUEANgIACyABIA5BCGs2AhwLIBJBEGokACAMC/wKASR/IwBBEGsiFCQAAkAgAyABKAIEIgwgASgCHCIJakkNACADIAxrIQgDQCAIIAlNRQRAIAEgCSAMaiAEIAhBA0EAEBAgCWohCQwBCwsgASAINgIcQQEgASgCECIIIAMgASgCBCITayINQQEgASgCuAF0IglrIAggDSAIayAJSxsgASgCGBsiFSAVQQFNGyEaIA1BfyABKAK8AUEBa3RBf3MiG2siCEEAIAggDU0bIRwgASgCXCADKAAAQbHz3fF5bEEgIAEoAsABa3ZBAnRqIiMoAgAhCiABKAK0ASIRKAIAIh0gESgCBCIeayIWQX8gESgCvAFBAWt0QX9zIh9rIBEoAhAiFyAWIBdrIB9LGyEkIB4gFSAWayIYayElIA0gFyAYamshJiAGIAZBA2oiCCAGIAhLGyEnIAEoAmQiKCANIBtxQQN0aiISQQRqIQ5B/x8gASgCzAEiCCAIQf8fTxshICADQQNqIRkgB0EBayEIIBMgASgCDCIhaiEiIA0gIWshKSANQQlqIQ9BASABKALEAXQhECARKALAASEqIAYhCQNAIAkgJ0cEQCANAn8gCUEDRgRAIAUoAgBBAWsMAQsgBSAJQQJ0aigCAAsiDGshBwJAAn8gKSAMQQFrIitLBEAgByAVSQ0CIAMgDGsoAAAgAygAAHNB////B3ENAiAZIBkgDGsgBBAGDAELICYgK00gByAha0F8S3INASAHICVqIgcoAAAgAygAAHNB////B3ENASAZIAdBA2ogBCAdICIQBQtBA2oiByAITQ0AIAAgC0EDdGoiCCAHNgIEIAggCSAGa0EBajYCACALQQFqIQsgByAgSw0DIAciCCADaiAERg0DCyAJQQFqIQkMAQsLIAECfwJAIAhBAksNACABIAIgAxCOASICIBpJDQAgDSACayIFQf//D0sNACADIAIgE2ogBBAGIgJBA0kNACAAIAI2AgQgACAFQQNqNgIAIAIgIE0EQEEBIQsgAiIIIANqIARHDQELQQEhCyANQQFqDAELICMgDTYCACANQQNqIQZBACEHQQAhBQJAAkACQAJAAkADQCAQRSAKIBpJcg0CIAggAyAFIAcgBSAHSRsiAmogCiATaiIJIAJqIAQQBiACaiICSQRAIAAgC0EDdGoiCCACNgIEIAggBiAKazYCACACIApqIA8gAiAPIAprSxshDyALQQFqIQsgAiADaiAERiACQYAgS3INBSACIQgLICggCiAbcUEDdGohDAJAAkACQCACIAlqLQAAIAIgA2otAABJBEAgEiAKNgIAIAogHEsNASAUQQxqIRIMBQsgDiAKNgIAIAogHE0NAiAMIQ4gAiEHDAELIAIhBSAMQQRqIhIhDAsgEEEBayEQIAwoAgAhCgwBCwsgFEEMaiEOCyAOQQA2AgAgEkEANgIADAELIA5BADYCACASQQA2AgAgEEUNAgsgESgCXCADKAAAQbHz3fF5bEEgICprdkECdGohCSATIBhqIQwgESgCZCEOQQAhCkEAIQcDQCAQRQ0CIAkoAgAiBSAXTQ0CIAggAyAHIAogByAKSRsiAmogBSAeaiIJIAJqIAQgHSAiEAUgAmoiAkkEQCAAIAtBA3RqIgggAjYCBCAIIAYgBSAYaiIIazYC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Bg8AAAAAAAAGEgAAAAAAAAYVAAAAAAAABhgAAAAAAAAGGwAAAAAAAAYeAAAAAAAABiEAAAAAAAEGIwAAAAAAAQYnAAAAAAACBisAAAAAAAMGMwAAAAAABAZDAAAAAAAFBmMAAAAAAAgGAwEAACAAAAQEAAAAMAAABAQAAAAQAAAEBQAAACAAAAUHAAAAIAAABQgAAAAgAAAFCgAAACAAAAULAAAAAAAABg4AAAAAAAAGEQAAAAAAAAYUAAAAAAAABhcAAAAAAAAGGgAAAAAAAAYdAAAAAAAABiAAAAAAABAGAwABAAAADwYDgAAAAAAOBgNAAAAAAA0GAyAAAAAADAYDEAAAAAALBgMIAAAAAAoGAwQAQbQjC3wBAAAAAwAAAAcAAAAPAAAAHwAAAD8AAAB/AAAA/wAAAP8BAAD/AwAA/wcAAP8PAAD/HwAA/z8AAP9/AAD//wAA//8BAP//AwD//wcA//8PAP//HwD//z8A//9/AP///wD///8B////A////wf///8P////H////z////9/AEHAJAuhAgEAAQABAAEAAQABAAIAAgACAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAP////////////8AAAAAAAAEAAMAAgACAAIAAgACAAIAAgACAAIAAgACAAEAAQABAAIAAgACAAIAAgACAAIAAgACAAMAAgABAAEAAQABAAEA//////////8AAAAAAAAAAAEABAADAAIAAgACAAIAAgACAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEAAQABAAEA//////////////////8AAAAAAAAsAAAALQAAAC4AAAAvAAAACAAAAAkAAAAKAAAACgAAACAAQfEmC+QBAQIDBAUGBwgJCgsMDQ4PEBARERISExMUFBQUFRUVFRYWFhYWFhYWFxcXFxcXFxcYGBgYGBgYGBgYGBgYGBgYAAECAwQFBgcICQoLDA0ODxAREhMUFRYXGBkaGxwdHh8gICEhIiIjIyQkJCQlJSUlJiYmJiYmJiYnJycnJycnJygoKCgoKCgoKCgoKCgoKCgpKSkpKSkpKSkpKSkpKSkpKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioAAAAAAAAAAAEAAAACAAAAAgAAAAMAAAADAAAABAAAAAQAAAAEAEHgKAv9JxMAAAAMAAAADQAAAAEAAAAGAAAAAQAAAAEAAAATAAAADQAAAA4AAAABAAAABwAAAAAAAAABAAAAFAAAAA8AAAAQAAAAAQAAAAYAAAAAAAAAAQAAABUAAAAQAAAAEQAAAAEAAAAFAAAAAAAAAAIAAAAVAAAAEgAAABIAAAABAAAABQAAAAAAAAACAAAAFQAAABIAAAATAAAAAwAAAAUAAAACAAAAAwAAABUAAAASAAAAEwAAAAMAAAAFAAAABAAAAAQAAAAVAAAAEwAAABQAAAAEAAAABQAAAAgAAAAEAAAAFQAAABMAAAAUAAAABAAAAAUAAAAQAAAABQAAABYAAAAUAAAAFQAAAAQAAAAFAAAAEAAAAAUAAAAWAAAAFQAAABYAAAAFAAAABQAAABAAAAAFAAAAFgAAABUAAAAWAAAABgAAAAUAAAAQAAAABQAAABYAAAAWAAAAFwAAAAYAAAAFAAAAIAAAAAUAAAAWAAAAFgAAABYAAAAEAAAABQAAACAAAAAGAAAAFgAAABYAAAAXAAAABQAAAAUAAAAgAAAABgAAABYAAAAXAAAAFwAAAAYAAAAFAAAAIAAAAAYAAAAWAAAAFgAAABYAAAAFAAAABQAAADAAAAAHAAAAFwAAABcAAAAWAAAABQAAAAQAAABAAAAABwAAABcAAAAXAAAAFgAAAAYAAAADAAAAQAAAAAgAAAAXAAAAGAAAABYAAAAHAAAAAwAAAAABAAAJAAAAGQAAABkAAAAXAAAABwAAAAMAAAAAAQAACQAAABoAAAAaAAAAGAAAAAcAAAADAAAAAAIAAAkAAAAbAAAAGwAAABkAAAAJAAAAAwAAAOcDAAAJAAAAEgAAAAwAAAANAAAAAQAAAAUAAAABAAAAAQAAABIAAAANAAAADgAAAAEAAAAGAAAAAAAAAAEAAAASAAAADgAAAA4AAAABAAAABQAAAAAAAAACAAAAEgAAABAAAAAQAAAAAQAAAAQAAAAAAAAAAgAAABIAAAAQAAAAEQAAAAMAAAAFAAAAAgAAAAMAAAASAAAAEQAAABIAAAAFAAAABQAAAAIAAAADAAAAEgAAABIAAAATAAAAAwAAAAUAAAAEAAAABAAAABIAAAASAAAAEwAAAAQAAAAEAAAABAAAAAQAAAASAAAAEgAAABMAAAAEAAAABAAAAAgAAAAFAAAAEgAAABIAAAATAAAABQAAAAQAAAAIAAAABQAAABIAAAASAAAAEwAAAAYAAAAEAAAACAAAAAUAAAASAAAAEgAAABMAAAAFAAAABAAAAAwAAAAGAAAAEgAAABMAAAATAAAABwAAAAQAAAAMAAAABgAAABIAAAASAAAAEwAAAAQAAAAEAAAAEAAAAAcAAAASAAAAEgAAABMAAAAEAAAAAwAAACAAAAAHAAAAEgAAABIAAAATAAAABgAAAAMAAACAAAAABwAAABIAAAATAAAAEwAAAAYAAAADAAAAgAAAAAgAAAASAAAAEwAAABMAAAAIAAAAAwAAAAABAAAIAAAAEgAAABMAAAATAAAABgAAAAMAAACAAAAACQAAABIAAAATAAAAEwAAAAgAAAADAAAAAAEAAAkAAAASAAAAEwAAABMAAAAKAAAAAwAAAAACAAAJAAAAEgAAABMAAAATAAAADAAAAAMAAAAAAgAACQAAABIAAAATAAAAEwAAAA0AAAADAAAA5wMAAAkAAAARAAAADAAAAAwAAAABAAAABQAAAAEAAAABAAAAEQAAAAwAAAANAAAAAQAAAAYAAAAAAAAAAQAAABEAAAANAAAADwAAAAEAAAAFAAAAAAAAAAEAAAARAAAADwAAABAAAAACAAAABQAAAAAAAAACAAAAEQAAABEAAAARAAAAAgAAAAQAAAAAAAAAAgAAABEAAAAQAAAAEQAAAAMAAAAEAAAAAgAAAAMAAAARAAAAEAAAABEAAAADAAAABAAAAAQAAAAEAAAAEQAAABAAAAARAAAAAwAAAAQAAAAIAAAABQAAABEAAAAQAAAAEQAAAAQAAAAEAAAACAAAAAUAAAARAAAAEAAAABEAAAAFAAAABAAAAAgAAAAFAAAAEQAAABAAAAARAAAABgAAAAQAAAAIAAAABQAAABEAAAARAAAAEQAAAAUAAAAEAAAACAAAAAYAAAARAAAAEgAAABEAAAAHAAAABAAAAAwAAAAGAAAAEQAAABIAAAARAAAAAwAAAAQAAAAMAAAABwAAABEAAAASAAAAEQAAAAQAAAADAAAAIAAAAAcAAAARAAAAEgAAABEAAAAGAAAAAwAAAAABAAAHAAAAEQAAABIAAAARAAAABgAAAAMAAACA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`\n\nlet _bytes: Uint8Array | undefined\n\n/** Decode the base64 string to bytes (cached after first call). */\nexport function getZstdWasmBytes(): Uint8Array {\n if (_bytes) return _bytes\n\n const binaryString = atob(ZSTD_WASM_BASE64)\n _bytes = new Uint8Array(binaryString.length)\n for (let i = 0; i < binaryString.length; i++) {\n _bytes[i] = binaryString.charCodeAt(i)\n }\n return _bytes\n}\n","/**\n * First-party zstd WASM decompression module.\n *\n * Directly instantiates the zstd WASM binary (from @bokuweb/zstd-wasm, MIT license)\n * without the Emscripten glue code that breaks webpack bundling.\n *\n * The WASM binary is base64-inlined to avoid bundler issues with\n * `new URL('./zstd.wasm', import.meta.url)` (e.g. Turbopack).\n *\n * Only exposes decompression with dictionary — the minimum needed for GTX.\n */\n\nimport {getZstdWasmBytes} from './zstdWasmInlined'\n\n// ─── WASM memory management ─────────────────────────────────────────────────\n\nlet wasmMemory: WebAssembly.Memory\nlet HEAP8: Int8Array\nlet HEAPU8: Uint8Array\nlet wasmExports: Record<string, CallableFunction>\nlet initialized = false\nlet initPromise: Promise<void> | undefined\n\nfunction updateMemoryViews(): void {\n const b = wasmMemory.buffer\n HEAP8 = new Int8Array(b)\n HEAPU8 = new Uint8Array(b)\n}\n\n// ─── WASM imports (matching the Emscripten-compiled binary's expectations) ──\n\nlet ABORT = false\nlet noExitRuntime = true\n\nfunction abort(what?: string): never {\n const msg = 'Aborted(' + (what ?? '') + ')'\n ABORT = true\n throw new WebAssembly.RuntimeError(msg)\n}\n\nfunction keepRuntimeAlive(): boolean {\n return noExitRuntime\n}\n\nfunction _proc_exit(code: number): void {\n if (!keepRuntimeAlive()) {\n ABORT = true\n }\n}\n\nfunction __abort_js(): never {\n abort('')\n}\n\nfunction __emscripten_runtime_keepalive_clear(): void {\n noExitRuntime = false\n}\n\n// Timer support (required by WASM but unused in practice for decompression)\nconst timers: Record<number, { id: ReturnType<typeof setTimeout>; timeout_ms: number }> = {}\nlet __emscripten_timeout: (which: number, now: number) => void\n\nfunction __setitimer_js(which: number, timeout_ms: number): number {\n if (timers[which]) {\n clearTimeout(timers[which].id)\n delete timers[which]\n }\n if (!timeout_ms) return 0\n const id = setTimeout(() => {\n delete timers[which]\n __emscripten_timeout(which, performance.now())\n }, timeout_ms)\n timers[which] = {id, timeout_ms}\n return 0\n}\n\nfunction alignMemory(size: number, alignment: number): number {\n return Math.ceil(size / alignment) * alignment\n}\n\nfunction _emscripten_resize_heap(requestedSize: number): boolean {\n const oldSize = HEAPU8.length\n requestedSize >>>= 0\n const maxHeapSize = 2147483648\n if (requestedSize > maxHeapSize) return false\n for (let cutDown = 1; cutDown <= 4; cutDown *= 2) {\n let overGrownHeapSize = oldSize * (1 + 0.2 / cutDown)\n overGrownHeapSize = Math.min(overGrownHeapSize, requestedSize + 100663296)\n const newSize = Math.min(maxHeapSize, alignMemory(Math.max(requestedSize, overGrownHeapSize), 65536))\n const pages = ((newSize - wasmMemory.buffer.byteLength + 65535) / 65536) | 0\n try {\n wasmMemory.grow(pages)\n updateMemoryViews()\n return true\n } catch { /* retry with smaller size */ }\n }\n return false\n}\n\n// The WASM binary expects imports keyed by single letters (Emscripten minification):\n// a: _proc_exit\n// b: __emscripten_runtime_keepalive_clear\n// c: __abort_js\n// d: __setitimer_js\n// e: _emscripten_resize_heap\nconst wasmImports = {\n a: _proc_exit,\n b: __emscripten_runtime_keepalive_clear,\n c: __abort_js,\n d: __setitimer_js,\n e: _emscripten_resize_heap,\n}\n\n// ─── Initialization ─────────────────────────────────────────────────────────\n\n/**\n * Initialize the zstd WASM module. Idempotent — safe to call multiple times.\n * Instantiates from the base64-inlined binary.\n */\nexport async function initZstd(): Promise<void> {\n if (initialized) return\n if (initPromise) return initPromise\n initPromise = doInit()\n return initPromise\n}\n\nasync function doInit(): Promise<void> {\n const binary = getZstdWasmBytes()\n const importObject = {a: wasmImports}\n const module = await WebAssembly.compile(binary.buffer as ArrayBuffer)\n const instance = await WebAssembly.instantiate(module, importObject)\n\n const exports = instance.exports as Record<string, WebAssembly.Global | WebAssembly.Memory | CallableFunction>\n\n // WASM exports (Emscripten minified names):\n // f: memory\n // g: __wasm_call_ctors (runtime init)\n // h: ZSTD_isError\n // n: ZSTD_createDCtx\n // o: ZSTD_freeDCtx\n // p: ZSTD_getFrameContentSize\n // q: ZSTD_decompress_usingDict\n // s: malloc\n // t: free\n wasmMemory = exports['f'] as WebAssembly.Memory\n updateMemoryViews()\n\n // Call constructors to initialize the runtime\n ;(exports['g'] as CallableFunction)()\n\n // Also set the timeout callback from exports\n __emscripten_timeout = exports['v'] as (which: number, now: number) => void\n\n wasmExports = exports as unknown as Record<string, CallableFunction>\n initialized = true\n}\n\n// ─── Public API ─────────────────────────────────────────────────────────────\n\n/** Create a decompression context. Returns an opaque handle. */\nexport function createDCtx(): number {\n if (!initialized) throw new Error('zstd WASM not initialized — call initZstd() first')\n return wasmExports['n']() as number\n}\n\n/** Free a decompression context. */\nexport function freeDCtx(dctx: number): void {\n if (!initialized) return\n wasmExports['o'](dctx)\n}\n\n/**\n * Decompress a zstd-compressed buffer using a dictionary.\n * Returns a newly allocated Uint8Array with the decompressed data.\n */\nexport function decompressUsingDict(\n dctx: number,\n compressed: Uint8Array,\n dictionary: Uint8Array,\n): Uint8Array {\n if (!initialized) throw new Error('zstd WASM not initialized — call initZstd() first')\n\n const malloc = wasmExports['s'] as (size: number) => number\n const free = wasmExports['t'] as (ptr: number) => void\n const getFrameContentSize = wasmExports['p'] as (src: number, srcSize: number) => number\n const decompress = wasmExports['q'] as (\n dctx: number, dst: number, dstCapacity: number,\n src: number, srcSize: number,\n dict: number, dictSize: number,\n ) => number\n const isError = wasmExports['h'] as (code: number) => number\n\n // Allocate WASM heap memory for input\n const srcPtr = malloc(compressed.byteLength)\n HEAP8.set(compressed, srcPtr)\n\n // Allocate for dictionary\n const dictPtr = malloc(dictionary.byteLength)\n HEAP8.set(dictionary, dictPtr)\n\n // Determine output size\n const contentSize = getFrameContentSize(srcPtr, compressed.byteLength)\n const dstCapacity = contentSize === -1 ? 1024 * 1024 : contentSize // 1MB default\n\n const dstPtr = malloc(dstCapacity)\n try {\n const sizeOrError = decompress(dctx, dstPtr, dstCapacity, srcPtr, compressed.byteLength, dictPtr, dictionary.byteLength)\n\n if (isError(sizeOrError)) {\n throw new Error(`zstd decompression failed with code ${sizeOrError}`)\n }\n\n // Copy result out of WASM heap (slice creates an independent copy)\n const result = new Uint8Array(HEAPU8.buffer, dstPtr, sizeOrError).slice()\n return result\n } finally {\n free(dstPtr)\n free(srcPtr)\n free(dictPtr)\n }\n}\n","/**\n * GTX file reader — binary format for bundled genomic signal data.\n *\n * A GTX file packs multiple experiments (BigWig-equivalent signal tracks) into\n * a single file with:\n * - Tile-based indexing (flat arrays, not R-trees)\n * - zstd dictionary compression for small chunk sizes\n * - Per-experiment metadata\n * - Multi-resolution zoom levels\n *\n * Uses HTTP Range Requests for selective remote access — never downloads\n * the full file.\n *\n * Layer 1 (Data + Layout): no DOM, no canvas.\n */\n\nimport {fetchRange} from '../io/rangeReader'\nimport {BinaryParser} from '../io/binaryParser'\nimport type {WigFeature} from '../types'\n\n// ─── Types ───────────────────────────────────────────────────────────────────\n\nexport interface GtxHeader {\n version: number\n genome: string\n nExperiments: number\n resolution: number\n payloadEncoding: number\n nZoomLevels: number\n chromDirectoryOffset: number\n experimentMetadataOffset: number\n dictionaryOffset: number\n dictionarySize: number\n zoomDirectoryOffset: number\n groupStatsDirectoryOffset: number\n}\n\nexport interface ChromEntry {\n name: string\n length: number\n tileIndexOffset: number\n tileIndexLength: number\n nTiles: number\n}\n\nexport interface ExperimentEntry {\n id: string\n experimentIndex: number\n metadata: Map<string, string>\n}\n\nexport interface ExperimentPointer {\n offset: number\n size: number\n}\n\nexport interface TileEntry {\n positionsOffset: number\n positionsSize: number\n experimentPointers: ExperimentPointer[]\n}\n\nexport interface ZoomLevel {\n reductionLevel: number\n chromTileIndexes: Map<string, ZoomChromEntry>\n}\n\nexport interface ZoomChromEntry {\n tileIndexOffset: number\n tileIndexLength: number\n nTiles: number\n}\n\n// ─── Constants ───────────────────────────────────────────────────────────────\n\nconst GTX_MAGIC = 0x00585447 // \"GTX\\0\" as little-endian u32\nconst HEADER_FETCH_SIZE = 256 // enough for any reasonable genome string\n\n// Standard tile sizes used by the Rust GTX writer (tried in order).\n// The writer picks the first size where ceil(chromLength / tileSize) produces\n// nTiles. We replicate this logic to get the exact integer tile boundaries.\nconst STANDARD_TILE_SIZES = [50_000, 100_000, 200_000, 500_000, 1_000_000]\n\nimport {initZstd, createDCtx, freeDCtx, decompressUsingDict} from './zstdWasm'\n\n/**\n * Infer the integer tile size from chromosome length and tile count.\n * Matches the Rust writer's logic: tile_size is a fixed integer, and\n * n_tiles = ceil(chrom_length / tile_size). The last tile may be smaller.\n */\nfunction inferTileSize(chromLength: number, nTiles: number): number {\n for (const ts of STANDARD_TILE_SIZES) {\n if (Math.ceil(chromLength / ts) === nTiles) {\n return ts\n }\n }\n // Fallback: derive from nTiles (integer division, rounding up)\n return Math.ceil(chromLength / nTiles)\n}\n\n// ─── Reader ──────────────────────────────────────────────────────────────────\n\nexport class GtxReader {\n private readonly url: string\n\n // Cached init data\n private header?: GtxHeader\n private dictionary?: Uint8Array\n private dctx?: number\n private experiments: ExperimentEntry[] = []\n private experimentIdToIndex = new Map<string, number>()\n private chromosomes = new Map<string, ChromEntry>()\n private chromOrder: string[] = [] // ordered chromosome names (matches chrom directory order)\n private tileIndexCache = new Map<string, TileEntry[]>()\n private zoomLevels: ZoomLevel[] = []\n private zoomTileIndexCache = new Map<string, TileEntry[]>() // key: `${zoomIdx}:${chrom}`\n\n private initialized = false\n private initPromise?: Promise<void>\n\n constructor(url: string) {\n this.url = url\n }\n\n // ─── Initialization ──────────────────────────────────────────────────\n\n /**\n * Initialize the reader: fetch header, dictionary, experiment metadata,\n * and chromosome directory. Idempotent — safe to call multiple times.\n *\n * Note: init does NOT forward the caller's AbortSignal to avoid a race\n * condition where aborting one track's fetch would leave the shared reader\n * half-initialized (header set but metadata empty), permanently broken\n * for all subsequent callers.\n */\n async init(_signal?: AbortSignal): Promise<void> {\n if (this.initialized) return\n if (this.initPromise) return this.initPromise\n this.initPromise = this._doInit().catch(err => {\n // Reset so a future init() call can retry\n this.initPromise = undefined\n throw err\n })\n return this.initPromise\n }\n\n private async _doInit(): Promise<void> {\n await initZstd()\n\n // Step 1: Fetch and parse header (no signal — init must complete atomically)\n const headerBuf = await fetchRange(this.url, {start: 0, size: HEADER_FETCH_SIZE})\n this.header = this.parseHeader(new BinaryParser(new DataView(headerBuf), true))\n const h = this.header\n\n // Step 2: Fetch metadata + dictionary and chrom + zoom directories.\n // File layout: header → metadata → dictionary → DATA BLOCKS → chrom dir → zoom dir → checksum\n // Metadata and dictionary are adjacent (~65 KB total).\n // Chrom and zoom directories are adjacent at the end (~8 KB total).\n // Two range requests instead of downloading the entire file.\n\n // Metadata: experimentMetadataOffset → dictionaryOffset (adjacent)\n const metadataSize = h.dictionaryOffset - h.experimentMetadataOffset\n\n // Batch metadata + dictionary (they're adjacent)\n const metaDictStart = h.experimentMetadataOffset\n const metaDictSize = metadataSize + h.dictionarySize\n\n // Chrom + zoom directories: chromDirectoryOffset → end of file\n // (the trailing 8-byte xxHash64 checksum won't affect parsing since\n // the directory parsers read a known structure and stop)\n const dirStart = h.chromDirectoryOffset\n const hasZoom = h.nZoomLevels > 0 && h.zoomDirectoryOffset > 0\n\n const dirFetchSize = this.computeDirFetchSize(h)\n\n // Fetch both ranges concurrently\n const [metaDictBuf, dirBuf] = await Promise.all([\n fetchRange(this.url, {start: metaDictStart, size: metaDictSize}),\n fetchRange(this.url, {start: dirStart, size: dirFetchSize}),\n ])\n\n // Parse metadata (first part of metaDictBuf)\n this.parseExperimentMetadata(new BinaryParser(\n new DataView(metaDictBuf, 0, metadataSize),\n true,\n ))\n\n // Parse dictionary (second part of metaDictBuf)\n this.dictionary = new Uint8Array(metaDictBuf, metadataSize, h.dictionarySize)\n\n // Create decompression context\n this.dctx = createDCtx()\n\n // Parse chromosome directory — clamp to actual buffer size\n const chromDirLength = hasZoom\n ? Math.min(h.zoomDirectoryOffset - h.chromDirectoryOffset, dirBuf.byteLength)\n : dirBuf.byteLength\n this.parseChromDirectory(new BinaryParser(\n new DataView(dirBuf, 0, chromDirLength),\n true,\n ))\n\n // Parse zoom directory if present.\n // Exclude the trailing 8-byte xxHash64 checksum from the DataView\n // so the parser doesn't read into it and misinterpret random bytes.\n if (hasZoom) {\n const zoomStart = h.zoomDirectoryOffset - dirStart\n const zoomLength = dirBuf.byteLength - zoomStart - 8 // subtract 8-byte checksum\n if (zoomStart >= 0 && zoomLength > 0) {\n this.parseZoomDirectory(new BinaryParser(\n new DataView(dirBuf, zoomStart, zoomLength),\n true,\n ))\n }\n }\n\n this.initialized = true\n }\n\n // ─── Header Parsing ──────────────────────────────────────────────────\n\n private parseHeader(p: BinaryParser): GtxHeader {\n const magic = p.getUInt()\n if (magic !== GTX_MAGIC) {\n throw new Error(`Not a GTX file (magic: 0x${magic.toString(16)}, expected 0x${GTX_MAGIC.toString(16)})`)\n }\n\n const version = p.getUShort()\n const genomeLen = p.getUShort()\n const genome = p.getFixedLengthString(genomeLen)\n const nExperiments = p.getUInt()\n const resolution = p.getUInt()\n const payloadEncoding = p.getByte()\n const nZoomLevels = p.getByte()\n const chromDirectoryOffset = this.readU64(p)\n const experimentMetadataOffset = this.readU64(p)\n const dictionaryOffset = this.readU64(p)\n const dictionarySize = p.getUInt()\n const zoomDirectoryOffset = this.readU64(p)\n const groupStatsDirectoryOffset = this.readU64(p)\n\n return {\n version, genome, nExperiments, resolution, payloadEncoding,\n nZoomLevels, chromDirectoryOffset, experimentMetadataOffset,\n dictionaryOffset, dictionarySize, zoomDirectoryOffset,\n groupStatsDirectoryOffset,\n }\n }\n\n // ─── Metadata Parsing ────────────────────────────────────────────────\n\n private parseExperimentMetadata(p: BinaryParser): void {\n const count = p.getUInt()\n for (let i = 0; i < count; i++) {\n const idLen = p.getUShort()\n const id = p.getFixedLengthString(idLen)\n const experimentIndex = p.getUInt()\n const nMeta = p.getUShort()\n const metadata = new Map<string, string>()\n for (let j = 0; j < nMeta; j++) {\n const keyLen = p.getUShort()\n const key = p.getFixedLengthString(keyLen)\n const valLen = p.getUShort()\n const val = p.getFixedLengthString(valLen)\n metadata.set(key, val)\n }\n const entry: ExperimentEntry = {id, experimentIndex, metadata}\n this.experiments.push(entry)\n this.experimentIdToIndex.set(id, experimentIndex)\n }\n }\n\n private parseChromDirectory(p: BinaryParser): void {\n const nChromosomes = p.getUShort()\n for (let i = 0; i < nChromosomes; i++) {\n const nameLen = p.getUShort()\n const name = p.getFixedLengthString(nameLen)\n const length = p.getUInt()\n const tileIndexOffset = this.readU64(p)\n const tileIndexLength = p.getUInt()\n const nTiles = p.getUInt()\n this.chromosomes.set(name, {name, length, tileIndexOffset, tileIndexLength, nTiles})\n this.chromOrder.push(name)\n }\n }\n\n private parseZoomDirectory(p: BinaryParser): void {\n const nZoomLevels = p.getByte()\n for (let i = 0; i < nZoomLevels; i++) {\n const reductionLevel = p.getUInt()\n const nChroms = p.getUShort()\n const chromTileIndexes = new Map<string, ZoomChromEntry>()\n for (let j = 0; j < nChroms; j++) {\n // Zoom entries are positional — no name strings.\n // Chromosome order matches the main chrom directory.\n const tileIndexOffset = this.readU64(p)\n const tileIndexLength = p.getUInt()\n const nTiles = p.getUInt()\n const name = this.chromOrder[j] ?? `chrom_${j}`\n chromTileIndexes.set(name, {tileIndexOffset, tileIndexLength, nTiles})\n }\n this.zoomLevels.push({reductionLevel, chromTileIndexes})\n }\n }\n\n // ─── Tile Index Loading ──────────────────────────────────────────────\n\n /**\n * Lazily fetch and parse the tile index for a chromosome.\n * Cached after first load.\n */\n async loadTileIndex(chrom: string, signal?: AbortSignal): Promise<TileEntry[]> {\n await this.init(signal)\n\n const cached = this.tileIndexCache.get(chrom)\n if (cached) return cached\n\n const chromEntry = this.chromosomes.get(chrom)\n if (!chromEntry) throw new Error(`Unknown chromosome: ${chrom}`)\n\n const buf = await fetchRange(this.url, {\n start: chromEntry.tileIndexOffset,\n size: chromEntry.tileIndexLength,\n }, signal)\n\n const tiles = this.parseTileIndex(new BinaryParser(new DataView(buf), true), chromEntry.nTiles)\n this.tileIndexCache.set(chrom, tiles)\n return tiles\n }\n\n private async loadZoomTileIndex(zoomIdx: number, chrom: string, signal?: AbortSignal): Promise<TileEntry[]> {\n const cacheKey = `${zoomIdx}:${chrom}`\n const cached = this.zoomTileIndexCache.get(cacheKey)\n if (cached) return cached\n\n const zoomLevel = this.zoomLevels[zoomIdx]\n if (!zoomLevel) throw new Error(`Unknown zoom level: ${zoomIdx}`)\n\n const chromEntry = zoomLevel.chromTileIndexes.get(chrom)\n if (!chromEntry) throw new Error(`Unknown chromosome in zoom: ${chrom}`)\n\n const buf = await fetchRange(this.url, {\n start: chromEntry.tileIndexOffset,\n size: chromEntry.tileIndexLength,\n }, signal)\n\n const tiles = this.parseTileIndex(new BinaryParser(new DataView(buf), true), chromEntry.nTiles)\n this.zoomTileIndexCache.set(cacheKey, tiles)\n return tiles\n }\n\n private parseTileIndex(p: BinaryParser, nTiles: number): TileEntry[] {\n const parsedNTiles = p.getUInt()\n const nExperiments = p.getUInt()\n if (parsedNTiles !== nTiles) {\n throw new Error(`Tile count mismatch: expected ${nTiles}, got ${parsedNTiles}`)\n }\n\n const tiles: TileEntry[] = []\n for (let i = 0; i < nTiles; i++) {\n const positionsOffset = this.readU64(p)\n const positionsSize = p.getUInt()\n const experimentPointers: ExperimentPointer[] = []\n for (let j = 0; j < nExperiments; j++) {\n const offset = this.readU64(p)\n const size = p.getUInt()\n experimentPointers.push({offset, size})\n }\n tiles.push({positionsOffset, positionsSize, experimentPointers})\n }\n return tiles\n }\n\n // ─── Data Reading ────────────────────────────────────────────────────\n\n /**\n * Read signal data for one or more experiments in a genomic region.\n * Multiple experiments from the same tile are fetched with merged byte ranges.\n *\n * @returns Map from experiment index to WigFeature array\n */\n async readFeatures(\n chrom: string,\n start: number,\n end: number,\n experimentIndexes: number[],\n bpPerPixel?: number,\n signal?: AbortSignal,\n ): Promise<Map<number, WigFeature[]>> {\n await this.init(signal)\n const h = this.header!\n\n // Select zoom level if appropriate\n if (bpPerPixel !== undefined && bpPerPixel > 1) {\n const zoomIdx = this.selectZoomLevel(bpPerPixel)\n if (zoomIdx !== undefined) {\n return this.readZoomFeatures(chrom, start, end, experimentIndexes, zoomIdx, signal)\n }\n }\n\n const chromEntry = this.chromosomes.get(chrom)\n if (!chromEntry) return new Map()\n\n const tiles = await this.loadTileIndex(chrom, signal)\n const tileSize = inferTileSize(chromEntry.length, chromEntry.nTiles)\n\n const firstTile = Math.max(0, Math.floor(start / tileSize))\n const lastTile = Math.min(chromEntry.nTiles - 1, Math.floor(Math.max(0, end - 1) / tileSize))\n\n // Collect byte ranges to fetch\n const fetchPlan: Array<{\n tileIdx: number\n expIdx: number\n pointer: ExperimentPointer\n }> = []\n\n for (let t = firstTile; t <= lastTile; t++) {\n const tile = tiles[t]\n for (const expIdx of experimentIndexes) {\n const ptr = tile.experimentPointers[expIdx]\n if (ptr && ptr.size > 0) {\n fetchPlan.push({tileIdx: t, expIdx, pointer: ptr})\n }\n }\n }\n\n if (fetchPlan.length === 0) return new Map()\n\n // Merge nearby ranges and fetch\n const chunks = await this.fetchMergedRanges(fetchPlan, signal)\n\n // Decompress and assemble results\n const result = new Map<number, WigFeature[]>()\n for (const expIdx of experimentIndexes) {\n result.set(expIdx, [])\n }\n\n for (const {tileIdx, expIdx, data} of chunks) {\n const decompressed = this.decompress(data)\n const values = new Float32Array(decompressed.buffer, decompressed.byteOffset, decompressed.byteLength / 4)\n\n const tileStart = tileIdx * tileSize\n const tileEnd = Math.min((tileIdx + 1) * tileSize, chromEntry.length)\n const overlapStart = Math.max(start, tileStart)\n const overlapEnd = Math.min(end, tileEnd)\n\n const firstBin = Math.floor((overlapStart - tileStart) / h.resolution)\n const lastBin = Math.ceil((overlapEnd - tileStart) / h.resolution)\n\n const features = result.get(expIdx)!\n for (let bin = firstBin; bin < lastBin && bin < values.length; bin++) {\n const value = values[bin]\n if (value === 0) continue\n const binStart = tileStart + bin * h.resolution\n const binEnd = Math.min(binStart + h.resolution, chromEntry.length)\n features.push({chr: chrom, start: binStart, end: binEnd, value})\n }\n }\n\n return result\n }\n\n /**\n * Read zoom-level data for one or more experiments.\n */\n private async readZoomFeatures(\n chrom: string,\n start: number,\n end: number,\n experimentIndexes: number[],\n zoomIdx: number,\n signal?: AbortSignal,\n ): Promise<Map<number, WigFeature[]>> {\n const zoomLevel = this.zoomLevels[zoomIdx]\n if (!zoomLevel) return new Map()\n\n const chromZoom = zoomLevel.chromTileIndexes.get(chrom)\n if (!chromZoom) return new Map()\n\n const chromEntry = this.chromosomes.get(chrom)\n if (!chromEntry) return new Map()\n\n const tiles = await this.loadZoomTileIndex(zoomIdx, chrom, signal)\n // Zoom uses the same tile grid as full resolution\n const tileSize = inferTileSize(chromEntry.length, chromZoom.nTiles)\n const zoomBinSize = zoomLevel.reductionLevel\n\n const firstTile = Math.max(0, Math.floor(start / tileSize))\n const lastTile = Math.min(chromZoom.nTiles - 1, Math.floor(Math.max(0, end - 1) / tileSize))\n\n const fetchPlan: Array<{\n tileIdx: number\n expIdx: number\n pointer: ExperimentPointer\n }> = []\n\n for (let t = firstTile; t <= lastTile; t++) {\n const tile = tiles[t]\n for (const expIdx of experimentIndexes) {\n const ptr = tile.experimentPointers[expIdx]\n if (ptr && ptr.size > 0) {\n fetchPlan.push({tileIdx: t, expIdx, pointer: ptr})\n }\n }\n }\n\n if (fetchPlan.length === 0) return new Map()\n\n const chunks = await this.fetchMergedRanges(fetchPlan, signal)\n\n const result = new Map<number, WigFeature[]>()\n for (const expIdx of experimentIndexes) {\n result.set(expIdx, [])\n }\n\n for (const {tileIdx, expIdx, data} of chunks) {\n const decompressed = this.decompress(data)\n const allValues = new Float32Array(decompressed.buffer, decompressed.byteOffset, decompressed.byteLength / 4)\n\n // Zoom data layout: [means..., maxes...] — first half is means, second half is maxes\n const nZoomBins = allValues.length / 2\n const means = allValues.subarray(0, nZoomBins)\n\n const tileStart = tileIdx * tileSize\n const tileEnd = Math.min((tileIdx + 1) * tileSize, chromEntry.length)\n const overlapStart = Math.max(start, tileStart)\n const overlapEnd = Math.min(end, tileEnd)\n\n const firstBin = Math.floor((overlapStart - tileStart) / zoomBinSize)\n const lastBin = Math.ceil((overlapEnd - tileStart) / zoomBinSize)\n\n const features = result.get(expIdx)!\n for (let bin = firstBin; bin < lastBin && bin < means.length; bin++) {\n const value = means[bin]\n if (value === 0) continue\n const binStart = tileStart + bin * zoomBinSize\n const binEnd = Math.min(binStart + zoomBinSize, chromEntry.length)\n features.push({chr: chrom, start: binStart, end: binEnd, value})\n }\n }\n\n return result\n }\n\n // ─── Experiment Metadata Stubs ───────────────────────────────────────\n\n /** Returns all experiment IDs in this GTX file. */\n getExperimentIds(): string[] {\n return this.experiments.map(e => e.id)\n }\n\n /** Returns metadata key-value pairs for an experiment, or undefined if not found. */\n getExperimentMetadata(id: string): Map<string, string> | undefined {\n const entry = this.experiments.find(e => e.id === id)\n return entry?.metadata\n }\n\n /** Resolve an experiment ID to its numeric index. */\n resolveExperimentIndex(id: string): number | undefined {\n return this.experimentIdToIndex.get(id)\n }\n\n /** Get the parsed header (must call init() first). */\n getHeader(): GtxHeader | undefined {\n return this.header\n }\n\n /** Get all chromosome entries. */\n getChromosomes(): Map<string, ChromEntry> {\n return this.chromosomes\n }\n\n // ─── Internal Helpers ────────────────────────────────────────────────\n\n /**\n * Compute the fetch size for the chrom + zoom directory region.\n *\n * The directories sit at the end of the file, followed only by an 8-byte\n * xxHash64 checksum. We compute the span from known offsets, and the\n * trailing checksum bytes won't affect parsing since directory parsers\n * read a known structure and stop.\n */\n private computeDirFetchSize(h: GtxHeader): number {\n // groupStatsDirectoryOffset marks the end of zoom directory\n if (h.groupStatsDirectoryOffset > 0 && h.groupStatsDirectoryOffset > h.chromDirectoryOffset) {\n // Include 8 bytes past groupStats to cover the checksum (harmless)\n return h.groupStatsDirectoryOffset - h.chromDirectoryOffset + 8\n }\n // Zoom directory + generous padding for zoom data after it\n if (h.nZoomLevels > 0 && h.zoomDirectoryOffset > 0) {\n return (h.zoomDirectoryOffset - h.chromDirectoryOffset) + 256 * 1024\n }\n // No zoom — just chrom directory + padding\n return 256 * 1024\n }\n\n /**\n * Select the best zoom level for a given bp/pixel resolution.\n * Returns undefined if full resolution should be used.\n */\n private selectZoomLevel(bpPerPixel: number): number | undefined {\n // Select the coarsest zoom level where zoom_bin_size < bpPerPixel * 2\n let bestIdx: number | undefined\n for (let i = 0; i < this.zoomLevels.length; i++) {\n if (this.zoomLevels[i].reductionLevel < bpPerPixel * 2) {\n bestIdx = i\n }\n }\n return bestIdx\n }\n\n /**\n * Merge adjacent/nearby byte ranges and fetch, then split back to\n * per-experiment chunks.\n */\n private async fetchMergedRanges(\n plan: Array<{tileIdx: number; expIdx: number; pointer: ExperimentPointer}>,\n signal?: AbortSignal,\n ): Promise<Array<{tileIdx: number; expIdx: number; data: Uint8Array}>> {\n // Sort by file offset for merging\n const sorted = [...plan].sort((a, b) => a.pointer.offset - b.pointer.offset)\n\n // Merge ranges that are within 1KB of each other\n const MERGE_GAP = 1024\n const mergedRanges: Array<{start: number; end: number; items: typeof sorted}> = []\n\n for (const item of sorted) {\n const itemEnd = item.pointer.offset + item.pointer.size\n const last = mergedRanges[mergedRanges.length - 1]\n\n if (last && item.pointer.offset - last.end <= MERGE_GAP) {\n last.end = Math.max(last.end, itemEnd)\n last.items.push(item)\n } else {\n mergedRanges.push({\n start: item.pointer.offset,\n end: itemEnd,\n items: [item],\n })\n }\n }\n\n // Fetch all merged ranges concurrently\n const fetches = mergedRanges.map(async range => {\n const buf = await fetchRange(this.url, {\n start: range.start,\n size: range.end - range.start,\n }, signal)\n return {range, buf}\n })\n\n const results = await Promise.all(fetches)\n const chunks: Array<{tileIdx: number; expIdx: number; data: Uint8Array}> = []\n\n for (const {range, buf} of results) {\n for (const item of range.items) {\n const localOffset = item.pointer.offset - range.start\n const data = new Uint8Array(buf, localOffset, item.pointer.size)\n chunks.push({tileIdx: item.tileIdx, expIdx: item.expIdx, data})\n }\n }\n\n return chunks\n }\n\n /** Decompress a zstd-compressed chunk using the cached dictionary. */\n private decompress(data: Uint8Array): Uint8Array {\n if (!this.dictionary || this.dctx === undefined) {\n throw new Error('GTX reader not initialized — call init() first')\n }\n return decompressUsingDict(this.dctx, data, this.dictionary)\n }\n\n /** Read a u64 from BinaryParser (as JavaScript number). */\n private readU64(p: BinaryParser): number {\n return p.getLong()\n }\n\n /** Clean up the decompression context. */\n dispose(): void {\n if (this.dctx !== undefined) {\n freeDCtx(this.dctx)\n this.dctx = undefined\n }\n }\n}\n","/**\n * GTX fetch coordinator — batches requests from multiple GtxDataSource\n * instances into a single readFeatures() call.\n *\n * When loadAllTracksIfNeeded fires for 5 GTX tracks, all 5\n * GtxDataSource.fetch() calls run synchronously in the same tick.\n * Each calls coordinator.request() which is synchronous — no awaits\n * before the batching logic. Requests are collected, then flushed\n * on the next microtask as a single readFeatures() call with all\n * experiment indexes, merging byte ranges across experiments.\n *\n * Layer 1 (Data + Layout): no DOM, no canvas.\n */\n\nimport {GtxReader} from './gtxReader'\nimport type {WigFeature, Locus} from '../types'\n\ninterface PendingExperiment {\n experimentId: string\n resolve: (features: WigFeature[]) => void\n reject: (err: unknown) => void\n}\n\ninterface PendingBatch {\n locus: Locus\n bpPerPixel: number\n signal: AbortSignal | undefined\n experiments: PendingExperiment[]\n}\n\n// One coordinator per GTX URL (same lifetime as the GtxReader)\nconst coordinators = new Map<string, GtxFetchCoordinator>()\n\nexport function getCoordinator(url: string, reader: GtxReader): GtxFetchCoordinator {\n let coord = coordinators.get(url)\n if (!coord) {\n coord = new GtxFetchCoordinator(url, reader)\n coordinators.set(url, coord)\n }\n return coord\n}\n\nexport function clearCoordinators(): void {\n coordinators.clear()\n}\n\nexport class GtxFetchCoordinator {\n private pending = new Map<string, PendingBatch>()\n\n constructor(\n private url: string,\n private reader: GtxReader,\n ) {}\n\n /**\n * Request features for one experiment. Fully synchronous — collects the\n * request and returns a promise that resolves when the batch flushes.\n *\n * The flush handles reader.init() internally, so callers do NOT need\n * to await init() before calling this. This is critical: if callers\n * awaited init(), the await would yield and each continuation would\n * resume in a separate microtask, defeating batching.\n */\n request(\n experimentId: string,\n locus: Locus,\n bpPerPixel: number,\n signal?: AbortSignal,\n ): Promise<WigFeature[]> {\n const key = `${locus.chr}:${locus.start}-${locus.end}|${bpPerPixel}`\n const existing = this.pending.get(key)\n\n if (existing) {\n return new Promise<WigFeature[]>((resolve, reject) => {\n existing.experiments.push({experimentId, resolve, reject})\n })\n }\n\n return new Promise<WigFeature[]>((resolve, reject) => {\n const batch: PendingBatch = {\n locus,\n bpPerPixel,\n signal,\n experiments: [{experimentId, resolve, reject}],\n }\n this.pending.set(key, batch)\n queueMicrotask(() => this.flush(key))\n })\n }\n\n private async flush(key: string): Promise<void> {\n const batch = this.pending.get(key)\n if (!batch) return\n this.pending.delete(key)\n\n const {locus, bpPerPixel, signal, experiments} = batch\n\n try {\n // Init inside flush — not in each caller\n await this.reader.init()\n\n // Resolve all experiment IDs to indexes\n const expIndexes: number[] = []\n const idToIdx = new Map<string, number>()\n for (const exp of experiments) {\n const idx = this.reader.resolveExperimentIndex(exp.experimentId)\n if (idx === undefined) {\n exp.reject(new Error(`Unknown experiment: ${exp.experimentId}`))\n continue\n }\n idToIdx.set(exp.experimentId, idx)\n expIndexes.push(idx)\n }\n\n if (expIndexes.length === 0) return\n\n // Single readFeatures call with all experiment indexes\n const result = await this.reader.readFeatures(\n locus.chr,\n locus.start,\n locus.end,\n expIndexes,\n bpPerPixel,\n signal,\n )\n\n // Distribute results\n for (const exp of experiments) {\n const idx = idToIdx.get(exp.experimentId)\n if (idx !== undefined) {\n exp.resolve(result.get(idx) ?? [])\n }\n }\n } catch (err) {\n for (const exp of experiments) {\n exp.reject(err)\n }\n }\n }\n}\n","/**\n * GTX reader — public API.\n *\n * Reads GTX binary files via HTTP range requests and returns\n * WigFeature[] arrays ready for rendering. A single GTX file\n * bundles multiple experiments; the reader is cached per URL\n * and shared across all experiments from the same file.\n *\n * Layer 1 (Data + Layout): no DOM, no canvas.\n */\n\nexport {GtxReader} from './gtxReader'\nexport type {GtxHeader, ChromEntry, ExperimentEntry} from './gtxReader'\n\nimport {GtxReader} from './gtxReader'\nimport {clearCoordinators} from './fetchCoordinator'\nimport type {WigFeature, WindowFunction, Locus} from '../types'\n\nexport interface FetchGtxOptions {\n /** Resolution in base pairs per pixel. Used to select an appropriate zoom level. */\n bpPerPixel?: number\n /** Aggregation function for zoom-level data. Default: 'mean'. */\n windowFunction?: WindowFunction\n /** AbortSignal for cancelling in-flight HTTP requests. */\n signal?: AbortSignal\n}\n\n// Cache readers by URL to reuse parsed headers, dictionaries, and indexes\nconst readerCache = new Map<string, GtxReader>()\n\nfunction getReader(url: string): GtxReader {\n let reader = readerCache.get(url)\n if (!reader) {\n reader = new GtxReader(url)\n readerCache.set(url, reader)\n }\n return reader\n}\n\n/**\n * Fetch GTX features for a single experiment at a genomic locus.\n */\nexport async function fetchGtxFeatures(\n url: string,\n experimentId: string,\n locus: Locus,\n options: FetchGtxOptions = {},\n): Promise<WigFeature[]> {\n const reader = getReader(url)\n await reader.init(options.signal)\n\n const expIdx = reader.resolveExperimentIndex(experimentId)\n if (expIdx === undefined) {\n throw new Error(`Unknown experiment: ${experimentId}`)\n }\n\n const result = await reader.readFeatures(\n locus.chr,\n locus.start,\n locus.end,\n [expIdx],\n options.bpPerPixel,\n options.signal,\n )\n\n return result.get(expIdx) ?? []\n}\n\n/**\n * Fetch GTX features across all specified chromosomes for whole genome view.\n * Returns features with per-chromosome coordinates (caller transforms to genome-wide).\n */\nexport async function fetchGtxWGFeatures(\n url: string,\n experimentId: string,\n chromNames: string[],\n bpPerPixel: number,\n options: Pick<FetchGtxOptions, 'windowFunction' | 'signal'> = {},\n): Promise<WigFeature[]> {\n const reader = getReader(url)\n await reader.init(options.signal)\n\n const expIdx = reader.resolveExperimentIndex(experimentId)\n if (expIdx === undefined) {\n throw new Error(`Unknown experiment: ${experimentId}`)\n }\n\n const allFeatures: WigFeature[] = []\n\n // Fetch each chromosome. GTX supports multi-experiment per request,\n // but for WG view we iterate chromosomes.\n for (const chrom of chromNames) {\n try {\n const result = await reader.readFeatures(\n chrom, 0, Number.MAX_SAFE_INTEGER,\n [expIdx],\n bpPerPixel,\n options.signal,\n )\n const features = result.get(expIdx)\n if (features) {\n allFeatures.push(...features)\n }\n } catch {\n // Skip chromosomes not in the GTX file\n }\n }\n\n return allFeatures\n}\n\n/**\n * Fetch GTX features for multiple experiments simultaneously.\n * Optimizes network by merging byte ranges for experiments in the same tiles.\n */\nexport async function fetchGtxMultiFeatures(\n url: string,\n experimentIds: string[],\n locus: Locus,\n options: FetchGtxOptions = {},\n): Promise<Map<string, WigFeature[]>> {\n const reader = getReader(url)\n await reader.init(options.signal)\n\n const idToIdx = new Map<string, number>()\n const indexes: number[] = []\n for (const id of experimentIds) {\n const idx = reader.resolveExperimentIndex(id)\n if (idx === undefined) {\n throw new Error(`Unknown experiment: ${id}`)\n }\n idToIdx.set(id, idx)\n indexes.push(idx)\n }\n\n const result = await reader.readFeatures(\n locus.chr,\n locus.start,\n locus.end,\n indexes,\n options.bpPerPixel,\n options.signal,\n )\n\n // Map back from experiment index to experiment ID\n const output = new Map<string, WigFeature[]>()\n for (const [id, idx] of idToIdx) {\n output.set(id, result.get(idx) ?? [])\n }\n return output\n}\n\n/** Clear the GTX reader cache (useful for testing or memory management). */\nexport function clearGtxCache(): void {\n for (const reader of readerCache.values()) {\n reader.dispose()\n }\n readerCache.clear()\n clearCoordinators()\n}\n","/**\n * GTX data source — DataSource<WigFeature> backed by a GTX file.\n *\n * A single GTX file contains multiple experiments. Each GtxDataSource\n * instance reads one experiment (by ID), but shares the underlying\n * GtxReader (and its cached header, dictionary, indexes) with other\n * GtxDataSource instances pointing to the same URL.\n *\n * Request coalescing: when multiple GtxDataSource instances for the\n * same URL call fetch() in the same tick (e.g., loadAllTracksIfNeeded),\n * the GtxFetchCoordinator batches them into a single readFeatures()\n * call with merged byte ranges — the core GTX performance advantage.\n *\n * Drop-in replacement for BigWigDataSource when the data is in GTX format.\n *\n * Layer 1 (Data + Layout): no DOM, no canvas.\n */\n\nimport type {DataSource, Locus, WigFeature, WindowFunction} from '../types'\nimport type {CumulativeOffsets} from '../genome/chromSizes'\nimport {GtxReader} from '../gtx'\nimport {getCoordinator} from '../gtx/fetchCoordinator'\nimport {fetchGtxWGFeatures} from '../gtx'\nimport {summarizeWigData} from '../tracks/wig/wigSummary'\nimport {isWholeGenomeView} from '../locusUtils'\n\n// Cache readers by URL (shared with gtx/index.ts reader cache)\nconst readerCache = new Map<string, GtxReader>()\n\nfunction getReader(url: string): GtxReader {\n let reader = readerCache.get(url)\n if (!reader) {\n reader = new GtxReader(url)\n readerCache.set(url, reader)\n }\n return reader\n}\n\nexport class GtxDataSource implements DataSource<WigFeature> {\n private _windowFunction: WindowFunction\n private _cumulativeOffsets?: CumulativeOffsets\n private _resolveChromName?: (chr: string) => string\n private reader: GtxReader\n\n constructor(\n private url: string,\n private experimentId: string,\n windowFunction: WindowFunction = 'mean',\n ) {\n this._windowFunction = windowFunction\n this.reader = getReader(url)\n }\n\n get windowFunction(): WindowFunction { return this._windowFunction }\n\n /** Update the window function for future fetches. */\n setWindowFunction(wf: WindowFunction): void {\n this._windowFunction = wf\n }\n\n /** Set cumulative offsets for whole genome view coordinate transformation. */\n setCumulativeOffsets(offsets: CumulativeOffsets): void {\n this._cumulativeOffsets = offsets\n }\n\n /** Set a chromosome name resolver for alias resolution (e.g., \"1\" → \"chr1\"). */\n setChromNameResolver(resolver: (chr: string) => string): void {\n this._resolveChromName = resolver\n }\n\n async fetch(locus: Locus, bpPerPixel: number, signal: AbortSignal): Promise<WigFeature[]> {\n if (isWholeGenomeView(locus) && this._cumulativeOffsets) {\n return this.fetchWG(bpPerPixel, signal)\n }\n\n // Resolve chromosome alias before querying\n const resolvedLocus = this._resolveChromName\n ? {...locus, chr: this._resolveChromName(locus.chr)}\n : locus\n\n // Use coordinator for batched fetching. coordinator.request() is\n // synchronous — no awaits before batching. All GtxDataSource\n // instances for the same URL that call fetch() in the same tick\n // are collected and flushed as a single readFeatures() call.\n // The coordinator handles reader.init() internally during flush.\n const coordinator = getCoordinator(this.url, this.reader)\n const features = await coordinator.request(\n this.experimentId,\n resolvedLocus,\n bpPerPixel,\n signal,\n )\n\n // Summarize to pixel resolution\n if (bpPerPixel > 1 && this._windowFunction !== 'none' && features.length > 0) {\n return summarizeWigData(features, locus.start, bpPerPixel, this._windowFunction)\n }\n return features\n }\n\n /**\n * Fetch all chromosomes for whole genome view and transform to genome-wide coordinates.\n */\n private async fetchWG(bpPerPixel: number, signal: AbortSignal): Promise<WigFeature[]> {\n const offsets = this._cumulativeOffsets!\n const features = await fetchGtxWGFeatures(\n this.url,\n this.experimentId,\n offsets.chromosomeNames,\n bpPerPixel,\n {windowFunction: this._windowFunction, signal},\n )\n\n // Transform to genome-wide coordinates\n const wgFeatures: WigFeature[] = []\n for (const f of features) {\n const offset = offsets.offsets[f.chr]\n if (offset === undefined) continue\n wgFeatures.push({\n ...f,\n chr: 'all',\n start: offset + f.start,\n end: offset + f.end,\n })\n }\n wgFeatures.sort((a, b) => a.start - b.start)\n\n // Summarize at genome-wide scale\n if (bpPerPixel > 1 && this._windowFunction !== 'none' && wgFeatures.length > 0) {\n return summarizeWigData(wgFeatures, 0, bpPerPixel, this._windowFunction)\n }\n return wgFeatures\n }\n}\n","/**\n * Shared exon and feature utilities used by multiple decoders (BED, genePred, GFF).\n *\n * Layer 1 (Data + Layout): pure functions, no I/O, no DOM.\n */\n\nimport type {Exon} from '../types'\n\n/**\n * Mark UTR exons and partial UTR boundaries.\n *\n * For non-coding transcripts (cdStart === cdEnd), all exons are marked as UTR.\n * For coding transcripts, exons entirely outside the CDS are marked as UTR,\n * and exons overlapping CDS boundaries get cdStart/cdEnd set.\n *\n * Port of js/feature/decode/ucsc.ts::findUTRs.\n */\nexport function findUTRs(exons: Exon[], cdStart: number, cdEnd: number): void {\n // Non-coding transcript: cdsStart === cdsEnd → all exons are UTR\n if (cdStart === cdEnd) {\n for (const exon of exons) {\n exon.utr = true\n }\n return\n }\n\n for (const exon of exons) {\n if (exon.end < cdStart || exon.start > cdEnd) {\n exon.utr = true\n } else {\n if (cdStart >= exon.start && cdStart <= exon.end) {\n exon.cdStart = cdStart\n }\n if (cdEnd >= exon.start && cdEnd <= exon.end) {\n exon.cdEnd = cdEnd\n }\n }\n }\n}\n\n/**\n * Parse a color value from a BED column (comma-separated RGB or hex) into a CSS color string.\n *\n * Accepts:\n * - \"r,g,b\" (e.g. \"255,0,0\" → \"rgb(255,0,0)\")\n * - \"#RRGGBB\" or \"#RGB\" (returned as-is)\n * - \".\" or \"0\" → returns undefined (no color)\n *\n * Port of igv.js IGVColor.createColorString() for the subset used by BED format.\n */\nexport function parseColorString(value: string): string | undefined {\n if (!value || value === '.' || value === '0') return undefined\n\n // Already a hex color\n if (value.startsWith('#')) return value\n\n // Comma-separated RGB\n const parts = value.split(',')\n if (parts.length >= 3) {\n const r = parseInt(parts[0].trim())\n const g = parseInt(parts[1].trim())\n const b = parseInt(parts[2].trim())\n if (!isNaN(r) && !isNaN(g) && !isNaN(b)) {\n return `rgb(${r},${g},${b})`\n }\n }\n\n return undefined\n}\n\n/** Parse a strand character to a typed strand value. */\nexport function parseStrand(s: string): '+' | '-' | undefined {\n if (s === '+') return '+'\n if (s === '-') return '-'\n return undefined\n}\n","/**\n * UCSC gene prediction format decoders.\n *\n * Ported from js/feature/decode/ucsc.ts — handles genePred, genePredExt,\n * and refGene formats. These are the formats used by UCSC genome browser\n * for gene annotations (ncbiRefSeq, knownGene, etc.).\n */\n\nimport type {Exon, AnnotationFeature} from '../types'\nimport {findUTRs, parseStrand} from './exonUtils'\n\n/**\n * Decode a UCSC \"genePred\" record (basic gene prediction format).\n *\n * Column layout (no bin): name, chrom, strand, txStart, txEnd, cdsStart, cdsEnd,\n * exonCount, exonStarts, exonEnds\n * Column layout (with bin): bin, name, chrom, strand, txStart, txEnd, cdsStart, cdsEnd,\n * exonCount, exonStarts, exonEnds, score, name2\n *\n * @param tokens - Tab-split fields from a single line\n * @param shift - 1 if the record has a leading `bin` column (refGene), 0 otherwise\n */\nexport function decodeGenePred(tokens: string[], shift: 0 | 1 = 0): AnnotationFeature | undefined {\n if (tokens.length <= 10 + shift) return undefined\n\n const cdStart = parseInt(tokens[5 + shift])\n const cdEnd = parseInt(tokens[6 + shift])\n\n const feature: AnnotationFeature = {\n id: tokens[0 + shift],\n chr: tokens[1 + shift],\n strand: parseStrand(tokens[2 + shift]),\n start: parseInt(tokens[3 + shift]),\n end: parseInt(tokens[4 + shift]),\n cdStart,\n cdEnd,\n name: tokens.length > 11 + shift ? tokens[11 + shift] : tokens[0 + shift],\n }\n\n const exons = decodeExons(\n parseInt(tokens[7 + shift]),\n tokens[8 + shift],\n tokens[9 + shift],\n )\n findUTRs(exons, cdStart, cdEnd)\n feature.exons = exons\n\n return feature\n}\n\n/**\n * Decode a UCSC \"genePredExt\" record. refGene files are in this format.\n *\n * Same as genePred but with additional columns:\n * ..., score, name2, cdsStartStat, cdsEndStat, exonFrames\n *\n * @param tokens - Tab-split fields from a single line\n * @param shift - 1 if the record has a leading `bin` column (refGene), 0 otherwise\n */\nexport function decodeGenePredExt(tokens: string[], shift: 0 | 1 = 0): AnnotationFeature | undefined {\n if (tokens.length <= 11 + shift) return undefined\n\n const cdStart = parseInt(tokens[5 + shift])\n const cdEnd = parseInt(tokens[6 + shift])\n\n const feature: AnnotationFeature = {\n name: tokens[11 + shift],\n chr: tokens[1 + shift],\n strand: parseStrand(tokens[2 + shift]),\n start: parseInt(tokens[3 + shift]),\n end: parseInt(tokens[4 + shift]),\n cdStart,\n cdEnd,\n id: tokens[0 + shift],\n }\n\n // Score (column 10+shift, if present)\n if (tokens.length > 10 + shift) {\n const s = parseInt(tokens[10 + shift])\n if (!isNaN(s)) feature.score = s\n }\n\n // cdsStartStat / cdsEndStat (columns 12-13+shift)\n if (tokens.length > 13 + shift) {\n feature.cdsStartStat = tokens[12 + shift]\n feature.cdsEndStat = tokens[13 + shift]\n }\n\n // exonFrames is column 14+shift\n const exons = decodeExons(\n parseInt(tokens[7 + shift]),\n tokens[8 + shift],\n tokens[9 + shift],\n tokens[14 + shift],\n )\n findUTRs(exons, cdStart, cdEnd)\n feature.exons = exons\n\n return feature\n}\n\n/**\n * Decode a UCSC REST API JSON record into a AnnotationFeature.\n *\n * The UCSC API returns JSON objects with the same fields as the text format\n * but as named properties instead of positional columns.\n */\nexport function decodeRefGeneJson(rec: RefGeneRecord): AnnotationFeature {\n const cdStart = rec.cdsStart\n const cdEnd = rec.cdsEnd\n\n const feature: AnnotationFeature = {\n name: rec.name2,\n chr: rec.chrom,\n strand: parseStrand(rec.strand),\n start: rec.txStart,\n end: rec.txEnd,\n cdStart,\n cdEnd,\n id: rec.name,\n }\n\n if (rec.score !== undefined) feature.score = rec.score\n if (rec.cdsStartStat) feature.cdsStartStat = rec.cdsStartStat\n if (rec.cdsEndStat) feature.cdsEndStat = rec.cdsEndStat\n\n const exonStarts = rec.exonStarts.replace(/,$/, '').split(',')\n const exonEnds = rec.exonEnds.replace(/,$/, '').split(',')\n const frameOffsets = rec.exonFrames\n ? rec.exonFrames.replace(/,$/, '').split(',')\n : undefined\n\n const exons: Exon[] = []\n for (let i = 0; i < rec.exonCount; i++) {\n const start = parseInt(exonStarts[i])\n const end = parseInt(exonEnds[i])\n const exon: Exon = {start, end}\n if (frameOffsets) {\n const fo = parseInt(frameOffsets[i])\n if (fo !== -1) exon.readingFrame = fo\n }\n exons.push(exon)\n }\n findUTRs(exons, cdStart, cdEnd)\n feature.exons = exons\n\n return feature\n}\n\n/** Shape of a record returned by the UCSC REST API for ncbiRefSeq/refGene tracks. */\nexport interface RefGeneRecord {\n bin?: number\n name: string\n name2: string\n chrom: string\n strand: string\n txStart: number\n txEnd: number\n cdsStart: number\n cdsEnd: number\n exonCount: number\n exonStarts: string\n exonEnds: string\n score?: number\n cdsStartStat?: string\n cdsEndStat?: string\n exonFrames?: string\n}\n\n// --- Internal helpers ---\n\n/**\n * Parse exons from comma-separated start/end strings.\n * Matches js/feature/decode/ucsc.ts::decodeExons.\n */\nfunction decodeExons(\n exonCount: number,\n startsString: string,\n endsString: string,\n frameOffsetsString?: string,\n): Exon[] {\n const exonStarts = startsString.replace(/,$/, '').split(',')\n const exonEnds = endsString.replace(/,$/, '').split(',')\n const frameOffsets = frameOffsetsString\n ? frameOffsetsString.replace(/,$/, '').split(',')\n : undefined\n\n const exons: Exon[] = []\n for (let i = 0; i < exonCount; i++) {\n const start = parseInt(exonStarts[i])\n const end = parseInt(exonEnds[i])\n const exon: Exon = {start, end}\n if (frameOffsets) {\n const fo = parseInt(frameOffsets[i])\n if (fo !== -1) exon.readingFrame = fo\n }\n exons.push(exon)\n }\n return exons\n}\n","/**\n * UCSC Genome Browser REST API client.\n *\n * Fetches gene annotation data from the UCSC REST API and decodes it\n * into GeneFeature objects using the same parsing logic as igv.js.\n *\n * API docs: https://genome.ucsc.edu/goldenPath/help/api.html\n */\n\nimport type {AnnotationFeature, Locus} from '../types'\nimport {decodeRefGeneJson} from '../decode/ucsc'\nimport type {RefGeneRecord} from '../decode/ucsc'\n\nconst UCSC_API_BASE = 'https://api.genome.ucsc.edu'\n\nexport interface FetchGenesOptions {\n /** Genome assembly, e.g. \"hg38\", \"hg19\", \"mm10\". Default: \"hg38\". */\n genome?: string\n /** UCSC track name, e.g. \"ncbiRefSeq\", \"knownGene\". Default: \"ncbiRefSeq\". */\n track?: string\n}\n\n/**\n * Fetch gene features for a genomic region from the UCSC REST API.\n *\n * Uses the same ncbiRefSeq track that igv.js loads by default for hg38.\n */\nexport async function fetchGeneFeatures(\n locus: Locus,\n options: FetchGenesOptions = {},\n signal?: AbortSignal,\n): Promise<AnnotationFeature[]> {\n const genome = options.genome ?? 'hg38'\n const track = options.track ?? 'ncbiRefSeq'\n\n const url = `${UCSC_API_BASE}/getData/track?genome=${genome}&track=${track}&chrom=${locus.chr}&start=${locus.start}&end=${locus.end}`\n const resp = await fetch(url, signal ? {signal} : undefined)\n\n if (!resp.ok) {\n throw new Error(`UCSC API error: ${resp.status} ${resp.statusText}`)\n }\n\n const data = await resp.json()\n const records: RefGeneRecord[] = data[track] ?? []\n return records.map(decodeRefGeneJson)\n}\n","import type {DataSource, Locus, AnnotationFeature} from '../types'\nimport type {CumulativeOffsets} from '../genome/chromSizes'\nimport {fetchGeneFeatures} from '../data/ucscApi'\nimport type {FetchGenesOptions} from '../data/ucscApi'\nimport {isWholeGenomeView} from '../locusUtils'\n\n/** Maximum number of WG features to avoid rendering performance issues (reservoir sampling). */\nconst MAX_WG_FEATURES = 10_000\n\nexport class GeneDataSource implements DataSource<AnnotationFeature> {\n private _cumulativeOffsets?: CumulativeOffsets\n\n constructor(private options: FetchGenesOptions = {}) {}\n\n /** Set cumulative offsets for whole genome view coordinate transformation. */\n setCumulativeOffsets(offsets: CumulativeOffsets): void {\n this._cumulativeOffsets = offsets\n }\n\n async fetch(locus: Locus, _bpPerPixel: number, signal: AbortSignal): Promise<AnnotationFeature[]> {\n if (isWholeGenomeView(locus) && this._cumulativeOffsets) {\n return this.fetchWG(signal)\n }\n return fetchGeneFeatures(locus, this.options, signal)\n }\n\n /**\n * Fetch genes for all main chromosomes and transform to genome-wide coordinates.\n * Follows igv.js computeWGFeatures() pattern: strips exons, downsamples.\n */\n private async fetchWG(signal: AbortSignal): Promise<AnnotationFeature[]> {\n const offsets = this._cumulativeOffsets!\n\n // Fetch all chromosomes in parallel\n const promises = offsets.chromosomeNames.map(chr =>\n fetchGeneFeatures({chr, start: 0, end: Number.MAX_SAFE_INTEGER}, this.options, signal)\n .catch(() => [] as AnnotationFeature[]) // Skip chromosomes that fail\n )\n\n const perChromResults = await Promise.all(promises)\n\n // Transform to genome-wide coordinates, strip exons for WG scale\n const wgFeatures: AnnotationFeature[] = []\n for (let i = 0; i < offsets.chromosomeNames.length; i++) {\n const chr = offsets.chromosomeNames[i]\n const offset = offsets.offsets[chr]\n if (offset === undefined) continue\n\n for (const f of perChromResults[i]) {\n wgFeatures.push({\n ...f,\n chr: 'all',\n start: offset + f.start,\n end: offset + f.end,\n // Strip detailed structure — too zoomed out\n exons: undefined,\n cdStart: undefined,\n cdEnd: undefined,\n })\n }\n }\n\n // Downsample with reservoir sampling if too many features\n if (wgFeatures.length > MAX_WG_FEATURES) {\n return reservoirSample(wgFeatures, MAX_WG_FEATURES)\n }\n\n return wgFeatures\n }\n}\n\n/** Reservoir sampling — uniform random sample of k items from an array. */\nfunction reservoirSample<T>(items: T[], k: number): T[] {\n const reservoir = items.slice(0, k)\n for (let i = k; i < items.length; i++) {\n const j = Math.floor(Math.random() * (i + 1))\n if (j < k) {\n reservoir[j] = items[i]\n }\n }\n return reservoir\n}\n","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\r\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\r\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\r\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\r\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\r\n var _, done = false;\r\n for (var i = decorators.length - 1; i >= 0; i--) {\r\n var context = {};\r\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\r\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\r\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\r\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\r\n if (kind === \"accessor\") {\r\n if (result === void 0) continue;\r\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\r\n if (_ = accept(result.get)) descriptor.get = _;\r\n if (_ = accept(result.set)) descriptor.set = _;\r\n if (_ = accept(result.init)) initializers.unshift(_);\r\n }\r\n else if (_ = accept(result)) {\r\n if (kind === \"field\") initializers.unshift(_);\r\n else descriptor[key] = _;\r\n }\r\n }\r\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\r\n done = true;\r\n};\r\n\r\nexport function __runInitializers(thisArg, initializers, value) {\r\n var useValue = arguments.length > 2;\r\n for (var i = 0; i < initializers.length; i++) {\r\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\r\n }\r\n return useValue ? value : void 0;\r\n};\r\n\r\nexport function __propKey(x) {\r\n return typeof x === \"symbol\" ? x : \"\".concat(x);\r\n};\r\n\r\nexport function __setFunctionName(f, name, prefix) {\r\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\r\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\r\n};\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\r\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\r\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nvar ownKeys = function(o) {\r\n ownKeys = Object.getOwnPropertyNames || function (o) {\r\n var ar = [];\r\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\r\n return ar;\r\n };\r\n return ownKeys(o);\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n\r\nexport function __addDisposableResource(env, value, async) {\r\n if (value !== null && value !== void 0) {\r\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\r\n var dispose, inner;\r\n if (async) {\r\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\r\n dispose = value[Symbol.asyncDispose];\r\n }\r\n if (dispose === void 0) {\r\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\r\n dispose = value[Symbol.dispose];\r\n if (async) inner = dispose;\r\n }\r\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\r\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\r\n env.stack.push({ value: value, dispose: dispose, async: async });\r\n }\r\n else if (async) {\r\n env.stack.push({ async: true });\r\n }\r\n return value;\r\n\r\n}\r\n\r\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\r\n var e = new Error(message);\r\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\r\n};\r\n\r\nexport function __disposeResources(env) {\r\n function fail(e) {\r\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\r\n env.hasError = true;\r\n }\r\n var r, s = 0;\r\n function next() {\r\n while (r = env.stack.pop()) {\r\n try {\r\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\r\n if (r.dispose) {\r\n var result = r.dispose.call(r.value);\r\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\r\n }\r\n else s |= 1;\r\n }\r\n catch (e) {\r\n fail(e);\r\n }\r\n }\r\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\r\n if (env.hasError) throw env.error;\r\n }\r\n return next();\r\n}\r\n\r\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\r\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\r\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\r\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\r\n });\r\n }\r\n return path;\r\n}\r\n\r\nexport default {\r\n __extends: __extends,\r\n __assign: __assign,\r\n __rest: __rest,\r\n __decorate: __decorate,\r\n __param: __param,\r\n __esDecorate: __esDecorate,\r\n __runInitializers: __runInitializers,\r\n __propKey: __propKey,\r\n __setFunctionName: __setFunctionName,\r\n __metadata: __metadata,\r\n __awaiter: __awaiter,\r\n __generator: __generator,\r\n __createBinding: __createBinding,\r\n __exportStar: __exportStar,\r\n __values: __values,\r\n __read: __read,\r\n __spread: __spread,\r\n __spreadArrays: __spreadArrays,\r\n __spreadArray: __spreadArray,\r\n __await: __await,\r\n __asyncGenerator: __asyncGenerator,\r\n __asyncDelegator: __asyncDelegator,\r\n __asyncValues: __asyncValues,\r\n __makeTemplateObject: __makeTemplateObject,\r\n __importStar: __importStar,\r\n __importDefault: __importDefault,\r\n __classPrivateFieldGet: __classPrivateFieldGet,\r\n __classPrivateFieldSet: __classPrivateFieldSet,\r\n __classPrivateFieldIn: __classPrivateFieldIn,\r\n __addDisposableResource: __addDisposableResource,\r\n __disposeResources: __disposeResources,\r\n __rewriteRelativeImportExtension: __rewriteRelativeImportExtension,\r\n};\r\n","/**\n * Augmented red-black interval tree for efficient overlap queries.\n *\n * Port of igv.js `js/intervalTree.ts` (CLR-based implementation).\n * Typed generically — values stored in intervals are `T` instead of `unknown`.\n *\n * Each node stores augmented min/max for its subtree, enabling O(log n + k)\n * overlap queries via subtree pruning.\n *\n * Layer 1 (Data + Layout) — pure data structure, no DOM, no canvas.\n */\n\nconst BLACK = 1\nconst RED = 2\n\n/** An interval with an associated value. */\nexport interface Interval<T = unknown> {\n low: number\n high: number\n value: T\n}\n\ninterface TreeNode<T> {\n color: number\n parent: TreeNode<T>\n left: TreeNode<T>\n right: TreeNode<T>\n interval: Interval<T>\n /** Augmented: maximum high value in this subtree. */\n max: number\n /** Augmented: minimum low value in this subtree. */\n min: number\n}\n\n// Shared NIL sentinel — avoids null checks throughout.\n// Self-referential: NIL.parent = NIL.left = NIL.right = NIL.\nconst NIL = {} as TreeNode<never>\nNIL.color = BLACK\nNIL.parent = NIL\nNIL.left = NIL\nNIL.right = NIL\n// NIL needs valid min/max for comparisons in applyUpdate.\n// Use +Infinity/-Infinity so NIL never wins min/max comparisons.\nNIL.min = Infinity\nNIL.max = -Infinity\n\n/**\n * Augmented red-black interval tree.\n *\n * Public API:\n * - `insert(start, end, value)` — O(log n) insertion\n * - `findOverlapping(start, end)` — O(log n + k) query, returns sorted intervals\n * - `mapIntervals(fn)` — apply function to every interval (in-order)\n */\nexport class IntervalTree<T = unknown> {\n root: TreeNode<T>\n\n constructor() {\n this.root = NIL as TreeNode<T>\n }\n\n /**\n * Insert an interval [start, end] with associated value.\n * Maintains red-black balance and augmented min/max.\n */\n insert(start: number, end: number, value: T): void {\n const interval: Interval<T> = {low: start, high: end, value}\n const x = this.#createNode(interval)\n this.#treeInsert(x)\n x.color = RED\n let node = x\n while (node !== this.root && node.parent.color === RED) {\n if (node.parent === node.parent.parent.left) {\n const y = node.parent.parent.right\n if (y.color === RED) {\n node.parent.color = BLACK\n y.color = BLACK\n node.parent.parent.color = RED\n node = node.parent.parent\n } else {\n if (node === node.parent.right) {\n node = node.parent\n this.#leftRotate(node)\n }\n node.parent.color = BLACK\n node.parent.parent.color = RED\n this.#rightRotate(node.parent.parent)\n }\n } else {\n const y = node.parent.parent.left\n if (y.color === RED) {\n node.parent.color = BLACK\n y.color = BLACK\n node.parent.parent.color = RED\n node = node.parent.parent\n } else {\n if (node === node.parent.left) {\n node = node.parent\n this.#rightRotate(node)\n }\n node.parent.color = BLACK\n node.parent.parent.color = RED\n this.#leftRotate(node.parent.parent)\n }\n }\n }\n this.root.color = BLACK\n }\n\n /**\n * Find all intervals overlapping [start, end].\n * Returns intervals sorted by `low` value.\n */\n findOverlapping(start: number, end: number): Interval<T>[] {\n if (this.root === (NIL as TreeNode<T>)) return []\n\n const results = this.#searchAll(start, end, this.root, [])\n\n if (results.length > 1) {\n results.sort((a, b) => a.low - b.low)\n }\n\n return results\n }\n\n /**\n * Apply a function to every interval in the tree.\n */\n mapIntervals(fn: (interval: Interval<T>) => void): void {\n const applyInterval = (node: TreeNode<T>): void => {\n fn(node.interval)\n if (node.left !== (NIL as TreeNode<T>)) applyInterval(node.left)\n if (node.right !== (NIL as TreeNode<T>)) applyInterval(node.right)\n }\n if (this.root !== (NIL as TreeNode<T>)) {\n applyInterval(this.root)\n }\n }\n\n #createNode(interval: Interval<T>): TreeNode<T> {\n return {\n parent: NIL as TreeNode<T>,\n left: NIL as TreeNode<T>,\n right: NIL as TreeNode<T>,\n interval,\n color: RED,\n max: interval.high,\n min: interval.low,\n }\n }\n\n #searchAll(low: number, high: number, node: TreeNode<T>, results: Interval<T>[]): Interval<T>[] {\n // Check if this node's interval overlaps the query\n if (node.interval.low <= high && low <= node.interval.high) {\n results.push(node.interval)\n }\n\n // Prune: left subtree can contain overlaps only if its max >= query low\n if (node.left !== (NIL as TreeNode<T>) && node.left.max >= low) {\n this.#searchAll(low, high, node.left, results)\n }\n\n // Prune: right subtree can contain overlaps only if its min <= query high\n if (node.right !== (NIL as TreeNode<T>) && node.right.min <= high) {\n this.#searchAll(low, high, node.right, results)\n }\n\n return results\n }\n\n #leftRotate(x: TreeNode<T>): void {\n const y = x.right\n x.right = y.left\n if (y.left !== (NIL as TreeNode<T>)) {\n y.left.parent = x\n }\n y.parent = x.parent\n if (x.parent === (NIL as TreeNode<T>)) {\n this.root = y\n } else {\n if (x.parent.left === x) {\n x.parent.left = y\n } else {\n x.parent.right = y\n }\n }\n y.left = x\n x.parent = y\n this.#applyUpdate(x)\n }\n\n #rightRotate(x: TreeNode<T>): void {\n const y = x.left\n x.left = y.right\n if (y.right !== (NIL as TreeNode<T>)) {\n y.right.parent = x\n }\n y.parent = x.parent\n if (x.parent === (NIL as TreeNode<T>)) {\n this.root = y\n } else {\n if (x.parent.right === x) {\n x.parent.right = y\n } else {\n x.parent.left = y\n }\n }\n y.right = x\n x.parent = y\n this.#applyUpdate(x)\n }\n\n /** Update augmented min/max from node up to root. */\n #applyUpdate(node: TreeNode<T>): void {\n while (node !== (NIL as TreeNode<T>)) {\n const nodeMax = node.left.max > node.right.max ? node.left.max : node.right.max\n const intervalHigh = node.interval.high\n node.max = nodeMax > intervalHigh ? nodeMax : intervalHigh\n\n const nodeMin = node.left.min < node.right.min ? node.left.min : node.right.min\n const intervalLow = node.interval.low\n node.min = nodeMin < intervalLow ? nodeMin : intervalLow\n\n node = node.parent\n }\n }\n\n /** BST insertion (no RB rebalancing — done by caller). */\n #treeInsert(x: TreeNode<T>): void {\n let node = this.root\n let y = NIL as TreeNode<T>\n while (node !== (NIL as TreeNode<T>)) {\n y = node\n if (x.interval.low <= node.interval.low) {\n node = node.left\n } else {\n node = node.right\n }\n }\n x.parent = y\n\n if (y === (NIL as TreeNode<T>)) {\n this.root = x\n x.left = x.right = NIL as TreeNode<T>\n } else {\n if (x.interval.low <= y.interval.low) {\n y.left = x\n } else {\n y.right = x\n }\n }\n\n this.#applyUpdate(x)\n }\n}\n","/**\n * Feature cache with interval-tree-backed spatial queries.\n *\n * Port of igv.js `js/feature/featureCache.ts`. Features are grouped by\n * chromosome, sorted, chunked, and indexed via IntervalTree for O(log n + k)\n * range queries.\n *\n * Layer 1 (Data + Layout) — pure data structure, no DOM, no canvas.\n */\n\nimport {IntervalTree} from './intervalTree'\n\n/** Minimal interface for features stored in the cache. */\nexport interface CacheableFeature {\n chr: string\n start: number\n end: number\n}\n\n/**\n * Range metadata describing what genomic region is fully cached.\n * When present, `containsRange()` delegates to this; when absent,\n * the cache is assumed to contain all features (e.g., whole-file load).\n */\nexport interface CacheRange {\n contains(chr: string, start: number, end: number): boolean\n}\n\n/** Index range pointing into the sorted allFeatures[chr] array. */\ninterface IndexRange {\n start: number\n end: number\n}\n\n/**\n * Spatial feature cache backed by per-chromosome interval trees.\n *\n * Features are chunked (max(10, len/10) per chunk) to reduce tree size\n * while maintaining fast overlap queries. Matches igv.js FeatureCache.\n *\n * @typeParam F - Feature type, must have chr/start/end at minimum.\n */\nexport class FeatureCache<F extends CacheableFeature> {\n /** Per-chromosome interval trees indexing feature chunks. */\n readonly treeMap: Record<string, IntervalTree<IndexRange>>\n /** Optional range metadata for partial-cache validation. */\n readonly range: CacheRange | undefined\n /** Total number of cached features across all chromosomes. */\n readonly count: number\n /** All features grouped by chromosome, sorted by start. */\n readonly allFeatures: Record<string, F[]>\n\n constructor(featureList?: F[], range?: CacheRange) {\n const features = featureList ?? []\n this.range = range\n this.count = features.length\n const {treeMap, allFeatures} = buildTreeMap(features)\n this.treeMap = treeMap\n this.allFeatures = allFeatures\n }\n\n /**\n * Check if the cache covers a genomic range.\n * Returns true when no range metadata is set (cache assumed complete)\n * or when the range metadata confirms coverage.\n */\n containsRange(chr: string, start: number, end: number): boolean {\n return this.range === undefined || this.range.contains(chr, start, end)\n }\n\n /**\n * Query features overlapping [start, end] on the given chromosome.\n * Returns features sorted by start position. O(log n + k) via interval tree.\n */\n queryFeatures(chr: string, start: number, end: number): F[] {\n const tree = this.treeMap[chr]\n if (!tree) return []\n\n const intervals = tree.findOverlapping(start, end)\n if (intervals.length === 0) return []\n\n // Trim features within matching chunks to the exact query range.\n // Relies on allFeatures[chr] being sorted by start.\n const featureList: F[] = []\n const all = this.allFeatures[chr]\n if (all) {\n for (const interval of intervals) {\n const indexRange = interval.value\n for (let i = indexRange.start; i < indexRange.end; i++) {\n const feature = all[i]\n if (feature.start > end) break\n else if (feature.end >= start) {\n featureList.push(feature)\n }\n }\n }\n featureList.sort((a, b) => a.start - b.start)\n }\n return featureList\n }\n\n /**\n * Search all cached features matching a predicate.\n * Scans every feature across all chromosomes — O(n).\n */\n findFeatures(fn: (f: F) => boolean): F[] {\n const found: F[] = []\n for (const featureList of Object.values(this.allFeatures)) {\n for (const f of featureList) {\n if (fn(f)) {\n found.push(f)\n }\n }\n }\n return found\n }\n\n /**\n * Returns all features grouped by chromosome.\n */\n getAllFeatures(): Record<string, F[]> {\n return this.allFeatures\n }\n}\n\n/**\n * Build per-chromosome interval trees from a feature list.\n *\n * Groups features by chr, sorts each group by start, chunks into groups\n * of max(10, len/10), and indexes chunk bounds in an interval tree.\n * This reduces tree size by 10x+ while maintaining fast overlap queries.\n */\nfunction buildTreeMap<F extends CacheableFeature>(\n featureList: F[],\n): {treeMap: Record<string, IntervalTree<IndexRange>>; allFeatures: Record<string, F[]>} {\n const treeMap: Record<string, IntervalTree<IndexRange>> = {}\n const allFeatures: Record<string, F[]> = {}\n const chromosomes: string[] = []\n\n // Group by chromosome\n for (const feature of featureList) {\n const chr = feature.chr\n let list = allFeatures[chr]\n if (!list) {\n chromosomes.push(chr)\n list = []\n allFeatures[chr] = list\n }\n list.push(feature)\n }\n\n // Build interval tree per chromosome\n for (const chr of chromosomes) {\n const chrFeatures = allFeatures[chr]\n chrFeatures.sort((a, b) => a.start === b.start ? 0 : (a.start > b.start ? 1 : -1))\n treeMap[chr] = buildIntervalTree(chrFeatures)\n }\n\n return {treeMap, allFeatures}\n}\n\n/**\n * Build an interval tree for a sorted feature array.\n *\n * Features are lumped into chunks of max(10, len/10) to reduce tree node\n * count. Each tree node stores the genomic extent of its chunk (min start,\n * max end) and an IndexRange pointing into the sorted array.\n */\nfunction buildIntervalTree<F extends CacheableFeature>(featureList: F[]): IntervalTree<IndexRange> {\n const tree = new IntervalTree<IndexRange>()\n const len = featureList.length\n const chunkSize = Math.max(10, Math.round(len / 10))\n\n for (let i = 0; i < len; i += chunkSize) {\n const e = Math.min(len, i + chunkSize)\n const subArray: IndexRange = {start: i, end: e}\n const iStart = featureList[i].start\n let iEnd = iStart\n for (let j = i; j < e; j++) {\n iEnd = Math.max(iEnd, featureList[j].end)\n }\n tree.insert(iStart, iEnd, subArray)\n }\n\n return tree\n}\n","function _has(obj, key) {\n return Object.prototype.hasOwnProperty.call(obj, key);\n}\nexport function assign(obj /*from1, from2, from3, ...*/) {\n var sources = Array.prototype.slice.call(arguments, 1);\n while (sources.length) {\n var source = sources.shift();\n if (!source) {\n continue;\n }\n if (typeof source !== 'object') {\n throw new TypeError(source + 'must be non-object');\n }\n for (var p in source) {\n if (_has(source, p)) {\n obj[p] = source[p];\n }\n }\n }\n return obj;\n}\n// reduce buffer size, avoiding mem copy\nexport function shrinkBuf(buf, size) {\n if (buf.length === size) {\n return buf;\n }\n if (buf.subarray) {\n return buf.subarray(0, size);\n }\n buf.length = size;\n return buf;\n}\nvar fnTyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n if (src.subarray && dest.subarray) {\n dest.set(src.subarray(src_offs, src_offs + len), dest_offs);\n return;\n }\n // Fallback to ordinary array\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n var i, l, len, pos, chunk, result;\n // calculate data length\n len = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n len += chunks[i].length;\n }\n // join chunks\n result = new Uint8Array(len);\n pos = 0;\n for (i = 0, l = chunks.length; i < l; i++) {\n chunk = chunks[i];\n result.set(chunk, pos);\n pos += chunk.length;\n }\n return result;\n },\n Buf8: function (size) {\n return new Uint8Array(size);\n },\n Buf16: function (size) {\n return new Uint16Array(size);\n },\n Buf32: function (size) {\n return new Int32Array(size);\n },\n};\nvar fnUntyped = {\n arraySet: function (dest, src, src_offs, len, dest_offs) {\n for (var i = 0; i < len; i++) {\n dest[dest_offs + i] = src[src_offs + i];\n }\n },\n // Join array of chunks to single array.\n flattenChunks: function (chunks) {\n return [].concat.apply([], chunks);\n },\n Buf8: function (size) {\n return new Array(size);\n },\n Buf16: function (size) {\n return new Array(size);\n },\n Buf32: function (size) {\n return new Array(size);\n },\n};\nlet typedOK = () => {\n const supported = typeof Uint8Array !== 'undefined' &&\n typeof Uint16Array !== 'undefined' &&\n typeof Int32Array !== 'undefined';\n typedOK = () => supported;\n return supported;\n};\nexport let arraySet = (dest, src, src_offs, len, dest_offs) => {\n arraySet = typedOK() ? fnTyped.arraySet : fnUntyped.arraySet;\n return arraySet(dest, src, src_offs, len, dest_offs);\n};\nexport let flattenChunks = chunks => {\n flattenChunks = typedOK() ? fnTyped.flattenChunks : fnUntyped.flattenChunks;\n return flattenChunks(chunks);\n};\nexport let Buf8 = size => {\n Buf8 = typedOK() ? fnTyped.Buf8 : fnUntyped.Buf8;\n return Buf8(size);\n};\nexport let Buf16 = size => {\n Buf16 = typedOK() ? fnTyped.Buf16 : fnUntyped.Buf16;\n return Buf16(size);\n};\nexport let Buf32 = size => {\n Buf32 = typedOK() ? fnTyped.Buf32 : fnUntyped.Buf32;\n return Buf32(size);\n};\nexport function setTyped(on) {\n arraySet = on ? fnTyped.arraySet : fnUntyped.arraySet;\n flattenChunks = on ? fnTyped.flattenChunks : fnUntyped.flattenChunks;\n Buf8 = on ? fnTyped.Buf8 : fnUntyped.Buf8;\n Buf16 = on ? fnTyped.Buf16 : fnUntyped.Buf16;\n Buf32 = on ? fnTyped.Buf32 : fnUntyped.Buf32;\n}\n//# sourceMappingURL=common.js.map","// String encode/decode helpers\nimport { Buf8, shrinkBuf } from './common.js';\n// Quick check if we can use fast array to bin string conversion\n//\n// - apply(Array) can fail on Android 2.2\n// - apply(Uint8Array) can fail on iOS 5.1 Safari\nlet strApplyOK = function () {\n let result = true;\n try {\n String.fromCharCode.apply(null, [0]);\n }\n catch (_) {\n result = false;\n }\n strApplyOK = () => result;\n return result;\n};\nlet strApplyUintOK = function () {\n let result = true;\n try {\n String.fromCharCode.apply(null, new Uint8Array(1));\n }\n catch (_) {\n result = false;\n }\n strApplyUintOK = () => result;\n return result;\n};\nlet utf8len = function (c) {\n // Table with utf8 lengths (calculated by first byte of sequence)\n // Note, that 5 & 6-byte values and some 4-byte values can not be represented in JS,\n // because max possible codepoint is 0x10ffff\n var table = Buf8(256);\n for (var q = 0; q < 256; q++) {\n table[q] =\n q >= 252\n ? 6\n : q >= 248\n ? 5\n : q >= 240\n ? 4\n : q >= 224\n ? 3\n : q >= 192\n ? 2\n : 1;\n }\n table[254] = table[254] = 1; // Invalid sequence start\n utf8len = arg => table[arg];\n return table[c];\n};\n// convert string to array (typed, when possible)\nexport function string2buf(str) {\n var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0;\n // count binary size\n for (m_pos = 0; m_pos < str_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && m_pos + 1 < str_len) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n buf_len += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\n }\n // allocate buffer\n buf = new Uint8Array(buf_len);\n // convert\n for (i = 0, m_pos = 0; i < buf_len; m_pos++) {\n c = str.charCodeAt(m_pos);\n if ((c & 0xfc00) === 0xd800 && m_pos + 1 < str_len) {\n c2 = str.charCodeAt(m_pos + 1);\n if ((c2 & 0xfc00) === 0xdc00) {\n c = 0x10000 + ((c - 0xd800) << 10) + (c2 - 0xdc00);\n m_pos++;\n }\n }\n if (c < 0x80) {\n /* one byte */\n buf[i++] = c;\n }\n else if (c < 0x800) {\n /* two bytes */\n buf[i++] = 0xc0 | (c >>> 6);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n else if (c < 0x10000) {\n /* three bytes */\n buf[i++] = 0xe0 | (c >>> 12);\n buf[i++] = 0x80 | ((c >>> 6) & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n else {\n /* four bytes */\n buf[i++] = 0xf0 | (c >>> 18);\n buf[i++] = 0x80 | ((c >>> 12) & 0x3f);\n buf[i++] = 0x80 | ((c >>> 6) & 0x3f);\n buf[i++] = 0x80 | (c & 0x3f);\n }\n }\n return buf;\n}\n// Helper (used in 2 places)\nfunction _buf2binstring(buf, len) {\n // On Chrome, the arguments in a function call that are allowed is `65534`.\n // If the length of the buffer is smaller than that, we can use this optimization,\n // otherwise we will take a slower path.\n if (len < 65534) {\n if ((buf.subarray && strApplyUintOK()) || (!buf.subarray && strApplyOK())) {\n return String.fromCharCode.apply(null, shrinkBuf(buf, len));\n }\n }\n var result = '';\n for (var i = 0; i < len; i++) {\n result += String.fromCharCode(buf[i]);\n }\n return result;\n}\n// Convert byte array to binary string\nexport function buf2binstring(buf) {\n return _buf2binstring(buf, buf.length);\n}\n// Convert binary string (typed, when possible)\nexport function binstring2buf(str) {\n var buf = new Uint8Array(str.length);\n for (var i = 0, len = buf.length; i < len; i++) {\n buf[i] = str.charCodeAt(i);\n }\n return buf;\n}\n// convert array to string\nexport function buf2string(buf, max) {\n var i, out, c, c_len;\n var len = max || buf.length;\n // Reserve max possible length (2 words per char)\n // NB: by unknown reasons, Array is significantly faster for\n // String.fromCharCode.apply than Uint16Array.\n var utf16buf = new Array(len * 2);\n for (out = 0, i = 0; i < len;) {\n c = buf[i++];\n // quick process ascii\n if (c < 0x80) {\n utf16buf[out++] = c;\n continue;\n }\n c_len = utf8len(c);\n // skip 5 & 6 byte codes\n if (c_len > 4) {\n utf16buf[out++] = 0xfffd;\n i += c_len - 1;\n continue;\n }\n // apply mask on first byte\n c &= c_len === 2 ? 0x1f : c_len === 3 ? 0x0f : 0x07;\n // join the rest\n while (c_len > 1 && i < len) {\n c = (c << 6) | (buf[i++] & 0x3f);\n c_len--;\n }\n // terminated by end of string?\n if (c_len > 1) {\n utf16buf[out++] = 0xfffd;\n continue;\n }\n if (c < 0x10000) {\n utf16buf[out++] = c;\n }\n else {\n c -= 0x10000;\n utf16buf[out++] = 0xd800 | ((c >> 10) & 0x3ff);\n utf16buf[out++] = 0xdc00 | (c & 0x3ff);\n }\n }\n return _buf2binstring(utf16buf, out);\n}\n// Calculate max possible position in utf8 buffer,\n// that will not break sequence. If that's not possible\n// - (very small limits) return max size as is.\n//\n// buf[] - utf8 bytes array\n// max - length limit (mandatory);\nexport function utf8border(buf, max) {\n var pos;\n max = max || buf.length;\n if (max > buf.length) {\n max = buf.length;\n }\n // go back from last position, until start of sequence found\n pos = max - 1;\n while (pos >= 0 && (buf[pos] & 0xc0) === 0x80) {\n pos--;\n }\n // Very small and broken sequence,\n // return max, because we should return something anyway.\n if (pos < 0) {\n return max;\n }\n // If we came to start of buffer - that means buffer is too small,\n // return max too.\n if (pos === 0) {\n return max;\n }\n return pos + utf8len(buf[pos]) > max ? pos : max;\n}\n//# sourceMappingURL=strings.js.map","// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\nexport default function GZheader() {\n /* true if compressed data believed to be text */\n this.text = 0;\n /* modification time */\n this.time = 0;\n /* extra flags (not used when writing a gzip file) */\n this.xflags = 0;\n /* operating system */\n this.os = 0;\n /* pointer to extra field or Z_NULL if none */\n this.extra = null;\n /* extra field length (valid if extra != Z_NULL) */\n this.extra_len = 0; // Actually, we don't need it in JS,\n // but leave for few code modifications\n //\n // Setup limits is not necessary because in js we should not preallocate memory\n // for inflate use constant limit in 65536 bytes\n //\n /* space at extra (only when reading header) */\n // this.extra_max = 0;\n /* pointer to zero-terminated file name or Z_NULL */\n this.name = '';\n /* space at name (only when reading header) */\n // this.name_max = 0;\n /* pointer to zero-terminated comment or Z_NULL */\n this.comment = '';\n /* space at comment (only when reading header) */\n // this.comm_max = 0;\n /* true if there was or will be a header crc */\n this.hcrc = 0;\n /* true when done reading gzip header (not used when writing a gzip file) */\n this.done = false;\n}\n//# sourceMappingURL=gzheader.js.map","// Note: adler32 takes 12% for level 0 and 2% for level 6.\n// It isn't worth it to make additional optimizations as in original.\n// Small size is preferable.\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\nexport default function adler32(adler, buf, len, pos) {\n var s1 = (adler & 0xffff) | 0, s2 = ((adler >>> 16) & 0xffff) | 0, n = 0;\n while (len !== 0) {\n // Set limit ~ twice less than 5552, to keep\n // s2 in 31-bits, because we force signed ints.\n // in other case %= will fail.\n n = len > 2000 ? 2000 : len;\n len -= n;\n do {\n s1 = (s1 + buf[pos++]) | 0;\n s2 = (s2 + s1) | 0;\n } while (--n);\n s1 %= 65521;\n s2 %= 65521;\n }\n return s1 | (s2 << 16) | 0;\n}\n//# sourceMappingURL=adler32.js.map","// Note: we can't get significant speed boost here.\n// So write code to minimize size - no pregenerated tables\n// and array tools dependencies.\n// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n// Use ordinary array, since untyped makes no boost here\nfunction makeTable() {\n var c, table = [];\n for (var n = 0; n < 256; n++) {\n c = n;\n for (var k = 0; k < 8; k++) {\n c = c & 1 ? 0xedb88320 ^ (c >>> 1) : c >>> 1;\n }\n table[n] = c;\n }\n return table;\n}\nlet crcTable = function () {\n const table = makeTable();\n crcTable = () => table;\n return table;\n};\nexport default function crc32(crc, buf, len, pos) {\n var t = crcTable(), end = pos + len;\n crc ^= -1;\n for (var i = pos; i < end; i++) {\n crc = (crc >>> 8) ^ t[(crc ^ buf[i]) & 0xff];\n }\n return crc ^ -1; // >>> 0;\n}\n//# sourceMappingURL=crc32.js.map","// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n// See state defs from inflate.js\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\n/*\n Decode literal, length, and distance codes and write out the resulting\n literal and match bytes until either not enough input or output is\n available, an end-of-block is encountered, or a data error is encountered.\n When large enough input and output buffers are supplied to inflate(), for\n example, a 16K input buffer and a 64K output buffer, more than 95% of the\n inflate execution time is spent in this routine.\n\n Entry assumptions:\n\n state.mode === LEN\n strm.avail_in >= 6\n strm.avail_out >= 258\n start >= strm.avail_out\n state.bits < 8\n\n On return, state.mode is one of:\n\n LEN -- ran out of enough output space or enough available input\n TYPE -- reached end of block code, inflate() to interpret next block\n BAD -- error in block data\n\n Notes:\n\n - The maximum input bits used by a length/distance pair is 15 bits for the\n length code, 5 bits for the length extra, 15 bits for the distance code,\n and 13 bits for the distance extra. This totals 48 bits, or six bytes.\n Therefore if strm.avail_in >= 6, then there is enough input to avoid\n checking for available input while decoding.\n\n - The maximum bytes that a single length/distance pair can output is 258\n bytes, which is the maximum length that can be coded. inflate_fast()\n requires strm.avail_out >= 258 for each loop to avoid checking for\n output space.\n */\nexport default function inflate_fast(strm, start) {\n var state;\n var _in; /* local strm.input */\n var last; /* have enough input while in < last */\n var _out; /* local strm.output */\n var beg; /* inflate()'s initial strm.output */\n var end; /* while out < end, enough space available */\n //#ifdef INFLATE_STRICT\n var dmax; /* maximum distance from zlib header */\n //#endif\n var wsize; /* window size or zero if not using window */\n var whave; /* valid bytes in the window */\n var wnext; /* window write index */\n // Use `s_window` instead `window`, avoid conflict with instrumentation tools\n var s_window; /* allocated sliding window, if wsize != 0 */\n var hold; /* local strm.hold */\n var bits; /* local strm.bits */\n var lcode; /* local strm.lencode */\n var dcode; /* local strm.distcode */\n var lmask; /* mask for first level of length codes */\n var dmask; /* mask for first level of distance codes */\n var here; /* retrieved table entry */\n var op; /* code bits, operation, extra bits, or */\n /* window position, window bytes to copy */\n var len; /* match length, unused bytes */\n var dist; /* match distance */\n var from; /* where to copy match from */\n var from_source;\n var input, output; // JS specific, because we have no pointers\n /* copy state to local variables */\n state = strm.state;\n //here = state.here;\n _in = strm.next_in;\n input = strm.input;\n last = _in + (strm.avail_in - 5);\n _out = strm.next_out;\n output = strm.output;\n beg = _out - (start - strm.avail_out);\n end = _out + (strm.avail_out - 257);\n //#ifdef INFLATE_STRICT\n dmax = state.dmax;\n //#endif\n wsize = state.wsize;\n whave = state.whave;\n wnext = state.wnext;\n s_window = state.window;\n hold = state.hold;\n bits = state.bits;\n lcode = state.lencode;\n dcode = state.distcode;\n lmask = (1 << state.lenbits) - 1;\n dmask = (1 << state.distbits) - 1;\n /* decode literals and length/distances until end-of-block or not enough\n input data or output space */\n top: do {\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = lcode[hold & lmask];\n dolen: for (;;) {\n // Goto emulation\n op = here >>> 24; /*here.bits*/\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff; /*here.op*/\n if (op === 0) {\n /* literal */\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n output[_out++] = here & 0xffff; /*here.val*/\n }\n else if (op & 16) {\n /* length base */\n len = here & 0xffff; /*here.val*/\n op &= 15; /* number of extra bits */\n if (op) {\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n len += hold & ((1 << op) - 1);\n hold >>>= op;\n bits -= op;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", len));\n if (bits < 15) {\n hold += input[_in++] << bits;\n bits += 8;\n hold += input[_in++] << bits;\n bits += 8;\n }\n here = dcode[hold & dmask];\n dodist: for (;;) {\n // goto emulation\n op = here >>> 24; /*here.bits*/\n hold >>>= op;\n bits -= op;\n op = (here >>> 16) & 0xff; /*here.op*/\n if (op & 16) {\n /* distance base */\n dist = here & 0xffff; /*here.val*/\n op &= 15; /* number of extra bits */\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n if (bits < op) {\n hold += input[_in++] << bits;\n bits += 8;\n }\n }\n dist += hold & ((1 << op) - 1);\n //#ifdef INFLATE_STRICT\n if (dist > dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n //#endif\n hold >>>= op;\n bits -= op;\n //Tracevv((stderr, \"inflate: distance %u\\n\", dist));\n op = _out - beg; /* max distance in output */\n if (dist > op) {\n /* see if copy from window */\n op = dist - op; /* distance back in window */\n if (op > whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break top;\n }\n // (!) This block is disabled in zlib defaults,\n // don't enable it for binary compatibility\n //#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n // if (len <= op - whave) {\n // do {\n // output[_out++] = 0;\n // } while (--len);\n // continue top;\n // }\n // len -= op - whave;\n // do {\n // output[_out++] = 0;\n // } while (--op > whave);\n // if (op === 0) {\n // from = _out - dist;\n // do {\n // output[_out++] = output[from++];\n // } while (--len);\n // continue top;\n // }\n //#endif\n }\n from = 0; // window index\n from_source = s_window;\n if (wnext === 0) {\n /* very common case */\n from += wsize - op;\n if (op < len) {\n /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n else if (wnext < op) {\n /* wrap around window */\n from += wsize + wnext - op;\n op -= wnext;\n if (op < len) {\n /* some from end of window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = 0;\n if (wnext < len) {\n /* some from start of window */\n op = wnext;\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n }\n else {\n /* contiguous in window */\n from += wnext - op;\n if (op < len) {\n /* some from window */\n len -= op;\n do {\n output[_out++] = s_window[from++];\n } while (--op);\n from = _out - dist; /* rest from output */\n from_source = output;\n }\n }\n while (len > 2) {\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n output[_out++] = from_source[from++];\n len -= 3;\n }\n if (len) {\n output[_out++] = from_source[from++];\n if (len > 1) {\n output[_out++] = from_source[from++];\n }\n }\n }\n else {\n from = _out - dist; /* copy direct from output */\n do {\n /* minimum length is three */\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n output[_out++] = output[from++];\n len -= 3;\n } while (len > 2);\n if (len) {\n output[_out++] = output[from++];\n if (len > 1) {\n output[_out++] = output[from++];\n }\n }\n }\n }\n else if ((op & 64) === 0) {\n /* 2nd level distance code */\n here =\n dcode[(here & 0xffff) /*here.val*/ + (hold & ((1 << op) - 1))];\n continue dodist;\n }\n else {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break top;\n }\n break; // need to emulate goto via \"continue\"\n }\n }\n else if ((op & 64) === 0) {\n /* 2nd level length code */\n here = lcode[(here & 0xffff) /*here.val*/ + (hold & ((1 << op) - 1))];\n continue dolen;\n }\n else if (op & 32) {\n /* end-of-block */\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.mode = TYPE;\n break top;\n }\n else {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break top;\n }\n break; // need to emulate goto via \"continue\"\n }\n } while (_in < last && _out < end);\n /* return unused bytes (on entry, bits < 8, so in won't go too far back) */\n len = bits >> 3;\n _in -= len;\n bits -= len << 3;\n hold &= (1 << bits) - 1;\n /* update state and return */\n strm.next_in = _in;\n strm.next_out = _out;\n strm.avail_in = _in < last ? 5 + (last - _in) : 5 - (_in - last);\n strm.avail_out = _out < end ? 257 + (end - _out) : 257 - (_out - end);\n state.hold = hold;\n state.bits = bits;\n return;\n}\n//# sourceMappingURL=inffast.js.map","// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\nimport { Buf16 } from '../utils/common.js';\nvar MAXBITS = 15;\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\nvar lbase = [\n /* Length codes 257..285 base */ 3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19,\n 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0,\n];\nvar lext = [\n /* Length codes 257..285 extra */ 16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17,\n 17, 18, 18, 18, 18, 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72,\n 78,\n];\nvar dbase = [\n /* Distance codes 0..29 base */ 1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65,\n 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193,\n 12289, 16385, 24577, 0, 0,\n];\nvar dext = [\n /* Distance codes 0..29 extra */ 16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20,\n 20, 21, 21, 22, 22, 23, 23, 24, 24, 25, 25, 26, 26, 27, 27, 28, 28, 29, 29,\n 64, 64,\n];\nexport default function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts) {\n var bits = opts.bits;\n //here = opts.here; /* table entry for duplication */\n var len = 0; /* a code's length in bits */\n var sym = 0; /* index of code symbols */\n var min = 0, max = 0; /* minimum and maximum code lengths */\n var root = 0; /* number of index bits for root table */\n var curr = 0; /* number of index bits for current table */\n var drop = 0; /* code bits to drop for sub-table */\n var left = 0; /* number of prefix codes available */\n var used = 0; /* code entries in table used */\n var huff = 0; /* Huffman code */\n var incr; /* for incrementing code, index */\n var fill; /* index for replicating entries */\n var low; /* low bits for current root entry */\n var mask; /* mask for low root bits */\n var next; /* next available space in table */\n var base = null; /* base value table to use */\n var base_index = 0;\n // var shoextra; /* extra bits table to use */\n var end; /* use base and extra for symbol > end */\n var count = Buf16(MAXBITS + 1); //[MAXBITS+1]; /* number of codes of each length */\n var offs = Buf16(MAXBITS + 1); //[MAXBITS+1]; /* offsets in table for each length */\n var extra = null;\n var extra_index = 0;\n var here_bits, here_op, here_val;\n /*\n Process a set of code lengths to create a canonical Huffman code. The\n code lengths are lens[0..codes-1]. Each length corresponds to the\n symbols 0..codes-1. The Huffman code is generated by first sorting the\n symbols by length from short to long, and retaining the symbol order\n for codes with equal lengths. Then the code starts with all zero bits\n for the first code of the shortest length, and the codes are integer\n increments for the same length, and zeros are appended as the length\n increases. For the deflate format, these bits are stored backwards\n from their more natural integer increment ordering, and so when the\n decoding tables are built in the large loop below, the integer codes\n are incremented backwards.\n \n This routine assumes, but does not check, that all of the entries in\n lens[] are in the range 0..MAXBITS. The caller must assure this.\n 1..MAXBITS is interpreted as that code length. zero means that that\n symbol does not occur in this code.\n \n The codes are sorted by computing a count of codes for each length,\n creating from that a table of starting indices for each length in the\n sorted table, and then entering the symbols in order in the sorted\n table. The sorted table is work[], with that space being provided by\n the caller.\n \n The length counts are used for other purposes as well, i.e. finding\n the minimum and maximum length codes, determining if there are any\n codes at all, checking for a valid set of lengths, and looking ahead\n at length counts to determine sub-table sizes when building the\n decoding tables.\n */\n /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */\n for (len = 0; len <= MAXBITS; len++) {\n count[len] = 0;\n }\n for (sym = 0; sym < codes; sym++) {\n count[lens[lens_index + sym]]++;\n }\n /* bound code lengths, force root to be within code lengths */\n root = bits;\n for (max = MAXBITS; max >= 1; max--) {\n if (count[max] !== 0) {\n break;\n }\n }\n if (root > max) {\n root = max;\n }\n if (max === 0) {\n /* no symbols to code at all */\n //table.op[opts.table_index] = 64; //here.op = (var char)64; /* invalid code marker */\n //table.bits[opts.table_index] = 1; //here.bits = (var char)1;\n //table.val[opts.table_index++] = 0; //here.val = (var short)0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n //table.op[opts.table_index] = 64;\n //table.bits[opts.table_index] = 1;\n //table.val[opts.table_index++] = 0;\n table[table_index++] = (1 << 24) | (64 << 16) | 0;\n opts.bits = 1;\n return 0; /* no symbols, but wait for decoding to report error */\n }\n for (min = 1; min < max; min++) {\n if (count[min] !== 0) {\n break;\n }\n }\n if (root < min) {\n root = min;\n }\n /* check for an over-subscribed or incomplete set of lengths */\n left = 1;\n for (len = 1; len <= MAXBITS; len++) {\n left <<= 1;\n left -= count[len];\n if (left < 0) {\n return -1;\n } /* over-subscribed */\n }\n if (left > 0 && (type === CODES || max !== 1)) {\n return -1; /* incomplete set */\n }\n /* generate offsets into symbol table for each length for sorting */\n offs[1] = 0;\n for (len = 1; len < MAXBITS; len++) {\n offs[len + 1] = offs[len] + count[len];\n }\n /* sort symbols by length, by symbol order within each length */\n for (sym = 0; sym < codes; sym++) {\n if (lens[lens_index + sym] !== 0) {\n work[offs[lens[lens_index + sym]]++] = sym;\n }\n }\n /*\n Create and fill in decoding tables. In this loop, the table being\n filled is at next and has curr index bits. The code being used is huff\n with length len. That code is converted to an index by dropping drop\n bits off of the bottom. For codes where len is less than drop + curr,\n those top drop + curr - len bits are incremented through all values to\n fill the table with replicated entries.\n \n root is the number of index bits for the root table. When len exceeds\n root, sub-tables are created pointed to by the root entry with an index\n of the low root bits of huff. This is saved in low to check for when a\n new sub-table should be started. drop is zero when the root table is\n being filled, and drop is root when sub-tables are being filled.\n \n When a new sub-table is needed, it is necessary to look ahead in the\n code lengths to determine what size sub-table is needed. The length\n counts are used for this, and so count[] is decremented as codes are\n entered in the tables.\n \n used keeps track of how many table entries have been allocated from the\n provided *table space. It is checked for LENS and DIST tables against\n the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in\n the initial root table size constants. See the comments in inftrees.h\n for more information.\n \n sym increments through all symbols, and the loop terminates when\n all codes of length max, i.e. all codes, have been processed. This\n routine permits incomplete codes, so another loop after this one fills\n in the rest of the decoding tables with invalid code markers.\n */\n /* set up for code type */\n // poor man optimization - use if-else instead of switch,\n // to avoid deopts in old v8\n if (type === CODES) {\n base = extra = work; /* dummy value--not used */\n end = 19;\n }\n else if (type === LENS) {\n base = lbase;\n base_index -= 257;\n extra = lext;\n extra_index -= 257;\n end = 256;\n }\n else {\n /* DISTS */\n base = dbase;\n extra = dext;\n end = -1;\n }\n /* initialize opts for loop */\n huff = 0; /* starting code */\n sym = 0; /* starting code symbol */\n len = min; /* starting code length */\n next = table_index; /* current table to fill in */\n curr = root; /* current table index bits */\n drop = 0; /* current bits to drop from code for index */\n low = -1; /* trigger new sub-table when len > root */\n used = 1 << root; /* use root table entries */\n mask = used - 1; /* mask for comparing low */\n /* check available table space */\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n /* process all codes and make table entries */\n for (;;) {\n /* create table entry */\n here_bits = len - drop;\n if (work[sym] < end) {\n here_op = 0;\n here_val = work[sym];\n }\n else if (work[sym] > end) {\n here_op = extra[extra_index + work[sym]];\n here_val = base[base_index + work[sym]];\n }\n else {\n here_op = 32 + 64; /* end of block */\n here_val = 0;\n }\n /* replicate for those indices with low len bits equal to huff */\n incr = 1 << (len - drop);\n fill = 1 << curr;\n min = fill; /* save offset to next table */\n do {\n fill -= incr;\n table[next + (huff >> drop) + fill] =\n (here_bits << 24) | (here_op << 16) | here_val | 0;\n } while (fill !== 0);\n /* backwards increment the len-bit code huff */\n incr = 1 << (len - 1);\n while (huff & incr) {\n incr >>= 1;\n }\n if (incr !== 0) {\n huff &= incr - 1;\n huff += incr;\n }\n else {\n huff = 0;\n }\n /* go to next symbol, update count, len */\n sym++;\n if (--count[len] === 0) {\n if (len === max) {\n break;\n }\n len = lens[lens_index + work[sym]];\n }\n /* create new sub-table if needed */\n if (len > root && (huff & mask) !== low) {\n /* if first time, transition to sub-tables */\n if (drop === 0) {\n drop = root;\n }\n /* increment past last table */\n next += min; /* here min is 1 << curr */\n /* determine length of next table */\n curr = len - drop;\n left = 1 << curr;\n while (curr + drop < max) {\n left -= count[curr + drop];\n if (left <= 0) {\n break;\n }\n curr++;\n left <<= 1;\n }\n /* check for enough space */\n used += 1 << curr;\n if ((type === LENS && used > ENOUGH_LENS) ||\n (type === DISTS && used > ENOUGH_DISTS)) {\n return 1;\n }\n /* point entry in root table to sub-table */\n low = huff & mask;\n /*table.op[low] = curr;\n table.bits[low] = root;\n table.val[low] = next - opts.table_index;*/\n table[low] = (root << 24) | (curr << 16) | (next - table_index) | 0;\n }\n }\n /* fill in remaining table entry if code is incomplete (guaranteed to have\n at most one remaining entry, since if the code is incomplete, the\n maximum code length that was allowed to get this far is one bit) */\n if (huff !== 0) {\n //table.op[next + huff] = 64; /* invalid code marker */\n //table.bits[next + huff] = len - drop;\n //table.val[next + huff] = 0;\n table[next + huff] = ((len - drop) << 24) | (64 << 16) | 0;\n }\n /* set return parameters */\n //opts.table_index += used;\n opts.bits = root;\n return 0;\n}\n//# sourceMappingURL=inftrees.js.map","// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\nimport adler32 from './adler32.js';\nimport crc32 from './crc32.js';\nimport inflate_fast from './inffast.js';\nimport inflate_table from './inftrees.js';\nimport { Buf16, Buf32, Buf8, arraySet } from '../utils/common.js';\nvar CODES = 0;\nvar LENS = 1;\nvar DISTS = 2;\n/* Public constants ==========================================================*/\n/* ===========================================================================*/\n/* Allowed flush values; see deflate() and inflate() below for details */\n//var Z_NO_FLUSH = 0;\n//var Z_PARTIAL_FLUSH = 1;\n//var Z_SYNC_FLUSH = 2;\n//var Z_FULL_FLUSH = 3;\nvar Z_FINISH = 4;\nvar Z_BLOCK = 5;\nvar Z_TREES = 6;\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nvar Z_OK = 0;\nvar Z_STREAM_END = 1;\nvar Z_NEED_DICT = 2;\n//var Z_ERRNO = -1;\nvar Z_STREAM_ERROR = -2;\nvar Z_DATA_ERROR = -3;\nvar Z_MEM_ERROR = -4;\nvar Z_BUF_ERROR = -5;\n//var Z_VERSION_ERROR = -6;\n/* The deflate compression method */\nvar Z_DEFLATED = 8;\n/* STATES ====================================================================*/\n/* ===========================================================================*/\nvar HEAD = 1; /* i: waiting for magic header */\nvar FLAGS = 2; /* i: waiting for method and flags (gzip) */\nvar TIME = 3; /* i: waiting for modification time (gzip) */\nvar OS = 4; /* i: waiting for extra flags and operating system (gzip) */\nvar EXLEN = 5; /* i: waiting for extra length (gzip) */\nvar EXTRA = 6; /* i: waiting for extra bytes (gzip) */\nvar NAME = 7; /* i: waiting for end of file name (gzip) */\nvar COMMENT = 8; /* i: waiting for end of comment (gzip) */\nvar HCRC = 9; /* i: waiting for header crc (gzip) */\nvar DICTID = 10; /* i: waiting for dictionary check value */\nvar DICT = 11; /* waiting for inflateSetDictionary() call */\nvar TYPE = 12; /* i: waiting for type bits, including last-flag bit */\nvar TYPEDO = 13; /* i: same, but skip check to exit inflate on new block */\nvar STORED = 14; /* i: waiting for stored size (length and complement) */\nvar COPY_ = 15; /* i/o: same as COPY below, but only first time in */\nvar COPY = 16; /* i/o: waiting for input or output to copy stored block */\nvar TABLE = 17; /* i: waiting for dynamic block table lengths */\nvar LENLENS = 18; /* i: waiting for code length code lengths */\nvar CODELENS = 19; /* i: waiting for length/lit and distance code lengths */\nvar LEN_ = 20; /* i: same as LEN below, but only first time in */\nvar LEN = 21; /* i: waiting for length/lit/eob code */\nvar LENEXT = 22; /* i: waiting for length extra bits */\nvar DIST = 23; /* i: waiting for distance code */\nvar DISTEXT = 24; /* i: waiting for distance extra bits */\nvar MATCH = 25; /* o: waiting for output space to copy string */\nvar LIT = 26; /* o: waiting for output space to write literal */\nvar CHECK = 27; /* i: waiting for 32-bit check value */\nvar LENGTH = 28; /* i: waiting for 32-bit length (gzip) */\nvar DONE = 29; /* finished check, done -- remain here until reset */\nvar BAD = 30; /* got a data error -- remain here until reset */\nvar MEM = 31; /* got an inflate() memory error -- remain here until reset */\nvar SYNC = 32; /* looking for synchronization bytes to restart inflate() */\n/* ===========================================================================*/\nvar ENOUGH_LENS = 852;\nvar ENOUGH_DISTS = 592;\n//var ENOUGH = (ENOUGH_LENS+ENOUGH_DISTS);\nvar MAX_WBITS = 15;\n/* 32K LZ77 window */\nvar DEF_WBITS = MAX_WBITS;\nfunction zswap32(q) {\n return (((q >>> 24) & 0xff) +\n ((q >>> 8) & 0xff00) +\n ((q & 0xff00) << 8) +\n ((q & 0xff) << 24));\n}\nfunction InflateState() {\n this.mode = 0; /* current inflate mode */\n this.last = false; /* true if processing last block */\n this.wrap = 0; /* bit 0 true for zlib, bit 1 true for gzip */\n this.havedict = false; /* true if dictionary provided */\n this.flags = 0; /* gzip header method and flags (0 if zlib) */\n this.dmax = 0; /* zlib header max distance (INFLATE_STRICT) */\n this.check = 0; /* protected copy of check value */\n this.total = 0; /* protected copy of output count */\n // TODO: may be {}\n this.head = null; /* where to save gzip header information */\n /* sliding window */\n this.wbits = 0; /* log base 2 of requested window size */\n this.wsize = 0; /* window size or zero if not using window */\n this.whave = 0; /* valid bytes in the window */\n this.wnext = 0; /* window write index */\n this.window = null; /* allocated sliding window, if needed */\n /* bit accumulator */\n this.hold = 0; /* input bit accumulator */\n this.bits = 0; /* number of bits in \"in\" */\n /* for string and stored block copying */\n this.length = 0; /* literal or length of data to copy */\n this.offset = 0; /* distance back to copy string from */\n /* for table and code decoding */\n this.extra = 0; /* extra bits needed */\n /* fixed and dynamic code tables */\n this.lencode = null; /* starting table for length/literal codes */\n this.distcode = null; /* starting table for distance codes */\n this.lenbits = 0; /* index bits for lencode */\n this.distbits = 0; /* index bits for distcode */\n /* dynamic table building */\n this.ncode = 0; /* number of code length code lengths */\n this.nlen = 0; /* number of length code lengths */\n this.ndist = 0; /* number of distance code lengths */\n this.have = 0; /* number of code lengths in lens[] */\n this.next = null; /* next available space in codes[] */\n this.lens = Buf16(320); /* temporary storage for code lengths */\n this.work = Buf16(288); /* work area for code table building */\n /*\n because we don't have pointers in js, we use lencode and distcode directly\n as buffers so we don't need codes\n */\n //this.codes = Buf32(ENOUGH); /* space for code tables */\n this.lendyn = null; /* dynamic table for length/literal codes (JS specific) */\n this.distdyn = null; /* dynamic table for distance codes (JS specific) */\n this.sane = 0; /* if false, allow invalid distance too far */\n this.back = 0; /* bits back of last unprocessed length/lit */\n this.was = 0; /* initial length of match */\n}\nexport function inflateResetKeep(strm) {\n var state;\n if (!strm || !strm.state) {\n return Z_STREAM_ERROR;\n }\n state = strm.state;\n strm.total_in = strm.total_out = state.total = 0;\n strm.msg = ''; /*Z_NULL*/\n if (state.wrap) {\n /* to support ill-conceived Java test suite */\n strm.adler = state.wrap & 1;\n }\n state.mode = HEAD;\n state.last = 0;\n state.havedict = 0;\n state.dmax = 32768;\n state.head = null; /*Z_NULL*/\n state.hold = 0;\n state.bits = 0;\n //state.lencode = state.distcode = state.next = state.codes;\n state.lencode = state.lendyn = Buf32(ENOUGH_LENS);\n state.distcode = state.distdyn = Buf32(ENOUGH_DISTS);\n state.sane = 1;\n state.back = -1;\n //Tracev((stderr, \"inflate: reset\\n\"));\n return Z_OK;\n}\nexport function inflateReset(strm) {\n var state;\n if (!strm || !strm.state) {\n return Z_STREAM_ERROR;\n }\n state = strm.state;\n state.wsize = 0;\n state.whave = 0;\n state.wnext = 0;\n return inflateResetKeep(strm);\n}\nexport function inflateReset2(strm, windowBits) {\n var wrap;\n var state;\n /* get the state */\n if (!strm || !strm.state) {\n return Z_STREAM_ERROR;\n }\n state = strm.state;\n /* extract wrap request from windowBits parameter */\n if (windowBits < 0) {\n wrap = 0;\n windowBits = -windowBits;\n }\n else {\n wrap = (windowBits >> 4) + 1;\n if (windowBits < 48) {\n windowBits &= 15;\n }\n }\n /* set number of window bits, free window if different */\n if (windowBits && (windowBits < 8 || windowBits > 15)) {\n return Z_STREAM_ERROR;\n }\n if (state.window !== null && state.wbits !== windowBits) {\n state.window = null;\n }\n /* update state and reset the rest of it */\n state.wrap = wrap;\n state.wbits = windowBits;\n return inflateReset(strm);\n}\nexport function inflateInit2(strm, windowBits) {\n var ret;\n var state;\n if (!strm) {\n return Z_STREAM_ERROR;\n }\n //strm.msg = Z_NULL; /* in case we return an error */\n state = new InflateState();\n //if (state === Z_NULL) return Z_MEM_ERROR;\n //Tracev((stderr, \"inflate: allocated\\n\"));\n strm.state = state;\n state.window = null; /*Z_NULL*/\n ret = inflateReset2(strm, windowBits);\n if (ret !== Z_OK) {\n strm.state = null; /*Z_NULL*/\n }\n return ret;\n}\nexport function inflateInit(strm) {\n return inflateInit2(strm, DEF_WBITS);\n}\n/*\n Return state with length and distance decoding tables and index sizes set to\n fixed code decoding. Normally this returns fixed tables from inffixed.h.\n If BUILDFIXED is defined, then instead this routine builds the tables the\n first time it's called, and returns those tables the first time and\n thereafter. This reduces the size of the code by about 2K bytes, in\n exchange for a little execution time. However, BUILDFIXED should not be\n used for threaded applications, since the rewriting of the tables and virgin\n may not be thread-safe.\n */\nvar virgin = true;\nvar lenfix, distfix; // We have no pointers in JS, so keep tables separate\nfunction fixedtables(state) {\n /* build fixed huffman tables if first call (may not be thread safe) */\n if (virgin) {\n var sym;\n lenfix = Buf32(512);\n distfix = Buf32(32);\n /* literal/length table */\n sym = 0;\n while (sym < 144) {\n state.lens[sym++] = 8;\n }\n while (sym < 256) {\n state.lens[sym++] = 9;\n }\n while (sym < 280) {\n state.lens[sym++] = 7;\n }\n while (sym < 288) {\n state.lens[sym++] = 8;\n }\n inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 });\n /* distance table */\n sym = 0;\n while (sym < 32) {\n state.lens[sym++] = 5;\n }\n inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, {\n bits: 5,\n });\n /* do this just once */\n virgin = false;\n }\n state.lencode = lenfix;\n state.lenbits = 9;\n state.distcode = distfix;\n state.distbits = 5;\n}\n/*\n Update the window with the last wsize (normally 32K) bytes written before\n returning. If window does not exist yet, create it. This is only called\n when a window is already in use, or when output has been written during this\n inflate call, but the end of the deflate stream has not been reached yet.\n It is also called to create a window for dictionary data when a dictionary\n is loaded.\n\n Providing output buffers larger than 32K to inflate() should provide a speed\n advantage, since only the last 32K of output is copied to the sliding window\n upon return from inflate(), and since all distances after the first 32K of\n output will fall in the output data, making match copies simpler and faster.\n The advantage may be dependent on the size of the processor's data caches.\n */\nfunction updatewindow(strm, src, end, copy) {\n var dist;\n var state = strm.state;\n /* if it hasn't been done already, allocate space for the window */\n if (state.window === null) {\n state.wsize = 1 << state.wbits;\n state.wnext = 0;\n state.whave = 0;\n state.window = Buf8(state.wsize);\n }\n /* copy state->wsize or less output bytes into the circular window */\n if (copy >= state.wsize) {\n arraySet(state.window, src, end - state.wsize, state.wsize, 0);\n state.wnext = 0;\n state.whave = state.wsize;\n }\n else {\n dist = state.wsize - state.wnext;\n if (dist > copy) {\n dist = copy;\n }\n //zmemcpy(state->window + state->wnext, end - copy, dist);\n arraySet(state.window, src, end - copy, dist, state.wnext);\n copy -= dist;\n if (copy) {\n //zmemcpy(state->window, end - copy, copy);\n arraySet(state.window, src, end - copy, copy, 0);\n state.wnext = copy;\n state.whave = state.wsize;\n }\n else {\n state.wnext += dist;\n if (state.wnext === state.wsize) {\n state.wnext = 0;\n }\n if (state.whave < state.wsize) {\n state.whave += dist;\n }\n }\n }\n return 0;\n}\nexport function inflate(strm, flush) {\n var state;\n var input, output; // input/output buffers\n var next; /* next input INDEX */\n var put; /* next output INDEX */\n var have, left; /* available input and output */\n var hold; /* bit buffer */\n var bits; /* bits in bit buffer */\n var _in, _out; /* save starting available input and output */\n var copy; /* number of stored or match bytes to copy */\n var from; /* where to copy match bytes from */\n var from_source;\n var here = 0; /* current decoding table entry */\n var here_bits, here_op, here_val; // paked \"here\" denormalized (JS specific)\n //var last; /* parent table entry */\n var last_bits, last_op, last_val; // paked \"last\" denormalized (JS specific)\n var len; /* length to copy for repeats, bits to drop */\n var ret; /* return code */\n var hbuf = Buf8(4); /* buffer for gzip header crc calculation */\n var opts;\n var n; // temporary var for NEED_BITS\n var order = \n /* permutation of code lengths */\n [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15];\n if (!strm ||\n !strm.state ||\n !strm.output ||\n (!strm.input && strm.avail_in !== 0)) {\n return Z_STREAM_ERROR;\n }\n state = strm.state;\n if (state.mode === TYPE) {\n state.mode = TYPEDO;\n } /* skip check */\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n _in = have;\n _out = left;\n ret = Z_OK;\n // goto emulation\n inf_leave: for (;;) {\n switch (state.mode) {\n case HEAD:\n if (state.wrap === 0) {\n state.mode = TYPEDO;\n break;\n }\n //=== NEEDBITS(16);\n while (bits < 16) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.wrap & 2 && hold === 0x8b1f) {\n /* gzip header */\n state.check = 0; /*crc32(0L, Z_NULL, 0)*/\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = FLAGS;\n break;\n }\n state.flags = 0; /* expect zlib header */\n if (state.head) {\n state.head.done = false;\n }\n if (!(state.wrap & 1) /* check if zlib header allowed */ ||\n (((hold & 0xff) /*BITS(8)*/ << 8) + (hold >> 8)) % 31) {\n strm.msg = 'incorrect header check';\n state.mode = BAD;\n break;\n }\n if ((hold & 0x0f) /*BITS(4)*/ !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n len = (hold & 0x0f) /*BITS(4)*/ + 8;\n if (state.wbits === 0) {\n state.wbits = len;\n }\n else if (len > state.wbits) {\n strm.msg = 'invalid window size';\n state.mode = BAD;\n break;\n }\n state.dmax = 1 << len;\n //Tracev((stderr, \"inflate: zlib header ok\\n\"));\n strm.adler = state.check = 1; /*adler32(0L, Z_NULL, 0)*/\n state.mode = hold & 0x200 ? DICTID : TYPE;\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n break;\n case FLAGS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.flags = hold;\n if ((state.flags & 0xff) !== Z_DEFLATED) {\n strm.msg = 'unknown compression method';\n state.mode = BAD;\n break;\n }\n if (state.flags & 0xe000) {\n strm.msg = 'unknown header flags set';\n state.mode = BAD;\n break;\n }\n if (state.head) {\n state.head.text = (hold >> 8) & 1;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = TIME;\n /* falls through */\n case TIME:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.time = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC4(state.check, hold)\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n hbuf[2] = (hold >>> 16) & 0xff;\n hbuf[3] = (hold >>> 24) & 0xff;\n state.check = crc32(state.check, hbuf, 4, 0);\n //===\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = OS;\n /* falls through */\n case OS:\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (state.head) {\n state.head.xflags = hold & 0xff;\n state.head.os = hold >> 8;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = EXLEN;\n /* falls through */\n case EXLEN:\n if (state.flags & 0x0400) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length = hold;\n if (state.head) {\n state.head.extra_len = hold;\n }\n if (state.flags & 0x0200) {\n //=== CRC2(state.check, hold);\n hbuf[0] = hold & 0xff;\n hbuf[1] = (hold >>> 8) & 0xff;\n state.check = crc32(state.check, hbuf, 2, 0);\n //===//\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n else if (state.head) {\n state.head.extra = null; /*Z_NULL*/\n }\n state.mode = EXTRA;\n /* falls through */\n case EXTRA:\n if (state.flags & 0x0400) {\n copy = state.length;\n if (copy > have) {\n copy = have;\n }\n if (copy) {\n if (state.head) {\n len = state.head.extra_len - state.length;\n if (!state.head.extra) {\n // Use untyped array for more convenient processing later\n state.head.extra = new Array(state.head.extra_len);\n }\n arraySet(state.head.extra, input, next, \n // extra field is limited to 65536 bytes\n // - no need for additional size check\n copy, \n /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/\n len);\n //zmemcpy(state.head.extra + len, next,\n // len + copy > state.head.extra_max ?\n // state.head.extra_max - len : copy);\n }\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n state.length -= copy;\n }\n if (state.length) {\n break inf_leave;\n }\n }\n state.length = 0;\n state.mode = NAME;\n /* falls through */\n case NAME:\n if (state.flags & 0x0800) {\n if (have === 0) {\n break inf_leave;\n }\n copy = 0;\n do {\n // TODO: 2 or 1 bytes?\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head &&\n len &&\n state.length < 65536 /*state.head.name_max*/) {\n state.head.name += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) {\n break inf_leave;\n }\n }\n else if (state.head) {\n state.head.name = null;\n }\n state.length = 0;\n state.mode = COMMENT;\n /* falls through */\n case COMMENT:\n if (state.flags & 0x1000) {\n if (have === 0) {\n break inf_leave;\n }\n copy = 0;\n do {\n len = input[next + copy++];\n /* use constant limit because in js we should not preallocate memory */\n if (state.head &&\n len &&\n state.length < 65536 /*state.head.comm_max*/) {\n state.head.comment += String.fromCharCode(len);\n }\n } while (len && copy < have);\n if (state.flags & 0x0200) {\n state.check = crc32(state.check, input, copy, next);\n }\n have -= copy;\n next += copy;\n if (len) {\n break inf_leave;\n }\n }\n else if (state.head) {\n state.head.comment = null;\n }\n state.mode = HCRC;\n /* falls through */\n case HCRC:\n if (state.flags & 0x0200) {\n //=== NEEDBITS(16); */\n while (bits < 16) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.check & 0xffff)) {\n strm.msg = 'header crc mismatch';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n }\n if (state.head) {\n state.head.hcrc = (state.flags >> 9) & 1;\n state.head.done = true;\n }\n strm.adler = state.check = 0;\n state.mode = TYPE;\n break;\n case DICTID:\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n strm.adler = state.check = zswap32(hold);\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = DICT;\n /* falls through */\n case DICT:\n if (state.havedict === 0) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n return Z_NEED_DICT;\n }\n strm.adler = state.check = 1; /*adler32(0L, Z_NULL, 0)*/\n state.mode = TYPE;\n /* falls through */\n case TYPE:\n if (flush === Z_BLOCK || flush === Z_TREES) {\n break inf_leave;\n }\n /* falls through */\n case TYPEDO:\n if (state.last) {\n //--- BYTEBITS() ---//\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n state.mode = CHECK;\n break;\n }\n //=== NEEDBITS(3); */\n while (bits < 3) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.last = hold & 0x01; /*BITS(1)*/\n //--- DROPBITS(1) ---//\n hold >>>= 1;\n bits -= 1;\n //---//\n switch (hold & 0x03 /*BITS(2)*/) {\n case 0 /* stored block */:\n //Tracev((stderr, \"inflate: stored block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = STORED;\n break;\n case 1 /* fixed block */:\n fixedtables(state);\n //Tracev((stderr, \"inflate: fixed codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = LEN_; /* decode codes */\n if (flush === Z_TREES) {\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break inf_leave;\n }\n break;\n case 2 /* dynamic block */:\n //Tracev((stderr, \"inflate: dynamic codes block%s\\n\",\n // state.last ? \" (last)\" : \"\"));\n state.mode = TABLE;\n break;\n case 3:\n strm.msg = 'invalid block type';\n state.mode = BAD;\n }\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n break;\n case STORED:\n //--- BYTEBITS() ---// /* go to byte boundary */\n hold >>>= bits & 7;\n bits -= bits & 7;\n //---//\n //=== NEEDBITS(32); */\n while (bits < 32) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if ((hold & 0xffff) !== ((hold >>> 16) ^ 0xffff)) {\n strm.msg = 'invalid stored block lengths';\n state.mode = BAD;\n break;\n }\n state.length = hold & 0xffff;\n //Tracev((stderr, \"inflate: stored length %u\\n\",\n // state.length));\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n state.mode = COPY_;\n if (flush === Z_TREES) {\n break inf_leave;\n }\n /* falls through */\n case COPY_:\n state.mode = COPY;\n /* falls through */\n case COPY:\n copy = state.length;\n if (copy) {\n if (copy > have) {\n copy = have;\n }\n if (copy > left) {\n copy = left;\n }\n if (copy === 0) {\n break inf_leave;\n }\n //--- zmemcpy(put, next, copy); ---\n arraySet(output, input, next, copy, put);\n //---//\n have -= copy;\n next += copy;\n left -= copy;\n put += copy;\n state.length -= copy;\n break;\n }\n //Tracev((stderr, \"inflate: stored end\\n\"));\n state.mode = TYPE;\n break;\n case TABLE:\n //=== NEEDBITS(14); */\n while (bits < 14) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.nlen = (hold & 0x1f) /*BITS(5)*/ + 257;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ndist = (hold & 0x1f) /*BITS(5)*/ + 1;\n //--- DROPBITS(5) ---//\n hold >>>= 5;\n bits -= 5;\n //---//\n state.ncode = (hold & 0x0f) /*BITS(4)*/ + 4;\n //--- DROPBITS(4) ---//\n hold >>>= 4;\n bits -= 4;\n //---//\n //#ifndef PKZIP_BUG_WORKAROUND\n if (state.nlen > 286 || state.ndist > 30) {\n strm.msg = 'too many length or distance symbols';\n state.mode = BAD;\n break;\n }\n //#endif\n //Tracev((stderr, \"inflate: table sizes ok\\n\"));\n state.have = 0;\n state.mode = LENLENS;\n /* falls through */\n case LENLENS:\n while (state.have < state.ncode) {\n //=== NEEDBITS(3);\n while (bits < 3) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.lens[order[state.have++]] = hold & 0x07; //BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n while (state.have < 19) {\n state.lens[order[state.have++]] = 0;\n }\n // We have separate tables & no pointers. 2 commented lines below not needed.\n //state.next = state.codes;\n //state.lencode = state.next;\n // Switch to use dynamic table\n state.lencode = state.lendyn;\n state.lenbits = 7;\n opts = { bits: state.lenbits };\n ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts);\n state.lenbits = opts.bits;\n if (ret) {\n strm.msg = 'invalid code lengths set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, \"inflate: code lengths ok\\n\"));\n state.have = 0;\n state.mode = CODELENS;\n /* falls through */\n case CODELENS:\n while (state.have < state.nlen + state.ndist) {\n for (;;) {\n here =\n state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n if (here_bits <= bits) {\n break;\n }\n //--- PULLBYTE() ---//\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_val < 16) {\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.lens[state.have++] = here_val;\n }\n else {\n if (here_val === 16) {\n //=== NEEDBITS(here.bits + 2);\n n = here_bits + 2;\n while (bits < n) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n if (state.have === 0) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n len = state.lens[state.have - 1];\n copy = 3 + (hold & 0x03); //BITS(2);\n //--- DROPBITS(2) ---//\n hold >>>= 2;\n bits -= 2;\n //---//\n }\n else if (here_val === 17) {\n //=== NEEDBITS(here.bits + 3);\n n = here_bits + 3;\n while (bits < n) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 3 + (hold & 0x07); //BITS(3);\n //--- DROPBITS(3) ---//\n hold >>>= 3;\n bits -= 3;\n //---//\n }\n else {\n //=== NEEDBITS(here.bits + 7);\n n = here_bits + 7;\n while (bits < n) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n len = 0;\n copy = 11 + (hold & 0x7f); //BITS(7);\n //--- DROPBITS(7) ---//\n hold >>>= 7;\n bits -= 7;\n //---//\n }\n if (state.have + copy > state.nlen + state.ndist) {\n strm.msg = 'invalid bit length repeat';\n state.mode = BAD;\n break;\n }\n while (copy--) {\n state.lens[state.have++] = len;\n }\n }\n }\n /* handle error breaks in while */\n if (state.mode === BAD) {\n break;\n }\n /* check for end-of-block code (better have one) */\n if (state.lens[256] === 0) {\n strm.msg = 'invalid code -- missing end-of-block';\n state.mode = BAD;\n break;\n }\n /* build code tables -- note: do not change the lenbits or distbits\n values here (9 and 6) without reading the comments in inftrees.h\n concerning the ENOUGH constants, which depend on those values */\n state.lenbits = 9;\n opts = { bits: state.lenbits };\n ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.lenbits = opts.bits;\n // state.lencode = state.next;\n if (ret) {\n strm.msg = 'invalid literal/lengths set';\n state.mode = BAD;\n break;\n }\n state.distbits = 6;\n //state.distcode.copy(state.codes);\n // Switch to use dynamic table\n state.distcode = state.distdyn;\n opts = { bits: state.distbits };\n ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts);\n // We have separate tables & no pointers. 2 commented lines below not needed.\n // state.next_index = opts.table_index;\n state.distbits = opts.bits;\n // state.distcode = state.next;\n if (ret) {\n strm.msg = 'invalid distances set';\n state.mode = BAD;\n break;\n }\n //Tracev((stderr, 'inflate: codes ok\\n'));\n state.mode = LEN_;\n if (flush === Z_TREES) {\n break inf_leave;\n }\n /* falls through */\n case LEN_:\n state.mode = LEN;\n /* falls through */\n case LEN:\n if (have >= 6 && left >= 258) {\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n inflate_fast(strm, _out);\n //--- LOAD() ---\n put = strm.next_out;\n output = strm.output;\n left = strm.avail_out;\n next = strm.next_in;\n input = strm.input;\n have = strm.avail_in;\n hold = state.hold;\n bits = state.bits;\n //---\n if (state.mode === TYPE) {\n state.back = -1;\n }\n break;\n }\n state.back = 0;\n for (;;) {\n here =\n state.lencode[hold & ((1 << state.lenbits) - 1)]; /*BITS(state.lenbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n if (here_bits <= bits) {\n break;\n }\n //--- PULLBYTE() ---//\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if (here_op && (here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here =\n state.lencode[last_val +\n ((hold &\n ((1 << (last_bits + last_op)) -\n 1)) /*BITS(last.bits + last.op)*/ >>\n last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n if (last_bits + here_bits <= bits) {\n break;\n }\n //--- PULLBYTE() ---//\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n state.length = here_val;\n if (here_op === 0) {\n //Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ?\n // \"inflate: literal '%c'\\n\" :\n // \"inflate: literal 0x%02x\\n\", here.val));\n state.mode = LIT;\n break;\n }\n if (here_op & 32) {\n //Tracevv((stderr, \"inflate: end of block\\n\"));\n state.back = -1;\n state.mode = TYPE;\n break;\n }\n if (here_op & 64) {\n strm.msg = 'invalid literal/length code';\n state.mode = BAD;\n break;\n }\n state.extra = here_op & 15;\n state.mode = LENEXT;\n /* falls through */\n case LENEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.length += hold & ((1 << state.extra) - 1); /*BITS(state.extra)*/\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //Tracevv((stderr, \"inflate: length %u\\n\", state.length));\n state.was = state.length;\n state.mode = DIST;\n /* falls through */\n case DIST:\n for (;;) {\n here =\n state.distcode[hold & ((1 << state.distbits) - 1)]; /*BITS(state.distbits)*/\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n if (here_bits <= bits) {\n break;\n }\n //--- PULLBYTE() ---//\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n if ((here_op & 0xf0) === 0) {\n last_bits = here_bits;\n last_op = here_op;\n last_val = here_val;\n for (;;) {\n here =\n state.distcode[last_val +\n ((hold &\n ((1 << (last_bits + last_op)) -\n 1)) /*BITS(last.bits + last.op)*/ >>\n last_bits)];\n here_bits = here >>> 24;\n here_op = (here >>> 16) & 0xff;\n here_val = here & 0xffff;\n if (last_bits + here_bits <= bits) {\n break;\n }\n //--- PULLBYTE() ---//\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n //---//\n }\n //--- DROPBITS(last.bits) ---//\n hold >>>= last_bits;\n bits -= last_bits;\n //---//\n state.back += last_bits;\n }\n //--- DROPBITS(here.bits) ---//\n hold >>>= here_bits;\n bits -= here_bits;\n //---//\n state.back += here_bits;\n if (here_op & 64) {\n strm.msg = 'invalid distance code';\n state.mode = BAD;\n break;\n }\n state.offset = here_val;\n state.extra = here_op & 15;\n state.mode = DISTEXT;\n /* falls through */\n case DISTEXT:\n if (state.extra) {\n //=== NEEDBITS(state.extra);\n n = state.extra;\n while (bits < n) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n state.offset += hold & ((1 << state.extra) - 1); /*BITS(state.extra)*/\n //--- DROPBITS(state.extra) ---//\n hold >>>= state.extra;\n bits -= state.extra;\n //---//\n state.back += state.extra;\n }\n //#ifdef INFLATE_STRICT\n if (state.offset > state.dmax) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n //#endif\n //Tracevv((stderr, \"inflate: distance %u\\n\", state.offset));\n state.mode = MATCH;\n /* falls through */\n case MATCH:\n if (left === 0) {\n break inf_leave;\n }\n copy = _out - left;\n if (state.offset > copy) {\n /* copy from window */\n copy = state.offset - copy;\n if (copy > state.whave) {\n if (state.sane) {\n strm.msg = 'invalid distance too far back';\n state.mode = BAD;\n break;\n }\n // (!) This block is disabled in zlib defaults,\n // don't enable it for binary compatibility\n //#ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR\n // Trace((stderr, \"inflate.c too far\\n\"));\n // copy -= state.whave;\n // if (copy > state.length) { copy = state.length; }\n // if (copy > left) { copy = left; }\n // left -= copy;\n // state.length -= copy;\n // do {\n // output[put++] = 0;\n // } while (--copy);\n // if (state.length === 0) { state.mode = LEN; }\n // break;\n //#endif\n }\n if (copy > state.wnext) {\n copy -= state.wnext;\n from = state.wsize - copy;\n }\n else {\n from = state.wnext - copy;\n }\n if (copy > state.length) {\n copy = state.length;\n }\n from_source = state.window;\n }\n else {\n /* copy from output */\n from_source = output;\n from = put - state.offset;\n copy = state.length;\n }\n if (copy > left) {\n copy = left;\n }\n left -= copy;\n state.length -= copy;\n do {\n output[put++] = from_source[from++];\n } while (--copy);\n if (state.length === 0) {\n state.mode = LEN;\n }\n break;\n case LIT:\n if (left === 0) {\n break inf_leave;\n }\n output[put++] = state.length;\n left--;\n state.mode = LEN;\n break;\n case CHECK:\n if (state.wrap) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n // Use '|' instead of '+' to make sure that result is signed\n hold |= input[next++] << bits;\n bits += 8;\n }\n //===//\n _out -= left;\n strm.total_out += _out;\n state.total += _out;\n if (_out) {\n strm.adler = state.check =\n /*UPDATE(state.check, put - _out, _out);*/\n state.flags\n ? crc32(state.check, output, _out, put - _out)\n : adler32(state.check, output, _out, put - _out);\n }\n _out = left;\n // NB: crc32 stored as signed 32-bit int, zswap32 returns signed too\n if ((state.flags ? hold : zswap32(hold)) !== state.check) {\n strm.msg = 'incorrect data check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: check matches trailer\\n\"));\n }\n state.mode = LENGTH;\n /* falls through */\n case LENGTH:\n if (state.wrap && state.flags) {\n //=== NEEDBITS(32);\n while (bits < 32) {\n if (have === 0) {\n break inf_leave;\n }\n have--;\n hold += input[next++] << bits;\n bits += 8;\n }\n //===//\n if (hold !== (state.total & 0xffffffff)) {\n strm.msg = 'incorrect length check';\n state.mode = BAD;\n break;\n }\n //=== INITBITS();\n hold = 0;\n bits = 0;\n //===//\n //Tracev((stderr, \"inflate: length matches trailer\\n\"));\n }\n state.mode = DONE;\n /* falls through */\n case DONE:\n ret = Z_STREAM_END;\n break inf_leave;\n case BAD:\n ret = Z_DATA_ERROR;\n break inf_leave;\n case MEM:\n return Z_MEM_ERROR;\n case SYNC:\n /* falls through */\n default:\n return Z_STREAM_ERROR;\n }\n }\n // inf_leave <- here is real place for \"goto inf_leave\", emulated via \"break inf_leave\"\n /*\n Return from inflate(), updating the total counts and the check value.\n If there was no progress during the inflate() call, return a buffer\n error. Call updatewindow() to create and/or update the window state.\n Note: a memory error from inflate() is non-recoverable.\n */\n //--- RESTORE() ---\n strm.next_out = put;\n strm.avail_out = left;\n strm.next_in = next;\n strm.avail_in = have;\n state.hold = hold;\n state.bits = bits;\n //---\n if (state.wsize ||\n (_out !== strm.avail_out &&\n state.mode < BAD &&\n (state.mode < CHECK || flush !== Z_FINISH))) {\n if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n }\n _in -= strm.avail_in;\n _out -= strm.avail_out;\n strm.total_in += _in;\n strm.total_out += _out;\n state.total += _out;\n if (state.wrap && _out) {\n strm.adler = state.check =\n /*UPDATE(state.check, strm.next_out - _out, _out);*/\n state.flags\n ? crc32(state.check, output, _out, strm.next_out - _out)\n : adler32(state.check, output, _out, strm.next_out - _out);\n }\n strm.data_type =\n state.bits +\n (state.last ? 64 : 0) +\n (state.mode === TYPE ? 128 : 0) +\n (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0);\n if (((_in === 0 && _out === 0) || flush === Z_FINISH) && ret === Z_OK) {\n ret = Z_BUF_ERROR;\n }\n return ret;\n}\nexport function inflateEnd(strm) {\n if (!strm || !strm.state /*|| strm->zfree == (free_func)0*/) {\n return Z_STREAM_ERROR;\n }\n var state = strm.state;\n if (state.window) {\n state.window = null;\n }\n strm.state = null;\n return Z_OK;\n}\nexport function inflateGetHeader(strm, head) {\n var state;\n /* check state */\n if (!strm || !strm.state) {\n return Z_STREAM_ERROR;\n }\n state = strm.state;\n if ((state.wrap & 2) === 0) {\n return Z_STREAM_ERROR;\n }\n /* save header structure */\n state.head = head;\n head.done = false;\n return Z_OK;\n}\nexport function inflateSetDictionary(strm, dictionary) {\n var dictLength = dictionary.length;\n var state;\n var dictid;\n var ret;\n /* check state */\n if (!strm /* == Z_NULL */ || !strm.state /* == Z_NULL */) {\n return Z_STREAM_ERROR;\n }\n state = strm.state;\n if (state.wrap !== 0 && state.mode !== DICT) {\n return Z_STREAM_ERROR;\n }\n /* check for correct dictionary identifier */\n if (state.mode === DICT) {\n dictid = 1; /* adler32(0, null, 0)*/\n /* dictid = adler32(dictid, dictionary, dictLength); */\n dictid = adler32(dictid, dictionary, dictLength, 0);\n if (dictid !== state.check) {\n return Z_DATA_ERROR;\n }\n }\n /* copy dictionary to window using updatewindow(), which will amend the\n existing dictionary if appropriate */\n ret = updatewindow(strm, dictionary, dictLength, dictLength);\n if (ret) {\n state.mode = MEM;\n return Z_MEM_ERROR;\n }\n state.havedict = 1;\n // Tracev((stderr, \"inflate: dictionary set\\n\"));\n return Z_OK;\n}\nexport var inflateInfo = 'pako inflate (from Nodeca project)';\n/* Not implemented\nexports.inflateCopy = inflateCopy;\nexports.inflateGetDictionary = inflateGetDictionary;\nexports.inflateMark = inflateMark;\nexports.inflatePrime = inflatePrime;\nexports.inflateSync = inflateSync;\nexports.inflateSyncPoint = inflateSyncPoint;\nexports.inflateUndermine = inflateUndermine;\n*/\n//# sourceMappingURL=inflate.js.map","// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\nexport default {\n 2: 'need dictionary' /* Z_NEED_DICT 2 */,\n 1: 'stream end' /* Z_STREAM_END 1 */,\n 0: '' /* Z_OK 0 */,\n '-1': 'file error' /* Z_ERRNO (-1) */,\n '-2': 'stream error' /* Z_STREAM_ERROR (-2) */,\n '-3': 'data error' /* Z_DATA_ERROR (-3) */,\n '-4': 'insufficient memory' /* Z_MEM_ERROR (-4) */,\n '-5': 'buffer error' /* Z_BUF_ERROR (-5) */,\n '-6': 'incompatible version' /* Z_VERSION_ERROR (-6) */,\n};\n//# sourceMappingURL=messages.js.map","// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\nexport default function ZStream() {\n /* next input byte */\n this.input = null; // JS specific, because we have no pointers\n this.next_in = 0;\n /* number of bytes available at input */\n this.avail_in = 0;\n /* total number of input bytes read so far */\n this.total_in = 0;\n /* next output byte should be put there */\n this.output = null; // JS specific, because we have no pointers\n this.next_out = 0;\n /* remaining free space at output */\n this.avail_out = 0;\n /* total number of bytes output so far */\n this.total_out = 0;\n /* last error message, NULL if no error */\n this.msg = ''; /*Z_NULL*/\n /* not visible by applications */\n this.state = null;\n /* best guess about the data type: binary or text */\n this.data_type = 2; /*Z_UNKNOWN*/\n /* adler32 value of the uncompressed data */\n this.adler = 0;\n}\n//# sourceMappingURL=zstream.js.map","import { Buf8, arraySet, assign, flattenChunks, shrinkBuf, } from './utils/common.js';\nimport { binstring2buf, buf2string, string2buf, utf8border, } from './utils/strings.js';\nimport { Z_BUF_ERROR, Z_FINISH, Z_NEED_DICT, Z_NO_FLUSH, Z_OK, Z_STREAM_END, Z_SYNC_FLUSH, } from './zlib/constants.js';\nimport GZheader from './zlib/gzheader.js';\nimport { inflate as zlibInflate, inflateEnd, inflateGetHeader, inflateInit2, inflateSetDictionary, } from './zlib/inflate.js';\nimport msg from './zlib/messages.js';\nimport ZStream from './zlib/zstream.js';\nvar toString = Object.prototype.toString;\n/**\n * class Inflate\n *\n * Generic JS-style wrapper for zlib calls. If you don't need\n * streaming behaviour - use more simple functions: [[inflate]]\n * and [[inflateRaw]].\n **/\n/* internal\n * inflate.chunks -> Array\n *\n * Chunks of output data, if [[Inflate#onData]] not overridden.\n **/\n/**\n * Inflate.result -> Uint8Array|Array|String\n *\n * Uncompressed result, generated by default [[Inflate#onData]]\n * and [[Inflate#onEnd]] handlers. Filled after you push last chunk\n * (call [[Inflate#push]] with `Z_FINISH` / `true` param) or if you\n * push a chunk with explicit flush (call [[Inflate#push]] with\n * `Z_SYNC_FLUSH` param).\n **/\n/**\n * Inflate.err -> Number\n *\n * Error code after inflate finished. 0 (Z_OK) on success.\n * Should be checked if broken data possible.\n **/\n/**\n * Inflate.msg -> String\n *\n * Error message, if [[Inflate.err]] != 0\n **/\n/**\n * new Inflate(options)\n * - options (Object): zlib inflate options.\n *\n * Creates new inflator instance with specified params. Throws exception\n * on bad params. Supported options:\n *\n * - `windowBits`\n * - `dictionary`\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information on these.\n *\n * Additional options, for internal needs:\n *\n * - `chunkSize` - size of generated data chunks (16K by default)\n * - `raw` (Boolean) - do raw inflate\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n * By default, when no options set, autodetect deflate/gzip data format via\n * wrapper header.\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , chunk1 = Uint8Array([1,2,3,4,5,6,7,8,9])\n * , chunk2 = Uint8Array([10,11,12,13,14,15,16,17,18,19]);\n *\n * var inflate = new pako.Inflate({ level: 3});\n *\n * inflate.push(chunk1, false);\n * inflate.push(chunk2, true); // true -> last chunk\n *\n * if (inflate.err) { throw new Error(inflate.err); }\n *\n * console.log(inflate.result);\n * ```\n **/\nexport class Inflate {\n constructor(options) {\n if (!(this instanceof Inflate))\n return new Inflate(options);\n this.options = assign({\n chunkSize: 16384,\n windowBits: 0,\n to: '',\n }, options || {});\n var opt = this.options;\n // Force window size for `raw` data, if not set directly,\n // because we have no header for autodetect.\n if (opt.raw && opt.windowBits >= 0 && opt.windowBits < 16) {\n opt.windowBits = -opt.windowBits;\n if (opt.windowBits === 0) {\n opt.windowBits = -15;\n }\n }\n // If `windowBits` not defined (and mode not raw) - set autodetect flag for gzip/deflate\n if (opt.windowBits >= 0 &&\n opt.windowBits < 16 &&\n !(options && options.windowBits)) {\n opt.windowBits += 32;\n }\n // Gzip header has no info about windows size, we can do autodetect only\n // for deflate. So, if window size not set, force it to max when gzip possible\n if (opt.windowBits > 15 && opt.windowBits < 48) {\n // bit 3 (16) -> gzipped data\n // bit 4 (32) -> autodetect gzip/deflate\n if ((opt.windowBits & 15) === 0) {\n opt.windowBits |= 15;\n }\n }\n this.err = 0; // error code, if happens (0 = Z_OK)\n this.msg = ''; // error message\n this.ended = false; // used to avoid multiple onEnd() calls\n this.chunks = []; // chunks of compressed data\n this.strm = new ZStream();\n this.strm.avail_out = 0;\n var status = inflateInit2(this.strm, opt.windowBits);\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n this.header = new GZheader();\n inflateGetHeader(this.strm, this.header);\n // Setup dictionary\n if (opt.dictionary) {\n // Convert data if needed\n if (typeof opt.dictionary === 'string') {\n opt.dictionary = string2buf(opt.dictionary);\n }\n else if (toString.call(opt.dictionary) === '[object ArrayBuffer]') {\n opt.dictionary = new Uint8Array(opt.dictionary);\n }\n if (opt.raw) {\n //In raw mode we need to set the dictionary early\n status = inflateSetDictionary(this.strm, opt.dictionary);\n if (status !== Z_OK) {\n throw new Error(msg[status]);\n }\n }\n }\n }\n /**\n * Inflate#push(data[, mode]) -> Boolean\n * - data (Uint8Array|Array|ArrayBuffer|String): input data\n * - mode (Number|Boolean): 0..6 for corresponding Z_NO_FLUSH..Z_TREE modes.\n * See constants. Skipped or `false` means Z_NO_FLUSH, `true` means Z_FINISH.\n *\n * Sends input data to inflate pipe, generating [[Inflate#onData]] calls with\n * new output chunks. Returns `true` on success. The last data block must have\n * mode Z_FINISH (or `true`). That will flush internal pending buffers and call\n * [[Inflate#onEnd]]. For interim explicit flushes (without ending the stream) you\n * can use mode Z_SYNC_FLUSH, keeping the decompression context.\n *\n * On fail call [[Inflate#onEnd]] with error code and return false.\n *\n * We strongly recommend to use `Uint8Array` on input for best speed (output\n * format is detected automatically). Also, don't skip last param and always\n * use the same type in your code (boolean or number). That will improve JS speed.\n *\n * For regular `Array`-s make sure all elements are [0..255].\n *\n * ##### Example\n *\n * ```javascript\n * push(chunk, false); // push one of data chunks\n * ...\n * push(chunk, true); // push last chunk\n * ```\n **/\n push(data, mode) {\n var strm = this.strm;\n var chunkSize = this.options.chunkSize;\n var dictionary = this.options.dictionary;\n var status, _mode;\n var next_out_utf8, tail, utf8str;\n var dict;\n // Flag to properly process Z_BUF_ERROR on testing inflate call\n // when we check that all output data was flushed.\n var allowBufError = false;\n if (this.ended) {\n return false;\n }\n _mode = mode === ~~mode ? mode : mode === true ? Z_FINISH : Z_NO_FLUSH;\n // Convert data if needed\n if (typeof data === 'string') {\n // Only binary strings can be decompressed on practice\n strm.input = binstring2buf(data);\n }\n else if (toString.call(data) === '[object ArrayBuffer]') {\n strm.input = new Uint8Array(data);\n }\n else {\n strm.input = data;\n }\n strm.next_in = 0;\n strm.avail_in = strm.input.length;\n do {\n if (strm.avail_out === 0) {\n strm.output = Buf8(chunkSize);\n strm.next_out = 0;\n strm.avail_out = chunkSize;\n }\n status = zlibInflate(strm, Z_NO_FLUSH); /* no bad return value */\n if (status === Z_NEED_DICT && dictionary) {\n // Convert data if needed\n if (typeof dictionary === 'string') {\n dict = string2buf(dictionary);\n }\n else if (toString.call(dictionary) === '[object ArrayBuffer]') {\n dict = new Uint8Array(dictionary);\n }\n else {\n dict = dictionary;\n }\n status = inflateSetDictionary(this.strm, dict);\n }\n if (status === Z_BUF_ERROR && allowBufError === true) {\n status = Z_OK;\n allowBufError = false;\n }\n if (status !== Z_STREAM_END && status !== Z_OK) {\n this.onEnd(status);\n this.ended = true;\n return false;\n }\n if (strm.next_out) {\n if (strm.avail_out === 0 ||\n status === Z_STREAM_END ||\n (strm.avail_in === 0 &&\n (_mode === Z_FINISH || _mode === Z_SYNC_FLUSH))) {\n if (this.options.to === 'string') {\n next_out_utf8 = utf8border(strm.output, strm.next_out);\n tail = strm.next_out - next_out_utf8;\n utf8str = buf2string(strm.output, next_out_utf8);\n // move tail\n strm.next_out = tail;\n strm.avail_out = chunkSize - tail;\n if (tail) {\n arraySet(strm.output, strm.output, next_out_utf8, tail, 0);\n }\n this.onData(utf8str);\n }\n else {\n this.onData(shrinkBuf(strm.output, strm.next_out));\n }\n }\n }\n // When no more input data, we should check that internal inflate buffers\n // are flushed. The only way to do it when avail_out = 0 - run one more\n // inflate pass. But if output data not exists, inflate return Z_BUF_ERROR.\n // Here we set flag to process this error properly.\n //\n // NOTE. Deflate does not return error in this case and does not needs such\n // logic.\n if (strm.avail_in === 0 && strm.avail_out === 0) {\n allowBufError = true;\n }\n } while ((strm.avail_in > 0 || strm.avail_out === 0) &&\n status !== Z_STREAM_END);\n if (status === Z_STREAM_END) {\n _mode = Z_FINISH;\n }\n // Finalize on the last chunk.\n if (_mode === Z_FINISH) {\n status = inflateEnd(this.strm);\n this.onEnd(status);\n this.ended = true;\n return status === Z_OK;\n }\n // callback interim results if Z_SYNC_FLUSH.\n if (_mode === Z_SYNC_FLUSH) {\n this.onEnd(Z_OK);\n strm.avail_out = 0;\n return true;\n }\n return true;\n }\n /**\n * Inflate#onData(chunk) -> Void\n * - chunk (Uint8Array|Array|String): output data. Type of array depends\n * on js engine support. When string output requested, each chunk\n * will be string.\n *\n * By default, stores data blocks in `chunks[]` property and glue\n * those in `onEnd`. Override this handler, if you need another behaviour.\n **/\n onData(chunk) {\n this.chunks.push(chunk);\n }\n /**\n * Inflate#onEnd(status) -> Void\n * - status (Number): inflate status. 0 (Z_OK) on success,\n * other if not.\n *\n * Called either after you tell inflate that the input stream is\n * complete (Z_FINISH) or should be flushed (Z_SYNC_FLUSH)\n * or if an error happened. By default - join collected chunks,\n * free memory and fill `results` / `err` properties.\n **/\n onEnd(status) {\n // On success - join\n if (status === Z_OK) {\n if (this.options.to === 'string') {\n // Glue & convert here, until we teach pako to send\n // utf8 aligned strings to onData\n this.result = this.chunks.join('');\n }\n else {\n this.result = flattenChunks(this.chunks);\n }\n }\n this.chunks = [];\n this.err = status;\n this.msg = this.strm.msg;\n }\n}\n/**\n * inflate(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Decompress `data` with inflate/ungzip and `options`. Autodetect\n * format via wrapper header by default. That's why we don't provide\n * separate `ungzip` method.\n *\n * Supported options are:\n *\n * - windowBits\n *\n * [http://zlib.net/manual.html#Advanced](http://zlib.net/manual.html#Advanced)\n * for more information.\n *\n * Sugar (options):\n *\n * - `raw` (Boolean) - say that we work with raw stream, if you don't wish to specify\n * negative windowBits implicitly.\n * - `to` (String) - if equal to 'string', then result will be converted\n * from utf8 to utf16 (javascript) string. When string output requested,\n * chunk length can differ from `chunkSize`, depending on content.\n *\n *\n * ##### Example:\n *\n * ```javascript\n * var pako = require('pako')\n * , input = pako.deflate([1,2,3,4,5,6,7,8,9])\n * , output;\n *\n * try {\n * output = pako.inflate(input);\n * } catch (err)\n * console.log(err);\n * }\n * ```\n **/\nexport function inflate(input, options) {\n var inflator = new Inflate(options);\n inflator.push(input, true);\n // That will never happens, if you don't cheat with options :)\n if (inflator.err) {\n throw inflator.msg || msg[inflator.err];\n }\n return inflator.result;\n}\n/**\n * inflateRaw(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * The same as [[inflate]], but creates raw data, without wrapper\n * (header and adler32 crc).\n **/\nexport function inflateRaw(input, options) {\n options = options || {};\n options.raw = true;\n return inflate(input, options);\n}\n/**\n * ungzip(data[, options]) -> Uint8Array|Array|String\n * - data (Uint8Array|Array|String): input data to decompress.\n * - options (Object): zlib inflate options.\n *\n * Just shortcut to [[inflate]], because it autodetects format\n * by header.content. Done for convenience.\n **/\nexport var ungzip = inflate;\n//# sourceMappingURL=inflate.js.map","// (C) 1995-2013 Jean-loup Gailly and Mark Adler\n// (C) 2014-2017 Vitaly Puzrin and Andrey Tupitsin\n//\n// This software is provided 'as-is', without any express or implied\n// warranty. In no event will the authors be held liable for any damages\n// arising from the use of this software.\n//\n// Permission is granted to anyone to use this software for any purpose,\n// including commercial applications, and to alter it and redistribute it\n// freely, subject to the following restrictions:\n//\n// 1. The origin of this software must not be misrepresented; you must not\n// claim that you wrote the original software. If you use this software\n// in a product, an acknowledgment in the product documentation would be\n// appreciated but is not required.\n// 2. Altered source versions must be plainly marked as such, and must not be\n// misrepresented as being the original software.\n// 3. This notice may not be removed or altered from any source distribution.\n/* Allowed flush values; see deflate() and inflate() below for details */\nexport var Z_NO_FLUSH = 0;\nexport var Z_PARTIAL_FLUSH = 1;\nexport var Z_SYNC_FLUSH = 2;\nexport var Z_FULL_FLUSH = 3;\nexport var Z_FINISH = 4;\nexport var Z_BLOCK = 5;\nexport var Z_TREES = 6;\n/* Return codes for the compression/decompression functions. Negative values\n * are errors, positive values are used for special but normal events.\n */\nexport var Z_OK = 0;\nexport var Z_STREAM_END = 1;\nexport var Z_NEED_DICT = 2;\nexport var Z_ERRNO = -1;\nexport var Z_STREAM_ERROR = -2;\nexport var Z_DATA_ERROR = -3;\n//export var Z_MEM_ERROR = -4;\nexport var Z_BUF_ERROR = -5;\n//export var Z_VERSION_ERROR = -6;\n/* compression levels */\nexport var Z_NO_COMPRESSION = 0;\nexport var Z_BEST_SPEED = 1;\nexport var Z_BEST_COMPRESSION = 9;\nexport var Z_DEFAULT_COMPRESSION = -1;\nexport var Z_FILTERED = 1;\nexport var Z_HUFFMAN_ONLY = 2;\nexport var Z_RLE = 3;\nexport var Z_FIXED = 4;\nexport var Z_DEFAULT_STRATEGY = 0;\n/* Possible values of the data_type field (though see inflate()) */\nexport var Z_BINARY = 0;\nexport var Z_TEXT = 1;\n//export var Z_ASCII = 1; // = Z_TEXT (deprecated)\nexport var Z_UNKNOWN = 2;\n/* The deflate compression method */\nexport var Z_DEFLATED = 8;\n//export var Z_NULL = null // Use -1 or null inline; depending on var type\n//# sourceMappingURL=constants.js.map","/******/ // The require scope\n/******/ var __webpack_require__ = {};\n/******/\n/************************************************************************/\n/******/ /* webpack/runtime/define property getters */\n/******/ (() => {\n /******/ // define getter functions for harmony exports\n /******/ __webpack_require__.d = (exports, definition) => {\n /******/ for (var key in definition) {\n /******/ if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n /******/ }\n /******/ }\n /******/ \n };\n /******/ \n})();\n/******/\n/******/ /* webpack/runtime/hasOwnProperty shorthand */\n/******/ (() => {\n /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop));\n /******/ \n})();\n/******/\n/******/ /* webpack/runtime/make namespace object */\n/******/ (() => {\n /******/ // define __esModule on exports\n /******/ __webpack_require__.r = (exports) => {\n /******/ if (typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n /******/ }\n /******/ Object.defineProperty(exports, '__esModule', { value: true });\n /******/ \n };\n /******/ \n})();\n/******/\n/************************************************************************/\nvar __webpack_exports__ = {};\n// NAMESPACE OBJECT: ./src/wasm/bgzf_wasm_bg.js\nvar src_wasm_bgzf_wasm_bg_namespaceObject = {};\n__webpack_require__.r(src_wasm_bgzf_wasm_bg_namespaceObject);\n__webpack_require__.d(src_wasm_bgzf_wasm_bg_namespaceObject, {\n ChunkSliceResult: () => (ChunkSliceResult),\n DecompressResult: () => (DecompressResult),\n __wbg_Error_8c4e43fe74559d73: () => (__wbg_Error_8c4e43fe74559d73),\n __wbg___wbindgen_throw_be289d5034ed271b: () => (__wbg___wbindgen_throw_be289d5034ed271b),\n __wbg_set_wasm: () => (__wbg_set_wasm),\n decompress_all: () => (decompress_all),\n decompress_block: () => (decompress_block),\n decompress_chunk_slice: () => (decompress_chunk_slice)\n});\n; // ./src/wasm/bgzf_wasm_bg.wasm\nconst bgzf_wasm_bg_namespaceObject = \"data:application/wasm;base64,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AAsgASADNgIEIAEgAjYCACABQfiSwAAgACgCBCAAKAIIIgAtAAggAC0ACRAeAAuLAQEBfyMAQRBrIgMkAAJAIAIgAWoiASACTw0AQQBBABBNAAsgA0EEaiAAKAIAIgIgACgCBCABIAJBAXQiAiABIAJLGyICQQggAkEISxsiAkEBQQEQIAJAIAMoAgRBAUcNACADKAIIIAMoAgwQTQALIAMoAgghASAAIAI2AgAgACABNgIEIANBEGokAAuHAQEBfyMAQSBrIgIkAAJAAkAgACgCAEGAgICAeEYNACABIAAoAgQgACgCCBBSIQAMAQsgAkEIakEIaiAAKAIMKAIAIgBBCGopAgA3AwAgAkEIakEQaiAAQRBqKQIANwMAIAIgACkCADcDCCABKAIAIAEoAgQgAkEIahALIQALIAJBIGokACAAC3wBAX8CQCAAKAIAIgAoAgwiAUUNACAAKAIQIAFBARBWCwJAIAAoAhgiAUUNACAAKAIcIAFBA3RBCBBWCwJAIAAoAiQiAUUNACAAKAIoIAFBA3RBCBBWCwJAIABBf0YNACAAIAAoAgRBf2oiATYCBCABDQAgAEEwQQQQVgsLhAEBAn8jAEEQayIGJABBACEHIAZBADYCDAJAAkACQAJAAkAgASgCACACIAMgBCAFIAZBDGoQUA4EAQIAAwALQZCFwABB7ABB/IXAABA/AAsgACAGKAIMNgIEDAILIABBADoAAUEBIQcMAQtBASEHIABBAToAAQsgACAHOgAAIAZBEGokAAtrAQN/IwBBEGsiASQAIAFBBGogACgCACICIAAoAgQgAkEBdCICQQQgAkEESxsiAkEIQQgQIAJAIAEoAgRBAUcNACABKAIIIAEoAgwQTQALIAEoAgghAyAAIAI2AgAgACADNgIEIAFBEGokAAtoAQF/IwBBMGsiAiQAAkAQaEH/AXENACACQTBqJAAPCyACIAE2AiQgAkECNgIQIAJBpJLAADYCDCACQgE3AhggAkEErUIghiACQSRqrYQ3AyggAiACQShqNgIUIAJBDGpBtJLAABBAAAtoAgF/AX4jAEEwayIDJAAgAyABNgIEIAMgADYCACADQQI2AgwgA0GcmMAANgIIIANCAjcCFCADQQStQiCGIgQgA62ENwMoIAMgBCADQQRqrYQ3AyAgAyADQSBqNgIQIANBCGogAhBA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ABWAAAAWgAAAF4AAABiAAAAZgAAAGoAAABuAAAAcgAAAHYAAAB6AAAAfgAAAIIAAACGAAAAigAAAI4AAACSAAAAlgAAAJoAAACeAAAAogAAAKYAAACqAAAArgAAALIAAAC2AAAAugAAAL4AAADCAAAAxgAAAMoAAADOAAAA0gAAANYAAADaAAAA3gAAAOIAAADmAAAA6gAAAO4AAADyAAAA9gAAAPoAAAD+AAABAgAAAQYAAAEKAAABDgAAARIAAAEWAAABGgAAAR4AAAEiAAABJgAAASoAAAEuAAABMgAAATYAAAE6AAABPgAAAUIAAAFGAAABSgAAAU4AAAFSAAABVgAAAVoAAAFeAAABYgAAAWYAAAFqAAABbgAAAXIAAAF2AAABegAAAX4AAAGCAAABhgAAAYoAAAGOAAABkgAAAZYAAAGaAAABngAAAaIAAAGmAAABqgAAAa4AAAGyAAABtgAAAboAAAG+AAABwgAAAcYAAAHKAAABzgAAAdIAAAHWAAAB2gAAAd4AAAHiAAAB5gAAAeoAAAHuAAAB8gAAAfYAAAH6AAAB/gAAAgIAAAIGAAACCgAAAg4AAAISAAACFgAAAhoAAAIeAAACIgAAAiYAAAIqAAACLgAAAjIAAAI2AAACOgAAAj4AAAJCAAACRgAAAkoAAAJOAAACUgAAAlYAAAJaAAACXgAAAmIAAAJmAAACagAAAm4AAAJyAAACdgAAAnoAAAJ+AAACggAAAoYAAAKKAAACjgAAApIAAAKWAAACmgAAAp4AAAKiAAACpgAAAqoAAAKuAAACsgAAArYAAAK6AAACvgAAAsIAAALGAAACygAAAs4AAALSAAAC1gAAAtoAAALeAAAC4gAAAuYAAALqAAAC7gAAAvIAAAL2AAAC+gAAAv4AAAMCAAADBgAAAwoAAAMOAAADEgAAAxYAAAMaAAADHgAAAyIAAAMmAAADKgAAAy4AAAMyAAADNgAAAzoAAAM+AAADQgAAA0YAAANKAAADTgAAA1IAAANWAAADWgAAA14AAANiAAADZgAAA2oAAANuAAADcgAAA3YAAAN6AAADfgAAA4IAAAOGAAADigAAA44AAAOSAAADlgAAA5oAAAOeAAADogAAA6YAAAOqAAADrgAAA7IAAAO2AAADugAAA74AAAPCAAADxgAAA8oAAAPOAAAD0gAAA9YAAAPaAAAD3gAAA+IAAAPmAAAD6gAAA+4AAAPyAAAD9gAAA/oAAAP+AAKAAAAAAAwAAAAQAAAAFAAAABgAAAAcAAAAIAAAACQAAAAoAAQALAAEADQABAA8AAQARAAIAEwACABcAAgAbAAIAHwADACMAAwArAAMAMwADADsABABDAAQAUwAEAGMABABzAAUAgwAFAKMABQDDAAUA4wAAAAIBAAACAQAAAgF8/YsyV+ZX+QLfRL/jSOevbV3L1ixQ62N4QaZXcRuLuW1lbW9yeSBhbGxvY2F0aW9uIG9mICBieXRlcyBmYWlsZWQAAAAJEAAVAAAAFQkQAA0AAAAGARAAGAAAAGQBAAAJAAAAAAAAAAgAAAAEAAAABQAAAAYAAAAHAAAACAAAAAkAAAAMAAAABAAAAAoAAAALAAAADAAAAAAAAAAIAAAABAAAAA0AAAAOAAAADwAAABAAAAARAAAAEAAAAAQAAAASAAAAEwAAABQAAAAIAAAAAAAAAAgAAAAEAAAAFQAAAGFzc2VydGlvbiBmYWlsZWQ6IHBzaXplID49IHNpemUgKyBtaW5fb3ZlcmhlYWQAANsAEAAqAAAAsQQAAAkAAABhc3NlcnRpb24gZmFpbGVkOiBwc2l6ZSA8PSBzaXplICsgbWF4X292ZXJoZWFkAADbABAAKgAAALcEAAANAAAACQAAAAwAAAAEAAAAFgAAAGNhcGFjaXR5IG92ZXJmbG93AAAAUAoQABEAAAC6ABAAIAAAABwAAAAFAAAAAQAAAAAAAAAwMDAxMDIwMzA0MDUwNjA3MDgwOTEwMTExMjEzMTQxNTE2MTcxODE5MjAyMTIyMjMyNDI1MjYyNzI4MjkzMDMxMzIzMzM0MzUzNjM3MzgzOTQwNDE0MjQzNDQ0NTQ2NDc0ODQ5NTA1MTUyNTM1NDU1NTY1NzU4NTk2MDYxNjI2MzY0NjU2NjY3Njg2OTcwNzE3MjczNzQ3NTc2Nzc3ODc5ODA4MTgyODM4NDg1ODY4Nzg4ODk5MDkxOTI5Mzk0OTU5Njk3OTg5OXJhbmdlIGVuZCBpbmRleCAgb3V0IG9mIHJhbmdlIGZvciBzbGljZSBvZiBsZW5ndGggAABMCxAAEAAAAFwLEAAiAAAAc2xpY2UgaW5kZXggc3RhcnRzIGF0ICBidXQgZW5kcyBhdCAAkAsQABYAAACmCxAADQAAAHJhbmdlIHN0YXJ0IGluZGV4IAAAxAsQABIAAABcCxAAIgAAAGluZGV4IG91dCBvZiBib3VuZHM6IHRoZSBsZW4gaXMgIGJ1dCB0aGUgaW5kZXggaXMgAADoCxAAIAAAAAgMEAASAAAAUmVmQ2VsbCBhbHJlYWR5IGJvcnJvd2VkAEHEmMAACwQEAAAAACkEbmFtZQEiAVgfX193YmluZGdlbl9hZGRfdG9fc3RhY2tfcG9pbnRlcgA8CXByb2R1Y2VycwEMcHJvY2Vzc2VkLWJ5AgZ3YWxydXMGMC4yNC40DHdhc20tYmluZGdlbgcwLjIuMTA4\";\n; // ./src/wasm/bgzf_wasm_bg.js\nclass ChunkSliceResult {\n static __wrap(ptr) {\n ptr = ptr >>> 0;\n const obj = Object.create(ChunkSliceResult.prototype);\n obj.__wbg_ptr = ptr;\n ChunkSliceResultFinalization.register(obj, obj.__wbg_ptr, obj);\n return obj;\n }\n __destroy_into_raw() {\n const ptr = this.__wbg_ptr;\n this.__wbg_ptr = 0;\n ChunkSliceResultFinalization.unregister(this);\n return ptr;\n }\n free() {\n const ptr = this.__destroy_into_raw();\n wasm.__wbg_chunksliceresult_free(ptr, 0);\n }\n /**\n * @returns {Uint8Array}\n */\n get buffer() {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n wasm.chunksliceresult_buffer(retptr, this.__wbg_ptr);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var v1 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export(r0, r1 * 1, 1);\n return v1;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n }\n /**\n * @returns {Float64Array}\n */\n get cpositions() {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n wasm.chunksliceresult_cpositions(retptr, this.__wbg_ptr);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var v1 = getArrayF64FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export(r0, r1 * 8, 8);\n return v1;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n }\n /**\n * @returns {Float64Array}\n */\n get dpositions() {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n wasm.chunksliceresult_dpositions(retptr, this.__wbg_ptr);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var v1 = getArrayF64FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export(r0, r1 * 8, 8);\n return v1;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n }\n}\nif (Symbol.dispose)\n ChunkSliceResult.prototype[Symbol.dispose] = ChunkSliceResult.prototype.free;\nclass DecompressResult {\n static __wrap(ptr) {\n ptr = ptr >>> 0;\n const obj = Object.create(DecompressResult.prototype);\n obj.__wbg_ptr = ptr;\n DecompressResultFinalization.register(obj, obj.__wbg_ptr, obj);\n return obj;\n }\n __destroy_into_raw() {\n const ptr = this.__wbg_ptr;\n this.__wbg_ptr = 0;\n DecompressResultFinalization.unregister(this);\n return ptr;\n }\n free() {\n const ptr = this.__destroy_into_raw();\n wasm.__wbg_decompressresult_free(ptr, 0);\n }\n /**\n * @returns {number}\n */\n get bytes_read() {\n const ret = wasm.decompressresult_bytes_read(this.__wbg_ptr);\n return ret >>> 0;\n }\n /**\n * @returns {Uint8Array}\n */\n get data() {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n wasm.decompressresult_data(retptr, this.__wbg_ptr);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var v1 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export(r0, r1 * 1, 1);\n return v1;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n }\n}\nif (Symbol.dispose)\n DecompressResult.prototype[Symbol.dispose] = DecompressResult.prototype.free;\n/**\n * @param {Uint8Array} input\n * @returns {Uint8Array}\n */\nfunction decompress_all(input) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(input, wasm.__wbindgen_export2);\n const len0 = WASM_VECTOR_LEN;\n wasm.decompress_all(retptr, ptr0, len0);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n var r3 = getDataViewMemory0().getInt32(retptr + 4 * 3, true);\n if (r3) {\n throw takeObject(r2);\n }\n var v2 = getArrayU8FromWasm0(r0, r1).slice();\n wasm.__wbindgen_export(r0, r1 * 1, 1);\n return v2;\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * @param {Uint8Array} input\n * @returns {DecompressResult}\n */\nfunction decompress_block(input) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(input, wasm.__wbindgen_export2);\n const len0 = WASM_VECTOR_LEN;\n wasm.decompress_block(retptr, ptr0, len0);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n if (r2) {\n throw takeObject(r1);\n }\n return DecompressResult.__wrap(r0);\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\n/**\n * Decompress a slice of BGZF data between two virtual offsets.\n * Position parameters use f64 to map to JS number, supporting files >4GB.\n * The input buffer should be a slice starting at min_block_position in the original file.\n * Positions are tracked as f64 to preserve precision for large files.\n * @param {Uint8Array} input\n * @param {number} min_block_position\n * @param {number} min_data_position\n * @param {number} max_block_position\n * @param {number} max_data_position\n * @returns {ChunkSliceResult}\n */\nfunction decompress_chunk_slice(input, min_block_position, min_data_position, max_block_position, max_data_position) {\n try {\n const retptr = wasm.__wbindgen_add_to_stack_pointer(-16);\n const ptr0 = passArray8ToWasm0(input, wasm.__wbindgen_export2);\n const len0 = WASM_VECTOR_LEN;\n wasm.decompress_chunk_slice(retptr, ptr0, len0, min_block_position, min_data_position, max_block_position, max_data_position);\n var r0 = getDataViewMemory0().getInt32(retptr + 4 * 0, true);\n var r1 = getDataViewMemory0().getInt32(retptr + 4 * 1, true);\n var r2 = getDataViewMemory0().getInt32(retptr + 4 * 2, true);\n if (r2) {\n throw takeObject(r1);\n }\n return ChunkSliceResult.__wrap(r0);\n }\n finally {\n wasm.__wbindgen_add_to_stack_pointer(16);\n }\n}\nfunction __wbg_Error_8c4e43fe74559d73(arg0, arg1) {\n const ret = Error(getStringFromWasm0(arg0, arg1));\n return addHeapObject(ret);\n}\nfunction __wbg___wbindgen_throw_be289d5034ed271b(arg0, arg1) {\n throw new Error(getStringFromWasm0(arg0, arg1));\n}\nconst ChunkSliceResultFinalization = (typeof FinalizationRegistry === 'undefined')\n ? { register: () => { }, unregister: () => { } }\n : new FinalizationRegistry(ptr => wasm.__wbg_chunksliceresult_free(ptr >>> 0, 1));\nconst DecompressResultFinalization = (typeof FinalizationRegistry === 'undefined')\n ? { register: () => { }, unregister: () => { } }\n : new FinalizationRegistry(ptr => wasm.__wbg_decompressresult_free(ptr >>> 0, 1));\nfunction addHeapObject(obj) {\n if (heap_next === heap.length)\n heap.push(heap.length + 1);\n const idx = heap_next;\n heap_next = heap[idx];\n heap[idx] = obj;\n return idx;\n}\nfunction dropObject(idx) {\n if (idx < 132)\n return;\n heap[idx] = heap_next;\n heap_next = idx;\n}\nfunction getArrayF64FromWasm0(ptr, len) {\n ptr = ptr >>> 0;\n return getFloat64ArrayMemory0().subarray(ptr / 8, ptr / 8 + len);\n}\nfunction getArrayU8FromWasm0(ptr, len) {\n ptr = ptr >>> 0;\n return getUint8ArrayMemory0().subarray(ptr / 1, ptr / 1 + len);\n}\nlet cachedDataViewMemory0 = null;\nfunction getDataViewMemory0() {\n if (cachedDataViewMemory0 === null || cachedDataViewMemory0.buffer.detached === true || (cachedDataViewMemory0.buffer.detached === undefined && cachedDataViewMemory0.buffer !== wasm.memory.buffer)) {\n cachedDataViewMemory0 = new DataView(wasm.memory.buffer);\n }\n return cachedDataViewMemory0;\n}\nlet cachedFloat64ArrayMemory0 = null;\nfunction getFloat64ArrayMemory0() {\n if (cachedFloat64ArrayMemory0 === null || cachedFloat64ArrayMemory0.byteLength === 0) {\n cachedFloat64ArrayMemory0 = new Float64Array(wasm.memory.buffer);\n }\n return cachedFloat64ArrayMemory0;\n}\nfunction getStringFromWasm0(ptr, len) {\n ptr = ptr >>> 0;\n return decodeText(ptr, len);\n}\nlet cachedUint8ArrayMemory0 = null;\nfunction getUint8ArrayMemory0() {\n if (cachedUint8ArrayMemory0 === null || cachedUint8ArrayMemory0.byteLength === 0) {\n cachedUint8ArrayMemory0 = new Uint8Array(wasm.memory.buffer);\n }\n return cachedUint8ArrayMemory0;\n}\nfunction getObject(idx) { return heap[idx]; }\nlet heap = new Array(128).fill(undefined);\nheap.push(undefined, null, true, false);\nlet heap_next = heap.length;\nfunction passArray8ToWasm0(arg, malloc) {\n const ptr = malloc(arg.length * 1, 1) >>> 0;\n getUint8ArrayMemory0().set(arg, ptr / 1);\n WASM_VECTOR_LEN = arg.length;\n return ptr;\n}\nfunction takeObject(idx) {\n const ret = getObject(idx);\n dropObject(idx);\n return ret;\n}\nlet cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });\ncachedTextDecoder.decode();\nconst MAX_SAFARI_DECODE_BYTES = 2146435072;\nlet numBytesDecoded = 0;\nfunction decodeText(ptr, len) {\n numBytesDecoded += len;\n if (numBytesDecoded >= MAX_SAFARI_DECODE_BYTES) {\n cachedTextDecoder = new TextDecoder('utf-8', { ignoreBOM: true, fatal: true });\n cachedTextDecoder.decode();\n numBytesDecoded = len;\n }\n return cachedTextDecoder.decode(getUint8ArrayMemory0().subarray(ptr, ptr + len));\n}\nlet WASM_VECTOR_LEN = 0;\nlet wasm;\nfunction __wbg_set_wasm(val) {\n wasm = val;\n}\n; // ./crate/src/wrapper.js\n// Import the WASM binary as base64 data URL\nlet wrapper_wasm = null;\nlet initPromise = null;\nasync function init() {\n if (wrapper_wasm)\n return wrapper_wasm;\n if (!initPromise) {\n initPromise = (async () => {\n // wasmData is a data URL from asset/inline\n const response = await fetch(bgzf_wasm_bg_namespaceObject);\n const bytes = await response.arrayBuffer();\n const { instance } = await WebAssembly.instantiate(bytes, {\n './bgzf_wasm_bg.js': src_wasm_bgzf_wasm_bg_namespaceObject,\n });\n wrapper_wasm = instance.exports;\n __wbg_set_wasm(wrapper_wasm);\n return wrapper_wasm;\n })();\n }\n return initPromise;\n}\nasync function decompressBlock(input, offset = 0) {\n await init();\n const subarray = offset > 0 ? input.subarray(offset) : input;\n const result = decompress_block(subarray);\n const data = result.data;\n const bytesRead = result.bytes_read;\n result.free();\n return { data, bytesRead };\n}\nasync function decompressAll(input) {\n await init();\n return decompress_all(input);\n}\nasync function decompressChunkSlice(input, minBlockPosition, minDataPosition, maxBlockPosition, maxDataPosition) {\n await init();\n const result = decompress_chunk_slice(input, minBlockPosition, minDataPosition, maxBlockPosition, maxDataPosition);\n const buffer = result.buffer;\n const cpositions = [...result.cpositions];\n const dpositions = [...result.dpositions];\n result.free();\n return { buffer, cpositions, dpositions };\n}\nexport { decompressAll, decompressBlock, decompressChunkSlice };\n//# sourceMappingURL=bgzf-wasm-inlined.js.map","import { ungzip } from 'pako-esm2';\nimport { decompressAll, decompressChunkSlice, } from './wasm/bgzf-wasm-inlined.js';\nfunction hasGzipHeader(data) {\n return data.length >= 2 && data[0] === 0x1f && data[1] === 0x8b;\n}\nasync function decompressGzip(inputData) {\n if (typeof DecompressionStream !== 'undefined') {\n const ds = new DecompressionStream('gzip');\n const writer = ds.writable.getWriter();\n const writePromise = writer\n .write(inputData)\n .then(() => writer.close());\n const chunks = [];\n const reader = ds.readable.getReader();\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n while (true) {\n const { done, value } = await reader.read();\n if (done) {\n break;\n }\n chunks.push(value);\n }\n await writePromise;\n const totalLength = chunks.reduce((sum, chunk) => sum + chunk.length, 0);\n const result = new Uint8Array(totalLength);\n let offset = 0;\n for (const chunk of chunks) {\n result.set(chunk, offset);\n offset += chunk.length;\n }\n return result;\n }\n else {\n return ungzip(inputData, undefined);\n }\n}\nexport async function unzip(inputData) {\n try {\n return await decompressAll(inputData);\n }\n catch (e) {\n if (/invalid bgzf header/.exec(`${e}`)) {\n if (hasGzipHeader(inputData)) {\n return decompressGzip(inputData);\n }\n throw new Error('problem decompressing block: not a valid bgzf or gzip block');\n }\n if (/invalid gzip header/.exec(`${e}`)) {\n throw new Error('problem decompressing block: incorrect gzip header check');\n }\n throw e;\n }\n}\nexport async function unzipChunkSlice(inputData, chunk, _blockCache) {\n try {\n const { minv, maxv } = chunk;\n const result = await decompressChunkSlice(inputData, minv.blockPosition, minv.dataPosition, maxv.blockPosition, maxv.dataPosition);\n return {\n buffer: result.buffer,\n cpositions: result.cpositions,\n dpositions: result.dpositions,\n };\n }\n catch (e) {\n if (/invalid gzip header/.exec(`${e}`)) {\n throw new Error('problem decompressing block: incorrect gzip header check');\n }\n throw e;\n }\n}\n//# sourceMappingURL=unzip.js.map","// little class representing a chunk in the index\nexport default class Chunk {\n constructor(minv, maxv, bin, fetchedSize) {\n this.minv = minv;\n this.maxv = maxv;\n this.bin = bin;\n this._fetchedSize = fetchedSize;\n }\n toUniqueString() {\n return `${this.minv}..${this.maxv} (bin ${this.bin}, fetchedSize ${this.fetchedSize()})`;\n }\n toString() {\n return this.toUniqueString();\n }\n compareTo(b) {\n return (this.minv.compareTo(b.minv) ||\n this.maxv.compareTo(b.maxv) ||\n this.bin - b.bin);\n }\n fetchedSize() {\n if (this._fetchedSize !== undefined) {\n return this._fetchedSize;\n }\n return this.maxv.blockPosition + (1 << 16) - this.minv.blockPosition;\n }\n}\n//# sourceMappingURL=chunk.js.map","export default class IndexFile {\n constructor({ filehandle, renameRefSeqs = (n) => n, }) {\n this.filehandle = filehandle;\n this.renameRefSeq = renameRefSeqs;\n }\n async getMetadata(opts = {}) {\n const { indices: _indices, ...rest } = await this.parse(opts);\n return rest;\n }\n _findFirstData(currentFdl, virtualOffset) {\n if (currentFdl) {\n return currentFdl.compareTo(virtualOffset) > 0\n ? virtualOffset\n : currentFdl;\n }\n else {\n return virtualOffset;\n }\n }\n async parse(opts = {}) {\n if (!this.parseP) {\n this.parseP = this._parse(opts).catch((error) => {\n this.parseP = undefined;\n throw error;\n });\n }\n return this.parseP;\n }\n async hasRefSeq(seqId, opts = {}) {\n const idx = await this.parse(opts);\n return !!idx.indices[seqId]?.binIndex;\n }\n _parseNameBytes(namesBytes) {\n let currRefId = 0;\n let currNameStart = 0;\n const refIdToName = [];\n const refNameToId = {};\n const decoder = new TextDecoder('utf8');\n for (let i = 0; i < namesBytes.length; i += 1) {\n if (!namesBytes[i]) {\n if (currNameStart < i) {\n const refName = this.renameRefSeq(decoder.decode(namesBytes.subarray(currNameStart, i)));\n refIdToName[currRefId] = refName;\n refNameToId[refName] = currRefId;\n }\n currNameStart = i + 1;\n currRefId += 1;\n }\n }\n return {\n refNameToId,\n refIdToName,\n };\n }\n}\n//# sourceMappingURL=indexFile.js.map","export const TWO_PWR_16_DBL = 1 << 16;\nexport const TWO_PWR_32_DBL = TWO_PWR_16_DBL * TWO_PWR_16_DBL;\nexport function longFromBytesToUnsigned(source, i = 0) {\n const low = source[i] |\n (source[i + 1] << 8) |\n (source[i + 2] << 16) |\n (source[i + 3] << 24);\n const high = source[i + 4] |\n (source[i + 5] << 8) |\n (source[i + 6] << 16) |\n (source[i + 7] << 24);\n return (high >>> 0) * TWO_PWR_32_DBL + (low >>> 0);\n}\n//# sourceMappingURL=long.js.map","export function canMergeBlocks(chunk1, chunk2) {\n return (chunk2.minv.blockPosition - chunk1.maxv.blockPosition < 65000 &&\n chunk2.maxv.blockPosition - chunk1.minv.blockPosition < 5000000);\n}\nexport function optimizeChunks(chunks, lowest) {\n const mergedChunks = [];\n let lastChunk;\n if (chunks.length === 0) {\n return chunks;\n }\n chunks.sort(function (c0, c1) {\n const dif = c0.minv.blockPosition - c1.minv.blockPosition;\n return dif === 0 ? c0.minv.dataPosition - c1.minv.dataPosition : dif;\n });\n for (const chunk of chunks) {\n if (!lowest || chunk.maxv.compareTo(lowest) > 0) {\n if (lastChunk === undefined) {\n mergedChunks.push(chunk);\n lastChunk = chunk;\n }\n else {\n if (canMergeBlocks(lastChunk, chunk)) {\n if (chunk.maxv.compareTo(lastChunk.maxv) > 0) {\n lastChunk.maxv = chunk.maxv;\n }\n }\n else {\n mergedChunks.push(chunk);\n lastChunk = chunk;\n }\n }\n }\n }\n return mergedChunks;\n}\n//# sourceMappingURL=util.js.map","export default class VirtualOffset {\n constructor(blockPosition, dataPosition) {\n this.blockPosition = blockPosition; // < offset of the compressed data block\n this.dataPosition = dataPosition; // < offset into the uncompressed data\n }\n toString() {\n return `${this.blockPosition}:${this.dataPosition}`;\n }\n compareTo(b) {\n return (this.blockPosition - b.blockPosition || this.dataPosition - b.dataPosition);\n }\n}\nexport function fromBytes(bytes, offset = 0) {\n return new VirtualOffset(bytes[offset + 7] * 0x10000000000 +\n bytes[offset + 6] * 0x100000000 +\n bytes[offset + 5] * 0x1000000 +\n bytes[offset + 4] * 0x10000 +\n bytes[offset + 3] * 0x100 +\n bytes[offset + 2], (bytes[offset + 1] << 8) | bytes[offset]);\n}\n//# sourceMappingURL=virtualOffset.js.map","import { unzip } from '@gmod/bgzf-filehandle';\nimport Chunk from \"./chunk.js\";\nimport IndexFile from \"./indexFile.js\";\nimport { longFromBytesToUnsigned } from \"./long.js\";\nimport { optimizeChunks } from \"./util.js\";\nimport VirtualOffset, { fromBytes } from \"./virtualOffset.js\";\nconst CSI1_MAGIC = 21582659; // CSI\\1\nconst CSI2_MAGIC = 38359875; // CSI\\2\nconst formats = {\n 0: 'generic',\n 1: 'SAM',\n 2: 'VCF',\n};\nfunction lshift(num, bits) {\n return num * 2 ** bits;\n}\nfunction rshift(num, bits) {\n return Math.floor(num / 2 ** bits);\n}\nexport default class CSI extends IndexFile {\n constructor(args) {\n super(args);\n this.maxBinNumber = 0;\n this.depth = 0;\n this.minShift = 0;\n }\n async lineCount(refName, opts = {}) {\n const indexData = await this.parse(opts);\n const refId = indexData.refNameToId[refName];\n if (refId === undefined) {\n return -1;\n }\n const idx = indexData.indices[refId];\n if (!idx) {\n return -1;\n }\n const { stats } = indexData.indices[refId];\n if (stats) {\n return stats.lineCount;\n }\n return -1;\n }\n indexCov() {\n throw new Error('CSI indexes do not support indexcov');\n }\n parseAuxData(bytes, offset) {\n const dataView = new DataView(bytes.buffer);\n const formatFlags = dataView.getInt32(offset, true);\n const coordinateType = formatFlags & 0x10000 ? 'zero-based-half-open' : '1-based-closed';\n const format = formats[(formatFlags & 0xf)];\n if (!format) {\n throw new Error(`invalid Tabix preset format flags ${formatFlags}`);\n }\n const columnNumbers = {\n ref: dataView.getInt32(offset + 4, true),\n start: dataView.getInt32(offset + 8, true),\n end: dataView.getInt32(offset + 12, true),\n };\n const metaValue = dataView.getInt32(offset + 16, true);\n const metaChar = metaValue ? String.fromCharCode(metaValue) : undefined;\n const skipLines = dataView.getInt32(offset + 20, true);\n const nameSectionLength = dataView.getInt32(offset + 24, true);\n const { refIdToName, refNameToId } = this._parseNameBytes(bytes.subarray(offset + 28, offset + 28 + nameSectionLength));\n return {\n refIdToName,\n refNameToId,\n skipLines,\n metaChar,\n columnNumbers,\n format,\n coordinateType,\n };\n }\n async _parse(opts = {}) {\n const bytes = await unzip(await this.filehandle.readFile(opts));\n const dataView = new DataView(bytes.buffer);\n // check TBI magic numbers\n let csiVersion;\n if (dataView.getUint32(0, true) === CSI1_MAGIC) {\n csiVersion = 1;\n }\n else if (dataView.getUint32(0, true) === CSI2_MAGIC) {\n csiVersion = 2;\n }\n else {\n throw new Error('Not a CSI file');\n }\n this.minShift = dataView.getInt32(4, true);\n this.depth = dataView.getInt32(8, true);\n this.maxBinNumber = ((1 << ((this.depth + 1) * 3)) - 1) / 7;\n const maxRefLength = 2 ** (this.minShift + this.depth * 3);\n const auxLength = dataView.getInt32(12, true);\n const aux = auxLength && auxLength >= 30\n ? this.parseAuxData(bytes, 16)\n : {\n refIdToName: [],\n refNameToId: {},\n metaChar: undefined,\n columnNumbers: { ref: 0, start: 1, end: 2 },\n coordinateType: 'zero-based-half-open',\n format: 'generic',\n };\n const refCount = dataView.getInt32(16 + auxLength, true);\n // read the indexes for each reference sequence\n let firstDataLine;\n let currOffset = 16 + auxLength + 4;\n const indices = new Array(refCount).fill(0).map(() => {\n const binCount = dataView.getInt32(currOffset, true);\n currOffset += 4;\n const binIndex = {};\n let stats;\n for (let j = 0; j < binCount; j += 1) {\n const bin = dataView.getUint32(currOffset, true);\n if (bin > this.maxBinNumber) {\n // this is a fake bin that actually has stats information about the\n // reference sequence in it\n stats = this.parsePseudoBin(bytes, currOffset + 4);\n currOffset += 4 + 8 + 4 + 16 + 16;\n }\n else {\n const loffset = fromBytes(bytes, currOffset + 4);\n firstDataLine = this._findFirstData(firstDataLine, loffset);\n const chunkCount = dataView.getInt32(currOffset + 12, true);\n currOffset += 16;\n const chunks = new Array(chunkCount);\n for (let k = 0; k < chunkCount; k += 1) {\n const u = fromBytes(bytes, currOffset);\n const v = fromBytes(bytes, currOffset + 8);\n currOffset += 16;\n chunks[k] = new Chunk(u, v, bin);\n }\n binIndex[bin] = chunks;\n }\n }\n return { binIndex, stats };\n });\n return {\n ...aux,\n csi: true,\n refCount,\n maxBlockSize: 1 << 16,\n firstDataLine,\n csiVersion,\n indices,\n depth: this.depth,\n maxBinNumber: this.maxBinNumber,\n maxRefLength,\n };\n }\n parsePseudoBin(bytes, offset) {\n return {\n lineCount: longFromBytesToUnsigned(bytes, offset + 28),\n };\n }\n async blocksForRange(refName, min, max, opts = {}) {\n if (min < 0) {\n min = 0;\n }\n const indexData = await this.parse(opts);\n const refId = indexData.refNameToId[refName];\n if (refId === undefined) {\n return [];\n }\n const ba = indexData.indices[refId];\n if (!ba) {\n return [];\n }\n // List of bin #s that overlap min, max\n const overlappingBins = this.reg2bins(min, max);\n const chunks = [];\n // Find chunks in overlapping bins. Leaf bins (< 4681) are not pruned\n for (const [start, end] of overlappingBins) {\n for (let bin = start; bin <= end; bin++) {\n if (ba.binIndex[bin]) {\n for (const c of ba.binIndex[bin]) {\n chunks.push(new Chunk(c.minv, c.maxv, bin));\n }\n }\n }\n }\n return optimizeChunks(chunks, new VirtualOffset(0, 0));\n }\n /**\n * calculate the list of bins that may overlap with region [beg,end) (zero-based half-open)\n */\n reg2bins(beg, end) {\n beg -= 1; // < convert to 1-based closed\n if (beg < 1) {\n beg = 1;\n }\n if (end > 2 ** 50) {\n end = 2 ** 34;\n } // 17 GiB ought to be enough for anybody\n end -= 1;\n let l = 0;\n let t = 0;\n let s = this.minShift + this.depth * 3;\n const bins = [];\n for (; l <= this.depth; s -= 3, t += lshift(1, l * 3), l += 1) {\n const b = t + rshift(beg, s);\n const e = t + rshift(end, s);\n if (e - b + bins.length > this.maxBinNumber) {\n throw new Error(`query ${beg}-${end} is too large for current binning scheme (shift ${this.minShift}, depth ${this.depth}), try a smaller query or a coarser index binning scheme`);\n }\n bins.push([b, e]);\n }\n return bins;\n }\n}\n//# sourceMappingURL=csi.js.map","import { unzip } from '@gmod/bgzf-filehandle';\nimport Chunk from \"./chunk.js\";\nimport IndexFile from \"./indexFile.js\";\nimport { longFromBytesToUnsigned } from \"./long.js\";\nimport { optimizeChunks } from \"./util.js\";\nimport VirtualOffset, { fromBytes } from \"./virtualOffset.js\";\nconst TBI_MAGIC = 21578324; // TBI\\1\nconst TAD_LIDX_SHIFT = 14;\n/**\n * calculate the list of bins that may overlap with region [beg,end)\n * (zero-based half-open)\n */\nfunction reg2bins(beg, end) {\n beg += 1; // < convert to 1-based closed\n end -= 1;\n return [\n [0, 0],\n [1 + (beg >> 26), 1 + (end >> 26)],\n [9 + (beg >> 23), 9 + (end >> 23)],\n [73 + (beg >> 20), 73 + (end >> 20)],\n [585 + (beg >> 17), 585 + (end >> 17)],\n [4681 + (beg >> 14), 4681 + (end >> 14)],\n ];\n}\nexport default class TabixIndex extends IndexFile {\n async lineCount(refName, opts = {}) {\n const indexData = await this.parse(opts);\n const refId = indexData.refNameToId[refName];\n if (refId === undefined) {\n return -1;\n }\n const idx = indexData.indices[refId];\n if (!idx) {\n return -1;\n }\n return indexData.indices[refId].stats?.lineCount ?? -1;\n }\n // fetch and parse the index\n async _parse(opts = {}) {\n const buf = await this.filehandle.readFile(opts);\n const bytes = await unzip(buf);\n const dataView = new DataView(bytes.buffer);\n const magic = dataView.getUint32(0, true);\n if (magic !== TBI_MAGIC /* \"TBI\\1\" */) {\n throw new Error('Not a TBI file');\n }\n // number of reference sequences in the index\n const refCount = dataView.getUint32(4, true);\n const formatFlags = dataView.getUint32(8, true);\n const coordinateType = formatFlags & 0x10000 ? 'zero-based-half-open' : '1-based-closed';\n const formatOpts = {\n 0: 'generic',\n 1: 'SAM',\n 2: 'VCF',\n };\n const format = formatOpts[formatFlags & 0xf];\n if (!format) {\n throw new Error(`invalid Tabix preset format flags ${formatFlags}`);\n }\n const columnNumbers = {\n ref: dataView.getInt32(12, true),\n start: dataView.getInt32(16, true),\n end: dataView.getInt32(20, true),\n };\n const metaValue = dataView.getInt32(24, true);\n const depth = 5;\n const maxBinNumber = ((1 << ((depth + 1) * 3)) - 1) / 7;\n const maxRefLength = 2 ** (14 + depth * 3);\n const metaChar = metaValue ? String.fromCharCode(metaValue) : undefined;\n const skipLines = dataView.getInt32(28, true);\n // read sequence dictionary\n const nameSectionLength = dataView.getInt32(32, true);\n const { refNameToId, refIdToName } = this._parseNameBytes(bytes.slice(36, 36 + nameSectionLength));\n // read the indexes for each reference sequence\n let currOffset = 36 + nameSectionLength;\n let firstDataLine;\n const indices = new Array(refCount).fill(0).map(() => {\n // the binning index\n const binCount = dataView.getInt32(currOffset, true);\n currOffset += 4;\n const binIndex = {};\n let stats;\n for (let j = 0; j < binCount; j += 1) {\n const bin = dataView.getUint32(currOffset, true);\n currOffset += 4;\n if (bin > maxBinNumber + 1) {\n throw new Error('tabix index contains too many bins, please use a CSI index');\n }\n else if (bin === maxBinNumber + 1) {\n const chunkCount = dataView.getInt32(currOffset, true);\n currOffset += 4;\n if (chunkCount === 2) {\n stats = this.parsePseudoBin(bytes, currOffset);\n }\n currOffset += 16 * chunkCount;\n }\n else {\n const chunkCount = dataView.getInt32(currOffset, true);\n currOffset += 4;\n const chunks = new Array(chunkCount);\n for (let k = 0; k < chunkCount; k += 1) {\n const u = fromBytes(bytes, currOffset);\n const v = fromBytes(bytes, currOffset + 8);\n currOffset += 16;\n firstDataLine = this._findFirstData(firstDataLine, u);\n chunks[k] = new Chunk(u, v, bin);\n }\n binIndex[bin] = chunks;\n }\n }\n // the linear index\n const linearCount = dataView.getInt32(currOffset, true);\n currOffset += 4;\n const linearIndex = new Array(linearCount);\n for (let k = 0; k < linearCount; k += 1) {\n linearIndex[k] = fromBytes(bytes, currOffset);\n currOffset += 8;\n firstDataLine = this._findFirstData(firstDataLine, linearIndex[k]);\n }\n return {\n binIndex,\n linearIndex,\n stats,\n };\n });\n return {\n indices,\n metaChar,\n maxBinNumber,\n maxRefLength,\n skipLines,\n firstDataLine,\n columnNumbers,\n coordinateType,\n format,\n refIdToName,\n refNameToId,\n maxBlockSize: 1 << 16,\n };\n }\n parsePseudoBin(bytes, offset) {\n return {\n lineCount: longFromBytesToUnsigned(bytes, offset + 16),\n };\n }\n async blocksForRange(refName, min, max, opts = {}) {\n if (min < 0) {\n min = 0;\n }\n const indexData = await this.parse(opts);\n const refId = indexData.refNameToId[refName];\n if (refId === undefined) {\n return [];\n }\n const ba = indexData.indices[refId];\n if (!ba) {\n return [];\n }\n const minOffset = ba.linearIndex.length > 0\n ? ba.linearIndex[min >> TAD_LIDX_SHIFT >= ba.linearIndex.length\n ? ba.linearIndex.length - 1\n : min >> TAD_LIDX_SHIFT]\n : new VirtualOffset(0, 0);\n if (!minOffset) {\n console.warn('querying outside of possible tabix range');\n }\n // const { linearIndex, binIndex } = indexes\n const overlappingBins = reg2bins(min, max); // List of bin #s that overlap min, max\n const chunks = [];\n // Find chunks in overlapping bins. Leaf bins (< 4681) are not pruned\n for (const [start, end] of overlappingBins) {\n for (let bin = start; bin <= end; bin++) {\n if (ba.binIndex[bin]) {\n for (const c of ba.binIndex[bin]) {\n chunks.push(new Chunk(c.minv, c.maxv, bin));\n }\n }\n }\n }\n // Use the linear index to find minimum file position of chunks that could\n // contain alignments in the region\n const nintv = ba.linearIndex.length;\n let lowest;\n const minLin = Math.min(min >> 14, nintv - 1);\n const maxLin = Math.min(max >> 14, nintv - 1);\n for (let i = minLin; i <= maxLin; ++i) {\n const vp = ba.linearIndex[i];\n if (vp && (!lowest || vp.compareTo(lowest) < 0)) {\n lowest = vp;\n }\n }\n return optimizeChunks(chunks, lowest);\n }\n}\n//# sourceMappingURL=tbi.js.map","import AbortablePromiseCache from '@gmod/abortable-promise-cache';\nimport { unzip, unzipChunkSlice } from '@gmod/bgzf-filehandle';\nimport LRU from '@jbrowse/quick-lru';\nimport { LocalFile, RemoteFile } from 'generic-filehandle2';\nimport CSI from \"./csi.js\";\nimport TBI from \"./tbi.js\";\nexport default class TabixIndexedFile {\n /**\n * @param {object} args\n *\n * @param {string} [args.path]\n *\n * @param {filehandle} [args.filehandle]\n *\n * @param {string} [args.tbiPath]\n *\n * @param {filehandle} [args.tbiFilehandle]\n *\n * @param {string} [args.csiPath]\n *\n * @param {filehandle} [args.csiFilehandle]\n *\n * @param {url} [args.url]\n *\n * @param {csiUrl} [args.csiUrl]\n *\n * @param {tbiUrl} [args.tbiUrl]\n *\n * @param {function} [args.renameRefSeqs] optional function with sig `string\n * => string` to transform reference sequence names for the purpose of\n * indexing and querying. note that the data that is returned is not altered,\n * just the names of the reference sequences that are used for querying.\n */\n constructor({ path, filehandle, url, tbiPath, tbiUrl, tbiFilehandle, csiPath, csiUrl, csiFilehandle, renameRefSeqs: renameRefSeqsPre, chunkCacheSize = 5 * 2 ** 20, }) {\n this.cache = new LRU({\n maxSize: 1000,\n });\n const renameRefSeqs = renameRefSeqsPre ?? (arg => arg);\n if (filehandle) {\n this.filehandle = filehandle;\n }\n else if (path) {\n this.filehandle = new LocalFile(path);\n }\n else if (url) {\n this.filehandle = new RemoteFile(url);\n }\n else {\n throw new TypeError('must provide either filehandle or path');\n }\n if (tbiFilehandle) {\n this.index = new TBI({\n filehandle: tbiFilehandle,\n renameRefSeqs,\n });\n }\n else if (csiFilehandle) {\n this.index = new CSI({\n filehandle: csiFilehandle,\n renameRefSeqs,\n });\n }\n else if (tbiPath) {\n this.index = new TBI({\n filehandle: new LocalFile(tbiPath),\n renameRefSeqs,\n });\n }\n else if (csiPath) {\n this.index = new CSI({\n filehandle: new LocalFile(csiPath),\n renameRefSeqs,\n });\n }\n else if (path) {\n this.index = new TBI({\n filehandle: new LocalFile(`${path}.tbi`),\n renameRefSeqs,\n });\n }\n else if (csiUrl) {\n this.index = new CSI({\n filehandle: new RemoteFile(csiUrl),\n });\n }\n else if (tbiUrl) {\n this.index = new TBI({\n filehandle: new RemoteFile(tbiUrl),\n });\n }\n else if (url) {\n this.index = new TBI({\n filehandle: new RemoteFile(`${url}.tbi`),\n });\n }\n else {\n throw new TypeError('must provide one of tbiFilehandle, tbiPath, csiFilehandle, csiPath, tbiUrl, csiUrl');\n }\n this.renameRefSeq = renameRefSeqs;\n this.hasCustomRenameRefSeq = renameRefSeqsPre !== undefined;\n this.chunkCache = new AbortablePromiseCache({\n cache: new LRU({ maxSize: Math.floor(chunkCacheSize / (1 << 16)) }),\n fill: (args, signal) => this.readChunk(args, { signal }),\n });\n }\n /**\n * @param refName name of the reference sequence\n *\n * @param start start of the region (in 0-based half-open coordinates)\n *\n * @param end end of the region (in 0-based half-open coordinates)\n *\n * @param opts callback called for each line in the region. can also pass a\n * object param containing obj.lineCallback, obj.signal, etc\n *\n * @returns promise that is resolved when the whole read is finished,\n * rejected on error\n */\n calculateFileOffset(cpositions, dpositions, pos, blockStart, minvDataPosition) {\n return (cpositions[pos] * (1 << 8) +\n (blockStart - dpositions[pos]) +\n minvDataPosition +\n 1);\n }\n async getLines(refName, s, e, opts) {\n let signal;\n let options = {};\n let callback;\n if (typeof opts === 'function') {\n callback = opts;\n }\n else {\n options = opts;\n callback = opts.lineCallback;\n signal = opts.signal;\n }\n const metadata = await this.index.getMetadata(options);\n const start = s ?? 0;\n const end = e ?? metadata.maxRefLength;\n if (!(start <= end)) {\n throw new TypeError('invalid start and end coordinates. start must be less than or equal to end');\n }\n if (start === end) {\n return;\n }\n const chunks = await this.index.blocksForRange(refName, start, end, options);\n const decoder = new TextDecoder('utf8');\n const isVCF = metadata.format === 'VCF';\n const columnNumbersEffective = {\n ref: metadata.columnNumbers.ref || 0,\n start: metadata.columnNumbers.start || 0,\n end: isVCF ? 8 : metadata.columnNumbers.end || 0,\n };\n const maxColumn = Math.max(columnNumbersEffective.ref, columnNumbersEffective.start, columnNumbersEffective.end);\n const metaCharCode = metadata.metaChar?.charCodeAt(0);\n const coordinateOffset = metadata.coordinateType === '1-based-closed' ? -1 : 0;\n const isIdentityRename = !this.hasCustomRenameRefSeq;\n // now go through each chunk and parse and filter the lines out of it\n for (const c of chunks) {\n const { buffer, cpositions, dpositions } = await this.chunkCache.get(c.toString(), c, signal);\n let blockStart = 0;\n let pos = 0;\n // fast path, Buffer is just ASCII chars and not gigantor, can be\n // converted to string and processed directly.\n //\n // if it is not ASCII or, we have to decode line by line, as it is\n // otherwise hard to get the right 'fileOffset' based feature IDs\n //\n // we use a basic check for isASCII: string length equals buffer length\n // if it is ASCII...no multi-byte decodings\n const str = decoder.decode(buffer);\n const strIsASCII = buffer.length == str.length;\n if (strIsASCII) {\n while (blockStart < str.length) {\n const n = str.indexOf('\\n', blockStart);\n if (n === -1) {\n break;\n }\n const line = str.slice(blockStart, n);\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (dpositions) {\n const target = blockStart + c.minv.dataPosition;\n while (pos < dpositions.length && target >= dpositions[pos]) {\n pos++;\n }\n }\n // filter the line for whether it is within the requested range\n const result = this.checkLine(refName, start, end, line, columnNumbersEffective.ref, columnNumbersEffective.start, columnNumbersEffective.end, maxColumn, metaCharCode, coordinateOffset, isVCF, isIdentityRename);\n if (result === null) {\n return;\n }\n else if (result !== undefined) {\n callback(line, this.calculateFileOffset(cpositions, dpositions, pos, blockStart, c.minv.dataPosition), result.start, result.end);\n }\n blockStart = n + 1;\n }\n }\n else {\n while (blockStart < buffer.length) {\n const n = buffer.indexOf('\\n'.charCodeAt(0), blockStart);\n if (n === -1) {\n break;\n }\n const b = buffer.slice(blockStart, n);\n const line = decoder.decode(b);\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (dpositions) {\n const target = blockStart + c.minv.dataPosition;\n while (pos < dpositions.length && target >= dpositions[pos]) {\n pos++;\n }\n }\n // filter the line for whether it is within the requested range\n const result = this.checkLine(refName, start, end, line, columnNumbersEffective.ref, columnNumbersEffective.start, columnNumbersEffective.end, maxColumn, metaCharCode, coordinateOffset, isVCF, isIdentityRename);\n if (result === null) {\n return;\n }\n else if (result !== undefined) {\n callback(line, this.calculateFileOffset(cpositions, dpositions, pos, blockStart, c.minv.dataPosition), result.start, result.end);\n }\n blockStart = n + 1;\n }\n }\n }\n }\n async getMetadata(opts = {}) {\n return this.index.getMetadata(opts);\n }\n /**\n * get a buffer containing the \"header\" region of the file, which are the\n * bytes up to the first non-meta line\n */\n async getHeaderBuffer(opts = {}) {\n const { firstDataLine, metaChar, maxBlockSize } = await this.getMetadata(opts);\n const maxFetch = (firstDataLine?.blockPosition || 0) + maxBlockSize;\n // TODO: what if we don't have a firstDataLine, and the header actually\n // takes up more than one block? this case is not covered here\n const buf = await this.filehandle.read(maxFetch, 0, opts);\n const bytes = await unzip(buf);\n // trim off lines after the last non-meta line\n if (metaChar) {\n // trim backward from the end\n let lastNewline = -1;\n const newlineByte = '\\n'.charCodeAt(0);\n const metaByte = metaChar.charCodeAt(0);\n for (let i = 0, l = bytes.length; i < l; i++) {\n const byte = bytes[i];\n if (i === lastNewline + 1 && byte !== metaByte) {\n break;\n }\n if (byte === newlineByte) {\n lastNewline = i;\n }\n }\n return bytes.subarray(0, lastNewline + 1);\n }\n return bytes;\n }\n /**\n * get a string containing the \"header\" region of the file, is the portion up\n * to the first non-meta line\n */\n async getHeader(opts = {}) {\n const decoder = new TextDecoder('utf8');\n const bytes = await this.getHeaderBuffer(opts);\n return decoder.decode(bytes);\n }\n /**\n * get an array of reference sequence names, in the order in which they occur\n * in the file. reference sequence renaming is not applied to these names.\n */\n async getReferenceSequenceNames(opts = {}) {\n const metadata = await this.getMetadata(opts);\n return metadata.refIdToName;\n }\n /**\n * @param {string} regionRefName\n *\n * @param {number} regionStart region start coordinate (0-based-half-open)\n *\n * @param {number} regionEnd region end coordinate (0-based-half-open)\n *\n * @param {string} line\n *\n * @param {number} refColumn column number for ref\n *\n * @param {number} startColumn column number for start\n *\n * @param {number} endColumn column number for end\n *\n * @param {number} maxColumn pre-calculated max column\n *\n * @param {number} metaCharCode pre-calculated metaChar code\n *\n * @param {number} coordinateOffset 0 or -1 for coordinate adjustment\n *\n * @param {boolean} isVCF whether this is VCF format\n *\n * @param {boolean} isIdentityRename whether renameRefSeq is the identity function\n *\n * @returns {{ start: number, end: number } | null | undefined} coordinates if overlapping, null if should stop processing, undefined otherwise\n */\n checkLine(regionRefName, regionStart, regionEnd, line, refColumn, startColumn, endColumn, maxColumn, metaCharCode, coordinateOffset, isVCF, isIdentityRename) {\n if (metaCharCode !== undefined && line.charCodeAt(0) === metaCharCode) {\n return;\n }\n // Length-based fast path: split for short lines, indexOf for long lines\n // Split is faster for short lines, but slow for long lines with big attribute columns\n if (line.length < 500) {\n const fields = line.split('\\t');\n const ref = fields[refColumn - 1];\n const refMatch = isIdentityRename\n ? ref === regionRefName\n : this.renameRefSeq(ref) === regionRefName;\n if (!refMatch) {\n return;\n }\n const startCoordinate = +fields[startColumn - 1] + coordinateOffset;\n if (startCoordinate >= regionEnd) {\n return null;\n }\n let endCoordinate;\n if (endColumn === 0 || endColumn === startColumn) {\n endCoordinate = startCoordinate + 1;\n }\n else if (isVCF) {\n endCoordinate = this._getVcfEnd(startCoordinate, fields[3], fields[endColumn - 1]);\n }\n else {\n endCoordinate = +fields[endColumn - 1];\n }\n if (endCoordinate <= regionStart) {\n return;\n }\n return { start: startCoordinate, end: endCoordinate };\n }\n // Long lines - use indexOf chain (avoids parsing long attribute column)\n let prev = -1;\n const tabs = [-1];\n for (let i = 0; i < maxColumn; i++) {\n const pos = line.indexOf('\\t', prev + 1);\n if (pos === -1) {\n tabs.push(line.length);\n break;\n }\n tabs.push(pos);\n prev = pos;\n }\n const ref = line.slice(tabs[refColumn - 1] + 1, tabs[refColumn]);\n const refMatch = isIdentityRename\n ? ref === regionRefName\n : this.renameRefSeq(ref) === regionRefName;\n if (!refMatch) {\n return;\n }\n const startCoordinate = +line.slice(tabs[startColumn - 1] + 1, tabs[startColumn]) +\n coordinateOffset;\n if (startCoordinate >= regionEnd) {\n return null;\n }\n let endCoordinate;\n if (endColumn === 0 || endColumn === startColumn) {\n endCoordinate = startCoordinate + 1;\n }\n else if (isVCF) {\n endCoordinate = this._getVcfEnd(startCoordinate, line.slice(tabs[3] + 1, tabs[4]), line.slice(tabs[endColumn - 1] + 1, tabs[endColumn]));\n }\n else {\n endCoordinate = +line.slice(tabs[endColumn - 1] + 1, tabs[endColumn]);\n }\n if (endCoordinate <= regionStart) {\n return;\n }\n return { start: startCoordinate, end: endCoordinate };\n }\n _getVcfEnd(startCoordinate, refSeq, info) {\n let endCoordinate = startCoordinate + refSeq.length;\n const isTRA = info.includes('SVTYPE=TRA');\n if (isTRA) {\n return startCoordinate + 1;\n }\n if (info[0] !== '.') {\n const endIdx = info.indexOf('END=');\n if (endIdx !== -1 && (endIdx === 0 || info[endIdx - 1] === ';')) {\n const start = endIdx + 4;\n let end = info.indexOf(';', start);\n if (end === -1) {\n end = info.length;\n }\n endCoordinate = Number.parseInt(info.slice(start, end), 10);\n }\n }\n return endCoordinate;\n }\n /**\n * return the approximate number of data lines in the given reference\n * sequence\n *\n * @param refSeq reference sequence name\n *\n * @returns number of data lines present on that reference sequence\n */\n async lineCount(refName, opts = {}) {\n return this.index.lineCount(refName, opts);\n }\n /**\n * read and uncompress the data in a chunk (composed of one or more\n * contiguous bgzip blocks) of the file\n */\n async readChunk(c, opts = {}) {\n const ret = await this.filehandle.read(c.fetchedSize(), c.minv.blockPosition, opts);\n return unzipChunkSlice(ret, c, this.cache);\n }\n}\n//# sourceMappingURL=tabixIndexedFile.js.map","/**\n * Tabix/BGZF reader — public API.\n *\n * Thin wrapper around @gmod/tabix that preserves the existing public API.\n * All BGZF decompression, index parsing, and block fetching is handled\n * by @gmod/tabix internally.\n */\n\nimport {TabixIndexedFile} from '@gmod/tabix'\nimport {RemoteFile} from 'generic-filehandle2'\n\n// ─── Types (preserved for backward compatibility) ─────────────────────────────\n\nexport interface TabixReaderOptions {\n /** URL to the .tbi index file. Defaults to `url + '.tbi'`. */\n indexUrl?: string\n}\n\nexport interface TabixHeader {\n nref: number\n format: number\n colSeq: number\n colBeg: number\n colEnd: number\n meta: number\n skip: number\n sequenceNames: string[]\n}\n\n// ─── Public API ───────────────────────────────────────────────────────────────\n\n/**\n * Thin wrapper around @gmod/tabix TabixIndexedFile that preserves the legacy API.\n */\nexport class TabixReader {\n private readonly tabix: TabixIndexedFile\n\n constructor(url: string, options?: TabixReaderOptions) {\n const indexUrl = options?.indexUrl ?? url + '.tbi'\n this.tabix = new TabixIndexedFile({\n filehandle: new RemoteFile(url),\n tbiFilehandle: new RemoteFile(indexUrl),\n })\n }\n\n /** Get the tabix header metadata. */\n async getHeader(signal?: AbortSignal): Promise<TabixHeader> {\n const meta = await this.tabix.getMetadata({signal})\n const refNames = Object.keys(meta.refNameToId)\n return {\n nref: refNames.length,\n format: meta.format === 'VCF' ? 2 : meta.format === 'SAM' ? 1 : 0,\n colSeq: meta.columnNumbers.ref,\n colBeg: meta.columnNumbers.start,\n colEnd: meta.columnNumbers.end,\n meta: meta.metaChar?.charCodeAt(0) ?? 0,\n skip: 0,\n sequenceNames: refNames,\n }\n }\n\n /** Get sequence names from the index. */\n async getSequenceNames(signal?: AbortSignal): Promise<string[]> {\n const meta = await this.tabix.getMetadata({signal})\n return Object.keys(meta.refNameToId)\n }\n\n /**\n * Read header lines from the beginning of the BGZF data file.\n * Returns lines that start with the meta character (e.g. '#' for VCF).\n */\n async readHeaderLines(signal?: AbortSignal): Promise<string[]> {\n const headerStr = await this.tabix.getHeader({signal})\n if (!headerStr) return []\n return headerStr.split('\\n').filter(line => line.length > 0)\n }\n\n /**\n * Read all text lines overlapping a genomic range.\n *\n * @param chr - Chromosome/sequence name\n * @param start - Start position (0-based)\n * @param end - End position (exclusive)\n */\n async readLines(\n chr: string,\n start: number,\n end: number,\n signal?: AbortSignal,\n ): Promise<string[]> {\n const lines: string[] = []\n await this.tabix.getLines(chr, start, end, {\n lineCallback: (line: string) => {\n lines.push(line)\n },\n signal,\n })\n return lines\n }\n}\n","/**\n * BED format decoders — BED (3-12 columns), narrowPeak, broadPeak, bedGraph, gappedPeak.\n *\n * Port of js/feature/decode/ucsc.ts (decodeBed, decodePeak, decodeNarrowPeak,\n * decodeBedGraph, decodeGappedPeak).\n *\n * Layer 1 (Data + Layout): pure functions, no I/O, no DOM.\n */\n\nimport type {Exon, BedFeature, PeakFeature, BedGraphFeature} from '../types'\nimport {findUTRs, parseColorString, parseStrand} from './exonUtils'\n\n/** Header metadata extracted from track lines and column directives. */\nexport interface BedHeader {\n nameField?: string\n /** When true, column 4 may contain GFF-style key=value attributes. */\n gffTags?: boolean\n /** Column index for color (from #columns directive). */\n colorColumn?: number\n /** Column index for thickness (from #columns directive). */\n thicknessColumn?: number\n}\n\n/**\n * Decode a BED format line (3-12 columns) into a BedFeature.\n *\n * Port of js/feature/decode/ucsc.ts::decodeBed().\n * Preserves igv.js patterns:\n * - Column count gating with maxColumnCount\n * - GFF-style attribute parsing in col4 when contains `=` and `;`\n * - Exon block validation (count < 1000, sizes.length === starts.length === count)\n * - Early return on parse errors (partial feature returned, not rejected)\n * - Color parsing for col8 (skip \".\" and \"0\")\n */\nexport function decodeBed(\n tokens: string[],\n header?: BedHeader,\n maxColumnCount: number = Number.MAX_SAFE_INTEGER,\n): BedFeature | undefined {\n\n if (tokens.length < 3) return undefined\n\n const gffTags = header?.gffTags\n\n const chr = tokens[0]\n const start = parseInt(tokens[1])\n const end = tokens.length > 2 ? parseInt(tokens[2]) : start + 1\n if (isNaN(start) || isNaN(end)) return undefined\n\n const feature: BedFeature = {chr, start, end, score: 1000}\n\n let columnCount = 3\n\n // Column 3: name (or GFF-style attributes)\n if (tokens.length > 3 && columnCount++ < maxColumnCount) {\n if (tokens[3].indexOf(';') > 0 && tokens[3].indexOf('=') > 0) {\n const attrs = parseGFFStyleAttributes(tokens[3])\n feature.attributes = attrs\n if (gffTags) {\n if (header?.nameField != null && attrs[header.nameField]) {\n feature.name = attrs[header.nameField]\n } else if (!feature.name) {\n for (const field of gffNameFields) {\n if (attrs[field]) {\n feature.name = attrs[field]\n break\n }\n }\n }\n }\n }\n if (!feature.name && !gffTags) {\n feature.name = tokens[3] === '.' ? '' : tokens[3]\n }\n }\n\n // Column 4: score\n if (tokens.length > 4 && columnCount++ < maxColumnCount) {\n feature.score = tokens[4] === '.' ? 0 : Number(tokens[4])\n if (isNaN(feature.score)) return feature\n }\n\n // Column 5: strand\n if (tokens.length > 5 && columnCount++ < maxColumnCount) {\n const s = tokens[5]\n if (s !== '.' && s !== '+' && s !== '-') return feature\n feature.strand = s as '+' | '-' | '.'\n }\n\n // Column 6: thickStart (cdStart)\n if (tokens.length > 6 && columnCount++ < maxColumnCount) {\n feature.cdStart = parseInt(tokens[6])\n if (isNaN(feature.cdStart)) return feature\n }\n\n // Column 7: thickEnd (cdEnd)\n if (tokens.length > 7 && columnCount++ < maxColumnCount) {\n feature.cdEnd = parseInt(tokens[7])\n if (isNaN(feature.cdEnd)) return feature\n }\n\n // Column 8: color\n if (tokens.length > 8 && columnCount++ < maxColumnCount) {\n if (tokens[8] !== '.' && tokens[8] !== '0') {\n feature.color = parseColorString(tokens[8])\n }\n }\n\n // Columns 9-11: exon blocks (blockCount, blockSizes, blockStarts)\n if (tokens.length > 11 && columnCount++ < maxColumnCount) {\n const exonCount = parseInt(tokens[9])\n // Basic sanity check\n if (exonCount > 1000) return feature\n\n const exonSizes = tokens[10].replace(/,$/, '').split(',')\n const exonStarts = tokens[11].replace(/,$/, '').split(',')\n if (!(exonSizes.length === exonStarts.length && exonCount === exonSizes.length)) {\n return feature\n }\n\n const exons: Exon[] = []\n for (let i = 0; i < exonCount; i++) {\n const eStart = start + parseInt(exonStarts[i])\n const eEnd = eStart + parseInt(exonSizes[i])\n exons.push({start: eStart, end: eEnd})\n }\n if (exons.length > 0) {\n findUTRs(exons, feature.cdStart ?? start, feature.cdEnd ?? end)\n feature.exons = exons\n }\n }\n\n // Optional extra columns from header directives\n if (header) {\n if (header.thicknessColumn !== undefined && tokens.length > header.thicknessColumn) {\n feature.thickness = parseFloat(tokens[header.thicknessColumn])\n }\n if (header.colorColumn !== undefined && tokens.length > header.colorColumn) {\n const c = parseColorString(tokens[header.colorColumn])\n if (c) feature.color = c\n }\n }\n\n return feature\n}\n\n/**\n * Decode a broadPeak/regionPeak format line (BED6+3: signal, pValue, qValue).\n *\n * Port of js/feature/decode/ucsc.ts::decodePeak().\n */\nexport function decodeBroadPeak(tokens: string[], header?: BedHeader): PeakFeature | undefined {\n const bed = decodeBed(tokens, header, 6) as PeakFeature | undefined\n if (!bed) return undefined\n\n if (tokens.length > 6) bed.signal = parseFloat(tokens[6])\n if (tokens.length > 7) bed.pValue = parseFloat(tokens[7])\n if (tokens.length > 8) bed.qValue = parseFloat(tokens[8])\n\n return bed\n}\n\n/**\n * Decode a narrowPeak format line (BED6+4: signal, pValue, qValue, peak).\n *\n * Port of js/feature/decode/ucsc.ts::decodeNarrowPeak().\n */\nexport function decodeNarrowPeak(tokens: string[], header?: BedHeader): PeakFeature | undefined {\n const bed = decodeBed(tokens, header, 6) as PeakFeature | undefined\n if (!bed) return undefined\n\n if (tokens.length > 6) bed.signal = parseFloat(tokens[6])\n if (tokens.length > 7) bed.pValue = parseFloat(tokens[7])\n if (tokens.length > 8) bed.qValue = parseFloat(tokens[8])\n if (tokens.length > 9) bed.peak = parseInt(tokens[9])\n\n return bed\n}\n\n/**\n * Decode a gappedPeak format line (BED12+3: signal, pValue, qValue).\n *\n * Port of js/feature/decode/ucsc.ts::decodeGappedPeak().\n */\nexport function decodeGappedPeak(tokens: string[], header?: BedHeader): PeakFeature | undefined {\n const bed = decodeBed(tokens, header) as PeakFeature | undefined\n if (!bed) return undefined\n\n if (tokens.length > 12) bed.signal = parseFloat(tokens[12])\n if (tokens.length > 13) bed.pValue = parseFloat(tokens[13])\n if (tokens.length > 14) bed.qValue = parseFloat(tokens[14])\n\n return bed\n}\n\n/**\n * Decode a BedGraph line (chr, start, end, value).\n *\n * Port of js/feature/decode/ucsc.ts::decodeBedGraph().\n */\nexport function decodeBedGraph(tokens: string[]): BedGraphFeature | undefined {\n if (tokens.length < 4) return undefined\n\n const chr = tokens[0]\n const start = parseInt(tokens[1])\n const end = parseInt(tokens[2])\n const value = parseFloat(tokens[3])\n\n if (isNaN(start) || isNaN(end) || isNaN(value)) return undefined\n\n return {chr, start, end, value}\n}\n\n/**\n * Decode a refFlat format line.\n *\n * Format: geneName, name, chrom, strand, txStart, txEnd, cdsStart, cdsEnd,\n * exonCount, exonStarts, exonEnds\n *\n * Port of js/feature/decode/ucsc.ts::decodeReflat().\n */\nexport function decodeRefflat(tokens: string[]): BedFeature | undefined {\n if (tokens.length < 11) return undefined\n\n const chr = tokens[2]\n const start = parseInt(tokens[4])\n const end = parseInt(tokens[5])\n const cdStart = parseInt(tokens[6])\n const cdEnd = parseInt(tokens[7])\n const strand = parseStrand(tokens[3])\n\n if (isNaN(start) || isNaN(end)) return undefined\n\n const feature: BedFeature = {\n chr,\n start,\n end,\n name: tokens[0],\n strand: strand as BedFeature['strand'],\n cdStart,\n cdEnd,\n }\n\n const exonCount = parseInt(tokens[8])\n const exonStarts = tokens[9].replace(/,$/, '').split(',')\n const exonEnds = tokens[10].replace(/,$/, '').split(',')\n\n if (exonCount > 0 && exonStarts.length === exonCount && exonEnds.length === exonCount) {\n const exons: Exon[] = []\n for (let i = 0; i < exonCount; i++) {\n exons.push({start: parseInt(exonStarts[i]), end: parseInt(exonEnds[i])})\n }\n findUTRs(exons, cdStart, cdEnd)\n feature.exons = exons\n }\n\n return feature\n}\n\n// ─── Internal helpers ────────────────────────────────────────────────────────\n\nconst gffNameFields = ['Name', 'transcript_id', 'gene_name', 'gene', 'gene_id', 'alias', 'locus', 'name']\n\n/** Parse GFF-style key=value attributes from BED column 4. */\nfunction parseGFFStyleAttributes(value: string): Record<string, string> {\n const attrs: Record<string, string> = {}\n const pairs = value.split(';')\n for (const pair of pairs) {\n const idx = pair.indexOf('=')\n if (idx > 0) {\n const key = pair.substring(0, idx).trim()\n const val = pair.substring(idx + 1).trim()\n attrs[key] = val\n }\n }\n return attrs\n}\n","/**\n * GFF3/GTF format decoders and transcript assembly.\n *\n * Ports:\n * - js/feature/gff/gff.ts (decodeGFF3, decodeGTF)\n * - js/feature/gff/parseAttributeString.ts (parseAttributeString, decodeGFFAttribute)\n * - js/feature/gff/gffHelper.ts (combineFeatures — transcript assembly)\n * - js/feature/gff/so.ts (sequence ontology type checks)\n *\n * Layer 1 (Data + Layout): pure functions, no I/O, no DOM.\n */\n\nimport type {Exon, GFFRecord, GFFFeature} from '../types'\n\n// ─── Sequence ontology type checks (port of js/feature/gff/so.ts) ───────────\n\nconst transcriptTypes = new Set([\n 'transcript', 'primary_transcript', 'processed_transcript', 'mRNA', 'mrna',\n 'lnc_RNA', 'miRNA', 'ncRNA', 'rRNA', 'scRNA', 'snRNA', 'snoRNA', 'tRNA',\n])\nconst cdsTypes = new Set(['CDS', 'cds', 'start_codon', 'stop_codon'])\nconst utrTypes = new Set(['5UTR', '3UTR', 'UTR', 'five_prime_UTR', 'three_prime_UTR', \"3'-UTR\", \"5'-UTR\"])\nconst exonTypes = new Set(['exon', 'coding-exon'])\n\nconst transcriptPartTypes = new Set<string>()\nfor (const cltn of [cdsTypes, utrTypes, exonTypes]) {\n for (const t of cltn) transcriptPartTypes.add(t)\n}\n\nexport function isTranscript(type: string): boolean {\n return transcriptTypes.has(type) || type.endsWith('RNA') || type.endsWith('transcript')\n}\nexport function isTranscriptPart(type: string): boolean {\n return transcriptPartTypes.has(type) || type.endsWith('RNA') || isIntron(type)\n}\nexport function isExon(type: string): boolean { return exonTypes.has(type) }\nexport function isIntron(type: string): boolean { return type.includes('intron') }\nexport function isCoding(type: string): boolean { return cdsTypes.has(type) }\nexport function isUTR(type: string): boolean { return utrTypes.has(type) }\n\n// ─── GFF attribute parsing (port of js/feature/gff/parseAttributeString.ts) ─\n\nconst gffEncodings = new Map<string, string>([\n ['%09', '\\t'], ['%0A', '\\n'], ['%0D', '\\r'], ['%25', '%'],\n ['%3B', ';'], ['%3D', '='], ['%26', '&'], ['%2C', ','],\n])\n\n/** Decode GFF3 percent-encoded characters. */\nexport function decodeGFFAttribute(str: string): string {\n if (!str.includes('%')) return str\n let decoded = ''\n for (let i = 0; i < str.length; i++) {\n if (str.charCodeAt(i) === 37 && i < str.length - 2) {\n const key = str.substring(i, i + 3)\n if (gffEncodings.has(key)) {\n decoded += gffEncodings.get(key)!\n } else {\n decoded += key\n }\n i += 2\n } else {\n decoded += str.charAt(i)\n }\n }\n return decoded\n}\n\n/**\n * Parse GFF/GTF attribute string (column 9) into key-value pairs.\n *\n * Returns an array (not a map) because attribute keys are not required to be unique.\n * GFF3 uses `=` as key-value delimiter, GTF uses space.\n *\n * Port of js/feature/gff/parseAttributeString.ts::parseAttributeString().\n */\nexport function parseGFFAttributes(attributeString: string, keyValueDelim: string = '='): Array<[string, string]> {\n const isGff3 = keyValueDelim === '='\n const attributes: Array<[string, string]> = []\n for (let kv of attributeString.split(';')) {\n kv = kv.trim()\n const idx = kv.indexOf(keyValueDelim)\n if (idx > 0 && idx < kv.length - 1) {\n let key = decodeGFFAttribute(kv.substring(0, idx).trim())\n let value = decodeGFFAttribute(kv.substring(idx + 1).trim())\n if (!isGff3) {\n key = stripQuotes(key)\n value = stripQuotes(value)\n }\n attributes.push([key, value])\n }\n }\n return attributes\n}\n\nfunction stripQuotes(value: string): string {\n if (value.startsWith('\"') && value.endsWith('\"')) {\n return value.substring(1, value.length - 1)\n }\n return value\n}\n\n// ─── Single-record decoders (port of js/feature/gff/gff.ts) ────────────────\n\nfunction decodeBase(tokens: string[], _delim: string): GFFRecord | undefined {\n if (tokens.length < 9) return undefined\n\n const start = parseInt(tokens[3]) - 1 // GFF is 1-based\n const end = parseInt(tokens[4])\n if (isNaN(start) || isNaN(end)) return undefined\n\n const score = tokens[5] === '.' ? undefined : Number(tokens[5])\n const strand = tokens[6] === '+' || tokens[6] === '-' || tokens[6] === '.'\n ? tokens[6] as '+' | '-' | '.'\n : undefined\n const phase = tokens[7] === '.' ? undefined : parseInt(tokens[7])\n\n return {\n chr: tokens[0],\n source: decodeGFFAttribute(tokens[1]),\n type: tokens[2],\n start,\n end,\n score: score !== undefined && !isNaN(score) ? score : undefined,\n strand,\n phase: phase !== undefined && !isNaN(phase) ? phase : undefined,\n attributeString: tokens[8],\n attributes: {},\n }\n}\n\n/**\n * Decode a single GFF3 record line.\n *\n * Parses column 9 attributes with `=` delimiter, extracts ID, Parent, color.\n */\nexport function decodeGFF3(tokens: string[]): GFFRecord | undefined {\n const feature = decodeBase(tokens, '=')\n if (!feature) return undefined\n\n const attributes = parseGFFAttributes(feature.attributeString, '=')\n const attrs: Record<string, string> = {}\n\n for (const [key, value] of attributes) {\n attrs[key] = value\n const keyLower = key.toLowerCase()\n if (keyLower === 'color' || keyLower === 'colour') {\n feature.color = value\n } else if (key === 'ID') {\n feature.id = value\n } else if (key === 'Parent') {\n feature.parent = value\n }\n }\n feature.attributes = attrs\n\n return feature\n}\n\n/**\n * Decode a single GTF record line.\n *\n * Parses column 9 attributes with space delimiter, infers ID/Parent from\n * feature type (gene→gene_id, transcript→transcript_id, exon→transcript_id parent).\n */\nexport function decodeGTF(tokens: string[]): GFFRecord | undefined {\n const feature = decodeBase(tokens, ' ')\n if (!feature) return undefined\n\n const attributes = parseGFFAttributes(feature.attributeString, ' ')\n const attrs: Record<string, string> = {}\n\n // Infer ID/Parent fields based on feature type\n let idField: string | undefined\n let parentField: string | undefined\n switch (feature.type) {\n case 'gene':\n idField = 'gene_id'\n break\n case 'transcript':\n idField = 'transcript_id'\n parentField = 'gene_id'\n break\n default:\n parentField = 'transcript_id'\n }\n\n for (const [key, value] of attributes) {\n attrs[key] = value\n const keyLower = key.toLowerCase()\n if (keyLower === 'color' || keyLower === 'colour') {\n feature.color = value\n } else if (key === idField) {\n feature.id = value\n } else if (key === parentField) {\n feature.parent = value\n }\n }\n feature.attributes = attrs\n\n return feature\n}\n\n// ─── GFF name field resolution ──────────────────────────────────────────────\n\nconst gffNameFields = ['Name', 'transcript_id', 'gene_name', 'gene', 'gene_id', 'alias', 'locus', 'name']\n\nfunction getAttributeValue(record: GFFRecord, name: string): string | undefined {\n if (record.attributes[name] !== undefined) return record.attributes[name]\n // Fall back to parsing attribute string\n const delim = record.attributeString.includes('=') ? '=' : ' '\n const attrs = parseGFFAttributes(record.attributeString, delim)\n for (const [key, value] of attrs) {\n if (key === name) return value\n }\n return undefined\n}\n\n// ─── Transcript assembly (port of js/feature/gff/gffHelper.ts) ─────────────\n\ninterface AssemblyOptions {\n /** Custom name field to use for feature names. */\n nameField?: string\n /** Feature types to filter out (default: ['chromosome']). */\n filterTypes?: string[]\n}\n\n/** Internal transcript model used during assembly. */\ninterface TranscriptBuilder {\n record: GFFRecord\n exons: Exon[]\n parts: GFFRecord[]\n cdStart?: number\n cdEnd?: number\n geneRecord?: GFFRecord\n}\n\n/**\n * Assemble flat GFFRecords into hierarchical GFFFeatures (transcripts with exon structure).\n *\n * Combines gene→transcript→exon/CDS records by parent/ID relationships.\n * Handles both GFF3 (explicit ID/Parent) and GTF (inferred from feature type).\n *\n * Port of js/feature/gff/gffHelper.ts::combineFeatures().\n */\nexport function assembleGFFTranscripts(\n records: GFFRecord[],\n format: 'gff3' | 'gtf' | 'gff',\n options?: AssemblyOptions,\n): GFFFeature[] {\n const filterTypes = new Set(options?.filterTypes ?? ['chromosome'])\n let filtered = records.filter(r => !filterTypes.has(r.type))\n\n // For GFF3, merge multi-part features with same ID\n if (format === 'gff3' || format === 'gff') {\n filtered = combineFeaturesById(filtered)\n }\n\n const result = combineFeaturesByType(filtered, format, options?.nameField)\n return result\n}\n\n/**\n * Combine multiple non-transcript features with the same ID on the same chromosome.\n * Port of GFFHelper.combineFeaturesById().\n */\nfunction combineFeaturesById(records: GFFRecord[]): GFFRecord[] {\n const chrIdMap = new Map<string, Map<string, GFFRecord[]>>()\n const combined: GFFRecord[] = []\n\n for (const f of records) {\n if (isTranscriptPart(f.type) || isTranscript(f.type) || !f.id) {\n combined.push(f)\n } else {\n let idMap = chrIdMap.get(f.chr)\n if (!idMap) {\n idMap = new Map()\n chrIdMap.set(f.chr, idMap)\n }\n let arr = idMap.get(f.id)\n if (arr) {\n arr.push(f)\n } else {\n idMap.set(f.id, [f])\n }\n }\n }\n\n for (const idMap of chrIdMap.values()) {\n for (const arr of idMap.values()) {\n if (arr.length > 1) {\n // Use first as prototype, merge spans as exons\n const cf = {...arr[0]}\n const exons: Array<{start: number; end: number}> = []\n for (const f of arr) {\n cf.start = Math.min(cf.start, f.start)\n cf.end = Math.max(cf.end, f.end)\n exons.push({start: f.start, end: f.end})\n }\n // Store merged exons in a temporary property\n ;(cf as GFFRecord & {_mergedExons?: Array<{start: number; end: number}>})._mergedExons = exons\n combined.push(cf)\n } else {\n combined.push(arr[0])\n }\n }\n }\n\n return combined\n}\n\n/**\n * Build gene→transcript→exon hierarchy from flat records.\n * Port of GFFHelper.combineFeaturesByType().\n */\nfunction combineFeaturesByType(\n records: GFFRecord[],\n format: string,\n nameField?: string,\n): GFFFeature[] {\n // Build gene map\n const geneMap: Record<string, GFFRecord> = Object.create(null)\n for (const r of records) {\n if (r.type === 'gene' || r.type.endsWith('_gene')) {\n if (r.id) geneMap[r.id] = r\n }\n }\n\n // Build transcript map\n const transcripts: Record<string, TranscriptBuilder> = Object.create(null)\n const result: GFFFeature[] = []\n const consumed = new Set<GFFRecord>()\n\n for (const r of records) {\n if (isTranscript(r.type) && r.id !== undefined) {\n const builder: TranscriptBuilder = {\n record: r,\n exons: [],\n parts: [],\n }\n transcripts[r.id] = builder\n consumed.add(r)\n\n // Link to parent gene\n if (r.parent && geneMap[r.parent]) {\n builder.geneRecord = geneMap[r.parent]\n consumed.add(geneMap[r.parent])\n }\n }\n }\n\n // Add exons and transcript parts\n for (const r of records) {\n if (isTranscriptPart(r.type)) {\n const parents = getParents(r)\n if (parents) {\n for (const parentId of parents) {\n let transcript = transcripts[parentId]\n if (!transcript && (format === 'gtf')) {\n // GTF does not require explicit transcript record\n const pseudoRecord: GFFRecord = {...r, type: 'transcript'}\n transcript = {record: pseudoRecord, exons: [], parts: []}\n transcripts[parentId] = transcript\n }\n if (transcript) {\n if (isExon(r.type)) {\n transcript.exons.push({start: r.start, end: r.end})\n } else {\n transcript.parts.push(r)\n }\n // Expand transcript bounds\n transcript.record.start = Math.min(transcript.record.start, r.start)\n transcript.record.end = Math.max(transcript.record.end, r.end)\n consumed.add(r)\n }\n }\n }\n }\n }\n\n // Finish transcripts: assemble parts, compute CDS/UTR\n for (const id of Object.keys(transcripts)) {\n const t = transcripts[id]\n finishTranscript(t)\n result.push(transcriptToFeature(t, nameField))\n }\n\n // Add unconsumed features as simple features\n for (const r of records) {\n if (!consumed.has(r)) {\n result.push(recordToSimpleFeature(r, nameField))\n }\n }\n\n // Number exons\n numberExons(result)\n\n return result\n}\n\n/** Assemble CDS/UTR parts into exon structure. Port of GFFTranscript.finish(). */\nfunction finishTranscript(t: TranscriptBuilder): void {\n // Sort parts\n t.parts.sort((a, b) => a.start - b.start)\n\n // Create implicit exons from CDS/UTR parts if no explicit exons\n if (t.parts.length > 0) {\n let lastStart = t.parts[0].start\n let lastEnd = t.parts[0].end\n\n for (let i = 1; i < t.parts.length; i++) {\n const part = t.parts[i]\n if (isIntron(part.type)) continue\n if (part.start <= lastEnd) {\n lastEnd = Math.max(lastEnd, part.end)\n } else {\n // Gap — check if an exon already covers this span\n if (!findExonContaining(t.exons, lastStart, lastEnd)) {\n t.exons.push({start: lastStart, end: lastEnd})\n }\n lastStart = part.start\n lastEnd = part.end\n }\n }\n if (!findExonContaining(t.exons, lastStart, lastEnd)) {\n t.exons.push({start: lastStart, end: lastEnd})\n t.record.start = Math.min(t.record.start, lastStart)\n t.record.end = Math.max(t.record.end, lastEnd)\n }\n }\n\n // Apply CDS parts\n for (const part of t.parts) {\n if (isCoding(part.type)) {\n addCDS(t, part)\n } else if (isUTR(part.type)) {\n addUTR(t, part)\n }\n }\n\n // Sort exons and mark fully UTR exons\n t.exons.sort((a, b) => a.start - b.start)\n if (t.cdStart !== undefined && t.cdEnd !== undefined) {\n for (const exon of t.exons) {\n if (exon.end < t.cdStart! || exon.start > t.cdEnd!) {\n exon.utr = true\n }\n }\n }\n}\n\nfunction findExonContaining(exons: Exon[], start: number, end: number): Exon | undefined {\n for (const exon of exons) {\n if (exon.end >= end && exon.start <= start) return exon\n }\n return undefined\n}\n\nfunction addCDS(t: TranscriptBuilder, cds: GFFRecord): void {\n const exon = findExonContaining(t.exons, cds.start, cds.end)\n if (exon) {\n exon.cdStart = exon.cdStart !== undefined ? Math.min(cds.start, exon.cdStart) : cds.start\n exon.cdEnd = exon.cdEnd !== undefined ? Math.max(cds.end, exon.cdEnd) : cds.end\n // Reading frame from phase\n if (cds.phase !== undefined) {\n const readingFrame = (3 - cds.phase) % 3\n if (exon.readingFrame === undefined) {\n exon.readingFrame = readingFrame\n }\n }\n }\n t.cdStart = t.cdStart !== undefined ? Math.min(cds.start, t.cdStart) : cds.start\n t.cdEnd = t.cdEnd !== undefined ? Math.max(cds.end, t.cdEnd) : cds.end\n}\n\nfunction addUTR(t: TranscriptBuilder, utr: GFFRecord): void {\n const exon = findExonContaining(t.exons, utr.start, utr.end)\n if (exon) {\n if (utr.start === exon.start && utr.end === exon.end) {\n exon.utr = true\n } else {\n if (utr.end < exon.end) {\n exon.cdStart = utr.end\n }\n if (exon.cdEnd === undefined || utr.start > exon.cdEnd) {\n exon.cdEnd = utr.start\n }\n }\n }\n}\n\nfunction getParents(r: GFFRecord): string[] | null {\n if (r.parent && r.parent.trim() !== '') {\n return r.parent.trim().split(',')\n }\n return null\n}\n\n/** Convert a TranscriptBuilder into a GFFFeature. */\nfunction transcriptToFeature(t: TranscriptBuilder, nameField?: string): GFFFeature {\n const r = t.record\n const name = resolveName(r, nameField)\n\n return {\n chr: r.chr,\n start: r.start,\n end: r.end,\n name,\n id: r.id,\n strand: r.strand === '+' || r.strand === '-' ? r.strand : undefined,\n type: r.type,\n source: r.source,\n score: r.score,\n cdStart: t.cdStart,\n cdEnd: t.cdEnd,\n exons: t.exons.length > 0 ? t.exons : undefined,\n attributes: r.attributes,\n color: r.color,\n }\n}\n\n/** Convert a GFFRecord into a simple GFFFeature (no transcript assembly). */\nfunction recordToSimpleFeature(r: GFFRecord, nameField?: string): GFFFeature {\n const name = resolveName(r, nameField)\n const mergedExons = (r as GFFRecord & {_mergedExons?: Array<{start: number; end: number}>})._mergedExons\n\n return {\n chr: r.chr,\n start: r.start,\n end: r.end,\n name,\n id: r.id,\n strand: r.strand === '+' || r.strand === '-' ? r.strand : undefined,\n type: r.type,\n source: r.source,\n score: r.score,\n exons: mergedExons,\n attributes: r.attributes,\n color: r.color,\n }\n}\n\nfunction resolveName(r: GFFRecord, nameField?: string): string | undefined {\n if (nameField) {\n return getAttributeValue(r, nameField)\n }\n for (const field of gffNameFields) {\n const v = getAttributeValue(r, field)\n if (v) return v\n }\n return undefined\n}\n\n/** Assign exon numbers based on strand direction. Port of GFFHelper.numberExons(). */\nfunction numberExons(features: GFFFeature[]): void {\n for (const f of features) {\n if (f.exons) {\n for (let i = 0; i < f.exons.length; i++) {\n f.exons[i].number = f.strand === '-' ? f.exons.length - i : i + 1\n }\n }\n }\n}\n","/**\n * BEDPE format decoder — pairwise genomic interactions (Hi-C, ChIA-PET, SVs).\n *\n * Standard BEDPE: 10+ columns (chr1/start1/end1/chr2/start2/end2/name/score/strand1/strand2).\n * Variants: 7-column (score in name column), hiccups (6 standard + extra columns).\n *\n * Port of js/feature/decode/bedpe.ts.\n * Layer 1 (Data + Layout): pure functions, no I/O, no DOM.\n */\n\nimport type {InteractionFeature} from '../types'\n\n/** Header metadata for BEDPE files. */\nexport interface BedpeHeader {\n /** Whether this is a hiccups-format file (auto-detected on first feature). */\n hiccups?: boolean\n /** Column names from header line. */\n columnNames?: string[]\n /** Column index for per-feature color. */\n colorColumn?: number\n /** Column index for per-feature line thickness. */\n thicknessColumn?: number\n}\n\n/**\n * Decode a single BEDPE line into an InteractionFeature.\n *\n * Handles standard 10-column BEDPE and hiccups variants.\n * Returns undefined for unparseable lines.\n */\nexport function decodeBedpe(tokens: string[], header?: BedpeHeader): InteractionFeature | undefined {\n if (tokens.length < 6) return undefined\n\n const chr1 = tokens[0]\n const start1 = parseInt(tokens[1])\n const end1 = parseInt(tokens[2])\n const chr2 = tokens[3]\n const start2 = parseInt(tokens[4])\n const end2 = parseInt(tokens[5])\n\n if (isNaN(start1) || isNaN(end1) || isNaN(start2) || isNaN(end2)) return undefined\n\n // Detect hiccups format on first feature (store on header for reuse)\n if (header && header.hiccups === undefined) {\n header.hiccups = header.columnNames ? isHiccups(header.columnNames) : false\n }\n const hiccups = header?.hiccups ?? false\n const stdColumns = hiccups ? 6 : 10\n\n const feature: InteractionFeature = {\n chr: chr1, start: 0, end: 0,\n chr1, start1, end1,\n chr2, start2, end2,\n dup: false,\n }\n\n if (!hiccups) {\n if (tokens.length > 6 && tokens[6] !== '.') {\n feature.name = tokens[6]\n }\n if (tokens.length > 7 && tokens[7] !== '.') {\n feature.score = Number(tokens[7])\n }\n if (tokens.length > 8 && tokens[8] !== '.') {\n feature.strand1 = tokens[8]\n }\n if (tokens.length > 9 && tokens[9] !== '.') {\n feature.strand2 = tokens[9]\n }\n }\n\n // Optional extra columns (color, thickness)\n if (header) {\n if (header.colorColumn !== undefined && header.colorColumn < tokens.length) {\n feature.color = tokens[header.colorColumn]\n }\n if (header.thicknessColumn !== undefined && header.thicknessColumn < tokens.length) {\n feature.thickness = Number(tokens[header.thicknessColumn])\n }\n if (tokens.length > stdColumns && header.columnNames && header.columnNames.length === tokens.length) {\n feature.extras = tokens.slice(stdColumns)\n }\n }\n\n // Set bounding extent for same-chromosome features\n if (chr1 === chr2) {\n feature.chr = chr1\n feature.start = Math.min(start1, start2)\n feature.end = Math.max(end1, end2)\n }\n\n return feature\n}\n\n/**\n * Post-process BEDPE features:\n * 1. Auto-detect score in name column (non-standard 7-col variant).\n * 2. Duplicate inter-chromosome features so each chromosome has a copy.\n */\nexport function fixBedPE(features: InteractionFeature[]): void {\n if (features.length === 0) return\n\n // Check if name column contains numeric scores\n const first = features[0]\n if (first.score === undefined && first.name !== undefined) {\n const allNumeric = features.every(f => f.name === undefined || f.name === '.' || isNumeric(f.name))\n if (allNumeric) {\n for (const f of features) {\n f.score = Number(f.name)\n f.name = undefined\n }\n }\n }\n\n // Duplicate inter-chr features for both chromosomes\n const interChr = features.filter(f => f.chr1 !== f.chr2)\n for (const f1 of interChr) {\n const f2: InteractionFeature = {...f1, dup: true}\n features.push(f2)\n\n f1.chr = f1.chr1\n f1.start = f1.start1\n f1.end = f1.end1\n\n f2.chr = f2.chr2\n f2.start = f2.start2\n f2.end = f2.end2\n }\n}\n\n/** Detect hiccups format from column headers. */\nexport function isHiccups(columns: string[]): boolean {\n return columns.includes('fdrDonut') || columns.includes('fdr_donut')\n}\n\nfunction isNumeric(s: string): boolean {\n return !isNaN(Number(s)) && s.trim() !== ''\n}\n","/**\n * Feature parser — lines → typed features.\n *\n * Dispatches to format-specific decoders based on format string. Handles\n * header parsing, comment skipping, delimiter selection, and GFF assembly.\n *\n * Port of js/feature/featureParser.ts.\n *\n * Layer 1 (Data + Layout): pure functions, no I/O, no DOM.\n */\n\nimport type {BedFeature, PeakFeature, BedGraphFeature, GFFRecord, GFFFeature, InteractionFeature, TextFileFormat} from '../types'\nimport {decodeBed, decodeBroadPeak, decodeNarrowPeak, decodeBedGraph, decodeGappedPeak, decodeRefflat} from '../decode/bed'\nimport type {BedHeader} from '../decode/bed'\nimport {decodeGFF3, decodeGTF, assembleGFFTranscripts} from '../decode/gff'\nimport {decodeGenePred, decodeGenePredExt} from '../decode/ucsc'\nimport {decodeBedpe, fixBedPE} from '../decode/bedpe'\nimport type {BedpeHeader} from '../decode/bedpe'\nimport {decodeInteract} from '../decode/interact'\n\n/** Decoder function type — takes tokens from a split line, returns a feature or undefined. */\nexport type DecoderFunction = (tokens: string[], header?: Record<string, unknown>) => unknown | undefined\n\n/** Header metadata extracted from track lines, column directives, and format directives. */\nexport interface FeatureHeader {\n format?: string\n nameField?: string\n gffTags?: boolean\n columnNames?: string[]\n colorColumn?: number\n thicknessColumn?: number\n /** Properties parsed from track lines. */\n properties?: Record<string, string>\n /** Wig step/span directive state (for fixedStep/variableStep). */\n wig?: WigDirective\n /** Column shift (1 for refgene/ensgene formats). */\n shift?: number\n}\n\ninterface WigDirective {\n format: string\n chrom: string\n start?: number\n step?: number\n span: number\n index?: number\n}\n\ninterface DecoderInfo {\n decode: (tokens: string[], header: FeatureHeader) => unknown | undefined\n delimiter: string | RegExp\n /** Whether parsed features need GFF transcript assembly. */\n requiresAssembly: boolean\n /** Optional post-processing of all decoded features (e.g., BEDPE fixup). */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n postProcess?: (features: any[]) => void\n}\n\n/**\n * Get the appropriate decoder function and delimiter for a format string.\n *\n * Port of js/feature/featureParser.ts::setDecoder().\n */\nexport function getDecoder(format: TextFileFormat, _header?: FeatureHeader): DecoderInfo {\n switch (format) {\n case 'broadpeak':\n case 'peaks':\n return {decode: (t, h) => decodeBroadPeak(t, toBedHeader(h)), delimiter: /\\s+/, requiresAssembly: false}\n case 'narrowpeak':\n return {decode: (t, h) => decodeNarrowPeak(t, toBedHeader(h)), delimiter: /\\s+/, requiresAssembly: false}\n case 'bedgraph':\n return {decode: (t) => decodeBedGraph(t), delimiter: /\\s+/, requiresAssembly: false}\n case 'gff3':\n case 'gff':\n return {decode: (t) => decodeGFF3(t), delimiter: '\\t', requiresAssembly: true}\n case 'gtf':\n return {decode: (t) => decodeGTF(t), delimiter: '\\t', requiresAssembly: true}\n case 'refflat':\n return {decode: (t) => decodeRefflat(t), delimiter: /\\s+/, requiresAssembly: false}\n case 'genepred':\n return {decode: (t) => decodeGenePred(t, 0), delimiter: /\\s+/, requiresAssembly: false}\n case 'genepredext':\n return {decode: (t) => decodeGenePredExt(t, 0), delimiter: /\\s+/, requiresAssembly: false}\n case 'ensgene':\n return {decode: (t) => decodeGenePred(t, 1), delimiter: /\\s+/, requiresAssembly: false}\n case 'refgene':\n return {decode: (t) => decodeGenePredExt(t, 1), delimiter: /\\s+/, requiresAssembly: false}\n case 'gappedpeak':\n return {decode: (t, h) => decodeGappedPeak(t, toBedHeader(h)), delimiter: /\\s+/, requiresAssembly: false}\n case 'bedpe':\n return {decode: (t, h) => decodeBedpe(t, toBedpeHeader(h)), delimiter: /\\s+/, requiresAssembly: false, postProcess: fixBedPE}\n case 'interact':\n case 'longrange':\n return {decode: (t) => decodeInteract(t), delimiter: /\\s+/, requiresAssembly: false}\n case 'bed':\n default:\n return {decode: (t, h) => decodeBed(t, toBedHeader(h)), delimiter: /\\s+/, requiresAssembly: false}\n }\n}\n\nfunction toBedHeader(h?: FeatureHeader): BedHeader | undefined {\n if (!h) return undefined\n return {\n nameField: h.nameField,\n gffTags: h.gffTags,\n colorColumn: h.colorColumn,\n thicknessColumn: h.thicknessColumn,\n }\n}\n\nfunction toBedpeHeader(h?: FeatureHeader): BedpeHeader | undefined {\n if (!h) return undefined\n return {\n columnNames: h.columnNames,\n colorColumn: h.colorColumn,\n thicknessColumn: h.thicknessColumn,\n }\n}\n\n/**\n * Parse header information from text lines.\n *\n * Extracts track line properties, column names, format directives\n * (#gffTags, ##gff-version 3, etc.).\n *\n * Port of js/feature/featureParser.ts::parseHeader().\n */\nexport function parseHeader(lines: string[], format: TextFileFormat): FeatureHeader {\n const header: FeatureHeader = {format}\n let columnNames: string[] | undefined\n\n for (const line of lines) {\n if (line.startsWith('track') || line.startsWith('#track')) {\n const props = parseTrackLine(line)\n Object.assign(header, {properties: props})\n if (props.type === 'interact') header.format = 'interact'\n if (props.type === 'gcnv') header.format = 'gcnv'\n } else if (line.startsWith('browser')) {\n // UCSC browser line, ignore\n } else if (line.startsWith('#columns')) {\n const cd = parseColumnsDirective(line)\n if (cd.colorColumn !== undefined) header.colorColumn = cd.colorColumn\n if (cd.thicknessColumn !== undefined) header.thicknessColumn = cd.thicknessColumn\n } else if (line.startsWith('##gff-version 3')) {\n header.format = 'gff3'\n } else if (line.startsWith('#gffTags')) {\n header.gffTags = true\n } else if (line.startsWith('fixedStep') || line.startsWith('variableStep')) {\n // Wig directive — we're in the data section\n break\n } else if (line.startsWith('#')) {\n const tokens = line.split('\\t')\n if (tokens.length > 1) columnNames = tokens\n } else {\n // First non-header line reached\n break\n }\n }\n\n if (columnNames) {\n header.columnNames = columnNames\n for (let n = 0; n < columnNames.length; n++) {\n if (columnNames[n] === 'color' || columnNames[n] === 'colour') {\n header.colorColumn = n\n } else if (columnNames[n] === 'thickness') {\n header.thicknessColumn = n\n }\n }\n }\n\n return header\n}\n\n/**\n * Parse text lines into features for a given format.\n *\n * Handles: comment/header skipping, delimiter-based tokenization,\n * WIG directive parsing, GFF transcript assembly.\n *\n * Port of js/feature/featureParser.ts::parseFeatures().\n */\nexport function parseFeatures(\n lines: string[],\n format: TextFileFormat,\n options?: {\n header?: FeatureHeader\n assembleGFF?: boolean\n },\n): Array<BedFeature | PeakFeature | BedGraphFeature | GFFFeature | GFFRecord | InteractionFeature> {\n\n const header: FeatureHeader = options?.header ?? parseHeader(lines, format)\n const resolvedFormat = (header.format ?? format) as TextFileFormat\n const info = getDecoder(resolvedFormat, header)\n const delimiter = info.delimiter\n\n const allFeatures: unknown[] = []\n const wigState: {wig?: WigDirective} = {}\n\n for (const line of lines) {\n if (!line || line.startsWith('track') || line.startsWith('#') || line.startsWith('browser')) {\n continue\n }\n\n // WIG directives\n if (resolvedFormat === 'wig') {\n if (line.startsWith('fixedStep')) {\n wigState.wig = parseFixedStep(line)\n continue\n }\n if (line.startsWith('variableStep')) {\n wigState.wig = parseVariableStep(line)\n continue\n }\n }\n\n const tokens = line.split(delimiter)\n if (tokens.length < 1) continue\n\n // For wig format, pass wig state in header\n const decodeHeader = resolvedFormat === 'wig'\n ? {...header, wig: wigState.wig}\n : header\n\n const feature = info.decode(tokens, decodeHeader)\n if (feature) {\n allFeatures.push(feature)\n }\n }\n\n // Post-process (e.g., BEDPE fixup: score detection, inter-chr duplication)\n if (info.postProcess) {\n info.postProcess(allFeatures)\n }\n\n // GFF/GTF transcript assembly\n if (info.requiresAssembly && (options?.assembleGFF !== false)) {\n const gffFormat = resolvedFormat === 'gff' ? 'gff' :\n resolvedFormat === 'gff3' ? 'gff3' : 'gtf'\n return assembleGFFTranscripts(\n allFeatures as GFFRecord[],\n gffFormat as 'gff3' | 'gtf' | 'gff',\n {nameField: header.nameField},\n )\n }\n\n return allFeatures as Array<BedFeature | PeakFeature | BedGraphFeature | GFFFeature | InteractionFeature>\n}\n\n// ─── Internal helpers ────────────────────────────────────────────────────────\n\n/**\n * Parse a UCSC track line into key=value pairs.\n * Port of js/feature/featureParser.ts::parseTrackLine().\n */\nfunction parseTrackLine(line: string): Record<string, string> {\n const properties: Record<string, string> = {}\n const tokens = line.split(/(?:\")([^\"]+)(?:\")|([^\\s\"]+)(?=\\s+|$)/g)\n\n let curr: string | undefined\n const tmp: string[] = []\n for (const tk of tokens) {\n if (!tk || tk.trim().length === 0) continue\n if (tk.endsWith('=')) {\n curr = tk\n } else if (curr) {\n tmp.push(curr + tk)\n curr = undefined\n } else {\n tmp.push(tk)\n }\n }\n\n for (const str of tmp) {\n if (!str) break\n const kv = str.split('=', 2)\n if (kv.length === 2) {\n properties[kv[0].trim()] = kv[1].trim()\n }\n }\n return properties\n}\n\n/** Parse #columns directive. Port of js/feature/featureParser.ts::parseColumnsDirective(). */\nfunction parseColumnsDirective(line: string): {colorColumn?: number; thicknessColumn?: number} {\n const result: {colorColumn?: number; thicknessColumn?: number} = {}\n const t1 = line.split(/\\s+/)\n if (t1.length === 2) {\n const t2 = t1[1].split(';')\n for (const kv of t2) {\n const t = kv.split('=')\n if (t[0] === 'color') result.colorColumn = parseInt(t[1]) - 1\n else if (t[0] === 'thickness') result.thicknessColumn = parseInt(t[1]) - 1\n }\n }\n return result\n}\n\nfunction parseFixedStep(line: string): WigDirective {\n const tokens = line.split(/\\s+/)\n const chrom = tokens[1].split('=')[1]\n const start = parseInt(tokens[2].split('=')[1], 10) - 1\n const step = parseInt(tokens[3].split('=')[1], 10)\n const span = tokens.length > 4 ? parseInt(tokens[4].split('=')[1], 10) : 1\n return {format: 'fixedStep', chrom, start, step, span, index: 0}\n}\n\nfunction parseVariableStep(line: string): WigDirective {\n const tokens = line.split(/\\s+/)\n const chrom = tokens[1].split('=')[1]\n const span = tokens.length > 2 ? parseInt(tokens[2].split('=')[1], 10) : 1\n return {format: 'variableStep', chrom, span}\n}\n","/**\n * UCSC interact format decoder — 18-column pairwise genomic interactions.\n *\n * See https://genome.ucsc.edu/goldenpath/help/interact.html\n *\n * Columns: chrom, chromStart, chromEnd, name, score, value, exp, color,\n * sourceChrom, sourceStart, sourceEnd, sourceName, sourceStrand,\n * targetChrom, targetStart, targetEnd, targetName, targetStrand\n *\n * Port of js/feature/decode/interact.ts.\n * Layer 1 (Data + Layout): pure functions, no I/O, no DOM.\n */\n\nimport type {InteractionFeature} from '../types'\n\n/**\n * Decode a single UCSC interact format line into an InteractionFeature.\n *\n * Returns undefined for lines with fewer than 6 columns.\n */\nexport function decodeInteract(tokens: string[]): InteractionFeature | undefined {\n if (tokens.length < 6) return undefined\n\n const chr = tokens[0]\n const start = parseInt(tokens[1])\n const end = parseInt(tokens[2])\n\n const chr1 = tokens[8]\n const start1 = parseInt(tokens[9])\n const end1 = parseInt(tokens[10])\n\n const chr2 = tokens[13]\n const start2 = parseInt(tokens[14])\n const end2 = parseInt(tokens[15])\n\n const colorToken = tokens[7]\n const color = colorToken === '.' ? undefined\n : colorToken === '0' ? 'rgb(0,0,0)'\n : colorToken\n\n return {\n chr, start, end,\n chr1, start1, end1,\n chr2, start2, end2,\n name: tokens[3],\n score: Number(tokens[4]),\n value: Number(tokens[5]),\n color,\n dup: false,\n }\n}\n","/**\n * Format detection from URL/filename and track type inference.\n *\n * Port of js/util/fileFormatUtils.ts (inferFileFormatFromName, knownFileExtensions)\n * and js/util/trackUtils.ts (inferTrackType).\n *\n * Layer 1 (Data + Layout): pure functions, no I/O, no DOM.\n */\n\n/** Comprehensive set of known file extensions. Port of js/util/fileFormatUtils.ts. */\nexport const knownFileExtensions: ReadonlySet<string> = new Set([\n 'narrowpeak', 'broadpeak', 'regionpeak', 'peaks',\n 'bedgraph', 'wig',\n 'gff3', 'gff', 'gtf',\n 'fusionjuncspan', 'refflat',\n 'seg', 'aed', 'bed', 'bedmethyl',\n 'vcf',\n 'bb', 'bigbed', 'biginteract', 'biggenepred', 'bignarrowpeak',\n 'bw', 'bigwig',\n 'bam', 'tdf',\n 'refgene', 'genepred', 'genepredext',\n 'bedpe', 'bp', 'snp', 'rmsk', 'cram',\n 'gwas', 'maf', 'mut', 'hiccups',\n 'fasta', 'fa', 'fna',\n 'pytor', 'hic', 'qtl',\n 'gtx',\n])\n\n/**\n * Infer file format from a URL or filename.\n *\n * Strips compression extensions (.gz, .bgz), auxiliary extensions (.txt, .tab, .tsv),\n * then checks the remaining extension against known formats.\n *\n * Port of js/util/fileFormatUtils.ts::inferFileFormatFromName().\n */\nexport function inferFormatFromPath(path: string): string | undefined {\n if (!path) return undefined\n\n let fn = path.toLowerCase()\n\n // Extract filename from URL (strip query params, path)\n const qIdx = fn.indexOf('?')\n if (qIdx > 0) fn = fn.substring(0, qIdx)\n const slashIdx = fn.lastIndexOf('/')\n if (slashIdx >= 0) fn = fn.substring(slashIdx + 1)\n\n // Special case: UCSC refgene files\n if (fn.endsWith('refgene.txt.gz') ||\n fn.endsWith('refgene.txt.bgz') ||\n fn.endsWith('refgene.txt') ||\n fn.endsWith('refgene.sorted.txt.gz') ||\n fn.endsWith('refgene.sorted.txt.bgz')) {\n return 'refgene'\n }\n\n // Strip compression extensions\n if (fn.endsWith('.gz')) fn = fn.substring(0, fn.length - 3)\n if (fn.endsWith('.bgz')) fn = fn.substring(0, fn.length - 4)\n\n // Strip auxiliary extensions\n if (fn.endsWith('.txt') || fn.endsWith('.tab') || fn.endsWith('.tsv')) {\n fn = fn.substring(0, fn.length - 4)\n }\n\n const idx = fn.lastIndexOf('.')\n const ext = idx < 0 ? fn : fn.substring(idx + 1)\n\n switch (ext) {\n case 'bw':\n return 'bigwig'\n case 'bb':\n return 'bigbed'\n case 'fasta':\n case 'fa':\n case 'fna':\n return 'fasta'\n case 'gtx':\n return 'gtx'\n default:\n if (knownFileExtensions.has(ext)) return ext\n return undefined\n }\n}\n\n/** Binary formats that cannot be read as text. */\nconst binaryFormats = new Set(['bigwig', 'bw', 'bigbed', 'bb', 'biginteract', 'biggenepred', 'bignarrowpeak', 'tdf', 'bam', 'cram', 'gtx'])\n\n/** Check if a format string represents a binary (non-text) format. */\nexport function isBinaryFormat(format: string): boolean {\n return binaryFormats.has(format.toLowerCase())\n}\n\n/** BigWig/BigBed format set — these use BWSource in igv.js. */\nexport const bbFormats = new Set(['bigwig', 'bw', 'bigbed', 'bb', 'biginteract', 'biggenepred', 'bignarrowpeak'])\n\n/**\n * Check if a URL is likely tabix-indexed.\n *\n * Only `.bgz` (bgzip-specific extension) is auto-detected as indexed.\n * Plain `.gz` files may be either bgzipped+tabix-indexed or plain gzipped,\n * so callers should explicitly set `indexed: true` or provide an `indexURL`\n * for those. This matches igv.js behavior where indexURL must be configured\n * for BED/GFF files to use tabix.\n */\nexport function isLikelyIndexed(url: string): boolean {\n const lower = url.toLowerCase()\n // Strip query params\n const qIdx = lower.indexOf('?')\n const path = qIdx > 0 ? lower.substring(0, qIdx) : lower\n return path.endsWith('.bgz')\n}\n\n/**\n * Infer the tabix index URL from a data file URL.\n * Appends '.tbi' to the URL (respecting query parameters).\n *\n * Port of js/util/fileFormatUtils.ts::inferIndexPath().\n */\nexport function inferIndexURL(url: string): string {\n if (url.includes('?')) {\n const idx = url.indexOf('?')\n return url.substring(0, idx) + '.tbi' + url.substring(idx)\n }\n return url + '.tbi'\n}\n\n/**\n * Infer the track type from a file format.\n *\n * Port of js/util/trackUtils.ts::inferTrackType().\n */\nexport function inferTrackType(format: string | undefined): string | undefined {\n if (!format) return undefined\n\n switch (format.toLowerCase()) {\n case 'bw':\n case 'bigwig':\n case 'wig':\n case 'bedgraph':\n case 'tdf':\n case 'gtx':\n return 'wig'\n case 'vcf':\n case 'vcftabix':\n return 'variant'\n case 'seg':\n return 'seg'\n case 'mut':\n case 'maf':\n return 'mut'\n case 'bam':\n case 'cram':\n return 'alignment'\n case 'hiccups':\n case 'bedpe':\n case 'bedpe-loop':\n case 'biginteract':\n case 'longrange':\n case 'hic':\n return 'interact'\n case 'bp':\n return 'arc'\n case 'gwas':\n return 'gwas'\n case 'bed':\n case 'bigbed':\n case 'bb':\n case 'biggenepred':\n case 'bignarrowpeak':\n return 'bedtype'\n case 'fasta':\n return 'sequence'\n case 'pytor':\n return 'cnvpytor'\n case 'qtl':\n return 'qtl'\n default:\n return 'annotation'\n }\n}\n","/**\n * Chromosome size data and utilities.\n *\n * Provides a lightweight ChromSizes type (chr → bp length), a default\n * hg38 dataset, and genome coordinate system utilities for whole genome view.\n */\n\n/** Mapping of chromosome names to their lengths in base pairs. */\nexport type ChromSizes = Record<string, number>\n\n/**\n * Look up the length of a chromosome. Returns undefined if not found.\n */\nexport function getChromLength(chr: string, chromSizes?: ChromSizes): number | undefined {\n return chromSizes?.[chr]\n}\n\n// ─── Whole Genome View utilities ─────────────────────────────────────────────\n\n/** Precomputed genome-wide coordinate system for whole genome view. */\nexport interface CumulativeOffsets {\n /** Chromosome name → genome-wide start position. */\n offsets: Record<string, number>\n /** Total length of all main chromosomes. */\n totalLength: number\n /** Ordered chromosome names used in the WG view. */\n chromosomeNames: string[]\n}\n\nconst MAIN_CHROM_RE = /^chr(\\d+|X|Y|M)$/i\n\n/** Check if a chromosome name is a \"main\" chromosome (chr1-22, X, Y, M). */\nexport function isMainChromosome(name: string): boolean {\n return MAIN_CHROM_RE.test(name)\n}\n\n/**\n * Return ordered list of main chromosome names from chromSizes.\n * Order: chr1-22 (numeric), chrX, chrY, chrM.\n */\nexport function mainChromosomeNames(chromSizes: ChromSizes): string[] {\n const names = Object.keys(chromSizes).filter(isMainChromosome)\n return names.sort((a, b) => {\n const aNum = chromNumber(a)\n const bNum = chromNumber(b)\n return aNum - bNum\n })\n}\n\n/** Map chromosome suffix to sort key: 1-22, then X=23, Y=24, M=25. */\nfunction chromNumber(name: string): number {\n const suffix = name.replace(/^chr/i, '')\n if (suffix === 'X' || suffix === 'x') return 23\n if (suffix === 'Y' || suffix === 'y') return 24\n if (suffix === 'M' || suffix === 'm') return 25\n const n = parseInt(suffix, 10)\n return isNaN(n) ? 100 : n\n}\n\n/**\n * Compute cumulative genome-wide offsets for main chromosomes.\n * Used to map per-chromosome coordinates to a linear genome-wide space.\n */\nexport function computeCumulativeOffsets(chromSizes: ChromSizes): CumulativeOffsets {\n const chromosomeNames = mainChromosomeNames(chromSizes)\n const offsets: Record<string, number> = {}\n let offset = 0\n for (const name of chromosomeNames) {\n offsets[name] = Math.floor(offset)\n offset += chromSizes[name]\n }\n return {offsets, totalLength: Math.floor(offset), chromosomeNames}\n}\n\n/**\n * Convert a genome-wide coordinate back to chromosome-relative coordinates.\n * Returns the chromosome and position within it.\n */\nexport function genomeToChromCoord(\n genomePos: number,\n cumOffsets: CumulativeOffsets,\n): {chr: string; position: number} {\n for (let i = cumOffsets.chromosomeNames.length - 1; i >= 0; i--) {\n const chr = cumOffsets.chromosomeNames[i]\n const offset = cumOffsets.offsets[chr]\n if (genomePos >= offset) {\n return {chr, position: genomePos - offset}\n }\n }\n // Fallback: first chromosome\n const chr = cumOffsets.chromosomeNames[0]\n return {chr, position: Math.max(0, genomePos)}\n}\n\n/**\n * Parse a tab-separated chrom.sizes file into a ChromSizes record.\n * Format: one line per chromosome, `name\\tlength`, with optional comments (#).\n * Mirrors the UCSC chrom.sizes file format.\n */\nexport function parseChromSizes(text: string): ChromSizes {\n const sizes: ChromSizes = {}\n for (const line of text.split('\\n')) {\n const trimmed = line.trim()\n if (!trimmed || trimmed.startsWith('#')) continue\n const parts = trimmed.split('\\t')\n if (parts.length >= 2) {\n const name = parts[0]\n const length = parseInt(parts[1], 10)\n if (name && !isNaN(length) && length > 0) {\n sizes[name] = length\n }\n }\n }\n return sizes\n}\n\n/**\n * GRCh38/hg38 chromosome sizes.\n * Includes main chromosomes (chr1-22, X, Y, M) plus all contigs and alts.\n * Source: UCSC hg38.chrom.sizes\n */\nexport const hg38ChromSizes: ChromSizes = {\n // Main chromosomes\n chr1: 248956422,\n chr2: 242193529,\n chr3: 198295559,\n chr4: 190214555,\n chr5: 181538259,\n chr6: 170805979,\n chr7: 159345973,\n chr8: 145138636,\n chr9: 138394717,\n chr10: 133797422,\n chr11: 135086622,\n chr12: 133275309,\n chr13: 114364328,\n chr14: 107043718,\n chr15: 101991189,\n chr16: 90338345,\n chr17: 83257441,\n chr18: 80373285,\n chr19: 58617616,\n chr20: 64444167,\n chr21: 46709983,\n chr22: 50818468,\n chrX: 156040895,\n chrY: 57227415,\n chrM: 16569,\n // Random contigs\n chr11_KI270721v1_random: 100316,\n chr14_GL000009v2_random: 201709,\n chr14_GL000225v1_random: 211173,\n chr14_KI270722v1_random: 194050,\n chr14_GL000194v1_random: 191469,\n chr14_KI270723v1_random: 38115,\n chr14_KI270724v1_random: 39555,\n chr14_KI270725v1_random: 172810,\n chr14_KI270726v1_random: 43739,\n chr15_KI270727v1_random: 448248,\n chr16_KI270728v1_random: 1872759,\n chr17_GL000205v2_random: 185591,\n chr17_KI270729v1_random: 280839,\n chr17_KI270730v1_random: 112551,\n chr1_KI270706v1_random: 175055,\n chr1_KI270707v1_random: 32032,\n chr1_KI270708v1_random: 127682,\n chr1_KI270709v1_random: 66860,\n chr1_KI270710v1_random: 40176,\n chr1_KI270711v1_random: 42210,\n chr1_KI270712v1_random: 176043,\n chr1_KI270713v1_random: 40745,\n chr1_KI270714v1_random: 41717,\n chr22_KI270731v1_random: 150754,\n chr22_KI270732v1_random: 41543,\n chr22_KI270733v1_random: 179772,\n chr22_KI270734v1_random: 165050,\n chr22_KI270735v1_random: 42811,\n chr22_KI270736v1_random: 181920,\n chr22_KI270737v1_random: 103838,\n chr22_KI270738v1_random: 99375,\n chr22_KI270739v1_random: 73985,\n chr2_KI270715v1_random: 161471,\n chr2_KI270716v1_random: 153799,\n chr3_GL000221v1_random: 155397,\n chr4_GL000008v2_random: 209709,\n chr5_GL000208v1_random: 92689,\n chr9_KI270717v1_random: 40062,\n chr9_KI270718v1_random: 38054,\n chr9_KI270719v1_random: 176845,\n chr9_KI270720v1_random: 39050,\n // Alt contigs\n chr1_KI270762v1_alt: 354444,\n chr1_KI270766v1_alt: 256271,\n chr1_KI270760v1_alt: 109528,\n chr1_KI270765v1_alt: 185285,\n chr1_GL383518v1_alt: 182439,\n chr1_GL383519v1_alt: 110268,\n chr1_GL383520v2_alt: 366580,\n chr1_KI270764v1_alt: 50258,\n chr1_KI270763v1_alt: 911658,\n chr1_KI270759v1_alt: 425601,\n chr1_KI270761v1_alt: 165834,\n chr2_KI270770v1_alt: 136240,\n chr2_KI270773v1_alt: 70887,\n chr2_KI270774v1_alt: 223625,\n chr2_KI270769v1_alt: 120616,\n chr2_GL383521v1_alt: 143390,\n chr2_KI270772v1_alt: 133041,\n chr2_KI270775v1_alt: 138019,\n chr2_KI270771v1_alt: 110395,\n chr2_KI270768v1_alt: 110099,\n chr2_GL582966v2_alt: 96131,\n chr2_GL383522v1_alt: 123821,\n chr2_KI270776v1_alt: 174166,\n chr2_KI270767v1_alt: 161578,\n chr3_JH636055v2_alt: 173151,\n chr3_KI270783v1_alt: 109187,\n chr3_KI270780v1_alt: 224108,\n chr3_GL383526v1_alt: 180671,\n chr3_KI270777v1_alt: 173649,\n chr3_KI270778v1_alt: 248252,\n chr3_KI270781v1_alt: 113034,\n chr3_KI270779v1_alt: 205312,\n chr3_KI270782v1_alt: 162429,\n chr3_KI270784v1_alt: 184404,\n chr4_KI270790v1_alt: 220246,\n chr4_GL383528v1_alt: 376187,\n chr4_KI270787v1_alt: 111943,\n chr4_GL000257v2_alt: 586476,\n chr4_KI270788v1_alt: 158965,\n chr4_GL383527v1_alt: 164536,\n chr4_KI270785v1_alt: 119912,\n chr4_KI270789v1_alt: 205944,\n chr4_KI270786v1_alt: 244096,\n chr5_KI270793v1_alt: 126136,\n chr5_KI270792v1_alt: 179043,\n chr5_KI270791v1_alt: 195710,\n chr5_GL383532v1_alt: 82728,\n chr5_GL949742v1_alt: 226852,\n chr5_KI270794v1_alt: 164558,\n chr5_GL339449v2_alt: 1612928,\n chr5_GL383530v1_alt: 101241,\n chr5_KI270796v1_alt: 172708,\n chr5_GL383531v1_alt: 173459,\n chr5_KI270795v1_alt: 131892,\n chr6_GL000250v2_alt: 4672374,\n chr6_KI270800v1_alt: 175808,\n chr6_KI270799v1_alt: 152148,\n chr6_GL383533v1_alt: 124736,\n chr6_KI270801v1_alt: 870480,\n chr6_KI270802v1_alt: 75005,\n chr6_KB021644v2_alt: 185823,\n chr6_KI270797v1_alt: 197536,\n chr6_KI270798v1_alt: 271782,\n chr7_KI270804v1_alt: 157952,\n chr7_KI270809v1_alt: 209586,\n chr7_KI270806v1_alt: 158166,\n chr7_GL383534v2_alt: 119183,\n chr7_KI270803v1_alt: 1111570,\n chr7_KI270808v1_alt: 271455,\n chr7_KI270807v1_alt: 126434,\n chr7_KI270805v1_alt: 209988,\n chr8_KI270818v1_alt: 145606,\n chr8_KI270812v1_alt: 282736,\n chr8_KI270811v1_alt: 292436,\n chr8_KI270821v1_alt: 985506,\n chr8_KI270813v1_alt: 300230,\n chr8_KI270822v1_alt: 624492,\n chr8_KI270814v1_alt: 141812,\n chr8_KI270810v1_alt: 374415,\n chr8_KI270819v1_alt: 133535,\n chr8_KI270820v1_alt: 36640,\n chr8_KI270817v1_alt: 158983,\n chr8_KI270816v1_alt: 305841,\n chr8_KI270815v1_alt: 132244,\n chr9_GL383539v1_alt: 162988,\n chr9_GL383540v1_alt: 71551,\n chr9_GL383541v1_alt: 171286,\n chr9_GL383542v1_alt: 60032,\n chr9_KI270823v1_alt: 439082,\n chr10_GL383545v1_alt: 179254,\n chr10_KI270824v1_alt: 181496,\n chr10_GL383546v1_alt: 309802,\n chr10_KI270825v1_alt: 188315,\n chr11_KI270832v1_alt: 210133,\n chr11_KI270830v1_alt: 177092,\n chr11_KI270831v1_alt: 296895,\n chr11_KI270829v1_alt: 204059,\n chr11_GL383547v1_alt: 154407,\n chr11_JH159136v1_alt: 200998,\n chr11_JH159137v1_alt: 191409,\n chr11_KI270827v1_alt: 67707,\n chr11_KI270826v1_alt: 186169,\n chr12_GL877875v1_alt: 167313,\n chr12_GL877876v1_alt: 408271,\n chr12_KI270837v1_alt: 40090,\n chr12_GL383549v1_alt: 120804,\n chr12_KI270835v1_alt: 238139,\n chr12_GL383550v2_alt: 153178,\n chr12_GL383552v1_alt: 138655,\n chr12_GL383553v2_alt: 152874,\n chr12_KI270834v1_alt: 119498,\n chr12_GL383551v1_alt: 184319,\n chr12_KI270833v1_alt: 76061,\n chr12_KI270836v1_alt: 56134,\n chr13_KI270840v1_alt: 191684,\n chr13_KI270839v1_alt: 180306,\n chr13_KI270843v1_alt: 103832,\n chr13_KI270841v1_alt: 169134,\n chr13_KI270838v1_alt: 306913,\n chr13_KI270842v1_alt: 37287,\n chr14_KI270844v1_alt: 322166,\n chr14_KI270847v1_alt: 1511111,\n chr14_KI270845v1_alt: 180703,\n chr14_KI270846v1_alt: 1351393,\n chr15_KI270852v1_alt: 478999,\n chr15_KI270851v1_alt: 263054,\n chr15_KI270848v1_alt: 327382,\n chr15_GL383554v1_alt: 296527,\n chr15_KI270849v1_alt: 244917,\n chr15_GL383555v2_alt: 388773,\n chr15_KI270850v1_alt: 430880,\n chr16_KI270854v1_alt: 134193,\n chr16_KI270856v1_alt: 63982,\n chr16_KI270855v1_alt: 232857,\n chr16_KI270853v1_alt: 2659700,\n chr16_GL383556v1_alt: 192462,\n chr16_GL383557v1_alt: 89672,\n chr17_GL383563v3_alt: 375691,\n chr17_KI270862v1_alt: 391357,\n chr17_KI270861v1_alt: 196688,\n chr17_KI270857v1_alt: 2877074,\n chr17_JH159146v1_alt: 278131,\n chr17_JH159147v1_alt: 70345,\n chr17_GL383564v2_alt: 133151,\n chr17_GL000258v2_alt: 1821992,\n chr17_GL383565v1_alt: 223995,\n chr17_KI270858v1_alt: 235827,\n chr17_KI270859v1_alt: 108763,\n chr17_GL383566v1_alt: 90219,\n chr17_KI270860v1_alt: 178921,\n chr18_KI270864v1_alt: 111737,\n chr18_GL383567v1_alt: 289831,\n chr18_GL383570v1_alt: 164789,\n chr18_GL383571v1_alt: 198278,\n chr18_GL383568v1_alt: 104552,\n chr18_GL383569v1_alt: 167950,\n chr18_GL383572v1_alt: 159547,\n chr18_KI270863v1_alt: 167999,\n chr19_KI270868v1_alt: 61734,\n chr19_KI270865v1_alt: 52969,\n chr19_GL383573v1_alt: 385657,\n chr19_GL383575v2_alt: 170222,\n chr19_GL383576v1_alt: 188024,\n chr19_GL383574v1_alt: 155864,\n chr19_KI270866v1_alt: 43156,\n chr19_KI270867v1_alt: 233762,\n chr19_GL949746v1_alt: 987716,\n chr20_GL383577v2_alt: 128386,\n chr20_KI270869v1_alt: 118774,\n chr20_KI270871v1_alt: 58661,\n chr20_KI270870v1_alt: 183433,\n chr21_GL383578v2_alt: 63917,\n chr21_KI270874v1_alt: 166743,\n chr21_KI270873v1_alt: 143900,\n chr21_GL383579v2_alt: 201197,\n chr21_GL383580v2_alt: 74653,\n chr21_GL383581v2_alt: 116689,\n chr21_KI270872v1_alt: 82692,\n chr22_KI270875v1_alt: 259914,\n chr22_KI270878v1_alt: 186262,\n chr22_KI270879v1_alt: 304135,\n chr22_KI270876v1_alt: 263666,\n chr22_KI270877v1_alt: 101331,\n chr22_GL383583v2_alt: 96924,\n chr22_GL383582v2_alt: 162811,\n chrX_KI270880v1_alt: 284869,\n chrX_KI270881v1_alt: 144206,\n chr19_KI270882v1_alt: 248807,\n chr19_KI270883v1_alt: 170399,\n chr19_KI270884v1_alt: 157053,\n chr19_KI270885v1_alt: 171027,\n chr19_KI270886v1_alt: 204239,\n chr19_KI270887v1_alt: 209512,\n chr19_KI270888v1_alt: 155532,\n chr19_KI270889v1_alt: 170698,\n chr19_KI270890v1_alt: 184499,\n chr19_KI270891v1_alt: 170680,\n chr1_KI270892v1_alt: 162212,\n chr2_KI270894v1_alt: 214158,\n chr2_KI270893v1_alt: 161218,\n chr3_KI270895v1_alt: 162896,\n chr4_KI270896v1_alt: 378547,\n chr5_KI270897v1_alt: 1144418,\n chr5_KI270898v1_alt: 130957,\n chr6_GL000251v2_alt: 4795265,\n chr7_KI270899v1_alt: 190869,\n chr8_KI270901v1_alt: 136959,\n chr8_KI270900v1_alt: 318687,\n chr11_KI270902v1_alt: 106711,\n chr11_KI270903v1_alt: 214625,\n chr12_KI270904v1_alt: 572349,\n chr15_KI270906v1_alt: 196384,\n chr15_KI270905v1_alt: 5161414,\n chr17_KI270907v1_alt: 137721,\n chr17_KI270910v1_alt: 157099,\n chr17_KI270909v1_alt: 325800,\n chr17_JH159148v1_alt: 88070,\n chr17_KI270908v1_alt: 1423190,\n chr18_KI270912v1_alt: 174061,\n chr18_KI270911v1_alt: 157710,\n chr19_GL949747v2_alt: 729520,\n chr22_KB663609v1_alt: 74013,\n chrX_KI270913v1_alt: 274009,\n chr19_KI270914v1_alt: 205194,\n chr19_KI270915v1_alt: 170665,\n chr19_KI270916v1_alt: 184516,\n chr19_KI270917v1_alt: 190932,\n chr19_KI270918v1_alt: 123111,\n chr19_KI270919v1_alt: 170701,\n chr19_KI270920v1_alt: 198005,\n chr19_KI270921v1_alt: 282224,\n chr19_KI270922v1_alt: 187935,\n chr19_KI270923v1_alt: 189352,\n chr3_KI270924v1_alt: 166540,\n chr4_KI270925v1_alt: 555799,\n chr6_GL000252v2_alt: 4604811,\n chr8_KI270926v1_alt: 229282,\n chr11_KI270927v1_alt: 218612,\n chr19_GL949748v2_alt: 1064304,\n chr22_KI270928v1_alt: 176103,\n chr19_KI270929v1_alt: 186203,\n chr19_KI270930v1_alt: 200773,\n chr19_KI270931v1_alt: 170148,\n chr19_KI270932v1_alt: 215732,\n chr19_KI270933v1_alt: 170537,\n chr19_GL000209v2_alt: 177381,\n chr3_KI270934v1_alt: 163458,\n chr6_GL000253v2_alt: 4677643,\n chr19_GL949749v2_alt: 1091841,\n chr3_KI270935v1_alt: 197351,\n chr6_GL000254v2_alt: 4827813,\n chr19_GL949750v2_alt: 1066390,\n chr3_KI270936v1_alt: 164170,\n chr6_GL000255v2_alt: 4606388,\n chr19_GL949751v2_alt: 1002683,\n chr3_KI270937v1_alt: 165607,\n chr6_GL000256v2_alt: 4929269,\n chr19_GL949752v1_alt: 987100,\n chr6_KI270758v1_alt: 76752,\n chr19_GL949753v2_alt: 796479,\n chr19_KI270938v1_alt: 1066800,\n // Unplaced contigs\n chrUn_KI270302v1: 2274,\n chrUn_KI270304v1: 2165,\n chrUn_KI270303v1: 1942,\n chrUn_KI270305v1: 1472,\n chrUn_KI270322v1: 21476,\n chrUn_KI270320v1: 4416,\n chrUn_KI270310v1: 1201,\n chrUn_KI270316v1: 1444,\n chrUn_KI270315v1: 2276,\n chrUn_KI270312v1: 998,\n chrUn_KI270311v1: 12399,\n chrUn_KI270317v1: 37690,\n chrUn_KI270412v1: 1179,\n chrUn_KI270411v1: 2646,\n chrUn_KI270414v1: 2489,\n chrUn_KI270419v1: 1029,\n chrUn_KI270418v1: 2145,\n chrUn_KI270420v1: 2321,\n chrUn_KI270424v1: 2140,\n chrUn_KI270417v1: 2043,\n chrUn_KI270422v1: 1445,\n chrUn_KI270423v1: 981,\n chrUn_KI270425v1: 1884,\n chrUn_KI270429v1: 1361,\n chrUn_KI270442v1: 392061,\n chrUn_KI270466v1: 1233,\n chrUn_KI270465v1: 1774,\n chrUn_KI270467v1: 3920,\n chrUn_KI270435v1: 92983,\n chrUn_KI270438v1: 112505,\n chrUn_KI270468v1: 4055,\n chrUn_KI270510v1: 2415,\n chrUn_KI270509v1: 2318,\n chrUn_KI270518v1: 2186,\n chrUn_KI270508v1: 1951,\n chrUn_KI270516v1: 1300,\n chrUn_KI270512v1: 22689,\n chrUn_KI270519v1: 138126,\n chrUn_KI270522v1: 5674,\n chrUn_KI270511v1: 8127,\n chrUn_KI270515v1: 6361,\n chrUn_KI270507v1: 5353,\n chrUn_KI270517v1: 3253,\n chrUn_KI270529v1: 1899,\n chrUn_KI270528v1: 2983,\n chrUn_KI270530v1: 2168,\n chrUn_KI270539v1: 993,\n chrUn_KI270538v1: 91309,\n chrUn_KI270544v1: 1202,\n chrUn_KI270548v1: 1599,\n chrUn_KI270583v1: 1400,\n chrUn_KI270587v1: 2969,\n chrUn_KI270580v1: 1553,\n chrUn_KI270581v1: 7046,\n chrUn_KI270579v1: 31033,\n chrUn_KI270589v1: 44474,\n chrUn_KI270590v1: 4685,\n chrUn_KI270584v1: 4513,\n chrUn_KI270582v1: 6504,\n chrUn_KI270588v1: 6158,\n chrUn_KI270593v1: 3041,\n chrUn_KI270591v1: 5796,\n chrUn_KI270330v1: 1652,\n chrUn_KI270329v1: 1040,\n chrUn_KI270334v1: 1368,\n chrUn_KI270333v1: 2699,\n chrUn_KI270335v1: 1048,\n chrUn_KI270338v1: 1428,\n chrUn_KI270340v1: 1428,\n chrUn_KI270336v1: 1026,\n chrUn_KI270337v1: 1121,\n chrUn_KI270363v1: 1803,\n chrUn_KI270364v1: 2855,\n chrUn_KI270362v1: 3530,\n chrUn_KI270366v1: 8320,\n chrUn_KI270378v1: 1048,\n chrUn_KI270379v1: 1045,\n chrUn_KI270389v1: 1298,\n chrUn_KI270390v1: 2387,\n chrUn_KI270387v1: 1537,\n chrUn_KI270395v1: 1143,\n chrUn_KI270396v1: 1880,\n chrUn_KI270388v1: 1216,\n chrUn_KI270394v1: 970,\n chrUn_KI270386v1: 1788,\n chrUn_KI270391v1: 1484,\n chrUn_KI270383v1: 1750,\n chrUn_KI270393v1: 1308,\n chrUn_KI270384v1: 1658,\n chrUn_KI270392v1: 971,\n chrUn_KI270381v1: 1930,\n chrUn_KI270385v1: 990,\n chrUn_KI270382v1: 4215,\n chrUn_KI270376v1: 1136,\n chrUn_KI270374v1: 2656,\n chrUn_KI270372v1: 1650,\n chrUn_KI270373v1: 1451,\n chrUn_KI270375v1: 2378,\n chrUn_KI270371v1: 2805,\n chrUn_KI270448v1: 7992,\n chrUn_KI270521v1: 7642,\n chrUn_GL000195v1: 182896,\n chrUn_GL000219v1: 179198,\n chrUn_GL000220v1: 161802,\n chrUn_GL000224v1: 179693,\n chrUn_KI270741v1: 157432,\n chrUn_GL000226v1: 15008,\n chrUn_GL000213v1: 164239,\n chrUn_KI270743v1: 210658,\n chrUn_KI270744v1: 168472,\n chrUn_KI270745v1: 41891,\n chrUn_KI270746v1: 66486,\n chrUn_KI270747v1: 198735,\n chrUn_KI270748v1: 93321,\n chrUn_KI270749v1: 158759,\n chrUn_KI270750v1: 148850,\n chrUn_KI270751v1: 150742,\n chrUn_KI270752v1: 27745,\n chrUn_KI270753v1: 62944,\n chrUn_KI270754v1: 40191,\n chrUn_KI270755v1: 36723,\n chrUn_KI270756v1: 79590,\n chrUn_KI270757v1: 71251,\n chrUn_GL000214v1: 137718,\n chrUn_KI270742v1: 186739,\n chrUn_GL000216v2: 176608,\n chrUn_GL000218v1: 161147,\n chrY_KI270740v1_random: 37240,\n}\n","/**\n * DataSource for text-based genomic feature files (BED, GFF, peaks, etc.).\n *\n * Supports:\n * - Indexed files (via TabixReader) — query by region, on-demand parsing\n * - Non-indexed files — fetch all, cache in FeatureCache, query locally\n * - Automatic format detection from URL\n * - Chromosome alias resolution\n *\n * Port of js/feature/textFeatureSource.ts and js/feature/featureFileReader.ts.\n * Layer 1 (Data + Layout): no DOM.\n */\n\nimport type {DataSource, Locus, TextFileFormat} from '../types'\nimport type {CacheableFeature} from '../featureCache'\nimport type {CumulativeOffsets} from '../genome/chromSizes'\nimport {FeatureCache} from '../featureCache'\nimport {TabixReader} from '../tabix'\nimport {parseFeatures, parseHeader} from '../formats/featureParser'\nimport type {FeatureHeader} from '../formats/featureParser'\nimport {inferFormatFromPath, isLikelyIndexed, inferIndexURL} from '../formats/formatDetection'\nimport {isWholeGenomeView} from '../locusUtils'\nimport {mainChromosomeNames} from '../genome/chromSizes'\n\nexport interface TextFeatureSourceConfig {\n /** URL to the data file. */\n url: string\n /** Explicit format override. When absent, inferred from URL. */\n format?: TextFileFormat\n /** Index URL override. Defaults to url + '.tbi'. */\n indexURL?: string\n /** Whether the file is indexed (tabix). Auto-detected if absent. */\n indexed?: boolean\n /** For GFF: whether to assemble transcript models. Default: true. */\n assembleGFF?: boolean\n}\n\n/**\n * DataSource for text-based genomic feature files.\n *\n * For indexed files: uses TabixReader to query by region, parses lines on each fetch.\n * For non-indexed files: loads entire file on first fetch, caches in FeatureCache.\n */\nexport class TextFeatureSource<F extends CacheableFeature = CacheableFeature> implements DataSource<F> {\n private readonly url: string\n private readonly format: TextFileFormat\n private readonly assembleGFF: boolean\n private readonly _indexed: boolean\n private _resolveChromName?: (chr: string) => string\n private _cumulativeOffsets?: CumulativeOffsets\n\n // Indexed path\n private tabixReader?: TabixReader\n\n // Non-indexed path\n private featureCache?: FeatureCache<F>\n private allFeaturesLoaded = false\n\n // Header (parsed lazily on first load)\n private header?: FeatureHeader\n\n constructor(config: TextFeatureSourceConfig) {\n this.url = config.url\n\n // Detect format\n const detected = config.format ?? inferFormatFromPath(config.url) as TextFileFormat | undefined\n this.format = detected ?? 'bed'\n\n this.assembleGFF = config.assembleGFF !== false\n\n // Determine if indexed\n if (config.indexed !== undefined) {\n this._indexed = config.indexed\n } else if (config.indexURL) {\n this._indexed = true\n } else {\n this._indexed = isLikelyIndexed(config.url)\n }\n\n // Set up TabixReader for indexed files\n if (this._indexed) {\n const indexUrl = config.indexURL ?? inferIndexURL(config.url)\n this.tabixReader = new TabixReader(config.url, {indexUrl})\n }\n }\n\n /** Whether this source is indexed (queryable by region). */\n get indexed(): boolean { return this._indexed }\n\n /** Set a chromosome name resolver for alias resolution. */\n setChromNameResolver(resolver: (chr: string) => string): void {\n this._resolveChromName = resolver\n }\n\n /** Set cumulative offsets for whole genome view coordinate transformation. */\n setCumulativeOffsets(offsets: CumulativeOffsets): void {\n this._cumulativeOffsets = offsets\n }\n\n /** Get sequence names from the file/index (for chromosome alias setup). */\n async getSequenceNames(signal?: AbortSignal): Promise<string[]> {\n if (this.tabixReader) {\n return this.tabixReader.getSequenceNames(signal)\n }\n // For non-indexed files, load all features first, extract from cache\n if (this.featureCache) {\n return Object.keys(this.featureCache.getAllFeatures())\n }\n return []\n }\n\n async fetch(locus: Locus, bpPerPixel: number, signal: AbortSignal): Promise<F[]> {\n if (isWholeGenomeView(locus) && this._cumulativeOffsets) {\n return this.fetchWG(signal)\n }\n\n const chr = this._resolveChromName\n ? this._resolveChromName(locus.chr)\n : locus.chr\n\n if (this._indexed && this.tabixReader) {\n return this.fetchIndexed(chr, locus.start, locus.end, signal)\n }\n return this.fetchNonIndexed(chr, locus.start, locus.end, signal)\n }\n\n private async fetchIndexed(chr: string, start: number, end: number, signal?: AbortSignal): Promise<F[]> {\n const reader = this.tabixReader!\n\n // Load header lazily for format metadata\n if (!this.header) {\n const headerLines = await reader.readHeaderLines(signal)\n this.header = parseHeader(headerLines, this.format)\n }\n\n const lines = await reader.readLines(chr, start, end, signal)\n\n const features = parseFeatures(lines, this.format, {\n header: this.header,\n assembleGFF: this.assembleGFF,\n }) as F[]\n\n // Sort by start position\n features.sort((a, b) => a.start - b.start)\n\n return features\n }\n\n private async fetchNonIndexed(chr: string, start: number, end: number, signal?: AbortSignal): Promise<F[]> {\n if (!this.allFeaturesLoaded) {\n await this.loadAllFeatures(signal)\n }\n return this.featureCache?.queryFeatures(chr, start, end) ?? []\n }\n\n private async loadAllFeatures(signal?: AbortSignal): Promise<void> {\n // Fetch entire file\n const response = await globalThis.fetch(this.url, {signal})\n if (!response.ok) {\n throw new Error(`Failed to fetch ${this.url}: ${response.status} ${response.statusText}`)\n }\n\n // Handle gzipped content: decompress if Content-Encoding wasn't already handled\n // by the browser (transparent decompression) or if the URL ends in .gz/.bgz\n let text: string\n const urlLower = this.url.toLowerCase()\n const isGzUrl = urlLower.endsWith('.gz') || urlLower.endsWith('.bgz') ||\n urlLower.includes('.gz?') || urlLower.includes('.bgz?')\n const contentEncoding = response.headers.get('Content-Encoding')\n const transparentlyDecompressed = contentEncoding === 'gzip' || contentEncoding === 'deflate'\n\n if (isGzUrl && !transparentlyDecompressed) {\n // Server sent raw gzip bytes — decompress manually\n const buffer = await response.arrayBuffer()\n const ds = new DecompressionStream('gzip')\n const decompressed = new Response(\n new Response(buffer).body!.pipeThrough(ds),\n )\n text = await decompressed.text()\n } else {\n text = await response.text()\n }\n\n const lines = text.split(/\\r?\\n/)\n\n // Parse header\n this.header = parseHeader(lines, this.format)\n\n // Parse features\n const features = parseFeatures(lines, this.format, {\n header: this.header,\n assembleGFF: this.assembleGFF,\n }) as F[]\n\n // Sort by chr then start\n features.sort((a, b) => {\n if (a.chr === b.chr) return a.start - b.start\n return a.chr.localeCompare(b.chr)\n })\n\n // Build cache\n this.featureCache = new FeatureCache(features)\n this.allFeaturesLoaded = true\n }\n\n private async fetchWG(signal: AbortSignal): Promise<F[]> {\n const offsets = this._cumulativeOffsets!\n\n if (this._indexed) {\n // For indexed files, fetch all main chromosomes\n const chrNames = mainChromosomeNames(\n Object.fromEntries(\n offsets.chromosomeNames.map(name => [name, offsets.offsets[name] ?? 0])\n ) as Record<string, number>,\n )\n\n const allFeatures: F[] = []\n for (const chrName of chrNames) {\n try {\n const features = await this.fetchIndexed(\n chrName, 0, Number.MAX_SAFE_INTEGER, signal,\n )\n const offset = offsets.offsets[chrName]\n if (offset === undefined) continue\n for (const f of features) {\n allFeatures.push({\n ...f,\n chr: 'all',\n start: offset + f.start,\n end: offset + f.end,\n })\n }\n } catch {\n // Skip chromosomes that fail\n }\n }\n allFeatures.sort((a, b) => a.start - b.start)\n return allFeatures\n } else {\n // Non-indexed: load all, transform coordinates\n if (!this.allFeaturesLoaded) {\n await this.loadAllFeatures(signal)\n }\n const allByChrom = this.featureCache?.getAllFeatures() ?? {}\n const wgFeatures: F[] = []\n for (const [chr, features] of Object.entries(allByChrom)) {\n const offset = offsets.offsets[chr]\n if (offset === undefined) continue\n for (const f of features) {\n wgFeatures.push({\n ...f,\n chr: 'all',\n start: offset + f.start,\n end: offset + f.end,\n })\n }\n }\n wgFeatures.sort((a, b) => a.start - b.start)\n return wgFeatures\n }\n }\n}\n","/**\n * Web Worker entry point for DataSource-based data fetching.\n *\n * Hosts persistent DataSource instances that handle the full pipeline:\n * network I/O → binary parsing → feature decoding → summarization.\n *\n * Communicates with the main thread via the DataSourceWorkerProvider protocol:\n * create, fetch, configure, cancel, destroy messages.\n *\n * Signals readiness via postMessage({type: 'ready'}) after module initialization,\n * following JBrowse 2's async worker init pattern (PR #2798).\n */\n\nimport {DataSourceRegistry} from './dataSourceRegistry'\nimport type {DataSourceWorkerRequest, DataSourceWorkerResponse} from '../dataSourceWorkerProvider'\n\n/** Minimal typing for the worker global scope (avoids WebWorker lib dependency). */\ninterface WorkerSelf {\n onmessage: ((e: MessageEvent<DataSourceWorkerRequest>) => void) | null\n postMessage(msg: DataSourceWorkerResponse, options?: { transfer?: Transferable[] }): void\n}\n\nconst workerSelf = self as unknown as WorkerSelf\nconst registry = new DataSourceRegistry()\n\nconsole.log('[loom data-worker] initialized')\n\nworkerSelf.onmessage = async (e: MessageEvent<DataSourceWorkerRequest>) => {\n const msg = e.data\n\n switch (msg.type) {\n case 'create':\n try {\n registry.create(msg.instanceId, msg.config)\n } catch (err) {\n console.error(`[loom data-worker] create failed for ${msg.instanceId}:`, err)\n }\n break\n\n case 'fetch': {\n try {\n const features = await registry.fetch(msg.instanceId, msg.fetchId, msg.locus, msg.bpPerPixel)\n workerSelf.postMessage({\n type: 'fetchResult',\n fetchId: msg.fetchId,\n features,\n })\n } catch (err) {\n // AbortErrors are expected during navigation — still report them\n // so the main thread can distinguish abort from real errors\n const message = err instanceof Error ? err.message : String(err)\n const isAbort = err instanceof DOMException && err.name === 'AbortError'\n workerSelf.postMessage({\n type: 'fetchError',\n fetchId: msg.fetchId,\n error: isAbort ? 'AbortError' : message,\n })\n }\n break\n }\n\n case 'configure':\n registry.configure(msg.instanceId, msg.method, msg.args)\n break\n\n case 'cancel':\n registry.cancel(msg.fetchId)\n break\n\n case 'destroy':\n registry.destroy(msg.instanceId)\n break\n }\n}\n\n// Signal readiness after module initialization\nworkerSelf.postMessage({type: 'ready'})\n","/**\n * DataSourceRegistry — manages long-lived DataSource instances inside a worker.\n *\n * Creates DataSource instances from serializable DataSourceConfig, caches them\n * by instanceId, and manages per-fetch AbortControllers for cancellation.\n *\n * Runs inside a web worker or Node worker_threads context.\n * Layer 1 (Data + Layout): no DOM.\n */\n\nimport type {DataSource, DataSourceConfig, Locus} from '../types'\nimport {BigWigDataSource} from '../dataSources/bigWigDataSource'\nimport {GtxDataSource} from '../dataSources/gtxDataSource'\nimport {GeneDataSource} from '../dataSources/geneDataSource'\nimport {TextFeatureSource} from '../dataSources/textFeatureSource'\n\nexport class DataSourceRegistry {\n private readonly instances = new Map<string, DataSource>()\n private readonly inflightAborts = new Map<number, AbortController>()\n\n /**\n * Create a DataSource from a serializable config and register it.\n * The DataSource persists until destroy() is called.\n */\n create(instanceId: string, config: DataSourceConfig): void {\n const ds = createDataSource(config)\n this.instances.set(instanceId, ds)\n }\n\n /**\n * Fetch features from a registered DataSource.\n * Creates an internal AbortController for cancellation via cancel().\n */\n async fetch(instanceId: string, fetchId: number, locus: Locus, bpPerPixel: number): Promise<unknown[]> {\n const ds = this.instances.get(instanceId)\n if (!ds) throw new Error(`DataSource not found: ${instanceId}`)\n\n const controller = new AbortController()\n this.inflightAborts.set(fetchId, controller)\n\n try {\n return await ds.fetch(locus, bpPerPixel, controller.signal)\n } finally {\n this.inflightAborts.delete(fetchId)\n }\n }\n\n /** Abort an in-flight fetch by its fetchId. */\n cancel(fetchId: number): void {\n this.inflightAborts.get(fetchId)?.abort()\n }\n\n /**\n * Call a setter method on a registered DataSource.\n * Used for serializable configuration updates (setCumulativeOffsets, setWindowFunction, etc.).\n */\n configure(instanceId: string, method: string, args: unknown[]): void {\n const ds = this.instances.get(instanceId)\n if (!ds) return\n\n const fn = (ds as unknown as Record<string, unknown>)[method]\n if (typeof fn === 'function') {\n fn.call(ds, ...args)\n }\n }\n\n /** Destroy a DataSource instance and clean up. */\n destroy(instanceId: string): void {\n this.instances.delete(instanceId)\n }\n}\n\n/**\n * Factory: create a DataSource from a serializable DataSourceConfig.\n *\n * Does NOT handle 'memory' or 'sequence' configs — those require\n * non-serializable inputs (in-memory features, SequenceProvider function)\n * and must stay on the main thread.\n */\nfunction createDataSource(config: DataSourceConfig): DataSource {\n switch (config.type) {\n case 'bigwig':\n return new BigWigDataSource(config.url, config.windowFunction ?? 'mean')\n case 'gtx':\n return new GtxDataSource(config.url, config.experimentId, config.windowFunction ?? 'mean')\n case 'ucsc':\n return new GeneDataSource({genome: config.genome, track: config.track})\n case 'text':\n return new TextFeatureSource({\n url: config.url,\n format: config.format,\n indexURL: config.indexURL,\n indexed: config.indexed,\n })\n case 'memory':\n throw new Error('MemoryDataSource cannot be created in a worker — requires in-memory features')\n default:\n throw new Error(`Unknown DataSourceConfig type: ${(config as {type: string}).type}`)\n }\n}\n"],"names":["BigInt32","BigInt","DataView","prototype","getBigInt64","byteOffset","littleEndian","dataView","littleEndianMask","Number","bigEndianMask","getInt32","getUint32","this","getBigUint64","a","b","RemoteFile","constructor","source","opts","baseOverrides","url","fetch","globalThis","bind","overrides","fetchImplementation","input","init","wrapError","e","Error","message","replace","getMessage","cause","response","includes","console","warn","cache","read","length","position","Uint8Array","headers","signal","Infinity","range","res","method","redirect","mode","ok","status","contentRange","get","sizeMatch","exec","_stat","size","parseInt","resData","bytes","arrayBuffer","byteLength","subarray","readFile","options","encoding","_","rest","text","stat","close","LocalFile","NullSignal","AggregateAbortController","signals","Set","abortController","AbortController","addSignal","aborted","add","handleAborted","addEventListener","delete","abort","AggregateStatusReporter","callbacks","addCallback","callback","currentMessage","elt","AbortablePromiseCache","fill","TypeError","set","fillCallback","isAbortException","exception","name","code","evict","key","entry","data","statusCallback","aborter","statusReporter","newEntry","promise","settled","then","catch","error","checkSinglePromise","checkForSingleAbort","Object","assign","result","has","AbortSignal","cacheEntry","cachedEntry","clear","keyIter","keys","deleteCount","next","done","value","_QuickLRU_instances","_QuickLRU_size","_QuickLRU_cache","_QuickLRU_oldCache","_QuickLRU_maxSize","_QuickLRU_maxAge","_QuickLRU_onEviction","_QuickLRU_emitEvictions","_QuickLRU_deleteIfExpired","_QuickLRU_getOrDeleteIfExpired","_QuickLRU_getItemValue","_QuickLRU_peek","_QuickLRU_set","_QuickLRU_moveToRecent","_QuickLRU_entriesAscending","__classPrivateFieldSet","receiver","state","kind","f","call","__classPrivateFieldGet","QuickLRU","Map","super","maxSize","maxAge","POSITIVE_INFINITY","onEviction","__oldCache","item","expiry","Date","now","undefined","peek","expiresIn","_a","deleted","resize","newSize","items","removeCount","slice","count","requested","evictCount","Math","trunc","min","max","values","WeakMap","WeakSet","Symbol","iterator","entriesDescending","i","entriesAscending","oldCacheSize","entries","forEach","callbackFunction","thisArgument","toStringTag","toString","for","mergeRanges","ranges","sorted","sort","merged","current","nxt","push","__webpack_require__","exports","definition","o","defineProperty","enumerable","obj","prop","hasOwnProperty","src_wasm_inflate_wasm_bg_namespaceObject","r","d","__wbg_Error_83742b46f01ce22d","__wbg_set_wasm","decompress_and_parse_bigwig","decompress_and_parse_summary","inflate_raw","inflate_raw_batch","inflate_raw_unknown_size","parse_bigwig_block","parse_summary_block","inputs","input_offsets","input_lengths","max_block_size","req_start","req_end","retptr","wasm","__wbindgen_add_to_stack_pointer","ptr0","passArray8ToWasm0","__wbindgen_export","len0","WASM_VECTOR_LEN","ptr1","passArray32ToWasm0","len1","ptr2","len2","r0","getDataViewMemory0","r1","r2","takeObject","v4","getArrayU8FromWasm0","__wbindgen_export2","req_chr_id","output_size","v2","arg0","arg1","ptr","heap_next","heap","idx","addHeapObject","len","numBytesDecoded","MAX_SAFARI_DECODE_BYTES","cachedTextDecoder","TextDecoder","ignoreBOM","fatal","decode","getUint8ArrayMemory0","decodeText","cachedDataViewMemory0","buffer","detached","memory","cachedUint32ArrayMemory0","cachedUint8ArrayMemory0","Array","arg","malloc","Uint32Array","ret","getObject","dropObject","val","wrapper_wasm","initPromise","async","instance","WebAssembly","instantiate","decompressAndParseBigWig","inputOffsets","inputLengths","maxBlockSize","reqStart","reqEnd","packed","starts","Int32Array","ends","scores","Float32Array","endsOffset","scoresOffset","unpackBigWigFeatures","decompressAndParseSummary","reqChrId","minScores","maxScores","minScoresOffset","maxScoresOffset","unpackSummaryFeatures","unzipBatch","blocks","maxOutputSize","block","offset","view","numBlocks","dataStart","offsets","inflateRawBatch","decompressAndParseBigWigBlocks","decompressAndParseSummaryBlocks","groupBlocks","b0","b1","blockGroups","lastBlock","lastBlockEnd","decoder","CIR_TREE_MAGIC","coordFilter","s1","e1","s2","e2","parseSummaryBlock","startOffset","request","features","chromId","start","end","validCnt","minScore","getFloat32","maxScore","sumData","chrId","summary","score","parseBigBedBlock","currOffset","c2","uniqueId","parseBigWigBlock","req","blockStart","itemStep","itemSpan","blockType","getUint8","itemCount","getUint16","parseBigWigBlockAsArrays","BlockView","bbi","refsByName","rTreeOffset","uncompressBufSize","rTreePromise","featureCache","_collectBlocks","chrName","magic","maxRTreeBlockSpan","blockIntersectsQuery","startChrom","startBase","endChrom","endBase","currentOffsets","spans","map","nextOffsets","resultBuffer","element","dv","isLeaf","nodeOffset","blockOffset","blockSize","childOffset","readWigData","collected","readFeatures","readWigDataAsArrays","optsWithReq","_readSummaryFeaturesAsArrays","_readBigWigFeaturesAsArrays","blockGroupsToFetch","allFeatures","blockGroup","groupOffset","subBlocks","decompressedData","decompressedOffsets","localBlocks","resultData","allStarts","allEnds","allScores","totalCount","isSummary","allMinScores","allMaxScores","BIG_BED_MAGIC","getDataView","BBI","headerP","renameRefSeqs","getHeader","_getHeader","args","filehandle","s","path","header","_getMainHeader","chroms","_readChromosomeTree","requestSize","version","numZoomLevels","chromosomeTreeOffset","unzoomedDataOffset","unzoomedIndexOffset","fieldCount","definedFieldCount","asOffset","totalSummaryOffset","extHeaderOffset","zoomLevels","reductionLevel","reserved","dataOffset","indexOffset","fileType","totalSummary","basesCovered","scoreMin","getFloat64","scoreMax","scoreSum","scoreSumSquares","autoSql","indexOf","refsByNumber","keySize","valSize","readBPlusTreeNode","currentOffset","isLeafNode","n","keyEnd","effectiveKeyEnd","refId","refSize","id","nextNodes","Promise","all","viewCache","getOrCreateBlockView","getUnzoomedView","_getView","basesPerSpan","scale","viewScale","getView","getFeatures","refName","getFeaturesAsArrays","BigWig","basesPerPx","zh","BinaryParser","setPosition","available","remLength","getByte","retValue","getShort","getInt16","getUShort","getInt","getUInt","getLong","getString","c","String","fromCharCode","getFixedLengthString","getFloat","getDouble","skip","readerCache","featureToWig","chr","wf","_b","_d","_c","_e","_f","BigWigReader","bw","reader","getGmodReader","loadHeader","h","bwVersion","nZoomLevels","chromTreeOffset","fullDataOffset","fullIndexOffset","autoSqlOffset","uncompressBuffSize","extensionOffset","getTotalSummary","mean","variance","minVal","maxVal","sumSquares","stddev","sqrt","bpStart","bpEnd","bpPerPixel","windowFunction","wig","readWGFeatures","chromNames","MAX_SAFE_INTEGER","SummaryBinData","bin","feature","summarizeWigData","startBP","binSize","summaryFeatures","finishBin","description","currentBinData","startBin","floor","endBin","consolidated","lastFeature","isWholeGenomeView","locus","toLowerCase","BigWigDataSource","_windowFunction","setWindowFunction","setCumulativeOffsets","_cumulativeOffsets","setChromNameResolver","resolver","_resolveChromName","fetchWG","resolvedLocus","fetchBigWigFeatures","fetchBigWigWGFeatures","chromosomeNames","wgFeatures","fetchRange","Range","redirected","contentLength","statusText","cl","getContentLength","clampedSize","_bytes","wasmMemory","HEAP8","HEAPU8","wasmExports","initialized","updateMemoryViews","Int8Array","timers","__emscripten_timeout","alignMemory","alignment","ceil","wasmImports","what","msg","RuntimeError","which","timeout_ms","clearTimeout","setTimeout","performance","requestedSize","oldSize","maxHeapSize","cutDown","overGrownHeapSize","pages","grow","initZstd","binary","binaryString","atob","charCodeAt","getZstdWasmBytes","importObject","module","compile","doInit","GTX_MAGIC","STANDARD_TILE_SIZES","inferTileSize","chromLength","nTiles","ts","GtxReader","experiments","experimentIdToIndex","chromosomes","chromOrder","tileIndexCache","zoomTileIndexCache","_signal","_doInit","err","headerBuf","parseHeader","metadataSize","dictionaryOffset","experimentMetadataOffset","metaDictStart","metaDictSize","dictionarySize","dirStart","chromDirectoryOffset","hasZoom","zoomDirectoryOffset","dirFetchSize","computeDirFetchSize","metaDictBuf","dirBuf","parseExperimentMetadata","dictionary","dctx","createDCtx","chromDirLength","parseChromDirectory","zoomStart","zoomLength","parseZoomDirectory","p","genomeLen","genome","nExperiments","resolution","payloadEncoding","readU64","groupStatsDirectoryOffset","idLen","experimentIndex","nMeta","metadata","j","keyLen","valLen","nChromosomes","nameLen","tileIndexOffset","tileIndexLength","nChroms","chromTileIndexes","loadTileIndex","chrom","cached","chromEntry","buf","tiles","parseTileIndex","loadZoomTileIndex","zoomIdx","cacheKey","zoomLevel","parsedNTiles","positionsOffset","positionsSize","experimentPointers","experimentIndexes","selectZoomLevel","readZoomFeatures","tileSize","firstTile","lastTile","fetchPlan","t","tile","expIdx","tileIdx","pointer","chunks","fetchMergedRanges","decompressed","decompress","tileStart","tileEnd","overlapStart","overlapEnd","firstBin","lastBin","binStart","binEnd","chromZoom","zoomBinSize","allValues","nZoomBins","means","getExperimentIds","getExperimentMetadata","find","resolveExperimentIndex","getChromosomes","bestIdx","plan","mergedRanges","itemEnd","last","fetches","results","localOffset","compressed","free","getFrameContentSize","isError","srcPtr","dictPtr","contentSize","dstCapacity","dstPtr","sizeOrError","decompressUsingDict","dispose","coordinators","GtxFetchCoordinator","pending","experimentId","existing","resolve","reject","batch","queueMicrotask","flush","expIndexes","idToIdx","exp","fetchGtxWGFeatures","getReader","GtxDataSource","coordinator","coord","getCoordinator","findUTRs","exons","cdStart","cdEnd","exon","utr","parseColorString","startsWith","parts","split","trim","g","isNaN","parseStrand","decodeGenePred","tokens","shift","strand","decodeExons","decodeGenePredExt","cdsStartStat","cdsEndStat","decodeRefGeneJson","rec","cdsStart","cdsEnd","name2","txStart","txEnd","exonStarts","exonEnds","frameOffsets","exonFrames","exonCount","fo","readingFrame","startsString","endsString","frameOffsetsString","fetchGeneFeatures","track","resp","json","GeneDataSource","_bpPerPixel","promises","perChromResults","k","reservoir","random","reservoirSample","SuppressedError","NIL","parent","left","right","IntervalTree","root","insert","interval","low","high","x","_IntervalTree_instances","_IntervalTree_createNode","_IntervalTree_treeInsert","color","node","y","_IntervalTree_leftRotate","_IntervalTree_rightRotate","findOverlapping","_IntervalTree_searchAll","mapIntervals","fn","applyInterval","_IntervalTree_applyUpdate","nodeMax","intervalHigh","nodeMin","intervalLow","FeatureCache","featureList","treeMap","list","chrFeatures","buildIntervalTree","buildTreeMap","containsRange","contains","queryFeatures","tree","intervals","indexRange","findFeatures","found","getAllFeatures","chunkSize","round","subArray","iStart","iEnd","_has","shrinkBuf","fnTyped","arraySet","dest","src","src_offs","dest_offs","flattenChunks","l","pos","chunk","Buf8","Buf16","Uint16Array","Buf32","fnUntyped","concat","apply","typedOK","supported","strApplyOK","strApplyUintOK","utf8len","table","q","string2buf","str","m_pos","str_len","buf_len","buf2string","out","c_len","utf16buf","_buf2binstring","utf8border","GZheader","time","xflags","os","extra","extra_len","comment","hcrc","adler32","adler","crcTable","makeTable","crc32","crc","inflate_fast","strm","_in","_out","beg","dmax","wsize","whave","wnext","s_window","hold","bits","lcode","dcode","lmask","dmask","here","op","dist","from","from_source","output","next_in","avail_in","next_out","avail_out","window","lencode","distcode","lenbits","distbits","top","dolen","sane","MAXBITS","lbase","lext","dbase","dext","inflate_table","type","lens","lens_index","codes","table_index","work","incr","mask","here_bits","here_op","here_val","sym","curr","drop","used","huff","base","base_index","offs","extra_index","Z_STREAM_ERROR","TYPE","BAD","zswap32","InflateState","wrap","havedict","flags","check","total","head","wbits","ncode","nlen","ndist","have","lendyn","distdyn","back","was","inflateReset","total_in","total_out","inflateResetKeep","inflateInit2","windowBits","inflateReset2","lenfix","distfix","virgin","fixedtables","updatewindow","copy","inflate","put","last_bits","last_op","last_val","hbuf","order","inf_leave","data_type","inflateSetDictionary","dictLength","ZStream","Inflate","sources","arguments","to","opt","raw","ended","_mode","next_out_utf8","tail","utf8str","dict","allowBufError","binstring2buf","zlibInflate","onEnd","onData","inflateEnd","join","ungzip","inflator","src_wasm_bgzf_wasm_bg_namespaceObject","ChunkSliceResult","DecompressResult","__wbg_Error_8c4e43fe74559d73","__wbg___wbindgen_throw_be289d5034ed271b","decompress_all","decompress_block","decompress_chunk_slice","__wrap","create","__wbg_ptr","ChunkSliceResultFinalization","register","__destroy_into_raw","unregister","__wbg_chunksliceresult_free","chunksliceresult_buffer","v1","cpositions","chunksliceresult_cpositions","getArrayF64FromWasm0","dpositions","chunksliceresult_dpositions","DecompressResultFinalization","__wbg_decompressresult_free","bytes_read","decompressresult_bytes_read","decompressresult_data","min_block_position","min_data_position","max_block_position","max_data_position","getStringFromWasm0","FinalizationRegistry","cachedFloat64ArrayMemory0","Float64Array","getFloat64ArrayMemory0","unzip","inputData","decompressAll","DecompressionStream","ds","writer","writable","getWriter","writePromise","write","readable","totalLength","reduce","sum","decompressGzip","unzipChunkSlice","_blockCache","minv","maxv","minBlockPosition","minDataPosition","maxBlockPosition","maxDataPosition","decompressChunkSlice","blockPosition","dataPosition","Chunk","fetchedSize","_fetchedSize","toUniqueString","compareTo","IndexFile","renameRefSeq","getMetadata","indices","_indices","parse","_findFirstData","currentFdl","virtualOffset","parseP","_parse","hasRefSeq","seqId","binIndex","_parseNameBytes","namesBytes","currRefId","currNameStart","refIdToName","refNameToId","longFromBytesToUnsigned","TWO_PWR_16_DBL","canMergeBlocks","chunk1","chunk2","optimizeChunks","lowest","mergedChunks","lastChunk","c0","c1","dif","VirtualOffset","fromBytes","formats","lshift","num","rshift","CSI","maxBinNumber","depth","minShift","lineCount","indexData","stats","indexCov","parseAuxData","formatFlags","coordinateType","format","columnNumbers","ref","metaValue","metaChar","skipLines","nameSectionLength","csiVersion","maxRefLength","auxLength","aux","refCount","firstDataLine","binCount","parsePseudoBin","loffset","chunkCount","u","v","csi","blocksForRange","ba","overlappingBins","reg2bins","bins","TabixIndex","linearCount","linearIndex","nintv","minLin","maxLin","vp","TabixIndexedFile","tbiPath","tbiUrl","tbiFilehandle","csiPath","csiUrl","csiFilehandle","renameRefSeqsPre","chunkCacheSize","LRU","index","TBI","hasCustomRenameRefSeq","chunkCache","readChunk","calculateFileOffset","minvDataPosition","getLines","lineCallback","isVCF","columnNumbersEffective","maxColumn","metaCharCode","coordinateOffset","isIdentityRename","line","target","checkLine","getHeaderBuffer","maxFetch","lastNewline","newlineByte","metaByte","byte","getReferenceSequenceNames","regionRefName","regionStart","regionEnd","refColumn","startColumn","endColumn","fields","startCoordinate","endCoordinate","_getVcfEnd","prev","tabs","refSeq","info","endIdx","TabixReader","indexUrl","tabix","meta","refNames","nref","colSeq","colBeg","colEnd","sequenceNames","getSequenceNames","readHeaderLines","headerStr","filter","readLines","lines","decodeBed","maxColumnCount","gffTags","columnCount","attrs","pairs","pair","substring","parseGFFStyleAttributes","attributes","nameField","field","gffNameFields","exonSizes","eStart","eEnd","thicknessColumn","thickness","parseFloat","colorColumn","transcriptTypes","cdsTypes","utrTypes","exonTypes","transcriptPartTypes","cltn","isTranscript","endsWith","isTranscriptPart","isIntron","isExon","isCoding","isUTR","gffEncodings","decodeGFFAttribute","decoded","charAt","parseGFFAttributes","attributeString","keyValueDelim","isGff3","kv","stripQuotes","decodeBase","_delim","phase","getAttributeValue","record","delim","assembleGFFTranscripts","records","filterTypes","filtered","chrIdMap","combined","idMap","arr","cf","_mergedExons","combineFeaturesById","geneMap","transcripts","consumed","builder","geneRecord","parents","getParents","parentId","transcript","finishTranscript","transcriptToFeature","recordToSimpleFeature","number","numberExons","combineFeaturesByType","lastStart","lastEnd","part","findExonContaining","addCDS","addUTR","cds","resolveName","mergedExons","fixBedPE","first","every","interChr","chr1","chr2","f1","f2","dup","start1","end1","start2","end2","getDecoder","_header","bed","pValue","qValue","decodeBroadPeak","toBedHeader","delimiter","requiresAssembly","peak","decodeNarrowPeak","decodeBedGraph","keyLower","decodeGFF3","idField","parentField","decodeGTF","decodeRefflat","decodeGappedPeak","columns","hiccups","columnNames","stdColumns","strand1","strand2","extras","decodeBedpe","toBedpeHeader","postProcess","colorToken","decodeInteract","props","parseTrackLine","properties","cd","parseColumnsDirective","parseFeatures","resolvedFormat","wigState","parseFixedStep","parseVariableStep","decodeHeader","assembleGFF","tmp","tk","t1","t2","step","span","knownFileExtensions","MAIN_CHROM_RE","isMainChromosome","test","chromNumber","suffix","TextFeatureSource","config","allFeaturesLoaded","detected","qIdx","slashIdx","lastIndexOf","ext","inferFormatFromPath","indexed","_indexed","indexURL","lower","isLikelyIndexed","inferIndexURL","tabixReader","fetchIndexed","fetchNonIndexed","headerLines","loadAllFeatures","urlLower","isGzUrl","contentEncoding","Response","body","pipeThrough","localeCompare","chrNames","chromSizes","fromEntries","allByChrom","workerSelf","self","registry","instances","inflightAborts","instanceId","createDataSource","fetchId","controller","cancel","configure","destroy","log","onmessage","postMessage","isAbort","DOMException"],"mappings":"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"}
|