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

@datagrok-libraries/chem-meta

Package Overview
Dependencies
Maintainers
3
Versions
28
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@datagrok-libraries/chem-meta - npm Package Compare versions

Comparing version 1.0.6 to 1.0.7

2

package.json

@@ -7,3 +7,3 @@ {

"friendlyName": "Datagrok chem-meta library",
"version": "1.0.6",
"version": "1.0.7",
"description": "",

@@ -10,0 +10,0 @@ "dependencies": {

@@ -8,2 +8,3 @@ export interface ChemicalTableParser {

z: Float32Array;
pairsOfBondedAtoms: Uint16Array[];
}

@@ -22,3 +23,11 @@ export declare type AtomAndBondCounts = {

protected constructor(file: string);
protected static instance: ChemicalTableParserBase;
protected file: string;
protected _atomCount?: number;
protected _bondCount?: number;
protected xyzAtomCoordinates?: CoordinateArrays;
protected _atomTypes?: string[];
protected _pairsOfBondedAtoms?: Uint16Array[];
init(file: string): void;
/** Total number of atoms in a molecule */
get atomCount(): number;

@@ -34,41 +43,24 @@ /** Number of bonds in a molecule */

get atomTypes(): string[];
protected file: string;
/** Index running along the string/file being parsed */
protected _atomCount?: number;
protected _bondCount?: number;
/** The array of X, Y, Z arrays for atomic coordinates */
protected atomCoordinates?: CoordinateArrays;
protected _atomTypes?: string[];
get pairsOfBondedAtoms(): Uint16Array[];
protected abstract parseAtomAndBondCounts(): AtomAndBondCounts;
protected abstract getCountsLineIdx(): number;
/** Get idx of the first line of the atom block containing atom data */
protected abstract getAtomBlockIdx(): number;
/** Get idx of the first line of the bond block containing bond data */
protected abstract getBondBlockIdx(): number;
/** Shift idx from the beginning of the line to X coordinate */
protected abstract shiftIdxToXColumn(lineStartIdx: number): number;
/** Shift idx from the beginning of the line to atom type column */
protected abstract shiftIdxToAtomType(lineStartIdx: number): number;
/** Parse atom type at idx */
protected abstract shiftIdxToBondedAtomsPair(lineStartIdx: number): number;
protected abstract parseAtomType(idx: number): string;
protected setAtomAndBondCounts(): void;
/** Gets the idx of the next column relatively to this._currentIdx */
protected getNextColumnIdx(idx: number): number;
/** Shift idx from beginning of the specified line to the specified column */
protected shiftToSpecifiedColumn(lineStartIdx: number, columnNumber: number): number;
protected shiftIdxToSpecifiedColumn(lineStartIdx: number, columnNumber: number): number;
protected parseAtomTypes(): string[];
protected parseAtomCoordinates(): CoordinateArrays;
/** Check if a character is whitespace including '\t' */
protected parseBondedAtomPairs(): Uint16Array[];
protected isWhitespace(idx: number): boolean;
/** Get index of the next line starting from idx */
protected getNextLineIdx(idx: number): number;
/** Get a float value in the current column (at idx) */
protected parseFloatValue(idx: number): number;
/** Get an int value in the current column (at idx) */
protected parseIntValue(idx: number): number;
/** Parse a numeric value depending on the functional argument */
protected parseNumericValue(parserFunction: (str: string) => number, idx: number): number;
protected static instance: ChemicalTableParserBase;
protected parseFloatValue(idxOfNumber: number): number;
protected parseIntValue(idxOfNumber: number): number;
protected parseNumericValue(parserFunction: (str: string) => number, idxOfNumber: number): number;
}
export {};
//# sourceMappingURL=chemical-table-parser.d.ts.map

@@ -7,4 +7,2 @@ /** Base singleton for Molfile or Mol2 parser/handler */

;
// Public members
// public abstract static createInstance(file: string): ChemicalTableParserBase;
init(file) {

@@ -15,4 +13,6 @@ this.file = file.replace(/\r/g, '');

this._bondCount = undefined;
this.atomCoordinates = undefined;
this.xyzAtomCoordinates = undefined;
this._pairsOfBondedAtoms = undefined;
}
/** Total number of atoms in a molecule */
get atomCount() {

@@ -31,5 +31,5 @@ if (this._atomCount === undefined)

get x() {
if (this.atomCoordinates === undefined)
this.atomCoordinates = this.parseAtomCoordinates();
return this.atomCoordinates.x;
if (this.xyzAtomCoordinates === undefined)
this.xyzAtomCoordinates = this.parseAtomCoordinates();
return this.xyzAtomCoordinates.x;
}

@@ -39,5 +39,5 @@ ;

get y() {
if (this.atomCoordinates === undefined)
this.atomCoordinates = this.parseAtomCoordinates();
return this.atomCoordinates.y;
if (this.xyzAtomCoordinates === undefined)
this.xyzAtomCoordinates = this.parseAtomCoordinates();
return this.xyzAtomCoordinates.y;
}

@@ -47,5 +47,5 @@ ;

get z() {
if (this.atomCoordinates === undefined)
this.atomCoordinates = this.parseAtomCoordinates();
return this.atomCoordinates.z;
if (this.xyzAtomCoordinates === undefined)
this.xyzAtomCoordinates = this.parseAtomCoordinates();
return this.xyzAtomCoordinates.z;
}

@@ -58,2 +58,7 @@ ;

}
get pairsOfBondedAtoms() {
if (this._pairsOfBondedAtoms === undefined)
this._pairsOfBondedAtoms = this.parseBondedAtomPairs();
return this._pairsOfBondedAtoms;
}
setAtomAndBondCounts() {

@@ -64,3 +69,2 @@ const { atomCount, bondCount } = this.parseAtomAndBondCounts();

}
/** Gets the idx of the next column relatively to this._currentIdx */
getNextColumnIdx(idx) {

@@ -75,6 +79,6 @@ // skip non-whitespace, if necessary

}
/** Shift idx from beginning of the specified line to the specified column */
shiftToSpecifiedColumn(lineStartIdx, columnNumber) {
shiftIdxToSpecifiedColumn(lineStartIdx, columnNumber) {
let idx = lineStartIdx;
for (let i = 0; i < columnNumber; i++)
const numberOfJumps = this.isWhitespace(idx) ? columnNumber : columnNumber - 1;
for (let i = 0; i < numberOfJumps; i++)
idx = this.getNextColumnIdx(idx);

@@ -110,7 +114,19 @@ return idx;

}
/** Check if a character is whitespace including '\t' */
parseBondedAtomPairs() {
const bondedAtomPairs = new Array(this.bondCount);
let idx = this.getBondBlockIdx();
for (let i = 0; i < this.bondCount; i++) {
idx = this.shiftIdxToBondedAtomsPair(idx);
const pair = new Uint16Array(2);
pair[0] = this.parseIntValue(idx);
idx = this.getNextColumnIdx(idx);
pair[1] = this.parseIntValue(idx);
bondedAtomPairs[i] = pair;
idx = this.getNextLineIdx(idx);
}
return bondedAtomPairs;
}
isWhitespace(idx) {
return /\s/.test(this.file.at(idx));
}
/** Get index of the next line starting from idx */
getNextLineIdx(idx) {

@@ -122,19 +138,16 @@ if (this.file.at(idx) !== '\n')

}
/** Get a float value in the current column (at idx) */
parseFloatValue(idx) {
return this.parseNumericValue(parseFloat, idx);
parseFloatValue(idxOfNumber) {
return this.parseNumericValue(parseFloat, idxOfNumber);
}
/** Get an int value in the current column (at idx) */
parseIntValue(idx) {
return this.parseNumericValue(parseInt, idx);
parseIntValue(idxOfNumber) {
return this.parseNumericValue(parseInt, idxOfNumber);
}
/** Parse a numeric value depending on the functional argument */
parseNumericValue(parserFunction, idx) {
let end = idx + 1;
parseNumericValue(parserFunction, idxOfNumber) {
let end = idxOfNumber + 1;
while (!this.isWhitespace(end))
++end;
const value = parserFunction(this.file.substring(idx, end));
const value = parserFunction(this.file.substring(idxOfNumber, end));
return value;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chemical-table-parser.js","sourceRoot":"","sources":["chemical-table-parser.ts"],"names":[],"mappings":"AAoBA,wDAAwD;AACxD,MAAM,OAAgB,uBAAuB;IAC3C,YAAsB,IAAY;QAChC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAAA,CAAC;IAEF,iBAAiB;IAEjB,gFAAgF;IAEzE,IAAI,CAAC,IAAY;QACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACpC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;IACnC,CAAC;IAED,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAC/B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,UAAW,CAAC;IAC1B,CAAC;IAED,qCAAqC;IACrC,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAC/B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,UAAW,CAAC;IAC1B,CAAC;IAED,gDAAgD;IAChD,IAAI,CAAC;QACH,IAAI,IAAI,CAAC,eAAe,KAAK,SAAS;YACpC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACrD,OAAO,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;IAChC,CAAC;IAAA,CAAC;IAEF,gDAAgD;IAChD,IAAI,CAAC;QACH,IAAI,IAAI,CAAC,eAAe,KAAK,SAAS;YACpC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACrD,OAAO,IAAI,CAAC,eAAgB,CAAC,CAAC,CAAC;IACjC,CAAC;IAAA,CAAC;IAEF,gDAAgD;IAChD,IAAI,CAAC;QACH,IAAI,IAAI,CAAC,eAAe,KAAK,SAAS;YACpC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACrD,OAAO,IAAI,CAAC,eAAgB,CAAC,CAAC,CAAC;IACjC,CAAC;IAAA,CAAC;IAEF,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAC/B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAC1C,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAyBS,oBAAoB;QAC5B,MAAM,EAAC,SAAS,EAAE,SAAS,EAAC,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC7D,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAC9B,CAAC;IAED,qEAAqE;IAC3D,gBAAgB,CAAC,GAAW;QACpC,oCAAoC;QACpC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;YAC5B,EAAE,GAAG,CAAC;QACR,kBAAkB;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;YAC3B,EAAE,GAAG,CAAC;QACR,OAAO,GAAG,CAAC;IACb,CAAC;IAED,8EAA8E;IACpE,sBAAsB,CAAC,YAAoB,EAAE,YAAoB;QACzE,IAAI,GAAG,GAAG,YAAY,CAAC;QACvB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,YAAY,EAAE,CAAC,EAAE;YACnC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;QACnC,OAAO,GAAG,CAAC;IACb,CAAC;IAES,cAAc;QACtB,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACjC,MAAM,SAAS,GAAG,IAAI,KAAK,CAAS,SAAS,CAAC,CAAC;QAC/C,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;YAClC,GAAG,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;YACnC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YACvC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;SAChC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAAA,CAAC;IAEQ,oBAAoB;QAC5B,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;YACvC,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;YAClC,KAAK,MAAM,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE;gBAC5B,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;gBACpC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;aAClC;YACD,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;SAChC;QACD,OAAO,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,CAAC;IAC5B,CAAC;IAED,yDAAyD;IAC/C,YAAY,CAAC,GAAW;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAE,CAAC,CAAC;IACvC,CAAC;IAED,oDAAoD;IAC1C,cAAc,CAAC,GAAW;QAClC,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,IAAI;YAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;;YAExC,OAAO,GAAG,GAAG,CAAC,CAAC;IACnB,CAAC;IAED,uDAAuD;IAC7C,eAAe,CAAC,GAAW;QACnC,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;IACjD,CAAC;IAED,sDAAsD;IAC5C,aAAa,CAAC,GAAW;QACjC,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IAC/C,CAAC;IAED,kEAAkE;IACxD,iBAAiB,CACzB,cAAuC,EACvC,GAAW;QAEX,IAAI,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC;QAClB,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;YAC5B,EAAE,GAAG,CAAC;QACR,MAAM,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAC5D,OAAO,KAAK,CAAC;IACf,CAAC;CAGF","sourcesContent":["export interface ChemicalTableParser {\n  init(file: string): void;\n  atomCount: number;\n  bondCount: number;\n  x: Float32Array;\n  y: Float32Array;\n  z: Float32Array;\n}\n\nexport type AtomAndBondCounts = {\n  atomCount: number,\n  bondCount: number\n}\n\ntype CoordinateArrays = {\n  x: Float32Array,\n  y: Float32Array,\n  z: Float32Array,\n}\n\n/** Base singleton for Molfile or Mol2 parser/handler */\nexport abstract class ChemicalTableParserBase implements ChemicalTableParser {\n  protected constructor(file: string) {\n    this.init(file);\n  };\n\n  // Public members\n\n  // public abstract static createInstance(file: string): ChemicalTableParserBase;\n\n  public init(file: string): void {\n    this.file = file.replace(/\\r/g, '');\n    this._atomCount = undefined;\n    this._atomTypes = undefined;\n    this._bondCount = undefined;\n    this.atomCoordinates = undefined;\n  }\n\n  get atomCount(): number {\n    if (this._atomCount === undefined)\n      this.setAtomAndBondCounts();\n    return this._atomCount!;\n  }\n\n  /** Number of bonds in a molecule  */\n  get bondCount(): number {\n    if (this._bondCount === undefined)\n      this.setAtomAndBondCounts();\n    return this._bondCount!;\n  }\n\n  /** X coordinates of all atoms in a molecule  */\n  get x(): Float32Array {\n    if (this.atomCoordinates === undefined)\n      this.atomCoordinates = this.parseAtomCoordinates();\n    return this.atomCoordinates.x;\n  };\n\n  /** Y coordinates of all atoms in a molecule  */\n  get y(): Float32Array {\n    if (this.atomCoordinates === undefined)\n      this.atomCoordinates = this.parseAtomCoordinates();\n    return this.atomCoordinates!.y;\n  };\n\n  /** Z coordinates of all atoms in a molecule  */\n  get z(): Float32Array {\n    if (this.atomCoordinates === undefined)\n      this.atomCoordinates = this.parseAtomCoordinates();\n    return this.atomCoordinates!.z;\n  };\n\n  get atomTypes(): string[] {\n    if (this._atomTypes === undefined)\n      this._atomTypes = this.parseAtomTypes();\n    return this._atomTypes;\n  }\n\n  // Protected members\n\n  protected file!: string;\n  /** Index running along the string/file being parsed  */\n  protected _atomCount?: number;\n  protected _bondCount?: number;\n  /** The array of X, Y, Z arrays for atomic coordinates */\n  protected atomCoordinates?: CoordinateArrays;\n  protected _atomTypes?: string[];\n\n  protected abstract parseAtomAndBondCounts(): AtomAndBondCounts;\n  protected abstract getCountsLineIdx(): number;\n  /** Get idx of the first line of the atom block containing atom data  */\n  protected abstract getAtomBlockIdx(): number;\n  /** Get idx of the first line of the bond block containing bond data */\n  protected abstract getBondBlockIdx(): number;\n  /** Shift idx from the beginning of the line to X coordinate */\n  protected abstract shiftIdxToXColumn(lineStartIdx: number): number;\n  /** Shift idx from the beginning of the line to atom type column */\n  protected abstract shiftIdxToAtomType(lineStartIdx: number): number;\n  /** Parse atom type at idx */\n  protected abstract parseAtomType(idx: number): string;\n\n  protected setAtomAndBondCounts(): void {\n    const {atomCount, bondCount} = this.parseAtomAndBondCounts();\n    this._atomCount = atomCount;\n    this._bondCount = bondCount;\n  }\n\n  /** Gets the idx of the next column relatively to this._currentIdx */\n  protected getNextColumnIdx(idx: number): number {\n    // skip non-whitespace, if necessary\n    while (!this.isWhitespace(idx))\n      ++idx;\n    // skip whitespace\n    while (this.isWhitespace(idx))\n      ++idx;\n    return idx;\n  }\n\n  /** Shift idx from beginning of the specified line to the specified column  */\n  protected shiftToSpecifiedColumn(lineStartIdx: number, columnNumber: number) {\n    let idx = lineStartIdx;\n    for (let i = 0; i < columnNumber; i++)\n      idx = this.getNextColumnIdx(idx);\n    return idx;\n  }\n\n  protected parseAtomTypes(): string[] {\n    const atomCount = this.atomCount;\n    const atomTypes = new Array<string>(atomCount);\n    let idx = this.getAtomBlockIdx();\n    for (let i = 0; i < atomCount; i++) {\n      idx = this.shiftIdxToAtomType(idx);\n      atomTypes[i] = this.parseAtomType(idx);\n      idx = this.getNextLineIdx(idx);\n    }\n    return atomTypes;\n  };\n\n  protected parseAtomCoordinates(): CoordinateArrays {\n    const x = new Float32Array(this.atomCount);\n    const y = new Float32Array(this.atomCount);\n    const z = new Float32Array(this.atomCount);\n    let idx = this.getAtomBlockIdx();\n    for (let i = 0; i < this.atomCount; i++) {\n      idx = this.shiftIdxToXColumn(idx);\n      for (const item of [x, y, z]) {\n        item[i] = this.parseFloatValue(idx);\n        idx = this.getNextColumnIdx(idx);\n      }\n      idx = this.getNextLineIdx(idx);\n    }\n    return {x: x, y: y, z: z};\n  }\n\n  /** Check if a character is whitespace including '\\t'  */\n  protected isWhitespace(idx: number): boolean {\n    return /\\s/.test(this.file.at(idx)!);\n  }\n\n  /** Get index of the next line starting from idx  */\n  protected getNextLineIdx(idx: number): number {\n    if (this.file.at(idx) !== '\\n')\n      return this.file.indexOf('\\n', idx) + 1;\n    else\n      return idx + 1;\n  }\n\n  /** Get a float value in the current column (at idx) */\n  protected parseFloatValue(idx: number): number {\n    return this.parseNumericValue(parseFloat, idx);\n  }\n\n  /** Get an int value in the current column (at idx) */\n  protected parseIntValue(idx: number): number {\n    return this.parseNumericValue(parseInt, idx);\n  }\n\n  /** Parse a numeric value depending on the functional argument  */\n  protected parseNumericValue(\n    parserFunction: (str: string) => number,\n    idx: number\n  ): number {\n    let end = idx + 1;\n    while (!this.isWhitespace(end))\n      ++end;\n    const value = parserFunction(this.file.substring(idx, end));\n    return value;\n  }\n\n  protected static instance: ChemicalTableParserBase;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chemical-table-parser.js","sourceRoot":"","sources":["chemical-table-parser.ts"],"names":[],"mappings":"AAqBA,wDAAwD;AACxD,MAAM,OAAgB,uBAAuB;IAC3C,YAAsB,IAAY;QAChC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAAA,CAAC;IAWK,IAAI,CAAC,IAAY;QACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACpC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,kBAAkB,GAAG,SAAS,CAAC;QACpC,IAAI,CAAC,mBAAmB,GAAG,SAAS,CAAC;IACvC,CAAC;IAED,0CAA0C;IAC1C,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAC/B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,UAAW,CAAC;IAC1B,CAAC;IAED,qCAAqC;IACrC,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAC/B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,OAAO,IAAI,CAAC,UAAW,CAAC;IAC1B,CAAC;IAED,gDAAgD;IAChD,IAAI,CAAC;QACH,IAAI,IAAI,CAAC,kBAAkB,KAAK,SAAS;YACvC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACxD,OAAO,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;IACnC,CAAC;IAAA,CAAC;IAEF,gDAAgD;IAChD,IAAI,CAAC;QACH,IAAI,IAAI,CAAC,kBAAkB,KAAK,SAAS;YACvC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACxD,OAAO,IAAI,CAAC,kBAAmB,CAAC,CAAC,CAAC;IACpC,CAAC;IAAA,CAAC;IAEF,gDAAgD;IAChD,IAAI,CAAC;QACH,IAAI,IAAI,CAAC,kBAAkB,KAAK,SAAS;YACvC,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACxD,OAAO,IAAI,CAAC,kBAAmB,CAAC,CAAC,CAAC;IACpC,CAAC;IAAA,CAAC;IAEF,IAAI,SAAS;QACX,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS;YAC/B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAC1C,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,kBAAkB;QACpB,IAAI,IAAI,CAAC,mBAAmB,KAAK,SAAS;YACxC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,oBAAoB,EAAE,CAAC;QACzD,OAAO,IAAI,CAAC,mBAAoB,CAAC;IACnC,CAAC;IAWS,oBAAoB;QAC5B,MAAM,EAAC,SAAS,EAAE,SAAS,EAAC,GAAG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC7D,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAC9B,CAAC;IAES,gBAAgB,CAAC,GAAW;QACpC,oCAAoC;QACpC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;YAC5B,EAAE,GAAG,CAAC;QACR,kBAAkB;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;YAC3B,EAAE,GAAG,CAAC;QACR,OAAO,GAAG,CAAC;IACb,CAAC;IAES,yBAAyB,CAAC,YAAoB,EAAE,YAAoB;QAC5E,IAAI,GAAG,GAAG,YAAY,CAAC;QACvB,MAAM,aAAa,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC;QAC/E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE;YACpC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;QACnC,OAAO,GAAG,CAAC;IACb,CAAC;IAES,cAAc;QACtB,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACjC,MAAM,SAAS,GAAG,IAAI,KAAK,CAAS,SAAS,CAAC,CAAC;QAC/C,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;YAClC,GAAG,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;YACnC,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YACvC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;SAChC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAAA,CAAC;IAEQ,oBAAoB;QAC5B,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,MAAM,CAAC,GAAG,IAAI,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC3C,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;YACvC,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;YAClC,KAAK,MAAM,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE;gBAC5B,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;gBACpC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;aAClC;YACD,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;SAChC;QACD,OAAO,EAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAC,CAAC;IAC5B,CAAC;IAES,oBAAoB;QAC5B,MAAM,eAAe,GAAG,IAAI,KAAK,CAAc,IAAI,CAAC,SAAS,CAAC,CAAC;QAC/D,IAAI,GAAG,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QACjC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;YACvC,GAAG,GAAG,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC;YAC1C,MAAM,IAAI,GAAG,IAAI,WAAW,CAAC,CAAC,CAAC,CAAC;YAChC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAClC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;YACjC,IAAI,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAClC,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;YAC1B,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;SAChC;QACD,OAAO,eAAe,CAAC;IACzB,CAAC;IAES,YAAY,CAAC,GAAW;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAE,CAAC,CAAC;IACvC,CAAC;IAES,cAAc,CAAC,GAAW;QAClC,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,KAAK,IAAI;YAC5B,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;;YAExC,OAAO,GAAG,GAAG,CAAC,CAAC;IACnB,CAAC;IAES,eAAe,CAAC,WAAmB;QAC3C,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;IACzD,CAAC;IAES,aAAa,CAAC,WAAmB;QACzC,OAAO,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,WAAW,CAAC,CAAC;IACvD,CAAC;IAES,iBAAiB,CACzB,cAAuC,EACvC,WAAmB;QAEnB,IAAI,GAAG,GAAG,WAAW,GAAG,CAAC,CAAC;QAC1B,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;YAC5B,EAAE,GAAG,CAAC;QACR,MAAM,KAAK,GAAG,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC,CAAC;QACpE,OAAO,KAAK,CAAC;IACf,CAAC;CACF","sourcesContent":["export interface ChemicalTableParser {\n  init(file: string): void;\n  atomCount: number;\n  bondCount: number;\n  x: Float32Array;\n  y: Float32Array;\n  z: Float32Array;\n  pairsOfBondedAtoms: Uint16Array[];\n}\n\nexport type AtomAndBondCounts = {\n  atomCount: number,\n  bondCount: number\n}\n\ntype CoordinateArrays = {\n  x: Float32Array,\n  y: Float32Array,\n  z: Float32Array,\n}\n\n/** Base singleton for Molfile or Mol2 parser/handler */\nexport abstract class ChemicalTableParserBase implements ChemicalTableParser {\n  protected constructor(file: string) {\n    this.init(file);\n  };\n\n  protected static instance: ChemicalTableParserBase;\n\n  protected file!: string;\n  protected _atomCount?: number;\n  protected _bondCount?: number;\n  protected xyzAtomCoordinates?: CoordinateArrays;\n  protected _atomTypes?: string[];\n  protected _pairsOfBondedAtoms?: Uint16Array[];\n\n  public init(file: string): void {\n    this.file = file.replace(/\\r/g, '');\n    this._atomCount = undefined;\n    this._atomTypes = undefined;\n    this._bondCount = undefined;\n    this.xyzAtomCoordinates = undefined;\n    this._pairsOfBondedAtoms = undefined;\n  }\n\n  /** Total number of atoms in a molecule */\n  get atomCount(): number {\n    if (this._atomCount === undefined)\n      this.setAtomAndBondCounts();\n    return this._atomCount!;\n  }\n\n  /** Number of bonds in a molecule  */\n  get bondCount(): number {\n    if (this._bondCount === undefined)\n      this.setAtomAndBondCounts();\n    return this._bondCount!;\n  }\n\n  /** X coordinates of all atoms in a molecule  */\n  get x(): Float32Array {\n    if (this.xyzAtomCoordinates === undefined)\n      this.xyzAtomCoordinates = this.parseAtomCoordinates();\n    return this.xyzAtomCoordinates.x;\n  };\n\n  /** Y coordinates of all atoms in a molecule  */\n  get y(): Float32Array {\n    if (this.xyzAtomCoordinates === undefined)\n      this.xyzAtomCoordinates = this.parseAtomCoordinates();\n    return this.xyzAtomCoordinates!.y;\n  };\n\n  /** Z coordinates of all atoms in a molecule  */\n  get z(): Float32Array {\n    if (this.xyzAtomCoordinates === undefined)\n      this.xyzAtomCoordinates = this.parseAtomCoordinates();\n    return this.xyzAtomCoordinates!.z;\n  };\n\n  get atomTypes(): string[] {\n    if (this._atomTypes === undefined)\n      this._atomTypes = this.parseAtomTypes();\n    return this._atomTypes;\n  }\n\n  get pairsOfBondedAtoms(): Uint16Array[] {\n    if (this._pairsOfBondedAtoms === undefined)\n      this._pairsOfBondedAtoms = this.parseBondedAtomPairs();\n    return this._pairsOfBondedAtoms!;\n  }\n\n  protected abstract parseAtomAndBondCounts(): AtomAndBondCounts;\n  protected abstract getCountsLineIdx(): number;\n  protected abstract getAtomBlockIdx(): number;\n  protected abstract getBondBlockIdx(): number;\n  protected abstract shiftIdxToXColumn(lineStartIdx: number): number;\n  protected abstract shiftIdxToAtomType(lineStartIdx: number): number;\n  protected abstract shiftIdxToBondedAtomsPair(lineStartIdx: number): number;\n  protected abstract parseAtomType(idx: number): string;\n\n  protected setAtomAndBondCounts(): void {\n    const {atomCount, bondCount} = this.parseAtomAndBondCounts();\n    this._atomCount = atomCount;\n    this._bondCount = bondCount;\n  }\n\n  protected getNextColumnIdx(idx: number): number {\n    // skip non-whitespace, if necessary\n    while (!this.isWhitespace(idx))\n      ++idx;\n    // skip whitespace\n    while (this.isWhitespace(idx))\n      ++idx;\n    return idx;\n  }\n\n  protected shiftIdxToSpecifiedColumn(lineStartIdx: number, columnNumber: number) {\n    let idx = lineStartIdx;\n    const numberOfJumps = this.isWhitespace(idx) ? columnNumber : columnNumber - 1;\n    for (let i = 0; i < numberOfJumps; i++)\n      idx = this.getNextColumnIdx(idx);\n    return idx;\n  }\n\n  protected parseAtomTypes(): string[] {\n    const atomCount = this.atomCount;\n    const atomTypes = new Array<string>(atomCount);\n    let idx = this.getAtomBlockIdx();\n    for (let i = 0; i < atomCount; i++) {\n      idx = this.shiftIdxToAtomType(idx);\n      atomTypes[i] = this.parseAtomType(idx);\n      idx = this.getNextLineIdx(idx);\n    }\n    return atomTypes;\n  };\n\n  protected parseAtomCoordinates(): CoordinateArrays {\n    const x = new Float32Array(this.atomCount);\n    const y = new Float32Array(this.atomCount);\n    const z = new Float32Array(this.atomCount);\n    let idx = this.getAtomBlockIdx();\n    for (let i = 0; i < this.atomCount; i++) {\n      idx = this.shiftIdxToXColumn(idx);\n      for (const item of [x, y, z]) {\n        item[i] = this.parseFloatValue(idx);\n        idx = this.getNextColumnIdx(idx);\n      }\n      idx = this.getNextLineIdx(idx);\n    }\n    return {x: x, y: y, z: z};\n  }\n\n  protected parseBondedAtomPairs(): Uint16Array[] {\n    const bondedAtomPairs = new Array<Uint16Array>(this.bondCount);\n    let idx = this.getBondBlockIdx();\n    for (let i = 0; i < this.bondCount; i++) {\n      idx = this.shiftIdxToBondedAtomsPair(idx);\n      const pair = new Uint16Array(2);\n      pair[0] = this.parseIntValue(idx);\n      idx = this.getNextColumnIdx(idx);\n      pair[1] = this.parseIntValue(idx);\n      bondedAtomPairs[i] = pair;\n      idx = this.getNextLineIdx(idx);\n    }\n    return bondedAtomPairs;\n  }\n\n  protected isWhitespace(idx: number): boolean {\n    return /\\s/.test(this.file.at(idx)!);\n  }\n\n  protected getNextLineIdx(idx: number): number {\n    if (this.file.at(idx) !== '\\n')\n      return this.file.indexOf('\\n', idx) + 1;\n    else\n      return idx + 1;\n  }\n\n  protected parseFloatValue(idxOfNumber: number): number {\n    return this.parseNumericValue(parseFloat, idxOfNumber);\n  }\n\n  protected parseIntValue(idxOfNumber: number): number {\n    return this.parseNumericValue(parseInt, idxOfNumber);\n  }\n\n  protected parseNumericValue(\n    parserFunction: (str: string) => number,\n    idxOfNumber: number\n  ): number {\n    let end = idxOfNumber + 1;\n    while (!this.isWhitespace(end))\n      ++end;\n    const value = parserFunction(this.file.substring(idxOfNumber, end));\n    return value;\n  }\n}\n"]}
import { ChemicalTableParser, ChemicalTableParserBase, AtomAndBondCounts } from './chemical-table-parser';
/** Class for handling MDL Molfiles V2000 and V3000 */
export declare class MolfileHandler extends ChemicalTableParserBase implements ChemicalTableParser {

@@ -14,2 +13,3 @@ constructor(molfile: string);

protected getBondBlockIdx: () => number;
protected shiftIdxToBondedAtomsPair: (lineStartIdx: number) => number;
protected parseAtomType(idx: number): string;

@@ -26,2 +26,4 @@ /** Determine whether the file is V2000/V3000, or throw */

private shiftIdxToXColumnV3K;
private shiftIdxToBondedAtomsPairV2K;
private shiftIdxToBondedAtomsPairV3K;
private getBondBlockIdxV2K;

@@ -28,0 +30,0 @@ private getBondBlockIdxV3K;

import { ChemicalTableParserBase } from './chemical-table-parser';
import { MOLFILE_VERSION, V2K } from './molfile-parsing-const';
/** Class for handling MDL Molfiles V2000 and V3000 */
import { MOLFILE_VERSION, V2K_CONST } from './molfile-parsing-const';
export class MolfileHandler extends ChemicalTableParserBase {

@@ -9,3 +8,2 @@ constructor(molfile) {

}
// Public members
/** Init/reset the state of the handler for a new molfile */

@@ -23,6 +21,7 @@ init(molfile) {

this.getBondBlockIdx = isV2K ? this.getBondBlockIdxV2K : this.getBondBlockIdxV3K;
this.shiftIdxToBondedAtomsPair = isV2K ? this.shiftIdxToBondedAtomsPairV2K : this.shiftIdxToBondedAtomsPairV3K;
}
static createInstance(file) {
if (!this.instance)
this.instance = new MolfileHandler(file); // a workaround to define an abstract singleton
this.instance = new MolfileHandler(file);
return this.instance;

@@ -35,3 +34,2 @@ }

}
// Private members
/** Determine whether the file is V2000/V3000, or throw */

@@ -47,11 +45,10 @@ static determineMolfileVersion(molfile) {

shiftIdxToAtomTypeV2K(lineStartIdx) {
return this.shiftToSpecifiedColumn(lineStartIdx, 4);
return this.shiftIdxToSpecifiedColumn(lineStartIdx, V2K_CONST.ATOM_TYPE_COL);
}
shiftIdxToAtomTypeV3K(lineStartIdx) {
return this.shiftToSpecifiedColumn(lineStartIdx, 3);
return this.shiftIdxToSpecifiedColumn(lineStartIdx, 4 /* V3K_CONST.ATOM_TYPE_COL */);
}
getCountsLineV2KIdx() {
let idx = 0;
// 3 is for the number of header lines in molfiles
for (let i = 0; i < 3; ++i)
for (let i = 0; i < V2K_CONST.NUM_OF_HEADER_LINES; ++i)
idx = this.getNextLineIdx(idx);

@@ -61,3 +58,3 @@ return idx;

getCountsLineV3KIdx() {
return this.file.indexOf("M V30 COUNTS " /* V3K.BEGIN_COUNTS_LINE */);
return this.file.indexOf("M V30 COUNTS " /* V3K_CONST.BEGIN_COUNTS_LINE */);
}

@@ -70,3 +67,3 @@ getAtomBlockIdxV2K() {

getAtomBlockIdxV3K() {
let idx = this.file.indexOf("M V30 BEGIN ATOM" /* V3K.BEGIN_ATOM_BLOCK */);
let idx = this.file.indexOf("M V30 BEGIN ATOM" /* V3K_CONST.BEGIN_ATOM_BLOCK */);
idx = this.getNextLineIdx(idx);

@@ -79,4 +76,10 @@ return idx;

shiftIdxToXColumnV3K(lineStartIdx) {
return this.shiftToSpecifiedColumn(lineStartIdx, 4);
return this.shiftIdxToSpecifiedColumn(lineStartIdx, 5 /* V3K_CONST.X_COL */);
}
shiftIdxToBondedAtomsPairV2K(lineStartIdx) {
return this.shiftIdxToSpecifiedColumn(lineStartIdx, V2K_CONST.FIRST_BONDED_ATOM_COL);
}
shiftIdxToBondedAtomsPairV3K(lineStartIdx) {
return this.shiftIdxToSpecifiedColumn(lineStartIdx, 5 /* V3K_CONST.FIRST_BONDED_ATOM_COL */);
}
getBondBlockIdxV2K() {

@@ -89,25 +92,18 @@ let idx = this.getAtomBlockIdx();

getBondBlockIdxV3K() {
return this.getNextLineIdx(this.file.indexOf("M V30 BEGIN BOND" /* V3K.BEGIN_BOND_BLOCK */));
return this.getNextLineIdx(this.file.indexOf("M V30 BEGIN BOND" /* V3K_CONST.BEGIN_BOND_BLOCK */));
}
// todo: devise a more reliable validation
static validateV3K(molfile) {
if (molfile.indexOf("V3000" /* V3K.HEADER */) !== -1 &&
molfile.indexOf("M END" /* V3K.END */) !== -1)
return true;
return false;
return (molfile.indexOf("V3000" /* V3K_CONST.HEADER */) !== -1 &&
molfile.indexOf("M END" /* V3K_CONST.END */) !== -1);
}
// todo: devise a more reliable validation
static validateV2K(molfile) {
if (molfile.indexOf(V2K.HEADER) !== -1 &&
molfile.indexOf(V2K.END) !== -1)
return true;
return false;
return (molfile.indexOf(V2K_CONST.HEADER) !== -1 &&
molfile.indexOf(V2K_CONST.END) !== -1);
}
parseAtomAndBondCountsV2K() {
let begin = this.getCountsLineIdx();
// 3 is the # of digits allocated for atom/bond counts
let end = begin + 3;
let end = begin + V2K_CONST.NUM_OF_COUNTS_DIGITS;
const atomCount = parseInt(this.file.substring(begin, end));
begin = end;
end += 3;
end += V2K_CONST.NUM_OF_COUNTS_DIGITS;
const bondCount = parseInt(this.file.substring(begin, end));

@@ -119,3 +115,3 @@ return { atomCount: atomCount, bondCount: bondCount };

// parse atom count
let begin = this.file.indexOf("M V30 COUNTS " /* V3K.BEGIN_COUNTS_LINE */) + 14 /* V3K.COUNTS_SHIFT */;
let begin = this.file.indexOf("M V30 COUNTS " /* V3K_CONST.BEGIN_COUNTS_LINE */) + 14 /* V3K_CONST.COUNTS_SHIFT */;
let end = this.file.indexOf(' ', begin + 1);

@@ -130,2 +126,2 @@ const numOfAtoms = parseInt(this.file.substring(begin, end));

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"molfile-handler.js","sourceRoot":"","sources":["molfile-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChemicalTableParser, ChemicalTableParserBase, AtomAndBondCounts} from './chemical-table-parser';\nimport {MOLFILE_VERSION, V2K, V3K} from './molfile-parsing-const';\n\n/** Class for handling MDL Molfiles V2000 and V3000 */\nexport class MolfileHandler extends ChemicalTableParserBase implements ChemicalTableParser {\n  constructor(molfile: string) {\n    super(molfile);\n    this.init(molfile);\n  }\n\n  // Public members\n\n  /** Init/reset the state of the handler for a new molfile */\n  public init(molfile: string) {\n    super.init(molfile);\n\n    const molfileVersion = MolfileHandler.determineMolfileVersion(this.file);\n    const isV2K = (molfileVersion === MOLFILE_VERSION.V2000);\n\n    this.parseAtomAndBondCounts = isV2K ? this.parseAtomAndBondCountsV2K : this.parseAtomAndBondCountsV3K;\n\n    this.getAtomBlockIdx = isV2K ? this.getAtomBlockIdxV2K : this.getAtomBlockIdxV3K;\n\n    this.getCountsLineIdx = isV2K ? this.getCountsLineV2KIdx : this.getCountsLineV3KIdx;\n\n    this.shiftIdxToXColumn = isV2K ? this.shiftIdxToXColumnV2K : this.shiftIdxToXColumnV3K;\n\n    this.shiftIdxToAtomType = isV2K ? this.shiftIdxToAtomTypeV2K :\n      this.shiftIdxToAtomTypeV3K;\n\n    this.getBondBlockIdx = isV2K ? this.getBondBlockIdxV2K : this.getBondBlockIdxV3K;\n  }\n\n  public static createInstance(file: string): MolfileHandler {\n    if (!this.instance)\n      this.instance = new MolfileHandler(file); // a workaround to define an abstract singleton\n    return this.instance as MolfileHandler;\n  }\n\n  // Protected members\n\n  protected parseAtomAndBondCounts!: () => AtomAndBondCounts;\n  protected getCountsLineIdx!: () => number;\n  protected getAtomBlockIdx!: () => number;\n  protected shiftIdxToXColumn!: (lineStartIdx: number) => number;\n  protected shiftIdxToAtomType!: (idx: number) => number;\n  protected getBondBlockIdx!: () => number;\n\n  protected parseAtomType(idx: number): string {\n    const begin = idx;\n    const end = this.file.indexOf(' ', begin);\n    return this.file.substring(begin, end);\n  }\n\n  // Private members\n\n  /** Determine whether the file is V2000/V3000, or throw */\n  private static determineMolfileVersion(molfile: string): MOLFILE_VERSION {\n    if (MolfileHandler.validateV3K(molfile))\n      return MOLFILE_VERSION.V3000;\n    else if (MolfileHandler.validateV2K(molfile))\n      return MOLFILE_VERSION.V2000;\n    else\n      throw new Error('Malformed molfile');\n  }\n\n  private shiftIdxToAtomTypeV2K(lineStartIdx: number): number {\n    return this.shiftToSpecifiedColumn(lineStartIdx, 4);\n  }\n\n  private shiftIdxToAtomTypeV3K(lineStartIdx: number): number {\n    return this.shiftToSpecifiedColumn(lineStartIdx, 3);\n  }\n\n  private getCountsLineV2KIdx(): number {\n    let idx = 0;\n    // 3 is for the number of header lines in molfiles\n    for (let i = 0; i < 3; ++i)\n      idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private getCountsLineV3KIdx(): number {\n    return this.file.indexOf(V3K.BEGIN_COUNTS_LINE);\n  }\n\n  private getAtomBlockIdxV2K(): number {\n    let idx = this.getCountsLineIdx();\n    idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private getAtomBlockIdxV3K(): number {\n    let idx = this.file.indexOf(V3K.BEGIN_ATOM_BLOCK);\n    idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private shiftIdxToXColumnV2K(lineStartIdx: number): number {\n    return this.getNextColumnIdx(lineStartIdx);\n  }\n\n  private shiftIdxToXColumnV3K(lineStartIdx: number): number {\n    return this.shiftToSpecifiedColumn(lineStartIdx, 4);\n  }\n\n  private getBondBlockIdxV2K(): number {\n    let idx = this.getAtomBlockIdx();\n    for (let i = 0; i < this.atomCount; i++)\n      idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private getBondBlockIdxV3K(): number {\n    return this.getNextLineIdx(this.file.indexOf(V3K.BEGIN_BOND_BLOCK));\n  }\n\n  // todo: devise a more reliable validation\n  private static validateV3K(molfile: string): boolean {\n    if (molfile.indexOf(V3K.HEADER) !== -1 &&\n    molfile.indexOf(V3K.END) !== -1)\n      return true;\n    return false;\n  }\n\n  // todo: devise a more reliable validation\n  private static validateV2K(molfile: string): boolean {\n    if (molfile.indexOf(V2K.HEADER) !== -1 &&\n    molfile.indexOf(V2K.END) !== -1)\n      return true;\n    return false;\n  }\n\n  private parseAtomAndBondCountsV2K(): AtomAndBondCounts {\n    let begin = this.getCountsLineIdx();\n    // 3 is the # of digits allocated for atom/bond counts\n    let end = begin + 3;\n    const atomCount = parseInt(this.file.substring(begin, end));\n    begin = end;\n    end += 3;\n    const bondCount = parseInt(this.file.substring(begin, end));\n    return {atomCount: atomCount, bondCount: bondCount};\n  };\n\n  private parseAtomAndBondCountsV3K(): AtomAndBondCounts {\n    // parse atom count\n    let begin = this.file.indexOf(V3K.BEGIN_COUNTS_LINE) + V3K.COUNTS_SHIFT;\n    let end = this.file.indexOf(' ', begin + 1);\n    const numOfAtoms = parseInt(this.file.substring(begin, end));\n\n    // parse bond count\n    begin = end + 1;\n    end = this.file.indexOf(' ', begin + 1);\n    const numOfBonds = parseInt(this.file.substring(begin, end));\n\n    return {atomCount: numOfAtoms, bondCount: numOfBonds};\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"molfile-handler.js","sourceRoot":"","sources":["molfile-handler.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChemicalTableParser, ChemicalTableParserBase, AtomAndBondCounts} from './chemical-table-parser';\nimport {MOLFILE_VERSION, V2K_CONST, V3K_CONST} from './molfile-parsing-const';\n\nexport class MolfileHandler extends ChemicalTableParserBase implements ChemicalTableParser {\n  constructor(molfile: string) {\n    super(molfile);\n    this.init(molfile);\n  }\n\n  /** Init/reset the state of the handler for a new molfile */\n  public init(molfile: string) {\n    super.init(molfile);\n\n    const molfileVersion = MolfileHandler.determineMolfileVersion(this.file);\n    const isV2K = (molfileVersion === MOLFILE_VERSION.V2000);\n\n    this.parseAtomAndBondCounts = isV2K ? this.parseAtomAndBondCountsV2K : this.parseAtomAndBondCountsV3K;\n\n    this.getAtomBlockIdx = isV2K ? this.getAtomBlockIdxV2K : this.getAtomBlockIdxV3K;\n\n    this.getCountsLineIdx = isV2K ? this.getCountsLineV2KIdx : this.getCountsLineV3KIdx;\n\n    this.shiftIdxToXColumn = isV2K ? this.shiftIdxToXColumnV2K : this.shiftIdxToXColumnV3K;\n\n    this.shiftIdxToAtomType = isV2K ? this.shiftIdxToAtomTypeV2K :\n      this.shiftIdxToAtomTypeV3K;\n\n    this.getBondBlockIdx = isV2K ? this.getBondBlockIdxV2K : this.getBondBlockIdxV3K;\n\n    this.shiftIdxToBondedAtomsPair = isV2K ? this.shiftIdxToBondedAtomsPairV2K : this.shiftIdxToBondedAtomsPairV3K;\n  }\n\n  public static createInstance(file: string): MolfileHandler {\n    if (!this.instance)\n      this.instance = new MolfileHandler(file);\n    return this.instance as MolfileHandler;\n  }\n\n  protected parseAtomAndBondCounts!: () => AtomAndBondCounts;\n  protected getCountsLineIdx!: () => number;\n  protected getAtomBlockIdx!: () => number;\n  protected shiftIdxToXColumn!: (lineStartIdx: number) => number;\n  protected shiftIdxToAtomType!: (idx: number) => number;\n  protected getBondBlockIdx!: () => number;\n  protected shiftIdxToBondedAtomsPair!: (lineStartIdx: number) => number;\n\n  protected parseAtomType(idx: number): string {\n    const begin = idx;\n    const end = this.file.indexOf(' ', begin);\n    return this.file.substring(begin, end);\n  }\n\n  /** Determine whether the file is V2000/V3000, or throw */\n  private static determineMolfileVersion(molfile: string): MOLFILE_VERSION {\n    if (MolfileHandler.validateV3K(molfile))\n      return MOLFILE_VERSION.V3000;\n    else if (MolfileHandler.validateV2K(molfile))\n      return MOLFILE_VERSION.V2000;\n    else\n      throw new Error('Malformed molfile');\n  }\n\n  private shiftIdxToAtomTypeV2K(lineStartIdx: number): number {\n    return this.shiftIdxToSpecifiedColumn(lineStartIdx, V2K_CONST.ATOM_TYPE_COL);\n  }\n\n  private shiftIdxToAtomTypeV3K(lineStartIdx: number): number {\n    return this.shiftIdxToSpecifiedColumn(lineStartIdx, V3K_CONST.ATOM_TYPE_COL);\n  }\n\n  private getCountsLineV2KIdx(): number {\n    let idx = 0;\n    for (let i = 0; i < V2K_CONST.NUM_OF_HEADER_LINES; ++i)\n      idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private getCountsLineV3KIdx(): number {\n    return this.file.indexOf(V3K_CONST.BEGIN_COUNTS_LINE);\n  }\n\n  private getAtomBlockIdxV2K(): number {\n    let idx = this.getCountsLineIdx();\n    idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private getAtomBlockIdxV3K(): number {\n    let idx = this.file.indexOf(V3K_CONST.BEGIN_ATOM_BLOCK);\n    idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private shiftIdxToXColumnV2K(lineStartIdx: number): number {\n    return this.getNextColumnIdx(lineStartIdx);\n  }\n\n  private shiftIdxToXColumnV3K(lineStartIdx: number): number {\n    return this.shiftIdxToSpecifiedColumn(lineStartIdx, V3K_CONST.X_COL);\n  }\n\n  private shiftIdxToBondedAtomsPairV2K(lineStartIdx: number): number {\n    return this.shiftIdxToSpecifiedColumn(lineStartIdx, V2K_CONST.FIRST_BONDED_ATOM_COL);\n  }\n\n  private shiftIdxToBondedAtomsPairV3K(lineStartIdx: number): number {\n    return this.shiftIdxToSpecifiedColumn(lineStartIdx, V3K_CONST.FIRST_BONDED_ATOM_COL);\n  }\n  private getBondBlockIdxV2K(): number {\n    let idx = this.getAtomBlockIdx();\n    for (let i = 0; i < this.atomCount; i++)\n      idx = this.getNextLineIdx(idx);\n    return idx;\n  }\n\n  private getBondBlockIdxV3K(): number {\n    return this.getNextLineIdx(this.file.indexOf(V3K_CONST.BEGIN_BOND_BLOCK));\n  }\n\n  private static validateV3K(molfile: string): boolean {\n    return (molfile.indexOf(V3K_CONST.HEADER) !== -1 &&\n    molfile.indexOf(V3K_CONST.END) !== -1);\n  }\n\n  private static validateV2K(molfile: string): boolean {\n    return (molfile.indexOf(V2K_CONST.HEADER) !== -1 &&\n    molfile.indexOf(V2K_CONST.END) !== -1);\n  }\n\n  private parseAtomAndBondCountsV2K(): AtomAndBondCounts {\n    let begin = this.getCountsLineIdx();\n    let end = begin + V2K_CONST.NUM_OF_COUNTS_DIGITS;\n    const atomCount = parseInt(this.file.substring(begin, end));\n    begin = end;\n    end += V2K_CONST.NUM_OF_COUNTS_DIGITS;\n    const bondCount = parseInt(this.file.substring(begin, end));\n    return {atomCount: atomCount, bondCount: bondCount};\n  };\n\n  private parseAtomAndBondCountsV3K(): AtomAndBondCounts {\n    // parse atom count\n    let begin = this.file.indexOf(V3K_CONST.BEGIN_COUNTS_LINE) + V3K_CONST.COUNTS_SHIFT;\n    let end = this.file.indexOf(' ', begin + 1);\n    const numOfAtoms = parseInt(this.file.substring(begin, end));\n\n    // parse bond count\n    begin = end + 1;\n    end = this.file.indexOf(' ', begin + 1);\n    const numOfBonds = parseInt(this.file.substring(begin, end));\n\n    return {atomCount: numOfAtoms, bondCount: numOfBonds};\n  }\n}\n"]}

@@ -6,3 +6,3 @@ export declare enum MOLFILE_VERSION {

/** Constants relevant for parsing of Molfile V3K */
export declare const enum V3K {
export declare const enum V3K_CONST {
HEADER = "V3000",

@@ -14,9 +14,16 @@ BEGIN_COUNTS_LINE = "M V30 COUNTS ",

BEGIN_BOND_BLOCK = "M V30 BEGIN BOND",
END = "M END"
END = "M END",
ATOM_TYPE_COL = 4,
X_COL = 5,
FIRST_BONDED_ATOM_COL = 5
}
/** Constants relevant for parsing of Molfile V2K */
export declare enum V2K {
export declare enum V2K_CONST {
HEADER = "V2000",
END = "M END"
END = "M END",
NUM_OF_HEADER_LINES = 3,
NUM_OF_COUNTS_DIGITS = 3,
ATOM_TYPE_COL = 4,
FIRST_BONDED_ATOM_COL = 1
}
//# sourceMappingURL=molfile-parsing-const.d.ts.map

@@ -7,7 +7,11 @@ export var MOLFILE_VERSION;

/** Constants relevant for parsing of Molfile V2K */
export var V2K;
(function (V2K) {
V2K["HEADER"] = "V2000";
V2K["END"] = "M END";
})(V2K || (V2K = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9sZmlsZS1wYXJzaW5nLWNvbnN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibW9sZmlsZS1wYXJzaW5nLWNvbnN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGVBR1g7QUFIRCxXQUFZLGVBQWU7SUFDekIsa0NBQWUsQ0FBQTtJQUNmLGtDQUFlLENBQUE7QUFDakIsQ0FBQyxFQUhXLGVBQWUsS0FBZixlQUFlLFFBRzFCO0FBYUQsb0RBQW9EO0FBQ3BELE1BQU0sQ0FBTixJQUFZLEdBR1g7QUFIRCxXQUFZLEdBQUc7SUFDYix1QkFBZ0IsQ0FBQTtJQUNoQixxQkFBYyxDQUFBO0FBQ2hCLENBQUMsRUFIVyxHQUFHLEtBQUgsR0FBRyxRQUdkIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gTU9MRklMRV9WRVJTSU9OIHtcbiAgVjIwMDAgPSAnVjIwMDAnLFxuICBWMzAwMCA9ICdWMzAwMCcsXG59XG5cbi8qKiBDb25zdGFudHMgcmVsZXZhbnQgZm9yIHBhcnNpbmcgb2YgTW9sZmlsZSBWM0sgKi9cbmV4cG9ydCBjb25zdCBlbnVtIFYzSyB7XG4gIEhFQURFUiA9ICdWMzAwMCcsXG4gIEJFR0lOX0NPVU5UU19MSU5FID0gJ00gIFYzMCBDT1VOVFMgJyxcbiAgLyoqIEluZGV4IHNoaWZ0IGZyb20gdGhlIGJlZ2lubmluZyBvZiB0aGUgJ0NPVU5UUycgbGluZSB0byB0aGUgbnVtYmVyIG9mIGF0b21zICAqL1xuICBDT1VOVFNfU0hJRlQgPSAxNCxcbiAgQkVHSU5fQVRPTV9CTE9DSyA9ICdNICBWMzAgQkVHSU4gQVRPTScsXG4gIEJFR0lOX0JPTkRfQkxPQ0sgPSAnTSAgVjMwIEJFR0lOIEJPTkQnLFxuICBFTkQgPSAnTSAgRU5EJyxcbn1cblxuLyoqIENvbnN0YW50cyByZWxldmFudCBmb3IgcGFyc2luZyBvZiBNb2xmaWxlIFYySyAqL1xuZXhwb3J0IGVudW0gVjJLIHtcbiAgSEVBREVSID0gJ1YyMDAwJyxcbiAgRU5EID0gJ00gIEVORCcsXG59XG5cbiJdfQ==
export var V2K_CONST;
(function (V2K_CONST) {
V2K_CONST["HEADER"] = "V2000";
V2K_CONST["END"] = "M END";
V2K_CONST[V2K_CONST["NUM_OF_HEADER_LINES"] = 3] = "NUM_OF_HEADER_LINES";
V2K_CONST[V2K_CONST["NUM_OF_COUNTS_DIGITS"] = 3] = "NUM_OF_COUNTS_DIGITS";
V2K_CONST[V2K_CONST["ATOM_TYPE_COL"] = 4] = "ATOM_TYPE_COL";
V2K_CONST[V2K_CONST["FIRST_BONDED_ATOM_COL"] = 1] = "FIRST_BONDED_ATOM_COL";
})(V2K_CONST || (V2K_CONST = {}));
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW9sZmlsZS1wYXJzaW5nLWNvbnN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsibW9sZmlsZS1wYXJzaW5nLWNvbnN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGVBR1g7QUFIRCxXQUFZLGVBQWU7SUFDekIsa0NBQWUsQ0FBQTtJQUNmLGtDQUFlLENBQUE7QUFDakIsQ0FBQyxFQUhXLGVBQWUsS0FBZixlQUFlLFFBRzFCO0FBZ0JELG9EQUFvRDtBQUNwRCxNQUFNLENBQU4sSUFBWSxTQU9YO0FBUEQsV0FBWSxTQUFTO0lBQ25CLDZCQUFnQixDQUFBO0lBQ2hCLDJCQUFjLENBQUE7SUFDZCx1RUFBdUIsQ0FBQTtJQUN2Qix5RUFBd0IsQ0FBQTtJQUN4QiwyREFBaUIsQ0FBQTtJQUNqQiwyRUFBeUIsQ0FBQTtBQUMzQixDQUFDLEVBUFcsU0FBUyxLQUFULFNBQVMsUUFPcEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZW51bSBNT0xGSUxFX1ZFUlNJT04ge1xuICBWMjAwMCA9ICdWMjAwMCcsXG4gIFYzMDAwID0gJ1YzMDAwJyxcbn1cblxuLyoqIENvbnN0YW50cyByZWxldmFudCBmb3IgcGFyc2luZyBvZiBNb2xmaWxlIFYzSyAqL1xuZXhwb3J0IGNvbnN0IGVudW0gVjNLX0NPTlNUIHtcbiAgSEVBREVSID0gJ1YzMDAwJyxcbiAgQkVHSU5fQ09VTlRTX0xJTkUgPSAnTSAgVjMwIENPVU5UUyAnLFxuICAvKiogSW5kZXggc2hpZnQgZnJvbSB0aGUgYmVnaW5uaW5nIG9mIHRoZSAnQ09VTlRTJyBsaW5lIHRvIHRoZSBudW1iZXIgb2YgYXRvbXMgICovXG4gIENPVU5UU19TSElGVCA9IDE0LFxuICBCRUdJTl9BVE9NX0JMT0NLID0gJ00gIFYzMCBCRUdJTiBBVE9NJyxcbiAgQkVHSU5fQk9ORF9CTE9DSyA9ICdNICBWMzAgQkVHSU4gQk9ORCcsXG4gIEVORCA9ICdNICBFTkQnLFxuICBBVE9NX1RZUEVfQ09MID0gNCxcbiAgWF9DT0wgPSA1LFxuICBGSVJTVF9CT05ERURfQVRPTV9DT0wgPSA1LFxufVxuXG4vKiogQ29uc3RhbnRzIHJlbGV2YW50IGZvciBwYXJzaW5nIG9mIE1vbGZpbGUgVjJLICovXG5leHBvcnQgZW51bSBWMktfQ09OU1Qge1xuICBIRUFERVIgPSAnVjIwMDAnLFxuICBFTkQgPSAnTSAgRU5EJyxcbiAgTlVNX09GX0hFQURFUl9MSU5FUyA9IDMsXG4gIE5VTV9PRl9DT1VOVFNfRElHSVRTID0gMyxcbiAgQVRPTV9UWVBFX0NPTCA9IDQsXG4gIEZJUlNUX0JPTkRFRF9BVE9NX0NPTCA9IDEsXG59XG5cbiJdfQ==

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

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