New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@gmod/bbi

Package Overview
Dependencies
Maintainers
5
Versions
57
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@gmod/bbi - npm Package Compare versions

Comparing version 1.0.27 to 1.0.28

7

CHANGELOG.md

@@ -0,1 +1,8 @@

## [1.0.28](https://github.com/GMOD/bbi-js/compare/v1.0.27...v1.0.28) (2020-01-28)
- Change typescript interface to use object keys instead of Map type for refsByName, refsById
- Typescript only release change
## [1.0.27](https://github.com/GMOD/bbi-js/compare/v1.0.26...v1.0.27) (2020-01-10)

@@ -2,0 +9,0 @@

8

dist/bbi.d.ts

@@ -38,4 +38,8 @@ import { GenericFilehandle } from 'generic-filehandle';

fileType: string;
refsByName: Map<string, number>;
refsByNumber: Map<number, RefInfo>;
refsByName: {
[key: string]: number;
};
refsByNumber: {
[key: number]: RefInfo;
};
}

@@ -42,0 +46,0 @@ declare class AbortAwareCache {

@@ -34,3 +34,3 @@ "use strict";

function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }

@@ -624,2 +624,2 @@ var BIG_WIG_MAGIC = -2003829722;

exports.BBI = BBI;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/bbi.ts"],"names":["BIG_WIG_MAGIC","BIG_BED_MAGIC","AbortAwareCache","Map","fn","cache","abortableMemoizeFn","signal","has","fnReturn","set","catch","aborted","delete","get","e","code","name","getParsers","isBE","le","headerParser","Parser","endianess","int32","uint16","uint64","uint32","array","length","type","totalSummaryParser","double","chromTreeParser","isLeafNode","uint8","skip","BBI","options","filehandle","renameRefSeqs","path","url","s","headerCache","bbi","RemoteFile","LocalFile","Error","getHeader","abortableMemoize","_getHeader","bind","abortSignal","_getMainHeader","header","_readChromTree","chroms","requestSize","read","Buffer","alloc","buffer","isBigEndian","_isBigEndian","ret","parse","result","fileType","magic","asOffset","totalSummaryOffset","autoSql","slice","indexOf","toString","tail","totalSummary","readInt32LE","readInt32BE","refsByNumber","refsByName","chromTreeOffset","unzoomedDataOffset","data","p","keySize","leafNodeParser","string","stripNull","nonleafNodeParser","rootNodeOffset","bptReadNode","currentOffset","offset","cnt","n","leafRet","key","refId","refSize","refRec","id","nextNodes","nonleafRet","childOffset","push","Promise","all","unzoomedIndexOffset","zoomLevels","uncompressBufSize","nzl","cirLen","dataOffset","BlockView","refName","start","end","opts","scale","chrName","basesPerSpan","getView","view","Observable","observer","readWigData","getFeatureStream","ob","pipe","acc","curr","concat","toPromise"],"mappings":"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","sourcesContent":["import { Parser } from '@gmod/binary-parser'\nimport { LocalFile, RemoteFile, GenericFilehandle } from 'generic-filehandle'\nimport { Observable, Observer } from 'rxjs'\nimport { reduce } from 'rxjs/operators'\n\nimport { BlockView } from './blockView'\nimport { abortBreakPoint, AbortError } from './util'\n\nconst BIG_WIG_MAGIC = -2003829722\nconst BIG_BED_MAGIC = -2021002517\n\nexport interface Feature {\n  start: number\n  end: number\n  score: number\n  rest?: string // for bigbed line\n  minScore?: number // for summary line\n  maxScore?: number // for summary line\n  summary?: boolean // is summary line\n  uniqueId?: string // for bigbed contains uniqueId calculated from file offset\n  field?: number // used in bigbed searching\n}\ninterface Statistics {\n  scoreSum: number\n  basesCovered: number\n  scoreSumSquares: number\n}\n\ninterface RefInfo {\n  name: string\n  id: number\n  length: number\n}\nexport interface Header {\n  autoSql: string\n  totalSummary: Statistics\n  zoomLevels: any\n  unzoomedIndexOffset: number\n  unzoomedDataOffset: number\n  definedFieldCount: number\n  uncompressBufSize: number\n  chromTreeOffset: number\n  fileSize: number\n  extHeaderOffset: number\n  isBigEndian: boolean\n  fileType: string\n  refsByName: Map<string, number>\n  refsByNumber: Map<number, RefInfo>\n}\n\ntype AbortableCallback = (signal: AbortSignal) => Promise<any>\n\n/* A class that provides memoization for abortable calls */\nclass AbortAwareCache {\n  private cache: Map<AbortableCallback, any> = new Map()\n\n  /*\n   * Takes a function that has one argument, abortSignal, that returns a promise\n   * and it works by retrying the function if a previous attempt to initialize the parse cache was aborted\n   * @param fn - an AbortableCallback\n   * @return a memoized version of the AbortableCallback using the AbortAwareCache\n   */\n  public abortableMemoize(fn: (signal?: AbortSignal) => Promise<any>): (signal?: AbortSignal) => Promise<any> {\n    const { cache } = this\n    return function abortableMemoizeFn(signal?: AbortSignal): Promise<any> {\n      if (!cache.has(fn)) {\n        const fnReturn = fn(signal)\n        cache.set(fn, fnReturn)\n        if (signal) {\n          fnReturn.catch((): void => {\n            if (signal.aborted) cache.delete(fn)\n          })\n        }\n        return cache.get(fn)\n      }\n      return cache.get(fn).catch(\n        (e: AbortError | DOMException): Promise<any> => {\n          if (e.code === 'ERR_ABORTED' || e.name === 'AbortError') {\n            return fn(signal)\n          }\n          throw e\n        },\n      )\n    }\n  }\n}\n\n/* get the compiled parsers for different sections of the bigwig file\n *\n * @param isBE - is big endian, typically false\n * @return an object with compiled parsers\n */\nfunction getParsers(isBE: boolean): any {\n  const le = isBE ? 'big' : 'little'\n  const headerParser = new Parser()\n    .endianess(le)\n    .int32('magic')\n    .uint16('version')\n    .uint16('numZoomLevels')\n    .uint64('chromTreeOffset')\n    .uint64('unzoomedDataOffset')\n    .uint64('unzoomedIndexOffset')\n    .uint16('fieldCount')\n    .uint16('definedFieldCount')\n    .uint64('asOffset') // autoSql offset, used in bigbed\n    .uint64('totalSummaryOffset')\n    .uint32('uncompressBufSize')\n    .uint64('extHeaderOffset') // name index offset, used in bigbed\n    .array('zoomLevels', {\n      length: 'numZoomLevels',\n      type: new Parser()\n        .uint32('reductionLevel')\n        .uint32('reserved')\n        .uint64('dataOffset')\n        .uint64('indexOffset'),\n    })\n\n  const totalSummaryParser = new Parser()\n    .endianess(le)\n    .uint64('basesCovered')\n    .double('scoreMin')\n    .double('scoreMax')\n    .double('scoreSum')\n    .double('scoreSumSquares')\n\n  const chromTreeParser = new Parser()\n    .endianess(le)\n    .uint32('magic')\n    .uint32('blockSize')\n    .uint32('keySize')\n    .uint32('valSize')\n    .uint64('itemCount')\n\n  const isLeafNode = new Parser()\n    .endianess(le)\n    .uint8('isLeafNode')\n    .skip(1)\n    .uint16('cnt')\n\n  return {\n    chromTreeParser,\n    totalSummaryParser,\n    headerParser,\n    isLeafNode,\n  }\n}\n\nexport abstract class BBI {\n  protected bbi: GenericFilehandle\n\n  protected headerCache: AbortAwareCache\n\n  protected renameRefSeqs: (a: string) => string\n\n  /* fetch and parse header information from a bigwig or bigbed file\n   * @param abortSignal - abort the operation, can be null\n   * @return a Header object\n   */\n  public getHeader: (abortSignal?: AbortSignal) => Promise<Header>\n\n  /*\n   * @param filehandle - a filehandle from generic-filehandle or implementing something similar to the node10 fs.promises API\n   * @param path - a Local file path as a string\n   * @param url - a URL string\n   * @param renameRefSeqs - an optional method to rename the internal reference sequences using a mapping function\n   */\n  public constructor(\n    options: {\n      filehandle?: GenericFilehandle\n      path?: string\n      url?: string\n      renameRefSeqs?: (a: string) => string\n    } = {},\n  ) {\n    const { filehandle, renameRefSeqs, path, url } = options\n    this.renameRefSeqs = renameRefSeqs || ((s: string): string => s)\n    this.headerCache = new AbortAwareCache()\n    if (filehandle) {\n      this.bbi = filehandle\n    } else if (url) {\n      this.bbi = new RemoteFile(url)\n    } else if (path) {\n      this.bbi = new LocalFile(path)\n    } else {\n      throw new Error('no file given')\n    }\n    this.getHeader = this.headerCache.abortableMemoize(this._getHeader.bind(this))\n  }\n\n  private async _getHeader(abortSignal?: AbortSignal) {\n    const header = await this._getMainHeader(abortSignal)\n    const chroms = await this._readChromTree(header, abortSignal)\n    return { ...header, ...chroms }\n  }\n\n  private async _getMainHeader(abortSignal?: AbortSignal, requestSize = 2000): Promise<Header> {\n    const { buffer } = await this.bbi.read(Buffer.alloc(requestSize), 0, requestSize, 0, { signal: abortSignal })\n    const isBigEndian = this._isBigEndian(buffer)\n    const ret = getParsers(isBigEndian)\n    const header = ret.headerParser.parse(buffer).result\n    header.fileType = header.magic === BIG_BED_MAGIC ? 'bigbed' : 'bigwig'\n    if (header.asOffset > requestSize || header.totalSummaryOffset > requestSize) {\n      return this._getMainHeader(abortSignal, requestSize * 2)\n    }\n    if (header.asOffset) {\n      header.autoSql = buffer.slice(header.asOffset, buffer.indexOf(0, header.asOffset)).toString('utf8')\n    }\n    if (header.totalSummaryOffset > requestSize) {\n      return this._getMainHeader(abortSignal, requestSize * 2)\n    }\n    if (header.totalSummaryOffset) {\n      const tail = buffer.slice(header.totalSummaryOffset)\n      header.totalSummary = ret.totalSummaryParser.parse(tail).result\n    }\n    return { ...header, isBigEndian }\n  }\n\n  private _isBigEndian(buffer: Buffer): boolean {\n    let ret = buffer.readInt32LE(0)\n    if (ret === BIG_WIG_MAGIC || ret === BIG_BED_MAGIC) {\n      return false\n    }\n    ret = buffer.readInt32BE(0)\n    if (ret === BIG_WIG_MAGIC || ret === BIG_BED_MAGIC) {\n      return true\n    }\n    throw new Error('not a BigWig/BigBed file')\n  }\n\n  // todo: add progress if long running\n  private async _readChromTree(header: Header, abortSignal?: AbortSignal) {\n    const isBE = header.isBigEndian\n    const le = isBE ? 'big' : 'little'\n    const refsByNumber: { [key: number]: { name: string; id: number; length: number } } = []\n    const refsByName: { [key: string]: number } = {}\n    const { chromTreeOffset } = header\n    let { unzoomedDataOffset } = header\n\n    while (unzoomedDataOffset % 4 !== 0) {\n      unzoomedDataOffset += 1\n    }\n\n    const { buffer: data } = await this.bbi.read(\n      Buffer.alloc(unzoomedDataOffset - chromTreeOffset),\n      0,\n      unzoomedDataOffset - chromTreeOffset,\n      chromTreeOffset,\n      { signal: abortSignal },\n    )\n\n    const p = getParsers(isBE)\n    const { keySize } = p.chromTreeParser.parse(data).result\n    const leafNodeParser = new Parser()\n      .endianess(le)\n      .string('key', { stripNull: true, length: keySize })\n      .uint32('refId')\n      .uint32('refSize')\n    const nonleafNodeParser = new Parser()\n      .endianess(le)\n      .skip(keySize)\n      .uint64('childOffset')\n    const rootNodeOffset = 32\n    const bptReadNode = async (currentOffset: number): Promise<void> => {\n      let offset = currentOffset\n      if (offset >= data.length) throw new Error('reading beyond end of buffer')\n      const ret = p.isLeafNode.parse(data.slice(offset))\n      const { isLeafNode, cnt } = ret.result\n      offset += ret.offset\n      await abortBreakPoint(abortSignal)\n      if (isLeafNode) {\n        for (let n = 0; n < cnt; n += 1) {\n          const leafRet = leafNodeParser.parse(data.slice(offset))\n          offset += leafRet.offset\n          const { key, refId, refSize } = leafRet.result\n          const refRec = { name: key, id: refId, length: refSize }\n          refsByName[this.renameRefSeqs(key)] = refId\n          refsByNumber[refId] = refRec\n        }\n      } else {\n        // parse index node\n        const nextNodes = []\n        for (let n = 0; n < cnt; n += 1) {\n          const nonleafRet = nonleafNodeParser.parse(data.slice(offset))\n          let { childOffset } = nonleafRet.result\n          offset += nonleafRet.offset\n          childOffset -= chromTreeOffset\n          nextNodes.push(bptReadNode(childOffset))\n        }\n        await Promise.all(nextNodes)\n      }\n    }\n    await bptReadNode(rootNodeOffset)\n    return {\n      refsByName,\n      refsByNumber,\n    }\n  }\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  protected async getUnzoomedView(abortSignal?: AbortSignal): Promise<BlockView> {\n    const {\n      unzoomedIndexOffset,\n      zoomLevels,\n      refsByName,\n      uncompressBufSize,\n      isBigEndian,\n      fileType,\n    } = await this.getHeader(abortSignal)\n    const nzl = zoomLevels[0]\n    const cirLen = nzl ? nzl.dataOffset - unzoomedIndexOffset : 4000\n    return new BlockView(\n      this.bbi,\n      refsByName,\n      unzoomedIndexOffset,\n      cirLen,\n      isBigEndian,\n      uncompressBufSize > 0,\n      fileType,\n    )\n  }\n\n  /*\n   * abstract method - get the view for a given scale\n   */\n  protected abstract async getView(scale: number, abortSignal?: AbortSignal): Promise<BlockView>\n\n  /**\n   * Gets features from a BigWig file\n   *\n   * @param refName - The chromosome name\n   * @param start - The start of a region\n   * @param end - The end of a region\n   * @param opts - An object containing basesPerSpan (e.g. pixels per basepair) or scale used to infer the zoomLevel to use\n   */\n  public async getFeatureStream(\n    refName: string,\n    start: number,\n    end: number,\n    opts: { basesPerSpan?: number; scale?: number; signal?: AbortSignal } = { scale: 1 },\n  ): Promise<Observable<Feature[]>> {\n    await this.getHeader(opts.signal)\n    const chrName = this.renameRefSeqs(refName)\n    let view: BlockView\n\n    if (opts.basesPerSpan) {\n      view = await this.getView(1 / opts.basesPerSpan, opts.signal)\n    } else if (opts.scale) {\n      view = await this.getView(opts.scale, opts.signal)\n    } else {\n      view = await this.getView(1, opts.signal)\n    }\n\n    if (!view) {\n      throw new Error('unable to get block view for data')\n    }\n    return new Observable((observer: Observer<Feature[]>): void => {\n      view.readWigData(chrName, start, end, observer, opts)\n    })\n  }\n\n  public async getFeatures(\n    refName: string,\n    start: number,\n    end: number,\n    opts: { basesPerSpan?: number; scale?: number; signal?: AbortSignal } = { scale: 1 },\n  ): Promise<Feature[]> {\n    const ob = await this.getFeatureStream(refName, start, end, opts)\n    const ret = await ob.pipe(reduce((acc: Feature[], curr: Feature[]): Feature[] => acc.concat(curr))).toPromise()\n    return ret || []\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/bbi.ts"],"names":["BIG_WIG_MAGIC","BIG_BED_MAGIC","AbortAwareCache","Map","fn","cache","abortableMemoizeFn","signal","has","fnReturn","set","catch","aborted","delete","get","e","code","name","getParsers","isBE","le","headerParser","Parser","endianess","int32","uint16","uint64","uint32","array","length","type","totalSummaryParser","double","chromTreeParser","isLeafNode","uint8","skip","BBI","options","filehandle","renameRefSeqs","path","url","s","headerCache","bbi","RemoteFile","LocalFile","Error","getHeader","abortableMemoize","_getHeader","bind","abortSignal","_getMainHeader","header","_readChromTree","chroms","requestSize","read","Buffer","alloc","buffer","isBigEndian","_isBigEndian","ret","parse","result","fileType","magic","asOffset","totalSummaryOffset","autoSql","slice","indexOf","toString","tail","totalSummary","readInt32LE","readInt32BE","refsByNumber","refsByName","chromTreeOffset","unzoomedDataOffset","data","p","keySize","leafNodeParser","string","stripNull","nonleafNodeParser","rootNodeOffset","bptReadNode","currentOffset","offset","cnt","n","leafRet","key","refId","refSize","refRec","id","nextNodes","nonleafRet","childOffset","push","Promise","all","unzoomedIndexOffset","zoomLevels","uncompressBufSize","nzl","cirLen","dataOffset","BlockView","refName","start","end","opts","scale","chrName","basesPerSpan","getView","view","Observable","observer","readWigData","getFeatureStream","ob","pipe","acc","curr","concat","toPromise"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAEA;;AACA;;;;;;AAEA,IAAMA,aAAa,GAAG,CAAC,UAAvB;AACA,IAAMC,aAAa,GAAG,CAAC,UAAvB;;AA2CA;IACMC,e;;;;;iDACyC,IAAIC,GAAJ,E;;;;;;AAE7C;;;;;;qCAMwBC,E,EAAoF;AAAA,UAClGC,KADkG,GACxF,IADwF,CAClGA,KADkG;AAE1G,aAAO,SAASC,kBAAT,CAA4BC,MAA5B,EAAgE;AACrE,YAAI,CAACF,KAAK,CAACG,GAAN,CAAUJ,EAAV,CAAL,EAAoB;AAClB,cAAMK,QAAQ,GAAGL,EAAE,CAACG,MAAD,CAAnB;AACAF,UAAAA,KAAK,CAACK,GAAN,CAAUN,EAAV,EAAcK,QAAd;;AACA,cAAIF,MAAJ,EAAY;AACVE,YAAAA,QAAQ,CAACE,KAAT,CAAe,YAAY;AACzB,kBAAIJ,MAAM,CAACK,OAAX,EAAoBP,KAAK,CAACQ,MAAN,CAAaT,EAAb;AACrB,aAFD;AAGD;;AACD,iBAAOC,KAAK,CAACS,GAAN,CAAUV,EAAV,CAAP;AACD;;AACD,eAAOC,KAAK,CAACS,GAAN,CAAUV,EAAV,EAAcO,KAAd,CACL,UAACI,CAAD,EAAgD;AAC9C,cAAIA,CAAC,CAACC,IAAF,KAAW,aAAX,IAA4BD,CAAC,CAACE,IAAF,KAAW,YAA3C,EAAyD;AACvD,mBAAOb,EAAE,CAACG,MAAD,CAAT;AACD;;AACD,gBAAMQ,CAAN;AACD,SANI,CAAP;AAQD,OAnBD;AAoBD;;;;AAGH;;;;;;;AAKA,SAASG,UAAT,CAAoBC,IAApB,EAAwC;AACtC,MAAMC,EAAE,GAAGD,IAAI,GAAG,KAAH,GAAW,QAA1B;AACA,MAAME,YAAY,GAAG,IAAIC,oBAAJ,GAClBC,SADkB,CACRH,EADQ,EAElBI,KAFkB,CAEZ,OAFY,EAGlBC,MAHkB,CAGX,SAHW,EAIlBA,MAJkB,CAIX,eAJW,EAKlBC,MALkB,CAKX,iBALW,EAMlBA,MANkB,CAMX,oBANW,EAOlBA,MAPkB,CAOX,qBAPW,EAQlBD,MARkB,CAQX,YARW,EASlBA,MATkB,CASX,mBATW,EAUlBC,MAVkB,CAUX,UAVW,EAUC;AAVD,GAWlBA,MAXkB,CAWX,oBAXW,EAYlBC,MAZkB,CAYX,mBAZW,EAalBD,MAbkB,CAaX,iBAbW,EAaQ;AAbR,GAclBE,KAdkB,CAcZ,YAdY,EAcE;AACnBC,IAAAA,MAAM,EAAE,eADW;AAEnBC,IAAAA,IAAI,EAAE,IAAIR,oBAAJ,GACHK,MADG,CACI,gBADJ,EAEHA,MAFG,CAEI,UAFJ,EAGHD,MAHG,CAGI,YAHJ,EAIHA,MAJG,CAII,aAJJ;AAFa,GAdF,CAArB;AAuBA,MAAMK,kBAAkB,GAAG,IAAIT,oBAAJ,GACxBC,SADwB,CACdH,EADc,EAExBM,MAFwB,CAEjB,cAFiB,EAGxBM,MAHwB,CAGjB,UAHiB,EAIxBA,MAJwB,CAIjB,UAJiB,EAKxBA,MALwB,CAKjB,UALiB,EAMxBA,MANwB,CAMjB,iBANiB,CAA3B;AAQA,MAAMC,eAAe,GAAG,IAAIX,oBAAJ,GACrBC,SADqB,CACXH,EADW,EAErBO,MAFqB,CAEd,OAFc,EAGrBA,MAHqB,CAGd,WAHc,EAIrBA,MAJqB,CAId,SAJc,EAKrBA,MALqB,CAKd,SALc,EAMrBD,MANqB,CAMd,WANc,CAAxB;AAQA,MAAMQ,UAAU,GAAG,IAAIZ,oBAAJ,GAChBC,SADgB,CACNH,EADM,EAEhBe,KAFgB,CAEV,YAFU,EAGhBC,IAHgB,CAGX,CAHW,EAIhBX,MAJgB,CAIT,KAJS,CAAnB;AAMA,SAAO;AACLQ,IAAAA,eAAe,EAAfA,eADK;AAELF,IAAAA,kBAAkB,EAAlBA,kBAFK;AAGLV,IAAAA,YAAY,EAAZA,YAHK;AAILa,IAAAA,UAAU,EAAVA;AAJK,GAAP;AAMD;;IAEqBG,G;;;AAOpB;;;;;AAMA;;;;;;AAMA,iBAOE;AAAA,QANAC,OAMA,uEADI,EACJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,QACQC,UADR,GACiDD,OADjD,CACQC,UADR;AAAA,QACoBC,aADpB,GACiDF,OADjD,CACoBE,aADpB;AAAA,QACmCC,IADnC,GACiDH,OADjD,CACmCG,IADnC;AAAA,QACyCC,GADzC,GACiDJ,OADjD,CACyCI,GADzC;;AAEA,SAAKF,aAAL,GAAqBA,aAAa,IAAK,UAACG,CAAD;AAAA,aAAuBA,CAAvB;AAAA,KAAvC;;AACA,SAAKC,WAAL,GAAmB,IAAI1C,eAAJ,EAAnB;;AACA,QAAIqC,UAAJ,EAAgB;AACd,WAAKM,GAAL,GAAWN,UAAX;AACD,KAFD,MAEO,IAAIG,GAAJ,EAAS;AACd,WAAKG,GAAL,GAAW,IAAIC,6BAAJ,CAAeJ,GAAf,CAAX;AACD,KAFM,MAEA,IAAID,IAAJ,EAAU;AACf,WAAKI,GAAL,GAAW,IAAIE,4BAAJ,CAAcN,IAAd,CAAX;AACD,KAFM,MAEA;AACL,YAAM,IAAIO,KAAJ,CAAU,eAAV,CAAN;AACD;;AACD,SAAKC,SAAL,GAAiB,KAAKL,WAAL,CAAiBM,gBAAjB,CAAkC,KAAKC,UAAL,CAAgBC,IAAhB,CAAqB,IAArB,CAAlC,CAAjB;AACD;;;;;;;iDAEwBC,W;;;;;;;uBACF,KAAKC,cAAL,CAAoBD,WAApB,C;;;AAAfE,gBAAAA,M;;uBACe,KAAKC,cAAL,CAAoBD,MAApB,EAA4BF,WAA5B,C;;;AAAfI,gBAAAA,M;mEACMF,M,MAAWE,M;;;;;;;;;;;;;;;;;;;;;kDAGIJ,W;;;;;;;;;;;;;;AAA2BK,gBAAAA,W,8DAAc,I;;uBAC3C,KAAKb,GAAL,CAASc,IAAT,CAAcC,MAAM,CAACC,KAAP,CAAaH,WAAb,CAAd,EAAyC,CAAzC,EAA4CA,WAA5C,EAAyD,CAAzD,EAA4D;AAAEnD,kBAAAA,MAAM,EAAE8C;AAAV,iBAA5D,C;;;;AAAjBS,gBAAAA,M,QAAAA,M;AACFC,gBAAAA,W,GAAc,KAAKC,YAAL,CAAkBF,MAAlB,C;AACdG,gBAAAA,G,GAAM/C,UAAU,CAAC6C,WAAD,C;AAChBR,gBAAAA,M,GAASU,GAAG,CAAC5C,YAAJ,CAAiB6C,KAAjB,CAAuBJ,MAAvB,EAA+BK,M;AAC9CZ,gBAAAA,MAAM,CAACa,QAAP,GAAkBb,MAAM,CAACc,KAAP,KAAiBpE,aAAjB,GAAiC,QAAjC,GAA4C,QAA9D;;sBACIsD,MAAM,CAACe,QAAP,GAAkBZ,WAAlB,IAAiCH,MAAM,CAACgB,kBAAP,GAA4Bb,W;;;;;kDACxD,KAAKJ,cAAL,CAAoBD,WAApB,EAAiCK,WAAW,GAAG,CAA/C,C;;;AAET,oBAAIH,MAAM,CAACe,QAAX,EAAqB;AACnBf,kBAAAA,MAAM,CAACiB,OAAP,GAAiBV,MAAM,CAACW,KAAP,CAAalB,MAAM,CAACe,QAApB,EAA8BR,MAAM,CAACY,OAAP,CAAe,CAAf,EAAkBnB,MAAM,CAACe,QAAzB,CAA9B,EAAkEK,QAAlE,CAA2E,MAA3E,CAAjB;AACD;;sBACGpB,MAAM,CAACgB,kBAAP,GAA4Bb,W;;;;;kDACvB,KAAKJ,cAAL,CAAoBD,WAApB,EAAiCK,WAAW,GAAG,CAA/C,C;;;AAET,oBAAIH,MAAM,CAACgB,kBAAX,EAA+B;AACvBK,kBAAAA,IADuB,GAChBd,MAAM,CAACW,KAAP,CAAalB,MAAM,CAACgB,kBAApB,CADgB;AAE7BhB,kBAAAA,MAAM,CAACsB,YAAP,GAAsBZ,GAAG,CAAClC,kBAAJ,CAAuBmC,KAAvB,CAA6BU,IAA7B,EAAmCT,MAAzD;AACD;;oEACWZ,M;AAAQQ,kBAAAA,WAAW,EAAXA;;;;;;;;;;;;;;;;;;;iCAGDD,M,EAAyB;AAC5C,UAAIG,GAAG,GAAGH,MAAM,CAACgB,WAAP,CAAmB,CAAnB,CAAV;;AACA,UAAIb,GAAG,KAAKjE,aAAR,IAAyBiE,GAAG,KAAKhE,aAArC,EAAoD;AAClD,eAAO,KAAP;AACD;;AACDgE,MAAAA,GAAG,GAAGH,MAAM,CAACiB,WAAP,CAAmB,CAAnB,CAAN;;AACA,UAAId,GAAG,KAAKjE,aAAR,IAAyBiE,GAAG,KAAKhE,aAArC,EAAoD;AAClD,eAAO,IAAP;AACD;;AACD,YAAM,IAAI+C,KAAJ,CAAU,0BAAV,CAAN;AACD,K,CAED;;;;;;;kDAC6BO,M,EAAgBF,W;;;;;;;;;AACrClC,gBAAAA,I,GAAOoC,MAAM,CAACQ,W;AACd3C,gBAAAA,E,GAAKD,IAAI,GAAG,KAAH,GAAW,Q;AACpB6D,gBAAAA,Y,GAAgF,E;AAChFC,gBAAAA,U,GAAwC,E;AACtCC,gBAAAA,e,GAAoB3B,M,CAApB2B,e;AACFC,gBAAAA,kB,GAAuB5B,M,CAAvB4B,kB;;AAEN,uBAAOA,kBAAkB,GAAG,CAArB,KAA2B,CAAlC,EAAqC;AACnCA,kBAAAA,kBAAkB,IAAI,CAAtB;AACD;;;uBAE8B,KAAKtC,GAAL,CAASc,IAAT,CAC7BC,MAAM,CAACC,KAAP,CAAasB,kBAAkB,GAAGD,eAAlC,CAD6B,EAE7B,CAF6B,EAG7BC,kBAAkB,GAAGD,eAHQ,EAI7BA,eAJ6B,EAK7B;AAAE3E,kBAAAA,MAAM,EAAE8C;AAAV,iBAL6B,C;;;;AAAf+B,gBAAAA,I,SAARtB,M;AAQFuB,gBAAAA,C,GAAInE,UAAU,CAACC,IAAD,C;AACZmE,gBAAAA,O,GAAYD,CAAC,CAACpD,eAAF,CAAkBiC,KAAlB,CAAwBkB,IAAxB,EAA8BjB,M,CAA1CmB,O;AACFC,gBAAAA,c,GAAiB,IAAIjE,oBAAJ,GACpBC,SADoB,CACVH,EADU,EAEpBoE,MAFoB,CAEb,KAFa,EAEN;AAAEC,kBAAAA,SAAS,EAAE,IAAb;AAAmB5D,kBAAAA,MAAM,EAAEyD;AAA3B,iBAFM,EAGpB3D,MAHoB,CAGb,OAHa,EAIpBA,MAJoB,CAIb,SAJa,C;AAKjB+D,gBAAAA,iB,GAAoB,IAAIpE,oBAAJ,GACvBC,SADuB,CACbH,EADa,EAEvBgB,IAFuB,CAElBkD,OAFkB,EAGvB5D,MAHuB,CAGhB,aAHgB,C;AAIpBiE,gBAAAA,c,GAAiB,E;;AACjBC,gBAAAA,W;;;;;4CAAc,kBAAOC,aAAP;AAAA;;AAAA;AAAA;AAAA;AAAA;AACdC,4BAAAA,MADc,GACLD,aADK;;AAAA,kCAEdC,MAAM,IAAIV,IAAI,CAACvD,MAFD;AAAA;AAAA;AAAA;;AAAA,kCAEe,IAAImB,KAAJ,CAAU,8BAAV,CAFf;;AAAA;AAGZiB,4BAAAA,GAHY,GAGNoB,CAAC,CAACnD,UAAF,CAAagC,KAAb,CAAmBkB,IAAI,CAACX,KAAL,CAAWqB,MAAX,CAAnB,CAHM;AAAA,0CAIU7B,GAAG,CAACE,MAJd,EAIVjC,UAJU,eAIVA,UAJU,EAIE6D,GAJF,eAIEA,GAJF;AAKlBD,4BAAAA,MAAM,IAAI7B,GAAG,CAAC6B,MAAd;AALkB;AAAA,mCAMZ,2BAAgBzC,WAAhB,CANY;;AAAA;AAAA,iCAOdnB,UAPc;AAAA;AAAA;AAAA;;AAQhB,iCAAS8D,CAAT,GAAa,CAAb,EAAgBA,CAAC,GAAGD,GAApB,EAAyBC,CAAC,IAAI,CAA9B,EAAiC;AACzBC,8BAAAA,OADyB,GACfV,cAAc,CAACrB,KAAf,CAAqBkB,IAAI,CAACX,KAAL,CAAWqB,MAAX,CAArB,CADe;AAE/BA,8BAAAA,MAAM,IAAIG,OAAO,CAACH,MAAlB;AAF+B,gDAGCG,OAAO,CAAC9B,MAHT,EAGvB+B,IAHuB,mBAGvBA,GAHuB,EAGlBC,KAHkB,mBAGlBA,KAHkB,EAGXC,OAHW,mBAGXA,OAHW;AAIzBC,8BAAAA,MAJyB,GAIhB;AAAEpF,gCAAAA,IAAI,EAAEiF,IAAR;AAAaI,gCAAAA,EAAE,EAAEH,KAAjB;AAAwBtE,gCAAAA,MAAM,EAAEuE;AAAhC,+BAJgB;AAK/BnB,8BAAAA,UAAU,CAAC,KAAI,CAACzC,aAAL,CAAmB0D,IAAnB,CAAD,CAAV,GAAsCC,KAAtC;AACAnB,8BAAAA,YAAY,CAACmB,KAAD,CAAZ,GAAsBE,MAAtB;AACD;;AAfe;AAAA;;AAAA;AAiBhB;AACME,4BAAAA,SAlBU,GAkBE,EAlBF;;AAmBhB,iCAASP,EAAT,GAAa,CAAb,EAAgBA,EAAC,GAAGD,GAApB,EAAyBC,EAAC,IAAI,CAA9B,EAAiC;AACzBQ,8BAAAA,UADyB,GACZd,iBAAiB,CAACxB,KAAlB,CAAwBkB,IAAI,CAACX,KAAL,CAAWqB,MAAX,CAAxB,CADY;AAEzBW,8BAAAA,WAFyB,GAETD,UAAU,CAACrC,MAFF,CAEzBsC,WAFyB;AAG/BX,8BAAAA,MAAM,IAAIU,UAAU,CAACV,MAArB;AACAW,8BAAAA,WAAW,IAAIvB,eAAf;AACAqB,8BAAAA,SAAS,CAACG,IAAV,CAAed,WAAW,CAACa,WAAD,CAA1B;AACD;;AAzBe;AAAA,mCA0BVE,OAAO,CAACC,GAAR,CAAYL,SAAZ,CA1BU;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mB;;kCAAdX,W;;;;;;uBA6BAA,WAAW,CAACD,cAAD,C;;;kDACV;AACLV,kBAAAA,UAAU,EAAVA,UADK;AAELD,kBAAAA,YAAY,EAAZA;AAFK,iB;;;;;;;;;;;;;;;;AAMT;;;;;;;;;;kDAIgC3B,W;;;;;;;;uBAQpB,KAAKJ,SAAL,CAAeI,WAAf,C;;;;AANRwD,gBAAAA,mB,SAAAA,mB;AACAC,gBAAAA,U,SAAAA,U;AACA7B,gBAAAA,U,SAAAA,U;AACA8B,gBAAAA,iB,SAAAA,iB;AACAhD,gBAAAA,W,SAAAA,W;AACAK,gBAAAA,Q,SAAAA,Q;AAEI4C,gBAAAA,G,GAAMF,UAAU,CAAC,CAAD,C;AAChBG,gBAAAA,M,GAASD,GAAG,GAAGA,GAAG,CAACE,UAAJ,GAAiBL,mBAApB,GAA0C,I;kDACrD,IAAIM,oBAAJ,CACL,KAAKtE,GADA,EAELoC,UAFK,EAGL4B,mBAHK,EAILI,MAJK,EAKLlD,WALK,EAMLgD,iBAAiB,GAAG,CANf,EAOL3C,QAPK,C;;;;;;;;;;;;;;;;AAWT;;;;;;;AAKA;;;;;;;;;;;kDASEgD,O,EACAC,K,EACAC,G;;;;;;;;;AACAC,gBAAAA,I,8DAAwE;AAAEC,kBAAAA,KAAK,EAAE;AAAT,iB;;uBAElE,KAAKvE,SAAL,CAAesE,IAAI,CAAChH,MAApB,C;;;AACAkH,gBAAAA,O,GAAU,KAAKjF,aAAL,CAAmB4E,OAAnB,C;;qBAGZG,IAAI,CAACG,Y;;;;;;uBACM,KAAKC,OAAL,CAAa,IAAIJ,IAAI,CAACG,YAAtB,EAAoCH,IAAI,CAAChH,MAAzC,C;;;AAAbqH,gBAAAA,I;;;;;qBACSL,IAAI,CAACC,K;;;;;;uBACD,KAAKG,OAAL,CAAaJ,IAAI,CAACC,KAAlB,EAAyBD,IAAI,CAAChH,MAA9B,C;;;AAAbqH,gBAAAA,I;;;;;;uBAEa,KAAKD,OAAL,CAAa,CAAb,EAAgBJ,IAAI,CAAChH,MAArB,C;;;AAAbqH,gBAAAA,I;;;oBAGGA,I;;;;;sBACG,IAAI5E,KAAJ,CAAU,mCAAV,C;;;kDAED,IAAI6E,gBAAJ,CAAe,UAACC,QAAD,EAAyC;AAC7DF,kBAAAA,IAAI,CAACG,WAAL,CAAiBN,OAAjB,EAA0BJ,KAA1B,EAAiCC,GAAjC,EAAsCQ,QAAtC,EAAgDP,IAAhD;AACD,iBAFM,C;;;;;;;;;;;;;;;;;;;;;kDAMPH,O,EACAC,K,EACAC,G;;;;;;;;;AACAC,gBAAAA,I,8DAAwE;AAAEC,kBAAAA,KAAK,EAAE;AAAT,iB;;uBAEvD,KAAKQ,gBAAL,CAAsBZ,OAAtB,EAA+BC,KAA/B,EAAsCC,GAAtC,EAA2CC,IAA3C,C;;;AAAXU,gBAAAA,E;;uBACYA,EAAE,CAACC,IAAH,CAAQ,uBAAO,UAACC,GAAD,EAAiBC,IAAjB;AAAA,yBAAgDD,GAAG,CAACE,MAAJ,CAAWD,IAAX,CAAhD;AAAA,iBAAP,CAAR,EAAkFE,SAAlF,E;;;AAAZrE,gBAAAA,G;kDACCA,GAAG,IAAI,E","sourcesContent":["import { Parser } from '@gmod/binary-parser'\nimport { LocalFile, RemoteFile, GenericFilehandle } from 'generic-filehandle'\nimport { Observable, Observer } from 'rxjs'\nimport { reduce } from 'rxjs/operators'\n\nimport { BlockView } from './blockView'\nimport { abortBreakPoint, AbortError } from './util'\n\nconst BIG_WIG_MAGIC = -2003829722\nconst BIG_BED_MAGIC = -2021002517\n\nexport interface Feature {\n  start: number\n  end: number\n  score: number\n  rest?: string // for bigbed line\n  minScore?: number // for summary line\n  maxScore?: number // for summary line\n  summary?: boolean // is summary line\n  uniqueId?: string // for bigbed contains uniqueId calculated from file offset\n  field?: number // used in bigbed searching\n}\ninterface Statistics {\n  scoreSum: number\n  basesCovered: number\n  scoreSumSquares: number\n}\n\ninterface RefInfo {\n  name: string\n  id: number\n  length: number\n}\nexport interface Header {\n  autoSql: string\n  totalSummary: Statistics\n  zoomLevels: any\n  unzoomedIndexOffset: number\n  unzoomedDataOffset: number\n  definedFieldCount: number\n  uncompressBufSize: number\n  chromTreeOffset: number\n  fileSize: number\n  extHeaderOffset: number\n  isBigEndian: boolean\n  fileType: string\n  refsByName: { [key: string]: number }\n  refsByNumber: { [key: number]: RefInfo }\n}\n\ntype AbortableCallback = (signal: AbortSignal) => Promise<any>\n\n/* A class that provides memoization for abortable calls */\nclass AbortAwareCache {\n  private cache: Map<AbortableCallback, any> = new Map()\n\n  /*\n   * Takes a function that has one argument, abortSignal, that returns a promise\n   * and it works by retrying the function if a previous attempt to initialize the parse cache was aborted\n   * @param fn - an AbortableCallback\n   * @return a memoized version of the AbortableCallback using the AbortAwareCache\n   */\n  public abortableMemoize(fn: (signal?: AbortSignal) => Promise<any>): (signal?: AbortSignal) => Promise<any> {\n    const { cache } = this\n    return function abortableMemoizeFn(signal?: AbortSignal): Promise<any> {\n      if (!cache.has(fn)) {\n        const fnReturn = fn(signal)\n        cache.set(fn, fnReturn)\n        if (signal) {\n          fnReturn.catch((): void => {\n            if (signal.aborted) cache.delete(fn)\n          })\n        }\n        return cache.get(fn)\n      }\n      return cache.get(fn).catch(\n        (e: AbortError | DOMException): Promise<any> => {\n          if (e.code === 'ERR_ABORTED' || e.name === 'AbortError') {\n            return fn(signal)\n          }\n          throw e\n        },\n      )\n    }\n  }\n}\n\n/* get the compiled parsers for different sections of the bigwig file\n *\n * @param isBE - is big endian, typically false\n * @return an object with compiled parsers\n */\nfunction getParsers(isBE: boolean): any {\n  const le = isBE ? 'big' : 'little'\n  const headerParser = new Parser()\n    .endianess(le)\n    .int32('magic')\n    .uint16('version')\n    .uint16('numZoomLevels')\n    .uint64('chromTreeOffset')\n    .uint64('unzoomedDataOffset')\n    .uint64('unzoomedIndexOffset')\n    .uint16('fieldCount')\n    .uint16('definedFieldCount')\n    .uint64('asOffset') // autoSql offset, used in bigbed\n    .uint64('totalSummaryOffset')\n    .uint32('uncompressBufSize')\n    .uint64('extHeaderOffset') // name index offset, used in bigbed\n    .array('zoomLevels', {\n      length: 'numZoomLevels',\n      type: new Parser()\n        .uint32('reductionLevel')\n        .uint32('reserved')\n        .uint64('dataOffset')\n        .uint64('indexOffset'),\n    })\n\n  const totalSummaryParser = new Parser()\n    .endianess(le)\n    .uint64('basesCovered')\n    .double('scoreMin')\n    .double('scoreMax')\n    .double('scoreSum')\n    .double('scoreSumSquares')\n\n  const chromTreeParser = new Parser()\n    .endianess(le)\n    .uint32('magic')\n    .uint32('blockSize')\n    .uint32('keySize')\n    .uint32('valSize')\n    .uint64('itemCount')\n\n  const isLeafNode = new Parser()\n    .endianess(le)\n    .uint8('isLeafNode')\n    .skip(1)\n    .uint16('cnt')\n\n  return {\n    chromTreeParser,\n    totalSummaryParser,\n    headerParser,\n    isLeafNode,\n  }\n}\n\nexport abstract class BBI {\n  protected bbi: GenericFilehandle\n\n  protected headerCache: AbortAwareCache\n\n  protected renameRefSeqs: (a: string) => string\n\n  /* fetch and parse header information from a bigwig or bigbed file\n   * @param abortSignal - abort the operation, can be null\n   * @return a Header object\n   */\n  public getHeader: (abortSignal?: AbortSignal) => Promise<Header>\n\n  /*\n   * @param filehandle - a filehandle from generic-filehandle or implementing something similar to the node10 fs.promises API\n   * @param path - a Local file path as a string\n   * @param url - a URL string\n   * @param renameRefSeqs - an optional method to rename the internal reference sequences using a mapping function\n   */\n  public constructor(\n    options: {\n      filehandle?: GenericFilehandle\n      path?: string\n      url?: string\n      renameRefSeqs?: (a: string) => string\n    } = {},\n  ) {\n    const { filehandle, renameRefSeqs, path, url } = options\n    this.renameRefSeqs = renameRefSeqs || ((s: string): string => s)\n    this.headerCache = new AbortAwareCache()\n    if (filehandle) {\n      this.bbi = filehandle\n    } else if (url) {\n      this.bbi = new RemoteFile(url)\n    } else if (path) {\n      this.bbi = new LocalFile(path)\n    } else {\n      throw new Error('no file given')\n    }\n    this.getHeader = this.headerCache.abortableMemoize(this._getHeader.bind(this))\n  }\n\n  private async _getHeader(abortSignal?: AbortSignal) {\n    const header = await this._getMainHeader(abortSignal)\n    const chroms = await this._readChromTree(header, abortSignal)\n    return { ...header, ...chroms }\n  }\n\n  private async _getMainHeader(abortSignal?: AbortSignal, requestSize = 2000): Promise<Header> {\n    const { buffer } = await this.bbi.read(Buffer.alloc(requestSize), 0, requestSize, 0, { signal: abortSignal })\n    const isBigEndian = this._isBigEndian(buffer)\n    const ret = getParsers(isBigEndian)\n    const header = ret.headerParser.parse(buffer).result\n    header.fileType = header.magic === BIG_BED_MAGIC ? 'bigbed' : 'bigwig'\n    if (header.asOffset > requestSize || header.totalSummaryOffset > requestSize) {\n      return this._getMainHeader(abortSignal, requestSize * 2)\n    }\n    if (header.asOffset) {\n      header.autoSql = buffer.slice(header.asOffset, buffer.indexOf(0, header.asOffset)).toString('utf8')\n    }\n    if (header.totalSummaryOffset > requestSize) {\n      return this._getMainHeader(abortSignal, requestSize * 2)\n    }\n    if (header.totalSummaryOffset) {\n      const tail = buffer.slice(header.totalSummaryOffset)\n      header.totalSummary = ret.totalSummaryParser.parse(tail).result\n    }\n    return { ...header, isBigEndian }\n  }\n\n  private _isBigEndian(buffer: Buffer): boolean {\n    let ret = buffer.readInt32LE(0)\n    if (ret === BIG_WIG_MAGIC || ret === BIG_BED_MAGIC) {\n      return false\n    }\n    ret = buffer.readInt32BE(0)\n    if (ret === BIG_WIG_MAGIC || ret === BIG_BED_MAGIC) {\n      return true\n    }\n    throw new Error('not a BigWig/BigBed file')\n  }\n\n  // todo: add progress if long running\n  private async _readChromTree(header: Header, abortSignal?: AbortSignal) {\n    const isBE = header.isBigEndian\n    const le = isBE ? 'big' : 'little'\n    const refsByNumber: { [key: number]: { name: string; id: number; length: number } } = []\n    const refsByName: { [key: string]: number } = {}\n    const { chromTreeOffset } = header\n    let { unzoomedDataOffset } = header\n\n    while (unzoomedDataOffset % 4 !== 0) {\n      unzoomedDataOffset += 1\n    }\n\n    const { buffer: data } = await this.bbi.read(\n      Buffer.alloc(unzoomedDataOffset - chromTreeOffset),\n      0,\n      unzoomedDataOffset - chromTreeOffset,\n      chromTreeOffset,\n      { signal: abortSignal },\n    )\n\n    const p = getParsers(isBE)\n    const { keySize } = p.chromTreeParser.parse(data).result\n    const leafNodeParser = new Parser()\n      .endianess(le)\n      .string('key', { stripNull: true, length: keySize })\n      .uint32('refId')\n      .uint32('refSize')\n    const nonleafNodeParser = new Parser()\n      .endianess(le)\n      .skip(keySize)\n      .uint64('childOffset')\n    const rootNodeOffset = 32\n    const bptReadNode = async (currentOffset: number): Promise<void> => {\n      let offset = currentOffset\n      if (offset >= data.length) throw new Error('reading beyond end of buffer')\n      const ret = p.isLeafNode.parse(data.slice(offset))\n      const { isLeafNode, cnt } = ret.result\n      offset += ret.offset\n      await abortBreakPoint(abortSignal)\n      if (isLeafNode) {\n        for (let n = 0; n < cnt; n += 1) {\n          const leafRet = leafNodeParser.parse(data.slice(offset))\n          offset += leafRet.offset\n          const { key, refId, refSize } = leafRet.result\n          const refRec = { name: key, id: refId, length: refSize }\n          refsByName[this.renameRefSeqs(key)] = refId\n          refsByNumber[refId] = refRec\n        }\n      } else {\n        // parse index node\n        const nextNodes = []\n        for (let n = 0; n < cnt; n += 1) {\n          const nonleafRet = nonleafNodeParser.parse(data.slice(offset))\n          let { childOffset } = nonleafRet.result\n          offset += nonleafRet.offset\n          childOffset -= chromTreeOffset\n          nextNodes.push(bptReadNode(childOffset))\n        }\n        await Promise.all(nextNodes)\n      }\n    }\n    await bptReadNode(rootNodeOffset)\n    return {\n      refsByName,\n      refsByNumber,\n    }\n  }\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  protected async getUnzoomedView(abortSignal?: AbortSignal): Promise<BlockView> {\n    const {\n      unzoomedIndexOffset,\n      zoomLevels,\n      refsByName,\n      uncompressBufSize,\n      isBigEndian,\n      fileType,\n    } = await this.getHeader(abortSignal)\n    const nzl = zoomLevels[0]\n    const cirLen = nzl ? nzl.dataOffset - unzoomedIndexOffset : 4000\n    return new BlockView(\n      this.bbi,\n      refsByName,\n      unzoomedIndexOffset,\n      cirLen,\n      isBigEndian,\n      uncompressBufSize > 0,\n      fileType,\n    )\n  }\n\n  /*\n   * abstract method - get the view for a given scale\n   */\n  protected abstract async getView(scale: number, abortSignal?: AbortSignal): Promise<BlockView>\n\n  /**\n   * Gets features from a BigWig file\n   *\n   * @param refName - The chromosome name\n   * @param start - The start of a region\n   * @param end - The end of a region\n   * @param opts - An object containing basesPerSpan (e.g. pixels per basepair) or scale used to infer the zoomLevel to use\n   */\n  public async getFeatureStream(\n    refName: string,\n    start: number,\n    end: number,\n    opts: { basesPerSpan?: number; scale?: number; signal?: AbortSignal } = { scale: 1 },\n  ): Promise<Observable<Feature[]>> {\n    await this.getHeader(opts.signal)\n    const chrName = this.renameRefSeqs(refName)\n    let view: BlockView\n\n    if (opts.basesPerSpan) {\n      view = await this.getView(1 / opts.basesPerSpan, opts.signal)\n    } else if (opts.scale) {\n      view = await this.getView(opts.scale, opts.signal)\n    } else {\n      view = await this.getView(1, opts.signal)\n    }\n\n    if (!view) {\n      throw new Error('unable to get block view for data')\n    }\n    return new Observable((observer: Observer<Feature[]>): void => {\n      view.readWigData(chrName, start, end, observer, opts)\n    })\n  }\n\n  public async getFeatures(\n    refName: string,\n    start: number,\n    end: number,\n    opts: { basesPerSpan?: number; scale?: number; signal?: AbortSignal } = { scale: 1 },\n  ): Promise<Feature[]> {\n    const ob = await this.getFeatureStream(refName, start, end, opts)\n    const ret = await ob.pipe(reduce((acc: Feature[], curr: Feature[]): Feature[] => acc.concat(curr))).toPromise()\n    return ret || []\n  }\n}\n"]}

@@ -41,3 +41,3 @@ "use strict";

function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }

@@ -44,0 +44,0 @@ function filterUndef(ts) {

@@ -34,3 +34,3 @@ "use strict";

function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }

@@ -37,0 +37,0 @@ var BIG_WIG_TYPE_GRAPH = 1;

{
"name": "@gmod/bbi",
"version": "1.0.27",
"version": "1.0.28",
"description": "Parser for BigWig/BigBed files",

@@ -5,0 +5,0 @@ "license": "MIT",

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc