@clickhouse/client 0.2.3 → 0.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,5 +1,5 @@
1
1
  <p align="center">
2
- <img src=".static/logo.png" width="200px" align="center">
2
+ <img src=".static/logo.svg" width="200px" align="center">
3
3
  <h1 align="center">ClickHouse JS client</h1>
4
4
  </p>
5
5
  <br/>
@@ -25,8 +25,10 @@ var __importStar = (this && this.__importStar) || function (mod) {
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
26
  exports.ResultSet = void 0;
27
27
  const client_common_1 = require("@clickhouse/client-common");
28
+ const buffer_1 = require("buffer");
28
29
  const stream_1 = __importStar(require("stream"));
29
30
  const utils_1 = require("./utils");
31
+ const NEWLINE = 0x0a;
30
32
  class ResultSet {
31
33
  constructor(_stream, format, query_id) {
32
34
  Object.defineProperty(this, "_stream", {
@@ -68,30 +70,53 @@ class ResultSet {
68
70
  throw Error(streamAlreadyConsumedMessage);
69
71
  }
70
72
  (0, client_common_1.validateStreamFormat)(this.format);
71
- let decodedChunk = '';
73
+ let incompleteChunks = [];
72
74
  const toRows = new stream_1.Transform({
73
- transform(chunk, encoding, callback) {
74
- decodedChunk += chunk.toString();
75
+ transform(chunk, _encoding, callback) {
75
76
  const rows = [];
76
- // eslint-disable-next-line no-constant-condition
77
- while (true) {
78
- const idx = decodedChunk.indexOf('\n');
79
- if (idx !== -1) {
80
- const text = decodedChunk.slice(0, idx);
81
- decodedChunk = decodedChunk.slice(idx + 1);
82
- rows.push({
83
- text,
84
- json() {
85
- return (0, client_common_1.decode)(text, 'JSON');
86
- },
87
- });
77
+ let lastIdx = 0;
78
+ // first pass on the current chunk
79
+ // using the incomplete row from the previous chunks
80
+ let idx = chunk.indexOf(NEWLINE);
81
+ if (idx !== -1) {
82
+ let text;
83
+ if (incompleteChunks.length > 0) {
84
+ text = buffer_1.Buffer.concat([...incompleteChunks, chunk.subarray(0, idx)], incompleteChunks.reduce((sz, buf) => sz + buf.length, 0) + idx).toString();
85
+ incompleteChunks = [];
88
86
  }
89
87
  else {
90
- if (rows.length) {
88
+ text = chunk.subarray(0, idx).toString();
89
+ }
90
+ rows.push({
91
+ text,
92
+ json() {
93
+ return JSON.parse(text);
94
+ },
95
+ });
96
+ lastIdx = idx + 1; // skipping newline character
97
+ // consequent passes on the current chunk with at least one row parsed
98
+ // all previous chunks with incomplete rows were already processed
99
+ do {
100
+ idx = chunk.indexOf(NEWLINE, lastIdx);
101
+ if (idx !== -1) {
102
+ const text = chunk.subarray(lastIdx, idx).toString();
103
+ rows.push({
104
+ text,
105
+ json() {
106
+ return JSON.parse(text);
107
+ },
108
+ });
109
+ }
110
+ else {
111
+ // to be processed during the first pass for the next chunk
112
+ incompleteChunks.push(chunk.subarray(lastIdx));
91
113
  this.push(rows);
92
114
  }
93
- break;
94
- }
115
+ lastIdx = idx + 1; // skipping newline character
116
+ } while (idx !== -1);
117
+ }
118
+ else {
119
+ incompleteChunks.push(chunk); // this chunk does not contain a full row
95
120
  }
96
121
  callback();
97
122
  },
@@ -1 +1 @@
1
- {"version":3,"file":"result_set.js","sourceRoot":"","sources":["../../../packages/client-node/src/result_set.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AACA,6DAAwE;AAExE,iDAA0C;AAC1C,mCAAmC;AAEnC,MAAa,SAAS;IACpB,YACU,OAAwB,EACf,MAAkB,EACnB,QAAgB;;;;;mBAFxB;;;;;;mBACS;;;;;;mBACD;;IACf,CAAC;IAEJ,KAAK,CAAC,IAAI;QACR,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE;YAC9B,MAAM,KAAK,CAAC,4BAA4B,CAAC,CAAA;SAC1C;QACD,OAAO,CAAC,MAAM,IAAA,iBAAS,EAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAA;IACnD,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE;YAC9B,MAAM,KAAK,CAAC,4BAA4B,CAAC,CAAA;SAC1C;QACD,OAAO,IAAA,sBAAM,EAAC,MAAM,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IAC/C,CAAC;IAED,MAAM;QACJ,0EAA0E;QAC1E,iDAAiD;QACjD,+CAA+C;QAC/C,IAAI,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE;YAC9B,MAAM,KAAK,CAAC,4BAA4B,CAAC,CAAA;SAC1C;QAED,IAAA,oCAAoB,EAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAEjC,IAAI,YAAY,GAAG,EAAE,CAAA;QACrB,MAAM,MAAM,GAAG,IAAI,kBAAS,CAAC;YAC3B,SAAS,CACP,KAAa,EACb,QAAwB,EACxB,QAA2B;gBAE3B,YAAY,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAA;gBAChC,MAAM,IAAI,GAAU,EAAE,CAAA;gBACtB,iDAAiD;gBACjD,OAAO,IAAI,EAAE;oBACX,MAAM,GAAG,GAAG,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,CAAA;oBACtC,IAAI,GAAG,KAAK,CAAC,CAAC,EAAE;wBACd,MAAM,IAAI,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;wBACvC,YAAY,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAA;wBAC1C,IAAI,CAAC,IAAI,CAAC;4BACR,IAAI;4BACJ,IAAI;gCACF,OAAO,IAAA,sBAAM,EAAC,IAAI,EAAE,MAAM,CAAC,CAAA;4BAC7B,CAAC;yBACF,CAAC,CAAA;qBACH;yBAAM;wBACL,IAAI,IAAI,CAAC,MAAM,EAAE;4BACf,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;yBAChB;wBACD,MAAK;qBACN;iBACF;gBACD,QAAQ,EAAE,CAAA;YACZ,CAAC;YACD,WAAW,EAAE,IAAI;YACjB,UAAU,EAAE,IAAI;SACjB,CAAC,CAAA;QAEF,OAAO,gBAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,UAAU,CAAC,GAAG;YAClE,IAAI,GAAG,EAAE;gBACP,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;aACnB;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,KAAK;QACH,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAA;IACxB,CAAC;CACF;AA3ED,8BA2EC;AAED,MAAM,4BAA4B,GAAG,kCAAkC,CAAA"}
1
+ {"version":3,"file":"result_set.js","sourceRoot":"","sources":["../../../packages/client-node/src/result_set.ts"],"names":[],"mappings":"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"}
package/dist/version.d.ts CHANGED
@@ -1,2 +1,2 @@
1
- declare const _default: "0.2.3";
1
+ declare const _default: "0.2.4";
2
2
  export default _default;
package/dist/version.js CHANGED
@@ -1,4 +1,4 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.default = '0.2.3';
3
+ exports.default = '0.2.4';
4
4
  //# sourceMappingURL=version.js.map
package/package.json CHANGED
@@ -2,7 +2,7 @@
2
2
  "name": "@clickhouse/client",
3
3
  "description": "Official JS client for ClickHouse DB - Node.js implementation",
4
4
  "homepage": "https://clickhouse.com",
5
- "version": "0.2.3",
5
+ "version": "0.2.4",
6
6
  "license": "Apache-2.0",
7
7
  "keywords": [
8
8
  "clickhouse",
@@ -23,6 +23,6 @@
23
23
  "dist"
24
24
  ],
25
25
  "dependencies": {
26
- "@clickhouse/client-common": "0.2.3"
26
+ "@clickhouse/client-common": "0.2.4"
27
27
  }
28
28
  }