Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@datagrok-libraries/chem-meta

Package Overview
Dependencies
Maintainers
3
Versions
27
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.5 to 1.0.6

4

package.json

@@ -6,8 +6,6 @@ {

},
"beta": true,
"friendlyName": "Datagrok chem-meta library",
"version": "1.0.5",
"version": "1.0.6",
"description": "",
"dependencies": {
"@datagrok-libraries/utils": "^2.1.2",
"wu": "latest"

@@ -14,0 +12,0 @@ },

@@ -10,3 +10,3 @@ /** Base singleton for Molfile or Mol2 parser/handler */

init(file) {
this.file = file.replaceAll('\r', '');
this.file = file.replace(/\r/g, '');
this._atomCount = undefined;

@@ -131,2 +131,2 @@ this._atomTypes = undefined;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chemical-table-parser.js","sourceRoot":"","sources":["chemical-table-parser.ts"],"names":[],"mappings":"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","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.replaceAll('\\r', '');\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":"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","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"]}

@@ -7,5 +7,5 @@ {

// "incremental": true, /* Enable incremental compilation */
"target": "es6", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */
"module": "es2020", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */
"lib": ["es2022", "dom"], /* Specify library files to be included in the compilation. */
"target": "es6", /* Specify ECMAScript target version: 'ES3' (default), 'ES5', 'ES2015', 'ES2016', 'ES2017', 'ES2018', 'ES2019', 'ES2020', or 'ESNEXT'. */
"module": "es2020", /* Specify module code generation: 'none', 'commonjs', 'amd', 'system', 'umd', 'es2015', 'es2020', or 'ESNext'. */
"lib": ["esnext", "dom"], /* Specify library files to be included in the compilation. */
// "allowJs": true, /* Allow javascript files to be compiled. */

@@ -12,0 +12,0 @@ // "checkJs": true, /* Report errors in .js files. */

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