@apache-arrow/esnext-cjs
Advanced tools
Comparing version 0.1.2 to 0.2.0
@@ -1,3 +0,13 @@ | ||
import { Table } from './table'; | ||
import { readBuffers } from './reader/arrow'; | ||
export { Table, readBuffers }; | ||
import { Table } from './vector/table'; | ||
import { Vector } from './vector/vector'; | ||
import { Utf8Vector } from './vector/utf8'; | ||
import { DictionaryVector } from './vector/dictionary'; | ||
import { StructVector, StructRow } from './vector/struct'; | ||
import { readVectors, readVectorsAsync } from './reader/arrow'; | ||
import { ListVector, BinaryVector, FixedSizeListVector } from './vector/list'; | ||
import { BoolVector, Int8Vector, Int16Vector, Int32Vector, Int64Vector, Uint8Vector, Uint16Vector, Uint32Vector, Uint64Vector, Float16Vector, Float32Vector, Float64Vector, Date32Vector, Date64Vector, Time32Vector, Time64Vector, DecimalVector, TimestampVector } from './vector/numeric'; | ||
export { Table, Vector, StructRow }; | ||
export { readVectors, readVectorsAsync }; | ||
export { NumericVectorConstructor } from './vector/numeric'; | ||
export { List, TypedArray, TypedArrayConstructor } from './vector/types'; | ||
export { BoolVector, ListVector, Utf8Vector, Int8Vector, Int16Vector, Int32Vector, Int64Vector, Uint8Vector, Uint16Vector, Uint32Vector, Uint64Vector, Date32Vector, Date64Vector, Time32Vector, Time64Vector, BinaryVector, StructVector, Float16Vector, Float32Vector, Float64Vector, DecimalVector, TimestampVector, DictionaryVector, FixedSizeListVector }; |
@@ -0,4 +1,5 @@ | ||
declare let RowVector: () => void; | ||
declare let Table: () => void; | ||
declare let Vector: () => void; | ||
declare let TypedVector: () => void; | ||
declare let ValidityVector: () => void; | ||
declare let BoolVector: () => void; | ||
declare let DictionaryVector: () => void; |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -26,18 +27,25 @@ // or more contributor license agreements. See the NOTICE file | ||
Symbol.asyncIterator; | ||
let RowVector = function () { }; | ||
/** @type {?} */ | ||
RowVector.prototype.toJSON; | ||
/** @type {?} */ | ||
RowVector.prototype.toArray; | ||
/** @type {?} */ | ||
RowVector.prototype.toObject; | ||
/** @type {?} */ | ||
RowVector.prototype.toString; | ||
let Table = function () { }; | ||
/** @type {?} */ | ||
Table.prototype.rows; | ||
Table.from; | ||
/** @type {?} */ | ||
Table.prototype.cols; | ||
Table.prototype.columns; | ||
/** @type {?} */ | ||
Table.prototype.getRow; | ||
Table.prototype.length; | ||
/** @type {?} */ | ||
Table.prototype.getCell; | ||
Table.prototype.col; | ||
/** @type {?} */ | ||
Table.prototype.getCellAt; | ||
Table.prototype.key; | ||
/** @type {?} */ | ||
Table.prototype.getColumn; | ||
Table.prototype.select; | ||
/** @type {?} */ | ||
Table.prototype.getColumnAt; | ||
/** @type {?} */ | ||
Table.prototype.toString; | ||
@@ -52,4 +60,2 @@ let Vector = function () { }; | ||
/** @type {?} */ | ||
Vector.prototype.props; | ||
/** @type {?} */ | ||
Vector.prototype.get; | ||
@@ -60,9 +66,19 @@ /** @type {?} */ | ||
Vector.prototype.slice; | ||
let TypedVector = function () { }; | ||
/** @type {?} */ | ||
TypedVector.prototype.arrayType; | ||
let ValidityVector = function () { }; | ||
Vector.prototype.metadata; | ||
/** @type {?} */ | ||
ValidityVector.pack; | ||
Vector.prototype.nullable; | ||
/** @type {?} */ | ||
Vector.prototype.nullCount; | ||
let BoolVector = function () { }; | ||
/** @type {?} */ | ||
BoolVector.pack; | ||
/** @type {?} */ | ||
BoolVector.prototype.set; | ||
let DictionaryVector = function () { }; | ||
/** @type {?} */ | ||
DictionaryVector.prototype.getKey; | ||
/** @type {?} */ | ||
DictionaryVector.prototype.getValue; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFycm93LmV4dGVybnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsNkRBQTZEO0FBQzdELCtEQUErRDtBQUMvRCx3REFBd0Q7QUFDeEQsNkRBQTZEO0FBQzdELG9EQUFvRDtBQUNwRCw2REFBNkQ7QUFDN0QsNkRBQTZEO0FBQzdELEVBQUU7QUFDRiwrQ0FBK0M7QUFDL0MsRUFBRTtBQUNGLDZEQUE2RDtBQUM3RCw4REFBOEQ7QUFDOUQseURBQXlEO0FBQ3pELDREQUE0RDtBQUM1RCwwREFBMEQ7QUFDMUQscUJBQXFCO0FBRXJCOzs7O0dBSUc7QUFDSCxxQkFBcUI7QUFDckIsTUFBTSxDQUFDLFFBQVEsQ0FBQztBQUNoQixxQkFBcUI7QUFDckIsTUFBTSxDQUFDLGFBQWEsQ0FBQztBQUNyQixJQUFJLEtBQUssR0FBRyxjQUFZLENBQUMsQ0FBQztBQUMxQixnQkFBZ0I7QUFDaEIsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7QUFDckIsZ0JBQWdCO0FBQ2hCLEtBQUssQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO0FBQ3JCLGdCQUFnQjtBQUNoQixLQUFLLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztBQUN2QixnQkFBZ0I7QUFDaEIsS0FBSyxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUM7QUFDeEIsZ0JBQWdCO0FBQ2hCLEtBQUssQ0FBQyxTQUFTLENBQUMsU0FBUyxDQUFDO0FBQzFCLGdCQUFnQjtBQUNoQixLQUFLLENBQUMsU0FBUyxDQUFDLFNBQVMsQ0FBQztBQUMxQixnQkFBZ0I7QUFDaEIsS0FBSyxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUM7QUFDNUIsZ0JBQWdCO0FBQ2hCLEtBQUssQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0FBRXpCLElBQUksTUFBTSxHQUFHLGNBQVksQ0FBQyxDQUFDO0FBQzNCLGdCQUFnQjtBQUNoQixNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztBQUN4QixnQkFBZ0I7QUFDaEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7QUFDdEIsZ0JBQWdCO0FBQ2hCLE1BQU0sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO0FBQ3RCLGdCQUFnQjtBQUNoQixNQUFNLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQztBQUN2QixnQkFBZ0I7QUFDaEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUM7QUFDckIsZ0JBQWdCO0FBQ2hCLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDO0FBQ3hCLGdCQUFnQjtBQUNoQixNQUFNLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQztBQUV2QixJQUFJLFdBQVcsR0FBRyxjQUFZLENBQUMsQ0FBQztBQUNoQyxnQkFBZ0I7QUFDaEIsV0FBVyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUM7QUFFaEMsSUFBSSxjQUFjLEdBQUcsY0FBWSxDQUFDLENBQUM7QUFDbkMsZ0JBQWdCO0FBQ1QsY0FBZSxDQUFDLElBQUksQ0FBQyIsImZpbGUiOiJBcnJvdy5leHRlcm5zLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTGljZW5zZWQgdG8gdGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChBU0YpIHVuZGVyIG9uZVxuLy8gb3IgbW9yZSBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlXG4vLyBkaXN0cmlidXRlZCB3aXRoIHRoaXMgd29yayBmb3IgYWRkaXRpb25hbCBpbmZvcm1hdGlvblxuLy8gcmVnYXJkaW5nIGNvcHlyaWdodCBvd25lcnNoaXAuICBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZVxuLy8gdG8geW91IHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZVxuLy8gXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4vLyB3aXRoIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4vL1xuLy8gICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbi8vXG4vLyBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsXG4vLyBzb2Z0d2FyZSBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhblxuLy8gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTllcbi8vIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZVxuLy8gc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZCBsaW1pdGF0aW9uc1xuLy8gdW5kZXIgdGhlIExpY2Vuc2UuXG5cbi8qKlxuICogQGZpbGVvdmVydmlldyBDbG9zdXJlIENvbXBpbGVyIGV4dGVybnMgZm9yIEFycm93XG4gKiBAZXh0ZXJuc1xuICogQHN1cHByZXNzIHtkdXBsaWNhdGUsY2hlY2tUeXBlc31cbiAqL1xuLyoqIEB0eXBlIHtzeW1ib2x9ICovXG5TeW1ib2wuaXRlcmF0b3I7XG4vKiogQHR5cGUge3N5bWJvbH0gKi9cblN5bWJvbC5hc3luY0l0ZXJhdG9yO1xubGV0IFRhYmxlID0gZnVuY3Rpb24oKSB7fTtcbi8qKiBAdHlwZSB7P30gKi9cblRhYmxlLnByb3RvdHlwZS5yb3dzO1xuLyoqIEB0eXBlIHs/fSAqL1xuVGFibGUucHJvdG90eXBlLmNvbHM7XG4vKiogQHR5cGUgez99ICovXG5UYWJsZS5wcm90b3R5cGUuZ2V0Um93O1xuLyoqIEB0eXBlIHs/fSAqL1xuVGFibGUucHJvdG90eXBlLmdldENlbGw7XG4vKiogQHR5cGUgez99ICovXG5UYWJsZS5wcm90b3R5cGUuZ2V0Q2VsbEF0O1xuLyoqIEB0eXBlIHs/fSAqL1xuVGFibGUucHJvdG90eXBlLmdldENvbHVtbjtcbi8qKiBAdHlwZSB7P30gKi9cblRhYmxlLnByb3RvdHlwZS5nZXRDb2x1bW5BdDtcbi8qKiBAdHlwZSB7P30gKi9cblRhYmxlLnByb3RvdHlwZS50b1N0cmluZztcblxubGV0IFZlY3RvciA9IGZ1bmN0aW9uKCkge307XG4vKiogQHR5cGUgez99ICovXG5WZWN0b3IucHJvdG90eXBlLmxlbmd0aDtcbi8qKiBAdHlwZSB7P30gKi9cblZlY3Rvci5wcm90b3R5cGUubmFtZTtcbi8qKiBAdHlwZSB7P30gKi9cblZlY3Rvci5wcm90b3R5cGUudHlwZTtcbi8qKiBAdHlwZSB7P30gKi9cblZlY3Rvci5wcm90b3R5cGUucHJvcHM7XG4vKiogQHR5cGUgez99ICovXG5WZWN0b3IucHJvdG90eXBlLmdldDtcbi8qKiBAdHlwZSB7P30gKi9cblZlY3Rvci5wcm90b3R5cGUuY29uY2F0O1xuLyoqIEB0eXBlIHs/fSAqL1xuVmVjdG9yLnByb3RvdHlwZS5zbGljZTtcblxubGV0IFR5cGVkVmVjdG9yID0gZnVuY3Rpb24oKSB7fTtcbi8qKiBAdHlwZSB7P30gKi9cblR5cGVkVmVjdG9yLnByb3RvdHlwZS5hcnJheVR5cGU7XG5cbmxldCBWYWxpZGl0eVZlY3RvciA9IGZ1bmN0aW9uKCkge307XG4vKiogQHR5cGUgez99ICovXG4oPGFueT4gVmFsaWRpdHlWZWN0b3IpLnBhY2s7XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFycm93LmV4dGVybnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDZEQUE2RDtBQUM3RCwrREFBK0Q7QUFDL0Qsd0RBQXdEO0FBQ3hELDZEQUE2RDtBQUM3RCxvREFBb0Q7QUFDcEQsNkRBQTZEO0FBQzdELDZEQUE2RDtBQUM3RCxFQUFFO0FBQ0YsK0NBQStDO0FBQy9DLEVBQUU7QUFDRiw2REFBNkQ7QUFDN0QsOERBQThEO0FBQzlELHlEQUF5RDtBQUN6RCw0REFBNEQ7QUFDNUQsMERBQTBEO0FBQzFELHFCQUFxQjtBQUVyQjs7OztHQUlHO0FBQ0gscUJBQXFCO0FBQ3JCLE1BQU0sQ0FBQyxRQUFRLENBQUM7QUFDaEIscUJBQXFCO0FBQ3JCLE1BQU0sQ0FBQyxhQUFhLENBQUM7QUFFckIsSUFBSSxTQUFTLEdBQUcsY0FBWSxDQUFDLENBQUM7QUFDOUIsZ0JBQWdCO0FBQ2hCLFNBQVMsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDO0FBQzNCLGdCQUFnQjtBQUNoQixTQUFTLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQztBQUM1QixnQkFBZ0I7QUFDaEIsU0FBUyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7QUFDN0IsZ0JBQWdCO0FBQ2hCLFNBQVMsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0FBRTdCLElBQUksS0FBSyxHQUFHLGNBQVksQ0FBQyxDQUFDO0FBQzFCLGdCQUFnQjtBQUNULEtBQU0sQ0FBQyxJQUFJLENBQUM7QUFDbkIsZ0JBQWdCO0FBQ2hCLEtBQUssQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDO0FBQ3hCLGdCQUFnQjtBQUNoQixLQUFLLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztBQUN2QixnQkFBZ0I7QUFDaEIsS0FBSyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUM7QUFDcEIsZ0JBQWdCO0FBQ2hCLEtBQUssQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDO0FBQ3BCLGdCQUFnQjtBQUNoQixLQUFLLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztBQUN2QixnQkFBZ0I7QUFDaEIsS0FBSyxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7QUFFekIsSUFBSSxNQUFNLEdBQUcsY0FBWSxDQUFDLENBQUM7QUFDM0IsZ0JBQWdCO0FBQ2hCLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDO0FBQ3hCLGdCQUFnQjtBQUNoQixNQUFNLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztBQUN0QixnQkFBZ0I7QUFDaEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7QUFDdEIsZ0JBQWdCO0FBQ2hCLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDO0FBQ3JCLGdCQUFnQjtBQUNoQixNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztBQUN4QixnQkFBZ0I7QUFDaEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUM7QUFDdkIsZ0JBQWdCO0FBQ2hCLE1BQU0sQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDO0FBQzFCLGdCQUFnQjtBQUNoQixNQUFNLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQztBQUMxQixnQkFBZ0I7QUFDaEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUM7QUFFM0IsSUFBSSxVQUFVLEdBQUcsY0FBWSxDQUFDLENBQUM7QUFDL0IsZ0JBQWdCO0FBQ1QsVUFBVyxDQUFDLElBQUksQ0FBQztBQUN4QixnQkFBZ0I7QUFDaEIsVUFBVSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUM7QUFFekIsSUFBSSxnQkFBZ0IsR0FBRyxjQUFZLENBQUMsQ0FBQztBQUNyQyxnQkFBZ0I7QUFDaEIsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQztBQUNsQyxnQkFBZ0I7QUFDaEIsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyIsImZpbGUiOiJBcnJvdy5leHRlcm5zLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTGljZW5zZWQgdG8gdGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChBU0YpIHVuZGVyIG9uZVxuLy8gb3IgbW9yZSBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlXG4vLyBkaXN0cmlidXRlZCB3aXRoIHRoaXMgd29yayBmb3IgYWRkaXRpb25hbCBpbmZvcm1hdGlvblxuLy8gcmVnYXJkaW5nIGNvcHlyaWdodCBvd25lcnNoaXAuICBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZVxuLy8gdG8geW91IHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZVxuLy8gXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4vLyB3aXRoIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4vL1xuLy8gICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbi8vXG4vLyBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsXG4vLyBzb2Z0d2FyZSBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhblxuLy8gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTllcbi8vIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZVxuLy8gc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZCBsaW1pdGF0aW9uc1xuLy8gdW5kZXIgdGhlIExpY2Vuc2UuXG5cbi8qKlxuICogQGZpbGVvdmVydmlldyBDbG9zdXJlIENvbXBpbGVyIGV4dGVybnMgZm9yIEFycm93XG4gKiBAZXh0ZXJuc1xuICogQHN1cHByZXNzIHtkdXBsaWNhdGUsY2hlY2tUeXBlc31cbiAqL1xuLyoqIEB0eXBlIHtzeW1ib2x9ICovXG5TeW1ib2wuaXRlcmF0b3I7XG4vKiogQHR5cGUge3N5bWJvbH0gKi9cblN5bWJvbC5hc3luY0l0ZXJhdG9yO1xuXG5sZXQgUm93VmVjdG9yID0gZnVuY3Rpb24oKSB7fTtcbi8qKiBAdHlwZSB7P30gKi9cblJvd1ZlY3Rvci5wcm90b3R5cGUudG9KU09OO1xuLyoqIEB0eXBlIHs/fSAqL1xuUm93VmVjdG9yLnByb3RvdHlwZS50b0FycmF5O1xuLyoqIEB0eXBlIHs/fSAqL1xuUm93VmVjdG9yLnByb3RvdHlwZS50b09iamVjdDtcbi8qKiBAdHlwZSB7P30gKi9cblJvd1ZlY3Rvci5wcm90b3R5cGUudG9TdHJpbmc7XG5cbmxldCBUYWJsZSA9IGZ1bmN0aW9uKCkge307XG4vKiogQHR5cGUgez99ICovXG4oPGFueT4gVGFibGUpLmZyb207XG4vKiogQHR5cGUgez99ICovXG5UYWJsZS5wcm90b3R5cGUuY29sdW1ucztcbi8qKiBAdHlwZSB7P30gKi9cblRhYmxlLnByb3RvdHlwZS5sZW5ndGg7XG4vKiogQHR5cGUgez99ICovXG5UYWJsZS5wcm90b3R5cGUuY29sO1xuLyoqIEB0eXBlIHs/fSAqL1xuVGFibGUucHJvdG90eXBlLmtleTtcbi8qKiBAdHlwZSB7P30gKi9cblRhYmxlLnByb3RvdHlwZS5zZWxlY3Q7XG4vKiogQHR5cGUgez99ICovXG5UYWJsZS5wcm90b3R5cGUudG9TdHJpbmc7XG5cbmxldCBWZWN0b3IgPSBmdW5jdGlvbigpIHt9O1xuLyoqIEB0eXBlIHs/fSAqL1xuVmVjdG9yLnByb3RvdHlwZS5sZW5ndGg7XG4vKiogQHR5cGUgez99ICovXG5WZWN0b3IucHJvdG90eXBlLm5hbWU7XG4vKiogQHR5cGUgez99ICovXG5WZWN0b3IucHJvdG90eXBlLnR5cGU7XG4vKiogQHR5cGUgez99ICovXG5WZWN0b3IucHJvdG90eXBlLmdldDtcbi8qKiBAdHlwZSB7P30gKi9cblZlY3Rvci5wcm90b3R5cGUuY29uY2F0O1xuLyoqIEB0eXBlIHs/fSAqL1xuVmVjdG9yLnByb3RvdHlwZS5zbGljZTtcbi8qKiBAdHlwZSB7P30gKi9cblZlY3Rvci5wcm90b3R5cGUubWV0YWRhdGE7XG4vKiogQHR5cGUgez99ICovXG5WZWN0b3IucHJvdG90eXBlLm51bGxhYmxlO1xuLyoqIEB0eXBlIHs/fSAqL1xuVmVjdG9yLnByb3RvdHlwZS5udWxsQ291bnQ7XG5cbmxldCBCb29sVmVjdG9yID0gZnVuY3Rpb24oKSB7fTtcbi8qKiBAdHlwZSB7P30gKi9cbig8YW55PiBCb29sVmVjdG9yKS5wYWNrO1xuLyoqIEB0eXBlIHs/fSAqL1xuQm9vbFZlY3Rvci5wcm90b3R5cGUuc2V0O1xuXG5sZXQgRGljdGlvbmFyeVZlY3RvciA9IGZ1bmN0aW9uKCkge307XG4vKiogQHR5cGUgez99ICovXG5EaWN0aW9uYXJ5VmVjdG9yLnByb3RvdHlwZS5nZXRLZXk7XG4vKiogQHR5cGUgez99ICovXG5EaWN0aW9uYXJ5VmVjdG9yLnByb3RvdHlwZS5nZXRWYWx1ZTtcbiJdfQ== |
71
Arrow.js
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -18,6 +19,39 @@ // or more contributor license agreements. See the NOTICE file | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const table_1 = require("./table"); | ||
const table_1 = require("./vector/table"); | ||
exports.Table = table_1.Table; | ||
const vector_1 = require("./vector/vector"); | ||
exports.Vector = vector_1.Vector; | ||
const utf8_1 = require("./vector/utf8"); | ||
exports.Utf8Vector = utf8_1.Utf8Vector; | ||
const dictionary_1 = require("./vector/dictionary"); | ||
exports.DictionaryVector = dictionary_1.DictionaryVector; | ||
const struct_1 = require("./vector/struct"); | ||
exports.StructVector = struct_1.StructVector; | ||
exports.StructRow = struct_1.StructRow; | ||
const arrow_1 = require("./reader/arrow"); | ||
exports.readBuffers = arrow_1.readBuffers; | ||
exports.readVectors = arrow_1.readVectors; | ||
exports.readVectorsAsync = arrow_1.readVectorsAsync; | ||
const list_1 = require("./vector/list"); | ||
exports.ListVector = list_1.ListVector; | ||
exports.BinaryVector = list_1.BinaryVector; | ||
exports.FixedSizeListVector = list_1.FixedSizeListVector; | ||
const numeric_1 = require("./vector/numeric"); | ||
exports.BoolVector = numeric_1.BoolVector; | ||
exports.Int8Vector = numeric_1.Int8Vector; | ||
exports.Int16Vector = numeric_1.Int16Vector; | ||
exports.Int32Vector = numeric_1.Int32Vector; | ||
exports.Int64Vector = numeric_1.Int64Vector; | ||
exports.Uint8Vector = numeric_1.Uint8Vector; | ||
exports.Uint16Vector = numeric_1.Uint16Vector; | ||
exports.Uint32Vector = numeric_1.Uint32Vector; | ||
exports.Uint64Vector = numeric_1.Uint64Vector; | ||
exports.Float16Vector = numeric_1.Float16Vector; | ||
exports.Float32Vector = numeric_1.Float32Vector; | ||
exports.Float64Vector = numeric_1.Float64Vector; | ||
exports.Date32Vector = numeric_1.Date32Vector; | ||
exports.Date64Vector = numeric_1.Date64Vector; | ||
exports.Time32Vector = numeric_1.Time32Vector; | ||
exports.Time64Vector = numeric_1.Time64Vector; | ||
exports.DecimalVector = numeric_1.DecimalVector; | ||
exports.TimestampVector = numeric_1.TimestampVector; | ||
/* These exports are needed for the closure umd targets */ | ||
@@ -28,9 +62,36 @@ try { | ||
// string indexers tell closure compiler not to rename these properties | ||
Arrow['readVectors'] = arrow_1.readVectors; | ||
Arrow['readVectorsAsync'] = arrow_1.readVectorsAsync; | ||
Arrow['Table'] = table_1.Table; | ||
Arrow['readBuffers'] = arrow_1.readBuffers; | ||
Arrow['Vector'] = vector_1.Vector; | ||
Arrow['StructRow'] = struct_1.StructRow; | ||
Arrow['BoolVector'] = numeric_1.BoolVector; | ||
Arrow['ListVector'] = list_1.ListVector; | ||
Arrow['Utf8Vector'] = utf8_1.Utf8Vector; | ||
Arrow['Int8Vector'] = numeric_1.Int8Vector; | ||
Arrow['Int16Vector'] = numeric_1.Int16Vector; | ||
Arrow['Int32Vector'] = numeric_1.Int32Vector; | ||
Arrow['Int64Vector'] = numeric_1.Int64Vector; | ||
Arrow['Uint8Vector'] = numeric_1.Uint8Vector; | ||
Arrow['Uint16Vector'] = numeric_1.Uint16Vector; | ||
Arrow['Uint32Vector'] = numeric_1.Uint32Vector; | ||
Arrow['Uint64Vector'] = numeric_1.Uint64Vector; | ||
Arrow['Date32Vector'] = numeric_1.Date32Vector; | ||
Arrow['Date64Vector'] = numeric_1.Date64Vector; | ||
Arrow['Time32Vector'] = numeric_1.Time32Vector; | ||
Arrow['Time64Vector'] = numeric_1.Time64Vector; | ||
Arrow['BinaryVector'] = list_1.BinaryVector; | ||
Arrow['StructVector'] = struct_1.StructVector; | ||
Arrow['Float16Vector'] = numeric_1.Float16Vector; | ||
Arrow['Float32Vector'] = numeric_1.Float32Vector; | ||
Arrow['Float64Vector'] = numeric_1.Float64Vector; | ||
Arrow['DecimalVector'] = numeric_1.DecimalVector; | ||
Arrow['TimestampVector'] = numeric_1.TimestampVector; | ||
Arrow['DictionaryVector'] = dictionary_1.DictionaryVector; | ||
Arrow['FixedSizeListVector'] = list_1.FixedSizeListVector; | ||
} | ||
} | ||
catch (e) { } | ||
/** end closure exports */ | ||
/* end closure exports */ | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFycm93LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDZEQUE2RDtBQUM3RCwrREFBK0Q7QUFDL0Qsd0RBQXdEO0FBQ3hELDZEQUE2RDtBQUM3RCxvREFBb0Q7QUFDcEQsNkRBQTZEO0FBQzdELDZEQUE2RDtBQUM3RCxFQUFFO0FBQ0YsK0NBQStDO0FBQy9DLEVBQUU7QUFDRiw2REFBNkQ7QUFDN0QsOERBQThEO0FBQzlELHlEQUF5RDtBQUN6RCw0REFBNEQ7QUFDNUQsMERBQTBEO0FBQzFELHFCQUFxQjs7QUFFckIsbUNBQWdDO0FBRXZCLGdCQUZBLGFBQUssQ0FFQTtBQURkLDBDQUE2QztBQUM3QixzQkFEUCxtQkFBVyxDQUNPO0FBRTNCLDBEQUEwRDtBQUMxRCxJQUFJLENBQUM7SUFDRCxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDOUIsRUFBRSxDQUFDLENBQUMsT0FBTyxLQUFLLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQztRQUM1Qix1RUFBdUU7UUFDdkUsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLGFBQUssQ0FBQztRQUN2QixLQUFLLENBQUMsYUFBYSxDQUFDLEdBQUcsbUJBQVcsQ0FBQztJQUN2QyxDQUFDO0FBQ0wsQ0FBQztBQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBMEIsQ0FBQztBQUN4QywwQkFBMEIiLCJmaWxlIjoiQXJyb3cuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBMaWNlbnNlZCB0byB0aGUgQXBhY2hlIFNvZnR3YXJlIEZvdW5kYXRpb24gKEFTRikgdW5kZXIgb25lXG4vLyBvciBtb3JlIGNvbnRyaWJ1dG9yIGxpY2Vuc2UgYWdyZWVtZW50cy4gIFNlZSB0aGUgTk9USUNFIGZpbGVcbi8vIGRpc3RyaWJ1dGVkIHdpdGggdGhpcyB3b3JrIGZvciBhZGRpdGlvbmFsIGluZm9ybWF0aW9uXG4vLyByZWdhcmRpbmcgY29weXJpZ2h0IG93bmVyc2hpcC4gIFRoZSBBU0YgbGljZW5zZXMgdGhpcyBmaWxlXG4vLyB0byB5b3UgdW5kZXIgdGhlIEFwYWNoZSBMaWNlbnNlLCBWZXJzaW9uIDIuMCAodGhlXG4vLyBcIkxpY2Vuc2VcIik7IHlvdSBtYXkgbm90IHVzZSB0aGlzIGZpbGUgZXhjZXB0IGluIGNvbXBsaWFuY2Vcbi8vIHdpdGggdGhlIExpY2Vuc2UuICBZb3UgbWF5IG9idGFpbiBhIGNvcHkgb2YgdGhlIExpY2Vuc2UgYXRcbi8vXG4vLyAgIGh0dHA6Ly93d3cuYXBhY2hlLm9yZy9saWNlbnNlcy9MSUNFTlNFLTIuMFxuLy9cbi8vIFVubGVzcyByZXF1aXJlZCBieSBhcHBsaWNhYmxlIGxhdyBvciBhZ3JlZWQgdG8gaW4gd3JpdGluZyxcbi8vIHNvZnR3YXJlIGRpc3RyaWJ1dGVkIHVuZGVyIHRoZSBMaWNlbnNlIGlzIGRpc3RyaWJ1dGVkIG9uIGFuXG4vLyBcIkFTIElTXCIgQkFTSVMsIFdJVEhPVVQgV0FSUkFOVElFUyBPUiBDT05ESVRJT05TIE9GIEFOWVxuLy8gS0lORCwgZWl0aGVyIGV4cHJlc3Mgb3IgaW1wbGllZC4gIFNlZSB0aGUgTGljZW5zZSBmb3IgdGhlXG4vLyBzcGVjaWZpYyBsYW5ndWFnZSBnb3Zlcm5pbmcgcGVybWlzc2lvbnMgYW5kIGxpbWl0YXRpb25zXG4vLyB1bmRlciB0aGUgTGljZW5zZS5cblxuaW1wb3J0IHsgVGFibGUgfSBmcm9tICcuL3RhYmxlJztcbmltcG9ydCB7IHJlYWRCdWZmZXJzIH0gZnJvbSAnLi9yZWFkZXIvYXJyb3cnO1xuZXhwb3J0IHsgVGFibGUsIHJlYWRCdWZmZXJzIH07XG5cbi8qIFRoZXNlIGV4cG9ydHMgYXJlIG5lZWRlZCBmb3IgdGhlIGNsb3N1cmUgdW1kIHRhcmdldHMgKi9cbnRyeSB7XG4gICAgY29uc3QgQXJyb3cgPSBldmFsKCdleHBvcnRzJyk7XG4gICAgaWYgKHR5cGVvZiBBcnJvdyA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgLy8gc3RyaW5nIGluZGV4ZXJzIHRlbGwgY2xvc3VyZSBjb21waWxlciBub3QgdG8gcmVuYW1lIHRoZXNlIHByb3BlcnRpZXNcbiAgICAgICAgQXJyb3dbJ1RhYmxlJ10gPSBUYWJsZTtcbiAgICAgICAgQXJyb3dbJ3JlYWRCdWZmZXJzJ10gPSByZWFkQnVmZmVycztcbiAgICB9XG59IGNhdGNoIChlKSB7IC8qIG5vdCB0aGUgVU1EIGJ1bmRsZSAqLyB9XG4vKiogZW5kIGNsb3N1cmUgZXhwb3J0cyAqL1xuIl19 | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["Arrow.ts"],"names":[],"mappings":"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","file":"Arrow.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { Table } from './vector/table';\nimport { Vector } from './vector/vector';\nimport { Utf8Vector } from './vector/utf8';\nimport { DictionaryVector } from './vector/dictionary';\nimport { StructVector, StructRow } from './vector/struct';\nimport { readVectors, readVectorsAsync } from './reader/arrow';\nimport { ListVector, BinaryVector, FixedSizeListVector } from './vector/list';\n\nimport {\n    BoolVector,\n    Int8Vector,\n    Int16Vector,\n    Int32Vector,\n    Int64Vector,\n    Uint8Vector,\n    Uint16Vector,\n    Uint32Vector,\n    Uint64Vector,\n    Float16Vector,\n    Float32Vector,\n    Float64Vector,\n    Date32Vector,\n    Date64Vector,\n    Time32Vector,\n    Time64Vector,\n    DecimalVector,\n    TimestampVector,\n} from './vector/numeric';\n\nexport { Table, Vector, StructRow };\nexport { readVectors, readVectorsAsync };\nexport { NumericVectorConstructor } from './vector/numeric';\nexport { List, TypedArray, TypedArrayConstructor } from './vector/types';\nexport {\n    BoolVector,\n    ListVector,\n    Utf8Vector,\n    Int8Vector,\n    Int16Vector,\n    Int32Vector,\n    Int64Vector,\n    Uint8Vector,\n    Uint16Vector,\n    Uint32Vector,\n    Uint64Vector,\n    Date32Vector,\n    Date64Vector,\n    Time32Vector,\n    Time64Vector,\n    BinaryVector,\n    StructVector,\n    Float16Vector,\n    Float32Vector,\n    Float64Vector,\n    DecimalVector,\n    TimestampVector,\n    DictionaryVector,\n    FixedSizeListVector,\n};\n\n/* These exports are needed for the closure umd targets */\ntry {\n    const Arrow = eval('exports');\n    if (typeof Arrow === 'object') {\n        // string indexers tell closure compiler not to rename these properties\n        Arrow['readVectors'] = readVectors;\n        Arrow['readVectorsAsync'] = readVectorsAsync;\n        Arrow['Table'] = Table;\n        Arrow['Vector'] = Vector;\n        Arrow['StructRow'] = StructRow;\n        Arrow['BoolVector'] = BoolVector;\n        Arrow['ListVector'] = ListVector;\n        Arrow['Utf8Vector'] = Utf8Vector;\n        Arrow['Int8Vector'] = Int8Vector;\n        Arrow['Int16Vector'] = Int16Vector;\n        Arrow['Int32Vector'] = Int32Vector;\n        Arrow['Int64Vector'] = Int64Vector;\n        Arrow['Uint8Vector'] = Uint8Vector;\n        Arrow['Uint16Vector'] = Uint16Vector;\n        Arrow['Uint32Vector'] = Uint32Vector;\n        Arrow['Uint64Vector'] = Uint64Vector;\n        Arrow['Date32Vector'] = Date32Vector;\n        Arrow['Date64Vector'] = Date64Vector;\n        Arrow['Time32Vector'] = Time32Vector;\n        Arrow['Time64Vector'] = Time64Vector;\n        Arrow['BinaryVector'] = BinaryVector;\n        Arrow['StructVector'] = StructVector;\n        Arrow['Float16Vector'] = Float16Vector;\n        Arrow['Float32Vector'] = Float32Vector;\n        Arrow['Float64Vector'] = Float64Vector;\n        Arrow['DecimalVector'] = DecimalVector;\n        Arrow['TimestampVector'] = TimestampVector;\n        Arrow['DictionaryVector'] = DictionaryVector;\n        Arrow['FixedSizeListVector'] = FixedSizeListVector;\n    }\n} catch (e) { /* not the UMD bundle */ }\n/* end closure exports */\n"]} |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// automatically generated by the FlatBuffers compiler, do not modify | ||
@@ -49,3 +50,3 @@ Object.defineProperty(exports, "__esModule", { value: true }); | ||
let offset = this.bb.__offset(this.bb_pos, 4); | ||
return offset ? (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1; | ||
return offset ? /** @type {org.apache.arrow.flatbuf.MetadataVersion} */ (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1; | ||
} | ||
@@ -235,2 +236,2 @@ /** | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["format/File.ts"],"names":[],"mappings":"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","file":"format/File.js","sourcesContent":["// automatically generated by the FlatBuffers compiler, do not modify\n\nimport { flatbuffers } from 'flatbuffers';\nimport * as NS16187549871986683199 from './Schema';\n/**\n * ----------------------------------------------------------------------\n * Arrow File metadata\n *\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class Footer {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {Footer}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): Footer {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {Footer=} obj\n     * @returns {Footer}\n     */\n    static getRootAsFooter(bb: flatbuffers.ByteBuffer, obj?: Footer): Footer {\n      return (obj || new Footer).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * @returns {org.apache.arrow.flatbuf.MetadataVersion}\n     */\n    version(): NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? /** @type {org.apache.arrow.flatbuf.MetadataVersion} */ (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1;\n    }\n\n    /**\n     * @param {org.apache.arrow.flatbuf.Schema=} obj\n     * @returns {org.apache.arrow.flatbuf.Schema|null}\n     */\n    schema(obj?: NS16187549871986683199.org.apache.arrow.flatbuf.Schema): NS16187549871986683199.org.apache.arrow.flatbuf.Schema | null {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? (obj || new NS16187549871986683199.org.apache.arrow.flatbuf.Schema).__init(this.bb.__indirect(this.bb_pos + offset), this.bb) : null;\n    }\n\n    /**\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.Block=} obj\n     * @returns {org.apache.arrow.flatbuf.Block}\n     */\n    dictionaries(index: number, obj?: org.apache.arrow.flatbuf.Block): org.apache.arrow.flatbuf.Block | null {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? (obj || new org.apache.arrow.flatbuf.Block).__init(this.bb.__vector(this.bb_pos + offset) + index * 24, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    dictionariesLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.Block=} obj\n     * @returns {org.apache.arrow.flatbuf.Block}\n     */\n    recordBatches(index: number, obj?: org.apache.arrow.flatbuf.Block): org.apache.arrow.flatbuf.Block | null {\n      let offset = this.bb.__offset(this.bb_pos, 10);\n      return offset ? (obj || new org.apache.arrow.flatbuf.Block).__init(this.bb.__vector(this.bb_pos + offset) + index * 24, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    recordBatchesLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 10);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startFooter(builder: flatbuffers.Builder) {\n      builder.startObject(4);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {org.apache.arrow.flatbuf.MetadataVersion} version\n     */\n    static addVersion(builder: flatbuffers.Builder, version: NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion) {\n      builder.addFieldInt16(0, version, NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} schemaOffset\n     */\n    static addSchema(builder: flatbuffers.Builder, schemaOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(1, schemaOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} dictionariesOffset\n     */\n    static addDictionaries(builder: flatbuffers.Builder, dictionariesOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(2, dictionariesOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startDictionariesVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(24, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} recordBatchesOffset\n     */\n    static addRecordBatches(builder: flatbuffers.Builder, recordBatchesOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(3, recordBatchesOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startRecordBatchesVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(24, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endFooter(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} offset\n     */\n    static finishFooterBuffer(builder: flatbuffers.Builder, offset: flatbuffers.Offset) {\n      builder.finish(offset);\n    }\n\n  }\n}\n/**\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class Block {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {Block}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): Block {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * Index to the start of the RecordBlock (note this is past the Message header)\n     *\n     * @returns {flatbuffers.Long}\n     */\n    offset(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos);\n    }\n\n    /**\n     * Length of the metadata\n     *\n     * @returns {number}\n     */\n    metaDataLength(): number {\n      return this.bb.readInt32(this.bb_pos + 8);\n    }\n\n    /**\n     * Length of the data (this is aligned so there can be a gap between this and\n     * the metatdata).\n     *\n     * @returns {flatbuffers.Long}\n     */\n    bodyLength(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos + 16);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} offset\n     * @param {number} metaDataLength\n     * @param {flatbuffers.Long} bodyLength\n     * @returns {flatbuffers.Offset}\n     */\n    static createBlock(builder: flatbuffers.Builder, offset: flatbuffers.Long, metaDataLength: number, bodyLength: flatbuffers.Long): flatbuffers.Offset {\n      builder.prep(8, 24);\n      builder.writeInt64(bodyLength);\n      builder.pad(4);\n      builder.writeInt32(metaDataLength);\n      builder.writeInt64(offset);\n      return builder.offset();\n    }\n\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["format/File.ts"],"names":[],"mappings":"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","file":"format/File.js","sourcesContent":["// automatically generated by the FlatBuffers compiler, do not modify\n\nimport { flatbuffers } from 'flatbuffers';\nimport * as NS16187549871986683199 from './Schema';\n/**\n * ----------------------------------------------------------------------\n * Arrow File metadata\n *\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class Footer {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {Footer}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): Footer {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {Footer=} obj\n     * @returns {Footer}\n     */\n    static getRootAsFooter(bb: flatbuffers.ByteBuffer, obj?: Footer): Footer {\n      return (obj || new Footer).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * @returns {org.apache.arrow.flatbuf.MetadataVersion}\n     */\n    version(): NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? /** @type {org.apache.arrow.flatbuf.MetadataVersion} */ (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1;\n    }\n\n    /**\n     * @param {org.apache.arrow.flatbuf.Schema=} obj\n     * @returns {org.apache.arrow.flatbuf.Schema|null}\n     */\n    schema(obj?: NS16187549871986683199.org.apache.arrow.flatbuf.Schema): NS16187549871986683199.org.apache.arrow.flatbuf.Schema | null {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? (obj || new NS16187549871986683199.org.apache.arrow.flatbuf.Schema).__init(this.bb.__indirect(this.bb_pos + offset), this.bb) : null;\n    }\n\n    /**\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.Block=} obj\n     * @returns {org.apache.arrow.flatbuf.Block}\n     */\n    dictionaries(index: number, obj?: org.apache.arrow.flatbuf.Block): org.apache.arrow.flatbuf.Block | null {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? (obj || new org.apache.arrow.flatbuf.Block).__init(this.bb.__vector(this.bb_pos + offset) + index * 24, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    dictionariesLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.Block=} obj\n     * @returns {org.apache.arrow.flatbuf.Block}\n     */\n    recordBatches(index: number, obj?: org.apache.arrow.flatbuf.Block): org.apache.arrow.flatbuf.Block | null {\n      let offset = this.bb.__offset(this.bb_pos, 10);\n      return offset ? (obj || new org.apache.arrow.flatbuf.Block).__init(this.bb.__vector(this.bb_pos + offset) + index * 24, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    recordBatchesLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 10);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startFooter(builder: flatbuffers.Builder) {\n      builder.startObject(4);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {org.apache.arrow.flatbuf.MetadataVersion} version\n     */\n    static addVersion(builder: flatbuffers.Builder, version: NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion) {\n      builder.addFieldInt16(0, version, NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} schemaOffset\n     */\n    static addSchema(builder: flatbuffers.Builder, schemaOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(1, schemaOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} dictionariesOffset\n     */\n    static addDictionaries(builder: flatbuffers.Builder, dictionariesOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(2, dictionariesOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startDictionariesVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(24, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} recordBatchesOffset\n     */\n    static addRecordBatches(builder: flatbuffers.Builder, recordBatchesOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(3, recordBatchesOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startRecordBatchesVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(24, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endFooter(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} offset\n     */\n    static finishFooterBuffer(builder: flatbuffers.Builder, offset: flatbuffers.Offset) {\n      builder.finish(offset);\n    }\n\n  }\n}\n/**\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class Block {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {Block}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): Block {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * Index to the start of the RecordBlock (note this is past the Message header)\n     *\n     * @returns {flatbuffers.Long}\n     */\n    offset(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos);\n    }\n\n    /**\n     * Length of the metadata\n     *\n     * @returns {number}\n     */\n    metaDataLength(): number {\n      return this.bb.readInt32(this.bb_pos + 8);\n    }\n\n    /**\n     * Length of the data (this is aligned so there can be a gap between this and\n     * the metatdata).\n     *\n     * @returns {flatbuffers.Long}\n     */\n    bodyLength(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos + 16);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} offset\n     * @param {number} metaDataLength\n     * @param {flatbuffers.Long} bodyLength\n     * @returns {flatbuffers.Offset}\n     */\n    static createBlock(builder: flatbuffers.Builder, offset: flatbuffers.Long, metaDataLength: number, bodyLength: flatbuffers.Long): flatbuffers.Offset {\n      builder.prep(8, 24);\n      builder.writeInt64(bodyLength);\n      builder.pad(4);\n      builder.writeInt32(metaDataLength);\n      builder.writeInt64(offset);\n      return builder.offset();\n    }\n\n  }\n}\n"]} |
/// <reference types="flatbuffers" /> | ||
import { flatbuffers } from 'flatbuffers'; | ||
import * as NS16187549871986683199 from './Schema'; | ||
import * as NS17322068828641907961 from './Tensor'; | ||
export declare namespace org.apache.arrow.flatbuf { | ||
export import Tensor = NS17322068828641907961.org.apache.arrow.flatbuf.Tensor; | ||
} | ||
export declare namespace org.apache.arrow.flatbuf { | ||
export import Schema = NS16187549871986683199.org.apache.arrow.flatbuf.Schema; | ||
@@ -187,9 +183,9 @@ } | ||
/** | ||
* ---------------------------------------------------------------------- | ||
* For sending dictionary encoding information. Any Field can be | ||
* dictionary-encoded, but in this case none of its children may be | ||
* dictionary-encoded. | ||
* There is one vector / column per dictionary | ||
* There is one vector / column per dictionary, but that vector / column | ||
* may be spread across multiple dictionary batches by using the isDelta | ||
* flag | ||
* | ||
* | ||
* @constructor | ||
@@ -229,2 +225,9 @@ */ | ||
/** | ||
* If isDelta is true the values in the dictionary are to be appended to a | ||
* dictionary with the indicated id | ||
* | ||
* @returns {boolean} | ||
*/ | ||
isDelta(): boolean; | ||
/** | ||
* @param {flatbuffers.Builder} builder | ||
@@ -245,2 +248,7 @@ */ | ||
* @param {flatbuffers.Builder} builder | ||
* @param {boolean} isDelta | ||
*/ | ||
static addIsDelta(builder: flatbuffers.Builder, isDelta: boolean): void; | ||
/** | ||
* @param {flatbuffers.Builder} builder | ||
* @returns {flatbuffers.Offset} | ||
@@ -247,0 +255,0 @@ */ |
@@ -0,5 +1,5 @@ | ||
"use strict"; | ||
// automatically generated by the FlatBuffers compiler, do not modify | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const NS16187549871986683199 = require("./Schema"); | ||
const NS17322068828641907961 = require("./Tensor"); | ||
var org; | ||
@@ -13,14 +13,2 @@ (function (org) { | ||
(function (flatbuf) { | ||
flatbuf.Tensor = NS17322068828641907961.org.apache.arrow.flatbuf.Tensor; | ||
})(flatbuf = arrow.flatbuf || (arrow.flatbuf = {})); | ||
})(arrow = apache.arrow || (apache.arrow = {})); | ||
})(apache = org.apache || (org.apache = {})); | ||
})(org = exports.org || (exports.org = {})); | ||
(function (org) { | ||
var apache; | ||
(function (apache) { | ||
var arrow; | ||
(function (arrow) { | ||
var flatbuf; | ||
(function (flatbuf) { | ||
flatbuf.Schema = NS16187549871986683199.org.apache.arrow.flatbuf.Schema; | ||
@@ -217,3 +205,3 @@ })(flatbuf = arrow.flatbuf || (arrow.flatbuf = {})); | ||
let offset = this.bb.__offset(this.bb_pos, 8); | ||
return offset ? (obj || new NS16187549871986683199.org.apache.arrow.flatbuf.Buffer).__init(this.bb.__vector(this.bb_pos + offset) + index * 24, this.bb) : null; | ||
return offset ? (obj || new NS16187549871986683199.org.apache.arrow.flatbuf.Buffer).__init(this.bb.__vector(this.bb_pos + offset) + index * 16, this.bb) : null; | ||
} | ||
@@ -266,3 +254,3 @@ /** | ||
static startBuffersVector(builder, numElems) { | ||
builder.startVector(24, numElems, 8); | ||
builder.startVector(16, numElems, 8); | ||
} | ||
@@ -284,9 +272,9 @@ /** | ||
/** | ||
* ---------------------------------------------------------------------- | ||
* For sending dictionary encoding information. Any Field can be | ||
* dictionary-encoded, but in this case none of its children may be | ||
* dictionary-encoded. | ||
* There is one vector / column per dictionary | ||
* There is one vector / column per dictionary, but that vector / column | ||
* may be spread across multiple dictionary batches by using the isDelta | ||
* flag | ||
* | ||
* | ||
* @constructor | ||
@@ -342,6 +330,16 @@ */ | ||
/** | ||
* If isDelta is true the values in the dictionary are to be appended to a | ||
* dictionary with the indicated id | ||
* | ||
* @returns {boolean} | ||
*/ | ||
isDelta() { | ||
let offset = this.bb.__offset(this.bb_pos, 8); | ||
return offset ? !!this.bb.readInt8(this.bb_pos + offset) : false; | ||
} | ||
/** | ||
* @param {flatbuffers.Builder} builder | ||
*/ | ||
static startDictionaryBatch(builder) { | ||
builder.startObject(2); | ||
builder.startObject(3); | ||
} | ||
@@ -364,2 +362,9 @@ /** | ||
* @param {flatbuffers.Builder} builder | ||
* @param {boolean} isDelta | ||
*/ | ||
static addIsDelta(builder, isDelta) { | ||
builder.addFieldInt8(2, +isDelta, +false); | ||
} | ||
/** | ||
* @param {flatbuffers.Builder} builder | ||
* @returns {flatbuffers.Offset} | ||
@@ -417,3 +422,3 @@ */ | ||
let offset = this.bb.__offset(this.bb_pos, 4); | ||
return offset ? (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1; | ||
return offset ? /** @type {org.apache.arrow.flatbuf.MetadataVersion} */ (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1; | ||
} | ||
@@ -425,3 +430,3 @@ /** | ||
let offset = this.bb.__offset(this.bb_pos, 6); | ||
return offset ? (this.bb.readUint8(this.bb_pos + offset)) : org.apache.arrow.flatbuf.MessageHeader.NONE; | ||
return offset ? /** @type {org.apache.arrow.flatbuf.MessageHeader} */ (this.bb.readUint8(this.bb_pos + offset)) : org.apache.arrow.flatbuf.MessageHeader.NONE; | ||
} | ||
@@ -499,2 +504,2 @@ /** | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["format/Message.ts"],"names":[],"mappings":"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","file":"format/Message.js","sourcesContent":["// automatically generated by the FlatBuffers compiler, do not modify\n\nimport { flatbuffers } from 'flatbuffers';\nimport * as NS16187549871986683199 from './Schema';\nimport * as NS17322068828641907961 from './Tensor';\nexport namespace org.apache.arrow.flatbuf {\n  export import Tensor = NS17322068828641907961.org.apache.arrow.flatbuf.Tensor;\n}\nexport namespace org.apache.arrow.flatbuf {\n  export import Schema = NS16187549871986683199.org.apache.arrow.flatbuf.Schema;\n}\n/**\n * ----------------------------------------------------------------------\n * The root Message type\n * This union enables us to easily send different message types without\n * redundant storage, and in the future we can easily add new message types.\n *\n * Arrow implementations do not need to implement all of the message types,\n * which may include experimental metadata types. For maximum compatibility,\n * it is best to send data using RecordBatch\n *\n * @enum\n */\nexport namespace org.apache.arrow.flatbuf {\n  export enum MessageHeader {\n    NONE = 0,\n    Schema = 1,\n    DictionaryBatch = 2,\n    RecordBatch = 3,\n    Tensor = 4\n  }\n}\n\n/**\n * ----------------------------------------------------------------------\n * Data structures for describing a table row batch (a collection of\n * equal-length Arrow arrays)\n * Metadata about a field at some level of a nested type tree (but not\n * its children).\n *\n * For example, a List<Int16> with values [[1, 2, 3], null, [4], [5, 6], null]\n * would have {length: 5, null_count: 2} for its List node, and {length: 6,\n * null_count: 0} for its Int16 node, as separate FieldNode structs\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class FieldNode {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {FieldNode}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): FieldNode {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * The number of value slots in the Arrow array at this level of a nested\n     * tree\n     *\n     * @returns {flatbuffers.Long}\n     */\n    length(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos);\n    }\n\n    /**\n     * The number of observed nulls. Fields with null_count == 0 may choose not\n     * to write their physical validity bitmap out as a materialized buffer,\n     * instead setting the length of the bitmap buffer to 0.\n     *\n     * @returns {flatbuffers.Long}\n     */\n    nullCount(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos + 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} length\n     * @param {flatbuffers.Long} null_count\n     * @returns {flatbuffers.Offset}\n     */\n    static createFieldNode(builder: flatbuffers.Builder, length: flatbuffers.Long, null_count: flatbuffers.Long): flatbuffers.Offset {\n      builder.prep(8, 16);\n      builder.writeInt64(null_count);\n      builder.writeInt64(length);\n      return builder.offset();\n    }\n\n  }\n}\n/**\n * A data header describing the shared memory layout of a \"record\" or \"row\"\n * batch. Some systems call this a \"row batch\" internally and others a \"record\n * batch\".\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class RecordBatch {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {RecordBatch}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): RecordBatch {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {RecordBatch=} obj\n     * @returns {RecordBatch}\n     */\n    static getRootAsRecordBatch(bb: flatbuffers.ByteBuffer, obj?: RecordBatch): RecordBatch {\n      return (obj || new RecordBatch).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * number of records / rows. The arrays in the batch should all have this\n     * length\n     *\n     * @returns {flatbuffers.Long}\n     */\n    length(): flatbuffers.Long {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? this.bb.readInt64(this.bb_pos + offset) : this.bb.createLong(0, 0);\n    }\n\n    /**\n     * Nodes correspond to the pre-ordered flattened logical schema\n     *\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.FieldNode=} obj\n     * @returns {org.apache.arrow.flatbuf.FieldNode}\n     */\n    nodes(index: number, obj?: org.apache.arrow.flatbuf.FieldNode): org.apache.arrow.flatbuf.FieldNode | null {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? (obj || new org.apache.arrow.flatbuf.FieldNode).__init(this.bb.__vector(this.bb_pos + offset) + index * 16, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    nodesLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * Buffers correspond to the pre-ordered flattened buffer tree\n     *\n     * The number of buffers appended to this list depends on the schema. For\n     * example, most primitive arrays will have 2 buffers, 1 for the validity\n     * bitmap and 1 for the values. For struct arrays, there will only be a\n     * single buffer for the validity (nulls) bitmap\n     *\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.Buffer=} obj\n     * @returns {org.apache.arrow.flatbuf.Buffer}\n     */\n    buffers(index: number, obj?: NS16187549871986683199.org.apache.arrow.flatbuf.Buffer): NS16187549871986683199.org.apache.arrow.flatbuf.Buffer | null {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? (obj || new NS16187549871986683199.org.apache.arrow.flatbuf.Buffer).__init(this.bb.__vector(this.bb_pos + offset) + index * 24, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    buffersLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startRecordBatch(builder: flatbuffers.Builder) {\n      builder.startObject(3);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} length\n     */\n    static addLength(builder: flatbuffers.Builder, length: flatbuffers.Long) {\n      builder.addFieldInt64(0, length, builder.createLong(0, 0));\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} nodesOffset\n     */\n    static addNodes(builder: flatbuffers.Builder, nodesOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(1, nodesOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startNodesVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(16, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} buffersOffset\n     */\n    static addBuffers(builder: flatbuffers.Builder, buffersOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(2, buffersOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startBuffersVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(24, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endRecordBatch(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n  }\n}\n/**\n * ----------------------------------------------------------------------\n * For sending dictionary encoding information. Any Field can be\n * dictionary-encoded, but in this case none of its children may be\n * dictionary-encoded.\n * There is one vector / column per dictionary\n *\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class DictionaryBatch {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {DictionaryBatch}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): DictionaryBatch {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {DictionaryBatch=} obj\n     * @returns {DictionaryBatch}\n     */\n    static getRootAsDictionaryBatch(bb: flatbuffers.ByteBuffer, obj?: DictionaryBatch): DictionaryBatch {\n      return (obj || new DictionaryBatch).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * @returns {flatbuffers.Long}\n     */\n    id(): flatbuffers.Long {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? this.bb.readInt64(this.bb_pos + offset) : this.bb.createLong(0, 0);\n    }\n\n    /**\n     * @param {org.apache.arrow.flatbuf.RecordBatch=} obj\n     * @returns {org.apache.arrow.flatbuf.RecordBatch|null}\n     */\n    data(obj?: org.apache.arrow.flatbuf.RecordBatch): org.apache.arrow.flatbuf.RecordBatch | null {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? (obj || new org.apache.arrow.flatbuf.RecordBatch).__init(this.bb.__indirect(this.bb_pos + offset), this.bb) : null;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startDictionaryBatch(builder: flatbuffers.Builder) {\n      builder.startObject(2);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} id\n     */\n    static addId(builder: flatbuffers.Builder, id: flatbuffers.Long) {\n      builder.addFieldInt64(0, id, builder.createLong(0, 0));\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} dataOffset\n     */\n    static addData(builder: flatbuffers.Builder, dataOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(1, dataOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endDictionaryBatch(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n  }\n}\n/**\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class Message {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {Message}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): Message {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {Message=} obj\n     * @returns {Message}\n     */\n    static getRootAsMessage(bb: flatbuffers.ByteBuffer, obj?: Message): Message {\n      return (obj || new Message).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * @returns {org.apache.arrow.flatbuf.MetadataVersion}\n     */\n    version(): NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? /** @type {org.apache.arrow.flatbuf.MetadataVersion} */ (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1;\n    }\n\n    /**\n     * @returns {org.apache.arrow.flatbuf.MessageHeader}\n     */\n    headerType(): org.apache.arrow.flatbuf.MessageHeader {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? /** @type {org.apache.arrow.flatbuf.MessageHeader} */ (this.bb.readUint8(this.bb_pos + offset)) : org.apache.arrow.flatbuf.MessageHeader.NONE;\n    }\n\n    /**\n     * @param {flatbuffers.Table} obj\n     * @returns {?flatbuffers.Table}\n     */\n    header<T extends flatbuffers.Table>(obj: T): T | null {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? this.bb.__union(obj, this.bb_pos + offset) : null;\n    }\n\n    /**\n     * @returns {flatbuffers.Long}\n     */\n    bodyLength(): flatbuffers.Long {\n      let offset = this.bb.__offset(this.bb_pos, 10);\n      return offset ? this.bb.readInt64(this.bb_pos + offset) : this.bb.createLong(0, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startMessage(builder: flatbuffers.Builder) {\n      builder.startObject(4);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {org.apache.arrow.flatbuf.MetadataVersion} version\n     */\n    static addVersion(builder: flatbuffers.Builder, version: NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion) {\n      builder.addFieldInt16(0, version, NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {org.apache.arrow.flatbuf.MessageHeader} headerType\n     */\n    static addHeaderType(builder: flatbuffers.Builder, headerType: org.apache.arrow.flatbuf.MessageHeader) {\n      builder.addFieldInt8(1, headerType, org.apache.arrow.flatbuf.MessageHeader.NONE);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} headerOffset\n     */\n    static addHeader(builder: flatbuffers.Builder, headerOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(2, headerOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} bodyLength\n     */\n    static addBodyLength(builder: flatbuffers.Builder, bodyLength: flatbuffers.Long) {\n      builder.addFieldInt64(3, bodyLength, builder.createLong(0, 0));\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endMessage(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} offset\n     */\n    static finishMessageBuffer(builder: flatbuffers.Builder, offset: flatbuffers.Offset) {\n      builder.finish(offset);\n    }\n\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["format/Message.ts"],"names":[],"mappings":";AAAA,qEAAqE;;AAGrE,mDAAmD;AACnD,IAAiB,GAAG,CAEnB;AAFD,WAAiB,GAAG;IAAC,IAAA,MAAM,CAE1B;IAFoB,WAAA,MAAM;QAAC,IAAA,KAAK,CAEhC;QAF2B,WAAA,KAAK;YAAC,IAAA,OAAO,CAExC;YAFiC,WAAA,OAAO;gBACzB,cAAM,GAAG,sBAAsB,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;YAChF,CAAC,EAFiC,OAAO,GAAP,aAAO,KAAP,aAAO,QAExC;QAAD,CAAC,EAF2B,KAAK,GAAL,YAAK,KAAL,YAAK,QAEhC;IAAD,CAAC,EAFoB,MAAM,GAAN,UAAM,KAAN,UAAM,QAE1B;AAAD,CAAC,EAFgB,GAAG,GAAH,WAAG,KAAH,WAAG,QAEnB;AACD;;;;;;;;;;;GAWG;AACH,WAAiB,GAAG;IAAC,IAAA,MAAM,CAQ1B;IARoB,WAAA,MAAM;QAAC,IAAA,KAAK,CAQhC;QAR2B,WAAA,KAAK;YAAC,IAAA,OAAO,CAQxC;YARiC,WAAA,OAAO;gBACvC,IAAY,aAMX;gBAND,WAAY,aAAa;oBACvB,iDAAQ,CAAA;oBACR,qDAAU,CAAA;oBACV,uEAAmB,CAAA;oBACnB,+DAAe,CAAA;oBACf,qDAAU,CAAA;gBACZ,CAAC,EANW,aAAa,GAAb,qBAAa,KAAb,qBAAa,QAMxB;YACH,CAAC,EARiC,OAAO,GAAP,aAAO,KAAP,aAAO,QAQxC;QAAD,CAAC,EAR2B,KAAK,GAAL,YAAK,KAAL,YAAK,QAQhC;IAAD,CAAC,EARoB,MAAM,GAAN,UAAM,KAAN,UAAM,QAQ1B;AAAD,CAAC,EARgB,GAAG,GAAH,WAAG,KAAH,WAAG,QAQnB;AAED;;;;;;;;;;;;GAYG;AACH,WAAiB,GAAG;IAAC,IAAA,MAAM,CAyD1B;IAzDoB,WAAA,MAAM;QAAC,IAAA,KAAK,CAyDhC;QAzD2B,WAAA,KAAK;YAAC,IAAA,OAAO,CAyDxC;YAzDiC,WAAA,OAAO;gBACvC;oBAAA;wBAME;;2BAEG;wBACH,WAAM,GAAW,CAAC,CAAC;oBA8CrB,CAAC;oBA7CC;;;;uBAIG;oBACH,MAAM,CAAC,CAAS,EAAE,EAA0B;wBAC1C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;wBAChB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;wBACb,MAAM,CAAC,IAAI,CAAC;oBACd,CAAC;oBAED;;;;;uBAKG;oBACH,MAAM;wBACJ,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACxC,CAAC;oBAED;;;;;;uBAMG;oBACH,SAAS;wBACP,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;oBAC5C,CAAC;oBAED;;;;;uBAKG;oBACH,MAAM,CAAC,eAAe,CAAC,OAA4B,EAAE,MAAwB,EAAE,UAA4B;wBACzG,OAAO,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;wBACpB,OAAO,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;wBAC/B,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;wBAC3B,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;oBAC1B,CAAC;iBAEF;gBAvDY,iBAAS,YAuDrB,CAAA;YACH,CAAC,EAzDiC,OAAO,GAAP,aAAO,KAAP,aAAO,QAyDxC;QAAD,CAAC,EAzD2B,KAAK,GAAL,YAAK,KAAL,YAAK,QAyDhC;IAAD,CAAC,EAzDoB,MAAM,GAAN,UAAM,KAAN,UAAM,QAyD1B;AAAD,CAAC,EAzDgB,GAAG,GAAH,WAAG,KAAH,WAAG,QAyDnB;AACD;;;;;;GAMG;AACH,WAAiB,GAAG;IAAC,IAAA,MAAM,CAgJ1B;IAhJoB,WAAA,MAAM;QAAC,IAAA,KAAK,CAgJhC;QAhJ2B,WAAA,KAAK;YAAC,IAAA,OAAO,CAgJxC;YAhJiC,WAAA,OAAO;gBACvC;oBAAA;wBAME;;2BAEG;wBACH,WAAM,GAAW,CAAC,CAAC;oBAqIrB,CAAC;oBApIC;;;;uBAIG;oBACH,MAAM,CAAC,CAAS,EAAE,EAA0B;wBAC1C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;wBAChB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;wBACb,MAAM,CAAC,IAAI,CAAC;oBACd,CAAC;oBAED;;;;uBAIG;oBACH,MAAM,CAAC,oBAAoB,CAAC,EAA0B,EAAE,GAAiB;wBACvE,MAAM,CAAC,CAAC,GAAG,IAAI,IAAI,WAAW,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;oBAC1F,CAAC;oBAED;;;;;uBAKG;oBACH,MAAM;wBACJ,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;oBACrF,CAAC;oBAED;;;;;;uBAMG;oBACH,KAAK,CAAC,KAAa,EAAE,GAAwC;wBAC3D,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,IAAI,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,KAAK,GAAG,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAC9I,CAAC;oBAED;;uBAEG;oBACH,WAAW;wBACT,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACjE,CAAC;oBAED;;;;;;;;;;;uBAWG;oBACH,OAAO,CAAC,KAAa,EAAE,GAA4D;wBACjF,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,IAAI,sBAAsB,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,KAAK,GAAG,EAAE,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBAClK,CAAC;oBAED;;uBAEG;oBACH,aAAa;wBACX,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACjE,CAAC;oBAED;;uBAEG;oBACH,MAAM,CAAC,gBAAgB,CAAC,OAA4B;wBAClD,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;oBACzB,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,SAAS,CAAC,OAA4B,EAAE,MAAwB;wBACrE,OAAO,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;oBAC7D,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,QAAQ,CAAC,OAA4B,EAAE,WAA+B;wBAC3E,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC;oBAC5C,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,gBAAgB,CAAC,OAA4B,EAAE,QAAgB;wBACpE,OAAO,CAAC,WAAW,CAAC,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;oBACvC,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,UAAU,CAAC,OAA4B,EAAE,aAAiC;wBAC/E,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;oBAC9C,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,kBAAkB,CAAC,OAA4B,EAAE,QAAgB;wBACtE,OAAO,CAAC,WAAW,CAAC,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;oBACvC,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,cAAc,CAAC,OAA4B;wBAChD,IAAI,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;wBACjC,MAAM,CAAC,MAAM,CAAC;oBAChB,CAAC;iBAEF;gBA9IY,mBAAW,cA8IvB,CAAA;YACH,CAAC,EAhJiC,OAAO,GAAP,aAAO,KAAP,aAAO,QAgJxC;QAAD,CAAC,EAhJ2B,KAAK,GAAL,YAAK,KAAL,YAAK,QAgJhC;IAAD,CAAC,EAhJoB,MAAM,GAAN,UAAM,KAAN,UAAM,QAgJ1B;AAAD,CAAC,EAhJgB,GAAG,GAAH,WAAG,KAAH,WAAG,QAgJnB;AACD;;;;;;;;;GASG;AACH,WAAiB,GAAG;IAAC,IAAA,MAAM,CAoG1B;IApGoB,WAAA,MAAM;QAAC,IAAA,KAAK,CAoGhC;QApG2B,WAAA,KAAK;YAAC,IAAA,OAAO,CAoGxC;YApGiC,WAAA,OAAO;gBACvC;oBAAA;wBAME;;2BAEG;wBACH,WAAM,GAAW,CAAC,CAAC;oBAyFrB,CAAC;oBAxFC;;;;uBAIG;oBACH,MAAM,CAAC,CAAS,EAAE,EAA0B;wBAC1C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;wBAChB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;wBACb,MAAM,CAAC,IAAI,CAAC;oBACd,CAAC;oBAED;;;;uBAIG;oBACH,MAAM,CAAC,wBAAwB,CAAC,EAA0B,EAAE,GAAqB;wBAC/E,MAAM,CAAC,CAAC,GAAG,IAAI,IAAI,eAAe,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;oBAC9F,CAAC;oBAED;;uBAEG;oBACH,EAAE;wBACA,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;oBACrF,CAAC;oBAED;;;uBAGG;oBACH,IAAI,CAAC,GAA0C;wBAC7C,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,IAAI,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBACrI,CAAC;oBAED;;;;;uBAKG;oBACH,OAAO;wBACL,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;oBACnE,CAAC;oBAED;;uBAEG;oBACH,MAAM,CAAC,oBAAoB,CAAC,OAA4B;wBACtD,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;oBACzB,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,KAAK,CAAC,OAA4B,EAAE,EAAoB;wBAC7D,OAAO,CAAC,aAAa,CAAC,CAAC,EAAE,EAAE,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;oBACzD,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,OAAO,CAAC,OAA4B,EAAE,UAA8B;wBACzE,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;oBAC3C,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,UAAU,CAAC,OAA4B,EAAE,OAAgB;wBAC9D,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC;oBAC5C,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,kBAAkB,CAAC,OAA4B;wBACpD,IAAI,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;wBACjC,MAAM,CAAC,MAAM,CAAC;oBAChB,CAAC;iBAEF;gBAlGY,uBAAe,kBAkG3B,CAAA;YACH,CAAC,EApGiC,OAAO,GAAP,aAAO,KAAP,aAAO,QAoGxC;QAAD,CAAC,EApG2B,KAAK,GAAL,YAAK,KAAL,YAAK,QAoGhC;IAAD,CAAC,EApGoB,MAAM,GAAN,UAAM,KAAN,UAAM,QAoG1B;AAAD,CAAC,EApGgB,GAAG,GAAH,WAAG,KAAH,WAAG,QAoGnB;AACD;;GAEG;AACH,WAAiB,GAAG;IAAC,IAAA,MAAM,CAyH1B;IAzHoB,WAAA,MAAM;QAAC,IAAA,KAAK,CAyHhC;QAzH2B,WAAA,KAAK;YAAC,IAAA,OAAO,CAyHxC;YAzHiC,WAAA,OAAO;gBACvC;oBAAA;wBAME;;2BAEG;wBACH,WAAM,GAAW,CAAC,CAAC;oBA8GrB,CAAC;oBA7GC;;;;uBAIG;oBACH,MAAM,CAAC,CAAS,EAAE,EAA0B;wBAC1C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;wBAChB,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;wBACb,MAAM,CAAC,IAAI,CAAC;oBACd,CAAC;oBAED;;;;uBAIG;oBACH,MAAM,CAAC,gBAAgB,CAAC,EAA0B,EAAE,GAAa;wBAC/D,MAAM,CAAC,CAAC,GAAG,IAAI,IAAI,OAAO,CAAC,CAAC,MAAM,CAAC,EAAE,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;oBACtF,CAAC;oBAED;;uBAEG;oBACH,OAAO;wBACL,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,uDAAuD,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,sBAAsB,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE,CAAC;oBACzL,CAAC;oBAED;;uBAEG;oBACH,UAAU;wBACR,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,qDAAqD,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC;oBAChK,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAA8B,GAAM;wBACxC,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;wBAC9C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;oBACpE,CAAC;oBAED;;uBAEG;oBACH,UAAU;wBACR,IAAI,MAAM,GAAG,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;wBAC/C,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;oBACrF,CAAC;oBAED;;uBAEG;oBACH,MAAM,CAAC,YAAY,CAAC,OAA4B;wBAC9C,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;oBACzB,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,UAAU,CAAC,OAA4B,EAAE,OAAwE;wBACtH,OAAO,CAAC,aAAa,CAAC,CAAC,EAAE,OAAO,EAAE,sBAAsB,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;oBACxG,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,aAAa,CAAC,OAA4B,EAAE,UAAkD;wBACnG,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE,UAAU,EAAE,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBACnF,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,SAAS,CAAC,OAA4B,EAAE,YAAgC;wBAC7E,OAAO,CAAC,cAAc,CAAC,CAAC,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;oBAC7C,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,aAAa,CAAC,OAA4B,EAAE,UAA4B;wBAC7E,OAAO,CAAC,aAAa,CAAC,CAAC,EAAE,UAAU,EAAE,OAAO,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;oBACjE,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,UAAU,CAAC,OAA4B;wBAC5C,IAAI,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;wBACjC,MAAM,CAAC,MAAM,CAAC;oBAChB,CAAC;oBAED;;;uBAGG;oBACH,MAAM,CAAC,mBAAmB,CAAC,OAA4B,EAAE,MAA0B;wBACjF,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;oBACzB,CAAC;iBAEF;gBAvHY,eAAO,UAuHnB,CAAA;YACH,CAAC,EAzHiC,OAAO,GAAP,aAAO,KAAP,aAAO,QAyHxC;QAAD,CAAC,EAzH2B,KAAK,GAAL,YAAK,KAAL,YAAK,QAyHhC;IAAD,CAAC,EAzHoB,MAAM,GAAN,UAAM,KAAN,UAAM,QAyH1B;AAAD,CAAC,EAzHgB,GAAG,GAAH,WAAG,KAAH,WAAG,QAyHnB","file":"format/Message.js","sourcesContent":["// automatically generated by the FlatBuffers compiler, do not modify\n\nimport { flatbuffers } from 'flatbuffers';\nimport * as NS16187549871986683199 from './Schema';\nexport namespace org.apache.arrow.flatbuf {\n  export import Schema = NS16187549871986683199.org.apache.arrow.flatbuf.Schema;\n}\n/**\n * ----------------------------------------------------------------------\n * The root Message type\n * This union enables us to easily send different message types without\n * redundant storage, and in the future we can easily add new message types.\n *\n * Arrow implementations do not need to implement all of the message types,\n * which may include experimental metadata types. For maximum compatibility,\n * it is best to send data using RecordBatch\n *\n * @enum\n */\nexport namespace org.apache.arrow.flatbuf {\n  export enum MessageHeader {\n    NONE = 0,\n    Schema = 1,\n    DictionaryBatch = 2,\n    RecordBatch = 3,\n    Tensor = 4\n  }\n}\n\n/**\n * ----------------------------------------------------------------------\n * Data structures for describing a table row batch (a collection of\n * equal-length Arrow arrays)\n * Metadata about a field at some level of a nested type tree (but not\n * its children).\n *\n * For example, a List<Int16> with values [[1, 2, 3], null, [4], [5, 6], null]\n * would have {length: 5, null_count: 2} for its List node, and {length: 6,\n * null_count: 0} for its Int16 node, as separate FieldNode structs\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class FieldNode {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {FieldNode}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): FieldNode {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * The number of value slots in the Arrow array at this level of a nested\n     * tree\n     *\n     * @returns {flatbuffers.Long}\n     */\n    length(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos);\n    }\n\n    /**\n     * The number of observed nulls. Fields with null_count == 0 may choose not\n     * to write their physical validity bitmap out as a materialized buffer,\n     * instead setting the length of the bitmap buffer to 0.\n     *\n     * @returns {flatbuffers.Long}\n     */\n    nullCount(): flatbuffers.Long {\n      return this.bb.readInt64(this.bb_pos + 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} length\n     * @param {flatbuffers.Long} null_count\n     * @returns {flatbuffers.Offset}\n     */\n    static createFieldNode(builder: flatbuffers.Builder, length: flatbuffers.Long, null_count: flatbuffers.Long): flatbuffers.Offset {\n      builder.prep(8, 16);\n      builder.writeInt64(null_count);\n      builder.writeInt64(length);\n      return builder.offset();\n    }\n\n  }\n}\n/**\n * A data header describing the shared memory layout of a \"record\" or \"row\"\n * batch. Some systems call this a \"row batch\" internally and others a \"record\n * batch\".\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class RecordBatch {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {RecordBatch}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): RecordBatch {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {RecordBatch=} obj\n     * @returns {RecordBatch}\n     */\n    static getRootAsRecordBatch(bb: flatbuffers.ByteBuffer, obj?: RecordBatch): RecordBatch {\n      return (obj || new RecordBatch).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * number of records / rows. The arrays in the batch should all have this\n     * length\n     *\n     * @returns {flatbuffers.Long}\n     */\n    length(): flatbuffers.Long {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? this.bb.readInt64(this.bb_pos + offset) : this.bb.createLong(0, 0);\n    }\n\n    /**\n     * Nodes correspond to the pre-ordered flattened logical schema\n     *\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.FieldNode=} obj\n     * @returns {org.apache.arrow.flatbuf.FieldNode}\n     */\n    nodes(index: number, obj?: org.apache.arrow.flatbuf.FieldNode): org.apache.arrow.flatbuf.FieldNode | null {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? (obj || new org.apache.arrow.flatbuf.FieldNode).__init(this.bb.__vector(this.bb_pos + offset) + index * 16, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    nodesLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * Buffers correspond to the pre-ordered flattened buffer tree\n     *\n     * The number of buffers appended to this list depends on the schema. For\n     * example, most primitive arrays will have 2 buffers, 1 for the validity\n     * bitmap and 1 for the values. For struct arrays, there will only be a\n     * single buffer for the validity (nulls) bitmap\n     *\n     * @param {number} index\n     * @param {org.apache.arrow.flatbuf.Buffer=} obj\n     * @returns {org.apache.arrow.flatbuf.Buffer}\n     */\n    buffers(index: number, obj?: NS16187549871986683199.org.apache.arrow.flatbuf.Buffer): NS16187549871986683199.org.apache.arrow.flatbuf.Buffer | null {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? (obj || new NS16187549871986683199.org.apache.arrow.flatbuf.Buffer).__init(this.bb.__vector(this.bb_pos + offset) + index * 16, this.bb) : null;\n    }\n\n    /**\n     * @returns {number}\n     */\n    buffersLength(): number {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? this.bb.__vector_len(this.bb_pos + offset) : 0;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startRecordBatch(builder: flatbuffers.Builder) {\n      builder.startObject(3);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} length\n     */\n    static addLength(builder: flatbuffers.Builder, length: flatbuffers.Long) {\n      builder.addFieldInt64(0, length, builder.createLong(0, 0));\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} nodesOffset\n     */\n    static addNodes(builder: flatbuffers.Builder, nodesOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(1, nodesOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startNodesVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(16, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} buffersOffset\n     */\n    static addBuffers(builder: flatbuffers.Builder, buffersOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(2, buffersOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {number} numElems\n     */\n    static startBuffersVector(builder: flatbuffers.Builder, numElems: number) {\n      builder.startVector(16, numElems, 8);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endRecordBatch(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n  }\n}\n/**\n * For sending dictionary encoding information. Any Field can be\n * dictionary-encoded, but in this case none of its children may be\n * dictionary-encoded.\n * There is one vector / column per dictionary, but that vector / column\n * may be spread across multiple dictionary batches by using the isDelta\n * flag\n *\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class DictionaryBatch {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {DictionaryBatch}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): DictionaryBatch {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {DictionaryBatch=} obj\n     * @returns {DictionaryBatch}\n     */\n    static getRootAsDictionaryBatch(bb: flatbuffers.ByteBuffer, obj?: DictionaryBatch): DictionaryBatch {\n      return (obj || new DictionaryBatch).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * @returns {flatbuffers.Long}\n     */\n    id(): flatbuffers.Long {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? this.bb.readInt64(this.bb_pos + offset) : this.bb.createLong(0, 0);\n    }\n\n    /**\n     * @param {org.apache.arrow.flatbuf.RecordBatch=} obj\n     * @returns {org.apache.arrow.flatbuf.RecordBatch|null}\n     */\n    data(obj?: org.apache.arrow.flatbuf.RecordBatch): org.apache.arrow.flatbuf.RecordBatch | null {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? (obj || new org.apache.arrow.flatbuf.RecordBatch).__init(this.bb.__indirect(this.bb_pos + offset), this.bb) : null;\n    }\n\n    /**\n     * If isDelta is true the values in the dictionary are to be appended to a\n     * dictionary with the indicated id\n     *\n     * @returns {boolean}\n     */\n    isDelta(): boolean {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? !!this.bb.readInt8(this.bb_pos + offset) : false;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startDictionaryBatch(builder: flatbuffers.Builder) {\n      builder.startObject(3);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} id\n     */\n    static addId(builder: flatbuffers.Builder, id: flatbuffers.Long) {\n      builder.addFieldInt64(0, id, builder.createLong(0, 0));\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} dataOffset\n     */\n    static addData(builder: flatbuffers.Builder, dataOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(1, dataOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {boolean} isDelta\n     */\n    static addIsDelta(builder: flatbuffers.Builder, isDelta: boolean) {\n      builder.addFieldInt8(2, +isDelta, +false);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endDictionaryBatch(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n  }\n}\n/**\n * @constructor\n */\nexport namespace org.apache.arrow.flatbuf {\n  export class Message {\n    /**\n     * @type {flatbuffers.ByteBuffer}\n     */\n    bb: flatbuffers.ByteBuffer;\n\n    /**\n     * @type {number}\n     */\n    bb_pos: number = 0;\n    /**\n     * @param {number} i\n     * @param {flatbuffers.ByteBuffer} bb\n     * @returns {Message}\n     */\n    __init(i: number, bb: flatbuffers.ByteBuffer): Message {\n      this.bb_pos = i;\n      this.bb = bb;\n      return this;\n    }\n\n    /**\n     * @param {flatbuffers.ByteBuffer} bb\n     * @param {Message=} obj\n     * @returns {Message}\n     */\n    static getRootAsMessage(bb: flatbuffers.ByteBuffer, obj?: Message): Message {\n      return (obj || new Message).__init(bb.readInt32(bb.position()) + bb.position(), bb);\n    }\n\n    /**\n     * @returns {org.apache.arrow.flatbuf.MetadataVersion}\n     */\n    version(): NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion {\n      let offset = this.bb.__offset(this.bb_pos, 4);\n      return offset ? /** @type {org.apache.arrow.flatbuf.MetadataVersion} */ (this.bb.readInt16(this.bb_pos + offset)) : NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1;\n    }\n\n    /**\n     * @returns {org.apache.arrow.flatbuf.MessageHeader}\n     */\n    headerType(): org.apache.arrow.flatbuf.MessageHeader {\n      let offset = this.bb.__offset(this.bb_pos, 6);\n      return offset ? /** @type {org.apache.arrow.flatbuf.MessageHeader} */ (this.bb.readUint8(this.bb_pos + offset)) : org.apache.arrow.flatbuf.MessageHeader.NONE;\n    }\n\n    /**\n     * @param {flatbuffers.Table} obj\n     * @returns {?flatbuffers.Table}\n     */\n    header<T extends flatbuffers.Table>(obj: T): T | null {\n      let offset = this.bb.__offset(this.bb_pos, 8);\n      return offset ? this.bb.__union(obj, this.bb_pos + offset) : null;\n    }\n\n    /**\n     * @returns {flatbuffers.Long}\n     */\n    bodyLength(): flatbuffers.Long {\n      let offset = this.bb.__offset(this.bb_pos, 10);\n      return offset ? this.bb.readInt64(this.bb_pos + offset) : this.bb.createLong(0, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     */\n    static startMessage(builder: flatbuffers.Builder) {\n      builder.startObject(4);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {org.apache.arrow.flatbuf.MetadataVersion} version\n     */\n    static addVersion(builder: flatbuffers.Builder, version: NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion) {\n      builder.addFieldInt16(0, version, NS16187549871986683199.org.apache.arrow.flatbuf.MetadataVersion.V1);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {org.apache.arrow.flatbuf.MessageHeader} headerType\n     */\n    static addHeaderType(builder: flatbuffers.Builder, headerType: org.apache.arrow.flatbuf.MessageHeader) {\n      builder.addFieldInt8(1, headerType, org.apache.arrow.flatbuf.MessageHeader.NONE);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} headerOffset\n     */\n    static addHeader(builder: flatbuffers.Builder, headerOffset: flatbuffers.Offset) {\n      builder.addFieldOffset(2, headerOffset, 0);\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Long} bodyLength\n     */\n    static addBodyLength(builder: flatbuffers.Builder, bodyLength: flatbuffers.Long) {\n      builder.addFieldInt64(3, bodyLength, builder.createLong(0, 0));\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @returns {flatbuffers.Offset}\n     */\n    static endMessage(builder: flatbuffers.Builder): flatbuffers.Offset {\n      let offset = builder.endObject();\n      return offset;\n    }\n\n    /**\n     * @param {flatbuffers.Builder} builder\n     * @param {flatbuffers.Offset} offset\n     */\n    static finishMessageBuffer(builder: flatbuffers.Builder, offset: flatbuffers.Offset) {\n      builder.finish(offset);\n    }\n\n  }\n}\n"]} |
@@ -8,5 +8,18 @@ /// <reference types="flatbuffers" /> | ||
enum MetadataVersion { | ||
/** | ||
* 0.1.0 | ||
*/ | ||
V1 = 0, | ||
/** | ||
* 0.2.0 | ||
*/ | ||
V2 = 1, | ||
/** | ||
* 0.3.0 -> 0.7.1 | ||
*/ | ||
V3 = 2, | ||
/** | ||
* >= 0.8.0 | ||
*/ | ||
V4 = 3, | ||
} | ||
@@ -1395,9 +1408,2 @@ } | ||
/** | ||
* The shared memory page id where this buffer is located. Currently this is | ||
* not used | ||
* | ||
* @returns {number} | ||
*/ | ||
page(): number; | ||
/** | ||
* The relative offset into the shared memory page where the bytes for this | ||
@@ -1418,3 +1424,2 @@ * buffer starts | ||
* @param {flatbuffers.Builder} builder | ||
* @param {number} page | ||
* @param {flatbuffers.Long} offset | ||
@@ -1424,3 +1429,3 @@ * @param {flatbuffers.Long} length | ||
*/ | ||
static createBuffer(builder: flatbuffers.Builder, page: number, offset: flatbuffers.Long, length: flatbuffers.Long): flatbuffers.Offset; | ||
static createBuffer(builder: flatbuffers.Builder, offset: flatbuffers.Long, length: flatbuffers.Long): flatbuffers.Offset; | ||
} | ||
@@ -1427,0 +1432,0 @@ } |
{ | ||
"name": "@apache-arrow/esnext-cjs", | ||
"version": "0.2.0", | ||
"main": "Arrow.js", | ||
"typings": "Arrow.d.ts", | ||
"name": "@apache-arrow/esnext-cjs", | ||
"version": "0.1.2", | ||
"description": "Apache's columnar in-memory data format for big data analytics", | ||
"author": "Graphistry, Inc.", | ||
"homepage": "https://github.com/graphistry/arrow#readme", | ||
"types": "Arrow.d.ts", | ||
"license": "Apache-2.0", | ||
"description": "Apache Arrow columnar in-memory format", | ||
"author": "Apache Software Foundation", | ||
"homepage": "https://github.com/apache/arrow/blob/master/js/README.md", | ||
"repository": { | ||
"type": "git", | ||
"url": "git+https://github.com/apache/arrow.git" | ||
}, | ||
"bugs": { | ||
"url": "https://github.com/graphistry/arrow/issues" | ||
"url": "https://issues.apache.org/jira/projects/ARROW" | ||
}, | ||
"license": "Apache-2.0", | ||
"keywords": [ | ||
@@ -17,9 +21,7 @@ "apache", | ||
], | ||
"repository": { | ||
"type": "git", | ||
"url": "git+https://github.com/graphistry/arrow.git" | ||
}, | ||
"peerDependencies": { | ||
"tslib": "^1.7.1" | ||
"dependencies": { | ||
"flatbuffers": "trxcllnt/flatbuffers-esm", | ||
"text-encoding-utf-8": "^1.0.2", | ||
"tslib": "^1.8.0" | ||
} | ||
} | ||
} |
/// <reference types="flatbuffers" /> | ||
/// <reference types="node" /> | ||
import { Vector } from '../vector/vector'; | ||
import { flatbuffers } from 'flatbuffers'; | ||
import * as File_ from '../format/File'; | ||
import * as Schema_ from '../format/Schema'; | ||
import * as Message_ from '../format/Message'; | ||
import { Vector } from '../vector/vector'; | ||
import ByteBuffer = flatbuffers.ByteBuffer; | ||
export import Schema = Schema_.org.apache.arrow.flatbuf.Schema; | ||
export import RecordBatch = Message_.org.apache.arrow.flatbuf.RecordBatch; | ||
export declare type Dictionaries = { | ||
[k: string]: Vector<any>; | ||
import Footer = File_.org.apache.arrow.flatbuf.Footer; | ||
import Field = Schema_.org.apache.arrow.flatbuf.Field; | ||
import Schema = Schema_.org.apache.arrow.flatbuf.Schema; | ||
import Message = Message_.org.apache.arrow.flatbuf.Message; | ||
import ArrowBuffer = Schema_.org.apache.arrow.flatbuf.Buffer; | ||
import FieldNode = Message_.org.apache.arrow.flatbuf.FieldNode; | ||
import RecordBatch = Message_.org.apache.arrow.flatbuf.RecordBatch; | ||
export declare type ArrowReaderContext = { | ||
schema?: Schema; | ||
footer?: Footer | null; | ||
dictionaries: Map<string, Vector>; | ||
dictionaryEncodedFields: Map<string, Field>; | ||
readMessages: (bb: ByteBuffer, footer: Footer) => Iterable<Message>; | ||
}; | ||
export declare type IteratorState = { | ||
nodeIndex: number; | ||
bufferIndex: number; | ||
}; | ||
export declare function readRecords(...bytes: ByteBuffer[]): IterableIterator<{ | ||
schema: any; | ||
batch: { | ||
id?: string; | ||
offset: number; | ||
bytes: Uint8Array; | ||
data: RecordBatch; | ||
}; | ||
}>; | ||
export declare function readBuffers(...bytes: Array<Uint8Array | Buffer | string>): IterableIterator<Vector<any>[]>; | ||
export interface VectorReaderContext { | ||
offset: number; | ||
bytes: Uint8Array; | ||
batch: RecordBatch; | ||
dictionaries: Map<string, Vector>; | ||
readNextNode(): FieldNode; | ||
readNextBuffer(): ArrowBuffer; | ||
} | ||
export declare function readVectors(buffers: Iterable<Uint8Array | Buffer | string>, context?: ArrowReaderContext): IterableIterator<Vector<any>[]>; | ||
export declare function readVectorsAsync(buffers: AsyncIterable<Uint8Array | Buffer | string>, context?: ArrowReaderContext): AsyncIterableIterator<Vector<any>[]>; |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -19,48 +20,96 @@ // or more contributor license agreements. See the NOTICE file | ||
const flatbuffers_1 = require("flatbuffers"); | ||
const vector_1 = require("./vector"); | ||
const format_1 = require("./format"); | ||
const Schema_ = require("../format/Schema"); | ||
const Message_ = require("../format/Message"); | ||
const file_1 = require("./file"); | ||
const stream_1 = require("./stream"); | ||
const vector_1 = require("./vector"); | ||
const dictionary_1 = require("./dictionary"); | ||
var ByteBuffer = flatbuffers_1.flatbuffers.ByteBuffer; | ||
exports.Schema = Schema_.org.apache.arrow.flatbuf.Schema; | ||
exports.RecordBatch = Message_.org.apache.arrow.flatbuf.RecordBatch; | ||
function* readRecords(...bytes) { | ||
try { | ||
yield* file_1.readFile(...bytes); | ||
var Field = Schema_.org.apache.arrow.flatbuf.Field; | ||
var RecordBatch = Message_.org.apache.arrow.flatbuf.RecordBatch; | ||
var MessageHeader = Message_.org.apache.arrow.flatbuf.MessageHeader; | ||
var MetadataVersion = Schema_.org.apache.arrow.flatbuf.MetadataVersion; | ||
var DictionaryBatch = Message_.org.apache.arrow.flatbuf.DictionaryBatch; | ||
function* readVectors(buffers, context) { | ||
const context_ = context || {}; | ||
for (const buffer of buffers) { | ||
yield* readBuffer(toByteBuffer(buffer), context_); | ||
} | ||
catch (e) { | ||
try { | ||
yield* stream_1.readStream(...bytes); | ||
} | ||
catch (e) { | ||
throw new Error('Invalid Arrow buffer'); | ||
} | ||
} | ||
exports.readVectors = readVectors; | ||
async function* readVectorsAsync(buffers, context) { | ||
const context_ = context || {}; | ||
for await (const buffer of buffers) { | ||
yield* readBuffer(toByteBuffer(buffer), context_); | ||
} | ||
} | ||
exports.readRecords = readRecords; | ||
function* readBuffers(...bytes) { | ||
const dictionaries = {}; | ||
const byteBuffers = bytes.map(toByteBuffer); | ||
for (let { schema, batch } of readRecords(...byteBuffers)) { | ||
let vectors = []; | ||
let state = { nodeIndex: 0, bufferIndex: 0 }; | ||
let index = -1, fieldsLength = schema.fieldsLength(); | ||
if (batch.id) { | ||
while (++index < fieldsLength) { | ||
for (let [id, vector] of dictionary_1.readDictionaries(schema.fields(index), batch, state, dictionaries)) { | ||
dictionaries[id] = dictionaries[id] && dictionaries[id].concat(vector) || vector; | ||
exports.readVectorsAsync = readVectorsAsync; | ||
function* readBuffer(bb, readerContext) { | ||
let { schema, footer, readMessages, dictionaryEncodedFields, dictionaries } = readerContext; | ||
if (!schema) { | ||
({ schema, footer, readMessages, dictionaryEncodedFields } = readSchema(bb)); | ||
readerContext.schema = schema; | ||
readerContext.readMessages = readMessages; | ||
readerContext.dictionaryEncodedFields = dictionaryEncodedFields; | ||
readerContext.dictionaries = dictionaries = new Map(); | ||
} | ||
const fieldsLength = schema.fieldsLength(); | ||
const context = new BufferReaderContext(bb.bytes(), dictionaries); | ||
for (const message of readMessages(bb, footer)) { | ||
let id; | ||
let field; | ||
let vector; | ||
let vectors; | ||
context.message = message; | ||
if (message.headerType() === MessageHeader.DictionaryBatch) { | ||
let batch; | ||
if (batch = message.header(new DictionaryBatch())) { | ||
context.batch = batch.data(); | ||
id = batch.id().toFloat64().toString(); | ||
field = dictionaryEncodedFields.get(id); | ||
vector = vector_1.readValueVector(field, context); | ||
if (batch.isDelta() && dictionaries.has(id)) { | ||
vector = dictionaries.get(id).concat(vector); | ||
} | ||
dictionaries.set(id, vector); | ||
} | ||
continue; | ||
} | ||
else { | ||
while (++index < fieldsLength) { | ||
vectors[index] = vector_1.readVector(schema.fields(index), batch, state, dictionaries); | ||
vectors = new Array(fieldsLength); | ||
context.batch = message.header(new RecordBatch()); | ||
for (let i = -1; ++i < fieldsLength;) { | ||
if ((field = schema.fields(i)) || (vectors[i] = null)) { | ||
vectors[i] = vector_1.readVector(field, context); | ||
} | ||
yield vectors; | ||
} | ||
yield vectors; | ||
} | ||
} | ||
exports.readBuffers = readBuffers; | ||
function readSchema(bb) { | ||
let schema, readMessages, footer = format_1.readFileFooter(bb); | ||
if (footer) { | ||
schema = footer.schema(); | ||
readMessages = format_1.readFileMessages; | ||
} | ||
else if (schema = format_1.readStreamSchema(bb)) { | ||
readMessages = format_1.readStreamMessages; | ||
} | ||
else { | ||
throw new Error('Invalid Arrow buffer'); | ||
} | ||
return { schema, footer, readMessages, dictionaryEncodedFields: readDictionaryEncodedFields(schema, new Map()) }; | ||
} | ||
function readDictionaryEncodedFields(parent, fields) { | ||
let field, encoding, id; | ||
let getField = parent instanceof Field ? parent.children : parent.fields; | ||
let getFieldCount = parent instanceof Field ? parent.childrenLength : parent.fieldsLength; | ||
for (let i = -1, n = getFieldCount.call(parent); ++i < n;) { | ||
if (field = getField.call(parent, i)) { | ||
if ((encoding = field.dictionary()) && | ||
(id = encoding.id().toFloat64().toString())) { | ||
!fields.has(id) && fields.set(id, field); | ||
} | ||
readDictionaryEncodedFields(field, fields); | ||
} | ||
} | ||
return fields; | ||
} | ||
function toByteBuffer(bytes) { | ||
@@ -77,3 +126,28 @@ let arr = bytes || new Uint8Array(0); | ||
} | ||
class BufferReaderContext { | ||
constructor(bytes, dictionaries) { | ||
this.bytes = bytes; | ||
this.dictionaries = dictionaries; | ||
} | ||
set message(m) { | ||
this.nodeIndex = 0; | ||
this.bufferIndex = 0; | ||
this.offset = m.bb.position(); | ||
this.metadataVersion = m.version(); | ||
} | ||
readNextNode() { | ||
return this.batch.nodes(this.nodeIndex++); | ||
} | ||
readNextBuffer() { | ||
const buffer = this.batch.buffers(this.bufferIndex++); | ||
// If this Arrow buffer was written before version 4, | ||
// advance the buffer's bb_pos 8 bytes to skip past | ||
// the now-removed page id field. | ||
if (this.metadataVersion < MetadataVersion[`V4`]) { | ||
buffer.bb_pos += (8 * this.bufferIndex); | ||
} | ||
return buffer; | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,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QUUsS0FBSyxFQUFFLFlBQVksQ0FBQyxDQUFDO1lBQ2xGLENBQUM7WUFDRCxNQUFNLE9BQU8sQ0FBQztRQUNsQixDQUFDO0lBQ0wsQ0FBQztBQUNMLENBQUM7QUFwQkQsa0NBb0JDO0FBRUQsc0JBQXNCLEtBQW9DO0lBQ3RELElBQUksR0FBRyxHQUFlLEtBQVksSUFBSSxJQUFJLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN4RCxFQUFFLENBQUMsQ0FBQyxPQUFPLEtBQUssS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBQzVCLEdBQUcsR0FBRyxJQUFJLFVBQVUsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDbkMsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUM7WUFDMUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDakMsQ0FBQztRQUNELE1BQU0sQ0FBQyxJQUFJLFVBQVUsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBQ0QsTUFBTSxDQUFDLElBQUksVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0FBQy9CLENBQUMiLCJmaWxlIjoicmVhZGVyL2Fycm93LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTGljZW5zZWQgdG8gdGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChBU0YpIHVuZGVyIG9uZVxuLy8gb3IgbW9yZSBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlXG4vLyBkaXN0cmlidXRlZCB3aXRoIHRoaXMgd29yayBmb3IgYWRkaXRpb25hbCBpbmZvcm1hdGlvblxuLy8gcmVnYXJkaW5nIGNvcHlyaWdodCBvd25lcnNoaXAuICBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZVxuLy8gdG8geW91IHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZVxuLy8gXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4vLyB3aXRoIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4vL1xuLy8gICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbi8vXG4vLyBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsXG4vLyBzb2Z0d2FyZSBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhblxuLy8gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTllcbi8vIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZVxuLy8gc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZCBsaW1pdGF0aW9uc1xuLy8gdW5kZXIgdGhlIExpY2Vuc2UuXG5cbmltcG9ydCB7IGZsYXRidWZmZXJzIH0gZnJvbSAnZmxhdGJ1ZmZlcnMnO1xuaW1wb3J0ICogYXMgU2NoZW1hXyBmcm9tICcuLi9mb3JtYXQvU2NoZW1hJztcbmltcG9ydCAqIGFzIE1lc3NhZ2VfIGZyb20gJy4uL2Zvcm1hdC9NZXNzYWdlJztcblxuaW1wb3J0IHsgcmVhZEZpbGUgfSBmcm9tICcuL2ZpbGUnO1xuaW1wb3J0IHsgcmVhZFN0cmVhbSB9IGZyb20gJy4vc3RyZWFtJztcbmltcG9ydCB7IHJlYWRWZWN0b3IgfSBmcm9tICcuL3ZlY3Rvcic7XG5pbXBvcnQgeyBWZWN0b3IgfSBmcm9tICcuLi92ZWN0b3IvdmVjdG9yJztcbmltcG9ydCB7IHJlYWREaWN0aW9uYXJpZXMgfSBmcm9tICcuL2RpY3Rpb25hcnknO1xuXG5pbXBvcnQgQnl0ZUJ1ZmZlciA9IGZsYXRidWZmZXJzLkJ5dGVCdWZmZXI7XG5leHBvcnQgaW1wb3J0IFNjaGVtYSA9IFNjaGVtYV8ub3JnLmFwYWNoZS5hcnJvdy5mbGF0YnVmLlNjaGVtYTtcbmV4cG9ydCBpbXBvcnQgUmVjb3JkQmF0Y2ggPSBNZXNzYWdlXy5vcmcuYXBhY2hlLmFycm93LmZsYXRidWYuUmVjb3JkQmF0Y2g7XG5leHBvcnQgdHlwZSBEaWN0aW9uYXJpZXMgPSB7IFtrOiBzdHJpbmddOiBWZWN0b3I8YW55PiB9O1xuZXhwb3J0IHR5cGUgSXRlcmF0b3JTdGF0ZSA9IHsgbm9kZUluZGV4OiBudW1iZXI7IGJ1ZmZlckluZGV4OiBudW1iZXIgfTtcblxuZXhwb3J0IGZ1bmN0aW9uKiByZWFkUmVjb3JkcyguLi5ieXRlczogQnl0ZUJ1ZmZlcltdKSB7XG4gICAgdHJ5IHtcbiAgICAgICAgeWllbGQqIHJlYWRGaWxlKC4uLmJ5dGVzKTtcbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgICB5aWVsZCogcmVhZFN0cmVhbSguLi5ieXRlcyk7XG4gICAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcignSW52YWxpZCBBcnJvdyBidWZmZXInKTtcbiAgICAgICAgfVxuICAgIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uKiByZWFkQnVmZmVycyguLi5ieXRlczogQXJyYXk8VWludDhBcnJheSB8IEJ1ZmZlciB8IHN0cmluZz4pIHtcbiAgICBjb25zdCBkaWN0aW9uYXJpZXM6IERpY3Rpb25hcmllcyA9IHt9O1xuICAgIGNvbnN0IGJ5dGVCdWZmZXJzID0gYnl0ZXMubWFwKHRvQnl0ZUJ1ZmZlcik7XG4gICAgZm9yIChsZXQgeyBzY2hlbWEsIGJhdGNoIH0gb2YgcmVhZFJlY29yZHMoLi4uYnl0ZUJ1ZmZlcnMpKSB7XG4gICAgICAgIGxldCB2ZWN0b3JzOiBWZWN0b3I8YW55PltdID0gW107XG4gICAgICAgIGxldCBzdGF0ZSA9IHsgbm9kZUluZGV4OiAwLCBidWZmZXJJbmRleDogMCB9O1xuICAgICAgICBsZXQgaW5kZXggPSAtMSwgZmllbGRzTGVuZ3RoID0gc2NoZW1hLmZpZWxkc0xlbmd0aCgpO1xuICAgICAgICBpZiAoYmF0Y2guaWQpIHtcbiAgICAgICAgICAgIHdoaWxlICgrK2luZGV4IDwgZmllbGRzTGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgZm9yIChsZXQgW2lkLCB2ZWN0b3JdIG9mIHJlYWREaWN0aW9uYXJpZXMoc2NoZW1hLmZpZWxkcyhpbmRleCksIGJhdGNoLCBzdGF0ZSwgZGljdGlvbmFyaWVzKSkge1xuICAgICAgICAgICAgICAgICAgICBkaWN0aW9uYXJpZXNbaWRdID0gZGljdGlvbmFyaWVzW2lkXSAmJiBkaWN0aW9uYXJpZXNbaWRdLmNvbmNhdCh2ZWN0b3IpIHx8IHZlY3RvcjtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB3aGlsZSAoKytpbmRleCA8IGZpZWxkc0xlbmd0aCkge1xuICAgICAgICAgICAgICAgIHZlY3RvcnNbaW5kZXhdID0gcmVhZFZlY3RvcihzY2hlbWEuZmllbGRzKGluZGV4KSwgYmF0Y2gsIHN0YXRlLCBkaWN0aW9uYXJpZXMpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgeWllbGQgdmVjdG9ycztcbiAgICAgICAgfVxuICAgIH1cbn1cblxuZnVuY3Rpb24gdG9CeXRlQnVmZmVyKGJ5dGVzPzogVWludDhBcnJheSB8IEJ1ZmZlciB8IHN0cmluZykge1xuICAgIGxldCBhcnI6IFVpbnQ4QXJyYXkgPSBieXRlcyBhcyBhbnkgfHwgbmV3IFVpbnQ4QXJyYXkoMCk7XG4gICAgaWYgKHR5cGVvZiBieXRlcyA9PT0gJ3N0cmluZycpIHtcbiAgICAgICAgYXJyID0gbmV3IFVpbnQ4QXJyYXkoYnl0ZXMubGVuZ3RoKTtcbiAgICAgICAgZm9yIChsZXQgaSA9IC0xLCBuID0gYnl0ZXMubGVuZ3RoOyArK2kgPCBuOykge1xuICAgICAgICAgICAgYXJyW2ldID0gYnl0ZXMuY2hhckNvZGVBdChpKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gbmV3IEJ5dGVCdWZmZXIoYXJyKTtcbiAgICB9XG4gICAgcmV0dXJuIG5ldyBCeXRlQnVmZmVyKGFycik7XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["reader/arrow.ts"],"names":[],"mappings":"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","file":"reader/arrow.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { Vector } from '../vector/vector';\nimport { flatbuffers } from 'flatbuffers';\nimport { readVector, readValueVector } from './vector';\nimport {\n    readFileFooter, readFileMessages,\n    readStreamSchema, readStreamMessages\n} from './format';\n\nimport * as File_ from '../format/File';\nimport * as Schema_ from '../format/Schema';\nimport * as Message_ from '../format/Message';\n\nimport ByteBuffer = flatbuffers.ByteBuffer;\nimport Footer = File_.org.apache.arrow.flatbuf.Footer;\nimport Field = Schema_.org.apache.arrow.flatbuf.Field;\nimport Schema = Schema_.org.apache.arrow.flatbuf.Schema;\nimport Message = Message_.org.apache.arrow.flatbuf.Message;\nimport ArrowBuffer = Schema_.org.apache.arrow.flatbuf.Buffer;\nimport FieldNode = Message_.org.apache.arrow.flatbuf.FieldNode;\nimport RecordBatch = Message_.org.apache.arrow.flatbuf.RecordBatch;\nimport MessageHeader = Message_.org.apache.arrow.flatbuf.MessageHeader;\nimport MetadataVersion = Schema_.org.apache.arrow.flatbuf.MetadataVersion;\nimport DictionaryBatch = Message_.org.apache.arrow.flatbuf.DictionaryBatch;\nimport DictionaryEncoding = Schema_.org.apache.arrow.flatbuf.DictionaryEncoding;\n\nexport type ArrowReaderContext = {\n    schema?: Schema;\n    footer?: Footer | null;\n    dictionaries: Map<string, Vector>;\n    dictionaryEncodedFields: Map<string, Field>;\n    readMessages: (bb: ByteBuffer, footer: Footer) => Iterable<Message>;\n};\n\nexport interface VectorReaderContext {\n    offset: number;\n    bytes: Uint8Array;\n    batch: RecordBatch;\n    dictionaries: Map<string, Vector>;\n    readNextNode(): FieldNode;\n    readNextBuffer(): ArrowBuffer;\n}\n\nexport function* readVectors(buffers: Iterable<Uint8Array | Buffer | string>, context?: ArrowReaderContext) {\n    const context_ = context || {} as ArrowReaderContext;\n    for (const buffer of buffers) {\n        yield* readBuffer(toByteBuffer(buffer), context_);\n    }\n}\n\nexport async function* readVectorsAsync(buffers: AsyncIterable<Uint8Array | Buffer | string>, context?: ArrowReaderContext) {\n    const context_ = context || {} as ArrowReaderContext;\n    for await (const buffer of buffers) {\n        yield* readBuffer(toByteBuffer(buffer), context_);\n    }\n}\n\nfunction* readBuffer(bb: ByteBuffer, readerContext: ArrowReaderContext) {\n\n    let { schema, footer, readMessages, dictionaryEncodedFields, dictionaries } = readerContext;\n\n    if (!schema) {\n        ({ schema, footer, readMessages, dictionaryEncodedFields } = readSchema(bb));\n        readerContext.schema = schema;\n        readerContext.readMessages = readMessages;\n        readerContext.dictionaryEncodedFields = dictionaryEncodedFields;\n        readerContext.dictionaries = dictionaries = new Map<string, Vector>();\n    }\n\n    const fieldsLength = schema.fieldsLength();\n    const context = new BufferReaderContext(bb.bytes(), dictionaries);\n\n    for (const message of readMessages(bb, footer!)) {\n\n        let id: string;\n        let field: Field;\n        let vector: Vector;\n        let vectors: Array<Vector>;\n\n        context.message = message;\n\n        if (message.headerType() === MessageHeader.DictionaryBatch) {\n            let batch: DictionaryBatch;\n            if (batch = message.header(new DictionaryBatch())!) {\n                context.batch = batch.data()!;\n                id = batch.id().toFloat64().toString();\n                field = dictionaryEncodedFields.get(id)!;\n                vector = readValueVector(field, context);\n                if (batch.isDelta() && dictionaries.has(id)) {\n                    vector = dictionaries.get(id)!.concat(vector);\n                }\n                dictionaries.set(id, vector);\n            }\n            continue;\n        }\n\n        vectors = new Array<Vector>(fieldsLength);\n        context.batch = message.header(new RecordBatch())!;\n\n        for (let i = -1; ++i < fieldsLength;) {\n            if ((field = schema.fields(i)!) || (vectors[i] = null as any)) {\n                vectors[i] = readVector(field, context);\n            }\n        }\n\n        yield vectors;\n    }\n}\n\nfunction readSchema(bb: ByteBuffer) {\n    let schema: Schema, readMessages, footer = readFileFooter(bb);\n    if (footer) {\n        schema = footer.schema()!;\n        readMessages = readFileMessages;\n    } else if (schema = readStreamSchema(bb)!) {\n        readMessages = readStreamMessages;\n    } else {\n        throw new Error('Invalid Arrow buffer');\n    }\n    return { schema, footer, readMessages, dictionaryEncodedFields: readDictionaryEncodedFields(schema, new Map<string, Field>()) };\n}\n\nfunction readDictionaryEncodedFields(parent: Schema | Field, fields: Map<string, Field>) {\n    let field: Field, encoding: DictionaryEncoding, id: string;\n    let getField = parent instanceof Field ? parent.children : parent.fields;\n    let getFieldCount = parent instanceof Field ? parent.childrenLength : parent.fieldsLength;\n    for (let i = -1, n = getFieldCount.call(parent); ++i < n;) {\n        if (field = getField.call(parent, i)!) {\n            if ((encoding = field.dictionary()!) &&\n                (id = encoding.id().toFloat64().toString())) {\n                !fields.has(id) && fields.set(id, field);\n            }\n            readDictionaryEncodedFields(field, fields);\n        }\n    }\n    return fields;\n}\n\nfunction toByteBuffer(bytes?: Uint8Array | Buffer | string) {\n    let arr: Uint8Array = bytes as any || new Uint8Array(0);\n    if (typeof bytes === 'string') {\n        arr = new Uint8Array(bytes.length);\n        for (let i = -1, n = bytes.length; ++i < n;) {\n            arr[i] = bytes.charCodeAt(i);\n        }\n        return new ByteBuffer(arr);\n    }\n    return new ByteBuffer(arr);\n}\n\nclass BufferReaderContext implements VectorReaderContext {\n    public offset: number;\n    public batch: RecordBatch;\n    private nodeIndex: number;\n    private bufferIndex: number;\n    private metadataVersion: MetadataVersion;\n    constructor(public bytes: Uint8Array,\n                public dictionaries: Map<string, Vector>) {\n    }\n    set message(m: Message) {\n        this.nodeIndex = 0;\n        this.bufferIndex = 0;\n        this.offset = m.bb.position();\n        this.metadataVersion = m.version();\n    }\n    public readNextNode() {\n        return this.batch.nodes(this.nodeIndex++)!;\n    }\n    public readNextBuffer() {\n        const buffer = this.batch.buffers(this.bufferIndex++)!;\n        // If this Arrow buffer was written before version 4,\n        // advance the buffer's bb_pos 8 bytes to skip past\n        // the now-removed page id field.\n        if (this.metadataVersion < MetadataVersion[`V4`]) {\n            buffer.bb_pos += (8 * this.bufferIndex);\n        }\n        return buffer;\n    }\n}"]} |
@@ -1,5 +0,21 @@ | ||
import { MessageBatch } from './message'; | ||
import { VectorReaderContext } from './arrow'; | ||
import * as Schema_ from '../format/Schema'; | ||
import { IteratorState, Dictionaries } from './arrow'; | ||
import { Vector, BoolVector, BinaryVector, DictionaryVector, Int8Vector, Int16Vector, Int32Vector, Uint8Vector, Uint16Vector, Uint32Vector, Utf8Vector, ListVector, FixedSizeListVector, StructVector, Float16Vector, Float32Vector, Float64Vector, DecimalVector, Date32Vector, Time32Vector, Time64Vector, TimestampVector } from '../vector/arrow'; | ||
import Field = Schema_.org.apache.arrow.flatbuf.Field; | ||
export declare function readVector(field: Field, batch: MessageBatch, state: IteratorState, dictionaries: Dictionaries): any; | ||
export declare function readVector(field: Field, state: VectorReaderContext): Vector<any>; | ||
export declare function readDictionaryVector(field: Field, state: VectorReaderContext): DictionaryVector | null; | ||
export declare function readValueVector(field: Field, state: VectorReaderContext): Vector; | ||
export declare function readNullVector(): Vector<any>; | ||
export declare function readBoolVector(field: Field, state: VectorReaderContext): BoolVector; | ||
export declare function readDateVector(field: Field, state: VectorReaderContext): Date32Vector; | ||
export declare function readTimeVector(field: Field, state: VectorReaderContext): Time32Vector | Time64Vector; | ||
export declare function readTimestampVector(field: Field, state: VectorReaderContext): TimestampVector; | ||
export declare function readListVector(field: Field, state: VectorReaderContext): ListVector; | ||
export declare function readStructVector(field: Field, state: VectorReaderContext): StructVector; | ||
export declare function readBinaryVector(field: Field, state: VectorReaderContext): BinaryVector; | ||
export declare function readDecimalVector(field: Field, state: VectorReaderContext): DecimalVector; | ||
export declare function readUtf8Vector(field: Field, state: VectorReaderContext): Utf8Vector; | ||
export declare function readFixedSizeListVector(field: Field, state: VectorReaderContext): FixedSizeListVector; | ||
export declare function readFixedSizeBinaryVector(field: Field, state: VectorReaderContext): FixedSizeListVector; | ||
export declare function readFloatVector(field: Field, state: VectorReaderContext): Float16Vector | Float32Vector | Float64Vector; | ||
export declare function readIntVector(field: Field, state: VectorReaderContext): Int8Vector | Int16Vector | Int32Vector | Uint8Vector | Uint16Vector | Uint32Vector; |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -18,180 +19,231 @@ // or more contributor license agreements. See the NOTICE file | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
const flatbuffers_1 = require("flatbuffers"); | ||
const Schema_ = require("../format/Schema"); | ||
const struct_1 = require("../vector/struct"); | ||
const dictionary_1 = require("../vector/dictionary"); | ||
const list_1 = require("../vector/list"); | ||
const typed_1 = require("../vector/typed"); | ||
const arrow_1 = require("../vector/arrow"); | ||
var Int = Schema_.org.apache.arrow.flatbuf.Int; | ||
var Date = Schema_.org.apache.arrow.flatbuf.Date; | ||
var Time = Schema_.org.apache.arrow.flatbuf.Time; | ||
var Type = Schema_.org.apache.arrow.flatbuf.Type; | ||
var Decimal = Schema_.org.apache.arrow.flatbuf.Decimal; | ||
var DateUnit = Schema_.org.apache.arrow.flatbuf.DateUnit; | ||
var TimeUnit = Schema_.org.apache.arrow.flatbuf.TimeUnit; | ||
// import Interval = Schema_.org.apache.arrow.flatbuf.Interval; | ||
var Timestamp = Schema_.org.apache.arrow.flatbuf.Timestamp; | ||
// import IntervalUnit = Schema_.org.apache.arrow.flatbuf.IntervalUnit; | ||
var Precision = Schema_.org.apache.arrow.flatbuf.Precision; | ||
var VectorType = Schema_.org.apache.arrow.flatbuf.VectorType; | ||
var VectorLayout = Schema_.org.apache.arrow.flatbuf.VectorLayout; | ||
var FixedSizeList = Schema_.org.apache.arrow.flatbuf.FixedSizeList; | ||
var FloatingPoint = Schema_.org.apache.arrow.flatbuf.FloatingPoint; | ||
function readVector(field, batch, state, dictionaries) { | ||
return readDictionaryVector(field, batch, state, dictionaries) || | ||
readTypedVector(field, batch, state, dictionaries); | ||
var FixedSizeBinary = Schema_.org.apache.arrow.flatbuf.FixedSizeBinary; | ||
function readVector(field, state) { | ||
return readDictionaryVector(field, state) || readValueVector(field, state); | ||
} | ||
exports.readVector = readVector; | ||
function readTypedVector(field, batch, iterator, dictionaries) { | ||
let typeType = field.typeType(), readTyped = typedVectorReaders[typeType]; | ||
if (!readTyped) { | ||
throw new Error('Unrecognized vector name "' + Type[typeType] + '" type "' + typeType + '"'); | ||
/* a dictionary index defaults to signed 32 bit int if unspecified */ | ||
const defaultDictionaryIndexType = { bitWidth: () => 32, isSigned: () => true }; | ||
const intVectors = [ | ||
[/* unsigned */ [arrow_1.Uint8Vector, Uint8Array], /* signed */ [arrow_1.Int8Vector, Int8Array]], | ||
[/* unsigned */ [arrow_1.Uint16Vector, Uint16Array], /* signed */ [arrow_1.Int16Vector, Int16Array]], | ||
[/* unsigned */ [arrow_1.Uint32Vector, Uint32Array], /* signed */ [arrow_1.Int32Vector, Int32Array]], , | ||
[/* unsigned */ [arrow_1.Uint64Vector, Uint32Array], /* signed */ [arrow_1.Int64Vector, Int32Array]] | ||
]; | ||
function readDictionaryVector(field, state) { | ||
const encoding = field.dictionary(); | ||
if (encoding) { | ||
const type = encoding.indexType() || defaultDictionaryIndexType; | ||
const data = state.dictionaries.get(encoding.id().toFloat64().toString()); | ||
const [IntVector, IntArray] = intVectors[type.bitWidth() >>> 4][+type.isSigned()]; | ||
const { fieldNode, validity, data: keys } = readNumericBuffers(field, state, IntArray); | ||
return new arrow_1.DictionaryVector({ | ||
validity, data, field, fieldNode, | ||
keys: new IntVector({ field, fieldNode, data: keys }) | ||
}); | ||
} | ||
return readTyped(field, batch, iterator, dictionaries); | ||
return null; | ||
} | ||
function readDictionaryVector(field, batch, iterator, dictionaries) { | ||
let encoding; | ||
if (dictionaries && (encoding = field.dictionary())) { | ||
let id = encoding.id().toFloat64().toString(); | ||
let fieldType = encoding.indexType() || | ||
/* a dictionary index defaults to signed 32 bit int if unspecified */ | ||
{ bitWidth: () => 32, isSigned: () => true }; | ||
let indexField = createSyntheticDictionaryIndexField(field, fieldType); | ||
let index = readIntVector(indexField, batch, iterator, null, fieldType); | ||
return dictionary_1.DictionaryVector.create(field, index.length, index, dictionaries[id]); | ||
exports.readDictionaryVector = readDictionaryVector; | ||
function readValueVector(field, state) { | ||
switch (field.typeType()) { | ||
case Type.NONE: return readNullVector(); | ||
case Type.Null: return readNullVector(); | ||
// case Type.Map: return readMapVector(field, state); | ||
case Type.Int: return readIntVector(field, state); | ||
case Type.Bool: return readBoolVector(field, state); | ||
case Type.Date: return readDateVector(field, state); | ||
case Type.List: return readListVector(field, state); | ||
case Type.Utf8: return readUtf8Vector(field, state); | ||
case Type.Time: return readTimeVector(field, state); | ||
// case Type.Union: return readUnionVector(field, state); | ||
case Type.Binary: return readBinaryVector(field, state); | ||
case Type.Decimal: return readDecimalVector(field, state); | ||
case Type.Struct_: return readStructVector(field, state); | ||
case Type.FloatingPoint: return readFloatVector(field, state); | ||
case Type.Timestamp: return readTimestampVector(field, state); | ||
case Type.FixedSizeList: return readFixedSizeListVector(field, state); | ||
case Type.FixedSizeBinary: return readFixedSizeBinaryVector(field, state); | ||
} | ||
throw new Error(`Unrecognized Vector { name: ${Type[field.typeType()]}, type: ${field.typeType()} }`); | ||
} | ||
const IntViews = [Int8Array, Int16Array, Int32Array, Int32Array]; | ||
const Int32Views = [Int32Array, Int32Array, Int32Array, Int32Array]; | ||
const UintViews = [Uint8Array, Uint16Array, Uint32Array, Uint32Array]; | ||
const Uint8Views = [Uint8Array, Uint8Array, Uint8Array, Uint8Array]; | ||
const Uint32Views = [Uint32Array, Uint32Array, Uint32Array, Uint32Array]; | ||
const FloatViews = [Int8Array, Int16Array, Float32Array, Float64Array]; | ||
const createIntDataViews = createDataView.bind(null, IntViews, null); | ||
const createUintDataViews = createDataView.bind(null, UintViews, null); | ||
const createDateDataViews = createDataView.bind(null, Uint32Views, null); | ||
const createFloatDataViews = createDataView.bind(null, FloatViews, null); | ||
const createNestedDataViews = createDataView.bind(null, Uint32Views, null); | ||
const createValidityDataViews = createDataView.bind(null, Uint8Views, null); | ||
const createUtf8DataViews = createDataView.bind(null, Uint8Views, Int32Views); | ||
const floatVectors = { | ||
[Precision.SINGLE]: typed_1.Float32Vector, | ||
[Precision.DOUBLE]: typed_1.Float64Vector | ||
}; | ||
const intVectors = [ | ||
[/* unsigned */ typed_1.Uint8Vector, /* signed */ typed_1.Int8Vector], | ||
[/* unsigned */ typed_1.Uint16Vector, /* signed */ typed_1.Int16Vector], | ||
[/* unsigned */ typed_1.Uint32Vector, /* signed */ typed_1.Int32Vector], | ||
[/* unsigned */ typed_1.Uint64Vector, /* signed */ typed_1.Int64Vector] | ||
]; | ||
function readIntVector(field, batch, iterator, dictionaries, fieldType) { | ||
let type = (fieldType || field.type(new Int())); | ||
return type.isSigned() ? | ||
read_IntVector(field, batch, iterator, dictionaries, type) : | ||
readUintVector(field, batch, iterator, dictionaries, type); | ||
exports.readValueVector = readValueVector; | ||
function readNullVector() { | ||
return new arrow_1.Vector(); | ||
} | ||
const read_IntVector = readVectorLayout(createIntDataViews, createIntVector); | ||
const readUintVector = readVectorLayout(createUintDataViews, createIntVector); | ||
function createIntVector(field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) { | ||
let type = fieldType || field.type(new Int()), bitWidth = type.bitWidth(); | ||
let Vector = valueForBitWidth(bitWidth, intVectors)[+type.isSigned()]; | ||
return Vector.create(field, length, validity, data || offsets); | ||
// ---------------------- so this is kinda strange 👆: | ||
// The dictionary encoded vectors I generated from sample mapd-core queries have the indicies' data buffers | ||
// tagged as VectorType.OFFSET (0) in the field metadata. The current TS impl ignores buffers' layout type, | ||
// and assumes the second buffer is the data for a NullableIntVector. Since we've been stricter about enforcing | ||
// the Arrow spec while parsing, the IntVector's data buffer reads empty in this case. If so, fallback to using | ||
// the offsets buffer as the data, since IntVectors don't have offsets. | ||
exports.readNullVector = readNullVector; | ||
function readBoolVector(field, state) { | ||
return new arrow_1.BoolVector(readNumericBuffers(field, state, Uint8Array)); | ||
} | ||
const readFloatVector = readVectorLayout(createFloatDataViews, (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => { | ||
let type = field.type(new FloatingPoint()); | ||
let Vector = floatVectors[type.precision()]; | ||
return Vector.create(field, length, validity, data); | ||
}); | ||
const readDateVector = readVectorLayout(createDateDataViews, (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => { | ||
return typed_1.DateVector.create(field, length, validity, data); | ||
}); | ||
const readUtf8Vector = readVectorLayout(createUtf8DataViews, (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => { | ||
let offsetsAdjusted = new Int32Array(offsets.buffer, offsets.byteOffset, length + 1); | ||
return list_1.Utf8Vector.create(field, length, validity, typed_1.Uint8Vector.create(field, data.length, null, data), typed_1.IndexVector.create(field, length + 1, null, offsetsAdjusted)); | ||
}); | ||
const readListVector = readVectorLayout(createNestedDataViews, (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => { | ||
let offsetsAdjusted = new Int32Array(offsets.buffer, offsets.byteOffset, length + 1); | ||
return list_1.ListVector.create(field, length, validity, readVector(field.children(0), batch, iterator, dictionaries), typed_1.IndexVector.create(field, length + 1, null, offsetsAdjusted)); | ||
}); | ||
const readFixedSizeListVector = readVectorLayout(createNestedDataViews, (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => { | ||
let size = field.type(new FixedSizeList()).listSize(); | ||
return list_1.FixedSizeListVector.create(field, length, size, validity, readVector(field.children(0), batch, iterator, dictionaries)); | ||
}); | ||
const readStructVector = readVectorLayout(createNestedDataViews, (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => { | ||
let vectors = []; | ||
for (let i = -1, n = field.childrenLength(); ++i < n;) { | ||
vectors[i] = readVector(field.children(i), batch, iterator, dictionaries); | ||
exports.readBoolVector = readBoolVector; | ||
function readDateVector(field, state) { | ||
const type = field.type(new Date()); | ||
switch (type.unit()) { | ||
case DateUnit.DAY: return new arrow_1.Date32Vector({ ...readNumericBuffers(field, state, Int32Array), unit: DateUnit[type.unit()] }); | ||
case DateUnit.MILLISECOND: return new arrow_1.Date64Vector({ ...readNumericBuffers(field, state, Int32Array), unit: DateUnit[type.unit()] }); | ||
} | ||
return struct_1.StructVector.create(field, length, validity, ...vectors); | ||
}); | ||
const typedVectorReaders = { | ||
[Type.Int]: readIntVector, | ||
[Type.Date]: readDateVector, | ||
[Type.List]: readListVector, | ||
[Type.Utf8]: readUtf8Vector, | ||
[Type.Struct_]: readStructVector, | ||
[Type.FloatingPoint]: readFloatVector, | ||
[Type.FixedSizeList]: readFixedSizeListVector, | ||
}; | ||
function readVectorLayout(createDataView, createVector) { | ||
return function readLayout(field, chunk, iterator, dictionaries, integerFieldType) { | ||
let batch = chunk.data; | ||
let layoutLength = field.layoutLength(); | ||
let node = batch.nodes(iterator.nodeIndex++); | ||
let data, offsets, validity; | ||
let type, bitWidth, bufferLength, nodeLength = node.length().low; | ||
for (let i = -1; ++i < layoutLength;) { | ||
let layout = field.layout(i); | ||
let buffer = batch.buffers(iterator.bufferIndex++); | ||
if ((type = layout.type()) === VectorType.TYPE || | ||
(bufferLength = buffer.length().low) <= 0 || | ||
(bitWidth = layout.bitWidth()) <= 0) { | ||
continue; | ||
} | ||
else if (type === VectorType.DATA) { | ||
data = createDataView(chunk, type, bitWidth, buffer.offset().low, bufferLength); | ||
} | ||
else if (type === VectorType.OFFSET) { | ||
offsets = createDataView(chunk, type, bitWidth, buffer.offset().low, bufferLength); | ||
} | ||
else if (node.nullCount().low > 0) { | ||
validity = createValidityDataViews(chunk, type, bitWidth, buffer.offset().low, nodeLength); | ||
} | ||
} | ||
return createVector(field, nodeLength, data, validity, offsets, integerFieldType, chunk, iterator, dictionaries); | ||
}; | ||
throw new Error(`Unrecognized Date { unit: ${type.unit()} }`); | ||
} | ||
function createDataView(dataViews, offsetViews, batch, type, bitWidth, offset, length) { | ||
const buffer = batch.bytes.buffer; | ||
const byteLength = buffer.byteLength; | ||
const byteOffset = batch.offset + offset; | ||
const DataViewType = valueForBitWidth(bitWidth, type === VectorType.OFFSET && offsetViews || dataViews); | ||
const dataViewLength = ((byteOffset + length) <= byteLength | ||
? length | ||
: byteLength - byteOffset) / DataViewType['BYTES_PER_ELEMENT']; | ||
return new DataViewType(buffer, byteOffset, dataViewLength); | ||
exports.readDateVector = readDateVector; | ||
function readTimeVector(field, state) { | ||
const type = field.type(new Time()); | ||
switch (type.bitWidth()) { | ||
case 32: return new arrow_1.Time32Vector({ ...readNumericBuffers(field, state, Int32Array), unit: TimeUnit[type.unit()] }); | ||
case 64: return new arrow_1.Time64Vector({ ...readNumericBuffers(field, state, Uint32Array), unit: TimeUnit[type.unit()] }); | ||
} | ||
throw new Error(`Unrecognized Time { unit: ${type.unit()}, bitWidth: ${type.bitWidth()} }`); | ||
} | ||
function valueForBitWidth(bitWidth, values) { | ||
return values[bitWidth >> 4] || values[3]; | ||
exports.readTimeVector = readTimeVector; | ||
function readTimestampVector(field, state) { | ||
const type = field.type(new Timestamp()); | ||
const { fieldNode, validity, data } = readNumericBuffers(field, state, Uint32Array); | ||
return new arrow_1.TimestampVector({ | ||
field, fieldNode, validity, data, | ||
timezone: type.timezone(), | ||
unit: TimeUnit[type.unit()], | ||
}); | ||
} | ||
function createSyntheticDictionaryIndexField(field, type) { | ||
let layouts = []; | ||
let builder = new flatbuffers_1.flatbuffers.Builder(); | ||
if (field.nullable()) { | ||
VectorLayout.startVectorLayout(builder); | ||
VectorLayout.addBitWidth(builder, 8); | ||
VectorLayout.addType(builder, VectorType.VALIDITY); | ||
builder.finish(VectorLayout.endVectorLayout(builder)); | ||
layouts.push(VectorLayout.getRootAsVectorLayout(builder.dataBuffer())); | ||
builder = new flatbuffers_1.flatbuffers.Builder(); | ||
exports.readTimestampVector = readTimestampVector; | ||
function readListVector(field, state) { | ||
const { fieldNode, validity, offsets } = readListBuffers(field, state); | ||
return new arrow_1.ListVector({ | ||
field, fieldNode, validity, offsets, | ||
values: readVector(field.children(0), state) | ||
}); | ||
} | ||
exports.readListVector = readListVector; | ||
function readStructVector(field, state) { | ||
const n = field.childrenLength(); | ||
const columns = new Array(n); | ||
const fieldNode = state.readNextNode(); | ||
const validity = readValidityBuffer(field, fieldNode, state); | ||
for (let i = -1, child; ++i < n;) { | ||
if (child = field.children(i)) { | ||
columns[i] = readVector(child, state); | ||
} | ||
} | ||
VectorLayout.startVectorLayout(builder); | ||
VectorLayout.addBitWidth(builder, type.bitWidth()); | ||
VectorLayout.addType(builder, VectorType.DATA); | ||
builder.finish(VectorLayout.endVectorLayout(builder)); | ||
layouts.push(VectorLayout.getRootAsVectorLayout(builder.dataBuffer())); | ||
return Object.create(field, { | ||
layout: { value(i) { return layouts[i]; } }, | ||
layoutLength: { value() { return layouts.length; } } | ||
return new arrow_1.StructVector({ field, fieldNode, validity, columns }); | ||
} | ||
exports.readStructVector = readStructVector; | ||
function readBinaryVector(field, state) { | ||
return new arrow_1.BinaryVector(readBinaryBuffers(field, state)); | ||
} | ||
exports.readBinaryVector = readBinaryVector; | ||
function readDecimalVector(field, state) { | ||
const type = field.type(new Decimal()); | ||
const { fieldNode, validity, data } = readNumericBuffers(field, state, Uint32Array); | ||
return new arrow_1.DecimalVector({ | ||
scale: type.scale(), | ||
precision: type.precision(), | ||
field, fieldNode, validity, data | ||
}); | ||
} | ||
exports.readDecimalVector = readDecimalVector; | ||
function readUtf8Vector(field, state) { | ||
const { fieldNode, validity, offsets, data } = readBinaryBuffers(field, state); | ||
return new arrow_1.Utf8Vector({ | ||
field, fieldNode, | ||
values: new arrow_1.BinaryVector({ | ||
validity, offsets, data | ||
}) | ||
}); | ||
} | ||
exports.readUtf8Vector = readUtf8Vector; | ||
function readFixedSizeListVector(field, state) { | ||
const type = field.type(new FixedSizeList()); | ||
const fieldNode = state.readNextNode(); | ||
const validity = readValidityBuffer(field, fieldNode, state); | ||
return new arrow_1.FixedSizeListVector({ | ||
field, fieldNode, validity, | ||
size: type.listSize(), | ||
values: readVector(field.children(0), state) | ||
}); | ||
} | ||
exports.readFixedSizeListVector = readFixedSizeListVector; | ||
function readFixedSizeBinaryVector(field, state) { | ||
const type = field.type(new FixedSizeBinary()); | ||
const { fieldNode, validity, data } = readNumericBuffers(field, state, Uint8Array); | ||
return new arrow_1.FixedSizeListVector({ | ||
size: type.byteWidth(), | ||
field, fieldNode, validity, | ||
values: new arrow_1.Uint8Vector({ data }) | ||
}); | ||
} | ||
exports.readFixedSizeBinaryVector = readFixedSizeBinaryVector; | ||
function readFloatVector(field, state) { | ||
const type = field.type(new FloatingPoint()); | ||
switch (type.precision()) { | ||
case Precision.HALF: return new arrow_1.Float16Vector(readNumericBuffers(field, state, Uint16Array)); | ||
case Precision.SINGLE: return new arrow_1.Float32Vector(readNumericBuffers(field, state, Float32Array)); | ||
case Precision.DOUBLE: return new arrow_1.Float64Vector(readNumericBuffers(field, state, Float64Array)); | ||
} | ||
throw new Error(`Unrecognized FloatingPoint { precision: ${type.precision()} }`); | ||
} | ||
exports.readFloatVector = readFloatVector; | ||
function readIntVector(field, state) { | ||
const type = field.type(new Int()); | ||
if (type.isSigned()) { | ||
switch (type.bitWidth()) { | ||
case 8: return new arrow_1.Int8Vector(readNumericBuffers(field, state, Int8Array)); | ||
case 16: return new arrow_1.Int16Vector(readNumericBuffers(field, state, Int16Array)); | ||
case 32: return new arrow_1.Int32Vector(readNumericBuffers(field, state, Int32Array)); | ||
case 64: return new arrow_1.Int64Vector(readNumericBuffers(field, state, Int32Array)); | ||
} | ||
} | ||
switch (type.bitWidth()) { | ||
case 8: return new arrow_1.Uint8Vector(readNumericBuffers(field, state, Uint8Array)); | ||
case 16: return new arrow_1.Uint16Vector(readNumericBuffers(field, state, Uint16Array)); | ||
case 32: return new arrow_1.Uint32Vector(readNumericBuffers(field, state, Uint32Array)); | ||
case 64: return new arrow_1.Uint64Vector(readNumericBuffers(field, state, Uint32Array)); | ||
} | ||
throw new Error(`Unrecognized Int { isSigned: ${type.isSigned()}, bitWidth: ${type.bitWidth()} }`); | ||
} | ||
exports.readIntVector = readIntVector; | ||
function readListBuffers(field, state) { | ||
const fieldNode = state.readNextNode(); | ||
const validity = readValidityBuffer(field, fieldNode, state); | ||
const offsets = readDataBuffer(Int32Array, state); | ||
return { field, fieldNode, validity, offsets }; | ||
} | ||
function readBinaryBuffers(field, state) { | ||
const fieldNode = state.readNextNode(); | ||
const validity = readValidityBuffer(field, fieldNode, state); | ||
const offsets = readDataBuffer(Int32Array, state); | ||
const data = readDataBuffer(Uint8Array, state); | ||
return { field, fieldNode, validity, offsets, data }; | ||
} | ||
function readNumericBuffers(field, state, ArrayConstructor) { | ||
const fieldNode = state.readNextNode(); | ||
const validity = readValidityBuffer(field, fieldNode, state); | ||
const data = readDataBuffer(ArrayConstructor, state); | ||
return { field, fieldNode, validity, data }; | ||
} | ||
function readDataBuffer(ArrayConstructor, state) { | ||
return createTypedArray(ArrayConstructor, state.bytes, state.offset, state.readNextBuffer()); | ||
} | ||
function readValidityBuffer(field, fieldNode, state) { | ||
return createValidityArray(field, fieldNode, state.bytes, state.offset, state.readNextBuffer()); | ||
} | ||
function createValidityArray(field, fieldNode, bytes, offset, buffer) { | ||
return field.nullable() && fieldNode.nullCount().low > 0 && createTypedArray(Uint8Array, bytes, offset, buffer) || null; | ||
} | ||
function createTypedArray(ArrayConstructor, bytes, offset, buffer) { | ||
return new ArrayConstructor(bytes.buffer, bytes.byteOffset + offset + buffer.offset().low, buffer.length().low / ArrayConstructor.BYTES_PER_ELEMENT); | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["reader/vector.ts"],"names":[],"mappings":"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","file":"reader/vector.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { flatbuffers } from 'flatbuffers';\nimport { MessageBatch } from './message';\nimport { Vector } from '../vector/vector';\nimport * as Schema_ from '../format/Schema';\nimport { StructVector } from '../vector/struct';\nimport { IteratorState, Dictionaries } from './arrow';\nimport { DictionaryVector } from '../vector/dictionary';\nimport { Utf8Vector, ListVector, FixedSizeListVector } from '../vector/list';\nimport {\n    TypedArray, TypedArrayCtor, IntArray, FloatArray,\n    Int8Vector, Int16Vector, Int32Vector, Int64Vector,\n    Uint8Vector, Uint16Vector, Uint32Vector, Uint64Vector,\n    Float32Vector, Float64Vector, IndexVector, DateVector,\n} from '../vector/typed';\n\nimport Int = Schema_.org.apache.arrow.flatbuf.Int;\nimport Type = Schema_.org.apache.arrow.flatbuf.Type;\nimport Field = Schema_.org.apache.arrow.flatbuf.Field;\nimport Precision = Schema_.org.apache.arrow.flatbuf.Precision;\nimport VectorType = Schema_.org.apache.arrow.flatbuf.VectorType;\nimport VectorLayout = Schema_.org.apache.arrow.flatbuf.VectorLayout;\nimport FixedSizeList = Schema_.org.apache.arrow.flatbuf.FixedSizeList;\nimport FloatingPoint = Schema_.org.apache.arrow.flatbuf.FloatingPoint;\nimport DictionaryEncoding = Schema_.org.apache.arrow.flatbuf.DictionaryEncoding;\n\nexport function readVector(field: Field, batch: MessageBatch, state: IteratorState, dictionaries: Dictionaries) {\n    return readDictionaryVector(field, batch, state, dictionaries) ||\n                readTypedVector(field, batch, state, dictionaries);\n}\n\nfunction readTypedVector(field: Field, batch: MessageBatch, iterator: IteratorState, dictionaries: Dictionaries) {\n    let typeType = field.typeType(), readTyped = typedVectorReaders[typeType];\n    if (!readTyped) {\n        throw new Error('Unrecognized vector name \"' + Type[typeType] + '\" type \"' + typeType + '\"');\n    }\n    return readTyped(field, batch, iterator, dictionaries);\n}\n\nfunction readDictionaryVector(field: Field, batch: MessageBatch, iterator: IteratorState, dictionaries: Dictionaries) {\n    let encoding: DictionaryEncoding;\n    if (dictionaries && (encoding = field.dictionary())) {\n        let id = encoding.id().toFloat64().toString();\n        let fieldType =  encoding.indexType() ||\n            /* a dictionary index defaults to signed 32 bit int if unspecified */\n            { bitWidth: () => 32, isSigned: () => true };\n        let indexField = createSyntheticDictionaryIndexField(field, fieldType);\n        let index = readIntVector(indexField, batch, iterator, null, fieldType);\n        return DictionaryVector.create(field, index.length, index, dictionaries[id]);\n    }\n}\n\nconst IntViews    = [Int8Array,    Int16Array,   Int32Array,   Int32Array  ];\nconst Int32Views  = [Int32Array,   Int32Array,   Int32Array,   Int32Array  ];\nconst UintViews   = [Uint8Array,   Uint16Array,  Uint32Array,  Uint32Array ];\nconst Uint8Views  = [Uint8Array,   Uint8Array,   Uint8Array,   Uint8Array  ];\nconst Uint32Views = [Uint32Array,  Uint32Array,  Uint32Array,  Uint32Array ];\nconst FloatViews  = [Int8Array,    Int16Array,   Float32Array, Float64Array];\n\nconst createIntDataViews = createDataView.bind(null, IntViews, null);\nconst createUintDataViews = createDataView.bind(null, UintViews, null);\nconst createDateDataViews = createDataView.bind(null, Uint32Views, null);\nconst createFloatDataViews = createDataView.bind(null, FloatViews, null);\nconst createNestedDataViews = createDataView.bind(null, Uint32Views, null);\nconst createValidityDataViews = createDataView.bind(null, Uint8Views, null);\nconst createUtf8DataViews = createDataView.bind(null, Uint8Views, Int32Views);\n\nconst floatVectors = {\n    [Precision.SINGLE]: Float32Vector,\n    [Precision.DOUBLE]: Float64Vector\n};\nconst intVectors = [\n    [/* unsigned */ Uint8Vector,   /* signed */ Int8Vector ],\n    [/* unsigned */ Uint16Vector,  /* signed */ Int16Vector],\n    [/* unsigned */ Uint32Vector,  /* signed */ Int32Vector],\n    [/* unsigned */ Uint64Vector,  /* signed */ Int64Vector]\n];\n\nfunction readIntVector(field: Field, batch: MessageBatch, iterator: IteratorState, dictionaries: Dictionaries, fieldType?: FieldType) {\n    let type = (fieldType || field.type(new Int()));\n    return type.isSigned() ?\n        read_IntVector(field, batch, iterator, dictionaries, type) :\n        readUintVector(field, batch, iterator, dictionaries, type);\n}\n\nconst read_IntVector = readVectorLayout<number, IntArray>(createIntDataViews, createIntVector);\nconst readUintVector = readVectorLayout<number, IntArray>(createUintDataViews, createIntVector);\nfunction createIntVector(field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) {\n    let type = fieldType || field.type(new Int()), bitWidth = type.bitWidth();\n    let Vector = valueForBitWidth(bitWidth, intVectors)[+type.isSigned()];\n    return Vector.create(field, length, validity, data || offsets);\n    // ---------------------- so this is kinda strange 👆:\n    // The dictionary encoded vectors I generated from sample mapd-core queries have the indicies' data buffers\n    // tagged as VectorType.OFFSET (0) in the field metadata. The current TS impl ignores buffers' layout type,\n    // and assumes the second buffer is the data for a NullableIntVector. Since we've been stricter about enforcing\n    // the Arrow spec while parsing, the IntVector's data buffer reads empty in this case. If so, fallback to using\n    // the offsets buffer as the data, since IntVectors don't have offsets.\n}\n\nconst readFloatVector = readVectorLayout<number, FloatArray>(\n    createFloatDataViews,\n    (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => {\n        let type = field.type(new FloatingPoint());\n        let Vector = floatVectors[type.precision()];\n        return Vector.create(field, length, validity, data);\n    }\n);\n\nconst readDateVector = readVectorLayout<Date, Uint32Array>(\n    createDateDataViews,\n    (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => {\n        return DateVector.create(field, length, validity, data);\n    }\n);\n\nconst readUtf8Vector = readVectorLayout<string, Uint8Array>(\n    createUtf8DataViews,\n    (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => {\n        let offsetsAdjusted = new Int32Array(offsets.buffer, offsets.byteOffset, length + 1);\n        return Utf8Vector.create(\n            field, length, validity,\n            Uint8Vector.create(field, data.length, null, data),\n            IndexVector.create(field, length + 1, null, offsetsAdjusted)\n        );\n    }\n);\n\nconst readListVector = readVectorLayout<any[], Uint32Array>(\n    createNestedDataViews,\n    (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => {\n        let offsetsAdjusted = new Int32Array(offsets.buffer, offsets.byteOffset, length + 1);\n        return ListVector.create(\n            field, length, validity,\n            readVector(field.children(0), batch, iterator, dictionaries),\n            IndexVector.create(field, length + 1, null, offsetsAdjusted)\n        );\n    }\n);\n\nconst readFixedSizeListVector = readVectorLayout<any[], Uint32Array>(\n    createNestedDataViews,\n    (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => {\n        let size = field.type(new FixedSizeList()).listSize();\n        return FixedSizeListVector.create(\n            field, length, size, validity,\n            readVector(field.children(0), batch, iterator, dictionaries)\n        );\n    }\n);\n\nconst readStructVector = readVectorLayout<any[], ArrayLike<any>>(\n    createNestedDataViews,\n    (field, length, data, validity, offsets, fieldType, batch, iterator, dictionaries) => {\n        let vectors: Vector<any>[] = [];\n        for (let i = -1, n = field.childrenLength(); ++i < n;) {\n            vectors[i] = readVector(field.children(i), batch, iterator, dictionaries);\n        }\n        return StructVector.create(field, length, validity, ...vectors);\n    }\n);\n\nconst typedVectorReaders = {\n    [Type.Int]: readIntVector,\n    [Type.Date]: readDateVector,\n    [Type.List]: readListVector,\n    [Type.Utf8]: readUtf8Vector,\n    [Type.Struct_]: readStructVector,\n    [Type.FloatingPoint]: readFloatVector,\n    [Type.FixedSizeList]: readFixedSizeListVector,\n};\n\ntype FieldType = { bitWidth(): number; isSigned(): boolean };\ntype dataViewFactory<V = TypedArray> = (batch: MessageBatch, type: VectorType, bitWidth: number, offset: number, length: number) => V;\ntype vectorFactory<TList, V = Vector<any>> = (field: Field,\n                                              length: number,\n                                              data: TList,\n                                              nulls: Uint8Array,\n                                              offsets: TypedArray,\n                                              fieldType: FieldType,\n                                              chunk: MessageBatch,\n                                              iterable: IteratorState,\n                                              dictionaries: Dictionaries) => V;\n\nfunction readVectorLayout<T, TList>(createDataView: dataViewFactory<TList>, createVector: vectorFactory<TList, Vector<T>>) {\n    return function readLayout(\n            field: Field,\n            chunk: MessageBatch,\n            iterator: IteratorState,\n            dictionaries: Dictionaries,\n            integerFieldType?: FieldType\n    ) {\n        let batch = chunk.data;\n        let layoutLength = field.layoutLength();\n        let node = batch.nodes(iterator.nodeIndex++);\n        let data: TList, offsets: any, validity: Uint8Array;\n        let type, bitWidth, bufferLength, nodeLength = node.length().low;\n        for (let i = -1; ++i < layoutLength;) {\n            let layout = field.layout(i);\n            let buffer = batch.buffers(iterator.bufferIndex++);\n            if ((type = layout.type()) === VectorType.TYPE ||\n                (bufferLength = buffer.length().low) <= 0  ||\n                (bitWidth = layout.bitWidth()) <= 0) {\n                continue;\n            } else if (type === VectorType.DATA) {\n                data = createDataView(chunk, type, bitWidth, buffer.offset().low, bufferLength);\n            } else if (type === VectorType.OFFSET) {\n                offsets = createDataView(chunk, type, bitWidth, buffer.offset().low, bufferLength);\n            } else if (node.nullCount().low > 0) {\n                validity = createValidityDataViews(chunk, type, bitWidth, buffer.offset().low, nodeLength);\n            }\n        }\n        return createVector(field, nodeLength, data, validity, offsets, integerFieldType, chunk, iterator, dictionaries);\n    };\n}\n\nfunction createDataView(\n    dataViews: TypedArrayCtor<any>[], offsetViews: TypedArrayCtor<any>[] | null,\n    batch: MessageBatch, type: VectorType, bitWidth: number, offset: number, length: number\n) {\n    const buffer = batch.bytes.buffer;\n    const byteLength = buffer.byteLength;\n    const byteOffset = batch.offset + offset;\n    const DataViewType = valueForBitWidth(bitWidth, type === VectorType.OFFSET && offsetViews || dataViews);\n    const dataViewLength = ((byteOffset + length) <= byteLength\n        ? length\n        : byteLength - byteOffset\n    ) / DataViewType['BYTES_PER_ELEMENT'];\n    return new DataViewType(buffer, byteOffset, dataViewLength);\n}\n\nfunction valueForBitWidth(bitWidth: number, values: any[]) {\n    return values[bitWidth >> 4] || values[3];\n}\n\nfunction createSyntheticDictionaryIndexField(field: Field, type: FieldType) {\n    let layouts = [];\n    let builder = new flatbuffers.Builder();\n    if (field.nullable()) {\n        VectorLayout.startVectorLayout(builder);\n        VectorLayout.addBitWidth(builder, 8);\n        VectorLayout.addType(builder, VectorType.VALIDITY);\n        builder.finish(VectorLayout.endVectorLayout(builder));\n        layouts.push(VectorLayout.getRootAsVectorLayout(builder.dataBuffer()));\n        builder = new flatbuffers.Builder();\n    }\n    VectorLayout.startVectorLayout(builder);\n    VectorLayout.addBitWidth(builder, type.bitWidth());\n    VectorLayout.addType(builder, VectorType.DATA);\n    builder.finish(VectorLayout.endVectorLayout(builder));\n    layouts.push(VectorLayout.getRootAsVectorLayout(builder.dataBuffer()));\n    return Object.create(field, {\n        layout: { value(i) { return layouts[i]; } },\n        layoutLength: { value() { return layouts.length; } }\n    });\n}"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["reader/vector.ts"],"names":[],"mappings":"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","file":"reader/vector.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { VectorReaderContext } from './arrow';\nimport * as Schema_ from '../format/Schema';\nimport * as Message_ from '../format/Message';\nimport { TypedArray, TypedArrayConstructor } from '../vector/types';\nimport {\n    Vector, BoolVector, BinaryVector, DictionaryVector,\n    Int8Vector, Int16Vector, Int32Vector, Int64Vector,\n    Uint8Vector, Uint16Vector, Uint32Vector, Uint64Vector,\n    Utf8Vector, ListVector, FixedSizeListVector, StructVector,\n    Float16Vector, Float32Vector, Float64Vector, DecimalVector,\n    Date32Vector, Date64Vector, Time32Vector, Time64Vector, TimestampVector,\n} from '../vector/arrow';\n\nimport Int = Schema_.org.apache.arrow.flatbuf.Int;\nimport Date = Schema_.org.apache.arrow.flatbuf.Date;\nimport Time = Schema_.org.apache.arrow.flatbuf.Time;\nimport Type = Schema_.org.apache.arrow.flatbuf.Type;\nimport Field = Schema_.org.apache.arrow.flatbuf.Field;\nimport Buffer = Schema_.org.apache.arrow.flatbuf.Buffer;\nimport Decimal = Schema_.org.apache.arrow.flatbuf.Decimal;\nimport DateUnit = Schema_.org.apache.arrow.flatbuf.DateUnit;\nimport TimeUnit = Schema_.org.apache.arrow.flatbuf.TimeUnit;\n// import Interval = Schema_.org.apache.arrow.flatbuf.Interval;\nimport Timestamp = Schema_.org.apache.arrow.flatbuf.Timestamp;\n// import IntervalUnit = Schema_.org.apache.arrow.flatbuf.IntervalUnit;\nimport Precision = Schema_.org.apache.arrow.flatbuf.Precision;\nimport FieldNode = Message_.org.apache.arrow.flatbuf.FieldNode;\nimport FixedSizeList = Schema_.org.apache.arrow.flatbuf.FixedSizeList;\nimport FloatingPoint = Schema_.org.apache.arrow.flatbuf.FloatingPoint;\nimport FixedSizeBinary = Schema_.org.apache.arrow.flatbuf.FixedSizeBinary;\n\nexport function readVector(field: Field, state: VectorReaderContext) {\n    return readDictionaryVector(field, state) || readValueVector(field, state);\n}\n\n/* a dictionary index defaults to signed 32 bit int if unspecified */\nconst defaultDictionaryIndexType = { bitWidth: () => 32, isSigned: () => true } as Int;\nconst intVectors = [\n    [/* unsigned */ [Uint8Vector,  Uint8Array ],  /* signed */ [Int8Vector , Int8Array ]],\n    [/* unsigned */ [Uint16Vector, Uint16Array],  /* signed */ [Int16Vector, Int16Array]],\n    [/* unsigned */ [Uint32Vector, Uint32Array],  /* signed */ [Int32Vector, Int32Array]],,\n    [/* unsigned */ [Uint64Vector, Uint32Array],  /* signed */ [Int64Vector, Int32Array]]\n] as [any, TypedArrayConstructor][][];\n\nexport function readDictionaryVector(field: Field, state: VectorReaderContext) {\n    const encoding = field.dictionary()!;\n    if (encoding) {\n        const type = encoding.indexType() || defaultDictionaryIndexType;\n        const data = state.dictionaries.get(encoding.id().toFloat64().toString())!;\n        const [IntVector, IntArray] = intVectors[type.bitWidth() >>> 4]![+type.isSigned()];\n        const { fieldNode, validity, data: keys } = readNumericBuffers(field, state, IntArray);\n        return new DictionaryVector({\n            validity, data, field, fieldNode,\n            keys: new IntVector({ field, fieldNode, data: keys })\n        });\n    }\n    return null;\n}\n\nexport function readValueVector(field: Field, state: VectorReaderContext): Vector {\n    switch (field.typeType()) {\n        case Type.NONE: return readNullVector();\n        case Type.Null: return readNullVector();\n        // case Type.Map: return readMapVector(field, state);\n        case Type.Int: return readIntVector(field, state);\n        case Type.Bool: return readBoolVector(field, state);\n        case Type.Date: return readDateVector(field, state);\n        case Type.List: return readListVector(field, state);\n        case Type.Utf8: return readUtf8Vector(field, state);\n        case Type.Time: return readTimeVector(field, state);\n        // case Type.Union: return readUnionVector(field, state);\n        case Type.Binary: return readBinaryVector(field, state);\n        case Type.Decimal: return readDecimalVector(field, state);\n        case Type.Struct_: return readStructVector(field, state);\n        case Type.FloatingPoint: return readFloatVector(field, state);\n        case Type.Timestamp: return readTimestampVector(field, state);\n        case Type.FixedSizeList: return readFixedSizeListVector(field, state);\n        case Type.FixedSizeBinary: return readFixedSizeBinaryVector(field, state);\n    }\n    throw new Error(`Unrecognized Vector { name: ${Type[field.typeType()]}, type: ${field.typeType()} }`);\n}\n\nexport function readNullVector() {\n    return new Vector();\n}\n\nexport function readBoolVector(field: Field, state: VectorReaderContext) {\n    return new BoolVector(readNumericBuffers(field, state, Uint8Array));\n}\n\nexport function readDateVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new Date())!;\n    switch (type.unit()) {\n        case DateUnit.DAY: return new Date32Vector({ ...readNumericBuffers(field, state, Int32Array), unit: DateUnit[type.unit()] });\n        case DateUnit.MILLISECOND: return new Date64Vector({ ...readNumericBuffers(field, state, Int32Array), unit: DateUnit[type.unit()] });\n    }\n    throw new Error(`Unrecognized Date { unit: ${type.unit()} }`);\n}\n\nexport function readTimeVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new Time())!;\n    switch (type.bitWidth()) {\n        case 32: return new Time32Vector({ ...readNumericBuffers(field, state, Int32Array), unit: TimeUnit[type.unit()] });\n        case 64: return new Time64Vector({ ...readNumericBuffers(field, state, Uint32Array), unit: TimeUnit[type.unit()] });\n    }\n    throw new Error(`Unrecognized Time { unit: ${type.unit()}, bitWidth: ${type.bitWidth()} }`);\n}\n\nexport function readTimestampVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new Timestamp())!;\n    const { fieldNode, validity, data } = readNumericBuffers(field, state, Uint32Array);\n    return new TimestampVector({\n        field, fieldNode, validity, data,\n        timezone: type.timezone()!,\n        unit: TimeUnit[type.unit()],\n    });\n}\n\nexport function readListVector(field: Field, state: VectorReaderContext) {\n    const { fieldNode, validity, offsets } = readListBuffers(field, state);\n    return new ListVector({\n        field, fieldNode, validity, offsets,\n        values: readVector(field.children(0)!, state)\n    });\n}\n\nexport function readStructVector(field: Field, state: VectorReaderContext) {\n    const n = field.childrenLength();\n    const columns = new Array<Vector>(n);\n    const fieldNode = state.readNextNode();\n    const validity = readValidityBuffer(field, fieldNode, state);\n    for (let i = -1, child: Field; ++i < n;) {\n        if (child = field.children(i)!) {\n            columns[i] = readVector(child, state);\n        }\n    }\n    return new StructVector({ field, fieldNode, validity, columns });\n}\n\nexport function readBinaryVector(field: Field, state: VectorReaderContext) {\n    return new BinaryVector(readBinaryBuffers(field, state));\n}\n\nexport function readDecimalVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new Decimal())!;\n    const { fieldNode, validity, data } = readNumericBuffers(field, state, Uint32Array);\n    return new DecimalVector({\n        scale: type.scale(),\n        precision: type.precision(),\n        field, fieldNode, validity, data\n    });\n}\n\nexport function readUtf8Vector(field: Field, state: VectorReaderContext) {\n    const { fieldNode, validity, offsets, data } = readBinaryBuffers(field, state);\n    return new Utf8Vector({\n        field, fieldNode,\n        values: new BinaryVector({\n            validity, offsets, data\n        })\n    });\n}\n\nexport function readFixedSizeListVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new FixedSizeList())!;\n    const fieldNode = state.readNextNode();\n    const validity = readValidityBuffer(field, fieldNode, state);\n    return new FixedSizeListVector({\n        field, fieldNode, validity,\n        size: type.listSize(),\n        values: readVector(field.children(0)!, state)\n    });\n}\n\nexport function readFixedSizeBinaryVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new FixedSizeBinary())!;\n    const { fieldNode, validity, data } = readNumericBuffers(field, state, Uint8Array);\n    return new FixedSizeListVector({\n        size: type.byteWidth(),\n        field, fieldNode, validity,\n        values: new Uint8Vector({ data })\n    });\n}\n\nexport function readFloatVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new FloatingPoint())!;\n    switch (type.precision()) {\n        case Precision.HALF:   return new Float16Vector(readNumericBuffers(field, state, Uint16Array));\n        case Precision.SINGLE: return new Float32Vector(readNumericBuffers(field, state, Float32Array));\n        case Precision.DOUBLE: return new Float64Vector(readNumericBuffers(field, state, Float64Array));\n    }\n    throw new Error(`Unrecognized FloatingPoint { precision: ${type.precision()} }`);\n}\n\nexport function readIntVector(field: Field, state: VectorReaderContext) {\n    const type = field.type(new Int())!;\n    if (type.isSigned()) {\n        switch (type.bitWidth()) {\n            case  8: return new  Int8Vector(readNumericBuffers(field, state, Int8Array));\n            case 16: return new Int16Vector(readNumericBuffers(field, state, Int16Array));\n            case 32: return new Int32Vector(readNumericBuffers(field, state, Int32Array));\n            case 64: return new Int64Vector(readNumericBuffers(field, state, Int32Array));\n        }\n    }\n    switch (type.bitWidth()) {\n        case  8: return new  Uint8Vector(readNumericBuffers(field, state, Uint8Array));\n        case 16: return new Uint16Vector(readNumericBuffers(field, state, Uint16Array));\n        case 32: return new Uint32Vector(readNumericBuffers(field, state, Uint32Array));\n        case 64: return new Uint64Vector(readNumericBuffers(field, state, Uint32Array));\n    }\n    throw new Error(`Unrecognized Int { isSigned: ${type.isSigned()}, bitWidth: ${type.bitWidth()} }`);\n}\n\nfunction readListBuffers(field: Field, state: VectorReaderContext) {\n    const fieldNode = state.readNextNode();\n    const validity = readValidityBuffer(field, fieldNode, state);\n    const offsets = readDataBuffer(Int32Array, state);\n    return { field, fieldNode, validity, offsets };\n}\n\nfunction readBinaryBuffers(field: Field, state: VectorReaderContext) {\n    const fieldNode = state.readNextNode();\n    const validity = readValidityBuffer(field, fieldNode, state);\n    const offsets = readDataBuffer(Int32Array, state);\n    const data = readDataBuffer(Uint8Array, state);\n    return { field, fieldNode, validity, offsets, data };\n}\n\nfunction readNumericBuffers<T extends TypedArray>(field: Field, state: VectorReaderContext, ArrayConstructor: TypedArrayConstructor<T>) {\n    const fieldNode = state.readNextNode();\n    const validity = readValidityBuffer(field, fieldNode, state);\n    const data = readDataBuffer(ArrayConstructor, state);\n    return { field, fieldNode, validity, data };\n}\n\nfunction readDataBuffer<T extends TypedArray>(ArrayConstructor: TypedArrayConstructor<T>, state: VectorReaderContext) {\n    return createTypedArray(ArrayConstructor, state.bytes, state.offset, state.readNextBuffer());\n}\n\nfunction readValidityBuffer(field: Field, fieldNode: FieldNode, state: VectorReaderContext) {\n    return createValidityArray(field, fieldNode, state.bytes, state.offset, state.readNextBuffer());\n}\n\nfunction createValidityArray(field: Field, fieldNode: FieldNode, bytes: Uint8Array, offset: number, buffer: Buffer) {\n    return field.nullable() && fieldNode.nullCount().low > 0 && createTypedArray(Uint8Array, bytes, offset, buffer) || null;\n}\n\nfunction createTypedArray<T extends TypedArray>(ArrayConstructor: TypedArrayConstructor<T>, bytes: Uint8Array, offset: number, buffer: Buffer) {\n    return new ArrayConstructor(\n        bytes.buffer,\n        bytes.byteOffset + offset + buffer.offset().low,\n        buffer.length().low / ArrayConstructor.BYTES_PER_ELEMENT\n    );\n}\n"]} |
145
README.md
@@ -22,28 +22,25 @@ <!--- | ||
[![Build Status](https://travis-ci.org/graphistry/arrow.svg?branch=master)](https://travis-ci.org/graphistry/arrow) | ||
[![Coverage Status](https://coveralls.io/repos/github/graphistry/arrow/badge.svg)](https://coveralls.io/github/graphistry/arrow) | ||
[![Build Status](https://travis-ci.org/apache/arrow.svg?branch=master)](https://travis-ci.org/apache/arrow) | ||
[![Coverage Status](https://coveralls.io/repos/github/apache/arrow/badge.svg)](https://coveralls.io/github/apache/arrow) | ||
Loading big native dataframes in JavaScript is finally awesome. `apache-arrow` provides an easy, modern, and efficient zero-copy JS interface to parse, iterate, and access [Apache Arrow](https://github.com/apache/arrow) columnar data on CPUs (GPU support via [GoAI](http://gpuopenanalytics.com/) is occurring in parallel). | ||
Arrow is a set of technologies that enable big-data systems to process and transfer data quickly. | ||
`apache-arrow` is tested on Apache's sample Arrow files and [MapD Core's](https://www.mapd.com/platform/core/) Arrow output, and powers much of [Graphistry's](https://www.graphistry.com) GPU visual analytics platform. It is in active development by Graphistry for its GPU client/cloud visual graph analytics platform. | ||
## install [apache-arrow from npm](https://www.npmjs.com/package/apache-arrow) | ||
***This project has been developed outside the Apache Software Foundation, but an effort to transfer IP and ownership to the ASF is underway.*** | ||
`npm install apache-arrow` | ||
## install | ||
(read about how we [package apache-arrow](#packaging) below) | ||
`npm install apache-arrow` | ||
# Powering Columnar In-Memory Analytics | ||
# What's Arrow? | ||
Apache Arrow is a columnar memory layout specification for encoding vectors and table-like containers of flat and nested data. The Arrow spec aligns columnar data in memory to minimize cache misses and take advantage of the latest SIMD (Single input multiple data) and GPU operations on modern processors. | ||
Apache Arrow is a columnar memory layout specification for encoding vectors and table-like containers of flat and nested data. The Arrow spec aligns columnar data in memory to maximize caches and take advantage of the latest SIMD (Single input multiple data) and GPU operations on modern processors. | ||
Apache Arrow is the emerging standard for large in-memory columnar data ([Spark](https://spark.apache.org/), [Pandas](http://wesmckinney.com/blog/pandas-and-apache-arrow/), [Drill](https://drill.apache.org/), ...). By standardizing on a common binary interchange format, big data systems can reduce the costs and friction associated with cross-system communication. | ||
Apache Arrow is the emerging standard for large in-memory columnar data ([Spark](https://spark.apache.org/), [Pandas](http://wesmckinney.com/blog/pandas-and-apache-arrow/), [Drill](https://drill.apache.org/), ...). By standardizing on a common interchange format, big data systems can reduce the costs and friction associated with cross-system communication. | ||
# Related Projects | ||
* [Apache Arrow](https://github.com/apache/arrow) -- Arrow columnar format | ||
* [GoAI](http://gpuopenanalytics.com/) -- Arrow standard extensions for GPUs | ||
* [rxjs-mapd](https://github.com/graphistry/rxjs-mapd) -- Library for querying MapD Core in node | ||
* [GoAI](http://gpuopenanalytics.com/) -- Arrow-powered GPU analytics | ||
* [rxjs-mapd](https://github.com/graphistry/rxjs-mapd) -- A MapD Core node-driver that returns query results as Arrow columns | ||
# Examples | ||
# Usage | ||
@@ -57,3 +54,3 @@ ## Get a table from an Arrow file on disk | ||
const arrow = readFileSync('simple.arrow'); | ||
const table = Table.from(arrow); | ||
const table = Table.from([arrow]); | ||
@@ -78,3 +75,3 @@ console.log(table.toString()); | ||
const table = Table.from(...[ | ||
const table = Table.from([ | ||
'latlong/schema.arrow', | ||
@@ -102,3 +99,3 @@ 'latlong/records.arrow' | ||
const table = Table.from(...[ | ||
const table = Table.from([ | ||
'latlong/schema.arrow', | ||
@@ -108,3 +105,3 @@ 'latlong/records.arrow' | ||
const column = table.getColumn('origin_lat'); | ||
const column = table.col('origin_lat'); | ||
const typed = column.slice(); | ||
@@ -119,3 +116,3 @@ | ||
## Use with MapD Core | ||
## Usage with MapD Core | ||
@@ -128,21 +125,25 @@ ```es6 | ||
const host = `localhost`; | ||
const encrypted = false; | ||
const username = `mapd`; | ||
const db = `mapd`; | ||
const user = `mapd`; | ||
const password = `HyperInteractive`; | ||
const dbName = `mapd`, timeout = 5000; | ||
MapD.open(host, port, encrypted) | ||
.connect(dbName, username, password, timeout) | ||
.flatMap((session) => | ||
session.queryDF(` | ||
SELECT origin_city | ||
FROM flights | ||
WHERE dest_city ILIKE 'dallas' | ||
LIMIT 5` | ||
).disconnect() | ||
MapD.open(host, port) | ||
.connect(db, user, password) | ||
.flatMap((session) => | ||
// queryDF returns Arrow buffers | ||
session.queryDF(` | ||
SELECT origin_city | ||
FROM flights | ||
WHERE dest_city ILIKE 'dallas' | ||
LIMIT 5` | ||
).disconnect() | ||
) | ||
.map(([schema, records]) => | ||
Table.from(schema, records)) | ||
.subscribe((table) => console.log( | ||
table.toString({ index: true }))); | ||
// Create Arrow Table from results | ||
Table.from(schema, records)) | ||
.map((table) => | ||
// Stringify the table to CSV with row numbers | ||
table.toString({ index: true })) | ||
.subscribe((csvStr) => | ||
console.log(csvStr)); | ||
/* | ||
@@ -158,38 +159,62 @@ Index, origin_city | ||
# Contribute | ||
# Getting involved | ||
See [develop.md](https://github.com/graphistry/arrow/blob/master/develop.md) | ||
See [develop.md](https://github.com/apache/arrow/blob/master/develop.md) | ||
Please create an issue if you encounter any bugs! | ||
Even if you do not plan to contribute to Apache Arrow itself or Arrow | ||
integrations in other projects, we'd be happy to have you involved: | ||
PR's welcome! Here's some ideas: | ||
* Join the mailing list: send an email to | ||
[dev-subscribe@arrow.apache.org][1]. Share your ideas and use cases for the | ||
project. | ||
* [Follow our activity on JIRA][3] | ||
* [Learn the format][2] | ||
* Contribute code to one of the reference implementations | ||
* API docs | ||
* More Tests/Benchmarks | ||
* Performance optimizations | ||
* Arrows from node-streams and async-iterators | ||
* GPU Arrows from node-opencl and node-cuda buffers | ||
* Bindings to [libgdf](https://github.com/gpuopenanalytics/libgdf) | ||
We prefer to receive contributions in the form of GitHub pull requests. Please send pull requests against the [github.com/apache/arrow][4] repository. | ||
### packaging | ||
`apache-arrow` is written in TypeScript, but the project is compiled to multiple JS versions and common module formats. The base `apache-arrow` package includes all the compilation targets for convenience, but if you're conscientious about your `node_modules` footprint, don't worry -- we got you. The targets are also published under the `@apache-arrow` namespace: | ||
If you are looking for some ideas on what to contribute, check out the [JIRA | ||
issues][3] for the Apache Arrow project. Comment on the issue and/or contact | ||
[dev@arrow.apache.org](http://mail-archives.apache.org/mod_mbox/arrow-dev/) | ||
with your questions and ideas. | ||
If you’d like to report a bug but don’t have time to fix it, you can still post | ||
it on JIRA, or email the mailing list | ||
[dev@arrow.apache.org](http://mail-archives.apache.org/mod_mbox/arrow-dev/) | ||
## Packaging | ||
`apache-arrow` is written in TypeScript, but the project is compiled to multiple JS versions and common module formats. | ||
The base `apache-arrow` package includes all the compilation targets for convenience, but if you're conscientious about your `node_modules` footprint, we got you. | ||
The targets are also published under the `@apache-arrow` namespace: | ||
```sh | ||
npm install @apache-arrow/es5-cjs # ES5 CommonJS target | ||
npm install @apache-arrow/es5-esm # ES5 ESModules target | ||
npm install @apache-arrow/es5-umd # ES5 UMD target | ||
npm install @apache-arrow/es2015-cjs # ES2015 CommonJS target | ||
npm install @apache-arrow/es2015-esm # ES2015 ESModules target | ||
npm install @apache-arrow/es2015-umd # ES2015 UMD target | ||
npm install @apache-arrow/esnext-esm # ESNext CommonJS target | ||
npm install @apache-arrow/esnext-esm # ESNext ESModules target | ||
npm install @apache-arrow/esnext-umd # ESNext UMD target | ||
npm install apache-arrow # <-- combined es5/CommonJS + UMD, es2015/ESModules + UMD, and TypeScript package | ||
npm install @apache-arrow/ts # standalone TypeScript package | ||
npm install @apache-arrow/es5-cjs # standalone es5/CommonJS package | ||
npm install @apache-arrow/es5-esm # standalone es5/ESModules package | ||
npm install @apache-arrow/es5-umd # standalone es5/UMD package | ||
npm install @apache-arrow/es2015-cjs # standalone es2015/CommonJS package | ||
npm install @apache-arrow/es2015-esm # standalone es2015/ESModules package | ||
npm install @apache-arrow/es2015-umd # standalone es2015/UMD package | ||
npm install @apache-arrow/esnext-esm # standalone esNext/CommonJS package | ||
npm install @apache-arrow/esnext-esm # standalone esNext/ESModules package | ||
npm install @apache-arrow/esnext-umd # standalone esNext/UMD package | ||
``` | ||
### why do we package like this? | ||
The JS community is a diverse group with a varied list of target environments and tool chains. Publishing multiple packages accommodates projects of all types. Friends targeting the latest JS runtimes can pull in the ESNext + ESM build. Friends needing wide browser support and small download size can use the UMD bundle, which has been run through Google's Closure Compiler with advanced optimizations. | ||
### Why we package like this | ||
If you think we missed a compilation target and it's a blocker for adoption, please open an issue. We're here for you ❤️. | ||
The JS community is a diverse group with a varied list of target environments and tool chains. Publishing multiple packages accommodates projects of all stripes. | ||
If you think we missed a compilation target and it's a blocker for adoption, please open an issue. | ||
# License | ||
[Apache 2.0](https://github.com/graphistry/arrow/blob/master/LICENSE) | ||
[Apache 2.0](https://github.com/apache/arrow/blob/master/LICENSE) | ||
[1]: mailto:dev-subscribe@arrow.apache.org | ||
[2]: https://github.com/apache/arrow/tree/master/format | ||
[3]: https://issues.apache.org/jira/browse/ARROW | ||
[4]: https://github.com/apache/arrow |
import { Vector } from './vector'; | ||
export declare class DictionaryVector<T> extends Vector<T> { | ||
protected data: Vector<T>; | ||
protected keys: Vector<number>; | ||
constructor(index: Vector<number>, dictionary: Vector<T>); | ||
index(index: number): number; | ||
value(index: number): T; | ||
get(index: number): T; | ||
concat(vector: DictionaryVector<T>): any; | ||
[Symbol.iterator](): IterableIterator<T>; | ||
readonly length: number; | ||
readonly data: Vector<T>; | ||
readonly keys: Vector<number>; | ||
constructor(argv: { | ||
data: Vector<T>; | ||
keys: Vector<number>; | ||
}); | ||
get(index: number): T | null; | ||
getKey(index: number): number | null; | ||
getValue(key: number): T | null; | ||
concat(...vectors: Vector<T>[]): Vector<T>; | ||
[Symbol.iterator](): IterableIterator<T | null>; | ||
} |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -19,25 +20,25 @@ // or more contributor license agreements. See the NOTICE file | ||
const vector_1 = require("./vector"); | ||
const virtual_1 = require("./virtual"); | ||
class DictionaryVector extends vector_1.Vector { | ||
constructor(index, dictionary) { | ||
constructor(argv) { | ||
super(); | ||
this.keys = index; | ||
this.data = dictionary; | ||
this.length = index && index.length || 0; | ||
this.data = argv.data; | ||
this.keys = argv.keys; | ||
this.length = this.keys.length; | ||
} | ||
index(index) { | ||
get(index) { | ||
return this.getValue(this.getKey(index)); | ||
} | ||
getKey(index) { | ||
return this.keys.get(index); | ||
} | ||
value(index) { | ||
return this.data.get(index); | ||
getValue(key) { | ||
return this.data.get(key); | ||
} | ||
get(index) { | ||
return this.value(this.index(index)); | ||
concat(...vectors) { | ||
return new virtual_1.VirtualVector(Array, this, ...vectors); | ||
} | ||
concat(vector) { | ||
return DictionaryVector.from(this, this.length + vector.length, this.keys.concat(vector.keys), this.data); | ||
} | ||
*[Symbol.iterator]() { | ||
let { data } = this; | ||
for (const loc of this.keys) { | ||
yield data.get(loc); | ||
for (let i = -1, n = this.length; ++i < n;) { | ||
yield this.get(i); | ||
} | ||
@@ -48,2 +49,2 @@ } | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInZlY3Rvci9kaWN0aW9uYXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDZEQUE2RDtBQUM3RCwrREFBK0Q7QUFDL0Qsd0RBQXdEO0FBQ3hELDZEQUE2RDtBQUM3RCxvREFBb0Q7QUFDcEQsNkRBQTZEO0FBQzdELDZEQUE2RDtBQUM3RCxFQUFFO0FBQ0YsK0NBQStDO0FBQy9DLEVBQUU7QUFDRiw2REFBNkQ7QUFDN0QsOERBQThEO0FBQzlELHlEQUF5RDtBQUN6RCw0REFBNEQ7QUFDNUQsMERBQTBEO0FBQzFELHFCQUFxQjs7QUFFckIscUNBQWtDO0FBRWxDLHNCQUFpQyxTQUFRLGVBQVM7SUFHOUMsWUFBWSxLQUFxQixFQUFFLFVBQXFCO1FBQ3BELEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7UUFDbEIsSUFBSSxDQUFDLElBQUksR0FBRyxVQUFVLENBQUM7UUFDdkIsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLElBQUksS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUM7SUFDN0MsQ0FBQztJQUNELEtBQUssQ0FBQyxLQUFhO1FBQ2YsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFDRCxLQUFLLENBQUMsS0FBYTtRQUNmLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO0lBQ0QsR0FBRyxDQUFDLEtBQWE7UUFDYixNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDekMsQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUEyQjtRQUM5QixNQUFNLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLElBQUksRUFDN0IsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxFQUMzQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQzdCLElBQUksQ0FBQyxJQUFJLENBQ1osQ0FBQztJQUNOLENBQUM7SUFDRCxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNkLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUM7UUFDcEIsR0FBRyxDQUFDLENBQUMsTUFBTSxHQUFHLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7WUFDMUIsTUFBTSxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3hCLENBQUM7SUFDTCxDQUFDO0NBQ0o7QUEvQkQsNENBK0JDIiwiZmlsZSI6InZlY3Rvci9kaWN0aW9uYXJ5LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTGljZW5zZWQgdG8gdGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChBU0YpIHVuZGVyIG9uZVxuLy8gb3IgbW9yZSBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlXG4vLyBkaXN0cmlidXRlZCB3aXRoIHRoaXMgd29yayBmb3IgYWRkaXRpb25hbCBpbmZvcm1hdGlvblxuLy8gcmVnYXJkaW5nIGNvcHlyaWdodCBvd25lcnNoaXAuICBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZVxuLy8gdG8geW91IHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZVxuLy8gXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4vLyB3aXRoIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4vL1xuLy8gICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbi8vXG4vLyBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsXG4vLyBzb2Z0d2FyZSBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhblxuLy8gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTllcbi8vIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZVxuLy8gc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZCBsaW1pdGF0aW9uc1xuLy8gdW5kZXIgdGhlIExpY2Vuc2UuXG5cbmltcG9ydCB7IFZlY3RvciB9IGZyb20gJy4vdmVjdG9yJztcblxuZXhwb3J0IGNsYXNzIERpY3Rpb25hcnlWZWN0b3I8VD4gZXh0ZW5kcyBWZWN0b3I8VD4ge1xuICAgIHByb3RlY3RlZCBkYXRhOiBWZWN0b3I8VD47XG4gICAgcHJvdGVjdGVkIGtleXM6IFZlY3RvcjxudW1iZXI+O1xuICAgIGNvbnN0cnVjdG9yKGluZGV4OiBWZWN0b3I8bnVtYmVyPiwgZGljdGlvbmFyeTogVmVjdG9yPFQ+KSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMua2V5cyA9IGluZGV4O1xuICAgICAgICB0aGlzLmRhdGEgPSBkaWN0aW9uYXJ5O1xuICAgICAgICB0aGlzLmxlbmd0aCA9IGluZGV4ICYmIGluZGV4Lmxlbmd0aCB8fCAwO1xuICAgIH1cbiAgICBpbmRleChpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmtleXMuZ2V0KGluZGV4KTtcbiAgICB9XG4gICAgdmFsdWUoaW5kZXg6IG51bWJlcikge1xuICAgICAgICByZXR1cm4gdGhpcy5kYXRhLmdldChpbmRleCk7XG4gICAgfVxuICAgIGdldChpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlKHRoaXMuaW5kZXgoaW5kZXgpKTtcbiAgICB9XG4gICAgY29uY2F0KHZlY3RvcjogRGljdGlvbmFyeVZlY3RvcjxUPikge1xuICAgICAgICByZXR1cm4gRGljdGlvbmFyeVZlY3Rvci5mcm9tKHRoaXMsXG4gICAgICAgICAgICB0aGlzLmxlbmd0aCArIHZlY3Rvci5sZW5ndGgsXG4gICAgICAgICAgICB0aGlzLmtleXMuY29uY2F0KHZlY3Rvci5rZXlzKSxcbiAgICAgICAgICAgIHRoaXMuZGF0YVxuICAgICAgICApO1xuICAgIH1cbiAgICAqW1N5bWJvbC5pdGVyYXRvcl0oKSB7XG4gICAgICAgIGxldCB7IGRhdGEgfSA9IHRoaXM7XG4gICAgICAgIGZvciAoY29uc3QgbG9jIG9mIHRoaXMua2V5cykge1xuICAgICAgICAgICAgeWllbGQgZGF0YS5nZXQobG9jKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInZlY3Rvci9kaWN0aW9uYXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSw2REFBNkQ7QUFDN0QsK0RBQStEO0FBQy9ELHdEQUF3RDtBQUN4RCw2REFBNkQ7QUFDN0Qsb0RBQW9EO0FBQ3BELDZEQUE2RDtBQUM3RCw2REFBNkQ7QUFDN0QsRUFBRTtBQUNGLCtDQUErQztBQUMvQyxFQUFFO0FBQ0YsNkRBQTZEO0FBQzdELDhEQUE4RDtBQUM5RCx5REFBeUQ7QUFDekQsNERBQTREO0FBQzVELDBEQUEwRDtBQUMxRCxxQkFBcUI7O0FBRXJCLHFDQUFrQztBQUNsQyx1Q0FBMEM7QUFFMUMsc0JBQWlDLFNBQVEsZUFBUztJQUk5QyxZQUFZLElBQStDO1FBQ3ZELEtBQUssRUFBRSxDQUFDO1FBQ1IsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQztRQUN0QixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDO0lBQ25DLENBQUM7SUFDRCxHQUFHLENBQUMsS0FBYTtRQUNiLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFFLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBQ0QsTUFBTSxDQUFDLEtBQWE7UUFDaEIsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFDRCxRQUFRLENBQUMsR0FBVztRQUNoQixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUNELE1BQU0sQ0FBQyxHQUFHLE9BQW9CO1FBQzFCLE1BQU0sQ0FBQyxJQUFJLHVCQUFhLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxHQUFHLE9BQU8sQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFDRCxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNkLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDO1lBQ3pDLE1BQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN0QixDQUFDO0lBQ0wsQ0FBQztDQUNKO0FBM0JELDRDQTJCQyIsImZpbGUiOiJ2ZWN0b3IvZGljdGlvbmFyeS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIExpY2Vuc2VkIHRvIHRoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbiAoQVNGKSB1bmRlciBvbmVcbi8vIG9yIG1vcmUgY29udHJpYnV0b3IgbGljZW5zZSBhZ3JlZW1lbnRzLiAgU2VlIHRoZSBOT1RJQ0UgZmlsZVxuLy8gZGlzdHJpYnV0ZWQgd2l0aCB0aGlzIHdvcmsgZm9yIGFkZGl0aW9uYWwgaW5mb3JtYXRpb25cbi8vIHJlZ2FyZGluZyBjb3B5cmlnaHQgb3duZXJzaGlwLiAgVGhlIEFTRiBsaWNlbnNlcyB0aGlzIGZpbGVcbi8vIHRvIHlvdSB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGVcbi8vIFwiTGljZW5zZVwiKTsgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZVxuLy8gd2l0aCB0aGUgTGljZW5zZS4gIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuLy9cbi8vICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4vL1xuLy8gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLFxuLy8gc29mdHdhcmUgZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW5cbi8vIFwiQVMgSVNcIiBCQVNJUywgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZXG4vLyBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLiAgU2VlIHRoZSBMaWNlbnNlIGZvciB0aGVcbi8vIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmQgbGltaXRhdGlvbnNcbi8vIHVuZGVyIHRoZSBMaWNlbnNlLlxuXG5pbXBvcnQgeyBWZWN0b3IgfSBmcm9tICcuL3ZlY3Rvcic7XG5pbXBvcnQgeyBWaXJ0dWFsVmVjdG9yIH0gZnJvbSAnLi92aXJ0dWFsJztcblxuZXhwb3J0IGNsYXNzIERpY3Rpb25hcnlWZWN0b3I8VD4gZXh0ZW5kcyBWZWN0b3I8VD4ge1xuICAgIHJlYWRvbmx5IGxlbmd0aDogbnVtYmVyO1xuICAgIHJlYWRvbmx5IGRhdGE6IFZlY3RvcjxUPjtcbiAgICByZWFkb25seSBrZXlzOiBWZWN0b3I8bnVtYmVyPjtcbiAgICBjb25zdHJ1Y3Rvcihhcmd2OiB7IGRhdGE6IFZlY3RvcjxUPiwga2V5czogVmVjdG9yPG51bWJlcj4gfSkge1xuICAgICAgICBzdXBlcigpO1xuICAgICAgICB0aGlzLmRhdGEgPSBhcmd2LmRhdGE7XG4gICAgICAgIHRoaXMua2V5cyA9IGFyZ3Yua2V5cztcbiAgICAgICAgdGhpcy5sZW5ndGggPSB0aGlzLmtleXMubGVuZ3RoO1xuICAgIH1cbiAgICBnZXQoaW5kZXg6IG51bWJlcikge1xuICAgICAgICByZXR1cm4gdGhpcy5nZXRWYWx1ZSh0aGlzLmdldEtleShpbmRleCkhKTtcbiAgICB9XG4gICAgZ2V0S2V5KGluZGV4OiBudW1iZXIpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMua2V5cy5nZXQoaW5kZXgpO1xuICAgIH1cbiAgICBnZXRWYWx1ZShrZXk6IG51bWJlcikge1xuICAgICAgICByZXR1cm4gdGhpcy5kYXRhLmdldChrZXkpO1xuICAgIH1cbiAgICBjb25jYXQoLi4udmVjdG9yczogVmVjdG9yPFQ+W10pOiBWZWN0b3I8VD4ge1xuICAgICAgICByZXR1cm4gbmV3IFZpcnR1YWxWZWN0b3IoQXJyYXksIHRoaXMsIC4uLnZlY3RvcnMpO1xuICAgIH1cbiAgICAqW1N5bWJvbC5pdGVyYXRvcl0oKSB7XG4gICAgICAgIGZvciAobGV0IGkgPSAtMSwgbiA9IHRoaXMubGVuZ3RoOyArK2kgPCBuOykge1xuICAgICAgICAgICAgeWllbGQgdGhpcy5nZXQoaSk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0= |
@@ -1,26 +0,32 @@ | ||
/// <reference types="text-encoding" /> | ||
import { List } from './types'; | ||
import { Vector } from './vector'; | ||
import { IndexVector, ValidityArgs } from './typed'; | ||
export declare class ListVectorBase<T> extends Vector<T> { | ||
protected values: Vector<T>; | ||
protected offsets: IndexVector; | ||
constructor(validity: ValidityArgs, values: Vector<any>, offsets: IndexVector); | ||
get(index: number): any; | ||
concat(vector: ListVectorBase<T>): any; | ||
[Symbol.iterator](): IterableIterator<any>; | ||
export declare class BinaryVector extends Vector<Uint8Array> { | ||
readonly data: Uint8Array; | ||
readonly offsets: Int32Array; | ||
constructor(argv: { | ||
offsets: Int32Array; | ||
data: Uint8Array; | ||
}); | ||
get(index: number): Uint8Array; | ||
concat(...vectors: Vector<Uint8Array>[]): Vector<Uint8Array>; | ||
} | ||
export declare class ListVector<T> extends ListVectorBase<T[]> { | ||
export declare class ListVector<T> extends Vector<T[]> { | ||
readonly offsets: Int32Array; | ||
readonly values: Vector<T>; | ||
constructor(argv: { | ||
offsets: Int32Array; | ||
values: Vector<T>; | ||
}); | ||
get(index: number): any[]; | ||
concat(...vectors: Vector<T[]>[]): Vector<T[]>; | ||
} | ||
export declare class Utf8Vector extends ListVectorBase<string> { | ||
protected static decoder: TextEncoding.TextDecoder; | ||
get(index: number): string; | ||
[Symbol.iterator](): IterableIterator<string>; | ||
export declare class FixedSizeListVector<T, TArray extends List<T>> extends Vector<TArray> { | ||
readonly size: number; | ||
readonly values: Vector<T>; | ||
constructor(argv: { | ||
size: number; | ||
values: Vector<T>; | ||
}); | ||
get(index: number): TArray; | ||
concat(...vectors: Vector<TArray>[]): Vector<TArray>; | ||
} | ||
export declare class FixedSizeListVector<T> extends Vector<T[]> { | ||
protected size: number; | ||
protected values: Vector<T>; | ||
constructor(size: number, validity: ValidityArgs, values: Vector<T>); | ||
get(index: number): T[]; | ||
concat(vector: FixedSizeListVector<T>): any; | ||
[Symbol.iterator](): IterableIterator<T[]>; | ||
} |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -19,79 +20,52 @@ // or more contributor license agreements. See the NOTICE file | ||
const vector_1 = require("./vector"); | ||
const text_encoding_1 = require("text-encoding"); | ||
const typed_1 = require("./typed"); | ||
class ListVectorBase extends vector_1.Vector { | ||
constructor(validity, values, offsets) { | ||
const virtual_1 = require("./virtual"); | ||
class BinaryVector extends vector_1.Vector { | ||
constructor(argv) { | ||
super(); | ||
this.values = values; | ||
this.offsets = offsets; | ||
validity && (this.validity = typed_1.BitVector.from(validity)); | ||
this.data = argv.data; | ||
this.offsets = argv.offsets; | ||
} | ||
get(index) { | ||
let batch, from, to, { offsets } = this; | ||
if (!this.validity.get(index) || | ||
/* return null if `to` is null */ | ||
((to = offsets.get(index + 1)) === null) || !( | ||
/* | ||
return null if `batch` is less than than 0. this check is placed | ||
second to avoid creating the [from, batch] tuple if `to` is null | ||
*/ | ||
([from, batch] = offsets.get(index, true)) && batch > -1)) { | ||
return null; | ||
} | ||
return this.values.slice(from, to, batch); | ||
return this.data.subarray(this.offsets[index], this.offsets[index + 1]); | ||
} | ||
concat(vector) { | ||
return this.constructor.from(this, this.length + vector.length, this.validity.concat(vector.validity), this.values.concat(vector.values), this.offsets.concat(vector.offsets)); | ||
concat(...vectors) { | ||
return new virtual_1.VirtualVector(Array, this, ...vectors); | ||
} | ||
*[Symbol.iterator]() { | ||
let v, r1, r2, { values } = this; | ||
let it = this.offsets[Symbol.iterator](); | ||
let iv = this.validity[Symbol.iterator](); | ||
while (!(v = iv.next()).done && !(r1 = it.next()).done && !(r2 = it.next()).done) { | ||
yield !v.value ? null : values.slice(r1.value[0], r2.value, r1.value[1]); | ||
} | ||
} | ||
exports.BinaryVector = BinaryVector; | ||
class ListVector extends vector_1.Vector { | ||
constructor(argv) { | ||
super(); | ||
this.values = argv.values; | ||
this.offsets = argv.offsets; | ||
} | ||
} | ||
exports.ListVectorBase = ListVectorBase; | ||
class ListVector extends ListVectorBase { | ||
} | ||
exports.ListVector = ListVector; | ||
class Utf8Vector extends ListVectorBase { | ||
get(index) { | ||
let chars = super.get(index); | ||
return chars ? Utf8Vector.decoder.decode(chars) : null; | ||
} | ||
*[Symbol.iterator]() { | ||
let decoder = Utf8Vector.decoder; | ||
for (const chars of super[Symbol.iterator]()) { | ||
yield !chars ? null : decoder.decode(chars); | ||
const { offsets, values } = this; | ||
const from = offsets[index]; | ||
const xs = new Array(offsets[index + 1] - from); | ||
for (let i = -1, n = xs.length; ++i < n;) { | ||
xs[i] = values.get(i + from); | ||
} | ||
return xs; | ||
} | ||
concat(...vectors) { | ||
return new virtual_1.VirtualVector(Array, this, ...vectors); | ||
} | ||
} | ||
Utf8Vector.decoder = new text_encoding_1.TextDecoder(`utf-8`); | ||
exports.Utf8Vector = Utf8Vector; | ||
exports.ListVector = ListVector; | ||
class FixedSizeListVector extends vector_1.Vector { | ||
constructor(size, validity, values) { | ||
constructor(argv) { | ||
super(); | ||
this.values = values; | ||
this.size = Math.abs(size | 0) || 1; | ||
validity && (this.validity = typed_1.BitVector.from(validity)); | ||
this.size = argv.size; | ||
this.values = argv.values; | ||
} | ||
get(index) { | ||
return !this.validity.get(index) ? null : this.values.slice(this.size * index, this.size * (index + 1)); | ||
return this.values.slice(this.size * index, this.size * (index + 1)); | ||
} | ||
concat(vector) { | ||
return FixedSizeListVector.from(this, this.length + vector.length, this.size, this.validity.concat(vector.validity), this.values.concat(vector.values)); | ||
concat(...vectors) { | ||
return new virtual_1.VirtualVector(Array, this, ...vectors); | ||
} | ||
*[Symbol.iterator]() { | ||
let v, i = -1; | ||
let { size, length, values } = this; | ||
let iv = this.validity[Symbol.iterator](); | ||
while (!(v = iv.next()).done && ++i < length) { | ||
yield !v.value ? null : values.slice(size * i, size * (i + 1)); | ||
} | ||
} | ||
} | ||
exports.FixedSizeListVector = FixedSizeListVector; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["vector/list.ts"],"names":[],"mappings":"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","file":"vector/list.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { Vector } from './vector';\nimport { TextDecoder } from 'text-encoding';\nimport { IndexVector, BitVector, ValidityArgs } from './typed';\n\nexport class ListVectorBase<T> extends Vector<T> {\n    protected values: Vector<T>;\n    protected offsets: IndexVector;\n    constructor(validity: ValidityArgs, values: Vector<any>, offsets: IndexVector) {\n        super();\n        this.values = values;\n        this.offsets = offsets;\n        validity && (this.validity = BitVector.from(validity));\n    }\n    get(index: number) {\n        let batch, from, to, { offsets } = this;\n        if (!this.validity.get(index) ||\n            /* return null if `to` is null */\n            ((to = offsets.get(index + 1)) === null) || !(\n            /*\n            return null if `batch` is less than than 0. this check is placed\n            second to avoid creating the [from, batch] tuple if `to` is null\n            */\n            ([from, batch] = offsets.get(index, true) as number[]) && batch > -1)) {\n            return null;\n        }\n        return this.values.slice(from, to, batch) as any;\n    }\n    concat(vector: ListVectorBase<T>) {\n        return (this.constructor as typeof ListVectorBase).from(this,\n            this.length + vector.length,\n            this.validity.concat(vector.validity),\n            this.values.concat(vector.values),\n            this.offsets.concat(vector.offsets)\n        );\n    }\n    *[Symbol.iterator]() {\n        let v, r1, r2, { values } = this;\n        let it = this.offsets[Symbol.iterator]();\n        let iv = this.validity[Symbol.iterator]();\n        while (!(v = iv.next()).done && !(r1 = it.next()).done && !(r2 = it.next()).done) {\n            yield !v.value ? null : values.slice(r1.value[0], r2.value, r1.value[1]) as any;\n        }\n    }\n}\n\nexport class ListVector<T> extends ListVectorBase<T[]> {}\nexport class Utf8Vector extends ListVectorBase<string> {\n    protected static decoder = new TextDecoder(`utf-8`);\n    get(index: number) {\n        let chars = super.get(index) as any;\n        return chars ? Utf8Vector.decoder.decode(chars) : null;\n    }\n    *[Symbol.iterator]() {\n        let decoder = Utf8Vector.decoder;\n        for (const chars of super[Symbol.iterator]()) {\n            yield !chars ? null : decoder.decode(chars);\n        }\n    }\n}\n\nexport class FixedSizeListVector<T> extends Vector<T[]> {\n    protected size: number;\n    protected values: Vector<T>;\n    constructor(size: number, validity: ValidityArgs, values: Vector<T>) {\n        super();\n        this.values = values;\n        this.size = Math.abs(size | 0) || 1;\n        validity && (this.validity = BitVector.from(validity));\n    }\n    get(index: number) {\n        return !this.validity.get(index) ? null : this.values.slice(\n            this.size * index, this.size * (index + 1)\n        ) as T[];\n    }\n    concat(vector: FixedSizeListVector<T>) {\n        return FixedSizeListVector.from(this,\n            this.length + vector.length,\n            this.size,\n            this.validity.concat(vector.validity),\n            this.values.concat(vector.values)\n        );\n    }\n    *[Symbol.iterator]() {\n        let v, i = -1;\n        let { size, length, values } = this;\n        let iv = this.validity[Symbol.iterator]();\n        while (!(v = iv.next()).done && ++i < length) {\n            yield !v.value ? null : values.slice(size * i, size * (i + 1)) as T[];\n        }\n    }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,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LENBQUMsR0FBRyxPQUF5QjtRQUMvQixNQUFNLENBQUMsSUFBSSx1QkFBYSxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsR0FBRyxPQUFPLENBQUMsQ0FBQztJQUN0RCxDQUFDO0NBQ0o7QUFkRCxrREFjQyIsImZpbGUiOiJ2ZWN0b3IvbGlzdC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIExpY2Vuc2VkIHRvIHRoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbiAoQVNGKSB1bmRlciBvbmVcbi8vIG9yIG1vcmUgY29udHJpYnV0b3IgbGljZW5zZSBhZ3JlZW1lbnRzLiAgU2VlIHRoZSBOT1RJQ0UgZmlsZVxuLy8gZGlzdHJpYnV0ZWQgd2l0aCB0aGlzIHdvcmsgZm9yIGFkZGl0aW9uYWwgaW5mb3JtYXRpb25cbi8vIHJlZ2FyZGluZyBjb3B5cmlnaHQgb3duZXJzaGlwLiAgVGhlIEFTRiBsaWNlbnNlcyB0aGlzIGZpbGVcbi8vIHRvIHlvdSB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGVcbi8vIFwiTGljZW5zZVwiKTsgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZVxuLy8gd2l0aCB0aGUgTGljZW5zZS4gIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuLy9cbi8vICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4vL1xuLy8gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLFxuLy8gc29mdHdhcmUgZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW5cbi8vIFwiQVMgSVNcIiBCQVNJUywgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZXG4vLyBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLiAgU2VlIHRoZSBMaWNlbnNlIGZvciB0aGVcbi8vIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmQgbGltaXRhdGlvbnNcbi8vIHVuZGVyIHRoZSBMaWNlbnNlLlxuXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBWZWN0b3IgfSBmcm9tICcuL3ZlY3Rvcic7XG5pbXBvcnQgeyBWaXJ0dWFsVmVjdG9yIH0gZnJvbSAnLi92aXJ0dWFsJztcblxuZXhwb3J0IGNsYXNzIEJpbmFyeVZlY3RvciBleHRlbmRzIFZlY3RvcjxVaW50OEFycmF5PiB7XG4gICAgcmVhZG9ubHkgZGF0YTogVWludDhBcnJheTtcbiAgICByZWFkb25seSBvZmZzZXRzOiBJbnQzMkFycmF5O1xuICAgIGNvbnN0cnVjdG9yKGFyZ3Y6IHsgb2Zmc2V0czogSW50MzJBcnJheSwgZGF0YTogVWludDhBcnJheSB9KSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMuZGF0YSA9IGFyZ3YuZGF0YTtcbiAgICAgICAgdGhpcy5vZmZzZXRzID0gYXJndi5vZmZzZXRzO1xuICAgIH1cbiAgICBnZXQoaW5kZXg6IG51bWJlcikge1xuICAgICAgICByZXR1cm4gdGhpcy5kYXRhLnN1YmFycmF5KHRoaXMub2Zmc2V0c1tpbmRleF0sIHRoaXMub2Zmc2V0c1tpbmRleCArIDFdKTtcbiAgICB9XG4gICAgY29uY2F0KC4uLnZlY3RvcnM6IFZlY3RvcjxVaW50OEFycmF5PltdKTogVmVjdG9yPFVpbnQ4QXJyYXk+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBWaXJ0dWFsVmVjdG9yKEFycmF5LCB0aGlzLCAuLi52ZWN0b3JzKTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBMaXN0VmVjdG9yPFQ+IGV4dGVuZHMgVmVjdG9yPFRbXT4ge1xuICAgIHJlYWRvbmx5IG9mZnNldHM6IEludDMyQXJyYXk7XG4gICAgcmVhZG9ubHkgdmFsdWVzOiBWZWN0b3I8VD47XG4gICAgY29uc3RydWN0b3IoYXJndjogeyBvZmZzZXRzOiBJbnQzMkFycmF5LCB2YWx1ZXM6IFZlY3RvcjxUPiB9KSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMudmFsdWVzID0gYXJndi52YWx1ZXM7XG4gICAgICAgIHRoaXMub2Zmc2V0cyA9IGFyZ3Yub2Zmc2V0cztcbiAgICB9XG4gICAgZ2V0KGluZGV4OiBudW1iZXIpIHtcbiAgICAgICAgY29uc3QgeyBvZmZzZXRzLCB2YWx1ZXMgfSA9IHRoaXM7XG4gICAgICAgIGNvbnN0IGZyb20gPSBvZmZzZXRzW2luZGV4XTtcbiAgICAgICAgY29uc3QgeHMgPSBuZXcgQXJyYXkob2Zmc2V0c1tpbmRleCArIDFdIC0gZnJvbSk7XG4gICAgICAgIGZvciAobGV0IGkgPSAtMSwgbiA9IHhzLmxlbmd0aDsgKytpIDwgbjspIHtcbiAgICAgICAgICAgIHhzW2ldID0gdmFsdWVzLmdldChpICsgZnJvbSk7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHhzO1xuICAgIH1cbiAgICBjb25jYXQoLi4udmVjdG9yczogVmVjdG9yPFRbXT5bXSk6IFZlY3RvcjxUW10+IHtcbiAgICAgICAgcmV0dXJuIG5ldyBWaXJ0dWFsVmVjdG9yKEFycmF5LCB0aGlzLCAuLi52ZWN0b3JzKTtcbiAgICB9XG59XG5cbmV4cG9ydCBjbGFzcyBGaXhlZFNpemVMaXN0VmVjdG9yPFQsIFRBcnJheSBleHRlbmRzIExpc3Q8VD4+IGV4dGVuZHMgVmVjdG9yPFRBcnJheT4ge1xuICAgIHJlYWRvbmx5IHNpemU6IG51bWJlcjtcbiAgICByZWFkb25seSB2YWx1ZXM6IFZlY3RvcjxUPjtcbiAgICBjb25zdHJ1Y3Rvcihhcmd2OiB7IHNpemU6IG51bWJlciwgdmFsdWVzOiBWZWN0b3I8VD4gfSkge1xuICAgICAgICBzdXBlcigpO1xuICAgICAgICB0aGlzLnNpemUgPSBhcmd2LnNpemU7XG4gICAgICAgIHRoaXMudmFsdWVzID0gYXJndi52YWx1ZXM7XG4gICAgfVxuICAgIGdldChpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHJldHVybiB0aGlzLnZhbHVlcy5zbGljZTxUQXJyYXk+KHRoaXMuc2l6ZSAqIGluZGV4LCB0aGlzLnNpemUgKiAoaW5kZXggKyAxKSk7XG4gICAgfVxuICAgIGNvbmNhdCguLi52ZWN0b3JzOiBWZWN0b3I8VEFycmF5PltdKTogVmVjdG9yPFRBcnJheT4ge1xuICAgICAgICByZXR1cm4gbmV3IFZpcnR1YWxWZWN0b3IoQXJyYXksIHRoaXMsIC4uLnZlY3RvcnMpO1xuICAgIH1cbn1cbiJdfQ== |
import { Vector } from './vector'; | ||
import { ValidityArgs } from './typed'; | ||
export declare class StructVector extends Vector<any[]> { | ||
protected vectors: Vector<any>[]; | ||
constructor(validity: ValidityArgs, ...vectors: Vector<any>[]); | ||
get(index: number): any[]; | ||
concat(vector: StructVector): any; | ||
export declare class StructVector<T = any> extends Vector<StructRow<T>> { | ||
readonly length: number; | ||
readonly columns: Vector[]; | ||
constructor(argv: { | ||
columns: Vector[]; | ||
}); | ||
get(index: number): StructRow<T>; | ||
col(name: string): Vector<any> | null; | ||
key(index: number): string | null; | ||
select(...columns: string[]): StructVector<any>; | ||
concat(...structs: Vector<StructRow<T>>[]): Vector<StructRow<T>>; | ||
toString(options?: any): string; | ||
} | ||
export declare class StructRow<T = any> extends Vector<T> { | ||
readonly row: number; | ||
readonly length: number; | ||
readonly table: StructVector<T>; | ||
[Symbol.toStringTag](): string; | ||
constructor(table: StructVector<T>, row: number); | ||
get(index: number): T | null; | ||
col(key: string): T | null; | ||
[Symbol.iterator](): IterableIterator<any>; | ||
concat(...rows: Vector<T>[]): Vector<T>; | ||
toArray(): any[]; | ||
toJSON(): any[]; | ||
toString(): string; | ||
toObject(): Record<string, T>; | ||
} |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -19,19 +20,107 @@ // or more contributor license agreements. See the NOTICE file | ||
const vector_1 = require("./vector"); | ||
const typed_1 = require("./typed"); | ||
const virtual_1 = require("./virtual"); | ||
class StructVector extends vector_1.Vector { | ||
constructor(validity, ...vectors) { | ||
constructor(argv) { | ||
super(); | ||
this.vectors = vectors; | ||
this.length = Math.max(0, ...vectors.map((v) => v.length)); | ||
validity && (this.validity = typed_1.BitVector.from(validity)); | ||
this.columns = argv.columns || []; | ||
} | ||
get(index) { | ||
return this.validity.get(index) ? this.vectors.map((v) => v.get(index)) : null; | ||
return new StructRow(this, index); | ||
} | ||
concat(vector) { | ||
return StructVector.from(this, this.length + vector.length, this.validity.concat(vector.validity), ...this.vectors.map((v, i) => v.concat(vector.vectors[i]))); | ||
col(name) { | ||
return this.columns.find((col) => col.name === name) || null; | ||
} | ||
key(index) { | ||
return this.columns[index] ? this.columns[index].name : null; | ||
} | ||
select(...columns) { | ||
return new StructVector({ columns: columns.map((name) => this.col(name)) }); | ||
} | ||
concat(...structs) { | ||
return new virtual_1.VirtualVector(Array, this, ...structs); | ||
} | ||
toString(options) { | ||
const index = typeof options === 'object' ? options && !!options.index | ||
: typeof options === 'boolean' ? !!options | ||
: false; | ||
const { length } = this; | ||
if (length <= 0) { | ||
return ''; | ||
} | ||
const rows = new Array(length + 1); | ||
const maxColumnWidths = []; | ||
rows[0] = this.columns.map((_, i) => this.key(i)); | ||
index && rows[0].unshift('Index'); | ||
for (let i = -1, n = rows.length - 1; ++i < n;) { | ||
rows[i + 1] = [...this.get(i)]; | ||
index && rows[i + 1].unshift(i); | ||
} | ||
// Pass one to convert to strings and count max column widths | ||
for (let i = -1, n = rows.length; ++i < n;) { | ||
const row = rows[i]; | ||
for (let j = -1, k = row.length; ++j < k;) { | ||
const val = row[j] = stringify(row[j]); | ||
maxColumnWidths[j] = !maxColumnWidths[j] | ||
? val.length | ||
: Math.max(maxColumnWidths[j], val.length); | ||
} | ||
} | ||
// Pass two to pad each one to max column width | ||
for (let i = -1, n = rows.length; ++i < n;) { | ||
const row = rows[i]; | ||
for (let j = -1, k = row.length; ++j < k;) { | ||
row[j] = leftPad(row[j], ' ', maxColumnWidths[j]); | ||
} | ||
rows[i] = row.join(', '); | ||
} | ||
return rows.join('\n'); | ||
} | ||
} | ||
exports.StructVector = StructVector; | ||
class StructRow extends vector_1.Vector { | ||
constructor(table, row) { | ||
super(); | ||
this.row = row; | ||
this.table = table; | ||
this.length = table.columns.length; | ||
} | ||
[Symbol.toStringTag]() { return 'Row'; } | ||
get(index) { | ||
const col = this.table.columns[index]; | ||
return col ? col.get(this.row) : null; | ||
} | ||
col(key) { | ||
const col = this.table.col(key); | ||
return col ? col.get(this.row) : null; | ||
} | ||
*[Symbol.iterator]() { | ||
const { row } = this; | ||
for (const col of this.table.columns) { | ||
yield col ? col.get(row) : null; | ||
} | ||
} | ||
concat(...rows) { | ||
return new virtual_1.VirtualVector(Array, this, ...rows); | ||
} | ||
toArray() { return [...this]; } | ||
toJSON() { return this.toArray(); } | ||
toString() { return JSON.stringify(this); } | ||
toObject() { | ||
const { row } = this, map = Object.create(null); | ||
for (const col of this.table.columns) { | ||
if (col && col.name) { | ||
map[col.name] = col.get(row); | ||
} | ||
} | ||
return map; | ||
} | ||
} | ||
exports.StructRow = StructRow; | ||
function leftPad(str, fill, n) { | ||
return (new Array(n + 1).join(fill) + str).slice(-1 * n); | ||
} | ||
function stringify(x) { | ||
return Array.isArray(x) ? JSON.stringify(x) : ArrayBuffer.isView(x) ? `[${x}]` : `${x}`; | ||
} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInZlY3Rvci9zdHJ1Y3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsNkRBQTZEO0FBQzdELCtEQUErRDtBQUMvRCx3REFBd0Q7QUFDeEQsNkRBQTZEO0FBQzdELG9EQUFvRDtBQUNwRCw2REFBNkQ7QUFDN0QsNkRBQTZEO0FBQzdELEVBQUU7QUFDRiwrQ0FBK0M7QUFDL0MsRUFBRTtBQUNGLDZEQUE2RDtBQUM3RCw4REFBOEQ7QUFDOUQseURBQXlEO0FBQ3pELDREQUE0RDtBQUM1RCwwREFBMEQ7QUFDMUQscUJBQXFCOztBQUVyQixxQ0FBa0M7QUFDbEMsbUNBQWtEO0FBRWxELGtCQUEwQixTQUFRLGVBQWE7SUFFM0MsWUFBWSxRQUFzQixFQUFFLEdBQUcsT0FBc0I7UUFDekQsS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEdBQUcsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUMzRCxRQUFRLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxHQUFHLGlCQUFTLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDM0QsQ0FBQztJQUNELEdBQUcsQ0FBQyxLQUFhO1FBQ2IsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDbkYsQ0FBQztJQUNELE1BQU0sQ0FBQyxNQUFvQjtRQUN2QixNQUFNLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQ3pCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sRUFDM0IsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxFQUNyQyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUM3RCxDQUFDO0lBQ04sQ0FBQztDQUNKO0FBbEJELG9DQWtCQyIsImZpbGUiOiJ2ZWN0b3Ivc3RydWN0LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLy8gTGljZW5zZWQgdG8gdGhlIEFwYWNoZSBTb2Z0d2FyZSBGb3VuZGF0aW9uIChBU0YpIHVuZGVyIG9uZVxuLy8gb3IgbW9yZSBjb250cmlidXRvciBsaWNlbnNlIGFncmVlbWVudHMuICBTZWUgdGhlIE5PVElDRSBmaWxlXG4vLyBkaXN0cmlidXRlZCB3aXRoIHRoaXMgd29yayBmb3IgYWRkaXRpb25hbCBpbmZvcm1hdGlvblxuLy8gcmVnYXJkaW5nIGNvcHlyaWdodCBvd25lcnNoaXAuICBUaGUgQVNGIGxpY2Vuc2VzIHRoaXMgZmlsZVxuLy8gdG8geW91IHVuZGVyIHRoZSBBcGFjaGUgTGljZW5zZSwgVmVyc2lvbiAyLjAgKHRoZVxuLy8gXCJMaWNlbnNlXCIpOyB5b3UgbWF5IG5vdCB1c2UgdGhpcyBmaWxlIGV4Y2VwdCBpbiBjb21wbGlhbmNlXG4vLyB3aXRoIHRoZSBMaWNlbnNlLiAgWW91IG1heSBvYnRhaW4gYSBjb3B5IG9mIHRoZSBMaWNlbnNlIGF0XG4vL1xuLy8gICBodHRwOi8vd3d3LmFwYWNoZS5vcmcvbGljZW5zZXMvTElDRU5TRS0yLjBcbi8vXG4vLyBVbmxlc3MgcmVxdWlyZWQgYnkgYXBwbGljYWJsZSBsYXcgb3IgYWdyZWVkIHRvIGluIHdyaXRpbmcsXG4vLyBzb2Z0d2FyZSBkaXN0cmlidXRlZCB1bmRlciB0aGUgTGljZW5zZSBpcyBkaXN0cmlidXRlZCBvbiBhblxuLy8gXCJBUyBJU1wiIEJBU0lTLCBXSVRIT1VUIFdBUlJBTlRJRVMgT1IgQ09ORElUSU9OUyBPRiBBTllcbi8vIEtJTkQsIGVpdGhlciBleHByZXNzIG9yIGltcGxpZWQuICBTZWUgdGhlIExpY2Vuc2UgZm9yIHRoZVxuLy8gc3BlY2lmaWMgbGFuZ3VhZ2UgZ292ZXJuaW5nIHBlcm1pc3Npb25zIGFuZCBsaW1pdGF0aW9uc1xuLy8gdW5kZXIgdGhlIExpY2Vuc2UuXG5cbmltcG9ydCB7IFZlY3RvciB9IGZyb20gJy4vdmVjdG9yJztcbmltcG9ydCB7IEJpdFZlY3RvciwgVmFsaWRpdHlBcmdzIH0gZnJvbSAnLi90eXBlZCc7XG5cbmV4cG9ydCBjbGFzcyBTdHJ1Y3RWZWN0b3IgZXh0ZW5kcyBWZWN0b3I8YW55W10+IHtcbiAgICBwcm90ZWN0ZWQgdmVjdG9yczogVmVjdG9yPGFueT5bXTtcbiAgICBjb25zdHJ1Y3Rvcih2YWxpZGl0eTogVmFsaWRpdHlBcmdzLCAuLi52ZWN0b3JzOiBWZWN0b3I8YW55PltdKSB7XG4gICAgICAgIHN1cGVyKCk7XG4gICAgICAgIHRoaXMudmVjdG9ycyA9IHZlY3RvcnM7XG4gICAgICAgIHRoaXMubGVuZ3RoID0gTWF0aC5tYXgoMCwgLi4udmVjdG9ycy5tYXAoKHYpID0+IHYubGVuZ3RoKSk7XG4gICAgICAgIHZhbGlkaXR5ICYmICh0aGlzLnZhbGlkaXR5ID0gQml0VmVjdG9yLmZyb20odmFsaWRpdHkpKTtcbiAgICB9XG4gICAgZ2V0KGluZGV4OiBudW1iZXIpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMudmFsaWRpdHkuZ2V0KGluZGV4KSA/IHRoaXMudmVjdG9ycy5tYXAoKHYpID0+IHYuZ2V0KGluZGV4KSkgOiBudWxsO1xuICAgIH1cbiAgICBjb25jYXQodmVjdG9yOiBTdHJ1Y3RWZWN0b3IpIHtcbiAgICAgICAgcmV0dXJuIFN0cnVjdFZlY3Rvci5mcm9tKHRoaXMsXG4gICAgICAgICAgICB0aGlzLmxlbmd0aCArIHZlY3Rvci5sZW5ndGgsXG4gICAgICAgICAgICB0aGlzLnZhbGlkaXR5LmNvbmNhdCh2ZWN0b3IudmFsaWRpdHkpLFxuICAgICAgICAgICAgLi4udGhpcy52ZWN0b3JzLm1hcCgodiwgaSkgPT4gdi5jb25jYXQodmVjdG9yLnZlY3RvcnNbaV0pKVxuICAgICAgICApO1xuICAgIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["vector/struct.ts"],"names":[],"mappings":"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","file":"vector/struct.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport { Vector } from './vector';\nimport { VirtualVector } from './virtual';\n\nexport class StructVector<T = any> extends Vector<StructRow<T>> {\n    readonly length: number;\n    readonly columns: Vector[];\n    constructor(argv: { columns: Vector[] }) {\n        super();\n        this.columns = argv.columns || [];\n    }\n    get(index: number): StructRow<T> {\n        return new StructRow(this, index);\n    }\n    col(name: string) {\n        return this.columns.find((col) => col.name === name) || null;\n    }\n    key(index: number) {\n        return this.columns[index] ? this.columns[index].name : null;\n    }\n    select(...columns: string[]) {\n        return new StructVector({ columns: columns.map((name) => this.col(name)!) });\n    }\n    concat(...structs: Vector<StructRow<T>>[]): Vector<StructRow<T>> {\n        return new VirtualVector(Array, this, ...structs as any[]);\n    }\n    toString(options?: any) {\n        const index = typeof options === 'object' ? options && !!options.index\n                    : typeof options === 'boolean' ? !!options\n                    : false;\n        const { length } = this;\n        if (length <= 0) { return ''; }\n        const rows = new Array(length + 1);\n        const maxColumnWidths = [] as number[];\n        rows[0] = this.columns.map((_, i) => this.key(i));\n        index && rows[0].unshift('Index');\n        for (let i = -1, n = rows.length - 1; ++i < n;) {\n            rows[i + 1] = [...this.get(i)!];\n            index && rows[i + 1].unshift(i);\n        }\n        // Pass one to convert to strings and count max column widths\n        for (let i = -1, n = rows.length; ++i < n;) {\n            const row = rows[i];\n            for (let j = -1, k = row.length; ++j < k;) {\n                const val = row[j] = stringify(row[j]);\n                maxColumnWidths[j] = !maxColumnWidths[j]\n                    ? val.length\n                    : Math.max(maxColumnWidths[j], val.length);\n            }\n        }\n        // Pass two to pad each one to max column width\n        for (let i = -1, n = rows.length; ++i < n;) {\n            const row = rows[i];\n            for (let j = -1, k = row.length; ++j < k;) {\n                row[j] = leftPad(row[j], ' ', maxColumnWidths[j]);\n            }\n            rows[i] = row.join(', ');\n        }\n        return rows.join('\\n');\n    }\n}\n\nexport class StructRow<T = any> extends Vector<T> {\n    readonly row: number;\n    readonly length: number;\n    readonly table: StructVector<T>;\n    [Symbol.toStringTag]() { return 'Row'; }\n    constructor(table: StructVector<T>, row: number) {\n        super();\n        this.row = row;\n        this.table = table;\n        this.length = table.columns.length;\n    }\n    get(index: number) {\n        const col = this.table.columns[index];\n        return col ? col.get(this.row) as T : null;\n    }\n    col(key: string) {\n        const col = this.table.col(key);\n        return col ? col.get(this.row) as T : null;\n    }\n    *[Symbol.iterator]() {\n        const { row } = this;\n        for (const col of this.table.columns) {\n            yield col ? col.get(row) : null;\n        }\n    }\n    concat(...rows: Vector<T>[]): Vector<T> {\n        return new VirtualVector(Array, this, ...rows as any[]);\n    }\n    toArray() { return [...this]; }\n    toJSON() { return this.toArray(); }\n    toString() { return JSON.stringify(this); }\n    toObject(): Record<string, T> {\n        const { row } = this, map = Object.create(null);\n        for (const col of this.table.columns) {\n            if (col && col.name) {\n                map[col.name] = col.get(row);\n            }\n        }\n        return map;\n    }\n}\n\nfunction leftPad(str: string, fill: string, n: number) {\n    return (new Array(n + 1).join(fill) + str).slice(-1 * n);\n}\n\nfunction stringify(x: any) {\n    return Array.isArray(x) ? JSON.stringify(x) : ArrayBuffer.isView(x) ? `[${x}]` : `${x}`;\n}\n"]} |
@@ -1,22 +0,14 @@ | ||
import * as Schema_ from '../format/Schema'; | ||
export import Type = Schema_.org.apache.arrow.flatbuf.Type; | ||
export import Field = Schema_.org.apache.arrow.flatbuf.Field; | ||
export declare function sliceToRangeArgs(length: number, start: number, end?: number): number[]; | ||
export declare class Vector<T> implements Iterable<T> { | ||
static defaultName: string; | ||
static defaultProps: Map<any, any>; | ||
static defaultType: string; | ||
static create<T = any>(field: Field, length: number, ...args: any[]): Vector<T>; | ||
static from<T = any>(source: Vector<T>, length: number, ...args: any[]): Vector<T>; | ||
name: string; | ||
type: string; | ||
length: number; | ||
stride: number; | ||
props: Map<PropertyKey, any>; | ||
protected validity: Vector<boolean>; | ||
get(index: number): T; | ||
concat(vector: Vector<T>): Vector<T>; | ||
slice<R = T>(start?: number, end?: number, batch?: number): Iterable<R>; | ||
protected range<R = T>(index: number, length: number, batch?: number): Iterable<R>; | ||
[Symbol.iterator](): IterableIterator<T>; | ||
export interface Vector<T = any> extends Iterable<T | null> { | ||
readonly name: string; | ||
readonly type: string; | ||
readonly length: number; | ||
readonly nullable: boolean; | ||
readonly nullCount: number; | ||
readonly metadata: Map<string, string>; | ||
get(index: number): T | null; | ||
concat(...vectors: Vector<T>[]): Vector<T>; | ||
slice<R = T[]>(start?: number, end?: number): R; | ||
} | ||
export declare class Vector<T = any> implements Vector<T> { | ||
[Symbol.iterator](): IterableIterator<T | null>; | ||
} |
@@ -0,1 +1,2 @@ | ||
"use strict"; | ||
// Licensed to the Apache Software Foundation (ASF) under one | ||
@@ -19,56 +20,11 @@ // or more contributor license agreements. See the NOTICE file | ||
const Schema_ = require("../format/Schema"); | ||
exports.Type = Schema_.org.apache.arrow.flatbuf.Type; | ||
exports.Field = Schema_.org.apache.arrow.flatbuf.Field; | ||
function sliceToRangeArgs(length, start, end) { | ||
let total = length, from = start || 0; | ||
let to = end === end && typeof end == 'number' ? end : total; | ||
if (to < 0) { | ||
to = total + to; | ||
} | ||
if (from < 0) { | ||
from = total - (from * -1) % total; | ||
} | ||
if (to < from) { | ||
from = to; | ||
to = start; | ||
} | ||
total = !isFinite(total = (to - from)) || total < 0 ? 0 : total; | ||
return [from, total]; | ||
} | ||
exports.sliceToRangeArgs = sliceToRangeArgs; | ||
var Type = Schema_.org.apache.arrow.flatbuf.Type; | ||
class Vector { | ||
static create(field, length, ...args) { | ||
let vector = new this(...args), m; | ||
vector.length = length; | ||
vector.name = field.name(); | ||
vector.type = exports.Type[field.typeType()]; | ||
if ((m = field.customMetadataLength()) > 0) { | ||
let entry, i = 0, data = vector.props = new Map(); | ||
do { | ||
entry = field.customMetadata(i); | ||
data[entry.key()] = entry.value(); | ||
} while (++i < m); | ||
slice(start, end) { | ||
let { length } = this, from = start | 0; | ||
let to = end === undefined ? length : Math.max(end | 0, from); | ||
let result = new Array(to - Math.min(from, to)); | ||
for (let i = -1, n = result.length; ++i < n;) { | ||
result[i] = this.get(i + from); | ||
} | ||
return vector; | ||
} | ||
static from(source, length, ...args) { | ||
let vector = new this(...args); | ||
vector.length = length; | ||
source.name !== Vector.defaultName && (vector.name = source.name); | ||
source.type !== Vector.defaultType && (vector.type = source.type); | ||
source.props !== Vector.defaultProps && (vector.props = source.props); | ||
return vector; | ||
} | ||
get(index) { return null; } | ||
concat(vector) { return vector; } | ||
slice(start, end, batch) { | ||
const { stride } = this; | ||
const [offset, length] = sliceToRangeArgs(stride * this.length, stride * (start || 0), stride * end); | ||
return this.range(offset, length, batch); | ||
} | ||
range(index, length, batch) { | ||
const result = new Array(length); | ||
for (let i = -1, n = this.length; ++i < length;) { | ||
result[i] = this.get((i + index) % n); | ||
} | ||
return result; | ||
@@ -82,12 +38,10 @@ } | ||
} | ||
Vector.defaultName = ''; | ||
Vector.defaultProps = new Map(); | ||
Vector.defaultType = exports.Type[exports.Type.NONE]; | ||
exports.Vector = Vector; | ||
Vector.prototype.length = 0; | ||
Vector.prototype.name = ''; | ||
Vector.prototype.stride = 1; | ||
Vector.prototype.name = Vector.defaultName; | ||
Vector.prototype.type = Vector.defaultType; | ||
Vector.prototype.props = Vector.defaultProps; | ||
Vector.prototype.nullable = !1; | ||
Vector.prototype.nullCount = 0; | ||
Vector.prototype.metadata = new Map(); | ||
Vector.prototype.type = Type[Type.NONE]; | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["vector/vector.ts"],"names":[],"mappings":"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","file":"vector/vector.js","sourcesContent":["// Licensed to the Apache Software Foundation (ASF) under one\n// or more contributor license agreements.  See the NOTICE file\n// distributed with this work for additional information\n// regarding copyright ownership.  The ASF licenses this file\n// to you under the Apache License, Version 2.0 (the\n// \"License\"); you may not use this file except in compliance\n// with the License.  You may obtain a copy of the License at\n//\n//   http://www.apache.org/licenses/LICENSE-2.0\n//\n// Unless required by applicable law or agreed to in writing,\n// software distributed under the License is distributed on an\n// \"AS IS\" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n// KIND, either express or implied.  See the License for the\n// specific language governing permissions and limitations\n// under the License.\n\nimport * as Schema_ from '../format/Schema';\nexport import Type = Schema_.org.apache.arrow.flatbuf.Type;\nexport import Field = Schema_.org.apache.arrow.flatbuf.Field;\n\nexport function sliceToRangeArgs(length: number, start: number, end?: number) {\n    let total = length, from = start || 0;\n    let to = end === end && typeof end == 'number' ? end : total;\n    if (to < 0) { to = total + to; }\n    if (from < 0) { from = total - (from * -1) % total; }\n    if (to < from) { from = to; to = start; }\n    total = !isFinite(total = (to - from)) || total < 0 ? 0 : total;\n    return [from, total];\n}\n\nexport class Vector<T> implements Iterable<T> {\n    static defaultName = '';\n    static defaultProps = new Map();\n    static defaultType = Type[Type.NONE];\n    static create<T = any>(field: Field, length: number, ...args: any[]) {\n        let vector = new this<T>(...args), m;\n        vector.length = length;\n        vector.name = field.name();\n        vector.type = Type[field.typeType()];\n        if ((m = field.customMetadataLength()) > 0) {\n            let entry, i = 0, data = vector.props = new Map();\n            do {\n                entry = field.customMetadata(i);\n                data[entry.key()] = entry.value();\n            } while (++i < m);\n        }\n        return vector;\n    }\n    static from<T = any>(source: Vector<T>, length: number, ...args: any[]) {\n        let vector = new this<T>(...args);\n        vector.length = length;\n        source.name !== Vector.defaultName && (vector.name = source.name);\n        source.type !== Vector.defaultType && (vector.type = source.type);\n        source.props !== Vector.defaultProps && (vector.props = source.props);\n        return vector;\n    }\n    public name: string;\n    public type: string;\n    public length: number;\n    public stride: number;\n    public props: Map<PropertyKey, any>;\n    protected validity: Vector<boolean>;\n    get(index: number): T { return null; }\n    concat(vector: Vector<T>) { return vector; }\n    slice<R = T>(start?: number, end?: number, batch?: number) {\n        const { stride } = this;\n        const [offset, length] = sliceToRangeArgs(\n            stride * this.length, stride * (start || 0), stride * end\n        );\n        return this.range<R>(offset, length, batch);\n    }\n    protected range<R = T>(index: number, length: number, batch?: number) {\n        const result = new Array<R>(length);\n        for (let i = -1, n = this.length; ++i < length;) {\n            result[i] = this.get((i + index) % n) as any;\n        }\n        return result as Iterable<R>;\n    }\n    *[Symbol.iterator]() {\n        for (let i = -1, n = this.length; ++i < n;) {\n            yield this.get(i);\n        }\n    }\n}\n\nVector.prototype.length = 0;\nVector.prototype.stride = 1;\nVector.prototype.name = Vector.defaultName;\nVector.prototype.type = Vector.defaultType;\nVector.prototype.props = Vector.defaultProps;\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInZlY3Rvci92ZWN0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDZEQUE2RDtBQUM3RCwrREFBK0Q7QUFDL0Qsd0RBQXdEO0FBQ3hELDZEQUE2RDtBQUM3RCxvREFBb0Q7QUFDcEQsNkRBQTZEO0FBQzdELDZEQUE2RDtBQUM3RCxFQUFFO0FBQ0YsK0NBQStDO0FBQy9DLEVBQUU7QUFDRiw2REFBNkQ7QUFDN0QsOERBQThEO0FBQzlELHlEQUF5RDtBQUN6RCw0REFBNEQ7QUFDNUQsMERBQTBEO0FBQzFELHFCQUFxQjs7QUFFckIsNENBQTRDO0FBQzVDLElBQU8sSUFBSSxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO0FBYXBEO0lBQ0ksS0FBSyxDQUFVLEtBQWMsRUFBRSxHQUFZO1FBQ3ZDLElBQUksRUFBRSxNQUFNLEVBQUUsR0FBRyxJQUFJLEVBQUUsSUFBSSxHQUFHLEtBQU0sR0FBRyxDQUFDLENBQUM7UUFDekMsSUFBSSxFQUFFLEdBQUcsR0FBRyxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsR0FBRyxDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDOUQsSUFBSSxNQUFNLEdBQUcsSUFBSSxLQUFLLENBQVcsRUFBRSxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDMUQsR0FBRyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLE1BQU0sQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUM7WUFDM0MsTUFBTSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1FBQ25DLENBQUM7UUFDRCxNQUFNLENBQUMsTUFBYSxDQUFDO0lBQ3pCLENBQUM7SUFDRCxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNkLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDO1lBQ3pDLE1BQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUN0QixDQUFDO0lBQ0wsQ0FBQztDQUNKO0FBZkQsd0JBZUM7QUFFQSxNQUFNLENBQUMsU0FBaUIsQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDO0FBQ25DLE1BQU0sQ0FBQyxTQUFpQixDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7QUFDcEMsTUFBTSxDQUFDLFNBQWlCLENBQUMsUUFBUSxHQUFHLENBQUMsQ0FBQyxDQUFDO0FBQ3ZDLE1BQU0sQ0FBQyxTQUFpQixDQUFDLFNBQVMsR0FBRyxDQUFDLENBQUM7QUFDdkMsTUFBTSxDQUFDLFNBQWlCLENBQUMsUUFBUSxHQUFHLElBQUksR0FBRyxFQUFFLENBQUM7QUFDOUMsTUFBTSxDQUFDLFNBQWlCLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMiLCJmaWxlIjoidmVjdG9yL3ZlY3Rvci5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIExpY2Vuc2VkIHRvIHRoZSBBcGFjaGUgU29mdHdhcmUgRm91bmRhdGlvbiAoQVNGKSB1bmRlciBvbmVcbi8vIG9yIG1vcmUgY29udHJpYnV0b3IgbGljZW5zZSBhZ3JlZW1lbnRzLiAgU2VlIHRoZSBOT1RJQ0UgZmlsZVxuLy8gZGlzdHJpYnV0ZWQgd2l0aCB0aGlzIHdvcmsgZm9yIGFkZGl0aW9uYWwgaW5mb3JtYXRpb25cbi8vIHJlZ2FyZGluZyBjb3B5cmlnaHQgb3duZXJzaGlwLiAgVGhlIEFTRiBsaWNlbnNlcyB0aGlzIGZpbGVcbi8vIHRvIHlvdSB1bmRlciB0aGUgQXBhY2hlIExpY2Vuc2UsIFZlcnNpb24gMi4wICh0aGVcbi8vIFwiTGljZW5zZVwiKTsgeW91IG1heSBub3QgdXNlIHRoaXMgZmlsZSBleGNlcHQgaW4gY29tcGxpYW5jZVxuLy8gd2l0aCB0aGUgTGljZW5zZS4gIFlvdSBtYXkgb2J0YWluIGEgY29weSBvZiB0aGUgTGljZW5zZSBhdFxuLy9cbi8vICAgaHR0cDovL3d3dy5hcGFjaGUub3JnL2xpY2Vuc2VzL0xJQ0VOU0UtMi4wXG4vL1xuLy8gVW5sZXNzIHJlcXVpcmVkIGJ5IGFwcGxpY2FibGUgbGF3IG9yIGFncmVlZCB0byBpbiB3cml0aW5nLFxuLy8gc29mdHdhcmUgZGlzdHJpYnV0ZWQgdW5kZXIgdGhlIExpY2Vuc2UgaXMgZGlzdHJpYnV0ZWQgb24gYW5cbi8vIFwiQVMgSVNcIiBCQVNJUywgV0lUSE9VVCBXQVJSQU5USUVTIE9SIENPTkRJVElPTlMgT0YgQU5ZXG4vLyBLSU5ELCBlaXRoZXIgZXhwcmVzcyBvciBpbXBsaWVkLiAgU2VlIHRoZSBMaWNlbnNlIGZvciB0aGVcbi8vIHNwZWNpZmljIGxhbmd1YWdlIGdvdmVybmluZyBwZXJtaXNzaW9ucyBhbmQgbGltaXRhdGlvbnNcbi8vIHVuZGVyIHRoZSBMaWNlbnNlLlxuXG5pbXBvcnQgKiBhcyBTY2hlbWFfIGZyb20gJy4uL2Zvcm1hdC9TY2hlbWEnO1xuaW1wb3J0IFR5cGUgPSBTY2hlbWFfLm9yZy5hcGFjaGUuYXJyb3cuZmxhdGJ1Zi5UeXBlO1xuXG5leHBvcnQgaW50ZXJmYWNlIFZlY3RvcjxUID0gYW55PiBleHRlbmRzIEl0ZXJhYmxlPFQgfCBudWxsPiB7XG4gICAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICAgIHJlYWRvbmx5IHR5cGU6IHN0cmluZztcbiAgICByZWFkb25seSBsZW5ndGg6IG51bWJlcjtcbiAgICByZWFkb25seSBudWxsYWJsZTogYm9vbGVhbjtcbiAgICByZWFkb25seSBudWxsQ291bnQ6IG51bWJlcjtcbiAgICByZWFkb25seSBtZXRhZGF0YTogTWFwPHN0cmluZywgc3RyaW5nPjtcbiAgICBnZXQoaW5kZXg6IG51bWJlcik6IFQgfCBudWxsO1xuICAgIGNvbmNhdCguLi52ZWN0b3JzOiBWZWN0b3I8VD5bXSk6IFZlY3RvcjxUPjtcbiAgICBzbGljZTxSID0gVFtdPihzdGFydD86IG51bWJlciwgZW5kPzogbnVtYmVyKTogUjtcbn1cbmV4cG9ydCBjbGFzcyBWZWN0b3I8VCA9IGFueT4gaW1wbGVtZW50cyBWZWN0b3I8VD4ge1xuICAgIHNsaWNlPFIgPSBUW10+KHN0YXJ0PzogbnVtYmVyLCBlbmQ/OiBudW1iZXIpOiBSIHtcbiAgICAgICAgbGV0IHsgbGVuZ3RoIH0gPSB0aGlzLCBmcm9tID0gc3RhcnQhIHwgMDtcbiAgICAgICAgbGV0IHRvID0gZW5kID09PSB1bmRlZmluZWQgPyBsZW5ndGggOiBNYXRoLm1heChlbmQgfCAwLCBmcm9tKTtcbiAgICAgICAgbGV0IHJlc3VsdCA9IG5ldyBBcnJheTxUIHwgbnVsbD4odG8gLSBNYXRoLm1pbihmcm9tLCB0bykpO1xuICAgICAgICBmb3IgKGxldCBpID0gLTEsIG4gPSByZXN1bHQubGVuZ3RoOyArK2kgPCBuOykge1xuICAgICAgICAgICAgcmVzdWx0W2ldID0gdGhpcy5nZXQoaSArIGZyb20pO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiByZXN1bHQgYXMgYW55O1xuICAgIH1cbiAgICAqW1N5bWJvbC5pdGVyYXRvcl0oKSB7XG4gICAgICAgIGZvciAobGV0IGkgPSAtMSwgbiA9IHRoaXMubGVuZ3RoOyArK2kgPCBuOykge1xuICAgICAgICAgICAgeWllbGQgdGhpcy5nZXQoaSk7XG4gICAgICAgIH1cbiAgICB9XG59XG5cbihWZWN0b3IucHJvdG90eXBlIGFzIGFueSkubmFtZSA9ICcnO1xuKFZlY3Rvci5wcm90b3R5cGUgYXMgYW55KS5zdHJpZGUgPSAxO1xuKFZlY3Rvci5wcm90b3R5cGUgYXMgYW55KS5udWxsYWJsZSA9ICExO1xuKFZlY3Rvci5wcm90b3R5cGUgYXMgYW55KS5udWxsQ291bnQgPSAwO1xuKFZlY3Rvci5wcm90b3R5cGUgYXMgYW55KS5tZXRhZGF0YSA9IG5ldyBNYXAoKTtcbihWZWN0b3IucHJvdG90eXBlIGFzIGFueSkudHlwZSA9IFR5cGVbVHlwZS5OT05FXTtcbiJdfQ== |
Sorry, the diff of this file is too big to display
GitHub dependency
Supply chain riskContains a dependency which resolves to a GitHub URL. Dependencies fetched from GitHub specifiers are not immutable can be used to inject untrusted code or reduce the likelihood of a reproducible install.
Found 1 instance in 1 package
Manifest confusion
Supply chain riskThis package has inconsistent metadata. This could be malicious or caused by an error when publishing the package.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
Mixed license
License(Experimental) Package contains multiple licenses.
Found 1 instance in 1 package
Unidentified License
License(Experimental) Something that seems like a license was found, but its contents could not be matched with a known license.
Found 1 instance in 1 package
705353
8892
212
3
2
80
1
3
+ Addedtext-encoding-utf-8@^1.0.2
+ Addedtslib@^1.8.0
+ Addedtext-encoding-utf-8@1.0.2(transitive)