@loaders.gl/parquet 3.1.0-alpha.5 → 3.1.0-beta.5

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.
Files changed (264) hide show
  1. package/dist/bundle.d.ts +1 -0
  2. package/dist/bundle.d.ts.map +1 -0
  3. package/dist/bundle.js +5 -0
  4. package/dist/constants.d.ts +1 -0
  5. package/dist/constants.d.ts.map +1 -0
  6. package/dist/constants.js +18 -0
  7. package/dist/dist.min.js +27 -13
  8. package/dist/dist.min.js.map +7 -1
  9. package/dist/es5/index.js +6 -26
  10. package/dist/es5/index.js.map +1 -1
  11. package/dist/es5/parquet-loader.js +1 -1
  12. package/dist/es5/parquet-loader.js.map +1 -1
  13. package/dist/es5/parquet-writer.js +1 -1
  14. package/dist/es5/parquet-writer.js.map +1 -1
  15. package/dist/es5/parquetjs/codecs/rle.js +1 -1
  16. package/dist/es5/parquetjs/codecs/rle.js.map +1 -1
  17. package/dist/es5/parquetjs/compression.js +1 -12
  18. package/dist/es5/parquetjs/compression.js.map +1 -1
  19. package/dist/es5/parquetjs/parser/decoders.js +1 -1
  20. package/dist/es5/parquetjs/parser/decoders.js.map +1 -1
  21. package/dist/es5/parquetjs/parser/parquet-envelope-reader.js +0 -13
  22. package/dist/es5/parquetjs/parser/parquet-envelope-reader.js.map +1 -1
  23. package/dist/es5/parquetjs/parser/parquet-reader.js +0 -13
  24. package/dist/es5/parquetjs/parser/parquet-reader.js.map +1 -1
  25. package/dist/es5/parquetjs/utils/file-utils.js +0 -53
  26. package/dist/es5/parquetjs/utils/file-utils.js.map +1 -1
  27. package/dist/esm/index.js +2 -3
  28. package/dist/esm/index.js.map +1 -1
  29. package/dist/esm/parquet-loader.js +1 -1
  30. package/dist/esm/parquet-loader.js.map +1 -1
  31. package/dist/esm/parquet-writer.js +1 -1
  32. package/dist/esm/parquet-writer.js.map +1 -1
  33. package/dist/esm/parquetjs/codecs/rle.js +1 -1
  34. package/dist/esm/parquetjs/codecs/rle.js.map +1 -1
  35. package/dist/esm/parquetjs/compression.js +1 -10
  36. package/dist/esm/parquetjs/compression.js.map +1 -1
  37. package/dist/esm/parquetjs/parser/decoders.js +1 -1
  38. package/dist/esm/parquetjs/parser/decoders.js.map +1 -1
  39. package/dist/esm/parquetjs/parser/parquet-envelope-reader.js +0 -9
  40. package/dist/esm/parquetjs/parser/parquet-envelope-reader.js.map +1 -1
  41. package/dist/esm/parquetjs/parser/parquet-reader.js +0 -13
  42. package/dist/esm/parquetjs/parser/parquet-reader.js.map +1 -1
  43. package/dist/esm/parquetjs/utils/file-utils.js +0 -45
  44. package/dist/esm/parquetjs/utils/file-utils.js.map +1 -1
  45. package/dist/index.d.ts +3 -3
  46. package/dist/index.d.ts.map +1 -0
  47. package/dist/index.js +30 -0
  48. package/dist/lib/convert-schema.d.ts +1 -0
  49. package/dist/lib/convert-schema.d.ts.map +1 -0
  50. package/dist/lib/convert-schema.js +70 -0
  51. package/dist/lib/parse-parquet.d.ts +1 -0
  52. package/dist/lib/parse-parquet.d.ts.map +1 -0
  53. package/dist/lib/parse-parquet.js +28 -0
  54. package/dist/lib/read-array-buffer.d.ts +1 -0
  55. package/dist/lib/read-array-buffer.d.ts.map +1 -0
  56. package/dist/lib/read-array-buffer.js +29 -0
  57. package/dist/parquet-loader.d.ts +1 -0
  58. package/dist/parquet-loader.d.ts.map +1 -0
  59. package/dist/parquet-loader.js +27 -0
  60. package/dist/parquet-worker.js +27 -13
  61. package/dist/parquet-worker.js.map +7 -1
  62. package/dist/parquet-writer.d.ts +1 -0
  63. package/dist/parquet-writer.d.ts.map +1 -0
  64. package/dist/parquet-writer.js +21 -0
  65. package/dist/parquetjs/codecs/declare.d.ts +1 -0
  66. package/dist/parquetjs/codecs/declare.d.ts.map +1 -0
  67. package/dist/parquetjs/codecs/declare.js +2 -0
  68. package/dist/parquetjs/codecs/dictionary.d.ts +1 -0
  69. package/dist/parquetjs/codecs/dictionary.d.ts.map +1 -0
  70. package/dist/parquetjs/codecs/dictionary.js +14 -0
  71. package/dist/parquetjs/codecs/index.d.ts +1 -0
  72. package/dist/parquetjs/codecs/index.d.ts.map +1 -0
  73. package/dist/parquetjs/codecs/index.js +51 -0
  74. package/dist/parquetjs/codecs/plain.d.ts +1 -0
  75. package/dist/parquetjs/codecs/plain.d.ts.map +1 -0
  76. package/dist/parquetjs/codecs/plain.js +211 -0
  77. package/dist/parquetjs/codecs/rle.d.ts +1 -0
  78. package/dist/parquetjs/codecs/rle.d.ts.map +1 -0
  79. package/dist/parquetjs/codecs/rle.js +145 -0
  80. package/dist/parquetjs/compression.d.ts +1 -0
  81. package/dist/parquetjs/compression.d.ts.map +1 -0
  82. package/dist/parquetjs/compression.js +168 -0
  83. package/dist/parquetjs/encoder/writer.d.ts +1 -0
  84. package/dist/parquetjs/encoder/writer.d.ts.map +1 -0
  85. package/dist/parquetjs/encoder/writer.js +478 -0
  86. package/dist/parquetjs/file.d.ts +1 -0
  87. package/dist/parquetjs/file.d.ts.map +1 -0
  88. package/dist/parquetjs/file.js +99 -0
  89. package/dist/parquetjs/parquet-thrift/BoundaryOrder.d.ts +1 -0
  90. package/dist/parquetjs/parquet-thrift/BoundaryOrder.d.ts.map +1 -0
  91. package/dist/parquetjs/parquet-thrift/BoundaryOrder.js +15 -0
  92. package/dist/parquetjs/parquet-thrift/BsonType.d.ts +1 -0
  93. package/dist/parquetjs/parquet-thrift/BsonType.d.ts.map +1 -0
  94. package/dist/parquetjs/parquet-thrift/BsonType.js +58 -0
  95. package/dist/parquetjs/parquet-thrift/ColumnChunk.d.ts +1 -0
  96. package/dist/parquetjs/parquet-thrift/ColumnChunk.d.ts.map +1 -0
  97. package/dist/parquetjs/parquet-thrift/ColumnChunk.js +207 -0
  98. package/dist/parquetjs/parquet-thrift/ColumnIndex.d.ts +1 -0
  99. package/dist/parquetjs/parquet-thrift/ColumnIndex.d.ts.map +1 -0
  100. package/dist/parquetjs/parquet-thrift/ColumnIndex.js +213 -0
  101. package/dist/parquetjs/parquet-thrift/ColumnMetaData.d.ts +1 -0
  102. package/dist/parquetjs/parquet-thrift/ColumnMetaData.d.ts.map +1 -0
  103. package/dist/parquetjs/parquet-thrift/ColumnMetaData.js +398 -0
  104. package/dist/parquetjs/parquet-thrift/ColumnOrder.d.ts +1 -0
  105. package/dist/parquetjs/parquet-thrift/ColumnOrder.d.ts.map +1 -0
  106. package/dist/parquetjs/parquet-thrift/ColumnOrder.js +104 -0
  107. package/dist/parquetjs/parquet-thrift/CompressionCodec.d.ts +1 -0
  108. package/dist/parquetjs/parquet-thrift/CompressionCodec.d.ts.map +1 -0
  109. package/dist/parquetjs/parquet-thrift/CompressionCodec.js +20 -0
  110. package/dist/parquetjs/parquet-thrift/ConvertedType.d.ts +1 -0
  111. package/dist/parquetjs/parquet-thrift/ConvertedType.d.ts.map +1 -0
  112. package/dist/parquetjs/parquet-thrift/ConvertedType.js +34 -0
  113. package/dist/parquetjs/parquet-thrift/DataPageHeader.d.ts +1 -0
  114. package/dist/parquetjs/parquet-thrift/DataPageHeader.d.ts.map +1 -0
  115. package/dist/parquetjs/parquet-thrift/DataPageHeader.js +166 -0
  116. package/dist/parquetjs/parquet-thrift/DataPageHeaderV2.d.ts +1 -0
  117. package/dist/parquetjs/parquet-thrift/DataPageHeaderV2.d.ts.map +1 -0
  118. package/dist/parquetjs/parquet-thrift/DataPageHeaderV2.js +226 -0
  119. package/dist/parquetjs/parquet-thrift/DateType.d.ts +1 -0
  120. package/dist/parquetjs/parquet-thrift/DateType.d.ts.map +1 -0
  121. package/dist/parquetjs/parquet-thrift/DateType.js +58 -0
  122. package/dist/parquetjs/parquet-thrift/DecimalType.d.ts +1 -0
  123. package/dist/parquetjs/parquet-thrift/DecimalType.d.ts.map +1 -0
  124. package/dist/parquetjs/parquet-thrift/DecimalType.js +105 -0
  125. package/dist/parquetjs/parquet-thrift/DictionaryPageHeader.d.ts +1 -0
  126. package/dist/parquetjs/parquet-thrift/DictionaryPageHeader.d.ts.map +1 -0
  127. package/dist/parquetjs/parquet-thrift/DictionaryPageHeader.js +122 -0
  128. package/dist/parquetjs/parquet-thrift/Encoding.d.ts +1 -0
  129. package/dist/parquetjs/parquet-thrift/Encoding.d.ts.map +1 -0
  130. package/dist/parquetjs/parquet-thrift/Encoding.js +20 -0
  131. package/dist/parquetjs/parquet-thrift/EnumType.d.ts +1 -0
  132. package/dist/parquetjs/parquet-thrift/EnumType.d.ts.map +1 -0
  133. package/dist/parquetjs/parquet-thrift/EnumType.js +58 -0
  134. package/dist/parquetjs/parquet-thrift/FieldRepetitionType.d.ts +1 -0
  135. package/dist/parquetjs/parquet-thrift/FieldRepetitionType.d.ts.map +1 -0
  136. package/dist/parquetjs/parquet-thrift/FieldRepetitionType.js +15 -0
  137. package/dist/parquetjs/parquet-thrift/FileMetaData.d.ts +1 -0
  138. package/dist/parquetjs/parquet-thrift/FileMetaData.d.ts.map +1 -0
  139. package/dist/parquetjs/parquet-thrift/FileMetaData.js +256 -0
  140. package/dist/parquetjs/parquet-thrift/IndexPageHeader.d.ts +1 -0
  141. package/dist/parquetjs/parquet-thrift/IndexPageHeader.d.ts.map +1 -0
  142. package/dist/parquetjs/parquet-thrift/IndexPageHeader.js +58 -0
  143. package/dist/parquetjs/parquet-thrift/IntType.d.ts +1 -0
  144. package/dist/parquetjs/parquet-thrift/IntType.d.ts.map +1 -0
  145. package/dist/parquetjs/parquet-thrift/IntType.js +105 -0
  146. package/dist/parquetjs/parquet-thrift/JsonType.d.ts +1 -0
  147. package/dist/parquetjs/parquet-thrift/JsonType.d.ts.map +1 -0
  148. package/dist/parquetjs/parquet-thrift/JsonType.js +58 -0
  149. package/dist/parquetjs/parquet-thrift/KeyValue.d.ts +1 -0
  150. package/dist/parquetjs/parquet-thrift/KeyValue.d.ts.map +1 -0
  151. package/dist/parquetjs/parquet-thrift/KeyValue.js +102 -0
  152. package/dist/parquetjs/parquet-thrift/ListType.d.ts +1 -0
  153. package/dist/parquetjs/parquet-thrift/ListType.d.ts.map +1 -0
  154. package/dist/parquetjs/parquet-thrift/ListType.js +58 -0
  155. package/dist/parquetjs/parquet-thrift/LogicalType.d.ts +1 -0
  156. package/dist/parquetjs/parquet-thrift/LogicalType.d.ts.map +1 -0
  157. package/dist/parquetjs/parquet-thrift/LogicalType.js +380 -0
  158. package/dist/parquetjs/parquet-thrift/MapType.d.ts +1 -0
  159. package/dist/parquetjs/parquet-thrift/MapType.d.ts.map +1 -0
  160. package/dist/parquetjs/parquet-thrift/MapType.js +58 -0
  161. package/dist/parquetjs/parquet-thrift/MicroSeconds.d.ts +1 -0
  162. package/dist/parquetjs/parquet-thrift/MicroSeconds.d.ts.map +1 -0
  163. package/dist/parquetjs/parquet-thrift/MicroSeconds.js +58 -0
  164. package/dist/parquetjs/parquet-thrift/MilliSeconds.d.ts +1 -0
  165. package/dist/parquetjs/parquet-thrift/MilliSeconds.d.ts.map +1 -0
  166. package/dist/parquetjs/parquet-thrift/MilliSeconds.js +58 -0
  167. package/dist/parquetjs/parquet-thrift/NullType.d.ts +1 -0
  168. package/dist/parquetjs/parquet-thrift/NullType.d.ts.map +1 -0
  169. package/dist/parquetjs/parquet-thrift/NullType.js +58 -0
  170. package/dist/parquetjs/parquet-thrift/OffsetIndex.d.ts +1 -0
  171. package/dist/parquetjs/parquet-thrift/OffsetIndex.d.ts.map +1 -0
  172. package/dist/parquetjs/parquet-thrift/OffsetIndex.js +97 -0
  173. package/dist/parquetjs/parquet-thrift/PageEncodingStats.d.ts +1 -0
  174. package/dist/parquetjs/parquet-thrift/PageEncodingStats.d.ts.map +1 -0
  175. package/dist/parquetjs/parquet-thrift/PageEncodingStats.js +127 -0
  176. package/dist/parquetjs/parquet-thrift/PageHeader.d.ts +1 -0
  177. package/dist/parquetjs/parquet-thrift/PageHeader.d.ts.map +1 -0
  178. package/dist/parquetjs/parquet-thrift/PageHeader.js +216 -0
  179. package/dist/parquetjs/parquet-thrift/PageLocation.d.ts +1 -0
  180. package/dist/parquetjs/parquet-thrift/PageLocation.d.ts.map +1 -0
  181. package/dist/parquetjs/parquet-thrift/PageLocation.js +141 -0
  182. package/dist/parquetjs/parquet-thrift/PageType.d.ts +1 -0
  183. package/dist/parquetjs/parquet-thrift/PageType.d.ts.map +1 -0
  184. package/dist/parquetjs/parquet-thrift/PageType.js +16 -0
  185. package/dist/parquetjs/parquet-thrift/RowGroup.d.ts +1 -0
  186. package/dist/parquetjs/parquet-thrift/RowGroup.d.ts.map +1 -0
  187. package/dist/parquetjs/parquet-thrift/RowGroup.js +182 -0
  188. package/dist/parquetjs/parquet-thrift/SchemaElement.d.ts +1 -0
  189. package/dist/parquetjs/parquet-thrift/SchemaElement.d.ts.map +1 -0
  190. package/dist/parquetjs/parquet-thrift/SchemaElement.js +239 -0
  191. package/dist/parquetjs/parquet-thrift/SortingColumn.d.ts +1 -0
  192. package/dist/parquetjs/parquet-thrift/SortingColumn.d.ts.map +1 -0
  193. package/dist/parquetjs/parquet-thrift/SortingColumn.js +127 -0
  194. package/dist/parquetjs/parquet-thrift/Statistics.d.ts +1 -0
  195. package/dist/parquetjs/parquet-thrift/Statistics.d.ts.map +1 -0
  196. package/dist/parquetjs/parquet-thrift/Statistics.js +176 -0
  197. package/dist/parquetjs/parquet-thrift/StringType.d.ts +1 -0
  198. package/dist/parquetjs/parquet-thrift/StringType.d.ts.map +1 -0
  199. package/dist/parquetjs/parquet-thrift/StringType.js +58 -0
  200. package/dist/parquetjs/parquet-thrift/TimeType.d.ts +1 -0
  201. package/dist/parquetjs/parquet-thrift/TimeType.d.ts.map +1 -0
  202. package/dist/parquetjs/parquet-thrift/TimeType.js +106 -0
  203. package/dist/parquetjs/parquet-thrift/TimeUnit.d.ts +1 -0
  204. package/dist/parquetjs/parquet-thrift/TimeUnit.d.ts.map +1 -0
  205. package/dist/parquetjs/parquet-thrift/TimeUnit.js +127 -0
  206. package/dist/parquetjs/parquet-thrift/TimestampType.d.ts +1 -0
  207. package/dist/parquetjs/parquet-thrift/TimestampType.d.ts.map +1 -0
  208. package/dist/parquetjs/parquet-thrift/TimestampType.js +106 -0
  209. package/dist/parquetjs/parquet-thrift/Type.d.ts +1 -0
  210. package/dist/parquetjs/parquet-thrift/Type.d.ts.map +1 -0
  211. package/dist/parquetjs/parquet-thrift/Type.js +20 -0
  212. package/dist/parquetjs/parquet-thrift/TypeDefinedOrder.d.ts +1 -0
  213. package/dist/parquetjs/parquet-thrift/TypeDefinedOrder.d.ts.map +1 -0
  214. package/dist/parquetjs/parquet-thrift/TypeDefinedOrder.js +58 -0
  215. package/dist/parquetjs/parquet-thrift/UUIDType.d.ts +1 -0
  216. package/dist/parquetjs/parquet-thrift/UUIDType.d.ts.map +1 -0
  217. package/dist/parquetjs/parquet-thrift/UUIDType.js +58 -0
  218. package/dist/parquetjs/parquet-thrift/index.d.ts +1 -0
  219. package/dist/parquetjs/parquet-thrift/index.d.ts.map +1 -0
  220. package/dist/parquetjs/parquet-thrift/index.js +61 -0
  221. package/dist/parquetjs/parser/decoders.d.ts +1 -0
  222. package/dist/parquetjs/parser/decoders.d.ts.map +1 -0
  223. package/dist/parquetjs/parser/decoders.js +318 -0
  224. package/dist/parquetjs/parser/parquet-cursor.d.ts +1 -0
  225. package/dist/parquetjs/parser/parquet-cursor.d.ts.map +1 -0
  226. package/dist/parquetjs/parser/parquet-cursor.js +74 -0
  227. package/dist/parquetjs/parser/parquet-envelope-reader.d.ts +1 -1
  228. package/dist/parquetjs/parser/parquet-envelope-reader.d.ts.map +1 -0
  229. package/dist/parquetjs/parser/parquet-envelope-reader.js +136 -0
  230. package/dist/parquetjs/parser/parquet-reader.d.ts +1 -5
  231. package/dist/parquetjs/parser/parquet-reader.d.ts.map +1 -0
  232. package/dist/parquetjs/parser/parquet-reader.js +134 -0
  233. package/dist/parquetjs/schema/declare.d.ts +1 -0
  234. package/dist/parquetjs/schema/declare.d.ts.map +1 -0
  235. package/dist/parquetjs/schema/declare.js +10 -0
  236. package/dist/parquetjs/schema/schema.d.ts +1 -0
  237. package/dist/parquetjs/schema/schema.d.ts.map +1 -0
  238. package/dist/parquetjs/schema/schema.js +162 -0
  239. package/dist/parquetjs/schema/shred.d.ts +1 -0
  240. package/dist/parquetjs/schema/shred.d.ts.map +1 -0
  241. package/dist/parquetjs/schema/shred.js +225 -0
  242. package/dist/parquetjs/schema/types.d.ts +1 -0
  243. package/dist/parquetjs/schema/types.d.ts.map +1 -0
  244. package/dist/parquetjs/schema/types.js +418 -0
  245. package/dist/parquetjs/utils/buffer-utils.d.ts +1 -0
  246. package/dist/parquetjs/utils/buffer-utils.d.ts.map +1 -0
  247. package/dist/parquetjs/utils/buffer-utils.js +22 -0
  248. package/dist/parquetjs/utils/file-utils.d.ts +1 -4
  249. package/dist/parquetjs/utils/file-utils.d.ts.map +1 -0
  250. package/dist/parquetjs/utils/file-utils.js +46 -0
  251. package/dist/parquetjs/utils/read-utils.d.ts +1 -0
  252. package/dist/parquetjs/utils/read-utils.d.ts.map +1 -0
  253. package/dist/parquetjs/utils/read-utils.js +109 -0
  254. package/dist/workers/parquet-worker.d.ts +1 -0
  255. package/dist/workers/parquet-worker.d.ts.map +1 -0
  256. package/dist/workers/parquet-worker.js +5 -0
  257. package/package.json +7 -8
  258. package/src/index.ts +3 -3
  259. package/src/parquetjs/codecs/rle.ts +1 -1
  260. package/src/parquetjs/compression.ts +10 -10
  261. package/src/parquetjs/parser/decoders.ts +1 -1
  262. package/src/parquetjs/parser/parquet-envelope-reader.ts +0 -11
  263. package/src/parquetjs/parser/parquet-reader.ts +0 -16
  264. package/src/parquetjs/utils/file-utils.ts +0 -49
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ Object.defineProperty(exports, "__esModule", { value: true });
22
+ exports.TypeDefinedOrder = void 0;
23
+ /* tslint:disable */
24
+ /* eslint-disable */
25
+ /*
26
+ * Autogenerated by @creditkarma/thrift-typescript v3.7.2
27
+ * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING
28
+ */
29
+ const thrift = __importStar(require("thrift"));
30
+ class TypeDefinedOrder {
31
+ constructor() { }
32
+ write(output) {
33
+ output.writeStructBegin('TypeDefinedOrder');
34
+ output.writeFieldStop();
35
+ output.writeStructEnd();
36
+ return;
37
+ }
38
+ static read(input) {
39
+ input.readStructBegin();
40
+ while (true) {
41
+ const ret = input.readFieldBegin();
42
+ const fieldType = ret.ftype;
43
+ const fieldId = ret.fid;
44
+ if (fieldType === thrift.Thrift.Type.STOP) {
45
+ break;
46
+ }
47
+ switch (fieldId) {
48
+ default: {
49
+ input.skip(fieldType);
50
+ }
51
+ }
52
+ input.readFieldEnd();
53
+ }
54
+ input.readStructEnd();
55
+ return new TypeDefinedOrder();
56
+ }
57
+ }
58
+ exports.TypeDefinedOrder = TypeDefinedOrder;
@@ -6,3 +6,4 @@ export declare class UUIDType {
6
6
  write(output: thrift.TProtocol): void;
7
7
  static read(input: thrift.TProtocol): UUIDType;
8
8
  }
9
+ //# sourceMappingURL=UUIDType.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UUIDType.d.ts","sourceRoot":"","sources":["../../../src/parquetjs/parquet-thrift/UUIDType.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,MAAM,MAAM,QAAQ,CAAC;AACjC,MAAM,WAAW,aAAa;CAAG;AACjC,qBAAa,QAAQ;;IAEZ,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,GAAG,IAAI;WAM9B,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,SAAS,GAAG,QAAQ;CAmBtD"}
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
10
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
11
+ }) : function(o, v) {
12
+ o["default"] = v;
13
+ });
14
+ var __importStar = (this && this.__importStar) || function (mod) {
15
+ if (mod && mod.__esModule) return mod;
16
+ var result = {};
17
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
18
+ __setModuleDefault(result, mod);
19
+ return result;
20
+ };
21
+ Object.defineProperty(exports, "__esModule", { value: true });
22
+ exports.UUIDType = void 0;
23
+ /* tslint:disable */
24
+ /* eslint-disable */
25
+ /*
26
+ * Autogenerated by @creditkarma/thrift-typescript v3.7.2
27
+ * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING
28
+ */
29
+ const thrift = __importStar(require("thrift"));
30
+ class UUIDType {
31
+ constructor() { }
32
+ write(output) {
33
+ output.writeStructBegin('UUIDType');
34
+ output.writeFieldStop();
35
+ output.writeStructEnd();
36
+ return;
37
+ }
38
+ static read(input) {
39
+ input.readStructBegin();
40
+ while (true) {
41
+ const ret = input.readFieldBegin();
42
+ const fieldType = ret.ftype;
43
+ const fieldId = ret.fid;
44
+ if (fieldType === thrift.Thrift.Type.STOP) {
45
+ break;
46
+ }
47
+ switch (fieldId) {
48
+ default: {
49
+ input.skip(fieldType);
50
+ }
51
+ }
52
+ input.readFieldEnd();
53
+ }
54
+ input.readStructEnd();
55
+ return new UUIDType();
56
+ }
57
+ }
58
+ exports.UUIDType = UUIDType;
@@ -41,3 +41,4 @@ export * from './FileMetaData';
41
41
  export * from './TimeUnit';
42
42
  export * from './LogicalType';
43
43
  export * from './ColumnOrder';
44
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/parquetjs/parquet-thrift/index.ts"],"names":[],"mappings":"AAMA,cAAc,QAAQ,CAAC;AACvB,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,iBAAiB,CAAC;AAChC,cAAc,YAAY,CAAC;AAC3B,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC;AACvC,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC;AAC7B,cAAc,YAAY,CAAC;AAC3B,cAAc,iBAAiB,CAAC;AAChC,cAAc,qBAAqB,CAAC;AACpC,cAAc,kBAAkB,CAAC;AACjC,cAAc,eAAe,CAAC;AAC9B,cAAc,YAAY,CAAC;AAC3B,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,eAAe,CAAC;AAC9B,cAAc,eAAe,CAAC;AAC9B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,eAAe,CAAC;AAC9B,cAAc,eAAe,CAAC"}
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
5
+ }) : (function(o, m, k, k2) {
6
+ if (k2 === undefined) k2 = k;
7
+ o[k2] = m[k];
8
+ }));
9
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
10
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
11
+ };
12
+ Object.defineProperty(exports, "__esModule", { value: true });
13
+ /* tslint:disable */
14
+ /* eslint-disable */
15
+ /*
16
+ * Autogenerated by @creditkarma/thrift-typescript v3.7.2
17
+ * DO NOT EDIT UNLESS YOU ARE SURE THAT YOU KNOW WHAT YOU ARE DOING
18
+ */
19
+ __exportStar(require("./Type"), exports);
20
+ __exportStar(require("./ConvertedType"), exports);
21
+ __exportStar(require("./FieldRepetitionType"), exports);
22
+ __exportStar(require("./Encoding"), exports);
23
+ __exportStar(require("./CompressionCodec"), exports);
24
+ __exportStar(require("./PageType"), exports);
25
+ __exportStar(require("./BoundaryOrder"), exports);
26
+ __exportStar(require("./Statistics"), exports);
27
+ __exportStar(require("./StringType"), exports);
28
+ __exportStar(require("./UUIDType"), exports);
29
+ __exportStar(require("./MapType"), exports);
30
+ __exportStar(require("./ListType"), exports);
31
+ __exportStar(require("./EnumType"), exports);
32
+ __exportStar(require("./DateType"), exports);
33
+ __exportStar(require("./NullType"), exports);
34
+ __exportStar(require("./DecimalType"), exports);
35
+ __exportStar(require("./MilliSeconds"), exports);
36
+ __exportStar(require("./MicroSeconds"), exports);
37
+ __exportStar(require("./TimestampType"), exports);
38
+ __exportStar(require("./TimeType"), exports);
39
+ __exportStar(require("./IntType"), exports);
40
+ __exportStar(require("./JsonType"), exports);
41
+ __exportStar(require("./BsonType"), exports);
42
+ __exportStar(require("./SchemaElement"), exports);
43
+ __exportStar(require("./DataPageHeader"), exports);
44
+ __exportStar(require("./IndexPageHeader"), exports);
45
+ __exportStar(require("./DictionaryPageHeader"), exports);
46
+ __exportStar(require("./DataPageHeaderV2"), exports);
47
+ __exportStar(require("./PageHeader"), exports);
48
+ __exportStar(require("./KeyValue"), exports);
49
+ __exportStar(require("./SortingColumn"), exports);
50
+ __exportStar(require("./PageEncodingStats"), exports);
51
+ __exportStar(require("./ColumnMetaData"), exports);
52
+ __exportStar(require("./ColumnChunk"), exports);
53
+ __exportStar(require("./RowGroup"), exports);
54
+ __exportStar(require("./TypeDefinedOrder"), exports);
55
+ __exportStar(require("./PageLocation"), exports);
56
+ __exportStar(require("./OffsetIndex"), exports);
57
+ __exportStar(require("./ColumnIndex"), exports);
58
+ __exportStar(require("./FileMetaData"), exports);
59
+ __exportStar(require("./TimeUnit"), exports);
60
+ __exportStar(require("./LogicalType"), exports);
61
+ __exportStar(require("./ColumnOrder"), exports);
@@ -31,3 +31,4 @@ export declare function decodeSchema(schemaElements: SchemaElement[], offset: nu
31
31
  next: number;
32
32
  schema: SchemaDefinition;
33
33
  };
34
+ //# sourceMappingURL=decoders.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decoders.d.ts","sourceRoot":"","sources":["../../../src/parquetjs/parser/decoders.ts"],"names":[],"mappings":";AACA,OAAO,EAEL,WAAW,EACX,cAAc,EACd,eAAe,EAGf,gBAAgB,EACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAC,YAAY,EAAsC,MAAM,WAAW,CAAC;AAC5E,OAAO,EAML,aAAa,EAEd,MAAM,mBAAmB,CAAC;AAK3B;;;;;;GAMG;AACH,wBAAsB,eAAe,CACnC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,cAAc,GACtB,OAAO,CAAC,WAAW,CAAC,CAmDtB;AAED;;;;GAIG;AACH,wBAAsB,UAAU,CAC9B,MAAM,EAAE,YAAY,EACpB,OAAO,EAAE,cAAc,GACtB,OAAO,CAAC,eAAe,CAAC,CAyB1B;AAED;;;;;;;;;GASG;AACH,wBAAgB,YAAY,CAC1B,cAAc,EAAE,aAAa,EAAE,EAC/B,MAAM,EAAE,MAAM,EACd,GAAG,EAAE,MAAM,GACV;IACD,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,gBAAgB,CAAC;CAC1B,CA4DA"}
@@ -0,0 +1,318 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.decodeSchema = exports.decodePage = exports.decodeDataPages = void 0;
4
+ const codecs_1 = require("../codecs");
5
+ const parquet_thrift_1 = require("../parquet-thrift");
6
+ const compression_1 = require("../compression");
7
+ const constants_1 = require("../../constants");
8
+ const read_utils_1 = require("../utils/read-utils");
9
+ /**
10
+ * Decode data pages
11
+ * @param buffer - input data
12
+ * @param column - parquet column
13
+ * @param compression - compression type
14
+ * @returns parquet data page data
15
+ */
16
+ async function decodeDataPages(buffer, options) {
17
+ const cursor = {
18
+ buffer,
19
+ offset: 0,
20
+ size: buffer.length
21
+ };
22
+ const data = {
23
+ rlevels: [],
24
+ dlevels: [],
25
+ values: [],
26
+ pageHeaders: [],
27
+ count: 0
28
+ };
29
+ let dictionary = options.dictionary || [];
30
+ while (
31
+ // @ts-ignore size can be undefined
32
+ cursor.offset < cursor.size &&
33
+ (!options.numValues || data.dlevels.length < Number(options.numValues))) {
34
+ // Looks like we have to decode these in sequence due to cursor updates?
35
+ const page = await decodePage(cursor, options);
36
+ if (page.dictionary) {
37
+ dictionary = page.dictionary;
38
+ // eslint-disable-next-line no-continue
39
+ continue;
40
+ }
41
+ if (dictionary.length) {
42
+ // eslint-disable-next-line no-loop-func
43
+ page.values = page.values.map((value) => dictionary[value]);
44
+ }
45
+ for (let index = 0; index < page.rlevels.length; index++) {
46
+ data.rlevels.push(page.rlevels[index]);
47
+ data.dlevels.push(page.dlevels[index]);
48
+ const value = page.values[index];
49
+ if (value !== undefined) {
50
+ data.values.push(value);
51
+ }
52
+ }
53
+ data.count += page.count;
54
+ data.pageHeaders.push(page.pageHeader);
55
+ }
56
+ return data;
57
+ }
58
+ exports.decodeDataPages = decodeDataPages;
59
+ /**
60
+ * Decode parquet page based on page type
61
+ * @param cursor
62
+ * @param options
63
+ */
64
+ async function decodePage(cursor, options) {
65
+ let page;
66
+ const { pageHeader, length } = (0, read_utils_1.decodePageHeader)(cursor.buffer, cursor.offset);
67
+ cursor.offset += length;
68
+ const pageType = (0, read_utils_1.getThriftEnum)(parquet_thrift_1.PageType, pageHeader.type);
69
+ switch (pageType) {
70
+ case 'DATA_PAGE':
71
+ page = await decodeDataPage(cursor, pageHeader, options);
72
+ break;
73
+ case 'DATA_PAGE_V2':
74
+ page = await decodeDataPageV2(cursor, pageHeader, options);
75
+ break;
76
+ case 'DICTIONARY_PAGE':
77
+ page = {
78
+ dictionary: await decodeDictionaryPage(cursor, pageHeader, options),
79
+ pageHeader
80
+ };
81
+ break;
82
+ default:
83
+ throw new Error(`invalid page type: ${pageType}`);
84
+ }
85
+ return page;
86
+ }
87
+ exports.decodePage = decodePage;
88
+ /**
89
+ * Decode parquet schema
90
+ * @param schemaElements input schema elements data
91
+ * @param offset offset to read from
92
+ * @param len length of data
93
+ * @returns result.offset
94
+ * result.next - offset at the end of function
95
+ * result.schema - schema read from the input data
96
+ * @todo output offset is the same as input - possibly excess output field
97
+ */
98
+ function decodeSchema(schemaElements, offset, len) {
99
+ const schema = {};
100
+ let next = offset;
101
+ for (let i = 0; i < len; i++) {
102
+ const schemaElement = schemaElements[next];
103
+ const repetitionType = next > 0 ? (0, read_utils_1.getThriftEnum)(parquet_thrift_1.FieldRepetitionType, schemaElement.repetition_type) : 'ROOT';
104
+ let optional = false;
105
+ let repeated = false;
106
+ switch (repetitionType) {
107
+ case 'REQUIRED':
108
+ break;
109
+ case 'OPTIONAL':
110
+ optional = true;
111
+ break;
112
+ case 'REPEATED':
113
+ repeated = true;
114
+ break;
115
+ default:
116
+ throw new Error('parquet: unknown repetition type');
117
+ }
118
+ if (schemaElement.num_children > 0) {
119
+ const res = decodeSchema(schemaElements, next + 1, schemaElement.num_children);
120
+ next = res.next;
121
+ schema[schemaElement.name] = {
122
+ // type: undefined,
123
+ optional,
124
+ repeated,
125
+ fields: res.schema
126
+ };
127
+ }
128
+ else {
129
+ const type = (0, read_utils_1.getThriftEnum)(parquet_thrift_1.Type, schemaElement.type);
130
+ let logicalType = type;
131
+ if (schemaElement.converted_type) {
132
+ logicalType = (0, read_utils_1.getThriftEnum)(parquet_thrift_1.ConvertedType, schemaElement.converted_type);
133
+ }
134
+ switch (logicalType) {
135
+ case 'DECIMAL':
136
+ logicalType = `${logicalType}_${type}`;
137
+ break;
138
+ default:
139
+ }
140
+ schema[schemaElement.name] = {
141
+ type: logicalType,
142
+ typeLength: schemaElement.type_length,
143
+ presision: schemaElement.precision,
144
+ scale: schemaElement.scale,
145
+ optional,
146
+ repeated
147
+ };
148
+ next++;
149
+ }
150
+ }
151
+ return { schema, offset, next };
152
+ }
153
+ exports.decodeSchema = decodeSchema;
154
+ /**
155
+ * Decode a consecutive array of data using one of the parquet encodings
156
+ */
157
+ function decodeValues(type, encoding, cursor, count, opts) {
158
+ if (!(encoding in codecs_1.PARQUET_CODECS)) {
159
+ throw new Error(`invalid encoding: ${encoding}`);
160
+ }
161
+ return codecs_1.PARQUET_CODECS[encoding].decodeValues(type, cursor, count, opts);
162
+ }
163
+ /**
164
+ * Do decoding of parquet dataPage from column chunk
165
+ * @param cursor
166
+ * @param header
167
+ * @param options
168
+ */
169
+ async function decodeDataPage(cursor, header, options) {
170
+ const cursorEnd = cursor.offset + header.compressed_page_size;
171
+ const valueCount = header.data_page_header?.num_values;
172
+ /* uncompress page */
173
+ let dataCursor = cursor;
174
+ if (options.compression !== 'UNCOMPRESSED') {
175
+ const valuesBuf = await (0, compression_1.decompress)(options.compression, cursor.buffer.slice(cursor.offset, cursorEnd), header.uncompressed_page_size);
176
+ dataCursor = {
177
+ buffer: valuesBuf,
178
+ offset: 0,
179
+ size: valuesBuf.length
180
+ };
181
+ cursor.offset = cursorEnd;
182
+ }
183
+ /* read repetition levels */
184
+ const rLevelEncoding = (0, read_utils_1.getThriftEnum)(parquet_thrift_1.Encoding, header.data_page_header?.repetition_level_encoding);
185
+ // tslint:disable-next-line:prefer-array-literal
186
+ let rLevels = new Array(valueCount);
187
+ if (options.column.rLevelMax > 0) {
188
+ rLevels = decodeValues(constants_1.PARQUET_RDLVL_TYPE, rLevelEncoding, dataCursor, valueCount, {
189
+ bitWidth: (0, read_utils_1.getBitWidth)(options.column.rLevelMax),
190
+ disableEnvelope: false
191
+ // column: opts.column
192
+ });
193
+ }
194
+ else {
195
+ rLevels.fill(0);
196
+ }
197
+ /* read definition levels */
198
+ const dLevelEncoding = (0, read_utils_1.getThriftEnum)(parquet_thrift_1.Encoding, header.data_page_header?.definition_level_encoding);
199
+ // tslint:disable-next-line:prefer-array-literal
200
+ let dLevels = new Array(valueCount);
201
+ if (options.column.dLevelMax > 0) {
202
+ dLevels = decodeValues(constants_1.PARQUET_RDLVL_TYPE, dLevelEncoding, dataCursor, valueCount, {
203
+ bitWidth: (0, read_utils_1.getBitWidth)(options.column.dLevelMax),
204
+ disableEnvelope: false
205
+ // column: opts.column
206
+ });
207
+ }
208
+ else {
209
+ dLevels.fill(0);
210
+ }
211
+ let valueCountNonNull = 0;
212
+ for (const dlvl of dLevels) {
213
+ if (dlvl === options.column.dLevelMax) {
214
+ valueCountNonNull++;
215
+ }
216
+ }
217
+ /* read values */
218
+ const valueEncoding = (0, read_utils_1.getThriftEnum)(parquet_thrift_1.Encoding, header.data_page_header?.encoding);
219
+ const decodeOptions = {
220
+ typeLength: options.column.typeLength,
221
+ bitWidth: options.column.typeLength
222
+ };
223
+ const values = decodeValues(options.column.primitiveType, valueEncoding, dataCursor, valueCountNonNull, decodeOptions);
224
+ return {
225
+ dlevels: dLevels,
226
+ rlevels: rLevels,
227
+ values,
228
+ count: valueCount,
229
+ pageHeader: header
230
+ };
231
+ }
232
+ /**
233
+ * Do decoding of parquet dataPage in version 2 from column chunk
234
+ * @param cursor
235
+ * @param header
236
+ * @param opts
237
+ * @returns
238
+ */
239
+ async function decodeDataPageV2(cursor, header, opts) {
240
+ const cursorEnd = cursor.offset + header.compressed_page_size;
241
+ const valueCount = header.data_page_header_v2?.num_values;
242
+ // @ts-ignore
243
+ const valueCountNonNull = valueCount - header.data_page_header_v2?.num_nulls;
244
+ const valueEncoding = (0, read_utils_1.getThriftEnum)(parquet_thrift_1.Encoding, header.data_page_header_v2?.encoding);
245
+ /* read repetition levels */
246
+ // tslint:disable-next-line:prefer-array-literal
247
+ let rLevels = new Array(valueCount);
248
+ if (opts.column.rLevelMax > 0) {
249
+ rLevels = decodeValues(constants_1.PARQUET_RDLVL_TYPE, constants_1.PARQUET_RDLVL_ENCODING, cursor, valueCount, {
250
+ bitWidth: (0, read_utils_1.getBitWidth)(opts.column.rLevelMax),
251
+ disableEnvelope: true
252
+ });
253
+ }
254
+ else {
255
+ rLevels.fill(0);
256
+ }
257
+ /* read definition levels */
258
+ // tslint:disable-next-line:prefer-array-literal
259
+ let dLevels = new Array(valueCount);
260
+ if (opts.column.dLevelMax > 0) {
261
+ dLevels = decodeValues(constants_1.PARQUET_RDLVL_TYPE, constants_1.PARQUET_RDLVL_ENCODING, cursor, valueCount, {
262
+ bitWidth: (0, read_utils_1.getBitWidth)(opts.column.dLevelMax),
263
+ disableEnvelope: true
264
+ });
265
+ }
266
+ else {
267
+ dLevels.fill(0);
268
+ }
269
+ /* read values */
270
+ let valuesBufCursor = cursor;
271
+ if (header.data_page_header_v2?.is_compressed) {
272
+ const valuesBuf = await (0, compression_1.decompress)(opts.compression, cursor.buffer.slice(cursor.offset, cursorEnd), header.uncompressed_page_size);
273
+ valuesBufCursor = {
274
+ buffer: valuesBuf,
275
+ offset: 0,
276
+ size: valuesBuf.length
277
+ };
278
+ cursor.offset = cursorEnd;
279
+ }
280
+ const decodeOptions = {
281
+ typeLength: opts.column.typeLength,
282
+ bitWidth: opts.column.typeLength
283
+ };
284
+ const values = decodeValues(opts.column.primitiveType, valueEncoding, valuesBufCursor, valueCountNonNull, decodeOptions);
285
+ return {
286
+ dlevels: dLevels,
287
+ rlevels: rLevels,
288
+ values,
289
+ count: valueCount,
290
+ pageHeader: header
291
+ };
292
+ }
293
+ /**
294
+ * Do decoding of dictionary page which helps to iterate over all indexes and get dataPage values.
295
+ * @param cursor
296
+ * @param pageHeader
297
+ * @param options
298
+ */
299
+ async function decodeDictionaryPage(cursor, pageHeader, options) {
300
+ const cursorEnd = cursor.offset + pageHeader.compressed_page_size;
301
+ let dictCursor = {
302
+ offset: 0,
303
+ buffer: cursor.buffer.slice(cursor.offset, cursorEnd),
304
+ size: cursorEnd - cursor.offset
305
+ };
306
+ cursor.offset = cursorEnd;
307
+ if (options.compression !== 'UNCOMPRESSED') {
308
+ const valuesBuf = await (0, compression_1.decompress)(options.compression, dictCursor.buffer.slice(dictCursor.offset, cursorEnd), pageHeader.uncompressed_page_size);
309
+ dictCursor = {
310
+ buffer: valuesBuf,
311
+ offset: 0,
312
+ size: valuesBuf.length
313
+ };
314
+ cursor.offset = cursorEnd;
315
+ }
316
+ const numValues = pageHeader?.dictionary_page_header?.num_values || 0;
317
+ return decodeValues(options.column.primitiveType, options.column.encoding, dictCursor, numValues, options).map((d) => d.toString());
318
+ }
@@ -33,3 +33,4 @@ export declare class ParquetCursor<T> implements AsyncIterable<T> {
33
33
  */
34
34
  [Symbol.asyncIterator](): AsyncIterator<T>;
35
35
  }
36
+ //# sourceMappingURL=parquet-cursor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parquet-cursor.d.ts","sourceRoot":"","sources":["../../../src/parquetjs/parser/parquet-cursor.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,YAAY,EAAC,MAAM,mBAAmB,CAAC;AAC/C,OAAO,EAAC,qBAAqB,EAAC,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAC,aAAa,EAAC,MAAM,mBAAmB,CAAC;AAGhD;;GAEG;AACH,qBAAa,aAAa,CAAC,CAAC,CAAE,YAAW,aAAa,CAAC,CAAC,CAAC;IAChD,QAAQ,EAAE,YAAY,CAAC;IACvB,cAAc,EAAE,qBAAqB,CAAC;IACtC,MAAM,EAAE,aAAa,CAAC;IACtB,UAAU,EAAE,MAAM,EAAE,EAAE,CAAC;IACvB,QAAQ,EAAE,aAAa,EAAE,CAAM;IAC/B,aAAa,EAAE,MAAM,CAAC;IAE7B;;;;;OAKG;gBAED,QAAQ,EAAE,YAAY,EACtB,cAAc,EAAE,qBAAqB,EACrC,MAAM,EAAE,aAAa,EACrB,UAAU,EAAE,MAAM,EAAE,EAAE;IASxB;;;OAGG;IACG,IAAI,CAAC,CAAC,GAAG,GAAG,KAAK,OAAO,CAAC,CAAC,CAAC;IAiBjC;;OAEG;IACH,MAAM,IAAI,IAAI;IAKd;;OAEG;IAEH,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI,aAAa,CAAC,CAAC,CAAC;CAuB3C"}
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ParquetCursor = void 0;
4
+ const shred_1 = require("../schema/shred");
5
+ /**
6
+ * A parquet cursor is used to retrieve rows from a parquet file in order
7
+ */
8
+ class ParquetCursor {
9
+ /**
10
+ * Create a new parquet reader from the file metadata and an envelope reader.
11
+ * It is usually not recommended to call this constructor directly except for
12
+ * advanced and internal use cases. Consider using getCursor() on the
13
+ * ParquetReader instead
14
+ */
15
+ constructor(metadata, envelopeReader, schema, columnList) {
16
+ this.rowGroup = [];
17
+ this.metadata = metadata;
18
+ this.envelopeReader = envelopeReader;
19
+ this.schema = schema;
20
+ this.columnList = columnList;
21
+ this.rowGroupIndex = 0;
22
+ }
23
+ /**
24
+ * Retrieve the next row from the cursor. Returns a row or NULL if the end
25
+ * of the file was reached
26
+ */
27
+ async next() {
28
+ if (this.rowGroup.length === 0) {
29
+ if (this.rowGroupIndex >= this.metadata.row_groups.length) {
30
+ // @ts-ignore
31
+ return null;
32
+ }
33
+ const rowBuffer = await this.envelopeReader.readRowGroup(this.schema, this.metadata.row_groups[this.rowGroupIndex], this.columnList);
34
+ this.rowGroup = (0, shred_1.materializeRecords)(this.schema, rowBuffer);
35
+ this.rowGroupIndex++;
36
+ }
37
+ return this.rowGroup.shift();
38
+ }
39
+ /**
40
+ * Rewind the cursor the the beginning of the file
41
+ */
42
+ rewind() {
43
+ this.rowGroup = [];
44
+ this.rowGroupIndex = 0;
45
+ }
46
+ /**
47
+ * Implement AsyncIterable
48
+ */
49
+ // tslint:disable-next-line:function-name
50
+ [Symbol.asyncIterator]() {
51
+ let done = false;
52
+ return {
53
+ next: async () => {
54
+ if (done) {
55
+ return { done, value: null };
56
+ }
57
+ const value = await this.next();
58
+ if (value === null) {
59
+ return { done: true, value };
60
+ }
61
+ return { done: false, value };
62
+ },
63
+ return: async () => {
64
+ done = true;
65
+ return { done, value: null };
66
+ },
67
+ throw: async () => {
68
+ done = true;
69
+ return { done: true, value: null };
70
+ }
71
+ };
72
+ }
73
+ }
74
+ exports.ParquetCursor = ParquetCursor;
@@ -17,7 +17,6 @@ export declare class ParquetEnvelopeReader {
17
17
  close: () => Promise<void>;
18
18
  fileSize: number;
19
19
  defaultDictionarySize: number;
20
- static openFile(filePath: string): Promise<ParquetEnvelopeReader>;
21
20
  static openBuffer(buffer: Buffer): Promise<ParquetEnvelopeReader>;
22
21
  constructor(read: (position: number, length: number) => Promise<Buffer>, close: () => Promise<void>, fileSize: number, options?: any);
23
22
  readHeader(): Promise<void>;
@@ -38,3 +37,4 @@ export declare class ParquetEnvelopeReader {
38
37
  getDictionary(dictionaryPageOffset: number, options: ParquetOptions, pagesOffset: number): Promise<string[]>;
39
38
  readFooter(): Promise<FileMetaData>;
40
39
  }
40
+ //# sourceMappingURL=parquet-envelope-reader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parquet-envelope-reader.d.ts","sourceRoot":"","sources":["../../../src/parquetjs/parser/parquet-envelope-reader.ts"],"names":[],"mappings":";AACA,OAAO,EAAC,aAAa,EAAC,MAAM,kBAAkB,CAAC;AAE/C,OAAO,EAAC,WAAW,EAAoB,YAAY,EAAE,QAAQ,EAAO,MAAM,mBAAmB,CAAC;AAC9F,OAAO,EACL,aAAa,EAEb,WAAW,EAEX,cAAc,EACf,MAAM,mBAAmB,CAAC;AAM3B;;;;;GAKG;AACH,qBAAa,qBAAqB;IACzB,IAAI,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,CAAC;IACnE;;;OAGG;IACI,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,QAAQ,EAAE,MAAM,CAAC;IACjB,qBAAqB,EAAE,MAAM,CAAC;WAExB,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,CAAC;gBAQrE,IAAI,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,KAAK,OAAO,CAAC,MAAM,CAAC,EAC3D,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,EAC1B,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE,GAAG;IAQT,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAc3B,YAAY,CAChB,MAAM,EAAE,aAAa,EACrB,QAAQ,EAAE,QAAQ,EAClB,UAAU,EAAE,MAAM,EAAE,EAAE,GACrB,OAAO,CAAC,aAAa,CAAC;IAgBzB;;;;OAIG;IACG,eAAe,CAAC,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;IAoDzF;;;;;;OAMG;IACG,aAAa,CACjB,oBAAoB,EAAE,MAAM,EAC5B,OAAO,EAAE,cAAc,EACvB,WAAW,EAAE,MAAM,GAClB,OAAO,CAAC,MAAM,EAAE,CAAC;IAwBd,UAAU,IAAI,OAAO,CAAC,YAAY,CAAC;CAqB1C"}