????
Current Path : C:/inetpub/vhost/binhdinhinvest.gdtvietnam.com/api/node_modules/tedious/lib/ |
Current File : C:/inetpub/vhost/binhdinhinvest.gdtvietnam.com/api/node_modules/tedious/lib/value-parser.js |
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _metadataParser = require("./metadata-parser"); var _dataType = require("./data-type"); var _iconvLite = _interopRequireDefault(require("iconv-lite")); var _sprintfJs = require("sprintf-js"); var _guidParser = require("./guid-parser"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const NULL = (1 << 16) - 1; const MAX = (1 << 16) - 1; const THREE_AND_A_THIRD = 3 + 1 / 3; const MONEY_DIVISOR = 10000; const PLP_NULL = Buffer.from([0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF]); const UNKNOWN_PLP_LEN = Buffer.from([0xFE, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF]); const DEFAULT_ENCODING = 'utf8'; function readTinyInt(parser, callback) { parser.readUInt8(callback); } function readSmallInt(parser, callback) { parser.readInt16LE(callback); } function readInt(parser, callback) { parser.readInt32LE(callback); } function readBigInt(parser, callback) { parser.readBigInt64LE(value => { callback(value.toString()); }); } function readReal(parser, callback) { parser.readFloatLE(callback); } function readFloat(parser, callback) { parser.readDoubleLE(callback); } function readSmallMoney(parser, callback) { parser.readInt32LE(value => { callback(value / MONEY_DIVISOR); }); } function readMoney(parser, callback) { parser.readInt32LE(high => { parser.readUInt32LE(low => { callback((low + 0x100000000 * high) / MONEY_DIVISOR); }); }); } function readBit(parser, callback) { parser.readUInt8(value => { callback(!!value); }); } function valueParse(parser, metadata, options, callback) { const type = metadata.type; switch (type.name) { case 'Null': return callback(null); case 'TinyInt': return readTinyInt(parser, callback); case 'SmallInt': return readSmallInt(parser, callback); case 'Int': return readInt(parser, callback); case 'BigInt': return readBigInt(parser, callback); case 'IntN': return parser.readUInt8(dataLength => { switch (dataLength) { case 0: return callback(null); case 1: return readTinyInt(parser, callback); case 2: return readSmallInt(parser, callback); case 4: return readInt(parser, callback); case 8: return readBigInt(parser, callback); default: throw new Error('Unsupported dataLength ' + dataLength + ' for IntN'); } }); case 'Real': return readReal(parser, callback); case 'Float': return readFloat(parser, callback); case 'FloatN': return parser.readUInt8(dataLength => { switch (dataLength) { case 0: return callback(null); case 4: return readReal(parser, callback); case 8: return readFloat(parser, callback); default: throw new Error('Unsupported dataLength ' + dataLength + ' for FloatN'); } }); case 'SmallMoney': return readSmallMoney(parser, callback); case 'Money': return readMoney(parser, callback); case 'MoneyN': return parser.readUInt8(dataLength => { switch (dataLength) { case 0: return callback(null); case 4: return readSmallMoney(parser, callback); case 8: return readMoney(parser, callback); default: throw new Error('Unsupported dataLength ' + dataLength + ' for MoneyN'); } }); case 'Bit': return readBit(parser, callback); case 'BitN': return parser.readUInt8(dataLength => { switch (dataLength) { case 0: return callback(null); case 1: return readBit(parser, callback); default: throw new Error('Unsupported dataLength ' + dataLength + ' for BitN'); } }); case 'VarChar': case 'Char': const codepage = metadata.collation.codepage; if (metadata.dataLength === MAX) { return readMaxChars(parser, codepage, callback); } else { return parser.readUInt16LE(dataLength => { if (dataLength === NULL) { return callback(null); } readChars(parser, dataLength, codepage, callback); }); } case 'NVarChar': case 'NChar': if (metadata.dataLength === MAX) { return readMaxNChars(parser, callback); } else { return parser.readUInt16LE(dataLength => { if (dataLength === NULL) { return callback(null); } readNChars(parser, dataLength, callback); }); } case 'VarBinary': case 'Binary': if (metadata.dataLength === MAX) { return readMaxBinary(parser, callback); } else { return parser.readUInt16LE(dataLength => { if (dataLength === NULL) { return callback(null); } readBinary(parser, dataLength, callback); }); } case 'Text': return parser.readUInt8(textPointerLength => { if (textPointerLength === 0) { return callback(null); } parser.readBuffer(textPointerLength, _textPointer => { parser.readBuffer(8, _timestamp => { parser.readUInt32LE(dataLength => { readChars(parser, dataLength, metadata.collation.codepage, callback); }); }); }); }); case 'NText': return parser.readUInt8(textPointerLength => { if (textPointerLength === 0) { return callback(null); } parser.readBuffer(textPointerLength, _textPointer => { parser.readBuffer(8, _timestamp => { parser.readUInt32LE(dataLength => { readNChars(parser, dataLength, callback); }); }); }); }); case 'Image': return parser.readUInt8(textPointerLength => { if (textPointerLength === 0) { return callback(null); } parser.readBuffer(textPointerLength, _textPointer => { parser.readBuffer(8, _timestamp => { parser.readUInt32LE(dataLength => { readBinary(parser, dataLength, callback); }); }); }); }); case 'Xml': return readMaxNChars(parser, callback); case 'SmallDateTime': return readSmallDateTime(parser, options.useUTC, callback); case 'DateTime': return readDateTime(parser, options.useUTC, callback); case 'DateTimeN': return parser.readUInt8(dataLength => { switch (dataLength) { case 0: return callback(null); case 4: return readSmallDateTime(parser, options.useUTC, callback); case 8: return readDateTime(parser, options.useUTC, callback); default: throw new Error('Unsupported dataLength ' + dataLength + ' for DateTimeN'); } }); case 'Time': return parser.readUInt8(dataLength => { if (dataLength === 0) { return callback(null); } else { return readTime(parser, dataLength, metadata.scale, options.useUTC, callback); } }); case 'Date': return parser.readUInt8(dataLength => { if (dataLength === 0) { return callback(null); } else { return readDate(parser, options.useUTC, callback); } }); case 'DateTime2': return parser.readUInt8(dataLength => { if (dataLength === 0) { return callback(null); } else { return readDateTime2(parser, dataLength, metadata.scale, options.useUTC, callback); } }); case 'DateTimeOffset': return parser.readUInt8(dataLength => { if (dataLength === 0) { return callback(null); } else { return readDateTimeOffset(parser, dataLength, metadata.scale, callback); } }); case 'NumericN': case 'DecimalN': return parser.readUInt8(dataLength => { if (dataLength === 0) { return callback(null); } else { return readNumeric(parser, dataLength, metadata.precision, metadata.scale, callback); } }); case 'UniqueIdentifier': return parser.readUInt8(dataLength => { switch (dataLength) { case 0: return callback(null); case 0x10: return readUniqueIdentifier(parser, options, callback); default: throw new Error((0, _sprintfJs.sprintf)('Unsupported guid size %d', dataLength - 1)); } }); case 'UDT': return readMaxBinary(parser, callback); case 'Variant': return parser.readUInt32LE(dataLength => { if (dataLength === 0) { return callback(null); } readVariant(parser, options, dataLength, callback); }); default: throw new Error((0, _sprintfJs.sprintf)('Unrecognised type %s', type.name)); } } function readUniqueIdentifier(parser, options, callback) { parser.readBuffer(0x10, data => { callback(options.lowerCaseGuids ? (0, _guidParser.bufferToLowerCaseGuid)(data) : (0, _guidParser.bufferToUpperCaseGuid)(data)); }); } function readNumeric(parser, dataLength, _precision, scale, callback) { parser.readUInt8(sign => { sign = sign === 1 ? 1 : -1; let readValue; if (dataLength === 5) { readValue = parser.readUInt32LE; } else if (dataLength === 9) { readValue = parser.readUNumeric64LE; } else if (dataLength === 13) { readValue = parser.readUNumeric96LE; } else if (dataLength === 17) { readValue = parser.readUNumeric128LE; } else { throw new Error((0, _sprintfJs.sprintf)('Unsupported numeric dataLength %d', dataLength)); } readValue.call(parser, value => { callback(value * sign / Math.pow(10, scale)); }); }); } function readVariant(parser, options, dataLength, callback) { return parser.readUInt8(baseType => { const type = _dataType.TYPE[baseType]; return parser.readUInt8(propBytes => { dataLength = dataLength - propBytes - 2; switch (type.name) { case 'UniqueIdentifier': return readUniqueIdentifier(parser, options, callback); case 'Bit': return readBit(parser, callback); case 'TinyInt': return readTinyInt(parser, callback); case 'SmallInt': return readSmallInt(parser, callback); case 'Int': return readInt(parser, callback); case 'BigInt': return readBigInt(parser, callback); case 'SmallDateTime': return readSmallDateTime(parser, options.useUTC, callback); case 'DateTime': return readDateTime(parser, options.useUTC, callback); case 'Real': return readReal(parser, callback); case 'Float': return readFloat(parser, callback); case 'SmallMoney': return readSmallMoney(parser, callback); case 'Money': return readMoney(parser, callback); case 'Date': return readDate(parser, options.useUTC, callback); case 'Time': return parser.readUInt8(scale => { return readTime(parser, dataLength, scale, options.useUTC, callback); }); case 'DateTime2': return parser.readUInt8(scale => { return readDateTime2(parser, dataLength, scale, options.useUTC, callback); }); case 'DateTimeOffset': return parser.readUInt8(scale => { return readDateTimeOffset(parser, dataLength, scale, callback); }); case 'VarBinary': case 'Binary': return parser.readUInt16LE(_maxLength => { readBinary(parser, dataLength, callback); }); case 'NumericN': case 'DecimalN': return parser.readUInt8(precision => { parser.readUInt8(scale => { readNumeric(parser, dataLength, precision, scale, callback); }); }); case 'VarChar': case 'Char': return parser.readUInt16LE(_maxLength => { (0, _metadataParser.readCollation)(parser, collation => { readChars(parser, dataLength, collation.codepage, callback); }); }); case 'NVarChar': case 'NChar': return parser.readUInt16LE(_maxLength => { (0, _metadataParser.readCollation)(parser, _collation => { readNChars(parser, dataLength, callback); }); }); default: throw new Error('Invalid type!'); } }); }); } function readBinary(parser, dataLength, callback) { return parser.readBuffer(dataLength, callback); } function readChars(parser, dataLength, codepage, callback) { if (codepage == null) { codepage = DEFAULT_ENCODING; } return parser.readBuffer(dataLength, data => { callback(_iconvLite.default.decode(data, codepage)); }); } function readNChars(parser, dataLength, callback) { parser.readBuffer(dataLength, data => { callback(data.toString('ucs2')); }); } function readMaxBinary(parser, callback) { return readMax(parser, callback); } function readMaxChars(parser, codepage, callback) { if (codepage == null) { codepage = DEFAULT_ENCODING; } readMax(parser, data => { if (data) { callback(_iconvLite.default.decode(data, codepage)); } else { callback(null); } }); } function readMaxNChars(parser, callback) { readMax(parser, data => { if (data) { callback(data.toString('ucs2')); } else { callback(null); } }); } function readMax(parser, callback) { parser.readBuffer(8, type => { if (type.equals(PLP_NULL)) { return callback(null); } else if (type.equals(UNKNOWN_PLP_LEN)) { return readMaxUnknownLength(parser, callback); } else { const low = type.readUInt32LE(0); const high = type.readUInt32LE(4); if (high >= 2 << 53 - 32) { console.warn('Read UInt64LE > 53 bits : high=' + high + ', low=' + low); } const expectedLength = low + 0x100000000 * high; return readMaxKnownLength(parser, expectedLength, callback); } }); } function readMaxKnownLength(parser, totalLength, callback) { const data = Buffer.alloc(totalLength, 0); let offset = 0; function next(done) { parser.readUInt32LE(chunkLength => { if (!chunkLength) { return done(); } parser.readBuffer(chunkLength, chunk => { chunk.copy(data, offset); offset += chunkLength; next(done); }); }); } next(() => { if (offset !== totalLength) { throw new Error('Partially Length-prefixed Bytes unmatched lengths : expected ' + totalLength + ', but got ' + offset + ' bytes'); } callback(data); }); } function readMaxUnknownLength(parser, callback) { const chunks = []; let length = 0; function next(done) { parser.readUInt32LE(chunkLength => { if (!chunkLength) { return done(); } parser.readBuffer(chunkLength, chunk => { chunks.push(chunk); length += chunkLength; next(done); }); }); } next(() => { callback(Buffer.concat(chunks, length)); }); } function readSmallDateTime(parser, useUTC, callback) { parser.readUInt16LE(days => { parser.readUInt16LE(minutes => { let value; if (useUTC) { value = new Date(Date.UTC(1900, 0, 1 + days, 0, minutes)); } else { value = new Date(1900, 0, 1 + days, 0, minutes); } callback(value); }); }); } function readDateTime(parser, useUTC, callback) { parser.readInt32LE(days => { parser.readUInt32LE(threeHundredthsOfSecond => { const milliseconds = Math.round(threeHundredthsOfSecond * THREE_AND_A_THIRD); let value; if (useUTC) { value = new Date(Date.UTC(1900, 0, 1 + days, 0, 0, 0, milliseconds)); } else { value = new Date(1900, 0, 1 + days, 0, 0, 0, milliseconds); } callback(value); }); }); } function readTime(parser, dataLength, scale, useUTC, callback) { let readValue; switch (dataLength) { case 3: readValue = parser.readUInt24LE; break; case 4: readValue = parser.readUInt32LE; break; case 5: readValue = parser.readUInt40LE; } readValue.call(parser, value => { if (scale < 7) { for (let i = scale; i < 7; i++) { value *= 10; } } let date; if (useUTC) { date = new Date(Date.UTC(1970, 0, 1, 0, 0, 0, value / 10000)); } else { date = new Date(1970, 0, 1, 0, 0, 0, value / 10000); } Object.defineProperty(date, 'nanosecondsDelta', { enumerable: false, value: value % 10000 / Math.pow(10, 7) }); callback(date); }); } function readDate(parser, useUTC, callback) { parser.readUInt24LE(days => { if (useUTC) { callback(new Date(Date.UTC(2000, 0, days - 730118))); } else { callback(new Date(2000, 0, days - 730118)); } }); } function readDateTime2(parser, dataLength, scale, useUTC, callback) { readTime(parser, dataLength - 3, scale, useUTC, time => { // TODO: 'input' is 'time', but TypeScript cannot find "time.nanosecondsDelta"; parser.readUInt24LE(days => { let date; if (useUTC) { date = new Date(Date.UTC(2000, 0, days - 730118, 0, 0, 0, +time)); } else { date = new Date(2000, 0, days - 730118, time.getHours(), time.getMinutes(), time.getSeconds(), time.getMilliseconds()); } Object.defineProperty(date, 'nanosecondsDelta', { enumerable: false, value: time.nanosecondsDelta }); callback(date); }); }); } function readDateTimeOffset(parser, dataLength, scale, callback) { readTime(parser, dataLength - 5, scale, true, time => { parser.readUInt24LE(days => { // offset parser.readInt16LE(() => { const date = new Date(Date.UTC(2000, 0, days - 730118, 0, 0, 0, +time)); Object.defineProperty(date, 'nanosecondsDelta', { enumerable: false, value: time.nanosecondsDelta }); callback(date); }); }); }); } var _default = valueParse; exports.default = _default; module.exports = valueParse; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["NULL","MAX","THREE_AND_A_THIRD","MONEY_DIVISOR","PLP_NULL","Buffer","from","UNKNOWN_PLP_LEN","DEFAULT_ENCODING","readTinyInt","parser","callback","readUInt8","readSmallInt","readInt16LE","readInt","readInt32LE","readBigInt","readBigInt64LE","value","toString","readReal","readFloatLE","readFloat","readDoubleLE","readSmallMoney","readMoney","high","readUInt32LE","low","readBit","valueParse","metadata","options","type","name","dataLength","Error","codepage","collation","readMaxChars","readUInt16LE","readChars","readMaxNChars","readNChars","readMaxBinary","readBinary","textPointerLength","readBuffer","_textPointer","_timestamp","readSmallDateTime","useUTC","readDateTime","readTime","scale","readDate","readDateTime2","readDateTimeOffset","readNumeric","precision","readUniqueIdentifier","readVariant","data","lowerCaseGuids","_precision","sign","readValue","readUNumeric64LE","readUNumeric96LE","readUNumeric128LE","call","Math","pow","baseType","TYPE","propBytes","_maxLength","_collation","iconv","decode","readMax","equals","readMaxUnknownLength","console","warn","expectedLength","readMaxKnownLength","totalLength","alloc","offset","next","done","chunkLength","chunk","copy","chunks","length","push","concat","days","minutes","Date","UTC","threeHundredthsOfSecond","milliseconds","round","readUInt24LE","readUInt40LE","i","date","Object","defineProperty","enumerable","time","getHours","getMinutes","getSeconds","getMilliseconds","nanosecondsDelta","module","exports"],"sources":["../src/value-parser.ts"],"sourcesContent":["import Parser, { ParserOptions } from './token/stream-parser';\nimport { Metadata, readCollation } from './metadata-parser';\nimport { TYPE } from './data-type';\n\nimport iconv from 'iconv-lite';\nimport { sprintf } from 'sprintf-js';\nimport { bufferToLowerCaseGuid, bufferToUpperCaseGuid } from './guid-parser';\n\nconst NULL = (1 << 16) - 1;\nconst MAX = (1 << 16) - 1;\nconst THREE_AND_A_THIRD = 3 + (1 / 3);\nconst MONEY_DIVISOR = 10000;\nconst PLP_NULL = Buffer.from([0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF]);\nconst UNKNOWN_PLP_LEN = Buffer.from([0xFE, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF]);\nconst DEFAULT_ENCODING = 'utf8';\n\nfunction readTinyInt(parser: Parser, callback: (value: unknown) => void) {\n  parser.readUInt8(callback);\n}\n\nfunction readSmallInt(parser: Parser, callback: (value: unknown) => void) {\n  parser.readInt16LE(callback);\n}\n\nfunction readInt(parser: Parser, callback: (value: unknown) => void) {\n  parser.readInt32LE(callback);\n}\n\nfunction readBigInt(parser: Parser, callback: (value: unknown) => void) {\n  parser.readBigInt64LE((value) => {\n    callback(value.toString());\n  });\n}\n\nfunction readReal(parser: Parser, callback: (value: unknown) => void) {\n  parser.readFloatLE(callback);\n}\n\nfunction readFloat(parser: Parser, callback: (value: unknown) => void) {\n  parser.readDoubleLE(callback);\n}\n\nfunction readSmallMoney(parser: Parser, callback: (value: unknown) => void) {\n  parser.readInt32LE((value) => {\n    callback(value / MONEY_DIVISOR);\n  });\n}\n\nfunction readMoney(parser: Parser, callback: (value: unknown) => void) {\n  parser.readInt32LE((high) => {\n    parser.readUInt32LE((low) => {\n      callback((low + (0x100000000 * high)) / MONEY_DIVISOR);\n    });\n  });\n}\n\nfunction readBit(parser: Parser, callback: (value: unknown) => void) {\n  parser.readUInt8((value) => {\n    callback(!!value);\n  });\n}\n\nfunction valueParse(parser: Parser, metadata: Metadata, options: ParserOptions, callback: (value: unknown) => void): void {\n  const type = metadata.type;\n\n  switch (type.name) {\n    case 'Null':\n      return callback(null);\n\n    case 'TinyInt':\n      return readTinyInt(parser, callback);\n\n    case 'SmallInt':\n      return readSmallInt(parser, callback);\n\n    case 'Int':\n      return readInt(parser, callback);\n\n    case 'BigInt':\n      return readBigInt(parser, callback);\n\n    case 'IntN':\n      return parser.readUInt8((dataLength) => {\n        switch (dataLength) {\n          case 0:\n            return callback(null);\n\n          case 1:\n            return readTinyInt(parser, callback);\n          case 2:\n            return readSmallInt(parser, callback);\n          case 4:\n            return readInt(parser, callback);\n          case 8:\n            return readBigInt(parser, callback);\n\n          default:\n            throw new Error('Unsupported dataLength ' + dataLength + ' for IntN');\n        }\n      });\n\n    case 'Real':\n      return readReal(parser, callback);\n\n    case 'Float':\n      return readFloat(parser, callback);\n\n    case 'FloatN':\n      return parser.readUInt8((dataLength) => {\n        switch (dataLength) {\n          case 0:\n            return callback(null);\n\n          case 4:\n            return readReal(parser, callback);\n          case 8:\n            return readFloat(parser, callback);\n\n          default:\n            throw new Error('Unsupported dataLength ' + dataLength + ' for FloatN');\n        }\n      });\n\n    case 'SmallMoney':\n      return readSmallMoney(parser, callback);\n\n    case 'Money':\n      return readMoney(parser, callback);\n\n    case 'MoneyN':\n      return parser.readUInt8((dataLength) => {\n        switch (dataLength) {\n          case 0:\n            return callback(null);\n\n          case 4:\n            return readSmallMoney(parser, callback);\n          case 8:\n            return readMoney(parser, callback);\n\n          default:\n            throw new Error('Unsupported dataLength ' + dataLength + ' for MoneyN');\n        }\n      });\n\n    case 'Bit':\n      return readBit(parser, callback);\n\n    case 'BitN':\n      return parser.readUInt8((dataLength) => {\n        switch (dataLength) {\n          case 0:\n            return callback(null);\n\n          case 1:\n            return readBit(parser, callback);\n\n          default:\n            throw new Error('Unsupported dataLength ' + dataLength + ' for BitN');\n        }\n      });\n\n    case 'VarChar':\n    case 'Char':\n      const codepage = metadata.collation!.codepage!;\n      if (metadata.dataLength === MAX) {\n        return readMaxChars(parser, codepage, callback);\n      } else {\n        return parser.readUInt16LE((dataLength) => {\n          if (dataLength === NULL) {\n            return callback(null);\n          }\n\n          readChars(parser, dataLength!, codepage, callback);\n        });\n      }\n\n    case 'NVarChar':\n    case 'NChar':\n      if (metadata.dataLength === MAX) {\n        return readMaxNChars(parser, callback);\n      } else {\n        return parser.readUInt16LE((dataLength) => {\n          if (dataLength === NULL) {\n            return callback(null);\n          }\n\n          readNChars(parser, dataLength!, callback);\n        });\n      }\n\n    case 'VarBinary':\n    case 'Binary':\n      if (metadata.dataLength === MAX) {\n        return readMaxBinary(parser, callback);\n      } else {\n        return parser.readUInt16LE((dataLength) => {\n          if (dataLength === NULL) {\n            return callback(null);\n          }\n\n          readBinary(parser, dataLength!, callback);\n        });\n      }\n\n    case 'Text':\n      return parser.readUInt8((textPointerLength) => {\n        if (textPointerLength === 0) {\n          return callback(null);\n        }\n\n        parser.readBuffer(textPointerLength, (_textPointer) => {\n          parser.readBuffer(8, (_timestamp) => {\n            parser.readUInt32LE((dataLength) => {\n              readChars(parser, dataLength!, metadata.collation!.codepage!, callback);\n            });\n          });\n        });\n      });\n\n    case 'NText':\n      return parser.readUInt8((textPointerLength) => {\n        if (textPointerLength === 0) {\n          return callback(null);\n        }\n\n        parser.readBuffer(textPointerLength, (_textPointer) => {\n          parser.readBuffer(8, (_timestamp) => {\n            parser.readUInt32LE((dataLength) => {\n              readNChars(parser, dataLength!, callback);\n            });\n          });\n        });\n      });\n\n    case 'Image':\n      return parser.readUInt8((textPointerLength) => {\n        if (textPointerLength === 0) {\n          return callback(null);\n        }\n\n        parser.readBuffer(textPointerLength, (_textPointer) => {\n          parser.readBuffer(8, (_timestamp) => {\n            parser.readUInt32LE((dataLength) => {\n              readBinary(parser, dataLength!, callback);\n            });\n          });\n        });\n      });\n\n    case 'Xml':\n      return readMaxNChars(parser, callback);\n\n    case 'SmallDateTime':\n      return readSmallDateTime(parser, options.useUTC, callback);\n\n    case 'DateTime':\n      return readDateTime(parser, options.useUTC, callback);\n\n    case 'DateTimeN':\n      return parser.readUInt8((dataLength) => {\n        switch (dataLength) {\n          case 0:\n            return callback(null);\n\n          case 4:\n            return readSmallDateTime(parser, options.useUTC, callback);\n          case 8:\n            return readDateTime(parser, options.useUTC, callback);\n\n          default:\n            throw new Error('Unsupported dataLength ' + dataLength + ' for DateTimeN');\n        }\n      });\n\n    case 'Time':\n      return parser.readUInt8((dataLength) => {\n        if (dataLength === 0) {\n          return callback(null);\n        } else {\n          return readTime(parser, dataLength!, metadata.scale!, options.useUTC, callback);\n        }\n      });\n\n    case 'Date':\n      return parser.readUInt8((dataLength) => {\n        if (dataLength === 0) {\n          return callback(null);\n        } else {\n          return readDate(parser, options.useUTC, callback);\n        }\n      });\n\n    case 'DateTime2':\n      return parser.readUInt8((dataLength) => {\n        if (dataLength === 0) {\n          return callback(null);\n        } else {\n          return readDateTime2(parser, dataLength!, metadata.scale!, options.useUTC, callback);\n        }\n      });\n\n    case 'DateTimeOffset':\n      return parser.readUInt8((dataLength) => {\n        if (dataLength === 0) {\n          return callback(null);\n        } else {\n          return readDateTimeOffset(parser, dataLength!, metadata.scale!, callback);\n        }\n      });\n\n    case 'NumericN':\n    case 'DecimalN':\n      return parser.readUInt8((dataLength) => {\n        if (dataLength === 0) {\n          return callback(null);\n        } else {\n          return readNumeric(parser, dataLength!, metadata.precision!, metadata.scale!, callback);\n        }\n      });\n\n    case 'UniqueIdentifier':\n      return parser.readUInt8((dataLength) => {\n        switch (dataLength) {\n          case 0:\n            return callback(null);\n\n          case 0x10:\n            return readUniqueIdentifier(parser, options, callback);\n\n          default:\n            throw new Error(sprintf('Unsupported guid size %d', dataLength! - 1));\n        }\n      });\n\n    case 'UDT':\n      return readMaxBinary(parser, callback);\n\n    case 'Variant':\n      return parser.readUInt32LE((dataLength) => {\n        if (dataLength === 0) {\n          return callback(null);\n        }\n\n        readVariant(parser, options, dataLength!, callback);\n      });\n\n    default:\n      throw new Error(sprintf('Unrecognised type %s', type.name));\n  }\n}\n\nfunction readUniqueIdentifier(parser: Parser, options: ParserOptions, callback: (value: unknown) => void) {\n  parser.readBuffer(0x10, (data) => {\n    callback(options.lowerCaseGuids ? bufferToLowerCaseGuid(data) : bufferToUpperCaseGuid(data));\n  });\n}\n\nfunction readNumeric(parser: Parser, dataLength: number, _precision: number, scale: number, callback: (value: unknown) => void) {\n  parser.readUInt8((sign) => {\n    sign = sign === 1 ? 1 : -1;\n\n    let readValue;\n    if (dataLength === 5) {\n      readValue = parser.readUInt32LE;\n    } else if (dataLength === 9) {\n      readValue = parser.readUNumeric64LE;\n    } else if (dataLength === 13) {\n      readValue = parser.readUNumeric96LE;\n    } else if (dataLength === 17) {\n      readValue = parser.readUNumeric128LE;\n    } else {\n      throw new Error(sprintf('Unsupported numeric dataLength %d', dataLength));\n    }\n\n    readValue.call(parser, (value) => {\n      callback((value * sign) / Math.pow(10, scale));\n    });\n  });\n}\n\nfunction readVariant(parser: Parser, options: ParserOptions, dataLength: number, callback: (value: unknown) => void) {\n  return parser.readUInt8((baseType) => {\n    const type = TYPE[baseType];\n\n    return parser.readUInt8((propBytes) => {\n      dataLength = dataLength - propBytes - 2;\n\n      switch (type.name) {\n        case 'UniqueIdentifier':\n          return readUniqueIdentifier(parser, options, callback);\n\n        case 'Bit':\n          return readBit(parser, callback);\n\n        case 'TinyInt':\n          return readTinyInt(parser, callback);\n\n        case 'SmallInt':\n          return readSmallInt(parser, callback);\n\n        case 'Int':\n          return readInt(parser, callback);\n\n        case 'BigInt':\n          return readBigInt(parser, callback);\n\n        case 'SmallDateTime':\n          return readSmallDateTime(parser, options.useUTC, callback);\n\n        case 'DateTime':\n          return readDateTime(parser, options.useUTC, callback);\n\n        case 'Real':\n          return readReal(parser, callback);\n\n        case 'Float':\n          return readFloat(parser, callback);\n\n        case 'SmallMoney':\n          return readSmallMoney(parser, callback);\n\n        case 'Money':\n          return readMoney(parser, callback);\n\n        case 'Date':\n          return readDate(parser, options.useUTC, callback);\n\n        case 'Time':\n          return parser.readUInt8((scale) => {\n            return readTime(parser, dataLength, scale, options.useUTC, callback);\n          });\n\n        case 'DateTime2':\n          return parser.readUInt8((scale) => {\n            return readDateTime2(parser, dataLength, scale, options.useUTC, callback);\n          });\n\n        case 'DateTimeOffset':\n          return parser.readUInt8((scale) => {\n            return readDateTimeOffset(parser, dataLength, scale, callback);\n          });\n\n        case 'VarBinary':\n        case 'Binary':\n          return parser.readUInt16LE((_maxLength) => {\n            readBinary(parser, dataLength, callback);\n          });\n\n        case 'NumericN':\n        case 'DecimalN':\n          return parser.readUInt8((precision) => {\n            parser.readUInt8((scale) => {\n              readNumeric(parser, dataLength, precision, scale, callback);\n            });\n          });\n\n        case 'VarChar':\n        case 'Char':\n          return parser.readUInt16LE((_maxLength) => {\n            readCollation(parser, (collation) => {\n              readChars(parser, dataLength, collation.codepage!, callback);\n            });\n          });\n\n        case 'NVarChar':\n        case 'NChar':\n          return parser.readUInt16LE((_maxLength) => {\n            readCollation(parser, (_collation) => {\n              readNChars(parser, dataLength, callback);\n            });\n          });\n\n        default:\n          throw new Error('Invalid type!');\n      }\n    });\n  });\n}\n\nfunction readBinary(parser: Parser, dataLength: number, callback: (value: unknown) => void) {\n  return parser.readBuffer(dataLength, callback);\n}\n\nfunction readChars(parser: Parser, dataLength: number, codepage: string, callback: (value: unknown) => void) {\n  if (codepage == null) {\n    codepage = DEFAULT_ENCODING;\n  }\n\n  return parser.readBuffer(dataLength, (data) => {\n    callback(iconv.decode(data, codepage));\n  });\n}\n\nfunction readNChars(parser: Parser, dataLength: number, callback: (value: unknown) => void) {\n  parser.readBuffer(dataLength, (data) => {\n    callback(data.toString('ucs2'));\n  });\n}\n\nfunction readMaxBinary(parser: Parser, callback: (value: unknown) => void) {\n  return readMax(parser, callback);\n}\n\nfunction readMaxChars(parser: Parser, codepage: string, callback: (value: unknown) => void) {\n  if (codepage == null) {\n    codepage = DEFAULT_ENCODING;\n  }\n\n  readMax(parser, (data) => {\n    if (data) {\n      callback(iconv.decode(data, codepage));\n    } else {\n      callback(null);\n    }\n  });\n}\n\nfunction readMaxNChars(parser: Parser, callback: (value: string | null) => void) {\n  readMax(parser, (data) => {\n    if (data) {\n      callback(data.toString('ucs2'));\n    } else {\n      callback(null);\n    }\n  });\n}\n\nfunction readMax(parser: Parser, callback: (value: null | Buffer) => void) {\n  parser.readBuffer(8, (type) => {\n    if (type.equals(PLP_NULL)) {\n      return callback(null);\n    } else if (type.equals(UNKNOWN_PLP_LEN)) {\n      return readMaxUnknownLength(parser, callback);\n    } else {\n      const low = type.readUInt32LE(0);\n      const high = type.readUInt32LE(4);\n\n      if (high >= (2 << (53 - 32))) {\n        console.warn('Read UInt64LE > 53 bits : high=' + high + ', low=' + low);\n      }\n\n      const expectedLength = low + (0x100000000 * high);\n      return readMaxKnownLength(parser, expectedLength, callback);\n    }\n  });\n}\n\nfunction readMaxKnownLength(parser: Parser, totalLength: number, callback: (value: null | Buffer) => void) {\n  const data = Buffer.alloc(totalLength, 0);\n\n  let offset = 0;\n  function next(done: any) {\n    parser.readUInt32LE((chunkLength) => {\n      if (!chunkLength) {\n        return done();\n      }\n\n      parser.readBuffer(chunkLength, (chunk) => {\n        chunk.copy(data, offset);\n        offset += chunkLength;\n\n        next(done);\n      });\n    });\n  }\n\n  next(() => {\n    if (offset !== totalLength) {\n      throw new Error('Partially Length-prefixed Bytes unmatched lengths : expected ' + totalLength + ', but got ' + offset + ' bytes');\n    }\n\n    callback(data);\n  });\n}\n\nfunction readMaxUnknownLength(parser: Parser, callback: (value: null | Buffer) => void) {\n  const chunks: Buffer[] = [];\n\n  let length = 0;\n  function next(done: any) {\n    parser.readUInt32LE((chunkLength) => {\n      if (!chunkLength) {\n        return done();\n      }\n\n      parser.readBuffer(chunkLength, (chunk) => {\n        chunks.push(chunk);\n        length += chunkLength;\n\n        next(done);\n      });\n    });\n  }\n\n  next(() => {\n    callback(Buffer.concat(chunks, length));\n  });\n}\n\nfunction readSmallDateTime(parser: Parser, useUTC: boolean, callback: (value: Date) => void) {\n  parser.readUInt16LE((days) => {\n    parser.readUInt16LE((minutes) => {\n      let value;\n      if (useUTC) {\n        value = new Date(Date.UTC(1900, 0, 1 + days, 0, minutes));\n      } else {\n        value = new Date(1900, 0, 1 + days, 0, minutes);\n      }\n      callback(value);\n    });\n  });\n}\n\nfunction readDateTime(parser: Parser, useUTC: boolean, callback: (value: Date) => void) {\n  parser.readInt32LE((days) => {\n    parser.readUInt32LE((threeHundredthsOfSecond) => {\n      const milliseconds = Math.round(threeHundredthsOfSecond * THREE_AND_A_THIRD);\n\n      let value;\n      if (useUTC) {\n        value = new Date(Date.UTC(1900, 0, 1 + days, 0, 0, 0, milliseconds));\n      } else {\n        value = new Date(1900, 0, 1 + days, 0, 0, 0, milliseconds);\n      }\n\n      callback(value);\n    });\n  });\n}\n\ninterface DateWithNanosecondsDelta extends Date {\n  nanosecondsDelta: number;\n}\n\nfunction readTime(parser: Parser, dataLength: number, scale: number, useUTC: boolean, callback: (value: DateWithNanosecondsDelta) => void) {\n  let readValue: any;\n  switch (dataLength) {\n    case 3:\n      readValue = parser.readUInt24LE;\n      break;\n    case 4:\n      readValue = parser.readUInt32LE;\n      break;\n    case 5:\n      readValue = parser.readUInt40LE;\n  }\n\n  readValue!.call(parser, (value: number) => {\n    if (scale < 7) {\n      for (let i = scale; i < 7; i++) {\n        value *= 10;\n      }\n    }\n\n    let date;\n    if (useUTC) {\n      date = new Date(Date.UTC(1970, 0, 1, 0, 0, 0, value / 10000)) as DateWithNanosecondsDelta;\n    } else {\n      date = new Date(1970, 0, 1, 0, 0, 0, value / 10000) as DateWithNanosecondsDelta;\n    }\n    Object.defineProperty(date, 'nanosecondsDelta', {\n      enumerable: false,\n      value: (value % 10000) / Math.pow(10, 7)\n    });\n    callback(date);\n  });\n}\n\nfunction readDate(parser: Parser, useUTC: boolean, callback: (value: Date) => void) {\n  parser.readUInt24LE((days) => {\n    if (useUTC) {\n      callback(new Date(Date.UTC(2000, 0, days - 730118)));\n    } else {\n      callback(new Date(2000, 0, days - 730118));\n    }\n  });\n}\n\nfunction readDateTime2(parser: Parser, dataLength: number, scale: number, useUTC: boolean, callback: (value: DateWithNanosecondsDelta) => void) {\n  readTime(parser, dataLength - 3, scale, useUTC, (time) => { // TODO: 'input' is 'time', but TypeScript cannot find \"time.nanosecondsDelta\";\n    parser.readUInt24LE((days) => {\n      let date;\n      if (useUTC) {\n        date = new Date(Date.UTC(2000, 0, days - 730118, 0, 0, 0, +time)) as DateWithNanosecondsDelta;\n      } else {\n        date = new Date(2000, 0, days - 730118, time.getHours(), time.getMinutes(), time.getSeconds(), time.getMilliseconds()) as DateWithNanosecondsDelta;\n      }\n      Object.defineProperty(date, 'nanosecondsDelta', {\n        enumerable: false,\n        value: time.nanosecondsDelta\n      });\n      callback(date);\n    });\n  });\n}\n\nfunction readDateTimeOffset(parser: Parser, dataLength: number, scale: number, callback: (value: DateWithNanosecondsDelta) => void) {\n  readTime(parser, dataLength - 5, scale, true, (time) => {\n    parser.readUInt24LE((days) => {\n      // offset\n      parser.readInt16LE(() => {\n        const date = new Date(Date.UTC(2000, 0, days - 730118, 0, 0, 0, +time)) as DateWithNanosecondsDelta;\n        Object.defineProperty(date, 'nanosecondsDelta', {\n          enumerable: false,\n          value: time.nanosecondsDelta\n        });\n        callback(date);\n      });\n    });\n  });\n}\n\nexport default valueParse;\nmodule.exports = valueParse;\n"],"mappings":"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"}