f_00000d 53 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541
  1. export function encodeNormMsg(message) {
  2. let bb = popByteBuffer();
  3. _encodeNormMsg(message, bb);
  4. return toUint8Array(bb);
  5. }
  6. function _encodeNormMsg(message, bb) {
  7. let $sub = message.sub;
  8. if ($sub !== void 0) {
  9. writeVarint32(bb, 10);
  10. writeString(bb, $sub);
  11. }
  12. let $msg = message.msg;
  13. if ($msg !== void 0) {
  14. writeVarint32(bb, 18);
  15. writeString(bb, $msg);
  16. }
  17. let $error = message.error;
  18. if ($error !== void 0) {
  19. writeVarint32(bb, 26);
  20. writeString(bb, $error);
  21. }
  22. let $type = message.type;
  23. if ($type !== void 0) {
  24. writeVarint32(bb, 34);
  25. writeString(bb, $type);
  26. }
  27. let $fva11 = message.fva11;
  28. if ($fva11 !== void 0) {
  29. writeVarint32(bb, 45);
  30. writeFloat(bb, $fva11);
  31. }
  32. let $fva12 = message.fva12;
  33. if ($fva12 !== void 0) {
  34. writeVarint32(bb, 53);
  35. writeFloat(bb, $fva12);
  36. }
  37. let $iva11 = message.iva11;
  38. if ($iva11 !== void 0) {
  39. writeVarint32(bb, 56);
  40. writeVarint64(bb, intToLong($iva11));
  41. }
  42. let $iva12 = message.iva12;
  43. if ($iva12 !== void 0) {
  44. writeVarint32(bb, 64);
  45. writeVarint64(bb, intToLong($iva12));
  46. }
  47. }
  48. export function decodeNormMsg(binary) {
  49. return _decodeNormMsg(wrapByteBuffer(binary));
  50. }
  51. function _decodeNormMsg(bb) {
  52. let message = {};
  53. end_of_message:
  54. while (!isAtEnd(bb)) {
  55. let tag = readVarint32(bb);
  56. switch (tag >>> 3) {
  57. case 0:
  58. break end_of_message;
  59. case 1: {
  60. message.sub = readString(bb, readVarint32(bb));
  61. break;
  62. }
  63. case 2: {
  64. message.msg = readString(bb, readVarint32(bb));
  65. break;
  66. }
  67. case 3: {
  68. message.error = readString(bb, readVarint32(bb));
  69. break;
  70. }
  71. case 4: {
  72. message.type = readString(bb, readVarint32(bb));
  73. break;
  74. }
  75. case 5: {
  76. message.fva11 = readFloat(bb);
  77. break;
  78. }
  79. case 6: {
  80. message.fva12 = readFloat(bb);
  81. break;
  82. }
  83. case 7: {
  84. message.iva11 = readVarint32(bb);
  85. break;
  86. }
  87. case 8: {
  88. message.iva12 = readVarint32(bb);
  89. break;
  90. }
  91. default:
  92. skipUnknownField(bb, tag & 7);
  93. }
  94. }
  95. return message;
  96. }
  97. function pushTemporaryLength(bb) {
  98. let length = readVarint32(bb);
  99. let limit = bb.limit;
  100. bb.limit = bb.offset + length;
  101. return limit;
  102. }
  103. function skipUnknownField(bb, type) {
  104. switch (type) {
  105. case 0:
  106. while (readByte(bb) & 128) {
  107. }
  108. break;
  109. case 2:
  110. skip(bb, readVarint32(bb));
  111. break;
  112. case 5:
  113. skip(bb, 4);
  114. break;
  115. case 1:
  116. skip(bb, 8);
  117. break;
  118. default:
  119. throw new Error("Unimplemented type: " + type);
  120. }
  121. }
  122. function stringToLong(value) {
  123. return {
  124. low: value.charCodeAt(0) | value.charCodeAt(1) << 16,
  125. high: value.charCodeAt(2) | value.charCodeAt(3) << 16,
  126. unsigned: false
  127. };
  128. }
  129. function longToString(value) {
  130. let low = value.low;
  131. let high = value.high;
  132. return String.fromCharCode(
  133. low & 65535,
  134. low >>> 16,
  135. high & 65535,
  136. high >>> 16
  137. );
  138. }
  139. let f32 = new Float32Array(1);
  140. let f32_u8 = new Uint8Array(f32.buffer);
  141. let f64 = new Float64Array(1);
  142. let f64_u8 = new Uint8Array(f64.buffer);
  143. function intToLong(value) {
  144. value |= 0;
  145. return {
  146. low: value,
  147. high: value >> 31,
  148. unsigned: value >= 0
  149. };
  150. }
  151. let bbStack = [];
  152. function popByteBuffer() {
  153. const bb = bbStack.pop();
  154. if (!bb)
  155. return { bytes: new Uint8Array(64), offset: 0, limit: 0 };
  156. bb.offset = bb.limit = 0;
  157. return bb;
  158. }
  159. function pushByteBuffer(bb) {
  160. bbStack.push(bb);
  161. }
  162. function wrapByteBuffer(bytes) {
  163. return { bytes, offset: 0, limit: bytes.length };
  164. }
  165. function toUint8Array(bb) {
  166. let bytes = bb.bytes;
  167. let limit = bb.limit;
  168. return bytes.length === limit ? bytes : bytes.subarray(0, limit);
  169. }
  170. function skip(bb, offset) {
  171. if (bb.offset + offset > bb.limit) {
  172. throw new Error("Skip past limit");
  173. }
  174. bb.offset += offset;
  175. }
  176. function isAtEnd(bb) {
  177. return bb.offset >= bb.limit;
  178. }
  179. function grow(bb, count) {
  180. let bytes = bb.bytes;
  181. let offset = bb.offset;
  182. let limit = bb.limit;
  183. let finalOffset = offset + count;
  184. if (finalOffset > bytes.length) {
  185. let newBytes = new Uint8Array(finalOffset * 2);
  186. newBytes.set(bytes);
  187. bb.bytes = newBytes;
  188. }
  189. bb.offset = finalOffset;
  190. if (finalOffset > limit) {
  191. bb.limit = finalOffset;
  192. }
  193. return offset;
  194. }
  195. function advance(bb, count) {
  196. let offset = bb.offset;
  197. if (offset + count > bb.limit) {
  198. throw new Error("Read past limit");
  199. }
  200. bb.offset += count;
  201. return offset;
  202. }
  203. function readBytes(bb, count) {
  204. let offset = advance(bb, count);
  205. return bb.bytes.subarray(offset, offset + count);
  206. }
  207. function writeBytes(bb, buffer) {
  208. let offset = grow(bb, buffer.length);
  209. bb.bytes.set(buffer, offset);
  210. }
  211. function readString(bb, count) {
  212. let offset = advance(bb, count);
  213. let fromCharCode = String.fromCharCode;
  214. let bytes = bb.bytes;
  215. let invalid = "�";
  216. let text = "";
  217. for (let i = 0; i < count; i++) {
  218. let c1 = bytes[i + offset], c2, c3, c4, c;
  219. if ((c1 & 128) === 0) {
  220. text += fromCharCode(c1);
  221. } else if ((c1 & 224) === 192) {
  222. if (i + 1 >= count)
  223. text += invalid;
  224. else {
  225. c2 = bytes[i + offset + 1];
  226. if ((c2 & 192) !== 128)
  227. text += invalid;
  228. else {
  229. c = (c1 & 31) << 6 | c2 & 63;
  230. if (c < 128)
  231. text += invalid;
  232. else {
  233. text += fromCharCode(c);
  234. i++;
  235. }
  236. }
  237. }
  238. } else if ((c1 & 240) == 224) {
  239. if (i + 2 >= count)
  240. text += invalid;
  241. else {
  242. c2 = bytes[i + offset + 1];
  243. c3 = bytes[i + offset + 2];
  244. if (((c2 | c3 << 8) & 49344) !== 32896)
  245. text += invalid;
  246. else {
  247. c = (c1 & 15) << 12 | (c2 & 63) << 6 | c3 & 63;
  248. if (c < 2048 || c >= 55296 && c <= 57343)
  249. text += invalid;
  250. else {
  251. text += fromCharCode(c);
  252. i += 2;
  253. }
  254. }
  255. }
  256. } else if ((c1 & 248) == 240) {
  257. if (i + 3 >= count)
  258. text += invalid;
  259. else {
  260. c2 = bytes[i + offset + 1];
  261. c3 = bytes[i + offset + 2];
  262. c4 = bytes[i + offset + 3];
  263. if (((c2 | c3 << 8 | c4 << 16) & 12632256) !== 8421504)
  264. text += invalid;
  265. else {
  266. c = (c1 & 7) << 18 | (c2 & 63) << 12 | (c3 & 63) << 6 | c4 & 63;
  267. if (c < 65536 || c > 1114111)
  268. text += invalid;
  269. else {
  270. c -= 65536;
  271. text += fromCharCode((c >> 10) + 55296, (c & 1023) + 56320);
  272. i += 3;
  273. }
  274. }
  275. }
  276. } else
  277. text += invalid;
  278. }
  279. return text;
  280. }
  281. function writeString(bb, text) {
  282. let n = text.length;
  283. let byteCount = 0;
  284. for (let i = 0; i < n; i++) {
  285. let c = text.charCodeAt(i);
  286. if (c >= 55296 && c <= 56319 && i + 1 < n) {
  287. c = (c << 10) + text.charCodeAt(++i) - 56613888;
  288. }
  289. byteCount += c < 128 ? 1 : c < 2048 ? 2 : c < 65536 ? 3 : 4;
  290. }
  291. writeVarint32(bb, byteCount);
  292. let offset = grow(bb, byteCount);
  293. let bytes = bb.bytes;
  294. for (let i = 0; i < n; i++) {
  295. let c = text.charCodeAt(i);
  296. if (c >= 55296 && c <= 56319 && i + 1 < n) {
  297. c = (c << 10) + text.charCodeAt(++i) - 56613888;
  298. }
  299. if (c < 128) {
  300. bytes[offset++] = c;
  301. } else {
  302. if (c < 2048) {
  303. bytes[offset++] = c >> 6 & 31 | 192;
  304. } else {
  305. if (c < 65536) {
  306. bytes[offset++] = c >> 12 & 15 | 224;
  307. } else {
  308. bytes[offset++] = c >> 18 & 7 | 240;
  309. bytes[offset++] = c >> 12 & 63 | 128;
  310. }
  311. bytes[offset++] = c >> 6 & 63 | 128;
  312. }
  313. bytes[offset++] = c & 63 | 128;
  314. }
  315. }
  316. }
  317. function writeByteBuffer(bb, buffer) {
  318. let offset = grow(bb, buffer.limit);
  319. let from = bb.bytes;
  320. let to = buffer.bytes;
  321. for (let i = 0, n = buffer.limit; i < n; i++) {
  322. from[i + offset] = to[i];
  323. }
  324. }
  325. function readByte(bb) {
  326. return bb.bytes[advance(bb, 1)];
  327. }
  328. function writeByte(bb, value) {
  329. let offset = grow(bb, 1);
  330. bb.bytes[offset] = value;
  331. }
  332. function readFloat(bb) {
  333. let offset = advance(bb, 4);
  334. let bytes = bb.bytes;
  335. f32_u8[0] = bytes[offset++];
  336. f32_u8[1] = bytes[offset++];
  337. f32_u8[2] = bytes[offset++];
  338. f32_u8[3] = bytes[offset++];
  339. return f32[0];
  340. }
  341. function writeFloat(bb, value) {
  342. let offset = grow(bb, 4);
  343. let bytes = bb.bytes;
  344. f32[0] = value;
  345. bytes[offset++] = f32_u8[0];
  346. bytes[offset++] = f32_u8[1];
  347. bytes[offset++] = f32_u8[2];
  348. bytes[offset++] = f32_u8[3];
  349. }
  350. function readDouble(bb) {
  351. let offset = advance(bb, 8);
  352. let bytes = bb.bytes;
  353. f64_u8[0] = bytes[offset++];
  354. f64_u8[1] = bytes[offset++];
  355. f64_u8[2] = bytes[offset++];
  356. f64_u8[3] = bytes[offset++];
  357. f64_u8[4] = bytes[offset++];
  358. f64_u8[5] = bytes[offset++];
  359. f64_u8[6] = bytes[offset++];
  360. f64_u8[7] = bytes[offset++];
  361. return f64[0];
  362. }
  363. function writeDouble(bb, value) {
  364. let offset = grow(bb, 8);
  365. let bytes = bb.bytes;
  366. f64[0] = value;
  367. bytes[offset++] = f64_u8[0];
  368. bytes[offset++] = f64_u8[1];
  369. bytes[offset++] = f64_u8[2];
  370. bytes[offset++] = f64_u8[3];
  371. bytes[offset++] = f64_u8[4];
  372. bytes[offset++] = f64_u8[5];
  373. bytes[offset++] = f64_u8[6];
  374. bytes[offset++] = f64_u8[7];
  375. }
  376. function readInt32(bb) {
  377. let offset = advance(bb, 4);
  378. let bytes = bb.bytes;
  379. return bytes[offset] | bytes[offset + 1] << 8 | bytes[offset + 2] << 16 | bytes[offset + 3] << 24;
  380. }
  381. function writeInt32(bb, value) {
  382. let offset = grow(bb, 4);
  383. let bytes = bb.bytes;
  384. bytes[offset] = value;
  385. bytes[offset + 1] = value >> 8;
  386. bytes[offset + 2] = value >> 16;
  387. bytes[offset + 3] = value >> 24;
  388. }
  389. function readInt64(bb, unsigned) {
  390. return {
  391. low: readInt32(bb),
  392. high: readInt32(bb),
  393. unsigned
  394. };
  395. }
  396. function writeInt64(bb, value) {
  397. writeInt32(bb, value.low);
  398. writeInt32(bb, value.high);
  399. }
  400. function readVarint32(bb) {
  401. let c = 0;
  402. let value = 0;
  403. let b;
  404. do {
  405. b = readByte(bb);
  406. if (c < 32)
  407. value |= (b & 127) << c;
  408. c += 7;
  409. } while (b & 128);
  410. return value;
  411. }
  412. function writeVarint32(bb, value) {
  413. value >>>= 0;
  414. while (value >= 128) {
  415. writeByte(bb, value & 127 | 128);
  416. value >>>= 7;
  417. }
  418. writeByte(bb, value);
  419. }
  420. function readVarint64(bb, unsigned) {
  421. let part0 = 0;
  422. let part1 = 0;
  423. let part2 = 0;
  424. let b;
  425. b = readByte(bb);
  426. part0 = b & 127;
  427. if (b & 128) {
  428. b = readByte(bb);
  429. part0 |= (b & 127) << 7;
  430. if (b & 128) {
  431. b = readByte(bb);
  432. part0 |= (b & 127) << 14;
  433. if (b & 128) {
  434. b = readByte(bb);
  435. part0 |= (b & 127) << 21;
  436. if (b & 128) {
  437. b = readByte(bb);
  438. part1 = b & 127;
  439. if (b & 128) {
  440. b = readByte(bb);
  441. part1 |= (b & 127) << 7;
  442. if (b & 128) {
  443. b = readByte(bb);
  444. part1 |= (b & 127) << 14;
  445. if (b & 128) {
  446. b = readByte(bb);
  447. part1 |= (b & 127) << 21;
  448. if (b & 128) {
  449. b = readByte(bb);
  450. part2 = b & 127;
  451. if (b & 128) {
  452. b = readByte(bb);
  453. part2 |= (b & 127) << 7;
  454. }
  455. }
  456. }
  457. }
  458. }
  459. }
  460. }
  461. }
  462. }
  463. return {
  464. low: part0 | part1 << 28,
  465. high: part1 >>> 4 | part2 << 24,
  466. unsigned
  467. };
  468. }
  469. function writeVarint64(bb, value) {
  470. let part0 = value.low >>> 0;
  471. let part1 = (value.low >>> 28 | value.high << 4) >>> 0;
  472. let part2 = value.high >>> 24;
  473. 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;
  474. let offset = grow(bb, size);
  475. let bytes = bb.bytes;
  476. switch (size) {
  477. case 10:
  478. bytes[offset + 9] = part2 >>> 7 & 1;
  479. break;
  480. case 9:
  481. bytes[offset + 8] = size !== 9 ? part2 | 128 : part2 & 127;
  482. break;
  483. case 8:
  484. bytes[offset + 7] = size !== 8 ? part1 >>> 21 | 128 : part1 >>> 21 & 127;
  485. break;
  486. case 7:
  487. bytes[offset + 6] = size !== 7 ? part1 >>> 14 | 128 : part1 >>> 14 & 127;
  488. break;
  489. case 6:
  490. bytes[offset + 5] = size !== 6 ? part1 >>> 7 | 128 : part1 >>> 7 & 127;
  491. break;
  492. case 5:
  493. bytes[offset + 4] = size !== 5 ? part1 | 128 : part1 & 127;
  494. break;
  495. case 4:
  496. bytes[offset + 3] = size !== 4 ? part0 >>> 21 | 128 : part0 >>> 21 & 127;
  497. break;
  498. case 3:
  499. bytes[offset + 2] = size !== 3 ? part0 >>> 14 | 128 : part0 >>> 14 & 127;
  500. break;
  501. case 2:
  502. bytes[offset + 1] = size !== 2 ? part0 >>> 7 | 128 : part0 >>> 7 & 127;
  503. break;
  504. case 1:
  505. bytes[offset] = size !== 1 ? part0 | 128 : part0 & 127;
  506. }
  507. }
  508. function readVarint32ZigZag(bb) {
  509. let value = readVarint32(bb);
  510. return value >>> 1 ^ -(value & 1);
  511. }
  512. function writeVarint32ZigZag(bb, value) {
  513. writeVarint32(bb, value << 1 ^ value >> 31);
  514. }
  515. function readVarint64ZigZag(bb) {
  516. let value = readVarint64(
  517. bb,
  518. /* unsigned */
  519. false
  520. );
  521. let low = value.low;
  522. let high = value.high;
  523. let flip = -(low & 1);
  524. return {
  525. low: (low >>> 1 | high << 31) ^ flip,
  526. high: high >>> 1 ^ flip,
  527. unsigned: false
  528. };
  529. }
  530. function writeVarint64ZigZag(bb, value) {
  531. let low = value.low;
  532. let high = value.high;
  533. let flip = high >> 31;
  534. writeVarint64(bb, {
  535. low: low << 1 ^ flip,
  536. high: (high << 1 | low >>> 31) ^ flip,
  537. unsigned: false
  538. });
  539. }
  540. //# 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":[]}