export function encodeNormMsg(message) { let bb = popByteBuffer(); _encodeNormMsg(message, bb); return toUint8Array(bb); } function _encodeNormMsg(message, bb) { let $sub = message.sub; if ($sub !== void 0) { writeVarint32(bb, 10); writeString(bb, $sub); } let $msg = message.msg; if ($msg !== void 0) { writeVarint32(bb, 18); writeString(bb, $msg); } let $error = message.error; if ($error !== void 0) { writeVarint32(bb, 26); writeString(bb, $error); } let $type = message.type; if ($type !== void 0) { writeVarint32(bb, 34); writeString(bb, $type); } let $fva11 = message.fva11; if ($fva11 !== void 0) { writeVarint32(bb, 45); writeFloat(bb, $fva11); } let $fva12 = message.fva12; if ($fva12 !== void 0) { writeVarint32(bb, 53); writeFloat(bb, $fva12); } let $iva11 = message.iva11; if ($iva11 !== void 0) { writeVarint32(bb, 56); writeVarint64(bb, intToLong($iva11)); } let $iva12 = message.iva12; if ($iva12 !== void 0) { writeVarint32(bb, 64); writeVarint64(bb, intToLong($iva12)); } } export function decodeNormMsg(binary) { return _decodeNormMsg(wrapByteBuffer(binary)); } function _decodeNormMsg(bb) { let message = {}; end_of_message: while (!isAtEnd(bb)) { let tag = readVarint32(bb); switch (tag >>> 3) { case 0: break end_of_message; case 1: { message.sub = readString(bb, readVarint32(bb)); break; } case 2: { message.msg = readString(bb, readVarint32(bb)); break; } case 3: { message.error = readString(bb, readVarint32(bb)); break; } case 4: { message.type = readString(bb, readVarint32(bb)); break; } case 5: { message.fva11 = readFloat(bb); break; } case 6: { message.fva12 = readFloat(bb); break; } case 7: { message.iva11 = readVarint32(bb); break; } case 8: { message.iva12 = readVarint32(bb); break; } default: skipUnknownField(bb, tag & 7); } } return message; } function pushTemporaryLength(bb) { let length = readVarint32(bb); let limit = bb.limit; bb.limit = bb.offset + length; return limit; } function skipUnknownField(bb, type) { switch (type) { case 0: while (readByte(bb) & 128) { } break; case 2: skip(bb, readVarint32(bb)); break; case 5: skip(bb, 4); break; case 1: skip(bb, 8); break; default: throw new Error("Unimplemented type: " + type); } } function stringToLong(value) { return { low: value.charCodeAt(0) | value.charCodeAt(1) << 16, high: value.charCodeAt(2) | value.charCodeAt(3) << 16, unsigned: false }; } function longToString(value) { let low = value.low; let high = value.high; return String.fromCharCode( low & 65535, low >>> 16, high & 65535, high >>> 16 ); } let f32 = new Float32Array(1); let f32_u8 = new Uint8Array(f32.buffer); let f64 = new Float64Array(1); let f64_u8 = new Uint8Array(f64.buffer); function intToLong(value) { value |= 0; return { low: value, high: value >> 31, unsigned: value >= 0 }; } let bbStack = []; function popByteBuffer() { const bb = bbStack.pop(); if (!bb) return { bytes: new Uint8Array(64), offset: 0, limit: 0 }; bb.offset = bb.limit = 0; return bb; } function pushByteBuffer(bb) { bbStack.push(bb); } function wrapByteBuffer(bytes) { return { bytes, offset: 0, limit: bytes.length }; } function toUint8Array(bb) { let bytes = bb.bytes; let limit = bb.limit; return bytes.length === limit ? bytes : bytes.subarray(0, limit); } function skip(bb, offset) { if (bb.offset + offset > bb.limit) { throw new Error("Skip past limit"); } bb.offset += offset; } function isAtEnd(bb) { return bb.offset >= bb.limit; } function grow(bb, count) { let bytes = bb.bytes; let offset = bb.offset; let limit = bb.limit; let finalOffset = offset + count; if (finalOffset > bytes.length) { let newBytes = new Uint8Array(finalOffset * 2); newBytes.set(bytes); bb.bytes = newBytes; } bb.offset = finalOffset; if (finalOffset > limit) { bb.limit = finalOffset; } return offset; } function advance(bb, count) { let offset = bb.offset; if (offset + count > bb.limit) { throw new Error("Read past limit"); } bb.offset += count; return offset; } function readBytes(bb, count) { let offset = advance(bb, count); return bb.bytes.subarray(offset, offset + count); } function writeBytes(bb, buffer) { let offset = grow(bb, buffer.length); bb.bytes.set(buffer, offset); } function readString(bb, count) { let offset = advance(bb, count); let fromCharCode = String.fromCharCode; let bytes = bb.bytes; let invalid = "�"; let text = ""; for (let i = 0; i < count; i++) { let c1 = bytes[i + offset], c2, c3, c4, c; if ((c1 & 128) === 0) { text += fromCharCode(c1); } else if ((c1 & 224) === 192) { if (i + 1 >= count) text += invalid; else { c2 = bytes[i + offset + 1]; if ((c2 & 192) !== 128) text += invalid; else { c = (c1 & 31) << 6 | c2 & 63; if (c < 128) text += invalid; else { text += fromCharCode(c); i++; } } } } else if ((c1 & 240) == 224) { if (i + 2 >= count) text += invalid; else { c2 = bytes[i + offset + 1]; c3 = bytes[i + offset + 2]; if (((c2 | c3 << 8) & 49344) !== 32896) text += invalid; else { c = (c1 & 15) << 12 | (c2 & 63) << 6 | c3 & 63; if (c < 2048 || c >= 55296 && c <= 57343) text += invalid; else { text += fromCharCode(c); i += 2; } } } } else if ((c1 & 248) == 240) { if (i + 3 >= count) text += invalid; else { c2 = bytes[i + offset + 1]; c3 = bytes[i + offset + 2]; c4 = bytes[i + offset + 3]; if (((c2 | c3 << 8 | c4 << 16) & 12632256) !== 8421504) text += invalid; else { c = (c1 & 7) << 18 | (c2 & 63) << 12 | (c3 & 63) << 6 | c4 & 63; if (c < 65536 || c > 1114111) text += invalid; else { c -= 65536; text += fromCharCode((c >> 10) + 55296, (c & 1023) + 56320); i += 3; } } } } else text += invalid; } return text; } function writeString(bb, text) { let n = text.length; let byteCount = 0; for (let i = 0; i < n; i++) { let c = text.charCodeAt(i); if (c >= 55296 && c <= 56319 && i + 1 < n) { c = (c << 10) + text.charCodeAt(++i) - 56613888; } byteCount += c < 128 ? 1 : c < 2048 ? 2 : c < 65536 ? 3 : 4; } writeVarint32(bb, byteCount); let offset = grow(bb, byteCount); let bytes = bb.bytes; for (let i = 0; i < n; i++) { let c = text.charCodeAt(i); if (c >= 55296 && c <= 56319 && i + 1 < n) { c = (c << 10) + text.charCodeAt(++i) - 56613888; } if (c < 128) { bytes[offset++] = c; } else { if (c < 2048) { bytes[offset++] = c >> 6 & 31 | 192; } else { if (c < 65536) { bytes[offset++] = c >> 12 & 15 | 224; } else { bytes[offset++] = c >> 18 & 7 | 240; bytes[offset++] = c >> 12 & 63 | 128; } bytes[offset++] = c >> 6 & 63 | 128; } bytes[offset++] = c & 63 | 128; } } } function writeByteBuffer(bb, buffer) { let offset = grow(bb, buffer.limit); let from = bb.bytes; let to = buffer.bytes; for (let i = 0, n = buffer.limit; i < n; i++) { from[i + offset] = to[i]; } } function readByte(bb) { return bb.bytes[advance(bb, 1)]; } function writeByte(bb, value) { let offset = grow(bb, 1); bb.bytes[offset] = value; } function readFloat(bb) { let offset = advance(bb, 4); let bytes = bb.bytes; f32_u8[0] = bytes[offset++]; f32_u8[1] = bytes[offset++]; f32_u8[2] = bytes[offset++]; f32_u8[3] = bytes[offset++]; return f32[0]; } function writeFloat(bb, value) { let offset = grow(bb, 4); let bytes = bb.bytes; f32[0] = value; bytes[offset++] = f32_u8[0]; bytes[offset++] = f32_u8[1]; bytes[offset++] = f32_u8[2]; bytes[offset++] = f32_u8[3]; } function readDouble(bb) { let offset = advance(bb, 8); let bytes = bb.bytes; f64_u8[0] = bytes[offset++]; f64_u8[1] = bytes[offset++]; f64_u8[2] = bytes[offset++]; f64_u8[3] = bytes[offset++]; f64_u8[4] = bytes[offset++]; f64_u8[5] = bytes[offset++]; f64_u8[6] = bytes[offset++]; f64_u8[7] = bytes[offset++]; return f64[0]; } function writeDouble(bb, value) { let offset = grow(bb, 8); let bytes = bb.bytes; f64[0] = value; bytes[offset++] = f64_u8[0]; bytes[offset++] = f64_u8[1]; bytes[offset++] = f64_u8[2]; bytes[offset++] = f64_u8[3]; bytes[offset++] = f64_u8[4]; bytes[offset++] = f64_u8[5]; bytes[offset++] = f64_u8[6]; bytes[offset++] = f64_u8[7]; } function readInt32(bb) { let offset = advance(bb, 4); let bytes = bb.bytes; return bytes[offset] | bytes[offset + 1] << 8 | bytes[offset + 2] << 16 | bytes[offset + 3] << 24; } function writeInt32(bb, value) { let offset = grow(bb, 4); let bytes = bb.bytes; bytes[offset] = value; bytes[offset + 1] = value >> 8; bytes[offset + 2] = value >> 16; bytes[offset + 3] = value >> 24; } function readInt64(bb, unsigned) { return { low: readInt32(bb), high: readInt32(bb), unsigned }; } function writeInt64(bb, value) { writeInt32(bb, value.low); writeInt32(bb, value.high); } function readVarint32(bb) { let c = 0; let value = 0; let b; do { b = readByte(bb); if (c < 32) value |= (b & 127) << c; c += 7; } while (b & 128); return value; } function writeVarint32(bb, value) { value >>>= 0; while (value >= 128) { writeByte(bb, value & 127 | 128); value >>>= 7; } writeByte(bb, value); } function readVarint64(bb, unsigned) { let part0 = 0; let part1 = 0; let part2 = 0; let b; b = readByte(bb); part0 = b & 127; if (b & 128) { b = readByte(bb); part0 |= (b & 127) << 7; if (b & 128) { b = readByte(bb); part0 |= (b & 127) << 14; if (b & 128) { b = readByte(bb); part0 |= (b & 127) << 21; if (b & 128) { b = readByte(bb); part1 = b & 127; if (b & 128) { b = readByte(bb); part1 |= (b & 127) << 7; if (b & 128) { b = readByte(bb); part1 |= (b & 127) << 14; if (b & 128) { b = readByte(bb); part1 |= (b & 127) << 21; if (b & 128) { b = readByte(bb); part2 = b & 127; if (b & 128) { b = readByte(bb); part2 |= (b & 127) << 7; } } } } } } } } } return { low: part0 | part1 << 28, high: part1 >>> 4 | part2 << 24, unsigned }; } function writeVarint64(bb, value) { let part0 = value.low >>> 0; let part1 = (value.low >>> 28 | value.high << 4) >>> 0; let part2 = value.high >>> 24; let size = part2 === 0 ? part1 === 0 ? part0 < 1 << 14 ? part0 < 1 << 7 ? 1 : 2 : part0 < 1 << 21 ? 3 : 4 : part1 < 1 << 14 ? part1 < 1 << 7 ? 5 : 6 : part1 < 1 << 21 ? 7 : 8 : part2 < 1 << 7 ? 9 : 10; let offset = grow(bb, size); let bytes = bb.bytes; switch (size) { case 10: bytes[offset + 9] = part2 >>> 7 & 1; break; case 9: bytes[offset + 8] = size !== 9 ? part2 | 128 : part2 & 127; break; case 8: bytes[offset + 7] = size !== 8 ? part1 >>> 21 | 128 : part1 >>> 21 & 127; break; case 7: bytes[offset + 6] = size !== 7 ? part1 >>> 14 | 128 : part1 >>> 14 & 127; break; case 6: bytes[offset + 5] = size !== 6 ? part1 >>> 7 | 128 : part1 >>> 7 & 127; break; case 5: bytes[offset + 4] = size !== 5 ? part1 | 128 : part1 & 127; break; case 4: bytes[offset + 3] = size !== 4 ? part0 >>> 21 | 128 : part0 >>> 21 & 127; break; case 3: bytes[offset + 2] = size !== 3 ? part0 >>> 14 | 128 : part0 >>> 14 & 127; break; case 2: bytes[offset + 1] = size !== 2 ? part0 >>> 7 | 128 : part0 >>> 7 & 127; break; case 1: bytes[offset] = size !== 1 ? part0 | 128 : part0 & 127; } } function readVarint32ZigZag(bb) { let value = readVarint32(bb); return value >>> 1 ^ -(value & 1); } function writeVarint32ZigZag(bb, value) { writeVarint32(bb, value << 1 ^ value >> 31); } function readVarint64ZigZag(bb) { let value = readVarint64( bb, /* unsigned */ false ); let low = value.low; let high = value.high; let flip = -(low & 1); return { low: (low >>> 1 | high << 31) ^ flip, high: high >>> 1 ^ flip, unsigned: false }; } function writeVarint64ZigZag(bb, value) { let low = value.low; let high = value.high; let flip = high >> 31; writeVarint64(bb, { low: low << 1 ^ flip, high: (high << 1 | low >>> 31) ^ flip, unsigned: false }); } //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["message.ts"],"sourcesContent":["export interface NormMsg {\r\n  sub?: string;\r\n  msg?: string;\r\n  error?: string;\r\n  type?: string;\r\n  fva11?: number;\r\n  fva12?: number;\r\n  iva11?: number;\r\n  iva12?: number;\r\n}\r\n\r\nexport function encodeNormMsg(message: NormMsg): Uint8Array {\r\n  let bb = popByteBuffer();\r\n  _encodeNormMsg(message, bb);\r\n  return toUint8Array(bb);\r\n}\r\n\r\nfunction _encodeNormMsg(message: NormMsg, bb: ByteBuffer): void {\r\n  // optional string sub = 1;\r\n  let $sub = message.sub;\r\n  if ($sub !== undefined) {\r\n    writeVarint32(bb, 10);\r\n    writeString(bb, $sub);\r\n  }\r\n\r\n  // optional string msg = 2;\r\n  let $msg = message.msg;\r\n  if ($msg !== undefined) {\r\n    writeVarint32(bb, 18);\r\n    writeString(bb, $msg);\r\n  }\r\n\r\n  // optional string error = 3;\r\n  let $error = message.error;\r\n  if ($error !== undefined) {\r\n    writeVarint32(bb, 26);\r\n    writeString(bb, $error);\r\n  }\r\n\r\n  // optional string type = 4;\r\n  let $type = message.type;\r\n  if ($type !== undefined) {\r\n    writeVarint32(bb, 34);\r\n    writeString(bb, $type);\r\n  }\r\n\r\n  // optional float fva11 = 5;\r\n  let $fva11 = message.fva11;\r\n  if ($fva11 !== undefined) {\r\n    writeVarint32(bb, 45);\r\n    writeFloat(bb, $fva11);\r\n  }\r\n\r\n  // optional float fva12 = 6;\r\n  let $fva12 = message.fva12;\r\n  if ($fva12 !== undefined) {\r\n    writeVarint32(bb, 53);\r\n    writeFloat(bb, $fva12);\r\n  }\r\n\r\n  // optional int32 iva11 = 7;\r\n  let $iva11 = message.iva11;\r\n  if ($iva11 !== undefined) {\r\n    writeVarint32(bb, 56);\r\n    writeVarint64(bb, intToLong($iva11));\r\n  }\r\n\r\n  // optional int32 iva12 = 8;\r\n  let $iva12 = message.iva12;\r\n  if ($iva12 !== undefined) {\r\n    writeVarint32(bb, 64);\r\n    writeVarint64(bb, intToLong($iva12));\r\n  }\r\n}\r\n\r\nexport function decodeNormMsg(binary: Uint8Array): NormMsg {\r\n  return _decodeNormMsg(wrapByteBuffer(binary));\r\n}\r\n\r\nfunction _decodeNormMsg(bb: ByteBuffer): NormMsg {\r\n  let message: NormMsg = {} as any;\r\n\r\n  end_of_message: while (!isAtEnd(bb)) {\r\n    let tag = readVarint32(bb);\r\n\r\n    switch (tag >>> 3) {\r\n      case 0:\r\n        break end_of_message;\r\n\r\n      // optional string sub = 1;\r\n      case 1: {\r\n        message.sub = readString(bb, readVarint32(bb));\r\n        break;\r\n      }\r\n\r\n      // optional string msg = 2;\r\n      case 2: {\r\n        message.msg = readString(bb, readVarint32(bb));\r\n        break;\r\n      }\r\n\r\n      // optional string error = 3;\r\n      case 3: {\r\n        message.error = readString(bb, readVarint32(bb));\r\n        break;\r\n      }\r\n\r\n      // optional string type = 4;\r\n      case 4: {\r\n        message.type = readString(bb, readVarint32(bb));\r\n        break;\r\n      }\r\n\r\n      // optional float fva11 = 5;\r\n      case 5: {\r\n        message.fva11 = readFloat(bb);\r\n        break;\r\n      }\r\n\r\n      // optional float fva12 = 6;\r\n      case 6: {\r\n        message.fva12 = readFloat(bb);\r\n        break;\r\n      }\r\n\r\n      // optional int32 iva11 = 7;\r\n      case 7: {\r\n        message.iva11 = readVarint32(bb);\r\n        break;\r\n      }\r\n\r\n      // optional int32 iva12 = 8;\r\n      case 8: {\r\n        message.iva12 = readVarint32(bb);\r\n        break;\r\n      }\r\n\r\n      default:\r\n        skipUnknownField(bb, tag & 7);\r\n    }\r\n  }\r\n\r\n  return message;\r\n}\r\n\r\nexport interface Long {\r\n  low: number;\r\n  high: number;\r\n  unsigned: boolean;\r\n}\r\n\r\ninterface ByteBuffer {\r\n  bytes: Uint8Array;\r\n  offset: number;\r\n  limit: number;\r\n}\r\n\r\nfunction pushTemporaryLength(bb: ByteBuffer): number {\r\n  let length = readVarint32(bb);\r\n  let limit = bb.limit;\r\n  bb.limit = bb.offset + length;\r\n  return limit;\r\n}\r\n\r\nfunction skipUnknownField(bb: ByteBuffer, type: number): void {\r\n  switch (type) {\r\n    case 0:\r\n      while (readByte(bb) & 0x80) {}\r\n      break;\r\n    case 2:\r\n      skip(bb, readVarint32(bb));\r\n      break;\r\n    case 5:\r\n      skip(bb, 4);\r\n      break;\r\n    case 1:\r\n      skip(bb, 8);\r\n      break;\r\n    default:\r\n      throw new Error(\"Unimplemented type: \" + type);\r\n  }\r\n}\r\n\r\nfunction stringToLong(value: string): Long {\r\n  return {\r\n    low: value.charCodeAt(0) | (value.charCodeAt(1) << 16),\r\n    high: value.charCodeAt(2) | (value.charCodeAt(3) << 16),\r\n    unsigned: false,\r\n  };\r\n}\r\n\r\nfunction longToString(value: Long): string {\r\n  let low = value.low;\r\n  let high = value.high;\r\n  return String.fromCharCode(\r\n    low & 0xffff,\r\n    low >>> 16,\r\n    high & 0xffff,\r\n    high >>> 16\r\n  );\r\n}\r\n\r\n// The code below was modified from https://github.com/protobufjs/bytebuffer.js\r\n// which is under the Apache License 2.0.\r\n\r\nlet f32 = new Float32Array(1);\r\nlet f32_u8 = new Uint8Array(f32.buffer);\r\n\r\nlet f64 = new Float64Array(1);\r\nlet f64_u8 = new Uint8Array(f64.buffer);\r\n\r\nfunction intToLong(value: number): Long {\r\n  value |= 0;\r\n  return {\r\n    low: value,\r\n    high: value >> 31,\r\n    unsigned: value >= 0,\r\n  };\r\n}\r\n\r\nlet bbStack: ByteBuffer[] = [];\r\n\r\nfunction popByteBuffer(): ByteBuffer {\r\n  const bb = bbStack.pop();\r\n  if (!bb) return { bytes: new Uint8Array(64), offset: 0, limit: 0 };\r\n  bb.offset = bb.limit = 0;\r\n  return bb;\r\n}\r\n\r\nfunction pushByteBuffer(bb: ByteBuffer): void {\r\n  bbStack.push(bb);\r\n}\r\n\r\nfunction wrapByteBuffer(bytes: Uint8Array): ByteBuffer {\r\n  return { bytes, offset: 0, limit: bytes.length };\r\n}\r\n\r\nfunction toUint8Array(bb: ByteBuffer): Uint8Array {\r\n  let bytes = bb.bytes;\r\n  let limit = bb.limit;\r\n  return bytes.length === limit ? bytes : bytes.subarray(0, limit);\r\n}\r\n\r\nfunction skip(bb: ByteBuffer, offset: number): void {\r\n  if (bb.offset + offset > bb.limit) {\r\n    throw new Error(\"Skip past limit\");\r\n  }\r\n  bb.offset += offset;\r\n}\r\n\r\nfunction isAtEnd(bb: ByteBuffer): boolean {\r\n  return bb.offset >= bb.limit;\r\n}\r\n\r\nfunction grow(bb: ByteBuffer, count: number): number {\r\n  let bytes = bb.bytes;\r\n  let offset = bb.offset;\r\n  let limit = bb.limit;\r\n  let finalOffset = offset + count;\r\n  if (finalOffset > bytes.length) {\r\n    let newBytes = new Uint8Array(finalOffset * 2);\r\n    newBytes.set(bytes);\r\n    bb.bytes = newBytes;\r\n  }\r\n  bb.offset = finalOffset;\r\n  if (finalOffset > limit) {\r\n    bb.limit = finalOffset;\r\n  }\r\n  return offset;\r\n}\r\n\r\nfunction advance(bb: ByteBuffer, count: number): number {\r\n  let offset = bb.offset;\r\n  if (offset + count > bb.limit) {\r\n    throw new Error(\"Read past limit\");\r\n  }\r\n  bb.offset += count;\r\n  return offset;\r\n}\r\n\r\nfunction readBytes(bb: ByteBuffer, count: number): Uint8Array {\r\n  let offset = advance(bb, count);\r\n  return bb.bytes.subarray(offset, offset + count);\r\n}\r\n\r\nfunction writeBytes(bb: ByteBuffer, buffer: Uint8Array): void {\r\n  let offset = grow(bb, buffer.length);\r\n  bb.bytes.set(buffer, offset);\r\n}\r\n\r\nfunction readString(bb: ByteBuffer, count: number): string {\r\n  // Sadly a hand-coded UTF8 decoder is much faster than subarray+TextDecoder in V8\r\n  let offset = advance(bb, count);\r\n  let fromCharCode = String.fromCharCode;\r\n  let bytes = bb.bytes;\r\n  let invalid = \"\\uFFFD\";\r\n  let text = \"\";\r\n\r\n  for (let i = 0; i < count; i++) {\r\n    let c1 = bytes[i + offset],\r\n      c2: number,\r\n      c3: number,\r\n      c4: number,\r\n      c: number;\r\n\r\n    // 1 byte\r\n    if ((c1 & 0x80) === 0) {\r\n      text += fromCharCode(c1);\r\n    }\r\n\r\n    // 2 bytes\r\n    else if ((c1 & 0xe0) === 0xc0) {\r\n      if (i + 1 >= count) text += invalid;\r\n      else {\r\n        c2 = bytes[i + offset + 1];\r\n        if ((c2 & 0xc0) !== 0x80) text += invalid;\r\n        else {\r\n          c = ((c1 & 0x1f) << 6) | (c2 & 0x3f);\r\n          if (c < 0x80) text += invalid;\r\n          else {\r\n            text += fromCharCode(c);\r\n            i++;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    // 3 bytes\r\n    else if ((c1 & 0xf0) == 0xe0) {\r\n      if (i + 2 >= count) text += invalid;\r\n      else {\r\n        c2 = bytes[i + offset + 1];\r\n        c3 = bytes[i + offset + 2];\r\n        if (((c2 | (c3 << 8)) & 0xc0c0) !== 0x8080) text += invalid;\r\n        else {\r\n          c = ((c1 & 0x0f) << 12) | ((c2 & 0x3f) << 6) | (c3 & 0x3f);\r\n          if (c < 0x0800 || (c >= 0xd800 && c <= 0xdfff)) text += invalid;\r\n          else {\r\n            text += fromCharCode(c);\r\n            i += 2;\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    // 4 bytes\r\n    else if ((c1 & 0xf8) == 0xf0) {\r\n      if (i + 3 >= count) text += invalid;\r\n      else {\r\n        c2 = bytes[i + offset + 1];\r\n        c3 = bytes[i + offset + 2];\r\n        c4 = bytes[i + offset + 3];\r\n        if (((c2 | (c3 << 8) | (c4 << 16)) & 0xc0c0c0) !== 0x808080)\r\n          text += invalid;\r\n        else {\r\n          c =\r\n            ((c1 & 0x07) << 0x12) |\r\n            ((c2 & 0x3f) << 0x0c) |\r\n            ((c3 & 0x3f) << 0x06) |\r\n            (c4 & 0x3f);\r\n          if (c < 0x10000 || c > 0x10ffff) text += invalid;\r\n          else {\r\n            c -= 0x10000;\r\n            text += fromCharCode((c >> 10) + 0xd800, (c & 0x3ff) + 0xdc00);\r\n            i += 3;\r\n          }\r\n        }\r\n      }\r\n    } else text += invalid;\r\n  }\r\n\r\n  return text;\r\n}\r\n\r\nfunction writeString(bb: ByteBuffer, text: string): void {\r\n  // Sadly a hand-coded UTF8 encoder is much faster than TextEncoder+set in V8\r\n  let n = text.length;\r\n  let byteCount = 0;\r\n\r\n  // Write the byte count first\r\n  for (let i = 0; i < n; i++) {\r\n    let c = text.charCodeAt(i);\r\n    if (c >= 0xd800 && c <= 0xdbff && i + 1 < n) {\r\n      c = (c << 10) + text.charCodeAt(++i) - 0x35fdc00;\r\n    }\r\n    byteCount += c < 0x80 ? 1 : c < 0x800 ? 2 : c < 0x10000 ? 3 : 4;\r\n  }\r\n  writeVarint32(bb, byteCount);\r\n\r\n  let offset = grow(bb, byteCount);\r\n  let bytes = bb.bytes;\r\n\r\n  // Then write the bytes\r\n  for (let i = 0; i < n; i++) {\r\n    let c = text.charCodeAt(i);\r\n    if (c >= 0xd800 && c <= 0xdbff && i + 1 < n) {\r\n      c = (c << 10) + text.charCodeAt(++i) - 0x35fdc00;\r\n    }\r\n    if (c < 0x80) {\r\n      bytes[offset++] = c;\r\n    } else {\r\n      if (c < 0x800) {\r\n        bytes[offset++] = ((c >> 6) & 0x1f) | 0xc0;\r\n      } else {\r\n        if (c < 0x10000) {\r\n          bytes[offset++] = ((c >> 12) & 0x0f) | 0xe0;\r\n        } else {\r\n          bytes[offset++] = ((c >> 18) & 0x07) | 0xf0;\r\n          bytes[offset++] = ((c >> 12) & 0x3f) | 0x80;\r\n        }\r\n        bytes[offset++] = ((c >> 6) & 0x3f) | 0x80;\r\n      }\r\n      bytes[offset++] = (c & 0x3f) | 0x80;\r\n    }\r\n  }\r\n}\r\n\r\nfunction writeByteBuffer(bb: ByteBuffer, buffer: ByteBuffer): void {\r\n  let offset = grow(bb, buffer.limit);\r\n  let from = bb.bytes;\r\n  let to = buffer.bytes;\r\n\r\n  // This for loop is much faster than subarray+set on V8\r\n  for (let i = 0, n = buffer.limit; i < n; i++) {\r\n    from[i + offset] = to[i];\r\n  }\r\n}\r\n\r\nfunction readByte(bb: ByteBuffer): number {\r\n  return bb.bytes[advance(bb, 1)];\r\n}\r\n\r\nfunction writeByte(bb: ByteBuffer, value: number): void {\r\n  let offset = grow(bb, 1);\r\n  bb.bytes[offset] = value;\r\n}\r\n\r\nfunction readFloat(bb: ByteBuffer): number {\r\n  let offset = advance(bb, 4);\r\n  let bytes = bb.bytes;\r\n\r\n  // Manual copying is much faster than subarray+set in V8\r\n  f32_u8[0] = bytes[offset++];\r\n  f32_u8[1] = bytes[offset++];\r\n  f32_u8[2] = bytes[offset++];\r\n  f32_u8[3] = bytes[offset++];\r\n  return f32[0];\r\n}\r\n\r\nfunction writeFloat(bb: ByteBuffer, value: number): void {\r\n  let offset = grow(bb, 4);\r\n  let bytes = bb.bytes;\r\n  f32[0] = value;\r\n\r\n  // Manual copying is much faster than subarray+set in V8\r\n  bytes[offset++] = f32_u8[0];\r\n  bytes[offset++] = f32_u8[1];\r\n  bytes[offset++] = f32_u8[2];\r\n  bytes[offset++] = f32_u8[3];\r\n}\r\n\r\nfunction readDouble(bb: ByteBuffer): number {\r\n  let offset = advance(bb, 8);\r\n  let bytes = bb.bytes;\r\n\r\n  // Manual copying is much faster than subarray+set in V8\r\n  f64_u8[0] = bytes[offset++];\r\n  f64_u8[1] = bytes[offset++];\r\n  f64_u8[2] = bytes[offset++];\r\n  f64_u8[3] = bytes[offset++];\r\n  f64_u8[4] = bytes[offset++];\r\n  f64_u8[5] = bytes[offset++];\r\n  f64_u8[6] = bytes[offset++];\r\n  f64_u8[7] = bytes[offset++];\r\n  return f64[0];\r\n}\r\n\r\nfunction writeDouble(bb: ByteBuffer, value: number): void {\r\n  let offset = grow(bb, 8);\r\n  let bytes = bb.bytes;\r\n  f64[0] = value;\r\n\r\n  // Manual copying is much faster than subarray+set in V8\r\n  bytes[offset++] = f64_u8[0];\r\n  bytes[offset++] = f64_u8[1];\r\n  bytes[offset++] = f64_u8[2];\r\n  bytes[offset++] = f64_u8[3];\r\n  bytes[offset++] = f64_u8[4];\r\n  bytes[offset++] = f64_u8[5];\r\n  bytes[offset++] = f64_u8[6];\r\n  bytes[offset++] = f64_u8[7];\r\n}\r\n\r\nfunction readInt32(bb: ByteBuffer): number {\r\n  let offset = advance(bb, 4);\r\n  let bytes = bb.bytes;\r\n  return (\r\n    bytes[offset] |\r\n    (bytes[offset + 1] << 8) |\r\n    (bytes[offset + 2] << 16) |\r\n    (bytes[offset + 3] << 24)\r\n  );\r\n}\r\n\r\nfunction writeInt32(bb: ByteBuffer, value: number): void {\r\n  let offset = grow(bb, 4);\r\n  let bytes = bb.bytes;\r\n  bytes[offset] = value;\r\n  bytes[offset + 1] = value >> 8;\r\n  bytes[offset + 2] = value >> 16;\r\n  bytes[offset + 3] = value >> 24;\r\n}\r\n\r\nfunction readInt64(bb: ByteBuffer, unsigned: boolean): Long {\r\n  return {\r\n    low: readInt32(bb),\r\n    high: readInt32(bb),\r\n    unsigned,\r\n  };\r\n}\r\n\r\nfunction writeInt64(bb: ByteBuffer, value: Long): void {\r\n  writeInt32(bb, value.low);\r\n  writeInt32(bb, value.high);\r\n}\r\n\r\nfunction readVarint32(bb: ByteBuffer): number {\r\n  let c = 0;\r\n  let value = 0;\r\n  let b: number;\r\n  do {\r\n    b = readByte(bb);\r\n    if (c < 32) value |= (b & 0x7f) << c;\r\n    c += 7;\r\n  } while (b & 0x80);\r\n  return value;\r\n}\r\n\r\nfunction writeVarint32(bb: ByteBuffer, value: number): void {\r\n  value >>>= 0;\r\n  while (value >= 0x80) {\r\n    writeByte(bb, (value & 0x7f) | 0x80);\r\n    value >>>= 7;\r\n  }\r\n  writeByte(bb, value);\r\n}\r\n\r\nfunction readVarint64(bb: ByteBuffer, unsigned: boolean): Long {\r\n  let part0 = 0;\r\n  let part1 = 0;\r\n  let part2 = 0;\r\n  let b: number;\r\n\r\n  b = readByte(bb);\r\n  part0 = b & 0x7f;\r\n  if (b & 0x80) {\r\n    b = readByte(bb);\r\n    part0 |= (b & 0x7f) << 7;\r\n    if (b & 0x80) {\r\n      b = readByte(bb);\r\n      part0 |= (b & 0x7f) << 14;\r\n      if (b & 0x80) {\r\n        b = readByte(bb);\r\n        part0 |= (b & 0x7f) << 21;\r\n        if (b & 0x80) {\r\n          b = readByte(bb);\r\n          part1 = b & 0x7f;\r\n          if (b & 0x80) {\r\n            b = readByte(bb);\r\n            part1 |= (b & 0x7f) << 7;\r\n            if (b & 0x80) {\r\n              b = readByte(bb);\r\n              part1 |= (b & 0x7f) << 14;\r\n              if (b & 0x80) {\r\n                b = readByte(bb);\r\n                part1 |= (b & 0x7f) << 21;\r\n                if (b & 0x80) {\r\n                  b = readByte(bb);\r\n                  part2 = b & 0x7f;\r\n                  if (b & 0x80) {\r\n                    b = readByte(bb);\r\n                    part2 |= (b & 0x7f) << 7;\r\n                  }\r\n                }\r\n              }\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  return {\r\n    low: part0 | (part1 << 28),\r\n    high: (part1 >>> 4) | (part2 << 24),\r\n    unsigned,\r\n  };\r\n}\r\n\r\nfunction writeVarint64(bb: ByteBuffer, value: Long): void {\r\n  let part0 = value.low >>> 0;\r\n  let part1 = ((value.low >>> 28) | (value.high << 4)) >>> 0;\r\n  let part2 = value.high >>> 24;\r\n\r\n  // ref: src/google/protobuf/io/coded_stream.cc\r\n  let size =\r\n    part2 === 0\r\n      ? part1 === 0\r\n        ? part0 < 1 << 14\r\n          ? part0 < 1 << 7\r\n            ? 1\r\n            : 2\r\n          : part0 < 1 << 21\r\n          ? 3\r\n          : 4\r\n        : part1 < 1 << 14\r\n        ? part1 < 1 << 7\r\n          ? 5\r\n          : 6\r\n        : part1 < 1 << 21\r\n        ? 7\r\n        : 8\r\n      : part2 < 1 << 7\r\n      ? 9\r\n      : 10;\r\n\r\n  let offset = grow(bb, size);\r\n  let bytes = bb.bytes;\r\n\r\n  switch (size) {\r\n    case 10:\r\n      bytes[offset + 9] = (part2 >>> 7) & 0x01;\r\n      break;\r\n    case 9:\r\n      bytes[offset + 8] = size !== 9 ? part2 | 0x80 : part2 & 0x7f;\r\n      break;\r\n    case 8:\r\n      bytes[offset + 7] =\r\n        size !== 8 ? (part1 >>> 21) | 0x80 : (part1 >>> 21) & 0x7f;\r\n      break;\r\n    case 7:\r\n      bytes[offset + 6] =\r\n        size !== 7 ? (part1 >>> 14) | 0x80 : (part1 >>> 14) & 0x7f;\r\n      break;\r\n    case 6:\r\n      bytes[offset + 5] =\r\n        size !== 6 ? (part1 >>> 7) | 0x80 : (part1 >>> 7) & 0x7f;\r\n      break;\r\n    case 5:\r\n      bytes[offset + 4] = size !== 5 ? part1 | 0x80 : part1 & 0x7f;\r\n      break;\r\n    case 4:\r\n      bytes[offset + 3] =\r\n        size !== 4 ? (part0 >>> 21) | 0x80 : (part0 >>> 21) & 0x7f;\r\n      break;\r\n    case 3:\r\n      bytes[offset + 2] =\r\n        size !== 3 ? (part0 >>> 14) | 0x80 : (part0 >>> 14) & 0x7f;\r\n      break;\r\n    case 2:\r\n      bytes[offset + 1] =\r\n        size !== 2 ? (part0 >>> 7) | 0x80 : (part0 >>> 7) & 0x7f;\r\n      break;\r\n    case 1:\r\n      bytes[offset] = size !== 1 ? part0 | 0x80 : part0 & 0x7f;\r\n  }\r\n}\r\n\r\nfunction readVarint32ZigZag(bb: ByteBuffer): number {\r\n  let value = readVarint32(bb);\r\n\r\n  // ref: src/google/protobuf/wire_format_lite.h\r\n  return (value >>> 1) ^ -(value & 1);\r\n}\r\n\r\nfunction writeVarint32ZigZag(bb: ByteBuffer, value: number): void {\r\n  // ref: src/google/protobuf/wire_format_lite.h\r\n  writeVarint32(bb, (value << 1) ^ (value >> 31));\r\n}\r\n\r\nfunction readVarint64ZigZag(bb: ByteBuffer): Long {\r\n  let value = readVarint64(bb, /* unsigned */ false);\r\n  let low = value.low;\r\n  let high = value.high;\r\n  let flip = -(low & 1);\r\n\r\n  // ref: src/google/protobuf/wire_format_lite.h\r\n  return {\r\n    low: ((low >>> 1) | (high << 31)) ^ flip,\r\n    high: (high >>> 1) ^ flip,\r\n    unsigned: false,\r\n  };\r\n}\r\n\r\nfunction writeVarint64ZigZag(bb: ByteBuffer, value: Long): void {\r\n  let low = value.low;\r\n  let high = value.high;\r\n  let flip = high >> 31;\r\n\r\n  // ref: src/google/protobuf/wire_format_lite.h\r\n  writeVarint64(bb, {\r\n    low: (low << 1) ^ flip,\r\n    high: ((high << 1) | (low >>> 31)) ^ flip,\r\n    unsigned: false,\r\n  });\r\n}\r\n"],"mappings":"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","names":[]}