@itwin/core-quantity 4.4.0-dev.8 → 4.5.0-dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,6 +1,11 @@
1
1
  # Change Log - @itwin/core-quantity
2
2
 
3
- This log was last generated on Thu, 14 Dec 2023 20:24:02 GMT and should not be manually modified.
3
+ This log was last generated on Wed, 03 Jan 2024 19:29:41 GMT and should not be manually modified.
4
+
5
+ ## 4.3.3
6
+ Wed, 03 Jan 2024 19:28:38 GMT
7
+
8
+ _Version update only_
4
9
 
5
10
  ## 4.3.2
6
11
  Thu, 14 Dec 2023 20:23:02 GMT
@@ -1 +1 @@
1
- {"version":3,"file":"Parser.d.ts","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAE,2BAA2B,EAAE,kBAAkB,EAAE,aAAa,EAAuB,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AACjK,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C;;GAEG;AACH,oBAAY,UAAU;IACpB,2BAA2B,IAAI;IAC/B,0BAA0B,IAAA;IAC1B,8BAA8B,IAAA;IAC9B,WAAW,IAAA;IACX,oCAAoC,IAAA;IACpC,iBAAiB,IAAA;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,uDAAuD;IACvD,EAAE,EAAE,KAAK,CAAC;IACV,uDAAuD;IACvD,KAAK,EAAE,UAAU,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,uDAAuD;IACvD,EAAE,EAAE,IAAI,CAAC;IACT,4CAA4C;IAC5C,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;;GAGG;AACH,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAAG,kBAAkB,CAAC;AAEtE;;GAEG;AACH,cAAM,UAAU;IACP,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;gBAElB,KAAK,EAAE,MAAM,GAAG,MAAM;IAOlC,IAAW,QAAQ,IAAI,OAAO,CAA2C;IACzE,IAAW,QAAQ,IAAI,OAAO,CAA2C;CAC1E;AA+BD;;GAEG;AACH,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAS;WAEd,gBAAgB,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,cAAc;WAInE,YAAY,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,kBAAkB;IAIjF,OAAO,CAAC,MAAM,CAAC,0BAA0B;IAoBzC,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAyChC,OAAO,CAAC,MAAM,CAAC,OAAO;IAItB,OAAO,CAAC,MAAM,CAAC,yBAAyB;IAIxC;;OAEG;WACW,0BAA0B,CAAC,qBAAqB,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,UAAU,EAAE;mBA2IhF,iBAAiB;mBA6BjB,6BAA6B;IA2ElD;;;;OAIG;WACiB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,aAAa,CAAC;IAQlL,2DAA2D;IAC3D,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAyCpC,OAAO,CAAC,MAAM,CAAC,+BAA+B;IAqE9C;;;;OAIG;WACW,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,GAAG,mBAAmB;IAIhG;;;;OAIG;WACW,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,GAAG,mBAAmB;IA+BjI,+HAA+H;WAC3G,gCAAgC,CAAC,aAAa,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;IA4B1L,+HAA+H;WAC3G,yBAAyB,CAAC,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAgDhO"}
1
+ {"version":3,"file":"Parser.d.ts","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAE,2BAA2B,EAAE,kBAAkB,EAAE,aAAa,EAAuB,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AACjK,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C;;GAEG;AACH,oBAAY,UAAU;IACpB,2BAA2B,IAAI;IAC/B,0BAA0B,IAAA;IAC1B,8BAA8B,IAAA;IAC9B,WAAW,IAAA;IACX,oCAAoC,IAAA;IACpC,iBAAiB,IAAA;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,uDAAuD;IACvD,EAAE,EAAE,KAAK,CAAC;IACV,uDAAuD;IACvD,KAAK,EAAE,UAAU,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,uDAAuD;IACvD,EAAE,EAAE,IAAI,CAAC;IACT,4CAA4C;IAC5C,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;;GAGG;AACH,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAAG,kBAAkB,CAAC;AAEtE;;GAEG;AACH,cAAM,UAAU;IACP,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;gBAElB,KAAK,EAAE,MAAM,GAAG,MAAM;IAOlC,IAAW,QAAQ,IAAI,OAAO,CAA2C;IACzE,IAAW,QAAQ,IAAI,OAAO,CAA2C;CAC1E;AA+BD;;GAEG;AACH,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAS;WAEd,gBAAgB,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,cAAc;WAInE,YAAY,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,kBAAkB;IAIjF,OAAO,CAAC,MAAM,CAAC,0BAA0B;IAoBzC,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAyChC,OAAO,CAAC,MAAM,CAAC,OAAO;IAItB,OAAO,CAAC,MAAM,CAAC,yBAAyB;IAIxC;;OAEG;WACW,0BAA0B,CAAC,qBAAqB,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,UAAU,EAAE;mBA6IhF,iBAAiB;mBA6BjB,6BAA6B;IA2ElD;;;;OAIG;WACiB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,aAAa,CAAC;IAQlL,2DAA2D;IAC3D,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAyCpC,OAAO,CAAC,MAAM,CAAC,+BAA+B;IAqE9C;;;;OAIG;WACW,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,GAAG,mBAAmB;IAIhG;;;;OAIG;WACW,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,GAAG,mBAAmB;IA+BjI,+HAA+H;WAC3G,gCAAgC,CAAC,aAAa,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;IA4B1L,+HAA+H;WAC3G,yBAAyB,CAAC,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAgDhO"}
package/lib/cjs/Parser.js CHANGED
@@ -163,7 +163,9 @@ class Parser {
163
163
  }
164
164
  processingNumber = true;
165
165
  }
166
- wipToken = wipToken.concat(str[i]);
166
+ // Decimal separators must be replaced with '.' before converting to a number - parseFloat() only supports '.' as the decimal separator.
167
+ const charToAdd = charCode === format.decimalSeparator.charCodeAt(0) ? "." : str[i];
168
+ wipToken = wipToken.concat(charToAdd);
167
169
  }
168
170
  else {
169
171
  if (processingNumber) {
@@ -1 +1 @@
1
- {"version":3,"file":"Parser.js","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Quantity\n */\n\nimport { QuantityConstants } from \"./Constants\";\nimport { Format } from \"./Formatter/Format\";\nimport { FormatTraits, FormatType } from \"./Formatter/FormatEnums\";\nimport { AlternateUnitLabelsProvider, PotentialParseUnit, QuantityProps, UnitConversionProps, UnitConversionSpec, UnitProps, UnitsProvider } from \"./Interfaces\";\nimport { ParserSpec } from \"./ParserSpec\";\nimport { Quantity } from \"./Quantity\";\n\n/** Possible parser errors\n * @beta\n */\nexport enum ParseError {\n UnableToGenerateParseTokens = 1,\n NoValueOrUnitFoundInString,\n UnitLabelSuppliedButNotMatched,\n UnknownUnit,\n UnableToConvertParseTokensToQuantity,\n InvalidParserSpec,\n}\n\n/** Parse error result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParseQuantityError {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: false;\n /** The specific error that occurred during parsing. */\n error: ParseError;\n}\n\n/** Successful result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParsedQuantity {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: true;\n /** The magnitude of the parsed quantity. */\n value: number;\n}\n\n/**\n * Defines Results of parsing a string input by a user into its desired value type\n * @beta\n */\nexport type QuantityParseResult = ParsedQuantity | ParseQuantityError;\n\n/** A ParseToken holds either a numeric or string token extracted from a string that represents a quantity value.\n * @beta\n */\nclass ParseToken {\n public value: number | string;\n\n constructor(value: string | number) {\n if (typeof value === \"string\")\n this.value = value.trim();\n else\n this.value = value;\n }\n\n public get isString(): boolean { return typeof this.value === \"string\"; }\n public get isNumber(): boolean { return typeof this.value === \"number\"; }\n}\n\n/** A ScientificToken holds an index and string representing the exponent.\n * @beta\n */\nclass ScientificToken {\n public index: number;\n public exponent = \"\";\n\n constructor(index: number, exponent?: string) {\n this.index = index;\n if (exponent)\n this.exponent = exponent;\n }\n}\n\n/** A FractionToken holds an index and the fraction value of numerator / denominator.\n * @beta\n */\nclass FractionToken {\n public index: number;\n public fraction = 0.0;\n public exponent = \"\";\n\n constructor(index: number, fraction?: number) {\n this.index = index;\n if (fraction)\n this.fraction = fraction;\n }\n}\n\n/** A Parser class that is used to break a string that represents a quantity value into tokens.\n * @beta\n */\nexport class Parser {\n private static _log = false;\n\n public static isParsedQuantity(item: QuantityParseResult): item is ParsedQuantity {\n return item.ok;\n }\n\n public static isParseError(item: QuantityParseResult): item is ParseQuantityError {\n return !item.ok;\n }\n\n private static checkForScientificNotation(index: number, stringToParse: string, uomSeparatorToIgnore: number): ScientificToken {\n let exponentString = \"\";\n let i = index + 1;\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode) || ((charCode === QuantityConstants.CHAR_MINUS || charCode === QuantityConstants.CHAR_PLUS) && (i === (index + 1)))) {\n exponentString = exponentString.concat(stringToParse[i]);\n } else {\n i = uomSeparatorToIgnore === charCode ? i : i - 1;\n break;\n }\n }\n\n if (exponentString.length > 1 || ((exponentString.length === 1) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_MINUS) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_PLUS)))\n return new ScientificToken(i, exponentString);\n\n return new ScientificToken(index);\n }\n\n private static checkForFractions(index: number, stringToParse: string, uomSeparatorToIgnore: number, numeratorStr?: string): FractionToken {\n let numeratorToken = \"\";\n let denominatorToken = \"\";\n let processingNumerator = true;\n let i = index;\n if (numeratorStr && numeratorStr.length > 0) {\n numeratorToken = numeratorStr;\n processingNumerator = false;\n }\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode)) {\n if (processingNumerator) {\n numeratorToken = numeratorToken.concat(stringToParse[i]);\n } else {\n denominatorToken = denominatorToken.concat(stringToParse[i]);\n }\n } else {\n if (processingNumerator && (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH)) {\n processingNumerator = false;\n } else {\n if (uomSeparatorToIgnore !== charCode)\n i = i - 1; // skip over uom separator after fraction\n\n break;\n }\n }\n }\n\n if (numeratorToken.length > 0 && denominatorToken.length > 0) {\n const numerator = parseInt(numeratorToken, 10);\n const denominator = parseInt(denominatorToken, 10);\n if (denominator > 0)\n return new FractionToken(i, numerator / denominator);\n return new FractionToken(i);\n }\n\n return new FractionToken(index + 1);\n }\n\n private static isDigit(charCode: number): boolean {\n return (charCode >= QuantityConstants.CHAR_DIGIT_ZERO) && (charCode <= QuantityConstants.CHAR_DIGIT_NINE);\n }\n\n private static isDigitOrDecimalSeparator(charCode: number, format: Format): boolean {\n return (charCode === format.decimalSeparator.charCodeAt(0)) || Parser.isDigit(charCode);\n }\n\n /** Parse the quantity string and return and array of ParseTokens that represent the component invariant values and unit labels.\n * @param quantitySpecification The quantity string to ba parsed.\n */\n public static parseQuantitySpecification(quantitySpecification: string, format: Format): ParseToken[] {\n const tokens: ParseToken[] = [];\n const str = quantitySpecification.trim();\n let processingNumber = false;\n let wipToken = \"\";\n let signToken = \"\";\n let uomSeparatorToIgnore = 0;\n let fractionDashCode = 0;\n\n const skipCodes: number[] = [format.thousandSeparator.charCodeAt(0)];\n\n if (format.type === FormatType.Station && format.stationSeparator && format.stationSeparator.length === 1)\n skipCodes.push(format.stationSeparator.charCodeAt(0));\n\n if (format.type === FormatType.Fractional && format.hasFormatTraitSet(FormatTraits.FractionDash)) {\n fractionDashCode = QuantityConstants.CHAR_MINUS;\n }\n\n if (format.uomSeparator && format.uomSeparator !== \" \" && format.uomSeparator.length === 1) {\n uomSeparatorToIgnore = format.uomSeparator.charCodeAt(0);\n skipCodes.push(uomSeparatorToIgnore);\n }\n\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < str.length; i++) {\n const charCode = str.charCodeAt(i);\n if (Parser.isDigitOrDecimalSeparator(charCode, format)) {\n if (!processingNumber) {\n if (wipToken.length > 0) {\n tokens.push(new ParseToken(wipToken));\n wipToken = \"\";\n }\n processingNumber = true;\n }\n wipToken = wipToken.concat(str[i]);\n } else {\n if (processingNumber) {\n if (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_FRACTION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore, wipToken);\n let fraction = fractSymbol.fraction;\n i = fractSymbol.index;\n if (fractSymbol.fraction !== 0.0) {\n wipToken = \"\";\n if (signToken.length > 0) {\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(fraction));\n processingNumber = false;\n continue;\n }\n } else {\n // a space may signify end of number or start of decimal\n if (charCode === QuantityConstants.CHAR_SPACE || charCode === fractionDashCode) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore);\n let fraction = fractSymbol.fraction;\n if (fractSymbol.fraction !== 0.0) {\n i = fractSymbol.index;\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n const valueWithFraction = parseFloat(wipToken) + fraction;\n tokens.push(new ParseToken(valueWithFraction));\n processingNumber = false;\n wipToken = \"\";\n }\n continue;\n } else {\n // an \"E\" or \"e\" may signify scientific notation\n if (charCode === QuantityConstants.CHAR_UPPER_E || charCode === QuantityConstants.CHAR_LOWER_E) {\n const exponentSymbol = Parser.checkForScientificNotation(i, str, uomSeparatorToIgnore);\n i = exponentSymbol.index;\n\n if (exponentSymbol.exponent && exponentSymbol.exponent.length > 0) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n wipToken = `${wipToken}e${exponentSymbol.exponent}`;\n const scientificValue = Number(wipToken);\n tokens.push(new ParseToken(scientificValue));\n processingNumber = false;\n wipToken = \"\";\n continue;\n }\n }\n }\n }\n\n // ignore any codes in skipCodes\n if (skipCodes.findIndex((ref) => ref === charCode) !== -1)\n continue;\n\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(parseFloat(wipToken)));\n\n wipToken = (i < str.length) ? str[i] : \"\";\n processingNumber = false;\n } else {\n // not processing a number\n if ((charCode === QuantityConstants.CHAR_PLUS || charCode === QuantityConstants.CHAR_MINUS)) {\n if (0 === tokens.length) // sign token only needed for left most value\n signToken = str[i];\n continue;\n }\n\n wipToken = wipToken.concat(str[i]);\n }\n }\n }\n\n // handle case where end of input string is reached.\n if (wipToken.length > 0) {\n if (processingNumber) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n }\n tokens.push(new ParseToken(parseFloat(wipToken)));\n } else {\n tokens.push(new ParseToken(wipToken));\n }\n }\n\n return tokens;\n }\n\n private static async lookupUnitByLabel(unitLabel: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider) {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n const labelToFind = unitLabel.toLowerCase();\n // First look in format for a label and matches\n if (format.units && format.units.length > 0) {\n const formatUnit = format.units.find(([unit, label]) => {\n if (label && label.toLowerCase() === labelToFind)\n return true;\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // check any alternate labels that may be defined for the Unit\n if (alternateLabels && alternateLabels.find((lbl) => lbl.toLowerCase() === labelToFind))\n return true;\n\n return false;\n });\n if (formatUnit)\n return formatUnit[0];\n }\n\n // now try to find a unit from the same family and system\n let foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined, defaultUnit ? defaultUnit.system : undefined);\n\n // if nothing found yet just limit to family\n if (!foundUnit.isValid && defaultUnit)\n foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined);\n return foundUnit;\n }\n\n private static async createQuantityFromParseTokens(tokens: ParseToken[], format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n let defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n return new Quantity(unit);\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const unit = await this.lookupUnitByLabel(tokens[1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[0].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[1].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[1].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const unit = await this.lookupUnitByLabel(tokens[i + 1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (0 === i) {\n if (defaultUnit.name === unit.name)\n mag = value;\n else {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n mag = ((value * conversion.factor)) + conversion.offset;\n }\n } else {\n if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n }\n return new Quantity(defaultUnit, mag);\n }\n\n return new Quantity(defaultUnit);\n }\n\n /** Async method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString.\n * @param unitsProvider required to look up units that may be specified in inString\n */\n public static async parseIntoQuantity(inString: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return new Quantity();\n\n return Parser.createQuantityFromParseTokens(tokens, format, unitsProvider, altUnitLabelsProvider);\n }\n\n /** method to get the Unit Conversion given a unit label */\n private static tryFindUnitConversion(unitLabel: string, unitsConversions: UnitConversionSpec[], preferredUnit?: UnitProps): UnitConversionProps | undefined {\n if (unitsConversions.length > 0) {\n const label = unitLabel.toLocaleLowerCase();\n\n /* A preferred unit is used to target a unit if a unit label is used in more that one unit definition from the same unit family.\n * An example is if \"ft\" is used as the unitLabel and the preferredUnit is \"SURVEY_FT\" since that unit has an alternate label of \"ft\" the\n * conversion to \"SURVEY_FT\" is returned. If no preferredUnit is specified then the unit \"FT\" would likely to have been found first.\n * If \"in\" is the unit label and \"SURVEY_FT\" is the preferredUnit then conversion to \"SURVEY_IN\" would be returned.\n */\n if (preferredUnit) {\n // if there is a preferred unit defined see if unit label matched it or one of its alternates\n const preferredConversion = unitsConversions.find((conversion) => conversion.name === preferredUnit.name);\n if (preferredConversion && preferredConversion.parseLabels) {\n if (-1 !== preferredConversion.parseLabels.findIndex((lbl) => lbl === label))\n return preferredConversion.conversion;\n }\n // see if we can find a matching unitLabel in any unit within the same system as the preferred unit\n const preferredSystemConversions = unitsConversions.filter((conversion) => conversion.system === preferredUnit.system);\n for (const conversion of preferredSystemConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n }\n }\n }\n\n // if no unit found based on preferredUnit see if an unit label matches\n for (const conversion of unitsConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n } else {\n // eslint-disable-next-line no-console\n console.log(\"ERROR: Parser expects to find parseLabels array populate with all possible unit labels for the unit.\");\n }\n }\n }\n\n return undefined;\n }\n\n private static getQuantityValueFromParseTokens(tokens: ParseToken[], format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n if (defaultUnit) {\n const conversion = Parser.tryFindUnitConversion(defaultUnit.label, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n } else {\n // if no conversion or no defaultUnit, just return parsed number\n return { ok: true, value: tokens[0].value as number };\n }\n } else {\n // only the unit label was specified so assume magnitude of 1\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (undefined !== conversion)\n return { ok: true, value: conversion.factor + conversion.offset };\n else\n return { ok: false, error: ParseError.NoValueOrUnitFoundInString };\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[0].value as number };\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[1].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[1].value as number };\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const conversion = Parser.tryFindUnitConversion(tokens[i + 1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n return { ok: true, value: mag };\n }\n\n return { ok: false, error: ParseError.UnableToConvertParseTokensToQuantity };\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value.\n * @param inString A string that contains text represent a quantity.\n * @param parserSpec unit label if not explicitly defined by user. Must have matching entry in supplied array of unitsConversions.\n * @param defaultValue default value to return if parsing is un successful\n */\n public static parseQuantityString(inString: string, parserSpec: ParserSpec): QuantityParseResult {\n return Parser.parseToQuantityValue(inString, parserSpec.format, parserSpec.unitConversions);\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString. Primary unit serves as a default unit if no unit label found in string.\n * @param unitsConversions dictionary of conversions used to convert from unit used in inString to output quantity\n */\n public static parseToQuantityValue(inString: string, format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n // ensure any labels defined in composite unit definition are specified in unitConversions\n if (format.units) {\n format.units.forEach(([unit, label]) => {\n if (label) {\n if (unit.label !== label) { // if default unit label does not match composite label ensure the label is in the list of parse labels for the conversion\n const unitConversion = unitsConversions.find((conversion) => conversion.name === unit.name);\n if (unitConversion && unitConversion.parseLabels && !unitConversion.parseLabels.find((entry) => entry === label))\n unitConversion.parseLabels.push(label);\n }\n }\n });\n }\n\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return { ok: false, error: ParseError.UnableToGenerateParseTokens };\n\n if (Parser._log) {\n // eslint-disable-next-line no-console\n console.log(`Parse tokens`);\n let i = 0;\n for (const token of tokens) {\n // eslint-disable-next-line no-console\n console.log(` [${i++}] isNumber=${token.isNumber} isString=${token.isString} token=${token.value}`);\n }\n }\n\n return Parser.getQuantityValueFromParseTokens(tokens, format, unitsConversions);\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecsForUnit(unitsProvider: UnitsProvider, outUnit: UnitProps, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const familyUnits = await unitsProvider.getUnitsByFamily(outUnit.phenomenon);\n for (const unit of familyUnits) {\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecs(unitsProvider: UnitsProvider, outUnitName: string, potentialParseUnits: PotentialParseUnit[], altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const outUnit = await unitsProvider.findUnitByName(outUnitName);\n if (!outUnit || !outUnit.name || 0 === outUnit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate out unit ${outUnitName}.`);\n return unitConversionSpecs;\n }\n\n for (const potentialParseUnit of potentialParseUnits) {\n const unit = await unitsProvider.findUnitByName(potentialParseUnit.unitName);\n if (!unit || !unit.name || 0 === unit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate potential unit ${potentialParseUnit.unitName}.`);\n continue;\n }\n\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n // add any alternate labels that where provided by caller\n if (potentialParseUnit.altLabels) {\n potentialParseUnit.altLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n}\n"]}
1
+ {"version":3,"file":"Parser.js","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Quantity\n */\n\nimport { QuantityConstants } from \"./Constants\";\nimport { Format } from \"./Formatter/Format\";\nimport { FormatTraits, FormatType } from \"./Formatter/FormatEnums\";\nimport { AlternateUnitLabelsProvider, PotentialParseUnit, QuantityProps, UnitConversionProps, UnitConversionSpec, UnitProps, UnitsProvider } from \"./Interfaces\";\nimport { ParserSpec } from \"./ParserSpec\";\nimport { Quantity } from \"./Quantity\";\n\n/** Possible parser errors\n * @beta\n */\nexport enum ParseError {\n UnableToGenerateParseTokens = 1,\n NoValueOrUnitFoundInString,\n UnitLabelSuppliedButNotMatched,\n UnknownUnit,\n UnableToConvertParseTokensToQuantity,\n InvalidParserSpec,\n}\n\n/** Parse error result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParseQuantityError {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: false;\n /** The specific error that occurred during parsing. */\n error: ParseError;\n}\n\n/** Successful result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParsedQuantity {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: true;\n /** The magnitude of the parsed quantity. */\n value: number;\n}\n\n/**\n * Defines Results of parsing a string input by a user into its desired value type\n * @beta\n */\nexport type QuantityParseResult = ParsedQuantity | ParseQuantityError;\n\n/** A ParseToken holds either a numeric or string token extracted from a string that represents a quantity value.\n * @beta\n */\nclass ParseToken {\n public value: number | string;\n\n constructor(value: string | number) {\n if (typeof value === \"string\")\n this.value = value.trim();\n else\n this.value = value;\n }\n\n public get isString(): boolean { return typeof this.value === \"string\"; }\n public get isNumber(): boolean { return typeof this.value === \"number\"; }\n}\n\n/** A ScientificToken holds an index and string representing the exponent.\n * @beta\n */\nclass ScientificToken {\n public index: number;\n public exponent = \"\";\n\n constructor(index: number, exponent?: string) {\n this.index = index;\n if (exponent)\n this.exponent = exponent;\n }\n}\n\n/** A FractionToken holds an index and the fraction value of numerator / denominator.\n * @beta\n */\nclass FractionToken {\n public index: number;\n public fraction = 0.0;\n public exponent = \"\";\n\n constructor(index: number, fraction?: number) {\n this.index = index;\n if (fraction)\n this.fraction = fraction;\n }\n}\n\n/** A Parser class that is used to break a string that represents a quantity value into tokens.\n * @beta\n */\nexport class Parser {\n private static _log = false;\n\n public static isParsedQuantity(item: QuantityParseResult): item is ParsedQuantity {\n return item.ok;\n }\n\n public static isParseError(item: QuantityParseResult): item is ParseQuantityError {\n return !item.ok;\n }\n\n private static checkForScientificNotation(index: number, stringToParse: string, uomSeparatorToIgnore: number): ScientificToken {\n let exponentString = \"\";\n let i = index + 1;\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode) || ((charCode === QuantityConstants.CHAR_MINUS || charCode === QuantityConstants.CHAR_PLUS) && (i === (index + 1)))) {\n exponentString = exponentString.concat(stringToParse[i]);\n } else {\n i = uomSeparatorToIgnore === charCode ? i : i - 1;\n break;\n }\n }\n\n if (exponentString.length > 1 || ((exponentString.length === 1) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_MINUS) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_PLUS)))\n return new ScientificToken(i, exponentString);\n\n return new ScientificToken(index);\n }\n\n private static checkForFractions(index: number, stringToParse: string, uomSeparatorToIgnore: number, numeratorStr?: string): FractionToken {\n let numeratorToken = \"\";\n let denominatorToken = \"\";\n let processingNumerator = true;\n let i = index;\n if (numeratorStr && numeratorStr.length > 0) {\n numeratorToken = numeratorStr;\n processingNumerator = false;\n }\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode)) {\n if (processingNumerator) {\n numeratorToken = numeratorToken.concat(stringToParse[i]);\n } else {\n denominatorToken = denominatorToken.concat(stringToParse[i]);\n }\n } else {\n if (processingNumerator && (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH)) {\n processingNumerator = false;\n } else {\n if (uomSeparatorToIgnore !== charCode)\n i = i - 1; // skip over uom separator after fraction\n\n break;\n }\n }\n }\n\n if (numeratorToken.length > 0 && denominatorToken.length > 0) {\n const numerator = parseInt(numeratorToken, 10);\n const denominator = parseInt(denominatorToken, 10);\n if (denominator > 0)\n return new FractionToken(i, numerator / denominator);\n return new FractionToken(i);\n }\n\n return new FractionToken(index + 1);\n }\n\n private static isDigit(charCode: number): boolean {\n return (charCode >= QuantityConstants.CHAR_DIGIT_ZERO) && (charCode <= QuantityConstants.CHAR_DIGIT_NINE);\n }\n\n private static isDigitOrDecimalSeparator(charCode: number, format: Format): boolean {\n return (charCode === format.decimalSeparator.charCodeAt(0)) || Parser.isDigit(charCode);\n }\n\n /** Parse the quantity string and return and array of ParseTokens that represent the component invariant values and unit labels.\n * @param quantitySpecification The quantity string to ba parsed.\n */\n public static parseQuantitySpecification(quantitySpecification: string, format: Format): ParseToken[] {\n const tokens: ParseToken[] = [];\n const str = quantitySpecification.trim();\n let processingNumber = false;\n let wipToken = \"\";\n let signToken = \"\";\n let uomSeparatorToIgnore = 0;\n let fractionDashCode = 0;\n\n const skipCodes: number[] = [format.thousandSeparator.charCodeAt(0)];\n\n if (format.type === FormatType.Station && format.stationSeparator && format.stationSeparator.length === 1)\n skipCodes.push(format.stationSeparator.charCodeAt(0));\n\n if (format.type === FormatType.Fractional && format.hasFormatTraitSet(FormatTraits.FractionDash)) {\n fractionDashCode = QuantityConstants.CHAR_MINUS;\n }\n\n if (format.uomSeparator && format.uomSeparator !== \" \" && format.uomSeparator.length === 1) {\n uomSeparatorToIgnore = format.uomSeparator.charCodeAt(0);\n skipCodes.push(uomSeparatorToIgnore);\n }\n\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < str.length; i++) {\n const charCode = str.charCodeAt(i);\n if (Parser.isDigitOrDecimalSeparator(charCode, format)) {\n if (!processingNumber) {\n if (wipToken.length > 0) {\n tokens.push(new ParseToken(wipToken));\n wipToken = \"\";\n }\n processingNumber = true;\n }\n // Decimal separators must be replaced with '.' before converting to a number - parseFloat() only supports '.' as the decimal separator.\n const charToAdd = charCode === format.decimalSeparator.charCodeAt(0) ? \".\" : str[i];\n wipToken = wipToken.concat(charToAdd);\n } else {\n if (processingNumber) {\n if (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_FRACTION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore, wipToken);\n let fraction = fractSymbol.fraction;\n i = fractSymbol.index;\n if (fractSymbol.fraction !== 0.0) {\n wipToken = \"\";\n if (signToken.length > 0) {\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(fraction));\n processingNumber = false;\n continue;\n }\n } else {\n // a space may signify end of number or start of decimal\n if (charCode === QuantityConstants.CHAR_SPACE || charCode === fractionDashCode) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore);\n let fraction = fractSymbol.fraction;\n if (fractSymbol.fraction !== 0.0) {\n i = fractSymbol.index;\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n const valueWithFraction = parseFloat(wipToken) + fraction;\n tokens.push(new ParseToken(valueWithFraction));\n processingNumber = false;\n wipToken = \"\";\n }\n continue;\n } else {\n // an \"E\" or \"e\" may signify scientific notation\n if (charCode === QuantityConstants.CHAR_UPPER_E || charCode === QuantityConstants.CHAR_LOWER_E) {\n const exponentSymbol = Parser.checkForScientificNotation(i, str, uomSeparatorToIgnore);\n i = exponentSymbol.index;\n\n if (exponentSymbol.exponent && exponentSymbol.exponent.length > 0) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n wipToken = `${wipToken}e${exponentSymbol.exponent}`;\n const scientificValue = Number(wipToken);\n tokens.push(new ParseToken(scientificValue));\n processingNumber = false;\n wipToken = \"\";\n continue;\n }\n }\n }\n }\n\n // ignore any codes in skipCodes\n if (skipCodes.findIndex((ref) => ref === charCode) !== -1)\n continue;\n\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(parseFloat(wipToken)));\n\n wipToken = (i < str.length) ? str[i] : \"\";\n processingNumber = false;\n } else {\n // not processing a number\n if ((charCode === QuantityConstants.CHAR_PLUS || charCode === QuantityConstants.CHAR_MINUS)) {\n if (0 === tokens.length) // sign token only needed for left most value\n signToken = str[i];\n continue;\n }\n\n wipToken = wipToken.concat(str[i]);\n }\n }\n }\n\n // handle case where end of input string is reached.\n if (wipToken.length > 0) {\n if (processingNumber) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n }\n tokens.push(new ParseToken(parseFloat(wipToken)));\n } else {\n tokens.push(new ParseToken(wipToken));\n }\n }\n\n return tokens;\n }\n\n private static async lookupUnitByLabel(unitLabel: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider) {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n const labelToFind = unitLabel.toLowerCase();\n // First look in format for a label and matches\n if (format.units && format.units.length > 0) {\n const formatUnit = format.units.find(([unit, label]) => {\n if (label && label.toLowerCase() === labelToFind)\n return true;\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // check any alternate labels that may be defined for the Unit\n if (alternateLabels && alternateLabels.find((lbl) => lbl.toLowerCase() === labelToFind))\n return true;\n\n return false;\n });\n if (formatUnit)\n return formatUnit[0];\n }\n\n // now try to find a unit from the same family and system\n let foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined, defaultUnit ? defaultUnit.system : undefined);\n\n // if nothing found yet just limit to family\n if (!foundUnit.isValid && defaultUnit)\n foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined);\n return foundUnit;\n }\n\n private static async createQuantityFromParseTokens(tokens: ParseToken[], format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n let defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n return new Quantity(unit);\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const unit = await this.lookupUnitByLabel(tokens[1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[0].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[1].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[1].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const unit = await this.lookupUnitByLabel(tokens[i + 1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (0 === i) {\n if (defaultUnit.name === unit.name)\n mag = value;\n else {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n mag = ((value * conversion.factor)) + conversion.offset;\n }\n } else {\n if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n }\n return new Quantity(defaultUnit, mag);\n }\n\n return new Quantity(defaultUnit);\n }\n\n /** Async method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString.\n * @param unitsProvider required to look up units that may be specified in inString\n */\n public static async parseIntoQuantity(inString: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return new Quantity();\n\n return Parser.createQuantityFromParseTokens(tokens, format, unitsProvider, altUnitLabelsProvider);\n }\n\n /** method to get the Unit Conversion given a unit label */\n private static tryFindUnitConversion(unitLabel: string, unitsConversions: UnitConversionSpec[], preferredUnit?: UnitProps): UnitConversionProps | undefined {\n if (unitsConversions.length > 0) {\n const label = unitLabel.toLocaleLowerCase();\n\n /* A preferred unit is used to target a unit if a unit label is used in more that one unit definition from the same unit family.\n * An example is if \"ft\" is used as the unitLabel and the preferredUnit is \"SURVEY_FT\" since that unit has an alternate label of \"ft\" the\n * conversion to \"SURVEY_FT\" is returned. If no preferredUnit is specified then the unit \"FT\" would likely to have been found first.\n * If \"in\" is the unit label and \"SURVEY_FT\" is the preferredUnit then conversion to \"SURVEY_IN\" would be returned.\n */\n if (preferredUnit) {\n // if there is a preferred unit defined see if unit label matched it or one of its alternates\n const preferredConversion = unitsConversions.find((conversion) => conversion.name === preferredUnit.name);\n if (preferredConversion && preferredConversion.parseLabels) {\n if (-1 !== preferredConversion.parseLabels.findIndex((lbl) => lbl === label))\n return preferredConversion.conversion;\n }\n // see if we can find a matching unitLabel in any unit within the same system as the preferred unit\n const preferredSystemConversions = unitsConversions.filter((conversion) => conversion.system === preferredUnit.system);\n for (const conversion of preferredSystemConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n }\n }\n }\n\n // if no unit found based on preferredUnit see if an unit label matches\n for (const conversion of unitsConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n } else {\n // eslint-disable-next-line no-console\n console.log(\"ERROR: Parser expects to find parseLabels array populate with all possible unit labels for the unit.\");\n }\n }\n }\n\n return undefined;\n }\n\n private static getQuantityValueFromParseTokens(tokens: ParseToken[], format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n if (defaultUnit) {\n const conversion = Parser.tryFindUnitConversion(defaultUnit.label, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n } else {\n // if no conversion or no defaultUnit, just return parsed number\n return { ok: true, value: tokens[0].value as number };\n }\n } else {\n // only the unit label was specified so assume magnitude of 1\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (undefined !== conversion)\n return { ok: true, value: conversion.factor + conversion.offset };\n else\n return { ok: false, error: ParseError.NoValueOrUnitFoundInString };\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[0].value as number };\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[1].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[1].value as number };\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const conversion = Parser.tryFindUnitConversion(tokens[i + 1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n return { ok: true, value: mag };\n }\n\n return { ok: false, error: ParseError.UnableToConvertParseTokensToQuantity };\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value.\n * @param inString A string that contains text represent a quantity.\n * @param parserSpec unit label if not explicitly defined by user. Must have matching entry in supplied array of unitsConversions.\n * @param defaultValue default value to return if parsing is un successful\n */\n public static parseQuantityString(inString: string, parserSpec: ParserSpec): QuantityParseResult {\n return Parser.parseToQuantityValue(inString, parserSpec.format, parserSpec.unitConversions);\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString. Primary unit serves as a default unit if no unit label found in string.\n * @param unitsConversions dictionary of conversions used to convert from unit used in inString to output quantity\n */\n public static parseToQuantityValue(inString: string, format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n // ensure any labels defined in composite unit definition are specified in unitConversions\n if (format.units) {\n format.units.forEach(([unit, label]) => {\n if (label) {\n if (unit.label !== label) { // if default unit label does not match composite label ensure the label is in the list of parse labels for the conversion\n const unitConversion = unitsConversions.find((conversion) => conversion.name === unit.name);\n if (unitConversion && unitConversion.parseLabels && !unitConversion.parseLabels.find((entry) => entry === label))\n unitConversion.parseLabels.push(label);\n }\n }\n });\n }\n\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return { ok: false, error: ParseError.UnableToGenerateParseTokens };\n\n if (Parser._log) {\n // eslint-disable-next-line no-console\n console.log(`Parse tokens`);\n let i = 0;\n for (const token of tokens) {\n // eslint-disable-next-line no-console\n console.log(` [${i++}] isNumber=${token.isNumber} isString=${token.isString} token=${token.value}`);\n }\n }\n\n return Parser.getQuantityValueFromParseTokens(tokens, format, unitsConversions);\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecsForUnit(unitsProvider: UnitsProvider, outUnit: UnitProps, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const familyUnits = await unitsProvider.getUnitsByFamily(outUnit.phenomenon);\n for (const unit of familyUnits) {\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecs(unitsProvider: UnitsProvider, outUnitName: string, potentialParseUnits: PotentialParseUnit[], altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const outUnit = await unitsProvider.findUnitByName(outUnitName);\n if (!outUnit || !outUnit.name || 0 === outUnit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate out unit ${outUnitName}.`);\n return unitConversionSpecs;\n }\n\n for (const potentialParseUnit of potentialParseUnits) {\n const unit = await unitsProvider.findUnitByName(potentialParseUnit.unitName);\n if (!unit || !unit.name || 0 === unit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate potential unit ${potentialParseUnit.unitName}.`);\n continue;\n }\n\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n // add any alternate labels that where provided by caller\n if (potentialParseUnit.altLabels) {\n potentialParseUnit.altLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"Parser.d.ts","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAE,2BAA2B,EAAE,kBAAkB,EAAE,aAAa,EAAuB,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AACjK,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C;;GAEG;AACH,oBAAY,UAAU;IACpB,2BAA2B,IAAI;IAC/B,0BAA0B,IAAA;IAC1B,8BAA8B,IAAA;IAC9B,WAAW,IAAA;IACX,oCAAoC,IAAA;IACpC,iBAAiB,IAAA;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,uDAAuD;IACvD,EAAE,EAAE,KAAK,CAAC;IACV,uDAAuD;IACvD,KAAK,EAAE,UAAU,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,uDAAuD;IACvD,EAAE,EAAE,IAAI,CAAC;IACT,4CAA4C;IAC5C,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;;GAGG;AACH,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAAG,kBAAkB,CAAC;AAEtE;;GAEG;AACH,cAAM,UAAU;IACP,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;gBAElB,KAAK,EAAE,MAAM,GAAG,MAAM;IAOlC,IAAW,QAAQ,IAAI,OAAO,CAA2C;IACzE,IAAW,QAAQ,IAAI,OAAO,CAA2C;CAC1E;AA+BD;;GAEG;AACH,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAS;WAEd,gBAAgB,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,cAAc;WAInE,YAAY,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,kBAAkB;IAIjF,OAAO,CAAC,MAAM,CAAC,0BAA0B;IAoBzC,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAyChC,OAAO,CAAC,MAAM,CAAC,OAAO;IAItB,OAAO,CAAC,MAAM,CAAC,yBAAyB;IAIxC;;OAEG;WACW,0BAA0B,CAAC,qBAAqB,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,UAAU,EAAE;mBA2IhF,iBAAiB;mBA6BjB,6BAA6B;IA2ElD;;;;OAIG;WACiB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,aAAa,CAAC;IAQlL,2DAA2D;IAC3D,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAyCpC,OAAO,CAAC,MAAM,CAAC,+BAA+B;IAqE9C;;;;OAIG;WACW,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,GAAG,mBAAmB;IAIhG;;;;OAIG;WACW,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,GAAG,mBAAmB;IA+BjI,+HAA+H;WAC3G,gCAAgC,CAAC,aAAa,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;IA4B1L,+HAA+H;WAC3G,yBAAyB,CAAC,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAgDhO"}
1
+ {"version":3,"file":"Parser.d.ts","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,OAAO,EAAE,2BAA2B,EAAE,kBAAkB,EAAE,aAAa,EAAuB,kBAAkB,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AACjK,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C;;GAEG;AACH,oBAAY,UAAU;IACpB,2BAA2B,IAAI;IAC/B,0BAA0B,IAAA;IAC1B,8BAA8B,IAAA;IAC9B,WAAW,IAAA;IACX,oCAAoC,IAAA;IACpC,iBAAiB,IAAA;CAClB;AAED;;GAEG;AACH,MAAM,WAAW,kBAAkB;IACjC,uDAAuD;IACvD,EAAE,EAAE,KAAK,CAAC;IACV,uDAAuD;IACvD,KAAK,EAAE,UAAU,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,cAAc;IAC7B,uDAAuD;IACvD,EAAE,EAAE,IAAI,CAAC;IACT,4CAA4C;IAC5C,KAAK,EAAE,MAAM,CAAC;CACf;AAED;;;GAGG;AACH,MAAM,MAAM,mBAAmB,GAAG,cAAc,GAAG,kBAAkB,CAAC;AAEtE;;GAEG;AACH,cAAM,UAAU;IACP,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;gBAElB,KAAK,EAAE,MAAM,GAAG,MAAM;IAOlC,IAAW,QAAQ,IAAI,OAAO,CAA2C;IACzE,IAAW,QAAQ,IAAI,OAAO,CAA2C;CAC1E;AA+BD;;GAEG;AACH,qBAAa,MAAM;IACjB,OAAO,CAAC,MAAM,CAAC,IAAI,CAAS;WAEd,gBAAgB,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,cAAc;WAInE,YAAY,CAAC,IAAI,EAAE,mBAAmB,GAAG,IAAI,IAAI,kBAAkB;IAIjF,OAAO,CAAC,MAAM,CAAC,0BAA0B;IAoBzC,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAyChC,OAAO,CAAC,MAAM,CAAC,OAAO;IAItB,OAAO,CAAC,MAAM,CAAC,yBAAyB;IAIxC;;OAEG;WACW,0BAA0B,CAAC,qBAAqB,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,UAAU,EAAE;mBA6IhF,iBAAiB;mBA6BjB,6BAA6B;IA2ElD;;;;OAIG;WACiB,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,aAAa,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,aAAa,CAAC;IAQlL,2DAA2D;IAC3D,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAyCpC,OAAO,CAAC,MAAM,CAAC,+BAA+B;IAqE9C;;;;OAIG;WACW,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,EAAE,UAAU,GAAG,mBAAmB;IAIhG;;;;OAIG;WACW,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,GAAG,mBAAmB;IA+BjI,+HAA+H;WAC3G,gCAAgC,CAAC,aAAa,EAAE,aAAa,EAAE,OAAO,EAAE,SAAS,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;IA4B1L,+HAA+H;WAC3G,yBAAyB,CAAC,aAAa,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,EAAE,qBAAqB,CAAC,EAAE,2BAA2B,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAgDhO"}
package/lib/esm/Parser.js CHANGED
@@ -160,7 +160,9 @@ class Parser {
160
160
  }
161
161
  processingNumber = true;
162
162
  }
163
- wipToken = wipToken.concat(str[i]);
163
+ // Decimal separators must be replaced with '.' before converting to a number - parseFloat() only supports '.' as the decimal separator.
164
+ const charToAdd = charCode === format.decimalSeparator.charCodeAt(0) ? "." : str[i];
165
+ wipToken = wipToken.concat(charToAdd);
164
166
  }
165
167
  else {
166
168
  if (processingNumber) {
@@ -1 +1 @@
1
- {"version":3,"file":"Parser.js","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Quantity\n */\n\nimport { QuantityConstants } from \"./Constants\";\nimport { Format } from \"./Formatter/Format\";\nimport { FormatTraits, FormatType } from \"./Formatter/FormatEnums\";\nimport { AlternateUnitLabelsProvider, PotentialParseUnit, QuantityProps, UnitConversionProps, UnitConversionSpec, UnitProps, UnitsProvider } from \"./Interfaces\";\nimport { ParserSpec } from \"./ParserSpec\";\nimport { Quantity } from \"./Quantity\";\n\n/** Possible parser errors\n * @beta\n */\nexport enum ParseError {\n UnableToGenerateParseTokens = 1,\n NoValueOrUnitFoundInString,\n UnitLabelSuppliedButNotMatched,\n UnknownUnit,\n UnableToConvertParseTokensToQuantity,\n InvalidParserSpec,\n}\n\n/** Parse error result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParseQuantityError {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: false;\n /** The specific error that occurred during parsing. */\n error: ParseError;\n}\n\n/** Successful result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParsedQuantity {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: true;\n /** The magnitude of the parsed quantity. */\n value: number;\n}\n\n/**\n * Defines Results of parsing a string input by a user into its desired value type\n * @beta\n */\nexport type QuantityParseResult = ParsedQuantity | ParseQuantityError;\n\n/** A ParseToken holds either a numeric or string token extracted from a string that represents a quantity value.\n * @beta\n */\nclass ParseToken {\n public value: number | string;\n\n constructor(value: string | number) {\n if (typeof value === \"string\")\n this.value = value.trim();\n else\n this.value = value;\n }\n\n public get isString(): boolean { return typeof this.value === \"string\"; }\n public get isNumber(): boolean { return typeof this.value === \"number\"; }\n}\n\n/** A ScientificToken holds an index and string representing the exponent.\n * @beta\n */\nclass ScientificToken {\n public index: number;\n public exponent = \"\";\n\n constructor(index: number, exponent?: string) {\n this.index = index;\n if (exponent)\n this.exponent = exponent;\n }\n}\n\n/** A FractionToken holds an index and the fraction value of numerator / denominator.\n * @beta\n */\nclass FractionToken {\n public index: number;\n public fraction = 0.0;\n public exponent = \"\";\n\n constructor(index: number, fraction?: number) {\n this.index = index;\n if (fraction)\n this.fraction = fraction;\n }\n}\n\n/** A Parser class that is used to break a string that represents a quantity value into tokens.\n * @beta\n */\nexport class Parser {\n private static _log = false;\n\n public static isParsedQuantity(item: QuantityParseResult): item is ParsedQuantity {\n return item.ok;\n }\n\n public static isParseError(item: QuantityParseResult): item is ParseQuantityError {\n return !item.ok;\n }\n\n private static checkForScientificNotation(index: number, stringToParse: string, uomSeparatorToIgnore: number): ScientificToken {\n let exponentString = \"\";\n let i = index + 1;\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode) || ((charCode === QuantityConstants.CHAR_MINUS || charCode === QuantityConstants.CHAR_PLUS) && (i === (index + 1)))) {\n exponentString = exponentString.concat(stringToParse[i]);\n } else {\n i = uomSeparatorToIgnore === charCode ? i : i - 1;\n break;\n }\n }\n\n if (exponentString.length > 1 || ((exponentString.length === 1) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_MINUS) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_PLUS)))\n return new ScientificToken(i, exponentString);\n\n return new ScientificToken(index);\n }\n\n private static checkForFractions(index: number, stringToParse: string, uomSeparatorToIgnore: number, numeratorStr?: string): FractionToken {\n let numeratorToken = \"\";\n let denominatorToken = \"\";\n let processingNumerator = true;\n let i = index;\n if (numeratorStr && numeratorStr.length > 0) {\n numeratorToken = numeratorStr;\n processingNumerator = false;\n }\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode)) {\n if (processingNumerator) {\n numeratorToken = numeratorToken.concat(stringToParse[i]);\n } else {\n denominatorToken = denominatorToken.concat(stringToParse[i]);\n }\n } else {\n if (processingNumerator && (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH)) {\n processingNumerator = false;\n } else {\n if (uomSeparatorToIgnore !== charCode)\n i = i - 1; // skip over uom separator after fraction\n\n break;\n }\n }\n }\n\n if (numeratorToken.length > 0 && denominatorToken.length > 0) {\n const numerator = parseInt(numeratorToken, 10);\n const denominator = parseInt(denominatorToken, 10);\n if (denominator > 0)\n return new FractionToken(i, numerator / denominator);\n return new FractionToken(i);\n }\n\n return new FractionToken(index + 1);\n }\n\n private static isDigit(charCode: number): boolean {\n return (charCode >= QuantityConstants.CHAR_DIGIT_ZERO) && (charCode <= QuantityConstants.CHAR_DIGIT_NINE);\n }\n\n private static isDigitOrDecimalSeparator(charCode: number, format: Format): boolean {\n return (charCode === format.decimalSeparator.charCodeAt(0)) || Parser.isDigit(charCode);\n }\n\n /** Parse the quantity string and return and array of ParseTokens that represent the component invariant values and unit labels.\n * @param quantitySpecification The quantity string to ba parsed.\n */\n public static parseQuantitySpecification(quantitySpecification: string, format: Format): ParseToken[] {\n const tokens: ParseToken[] = [];\n const str = quantitySpecification.trim();\n let processingNumber = false;\n let wipToken = \"\";\n let signToken = \"\";\n let uomSeparatorToIgnore = 0;\n let fractionDashCode = 0;\n\n const skipCodes: number[] = [format.thousandSeparator.charCodeAt(0)];\n\n if (format.type === FormatType.Station && format.stationSeparator && format.stationSeparator.length === 1)\n skipCodes.push(format.stationSeparator.charCodeAt(0));\n\n if (format.type === FormatType.Fractional && format.hasFormatTraitSet(FormatTraits.FractionDash)) {\n fractionDashCode = QuantityConstants.CHAR_MINUS;\n }\n\n if (format.uomSeparator && format.uomSeparator !== \" \" && format.uomSeparator.length === 1) {\n uomSeparatorToIgnore = format.uomSeparator.charCodeAt(0);\n skipCodes.push(uomSeparatorToIgnore);\n }\n\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < str.length; i++) {\n const charCode = str.charCodeAt(i);\n if (Parser.isDigitOrDecimalSeparator(charCode, format)) {\n if (!processingNumber) {\n if (wipToken.length > 0) {\n tokens.push(new ParseToken(wipToken));\n wipToken = \"\";\n }\n processingNumber = true;\n }\n wipToken = wipToken.concat(str[i]);\n } else {\n if (processingNumber) {\n if (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_FRACTION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore, wipToken);\n let fraction = fractSymbol.fraction;\n i = fractSymbol.index;\n if (fractSymbol.fraction !== 0.0) {\n wipToken = \"\";\n if (signToken.length > 0) {\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(fraction));\n processingNumber = false;\n continue;\n }\n } else {\n // a space may signify end of number or start of decimal\n if (charCode === QuantityConstants.CHAR_SPACE || charCode === fractionDashCode) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore);\n let fraction = fractSymbol.fraction;\n if (fractSymbol.fraction !== 0.0) {\n i = fractSymbol.index;\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n const valueWithFraction = parseFloat(wipToken) + fraction;\n tokens.push(new ParseToken(valueWithFraction));\n processingNumber = false;\n wipToken = \"\";\n }\n continue;\n } else {\n // an \"E\" or \"e\" may signify scientific notation\n if (charCode === QuantityConstants.CHAR_UPPER_E || charCode === QuantityConstants.CHAR_LOWER_E) {\n const exponentSymbol = Parser.checkForScientificNotation(i, str, uomSeparatorToIgnore);\n i = exponentSymbol.index;\n\n if (exponentSymbol.exponent && exponentSymbol.exponent.length > 0) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n wipToken = `${wipToken}e${exponentSymbol.exponent}`;\n const scientificValue = Number(wipToken);\n tokens.push(new ParseToken(scientificValue));\n processingNumber = false;\n wipToken = \"\";\n continue;\n }\n }\n }\n }\n\n // ignore any codes in skipCodes\n if (skipCodes.findIndex((ref) => ref === charCode) !== -1)\n continue;\n\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(parseFloat(wipToken)));\n\n wipToken = (i < str.length) ? str[i] : \"\";\n processingNumber = false;\n } else {\n // not processing a number\n if ((charCode === QuantityConstants.CHAR_PLUS || charCode === QuantityConstants.CHAR_MINUS)) {\n if (0 === tokens.length) // sign token only needed for left most value\n signToken = str[i];\n continue;\n }\n\n wipToken = wipToken.concat(str[i]);\n }\n }\n }\n\n // handle case where end of input string is reached.\n if (wipToken.length > 0) {\n if (processingNumber) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n }\n tokens.push(new ParseToken(parseFloat(wipToken)));\n } else {\n tokens.push(new ParseToken(wipToken));\n }\n }\n\n return tokens;\n }\n\n private static async lookupUnitByLabel(unitLabel: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider) {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n const labelToFind = unitLabel.toLowerCase();\n // First look in format for a label and matches\n if (format.units && format.units.length > 0) {\n const formatUnit = format.units.find(([unit, label]) => {\n if (label && label.toLowerCase() === labelToFind)\n return true;\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // check any alternate labels that may be defined for the Unit\n if (alternateLabels && alternateLabels.find((lbl) => lbl.toLowerCase() === labelToFind))\n return true;\n\n return false;\n });\n if (formatUnit)\n return formatUnit[0];\n }\n\n // now try to find a unit from the same family and system\n let foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined, defaultUnit ? defaultUnit.system : undefined);\n\n // if nothing found yet just limit to family\n if (!foundUnit.isValid && defaultUnit)\n foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined);\n return foundUnit;\n }\n\n private static async createQuantityFromParseTokens(tokens: ParseToken[], format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n let defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n return new Quantity(unit);\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const unit = await this.lookupUnitByLabel(tokens[1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[0].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[1].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[1].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const unit = await this.lookupUnitByLabel(tokens[i + 1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (0 === i) {\n if (defaultUnit.name === unit.name)\n mag = value;\n else {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n mag = ((value * conversion.factor)) + conversion.offset;\n }\n } else {\n if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n }\n return new Quantity(defaultUnit, mag);\n }\n\n return new Quantity(defaultUnit);\n }\n\n /** Async method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString.\n * @param unitsProvider required to look up units that may be specified in inString\n */\n public static async parseIntoQuantity(inString: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return new Quantity();\n\n return Parser.createQuantityFromParseTokens(tokens, format, unitsProvider, altUnitLabelsProvider);\n }\n\n /** method to get the Unit Conversion given a unit label */\n private static tryFindUnitConversion(unitLabel: string, unitsConversions: UnitConversionSpec[], preferredUnit?: UnitProps): UnitConversionProps | undefined {\n if (unitsConversions.length > 0) {\n const label = unitLabel.toLocaleLowerCase();\n\n /* A preferred unit is used to target a unit if a unit label is used in more that one unit definition from the same unit family.\n * An example is if \"ft\" is used as the unitLabel and the preferredUnit is \"SURVEY_FT\" since that unit has an alternate label of \"ft\" the\n * conversion to \"SURVEY_FT\" is returned. If no preferredUnit is specified then the unit \"FT\" would likely to have been found first.\n * If \"in\" is the unit label and \"SURVEY_FT\" is the preferredUnit then conversion to \"SURVEY_IN\" would be returned.\n */\n if (preferredUnit) {\n // if there is a preferred unit defined see if unit label matched it or one of its alternates\n const preferredConversion = unitsConversions.find((conversion) => conversion.name === preferredUnit.name);\n if (preferredConversion && preferredConversion.parseLabels) {\n if (-1 !== preferredConversion.parseLabels.findIndex((lbl) => lbl === label))\n return preferredConversion.conversion;\n }\n // see if we can find a matching unitLabel in any unit within the same system as the preferred unit\n const preferredSystemConversions = unitsConversions.filter((conversion) => conversion.system === preferredUnit.system);\n for (const conversion of preferredSystemConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n }\n }\n }\n\n // if no unit found based on preferredUnit see if an unit label matches\n for (const conversion of unitsConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n } else {\n // eslint-disable-next-line no-console\n console.log(\"ERROR: Parser expects to find parseLabels array populate with all possible unit labels for the unit.\");\n }\n }\n }\n\n return undefined;\n }\n\n private static getQuantityValueFromParseTokens(tokens: ParseToken[], format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n if (defaultUnit) {\n const conversion = Parser.tryFindUnitConversion(defaultUnit.label, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n } else {\n // if no conversion or no defaultUnit, just return parsed number\n return { ok: true, value: tokens[0].value as number };\n }\n } else {\n // only the unit label was specified so assume magnitude of 1\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (undefined !== conversion)\n return { ok: true, value: conversion.factor + conversion.offset };\n else\n return { ok: false, error: ParseError.NoValueOrUnitFoundInString };\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[0].value as number };\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[1].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[1].value as number };\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const conversion = Parser.tryFindUnitConversion(tokens[i + 1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n return { ok: true, value: mag };\n }\n\n return { ok: false, error: ParseError.UnableToConvertParseTokensToQuantity };\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value.\n * @param inString A string that contains text represent a quantity.\n * @param parserSpec unit label if not explicitly defined by user. Must have matching entry in supplied array of unitsConversions.\n * @param defaultValue default value to return if parsing is un successful\n */\n public static parseQuantityString(inString: string, parserSpec: ParserSpec): QuantityParseResult {\n return Parser.parseToQuantityValue(inString, parserSpec.format, parserSpec.unitConversions);\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString. Primary unit serves as a default unit if no unit label found in string.\n * @param unitsConversions dictionary of conversions used to convert from unit used in inString to output quantity\n */\n public static parseToQuantityValue(inString: string, format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n // ensure any labels defined in composite unit definition are specified in unitConversions\n if (format.units) {\n format.units.forEach(([unit, label]) => {\n if (label) {\n if (unit.label !== label) { // if default unit label does not match composite label ensure the label is in the list of parse labels for the conversion\n const unitConversion = unitsConversions.find((conversion) => conversion.name === unit.name);\n if (unitConversion && unitConversion.parseLabels && !unitConversion.parseLabels.find((entry) => entry === label))\n unitConversion.parseLabels.push(label);\n }\n }\n });\n }\n\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return { ok: false, error: ParseError.UnableToGenerateParseTokens };\n\n if (Parser._log) {\n // eslint-disable-next-line no-console\n console.log(`Parse tokens`);\n let i = 0;\n for (const token of tokens) {\n // eslint-disable-next-line no-console\n console.log(` [${i++}] isNumber=${token.isNumber} isString=${token.isString} token=${token.value}`);\n }\n }\n\n return Parser.getQuantityValueFromParseTokens(tokens, format, unitsConversions);\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecsForUnit(unitsProvider: UnitsProvider, outUnit: UnitProps, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const familyUnits = await unitsProvider.getUnitsByFamily(outUnit.phenomenon);\n for (const unit of familyUnits) {\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecs(unitsProvider: UnitsProvider, outUnitName: string, potentialParseUnits: PotentialParseUnit[], altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const outUnit = await unitsProvider.findUnitByName(outUnitName);\n if (!outUnit || !outUnit.name || 0 === outUnit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate out unit ${outUnitName}.`);\n return unitConversionSpecs;\n }\n\n for (const potentialParseUnit of potentialParseUnits) {\n const unit = await unitsProvider.findUnitByName(potentialParseUnit.unitName);\n if (!unit || !unit.name || 0 === unit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate potential unit ${potentialParseUnit.unitName}.`);\n continue;\n }\n\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n // add any alternate labels that where provided by caller\n if (potentialParseUnit.altLabels) {\n potentialParseUnit.altLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n}\n"]}
1
+ {"version":3,"file":"Parser.js","sourceRoot":"","sources":["../../src/Parser.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Quantity\n */\n\nimport { QuantityConstants } from \"./Constants\";\nimport { Format } from \"./Formatter/Format\";\nimport { FormatTraits, FormatType } from \"./Formatter/FormatEnums\";\nimport { AlternateUnitLabelsProvider, PotentialParseUnit, QuantityProps, UnitConversionProps, UnitConversionSpec, UnitProps, UnitsProvider } from \"./Interfaces\";\nimport { ParserSpec } from \"./ParserSpec\";\nimport { Quantity } from \"./Quantity\";\n\n/** Possible parser errors\n * @beta\n */\nexport enum ParseError {\n UnableToGenerateParseTokens = 1,\n NoValueOrUnitFoundInString,\n UnitLabelSuppliedButNotMatched,\n UnknownUnit,\n UnableToConvertParseTokensToQuantity,\n InvalidParserSpec,\n}\n\n/** Parse error result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParseQuantityError {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: false;\n /** The specific error that occurred during parsing. */\n error: ParseError;\n}\n\n/** Successful result from [[Parser.parseToQuantityValue]] or [[Parser.parseToQuantityValue]].\n * @beta\n */\nexport interface ParsedQuantity {\n /** Union discriminator for [[QuantityParseResult]]. */\n ok: true;\n /** The magnitude of the parsed quantity. */\n value: number;\n}\n\n/**\n * Defines Results of parsing a string input by a user into its desired value type\n * @beta\n */\nexport type QuantityParseResult = ParsedQuantity | ParseQuantityError;\n\n/** A ParseToken holds either a numeric or string token extracted from a string that represents a quantity value.\n * @beta\n */\nclass ParseToken {\n public value: number | string;\n\n constructor(value: string | number) {\n if (typeof value === \"string\")\n this.value = value.trim();\n else\n this.value = value;\n }\n\n public get isString(): boolean { return typeof this.value === \"string\"; }\n public get isNumber(): boolean { return typeof this.value === \"number\"; }\n}\n\n/** A ScientificToken holds an index and string representing the exponent.\n * @beta\n */\nclass ScientificToken {\n public index: number;\n public exponent = \"\";\n\n constructor(index: number, exponent?: string) {\n this.index = index;\n if (exponent)\n this.exponent = exponent;\n }\n}\n\n/** A FractionToken holds an index and the fraction value of numerator / denominator.\n * @beta\n */\nclass FractionToken {\n public index: number;\n public fraction = 0.0;\n public exponent = \"\";\n\n constructor(index: number, fraction?: number) {\n this.index = index;\n if (fraction)\n this.fraction = fraction;\n }\n}\n\n/** A Parser class that is used to break a string that represents a quantity value into tokens.\n * @beta\n */\nexport class Parser {\n private static _log = false;\n\n public static isParsedQuantity(item: QuantityParseResult): item is ParsedQuantity {\n return item.ok;\n }\n\n public static isParseError(item: QuantityParseResult): item is ParseQuantityError {\n return !item.ok;\n }\n\n private static checkForScientificNotation(index: number, stringToParse: string, uomSeparatorToIgnore: number): ScientificToken {\n let exponentString = \"\";\n let i = index + 1;\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode) || ((charCode === QuantityConstants.CHAR_MINUS || charCode === QuantityConstants.CHAR_PLUS) && (i === (index + 1)))) {\n exponentString = exponentString.concat(stringToParse[i]);\n } else {\n i = uomSeparatorToIgnore === charCode ? i : i - 1;\n break;\n }\n }\n\n if (exponentString.length > 1 || ((exponentString.length === 1) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_MINUS) && (exponentString.charCodeAt(0) !== QuantityConstants.CHAR_PLUS)))\n return new ScientificToken(i, exponentString);\n\n return new ScientificToken(index);\n }\n\n private static checkForFractions(index: number, stringToParse: string, uomSeparatorToIgnore: number, numeratorStr?: string): FractionToken {\n let numeratorToken = \"\";\n let denominatorToken = \"\";\n let processingNumerator = true;\n let i = index;\n if (numeratorStr && numeratorStr.length > 0) {\n numeratorToken = numeratorStr;\n processingNumerator = false;\n }\n\n for (; i < stringToParse.length; i++) {\n const charCode = stringToParse.charCodeAt(i);\n if (Parser.isDigit(charCode)) {\n if (processingNumerator) {\n numeratorToken = numeratorToken.concat(stringToParse[i]);\n } else {\n denominatorToken = denominatorToken.concat(stringToParse[i]);\n }\n } else {\n if (processingNumerator && (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH)) {\n processingNumerator = false;\n } else {\n if (uomSeparatorToIgnore !== charCode)\n i = i - 1; // skip over uom separator after fraction\n\n break;\n }\n }\n }\n\n if (numeratorToken.length > 0 && denominatorToken.length > 0) {\n const numerator = parseInt(numeratorToken, 10);\n const denominator = parseInt(denominatorToken, 10);\n if (denominator > 0)\n return new FractionToken(i, numerator / denominator);\n return new FractionToken(i);\n }\n\n return new FractionToken(index + 1);\n }\n\n private static isDigit(charCode: number): boolean {\n return (charCode >= QuantityConstants.CHAR_DIGIT_ZERO) && (charCode <= QuantityConstants.CHAR_DIGIT_NINE);\n }\n\n private static isDigitOrDecimalSeparator(charCode: number, format: Format): boolean {\n return (charCode === format.decimalSeparator.charCodeAt(0)) || Parser.isDigit(charCode);\n }\n\n /** Parse the quantity string and return and array of ParseTokens that represent the component invariant values and unit labels.\n * @param quantitySpecification The quantity string to ba parsed.\n */\n public static parseQuantitySpecification(quantitySpecification: string, format: Format): ParseToken[] {\n const tokens: ParseToken[] = [];\n const str = quantitySpecification.trim();\n let processingNumber = false;\n let wipToken = \"\";\n let signToken = \"\";\n let uomSeparatorToIgnore = 0;\n let fractionDashCode = 0;\n\n const skipCodes: number[] = [format.thousandSeparator.charCodeAt(0)];\n\n if (format.type === FormatType.Station && format.stationSeparator && format.stationSeparator.length === 1)\n skipCodes.push(format.stationSeparator.charCodeAt(0));\n\n if (format.type === FormatType.Fractional && format.hasFormatTraitSet(FormatTraits.FractionDash)) {\n fractionDashCode = QuantityConstants.CHAR_MINUS;\n }\n\n if (format.uomSeparator && format.uomSeparator !== \" \" && format.uomSeparator.length === 1) {\n uomSeparatorToIgnore = format.uomSeparator.charCodeAt(0);\n skipCodes.push(uomSeparatorToIgnore);\n }\n\n // eslint-disable-next-line @typescript-eslint/prefer-for-of\n for (let i = 0; i < str.length; i++) {\n const charCode = str.charCodeAt(i);\n if (Parser.isDigitOrDecimalSeparator(charCode, format)) {\n if (!processingNumber) {\n if (wipToken.length > 0) {\n tokens.push(new ParseToken(wipToken));\n wipToken = \"\";\n }\n processingNumber = true;\n }\n // Decimal separators must be replaced with '.' before converting to a number - parseFloat() only supports '.' as the decimal separator.\n const charToAdd = charCode === format.decimalSeparator.charCodeAt(0) ? \".\" : str[i];\n wipToken = wipToken.concat(charToAdd);\n } else {\n if (processingNumber) {\n if (charCode === QuantityConstants.CHAR_SLASH || charCode === QuantityConstants.CHAR_FRACTION_SLASH || charCode === QuantityConstants.CHAR_DIVISION_SLASH) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore, wipToken);\n let fraction = fractSymbol.fraction;\n i = fractSymbol.index;\n if (fractSymbol.fraction !== 0.0) {\n wipToken = \"\";\n if (signToken.length > 0) {\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(fraction));\n processingNumber = false;\n continue;\n }\n } else {\n // a space may signify end of number or start of decimal\n if (charCode === QuantityConstants.CHAR_SPACE || charCode === fractionDashCode) {\n const fractSymbol = Parser.checkForFractions(i + 1, str, uomSeparatorToIgnore);\n let fraction = fractSymbol.fraction;\n if (fractSymbol.fraction !== 0.0) {\n i = fractSymbol.index;\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n if (signToken === \"-\")\n fraction = 0 - fraction;\n\n signToken = \"\";\n }\n\n const valueWithFraction = parseFloat(wipToken) + fraction;\n tokens.push(new ParseToken(valueWithFraction));\n processingNumber = false;\n wipToken = \"\";\n }\n continue;\n } else {\n // an \"E\" or \"e\" may signify scientific notation\n if (charCode === QuantityConstants.CHAR_UPPER_E || charCode === QuantityConstants.CHAR_LOWER_E) {\n const exponentSymbol = Parser.checkForScientificNotation(i, str, uomSeparatorToIgnore);\n i = exponentSymbol.index;\n\n if (exponentSymbol.exponent && exponentSymbol.exponent.length > 0) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n wipToken = `${wipToken}e${exponentSymbol.exponent}`;\n const scientificValue = Number(wipToken);\n tokens.push(new ParseToken(scientificValue));\n processingNumber = false;\n wipToken = \"\";\n continue;\n }\n }\n }\n }\n\n // ignore any codes in skipCodes\n if (skipCodes.findIndex((ref) => ref === charCode) !== -1)\n continue;\n\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n signToken = \"\";\n }\n\n tokens.push(new ParseToken(parseFloat(wipToken)));\n\n wipToken = (i < str.length) ? str[i] : \"\";\n processingNumber = false;\n } else {\n // not processing a number\n if ((charCode === QuantityConstants.CHAR_PLUS || charCode === QuantityConstants.CHAR_MINUS)) {\n if (0 === tokens.length) // sign token only needed for left most value\n signToken = str[i];\n continue;\n }\n\n wipToken = wipToken.concat(str[i]);\n }\n }\n }\n\n // handle case where end of input string is reached.\n if (wipToken.length > 0) {\n if (processingNumber) {\n if (signToken.length > 0) {\n wipToken = signToken + wipToken;\n }\n tokens.push(new ParseToken(parseFloat(wipToken)));\n } else {\n tokens.push(new ParseToken(wipToken));\n }\n }\n\n return tokens;\n }\n\n private static async lookupUnitByLabel(unitLabel: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider) {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n const labelToFind = unitLabel.toLowerCase();\n // First look in format for a label and matches\n if (format.units && format.units.length > 0) {\n const formatUnit = format.units.find(([unit, label]) => {\n if (label && label.toLowerCase() === labelToFind)\n return true;\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // check any alternate labels that may be defined for the Unit\n if (alternateLabels && alternateLabels.find((lbl) => lbl.toLowerCase() === labelToFind))\n return true;\n\n return false;\n });\n if (formatUnit)\n return formatUnit[0];\n }\n\n // now try to find a unit from the same family and system\n let foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined, defaultUnit ? defaultUnit.system : undefined);\n\n // if nothing found yet just limit to family\n if (!foundUnit.isValid && defaultUnit)\n foundUnit = await unitsProvider.findUnit(unitLabel, defaultUnit ? defaultUnit.phenomenon : undefined);\n return foundUnit;\n }\n\n private static async createQuantityFromParseTokens(tokens: ParseToken[], format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n let defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n return new Quantity(unit);\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const unit = await this.lookupUnitByLabel(tokens[1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[0].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[0].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const unit = await this.lookupUnitByLabel(tokens[0].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (defaultUnit && defaultUnit.name === unit.name) {\n return new Quantity(defaultUnit, tokens[1].value as number);\n } else if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n const mag = ((tokens[1].value as number * conversion.factor)) + conversion.offset;\n return new Quantity(defaultUnit, mag);\n }\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const unit = await this.lookupUnitByLabel(tokens[i + 1].value as string, format, unitsProvider, altUnitLabelsProvider);\n if (undefined === defaultUnit)\n defaultUnit = unit;\n if (0 === i) {\n if (defaultUnit.name === unit.name)\n mag = value;\n else {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n mag = ((value * conversion.factor)) + conversion.offset;\n }\n } else {\n if (defaultUnit) {\n const conversion = await unitsProvider.getConversion(unit, defaultUnit);\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n }\n return new Quantity(defaultUnit, mag);\n }\n\n return new Quantity(defaultUnit);\n }\n\n /** Async method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString.\n * @param unitsProvider required to look up units that may be specified in inString\n */\n public static async parseIntoQuantity(inString: string, format: Format, unitsProvider: UnitsProvider, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<QuantityProps> {\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return new Quantity();\n\n return Parser.createQuantityFromParseTokens(tokens, format, unitsProvider, altUnitLabelsProvider);\n }\n\n /** method to get the Unit Conversion given a unit label */\n private static tryFindUnitConversion(unitLabel: string, unitsConversions: UnitConversionSpec[], preferredUnit?: UnitProps): UnitConversionProps | undefined {\n if (unitsConversions.length > 0) {\n const label = unitLabel.toLocaleLowerCase();\n\n /* A preferred unit is used to target a unit if a unit label is used in more that one unit definition from the same unit family.\n * An example is if \"ft\" is used as the unitLabel and the preferredUnit is \"SURVEY_FT\" since that unit has an alternate label of \"ft\" the\n * conversion to \"SURVEY_FT\" is returned. If no preferredUnit is specified then the unit \"FT\" would likely to have been found first.\n * If \"in\" is the unit label and \"SURVEY_FT\" is the preferredUnit then conversion to \"SURVEY_IN\" would be returned.\n */\n if (preferredUnit) {\n // if there is a preferred unit defined see if unit label matched it or one of its alternates\n const preferredConversion = unitsConversions.find((conversion) => conversion.name === preferredUnit.name);\n if (preferredConversion && preferredConversion.parseLabels) {\n if (-1 !== preferredConversion.parseLabels.findIndex((lbl) => lbl === label))\n return preferredConversion.conversion;\n }\n // see if we can find a matching unitLabel in any unit within the same system as the preferred unit\n const preferredSystemConversions = unitsConversions.filter((conversion) => conversion.system === preferredUnit.system);\n for (const conversion of preferredSystemConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n }\n }\n }\n\n // if no unit found based on preferredUnit see if an unit label matches\n for (const conversion of unitsConversions) {\n if (conversion.parseLabels) {\n if (-1 !== conversion.parseLabels.findIndex((lbl) => lbl === label))\n return conversion.conversion;\n } else {\n // eslint-disable-next-line no-console\n console.log(\"ERROR: Parser expects to find parseLabels array populate with all possible unit labels for the unit.\");\n }\n }\n }\n\n return undefined;\n }\n\n private static getQuantityValueFromParseTokens(tokens: ParseToken[], format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n const defaultUnit = format.units && format.units.length > 0 ? format.units[0][0] : undefined;\n // common case where single value is supplied\n if (tokens.length === 1) {\n if (tokens[0].isNumber) {\n if (defaultUnit) {\n const conversion = Parser.tryFindUnitConversion(defaultUnit.label, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n } else {\n // if no conversion or no defaultUnit, just return parsed number\n return { ok: true, value: tokens[0].value as number };\n }\n } else {\n // only the unit label was specified so assume magnitude of 1\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (undefined !== conversion)\n return { ok: true, value: conversion.factor + conversion.offset };\n else\n return { ok: false, error: ParseError.NoValueOrUnitFoundInString };\n }\n }\n\n // common case where single value and single label are supplied\n if (tokens.length === 2) {\n if (tokens[0].isNumber && tokens[1].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[0].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[0].value as number };\n } else { // unit specification comes before value (like currency)\n if (tokens[1].isNumber && tokens[0].isString) {\n const conversion = Parser.tryFindUnitConversion(tokens[0].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n const value = (tokens[1].value as number) * conversion.factor + conversion.offset;\n return { ok: true, value };\n }\n // if no conversion, just return parsed number and ignore value in second token\n return { ok: true, value: tokens[1].value as number };\n }\n }\n }\n\n // common case where there are multiple value/label pairs\n if (tokens.length % 2 === 0) {\n let mag = 0.0;\n for (let i = 0; i < tokens.length; i = i + 2) {\n if (tokens[i].isNumber && tokens[i + 1].isString) {\n const value = tokens[i].value as number;\n const conversion = Parser.tryFindUnitConversion(tokens[i + 1].value as string, unitsConversions, defaultUnit);\n if (conversion) {\n if (mag < 0.0)\n mag = mag - ((value * conversion.factor)) + conversion.offset;\n else\n mag = mag + ((value * conversion.factor)) + conversion.offset;\n }\n }\n }\n return { ok: true, value: mag };\n }\n\n return { ok: false, error: ParseError.UnableToConvertParseTokensToQuantity };\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value.\n * @param inString A string that contains text represent a quantity.\n * @param parserSpec unit label if not explicitly defined by user. Must have matching entry in supplied array of unitsConversions.\n * @param defaultValue default value to return if parsing is un successful\n */\n public static parseQuantityString(inString: string, parserSpec: ParserSpec): QuantityParseResult {\n return Parser.parseToQuantityValue(inString, parserSpec.format, parserSpec.unitConversions);\n }\n\n /** Method to generate a Quantity given a string that represents a quantity value and likely a unit label.\n * @param inString A string that contains text represent a quantity.\n * @param format Defines the likely format of inString. Primary unit serves as a default unit if no unit label found in string.\n * @param unitsConversions dictionary of conversions used to convert from unit used in inString to output quantity\n */\n public static parseToQuantityValue(inString: string, format: Format, unitsConversions: UnitConversionSpec[]): QuantityParseResult {\n // ensure any labels defined in composite unit definition are specified in unitConversions\n if (format.units) {\n format.units.forEach(([unit, label]) => {\n if (label) {\n if (unit.label !== label) { // if default unit label does not match composite label ensure the label is in the list of parse labels for the conversion\n const unitConversion = unitsConversions.find((conversion) => conversion.name === unit.name);\n if (unitConversion && unitConversion.parseLabels && !unitConversion.parseLabels.find((entry) => entry === label))\n unitConversion.parseLabels.push(label);\n }\n }\n });\n }\n\n const tokens: ParseToken[] = Parser.parseQuantitySpecification(inString, format);\n if (tokens.length === 0)\n return { ok: false, error: ParseError.UnableToGenerateParseTokens };\n\n if (Parser._log) {\n // eslint-disable-next-line no-console\n console.log(`Parse tokens`);\n let i = 0;\n for (const token of tokens) {\n // eslint-disable-next-line no-console\n console.log(` [${i++}] isNumber=${token.isNumber} isString=${token.isString} token=${token.value}`);\n }\n }\n\n return Parser.getQuantityValueFromParseTokens(tokens, format, unitsConversions);\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecsForUnit(unitsProvider: UnitsProvider, outUnit: UnitProps, altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const familyUnits = await unitsProvider.getUnitsByFamily(outUnit.phenomenon);\n for (const unit of familyUnits) {\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n\n /** Async Method used to create an array of UnitConversionSpec entries that can be used in synchronous calls to parse units. */\n public static async createUnitConversionSpecs(unitsProvider: UnitsProvider, outUnitName: string, potentialParseUnits: PotentialParseUnit[], altUnitLabelsProvider?: AlternateUnitLabelsProvider): Promise<UnitConversionSpec[]> {\n const unitConversionSpecs: UnitConversionSpec[] = [];\n\n const outUnit = await unitsProvider.findUnitByName(outUnitName);\n if (!outUnit || !outUnit.name || 0 === outUnit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate out unit ${outUnitName}.`);\n return unitConversionSpecs;\n }\n\n for (const potentialParseUnit of potentialParseUnits) {\n const unit = await unitsProvider.findUnitByName(potentialParseUnit.unitName);\n if (!unit || !unit.name || 0 === unit.name.length) {\n // eslint-disable-next-line no-console\n console.log(`[Parser.createUnitConversionSpecs] ERROR: Unable to locate potential unit ${potentialParseUnit.unitName}.`);\n continue;\n }\n\n const conversion = await unitsProvider.getConversion(unit, outUnit);\n const parseLabels: string[] = [unit.label.toLocaleLowerCase()];\n const alternateLabels = altUnitLabelsProvider?.getAlternateUnitLabels(unit);\n // add any alternate labels that may be defined for the Unit\n if (alternateLabels) {\n alternateLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n\n // add any alternate labels that where provided by caller\n if (potentialParseUnit.altLabels) {\n potentialParseUnit.altLabels.forEach((label: string) => {\n const potentialLabel = label.toLocaleLowerCase();\n if (-1 === parseLabels.findIndex((lbl) => lbl === potentialLabel))\n parseLabels.push(label.toLocaleLowerCase());\n });\n }\n unitConversionSpecs.push({\n name: unit.name,\n label: unit.label,\n conversion,\n parseLabels,\n system: unit.system,\n });\n }\n return unitConversionSpecs;\n }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@itwin/core-quantity",
3
- "version": "4.4.0-dev.8",
3
+ "version": "4.5.0-dev.0",
4
4
  "description": "Quantity parsing, formatting and conversions for iModel.js",
5
5
  "main": "lib/cjs/core-quantity.js",
6
6
  "module": "lib/esm/core-quantity.js",
@@ -35,11 +35,11 @@
35
35
  "rimraf": "^3.0.2",
36
36
  "sinon": "^17.0.1",
37
37
  "typescript": "~5.0.2",
38
- "@itwin/build-tools": "4.4.0-dev.8",
39
- "@itwin/core-bentley": "4.4.0-dev.8"
38
+ "@itwin/build-tools": "4.5.0-dev.0",
39
+ "@itwin/core-bentley": "4.5.0-dev.0"
40
40
  },
41
41
  "peerDependencies": {
42
- "@itwin/core-bentley": "^4.4.0-dev.8"
42
+ "@itwin/core-bentley": "^4.5.0-dev.0"
43
43
  },
44
44
  "nyc": {
45
45
  "extends": "./node_modules/@itwin/build-tools/.nycrc"