@loaders.gl/json 3.0.13 → 3.0.14

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.
@@ -7,93 +7,252 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.default = parseJSONInBatches;
9
9
 
10
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
11
+
12
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
13
+
14
+ var _awaitAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/awaitAsyncGenerator"));
15
+
16
+ var _wrapAsyncGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/wrapAsyncGenerator"));
17
+
18
+ var _asyncIterator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncIterator"));
19
+
10
20
  var _schema = require("@loaders.gl/schema");
11
21
 
12
22
  var _loaderUtils = require("@loaders.gl/loader-utils");
13
23
 
14
24
  var _streamingJsonParser = _interopRequireDefault(require("./parser/streaming-json-parser"));
15
25
 
16
- async function* parseJSONInBatches(binaryAsyncIterator, options) {
17
- var _options$json;
18
-
19
- const asyncIterator = (0, _loaderUtils.makeTextDecoderIterator)(binaryAsyncIterator);
20
- const {
21
- metadata
22
- } = options;
23
- const {
24
- jsonpaths
25
- } = options.json || {};
26
- let isFirstChunk = true;
27
- const schema = null;
28
- const shape = (options === null || options === void 0 ? void 0 : (_options$json = options.json) === null || _options$json === void 0 ? void 0 : _options$json.shape) || 'row-table';
29
- const tableBatchBuilder = new _schema.TableBatchBuilder(schema, { ...options,
30
- shape
31
- });
32
- const parser = new _streamingJsonParser.default({
33
- jsonpaths
34
- });
35
-
36
- for await (const chunk of asyncIterator) {
37
- const rows = parser.write(chunk);
38
- const jsonpath = rows.length > 0 && parser.getStreamingJsonPathAsString();
39
-
40
- if (rows.length > 0 && isFirstChunk) {
41
- if (metadata) {
42
- const initialBatch = {
43
- shape,
44
- batchType: 'partial-result',
45
- data: [],
46
- length: 0,
47
- bytesUsed: 0,
48
- container: parser.getPartialResult(),
49
- jsonpath
50
- };
51
- yield initialBatch;
52
- }
26
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
27
+
28
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
29
+
30
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
31
+
32
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
33
+
34
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
35
+
36
+ function parseJSONInBatches(_x, _x2) {
37
+ return _parseJSONInBatches.apply(this, arguments);
38
+ }
39
+
40
+ function _parseJSONInBatches() {
41
+ _parseJSONInBatches = (0, _wrapAsyncGenerator2.default)(_regenerator.default.mark(function _callee(binaryAsyncIterator, options) {
42
+ var _options$json;
43
+
44
+ var asyncIterator, metadata, _ref, jsonpaths, isFirstChunk, schema, shape, tableBatchBuilder, parser, _iteratorNormalCompletion, _didIteratorError, _iteratorError, _iterator, _step, _value, chunk, rows, _jsonpath, initialBatch, _iterator2, _step2, row, _batch2, _batch, jsonpath, batch, finalBatch;
45
+
46
+ return _regenerator.default.wrap(function _callee$(_context) {
47
+ while (1) {
48
+ switch (_context.prev = _context.next) {
49
+ case 0:
50
+ asyncIterator = (0, _loaderUtils.makeTextDecoderIterator)(binaryAsyncIterator);
51
+ metadata = options.metadata;
52
+ _ref = options.json || {}, jsonpaths = _ref.jsonpaths;
53
+ isFirstChunk = true;
54
+ schema = null;
55
+ shape = (options === null || options === void 0 ? void 0 : (_options$json = options.json) === null || _options$json === void 0 ? void 0 : _options$json.shape) || 'row-table';
56
+ tableBatchBuilder = new _schema.TableBatchBuilder(schema, _objectSpread(_objectSpread({}, options), {}, {
57
+ shape: shape
58
+ }));
59
+ parser = new _streamingJsonParser.default({
60
+ jsonpaths: jsonpaths
61
+ });
62
+ _iteratorNormalCompletion = true;
63
+ _didIteratorError = false;
64
+ _context.prev = 10;
65
+ _iterator = (0, _asyncIterator2.default)(asyncIterator);
66
+
67
+ case 12:
68
+ _context.next = 14;
69
+ return (0, _awaitAsyncGenerator2.default)(_iterator.next());
70
+
71
+ case 14:
72
+ _step = _context.sent;
73
+ _iteratorNormalCompletion = _step.done;
74
+ _context.next = 18;
75
+ return (0, _awaitAsyncGenerator2.default)(_step.value);
76
+
77
+ case 18:
78
+ _value = _context.sent;
79
+
80
+ if (_iteratorNormalCompletion) {
81
+ _context.next = 57;
82
+ break;
83
+ }
84
+
85
+ chunk = _value;
86
+ rows = parser.write(chunk);
87
+ _jsonpath = rows.length > 0 && parser.getStreamingJsonPathAsString();
88
+
89
+ if (!(rows.length > 0 && isFirstChunk)) {
90
+ _context.next = 29;
91
+ break;
92
+ }
93
+
94
+ if (!metadata) {
95
+ _context.next = 28;
96
+ break;
97
+ }
98
+
99
+ initialBatch = {
100
+ shape: shape,
101
+ batchType: 'partial-result',
102
+ data: [],
103
+ length: 0,
104
+ bytesUsed: 0,
105
+ container: parser.getPartialResult(),
106
+ jsonpath: _jsonpath
107
+ };
108
+ _context.next = 28;
109
+ return initialBatch;
110
+
111
+ case 28:
112
+ isFirstChunk = false;
113
+
114
+ case 29:
115
+ _iterator2 = _createForOfIteratorHelper(rows);
116
+ _context.prev = 30;
117
+
118
+ _iterator2.s();
119
+
120
+ case 32:
121
+ if ((_step2 = _iterator2.n()).done) {
122
+ _context.next = 41;
123
+ break;
124
+ }
125
+
126
+ row = _step2.value;
127
+ tableBatchBuilder.addRow(row);
128
+ _batch2 = tableBatchBuilder.getFullBatch({
129
+ jsonpath: _jsonpath
130
+ });
131
+
132
+ if (!_batch2) {
133
+ _context.next = 39;
134
+ break;
135
+ }
136
+
137
+ _context.next = 39;
138
+ return _batch2;
139
+
140
+ case 39:
141
+ _context.next = 32;
142
+ break;
143
+
144
+ case 41:
145
+ _context.next = 46;
146
+ break;
147
+
148
+ case 43:
149
+ _context.prev = 43;
150
+ _context.t0 = _context["catch"](30);
151
+
152
+ _iterator2.e(_context.t0);
153
+
154
+ case 46:
155
+ _context.prev = 46;
156
+
157
+ _iterator2.f();
158
+
159
+ return _context.finish(46);
160
+
161
+ case 49:
162
+ tableBatchBuilder.chunkComplete(chunk);
163
+ _batch = tableBatchBuilder.getFullBatch({
164
+ jsonpath: _jsonpath
165
+ });
166
+
167
+ if (!_batch) {
168
+ _context.next = 54;
169
+ break;
170
+ }
171
+
172
+ _context.next = 54;
173
+ return _batch;
174
+
175
+ case 54:
176
+ _iteratorNormalCompletion = true;
177
+ _context.next = 12;
178
+ break;
179
+
180
+ case 57:
181
+ _context.next = 63;
182
+ break;
183
+
184
+ case 59:
185
+ _context.prev = 59;
186
+ _context.t1 = _context["catch"](10);
187
+ _didIteratorError = true;
188
+ _iteratorError = _context.t1;
189
+
190
+ case 63:
191
+ _context.prev = 63;
192
+ _context.prev = 64;
193
+
194
+ if (!(!_iteratorNormalCompletion && _iterator.return != null)) {
195
+ _context.next = 68;
196
+ break;
197
+ }
198
+
199
+ _context.next = 68;
200
+ return (0, _awaitAsyncGenerator2.default)(_iterator.return());
201
+
202
+ case 68:
203
+ _context.prev = 68;
204
+
205
+ if (!_didIteratorError) {
206
+ _context.next = 71;
207
+ break;
208
+ }
209
+
210
+ throw _iteratorError;
211
+
212
+ case 71:
213
+ return _context.finish(68);
214
+
215
+ case 72:
216
+ return _context.finish(63);
217
+
218
+ case 73:
219
+ jsonpath = parser.getStreamingJsonPathAsString();
220
+ batch = tableBatchBuilder.getFinalBatch({
221
+ jsonpath: jsonpath
222
+ });
223
+
224
+ if (!batch) {
225
+ _context.next = 78;
226
+ break;
227
+ }
228
+
229
+ _context.next = 78;
230
+ return batch;
53
231
 
54
- isFirstChunk = false;
55
- }
232
+ case 78:
233
+ if (!metadata) {
234
+ _context.next = 82;
235
+ break;
236
+ }
56
237
 
57
- for (const row of rows) {
58
- tableBatchBuilder.addRow(row);
59
- const batch = tableBatchBuilder.getFullBatch({
60
- jsonpath
61
- });
238
+ finalBatch = {
239
+ shape: shape,
240
+ batchType: 'final-result',
241
+ container: parser.getPartialResult(),
242
+ jsonpath: parser.getStreamingJsonPathAsString(),
243
+ data: [],
244
+ length: 0
245
+ };
246
+ _context.next = 82;
247
+ return finalBatch;
62
248
 
63
- if (batch) {
64
- yield batch;
249
+ case 82:
250
+ case "end":
251
+ return _context.stop();
252
+ }
65
253
  }
66
- }
67
-
68
- tableBatchBuilder.chunkComplete(chunk);
69
- const batch = tableBatchBuilder.getFullBatch({
70
- jsonpath
71
- });
72
-
73
- if (batch) {
74
- yield batch;
75
- }
76
- }
77
-
78
- const jsonpath = parser.getStreamingJsonPathAsString();
79
- const batch = tableBatchBuilder.getFinalBatch({
80
- jsonpath
81
- });
82
-
83
- if (batch) {
84
- yield batch;
85
- }
86
-
87
- if (metadata) {
88
- const finalBatch = {
89
- shape,
90
- batchType: 'final-result',
91
- container: parser.getPartialResult(),
92
- jsonpath: parser.getStreamingJsonPathAsString(),
93
- data: [],
94
- length: 0
95
- };
96
- yield finalBatch;
97
- }
254
+ }, _callee, null, [[10, 59, 63, 73], [30, 43, 46, 49], [64,, 68, 72]]);
255
+ }));
256
+ return _parseJSONInBatches.apply(this, arguments);
98
257
  }
99
258
  //# sourceMappingURL=parse-json-in-batches.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/parse-json-in-batches.ts"],"names":["parseJSONInBatches","binaryAsyncIterator","options","asyncIterator","metadata","jsonpaths","json","isFirstChunk","schema","shape","tableBatchBuilder","TableBatchBuilder","parser","StreamingJSONParser","chunk","rows","write","jsonpath","length","getStreamingJsonPathAsString","initialBatch","batchType","data","bytesUsed","container","getPartialResult","row","addRow","batch","getFullBatch","chunkComplete","getFinalBatch","finalBatch"],"mappings":";;;;;;;;;AAEA;;AACA;;AACA;;AAIe,gBAAgBA,kBAAhB,CACbC,mBADa,EAEbC,OAFa,EAGS;AAAA;;AACtB,QAAMC,aAAa,GAAG,0CAAwBF,mBAAxB,CAAtB;AAEA,QAAM;AAACG,IAAAA;AAAD,MAAaF,OAAnB;AACA,QAAM;AAACG,IAAAA;AAAD,MAAcH,OAAO,CAACI,IAAR,IAAgB,EAApC;AAEA,MAAIC,YAAqB,GAAG,IAA5B;AAGA,QAAMC,MAAM,GAAG,IAAf;AACA,QAAMC,KAAK,GAAG,CAAAP,OAAO,SAAP,IAAAA,OAAO,WAAP,6BAAAA,OAAO,CAAEI,IAAT,gEAAeG,KAAf,KAAwB,WAAtC;AAEA,QAAMC,iBAAiB,GAAG,IAAIC,yBAAJ,CAAsBH,MAAtB,EAA8B,EACtD,GAAGN,OADmD;AAEtDO,IAAAA;AAFsD,GAA9B,CAA1B;AAKA,QAAMG,MAAM,GAAG,IAAIC,4BAAJ,CAAwB;AAACR,IAAAA;AAAD,GAAxB,CAAf;;AAEA,aAAW,MAAMS,KAAjB,IAA0BX,aAA1B,EAAyC;AACvC,UAAMY,IAAI,GAAGH,MAAM,CAACI,KAAP,CAAaF,KAAb,CAAb;AAEA,UAAMG,QAAQ,GAAGF,IAAI,CAACG,MAAL,GAAc,CAAd,IAAmBN,MAAM,CAACO,4BAAP,EAApC;;AAEA,QAAIJ,IAAI,CAACG,MAAL,GAAc,CAAd,IAAmBX,YAAvB,EAAqC;AACnC,UAAIH,QAAJ,EAAc;AACZ,cAAMgB,YAAmB,GAAG;AAE1BX,UAAAA,KAF0B;AAG1BY,UAAAA,SAAS,EAAE,gBAHe;AAI1BC,UAAAA,IAAI,EAAE,EAJoB;AAK1BJ,UAAAA,MAAM,EAAE,CALkB;AAM1BK,UAAAA,SAAS,EAAE,CANe;AAQ1BC,UAAAA,SAAS,EAAEZ,MAAM,CAACa,gBAAP,EARe;AAS1BR,UAAAA;AAT0B,SAA5B;AAWA,cAAMG,YAAN;AACD;;AACDb,MAAAA,YAAY,GAAG,KAAf;AAED;;AAGD,SAAK,MAAMmB,GAAX,IAAkBX,IAAlB,EAAwB;AACtBL,MAAAA,iBAAiB,CAACiB,MAAlB,CAAyBD,GAAzB;AAEA,YAAME,KAAK,GAAGlB,iBAAiB,CAACmB,YAAlB,CAA+B;AAACZ,QAAAA;AAAD,OAA/B,CAAd;;AACA,UAAIW,KAAJ,EAAW;AACT,cAAMA,KAAN;AACD;AACF;;AAEDlB,IAAAA,iBAAiB,CAACoB,aAAlB,CAAgChB,KAAhC;AACA,UAAMc,KAAK,GAAGlB,iBAAiB,CAACmB,YAAlB,CAA+B;AAACZ,MAAAA;AAAD,KAA/B,CAAd;;AACA,QAAIW,KAAJ,EAAW;AACT,YAAMA,KAAN;AACD;AACF;;AAGD,QAAMX,QAAQ,GAAGL,MAAM,CAACO,4BAAP,EAAjB;AACA,QAAMS,KAAK,GAAGlB,iBAAiB,CAACqB,aAAlB,CAAgC;AAACd,IAAAA;AAAD,GAAhC,CAAd;;AACA,MAAIW,KAAJ,EAAW;AACT,UAAMA,KAAN;AACD;;AAED,MAAIxB,QAAJ,EAAc;AACZ,UAAM4B,UAAiB,GAAG;AACxBvB,MAAAA,KADwB;AAExBY,MAAAA,SAAS,EAAE,cAFa;AAGxBG,MAAAA,SAAS,EAAEZ,MAAM,CAACa,gBAAP,EAHa;AAIxBR,MAAAA,QAAQ,EAAEL,MAAM,CAACO,4BAAP,EAJc;AAKxBG,MAAAA,IAAI,EAAE,EALkB;AAMxBJ,MAAAA,MAAM,EAAE;AANgB,KAA1B;AASA,UAAMc,UAAN;AACD;AACF","sourcesContent":["import type {Batch} from '@loaders.gl/schema';\nimport type {JSONLoaderOptions} from '../json-loader';\nimport {TableBatchBuilder} from '@loaders.gl/schema';\nimport {makeTextDecoderIterator} from '@loaders.gl/loader-utils';\nimport StreamingJSONParser from './parser/streaming-json-parser';\n\n// TODO - support batch size 0 = no batching/single batch?\n// eslint-disable-next-line max-statements, complexity\nexport default async function* parseJSONInBatches(\n binaryAsyncIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,\n options: JSONLoaderOptions\n): AsyncIterable<Batch> {\n const asyncIterator = makeTextDecoderIterator(binaryAsyncIterator);\n\n const {metadata} = options;\n const {jsonpaths} = options.json || {};\n\n let isFirstChunk: boolean = true;\n\n // TODO fix Schema deduction\n const schema = null; // new Schema([]);\n const shape = options?.json?.shape || 'row-table';\n // @ts-ignore\n const tableBatchBuilder = new TableBatchBuilder(schema, {\n ...options,\n shape\n });\n\n const parser = new StreamingJSONParser({jsonpaths});\n\n for await (const chunk of asyncIterator) {\n const rows = parser.write(chunk);\n\n const jsonpath = rows.length > 0 && parser.getStreamingJsonPathAsString();\n\n if (rows.length > 0 && isFirstChunk) {\n if (metadata) {\n const initialBatch: Batch = {\n // Common fields\n shape,\n batchType: 'partial-result',\n data: [],\n length: 0,\n bytesUsed: 0,\n // JSON additions\n container: parser.getPartialResult(),\n jsonpath\n };\n yield initialBatch;\n }\n isFirstChunk = false;\n // schema = deduceSchema(rows);\n }\n\n // Add the row\n for (const row of rows) {\n tableBatchBuilder.addRow(row);\n // If a batch has been completed, emit it\n const batch = tableBatchBuilder.getFullBatch({jsonpath});\n if (batch) {\n yield batch;\n }\n }\n\n tableBatchBuilder.chunkComplete(chunk);\n const batch = tableBatchBuilder.getFullBatch({jsonpath});\n if (batch) {\n yield batch;\n }\n }\n\n // yield final batch\n const jsonpath = parser.getStreamingJsonPathAsString();\n const batch = tableBatchBuilder.getFinalBatch({jsonpath});\n if (batch) {\n yield batch;\n }\n\n if (metadata) {\n const finalBatch: Batch = {\n shape,\n batchType: 'final-result',\n container: parser.getPartialResult(),\n jsonpath: parser.getStreamingJsonPathAsString(),\n data: [],\n length: 0\n // schema: null\n };\n yield finalBatch;\n }\n}\n"],"file":"parse-json-in-batches.js"}
1
+ {"version":3,"sources":["../../../src/lib/parse-json-in-batches.ts"],"names":["parseJSONInBatches","binaryAsyncIterator","options","asyncIterator","metadata","json","jsonpaths","isFirstChunk","schema","shape","tableBatchBuilder","TableBatchBuilder","parser","StreamingJSONParser","chunk","rows","write","jsonpath","length","getStreamingJsonPathAsString","initialBatch","batchType","data","bytesUsed","container","getPartialResult","row","addRow","batch","getFullBatch","chunkComplete","getFinalBatch","finalBatch"],"mappings":"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","sourcesContent":["import type {Batch} from '@loaders.gl/schema';\nimport type {JSONLoaderOptions} from '../json-loader';\nimport {TableBatchBuilder} from '@loaders.gl/schema';\nimport {makeTextDecoderIterator} from '@loaders.gl/loader-utils';\nimport StreamingJSONParser from './parser/streaming-json-parser';\n\n// TODO - support batch size 0 = no batching/single batch?\n// eslint-disable-next-line max-statements, complexity\nexport default async function* parseJSONInBatches(\n binaryAsyncIterator: AsyncIterable<ArrayBuffer> | Iterable<ArrayBuffer>,\n options: JSONLoaderOptions\n): AsyncIterable<Batch> {\n const asyncIterator = makeTextDecoderIterator(binaryAsyncIterator);\n\n const {metadata} = options;\n const {jsonpaths} = options.json || {};\n\n let isFirstChunk: boolean = true;\n\n // TODO fix Schema deduction\n const schema = null; // new Schema([]);\n const shape = options?.json?.shape || 'row-table';\n // @ts-ignore\n const tableBatchBuilder = new TableBatchBuilder(schema, {\n ...options,\n shape\n });\n\n const parser = new StreamingJSONParser({jsonpaths});\n\n for await (const chunk of asyncIterator) {\n const rows = parser.write(chunk);\n\n const jsonpath = rows.length > 0 && parser.getStreamingJsonPathAsString();\n\n if (rows.length > 0 && isFirstChunk) {\n if (metadata) {\n const initialBatch: Batch = {\n // Common fields\n shape,\n batchType: 'partial-result',\n data: [],\n length: 0,\n bytesUsed: 0,\n // JSON additions\n container: parser.getPartialResult(),\n jsonpath\n };\n yield initialBatch;\n }\n isFirstChunk = false;\n // schema = deduceSchema(rows);\n }\n\n // Add the row\n for (const row of rows) {\n tableBatchBuilder.addRow(row);\n // If a batch has been completed, emit it\n const batch = tableBatchBuilder.getFullBatch({jsonpath});\n if (batch) {\n yield batch;\n }\n }\n\n tableBatchBuilder.chunkComplete(chunk);\n const batch = tableBatchBuilder.getFullBatch({jsonpath});\n if (batch) {\n yield batch;\n }\n }\n\n // yield final batch\n const jsonpath = parser.getStreamingJsonPathAsString();\n const batch = tableBatchBuilder.getFinalBatch({jsonpath});\n if (batch) {\n yield batch;\n }\n\n if (metadata) {\n const finalBatch: Batch = {\n shape,\n batchType: 'final-result',\n container: parser.getPartialResult(),\n jsonpath: parser.getStreamingJsonPathAsString(),\n data: [],\n length: 0\n // schema: null\n };\n yield finalBatch;\n }\n}\n"],"file":"parse-json-in-batches.js"}
@@ -1,15 +1,19 @@
1
1
  "use strict";
2
2
 
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
6
8
  exports.default = parseJSONSync;
7
9
 
10
+ var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
11
+
8
12
  function parseJSONSync(jsonText, options) {
9
13
  try {
10
14
  var _options$json;
11
15
 
12
- const json = JSON.parse(jsonText);
16
+ var json = JSON.parse(jsonText);
13
17
 
14
18
  if ((_options$json = options.json) !== null && _options$json !== void 0 && _options$json.table) {
15
19
  return getFirstArray(json) || json;
@@ -26,9 +30,10 @@ function getFirstArray(json) {
26
30
  return json;
27
31
  }
28
32
 
29
- if (json && typeof json === 'object') {
30
- for (const value of Object.values(json)) {
31
- const array = getFirstArray(value);
33
+ if (json && (0, _typeof2.default)(json) === 'object') {
34
+ for (var _i = 0, _Object$values = Object.values(json); _i < _Object$values.length; _i++) {
35
+ var value = _Object$values[_i];
36
+ var array = getFirstArray(value);
32
37
 
33
38
  if (array) {
34
39
  return array;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/lib/parse-json.ts"],"names":["parseJSONSync","jsonText","options","json","JSON","parse","table","getFirstArray","error","Error","Array","isArray","value","Object","values","array"],"mappings":";;;;;;;AAEe,SAASA,aAAT,CAAuBC,QAAvB,EAAyCC,OAAzC,EAAqE;AAClF,MAAI;AAAA;;AACF,UAAMC,IAAI,GAAGC,IAAI,CAACC,KAAL,CAAWJ,QAAX,CAAb;;AACA,yBAAIC,OAAO,CAACC,IAAZ,0CAAI,cAAcG,KAAlB,EAAyB;AACvB,aAAOC,aAAa,CAACJ,IAAD,CAAb,IAAuBA,IAA9B;AACD;;AACD,WAAOA,IAAP;AACD,GAND,CAME,OAAOK,KAAP,EAAc;AACd,UAAM,IAAIC,KAAJ,CAAU,kCAAV,CAAN;AACD;AACF;;AAED,SAASF,aAAT,CAAuBJ,IAAvB,EAA6B;AAC3B,MAAIO,KAAK,CAACC,OAAN,CAAcR,IAAd,CAAJ,EAAyB;AACvB,WAAOA,IAAP;AACD;;AACD,MAAIA,IAAI,IAAI,OAAOA,IAAP,KAAgB,QAA5B,EAAsC;AACpC,SAAK,MAAMS,KAAX,IAAoBC,MAAM,CAACC,MAAP,CAAcX,IAAd,CAApB,EAAyC;AACvC,YAAMY,KAAK,GAAGR,aAAa,CAACK,KAAD,CAA3B;;AACA,UAAIG,KAAJ,EAAW;AACT,eAAOA,KAAP;AACD;AACF;AACF;;AACD,SAAO,IAAP;AACD","sourcesContent":["import type {JSONLoaderOptions} from '../json-loader';\n\nexport default function parseJSONSync(jsonText: string, options: JSONLoaderOptions) {\n try {\n const json = JSON.parse(jsonText);\n if (options.json?.table) {\n return getFirstArray(json) || json;\n }\n return json;\n } catch (error) {\n throw new Error('JSONLoader: failed to parse JSON');\n }\n}\n\nfunction getFirstArray(json) {\n if (Array.isArray(json)) {\n return json;\n }\n if (json && typeof json === 'object') {\n for (const value of Object.values(json)) {\n const array = getFirstArray(value);\n if (array) {\n return array;\n }\n }\n }\n return null;\n}\n"],"file":"parse-json.js"}
1
+ {"version":3,"sources":["../../../src/lib/parse-json.ts"],"names":["parseJSONSync","jsonText","options","json","JSON","parse","table","getFirstArray","error","Error","Array","isArray","Object","values","value","array"],"mappings":";;;;;;;;;;;AAEe,SAASA,aAAT,CAAuBC,QAAvB,EAAyCC,OAAzC,EAAqE;AAClF,MAAI;AAAA;;AACF,QAAMC,IAAI,GAAGC,IAAI,CAACC,KAAL,CAAWJ,QAAX,CAAb;;AACA,yBAAIC,OAAO,CAACC,IAAZ,0CAAI,cAAcG,KAAlB,EAAyB;AACvB,aAAOC,aAAa,CAACJ,IAAD,CAAb,IAAuBA,IAA9B;AACD;;AACD,WAAOA,IAAP;AACD,GAND,CAME,OAAOK,KAAP,EAAc;AACd,UAAM,IAAIC,KAAJ,CAAU,kCAAV,CAAN;AACD;AACF;;AAED,SAASF,aAAT,CAAuBJ,IAAvB,EAA6B;AAC3B,MAAIO,KAAK,CAACC,OAAN,CAAcR,IAAd,CAAJ,EAAyB;AACvB,WAAOA,IAAP;AACD;;AACD,MAAIA,IAAI,IAAI,sBAAOA,IAAP,MAAgB,QAA5B,EAAsC;AACpC,sCAAoBS,MAAM,CAACC,MAAP,CAAcV,IAAd,CAApB,oCAAyC;AAApC,UAAMW,KAAK,qBAAX;AACH,UAAMC,KAAK,GAAGR,aAAa,CAACO,KAAD,CAA3B;;AACA,UAAIC,KAAJ,EAAW;AACT,eAAOA,KAAP;AACD;AACF;AACF;;AACD,SAAO,IAAP;AACD","sourcesContent":["import type {JSONLoaderOptions} from '../json-loader';\n\nexport default function parseJSONSync(jsonText: string, options: JSONLoaderOptions) {\n try {\n const json = JSON.parse(jsonText);\n if (options.json?.table) {\n return getFirstArray(json) || json;\n }\n return json;\n } catch (error) {\n throw new Error('JSONLoader: failed to parse JSON');\n }\n}\n\nfunction getFirstArray(json) {\n if (Array.isArray(json)) {\n return json;\n }\n if (json && typeof json === 'object') {\n for (const value of Object.values(json)) {\n const array = getFirstArray(value);\n if (array) {\n return array;\n }\n }\n }\n return null;\n}\n"],"file":"parse-json.js"}
@@ -7,14 +7,19 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.default = void 0;
9
9
 
10
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
+
12
+ var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
+
10
14
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
11
15
 
12
16
  var _clarinet = _interopRequireDefault(require("../clarinet/clarinet"));
13
17
 
14
18
  var _jsonpath = _interopRequireDefault(require("../jsonpath/jsonpath"));
15
19
 
16
- class JSONParser {
17
- constructor() {
20
+ var JSONParser = function () {
21
+ function JSONParser() {
22
+ (0, _classCallCheck2.default)(this, JSONParser);
18
23
  (0, _defineProperty2.default)(this, "jsonpath", void 0);
19
24
  (0, _defineProperty2.default)(this, "_parser", void 0);
20
25
  this.reset();
@@ -22,118 +27,134 @@ class JSONParser {
22
27
  this._initializeParser();
23
28
  }
24
29
 
25
- reset() {
26
- this.result = undefined;
27
- this.previousStates = [];
28
- this.currentState = Object.freeze({
29
- container: [],
30
- key: null
31
- });
32
- this.jsonpath = new _jsonpath.default();
33
- }
34
-
35
- write(chunk) {
36
- this.parser.write(chunk);
37
- }
38
-
39
- close() {
40
- this.parser.close();
41
- }
42
-
43
- _pushOrSet(value) {
44
- const {
45
- container,
46
- key
47
- } = this.currentState;
48
-
49
- if (key !== null) {
50
- container[key] = value;
51
- this.currentState.key = null;
52
- } else {
53
- container.push(value);
30
+ (0, _createClass2.default)(JSONParser, [{
31
+ key: "reset",
32
+ value: function reset() {
33
+ this.result = undefined;
34
+ this.previousStates = [];
35
+ this.currentState = Object.freeze({
36
+ container: [],
37
+ key: null
38
+ });
39
+ this.jsonpath = new _jsonpath.default();
54
40
  }
55
- }
56
-
57
- _openArray(newContainer = []) {
58
- this.jsonpath.push(null);
59
-
60
- this._pushOrSet(newContainer);
61
-
62
- this.previousStates.push(this.currentState);
63
- this.currentState = {
64
- container: newContainer,
65
- isArray: true,
66
- key: null
67
- };
68
- }
69
-
70
- _closeArray() {
71
- this.jsonpath.pop();
72
- this.currentState = this.previousStates.pop();
73
- }
74
-
75
- _openObject(newContainer = {}) {
76
- this.jsonpath.push(null);
77
-
78
- this._pushOrSet(newContainer);
79
-
80
- this.previousStates.push(this.currentState);
81
- this.currentState = {
82
- container: newContainer,
83
- isArray: false,
84
- key: null
85
- };
86
- }
87
-
88
- _closeObject() {
89
- this.jsonpath.pop();
90
- this.currentState = this.previousStates.pop();
91
- }
92
-
93
- _initializeParser() {
94
- this._parser = new _clarinet.default({
95
- onready: () => {
96
- this.jsonpath = new _jsonpath.default();
97
- this.previousStates.length = 0;
98
- this.currentState.container.length = 0;
99
- },
100
- onopenobject: name => {
101
- this._openObject({});
102
-
103
- if (typeof name !== 'undefined') {
104
- this.parser.onkey(name);
105
- }
106
- },
107
- onkey: name => {
108
- this.jsonpath.set(name);
109
- this.currentState.key = name;
110
- },
111
- oncloseobject: () => {
112
- this._closeObject();
113
- },
114
- onopenarray: () => {
115
- this._openArray();
116
- },
117
- onclosearray: () => {
118
- this._closeArray();
119
- },
120
- onvalue: value => {
121
- this._pushOrSet(value);
122
- },
123
- onerror: error => {
124
- throw error;
125
- },
126
- onend: () => {
127
- this.result = this.currentState.container.pop();
41
+ }, {
42
+ key: "write",
43
+ value: function write(chunk) {
44
+ this.parser.write(chunk);
45
+ }
46
+ }, {
47
+ key: "close",
48
+ value: function close() {
49
+ this.parser.close();
50
+ }
51
+ }, {
52
+ key: "_pushOrSet",
53
+ value: function _pushOrSet(value) {
54
+ var _this$currentState = this.currentState,
55
+ container = _this$currentState.container,
56
+ key = _this$currentState.key;
57
+
58
+ if (key !== null) {
59
+ container[key] = value;
60
+ this.currentState.key = null;
61
+ } else {
62
+ container.push(value);
128
63
  }
129
- });
130
- }
131
-
132
- get parser() {
133
- return this._parser;
134
- }
135
-
136
- }
64
+ }
65
+ }, {
66
+ key: "_openArray",
67
+ value: function _openArray() {
68
+ var newContainer = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
69
+ this.jsonpath.push(null);
70
+
71
+ this._pushOrSet(newContainer);
72
+
73
+ this.previousStates.push(this.currentState);
74
+ this.currentState = {
75
+ container: newContainer,
76
+ isArray: true,
77
+ key: null
78
+ };
79
+ }
80
+ }, {
81
+ key: "_closeArray",
82
+ value: function _closeArray() {
83
+ this.jsonpath.pop();
84
+ this.currentState = this.previousStates.pop();
85
+ }
86
+ }, {
87
+ key: "_openObject",
88
+ value: function _openObject() {
89
+ var newContainer = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
90
+ this.jsonpath.push(null);
91
+
92
+ this._pushOrSet(newContainer);
93
+
94
+ this.previousStates.push(this.currentState);
95
+ this.currentState = {
96
+ container: newContainer,
97
+ isArray: false,
98
+ key: null
99
+ };
100
+ }
101
+ }, {
102
+ key: "_closeObject",
103
+ value: function _closeObject() {
104
+ this.jsonpath.pop();
105
+ this.currentState = this.previousStates.pop();
106
+ }
107
+ }, {
108
+ key: "_initializeParser",
109
+ value: function _initializeParser() {
110
+ var _this = this;
111
+
112
+ this._parser = new _clarinet.default({
113
+ onready: function onready() {
114
+ _this.jsonpath = new _jsonpath.default();
115
+ _this.previousStates.length = 0;
116
+ _this.currentState.container.length = 0;
117
+ },
118
+ onopenobject: function onopenobject(name) {
119
+ _this._openObject({});
120
+
121
+ if (typeof name !== 'undefined') {
122
+ _this.parser.onkey(name);
123
+ }
124
+ },
125
+ onkey: function onkey(name) {
126
+ _this.jsonpath.set(name);
127
+
128
+ _this.currentState.key = name;
129
+ },
130
+ oncloseobject: function oncloseobject() {
131
+ _this._closeObject();
132
+ },
133
+ onopenarray: function onopenarray() {
134
+ _this._openArray();
135
+ },
136
+ onclosearray: function onclosearray() {
137
+ _this._closeArray();
138
+ },
139
+ onvalue: function onvalue(value) {
140
+ _this._pushOrSet(value);
141
+ },
142
+ onerror: function onerror(error) {
143
+ throw error;
144
+ },
145
+ onend: function onend() {
146
+ _this.result = _this.currentState.container.pop();
147
+ }
148
+ });
149
+ }
150
+ }, {
151
+ key: "parser",
152
+ get: function get() {
153
+ return this._parser;
154
+ }
155
+ }]);
156
+ return JSONParser;
157
+ }();
137
158
 
138
159
  exports.default = JSONParser;
139
160
  //# sourceMappingURL=json-parser.js.map