@loaders.gl/schema 4.0.0-alpha.4 → 4.0.0-alpha.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/bundle.d.ts +2 -0
- package/dist/bundle.d.ts.map +1 -0
- package/dist/bundle.js +2 -2
- package/dist/dist.min.js +13589 -0
- package/dist/es5/bundle.js +6 -0
- package/dist/es5/bundle.js.map +1 -0
- package/dist/es5/index.js +406 -0
- package/dist/es5/index.js.map +1 -0
- package/dist/es5/lib/mesh/convert-mesh.js +34 -0
- package/dist/es5/lib/mesh/convert-mesh.js.map +1 -0
- package/dist/es5/lib/mesh/deduce-mesh-schema.js +56 -0
- package/dist/es5/lib/mesh/deduce-mesh-schema.js.map +1 -0
- package/dist/es5/lib/mesh/mesh-to-arrow-table.js +2 -0
- package/dist/es5/lib/mesh/mesh-to-arrow-table.js.map +1 -0
- package/dist/es5/lib/mesh/mesh-utils.js +40 -0
- package/dist/es5/lib/mesh/mesh-utils.js.map +1 -0
- package/dist/es5/lib/table/arrow/arrow-type-utils.js +30 -0
- package/dist/es5/lib/table/arrow/arrow-type-utils.js.map +1 -0
- package/dist/es5/lib/table/arrow/convert-schema-arrow.js +179 -0
- package/dist/es5/lib/table/arrow/convert-schema-arrow.js.map +1 -0
- package/dist/es5/lib/table/arrow/convert-table-to-arrow.js +2 -0
- package/dist/es5/lib/table/arrow/convert-table-to-arrow.js.map +1 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-field.js +49 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-field.js.map +1 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-schema.js +118 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-schema.js.map +1 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-table.js +80 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-table.js.map +1 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-type.js +740 -0
- package/dist/es5/lib/table/arrow-api/arrow-like-type.js.map +1 -0
- package/dist/es5/lib/table/arrow-api/enum.js +55 -0
- package/dist/es5/lib/table/arrow-api/enum.js.map +1 -0
- package/dist/es5/lib/table/arrow-api/get-type-info.js +27 -0
- package/dist/es5/lib/table/arrow-api/get-type-info.js.map +1 -0
- package/dist/es5/lib/table/arrow-api/index.js +44 -0
- package/dist/es5/lib/table/arrow-api/index.js.map +1 -0
- package/dist/es5/lib/table/batches/base-table-batch-aggregator.js +78 -0
- package/dist/es5/lib/table/batches/base-table-batch-aggregator.js.map +1 -0
- package/dist/es5/lib/table/batches/columnar-table-batch-aggregator.js +106 -0
- package/dist/es5/lib/table/batches/columnar-table-batch-aggregator.js.map +1 -0
- package/dist/es5/lib/table/batches/row-table-batch-aggregator.js +96 -0
- package/dist/es5/lib/table/batches/row-table-batch-aggregator.js.map +1 -0
- package/dist/es5/lib/table/batches/table-batch-aggregator.js +2 -0
- package/dist/es5/lib/table/batches/table-batch-aggregator.js.map +1 -0
- package/dist/es5/lib/table/batches/table-batch-builder.js +173 -0
- package/dist/es5/lib/table/batches/table-batch-builder.js.map +1 -0
- package/dist/es5/lib/table/simple-table/convert-table.js +82 -0
- package/dist/es5/lib/table/simple-table/convert-table.js.map +1 -0
- package/dist/es5/lib/table/simple-table/data-type.js +94 -0
- package/dist/es5/lib/table/simple-table/data-type.js.map +1 -0
- package/dist/es5/lib/table/simple-table/make-table.js +60 -0
- package/dist/es5/lib/table/simple-table/make-table.js.map +1 -0
- package/dist/es5/lib/table/simple-table/row-utils.js +34 -0
- package/dist/es5/lib/table/simple-table/row-utils.js.map +1 -0
- package/dist/es5/lib/table/simple-table/table-accessors.js +343 -0
- package/dist/es5/lib/table/simple-table/table-accessors.js.map +1 -0
- package/dist/es5/lib/table/simple-table/table-column.js +12 -0
- package/dist/es5/lib/table/simple-table/table-column.js.map +1 -0
- package/dist/es5/lib/table/simple-table/table-schema.js +85 -0
- package/dist/es5/lib/table/simple-table/table-schema.js.map +1 -0
- package/dist/es5/lib/utils/assert.js +12 -0
- package/dist/es5/lib/utils/assert.js.map +1 -0
- package/dist/es5/lib/utils/async-queue.js +169 -0
- package/dist/es5/lib/utils/async-queue.js.map +1 -0
- package/dist/es5/types/category-gis.js +2 -0
- package/dist/es5/types/category-gis.js.map +1 -0
- package/dist/es5/types/category-image.js +2 -0
- package/dist/es5/types/category-image.js.map +1 -0
- package/dist/es5/types/category-mesh.js +2 -0
- package/dist/es5/types/category-mesh.js.map +1 -0
- package/dist/es5/types/category-table.js +2 -0
- package/dist/es5/types/category-table.js.map +1 -0
- package/dist/es5/types/category-texture.js +2 -0
- package/dist/es5/types/category-texture.js.map +1 -0
- package/dist/es5/types/schema.js +2 -0
- package/dist/es5/types/schema.js.map +1 -0
- package/dist/es5/types/types.js +2 -0
- package/dist/es5/types/types.js.map +1 -0
- package/dist/esm/bundle.js +4 -0
- package/dist/esm/bundle.js.map +1 -0
- package/dist/esm/index.js +16 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/{category → esm/lib}/mesh/convert-mesh.js +0 -11
- package/dist/esm/lib/mesh/convert-mesh.js.map +1 -0
- package/dist/esm/lib/mesh/deduce-mesh-schema.js +48 -0
- package/dist/esm/lib/mesh/deduce-mesh-schema.js.map +1 -0
- package/dist/esm/lib/mesh/mesh-to-arrow-table.js +2 -0
- package/dist/esm/lib/mesh/mesh-to-arrow-table.js.map +1 -0
- package/dist/{category → esm/lib}/mesh/mesh-utils.js +0 -5
- package/dist/esm/lib/mesh/mesh-utils.js.map +1 -0
- package/dist/{lib/arrow/arrow-like-type-utils.js → esm/lib/table/arrow/arrow-type-utils.js} +3 -11
- package/dist/esm/lib/table/arrow/arrow-type-utils.js.map +1 -0
- package/dist/esm/lib/table/arrow/convert-schema-arrow.js +158 -0
- package/dist/esm/lib/table/arrow/convert-schema-arrow.js.map +1 -0
- package/dist/esm/lib/table/arrow/convert-table-to-arrow.js +2 -0
- package/dist/esm/lib/table/arrow/convert-table-to-arrow.js.map +1 -0
- package/dist/{lib/schema/impl/field.js → esm/lib/table/arrow-api/arrow-like-field.js} +6 -13
- package/dist/esm/lib/table/arrow-api/arrow-like-field.js.map +1 -0
- package/dist/{lib/schema/impl/schema.js → esm/lib/table/arrow-api/arrow-like-schema.js} +22 -47
- package/dist/esm/lib/table/arrow-api/arrow-like-schema.js.map +1 -0
- package/dist/esm/lib/table/arrow-api/arrow-like-table.js +51 -0
- package/dist/esm/lib/table/arrow-api/arrow-like-table.js.map +1 -0
- package/dist/{lib/schema/impl/type.js → esm/lib/table/arrow-api/arrow-like-type.js} +11 -116
- package/dist/esm/lib/table/arrow-api/arrow-like-type.js.map +1 -0
- package/dist/{lib/schema/impl → esm/lib/table/arrow-api}/enum.js +3 -4
- package/dist/esm/lib/table/arrow-api/enum.js.map +1 -0
- package/dist/{lib/arrow → esm/lib/table/arrow-api}/get-type-info.js +1 -4
- package/dist/esm/lib/table/arrow-api/get-type-info.js.map +1 -0
- package/dist/esm/lib/table/arrow-api/index.js +5 -0
- package/dist/esm/lib/table/arrow-api/index.js.map +1 -0
- package/dist/{lib → esm/lib/table}/batches/base-table-batch-aggregator.js +1 -18
- package/dist/esm/lib/table/batches/base-table-batch-aggregator.js.map +1 -0
- package/dist/{lib → esm/lib/table}/batches/columnar-table-batch-aggregator.js +1 -24
- package/dist/esm/lib/table/batches/columnar-table-batch-aggregator.js.map +1 -0
- package/dist/{lib → esm/lib/table}/batches/row-table-batch-aggregator.js +2 -22
- package/dist/esm/lib/table/batches/row-table-batch-aggregator.js.map +1 -0
- package/dist/esm/lib/table/batches/table-batch-aggregator.js.map +1 -0
- package/dist/{lib → esm/lib/table}/batches/table-batch-builder.js +6 -49
- package/dist/esm/lib/table/batches/table-batch-builder.js.map +1 -0
- package/dist/esm/lib/table/simple-table/convert-table.js +59 -0
- package/dist/esm/lib/table/simple-table/convert-table.js.map +1 -0
- package/dist/esm/lib/table/simple-table/data-type.js +85 -0
- package/dist/esm/lib/table/simple-table/data-type.js.map +1 -0
- package/dist/esm/lib/table/simple-table/make-table.js +50 -0
- package/dist/esm/lib/table/simple-table/make-table.js.map +1 -0
- package/dist/{lib/utils → esm/lib/table/simple-table}/row-utils.js +0 -8
- package/dist/esm/lib/table/simple-table/row-utils.js.map +1 -0
- package/dist/esm/lib/table/simple-table/table-accessors.js +262 -0
- package/dist/esm/lib/table/simple-table/table-accessors.js.map +1 -0
- package/dist/esm/lib/table/simple-table/table-column.js +6 -0
- package/dist/esm/lib/table/simple-table/table-column.js.map +1 -0
- package/dist/esm/lib/table/simple-table/table-schema.js +70 -0
- package/dist/esm/lib/table/simple-table/table-schema.js.map +1 -0
- package/dist/esm/lib/utils/assert.js +6 -0
- package/dist/esm/lib/utils/assert.js.map +1 -0
- package/dist/esm/lib/utils/async-queue.js +94 -0
- package/dist/esm/lib/utils/async-queue.js.map +1 -0
- package/dist/esm/types/category-gis.js +2 -0
- package/dist/esm/types/category-gis.js.map +1 -0
- package/dist/esm/types/category-image.js +2 -0
- package/dist/esm/types/category-image.js.map +1 -0
- package/dist/esm/types/category-mesh.js +2 -0
- package/dist/esm/types/category-mesh.js.map +1 -0
- package/dist/esm/types/category-table.js +2 -0
- package/dist/esm/types/category-table.js.map +1 -0
- package/dist/esm/types/category-texture.js +2 -0
- package/dist/esm/types/category-texture.js.map +1 -0
- package/dist/esm/types/schema.js +2 -0
- package/dist/esm/types/schema.js.map +1 -0
- package/dist/esm/types/types.js.map +1 -0
- package/dist/index.d.ts +29 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +92 -13
- package/dist/lib/mesh/convert-mesh.d.ts +15 -0
- package/dist/lib/mesh/convert-mesh.d.ts.map +1 -0
- package/dist/lib/mesh/convert-mesh.js +40 -0
- package/dist/lib/mesh/deduce-mesh-schema.d.ts +24 -0
- package/dist/lib/mesh/deduce-mesh-schema.d.ts.map +1 -0
- package/dist/lib/mesh/deduce-mesh-schema.js +66 -0
- package/dist/lib/mesh/mesh-to-arrow-table.d.ts +1 -0
- package/dist/lib/mesh/mesh-to-arrow-table.d.ts.map +1 -0
- package/dist/lib/mesh/mesh-to-arrow-table.js +44 -0
- package/dist/lib/mesh/mesh-utils.d.ts +23 -0
- package/dist/lib/mesh/mesh-utils.d.ts.map +1 -0
- package/dist/lib/mesh/mesh-utils.js +51 -0
- package/dist/lib/table/arrow/arrow-type-utils.d.ts +4 -0
- package/dist/lib/table/arrow/arrow-type-utils.d.ts.map +1 -0
- package/dist/lib/table/arrow/arrow-type-utils.js +53 -0
- package/dist/lib/table/arrow/convert-schema-arrow.d.ts +13 -0
- package/dist/lib/table/arrow/convert-schema-arrow.d.ts.map +1 -0
- package/dist/lib/table/arrow/convert-schema-arrow.js +187 -0
- package/dist/lib/table/arrow/convert-table-to-arrow.d.ts +42 -0
- package/dist/lib/table/arrow/convert-table-to-arrow.d.ts.map +1 -0
- package/dist/lib/table/arrow/convert-table-to-arrow.js +57 -0
- package/dist/lib/table/arrow-api/arrow-like-field.d.ts +19 -0
- package/dist/lib/table/arrow-api/arrow-like-field.d.ts.map +1 -0
- package/dist/lib/table/arrow-api/arrow-like-field.js +34 -0
- package/dist/lib/table/arrow-api/arrow-like-schema.d.ts +12 -0
- package/dist/lib/table/arrow-api/arrow-like-schema.d.ts.map +1 -0
- package/dist/lib/table/arrow-api/arrow-like-schema.js +81 -0
- package/dist/lib/table/arrow-api/arrow-like-table.d.ts +28 -0
- package/dist/lib/table/arrow-api/arrow-like-table.d.ts.map +1 -0
- package/dist/lib/table/arrow-api/arrow-like-table.js +53 -0
- package/dist/lib/table/arrow-api/arrow-like-type.d.ts +177 -0
- package/dist/lib/table/arrow-api/arrow-like-type.d.ts.map +1 -0
- package/dist/lib/table/arrow-api/arrow-like-type.js +463 -0
- package/dist/lib/table/arrow-api/enum.d.ts +92 -0
- package/dist/lib/table/arrow-api/enum.d.ts.map +1 -0
- package/dist/lib/table/arrow-api/enum.js +97 -0
- package/dist/lib/table/arrow-api/get-type-info.d.ts +13 -0
- package/dist/lib/table/arrow-api/get-type-info.d.ts.map +1 -0
- package/dist/lib/table/arrow-api/get-type-info.js +29 -0
- package/dist/lib/table/arrow-api/index.d.ts +5 -0
- package/dist/lib/table/arrow-api/index.d.ts.map +1 -0
- package/dist/lib/table/arrow-api/index.js +25 -0
- package/dist/lib/table/batches/base-table-batch-aggregator.d.ts +19 -0
- package/dist/lib/table/batches/base-table-batch-aggregator.d.ts.map +1 -0
- package/dist/lib/table/batches/base-table-batch-aggregator.js +60 -0
- package/dist/lib/table/batches/columnar-table-batch-aggregator.d.ts +23 -0
- package/dist/lib/table/batches/columnar-table-batch-aggregator.d.ts.map +1 -0
- package/dist/lib/table/batches/columnar-table-batch-aggregator.js +92 -0
- package/dist/lib/table/batches/row-table-batch-aggregator.d.ts +22 -0
- package/dist/lib/table/batches/row-table-batch-aggregator.d.ts.map +1 -0
- package/dist/lib/table/batches/row-table-batch-aggregator.js +81 -0
- package/dist/lib/table/batches/table-batch-aggregator.d.ts +25 -0
- package/dist/lib/table/batches/table-batch-aggregator.d.ts.map +1 -0
- package/dist/lib/table/batches/table-batch-aggregator.js +3 -0
- package/dist/lib/table/batches/table-batch-builder.d.ts +53 -0
- package/dist/lib/table/batches/table-batch-builder.d.ts.map +1 -0
- package/dist/lib/table/batches/table-batch-builder.js +152 -0
- package/dist/lib/table/simple-table/convert-table.d.ts +8 -0
- package/dist/lib/table/simple-table/convert-table.d.ts.map +1 -0
- package/dist/lib/table/simple-table/convert-table.js +65 -0
- package/dist/lib/table/simple-table/data-type.d.ts +17 -0
- package/dist/lib/table/simple-table/data-type.d.ts.map +1 -0
- package/dist/lib/table/simple-table/data-type.js +93 -0
- package/dist/lib/table/simple-table/make-table.d.ts +65 -0
- package/dist/lib/table/simple-table/make-table.d.ts.map +1 -0
- package/dist/lib/table/simple-table/make-table.js +95 -0
- package/dist/lib/table/simple-table/row-utils.d.ts +9 -0
- package/dist/lib/table/simple-table/row-utils.d.ts.map +1 -0
- package/dist/lib/table/simple-table/row-utils.js +33 -0
- package/dist/lib/table/simple-table/table-accessors.d.ts +67 -0
- package/dist/lib/table/simple-table/table-accessors.d.ts.map +1 -0
- package/dist/lib/table/simple-table/table-accessors.js +319 -0
- package/dist/lib/table/simple-table/table-column.d.ts +7 -0
- package/dist/lib/table/simple-table/table-column.d.ts.map +1 -0
- package/dist/lib/table/simple-table/table-column.js +41 -0
- package/dist/lib/table/simple-table/table-schema.d.ts +15 -0
- package/dist/lib/table/simple-table/table-schema.d.ts.map +1 -0
- package/dist/lib/table/simple-table/table-schema.js +85 -0
- package/dist/lib/utils/assert.d.ts +2 -0
- package/dist/lib/utils/assert.d.ts.map +1 -0
- package/dist/lib/utils/assert.js +11 -5
- package/dist/lib/utils/async-queue.d.ts +18 -0
- package/dist/lib/utils/async-queue.d.ts.map +1 -0
- package/dist/lib/utils/async-queue.js +82 -109
- package/dist/types/category-gis.d.ts +99 -0
- package/dist/types/category-gis.d.ts.map +1 -0
- package/dist/types/category-gis.js +2 -0
- package/dist/types/category-image.d.ts +18 -0
- package/dist/types/category-image.d.ts.map +1 -0
- package/dist/types/category-image.js +2 -0
- package/dist/types/category-mesh.d.ts +48 -0
- package/dist/types/category-mesh.d.ts.map +1 -0
- package/dist/types/category-mesh.js +3 -0
- package/dist/types/category-table.d.ts +86 -0
- package/dist/types/category-table.d.ts.map +1 -0
- package/dist/types/category-table.js +3 -0
- package/dist/types/category-texture.d.ts +18 -0
- package/dist/types/category-texture.d.ts.map +1 -0
- package/dist/types/category-texture.js +3 -0
- package/dist/types/schema.d.ts +77 -0
- package/dist/types/schema.d.ts.map +1 -0
- package/dist/types/schema.js +3 -0
- package/dist/types/types.d.ts +15 -0
- package/dist/types/types.d.ts.map +1 -0
- package/dist/types/types.js +2 -0
- package/package.json +7 -8
- package/src/index.ts +82 -29
- package/src/{category → lib}/mesh/convert-mesh.ts +10 -8
- package/src/{category → lib}/mesh/deduce-mesh-schema.ts +20 -19
- package/src/{category → lib}/mesh/mesh-to-arrow-table.ts +5 -3
- package/src/{category → lib}/mesh/mesh-utils.ts +2 -2
- package/src/lib/{arrow → table/arrow}/arrow-type-utils.ts +16 -12
- package/src/lib/table/arrow/convert-schema-arrow.ts +232 -0
- package/src/lib/table/arrow/convert-table-to-arrow.ts +59 -0
- package/src/lib/{schema/impl/field.ts → table/arrow-api/arrow-like-field.ts} +6 -4
- package/src/lib/table/arrow-api/arrow-like-schema.ts +99 -0
- package/src/lib/table/arrow-api/arrow-like-table.ts +83 -0
- package/src/lib/{schema/impl/type.ts → table/arrow-api/arrow-like-type.ts} +2 -1
- package/src/lib/{arrow → table/arrow-api}/get-type-info.ts +4 -3
- package/src/lib/table/arrow-api/index.ts +6 -0
- package/src/lib/{batches → table/batches}/base-table-batch-aggregator.ts +5 -3
- package/src/lib/{batches → table/batches}/columnar-table-batch-aggregator.ts +5 -3
- package/src/lib/{batches → table/batches}/row-table-batch-aggregator.ts +6 -4
- package/src/lib/{batches → table/batches}/table-batch-aggregator.ts +4 -2
- package/src/lib/{batches → table/batches}/table-batch-builder.ts +8 -6
- package/src/lib/table/simple-table/convert-table.ts +72 -0
- package/src/lib/table/simple-table/data-type.ts +102 -0
- package/src/lib/table/simple-table/make-table.ts +108 -0
- package/src/lib/table/simple-table/table-accessors.ts +360 -0
- package/src/lib/table/simple-table/table-column.ts +47 -0
- package/src/lib/table/simple-table/table-schema.ts +97 -0
- package/src/types/category-gis.ts +136 -0
- package/src/types/category-image.ts +19 -0
- package/src/{category/mesh/mesh-types.ts → types/category-mesh.ts} +6 -4
- package/src/types/category-table.ts +104 -0
- package/src/types/category-texture.ts +30 -0
- package/src/types/schema.ts +97 -0
- package/src/types/types.ts +43 -0
- package/dist/bundle.js.map +0 -1
- package/dist/category/common.js +0 -2
- package/dist/category/common.js.map +0 -1
- package/dist/category/gis.js +0 -2
- package/dist/category/gis.js.map +0 -1
- package/dist/category/mesh/convert-mesh.js.map +0 -1
- package/dist/category/mesh/deduce-mesh-schema.js +0 -42
- package/dist/category/mesh/deduce-mesh-schema.js.map +0 -1
- package/dist/category/mesh/mesh-to-arrow-table.js +0 -31
- package/dist/category/mesh/mesh-to-arrow-table.js.map +0 -1
- package/dist/category/mesh/mesh-types.js +0 -2
- package/dist/category/mesh/mesh-types.js.map +0 -1
- package/dist/category/mesh/mesh-utils.js.map +0 -1
- package/dist/category/table/deduce-table-schema.js +0 -51
- package/dist/category/table/deduce-table-schema.js.map +0 -1
- package/dist/category/table/table-types.js +0 -2
- package/dist/category/table/table-types.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/lib/arrow/arrow-like-type-utils.js.map +0 -1
- package/dist/lib/arrow/arrow-type-utils.js +0 -62
- package/dist/lib/arrow/arrow-type-utils.js.map +0 -1
- package/dist/lib/arrow/get-type-info.js.map +0 -1
- package/dist/lib/batches/base-table-batch-aggregator.js.map +0 -1
- package/dist/lib/batches/columnar-table-batch-aggregator.js.map +0 -1
- package/dist/lib/batches/row-table-batch-aggregator.js.map +0 -1
- package/dist/lib/batches/table-batch-aggregator.js.map +0 -1
- package/dist/lib/batches/table-batch-builder.js.map +0 -1
- package/dist/lib/schema/impl/enum.js.map +0 -1
- package/dist/lib/schema/impl/field.js.map +0 -1
- package/dist/lib/schema/impl/schema.js.map +0 -1
- package/dist/lib/schema/impl/type.js.map +0 -1
- package/dist/lib/schema/index.js +0 -5
- package/dist/lib/schema/index.js.map +0 -1
- package/dist/lib/schema-utils/deduce-column-type.js +0 -23
- package/dist/lib/schema-utils/deduce-column-type.js.map +0 -1
- package/dist/lib/utils/assert.js.map +0 -1
- package/dist/lib/utils/async-queue.js.map +0 -1
- package/dist/lib/utils/row-utils.js.map +0 -1
- package/dist/types.js.map +0 -1
- package/src/category/common.ts +0 -30
- package/src/category/gis.ts +0 -61
- package/src/category/table/deduce-table-schema.ts +0 -123
- package/src/category/table/table-types.ts +0 -81
- package/src/lib/arrow/arrow-like-type-utils.ts +0 -25
- package/src/lib/schema/impl/schema.ts +0 -99
- package/src/lib/schema/index.ts +0 -82
- package/src/lib/schema-utils/deduce-column-type.ts +0 -92
- package/src/types.ts +0 -19
- /package/dist/{lib → esm/lib/table}/batches/table-batch-aggregator.js +0 -0
- /package/dist/{types.js → esm/types/types.js} +0 -0
- /package/src/lib/{schema/impl → table/arrow-api}/enum.ts +0 -0
- /package/src/lib/{utils → table/simple-table}/row-utils.ts +0 -0
|
@@ -0,0 +1,343 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _regeneratorRuntime2 = require("@babel/runtime/regenerator");
|
|
4
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.getTableCell = getTableCell;
|
|
9
|
+
exports.getTableCellAt = getTableCellAt;
|
|
10
|
+
exports.getTableColumnIndex = getTableColumnIndex;
|
|
11
|
+
exports.getTableColumnName = getTableColumnName;
|
|
12
|
+
exports.getTableLength = getTableLength;
|
|
13
|
+
exports.getTableNumCols = getTableNumCols;
|
|
14
|
+
exports.getTableRowAsArray = getTableRowAsArray;
|
|
15
|
+
exports.getTableRowAsObject = getTableRowAsObject;
|
|
16
|
+
exports.getTableRowShape = getTableRowShape;
|
|
17
|
+
exports.makeArrayRowIterator = makeArrayRowIterator;
|
|
18
|
+
exports.makeArrayRowTable = makeArrayRowTable;
|
|
19
|
+
exports.makeColumnarTable = makeColumnarTable;
|
|
20
|
+
exports.makeObjectRowIterator = makeObjectRowIterator;
|
|
21
|
+
exports.makeObjectRowTable = makeObjectRowTable;
|
|
22
|
+
exports.makeRowIterator = makeRowIterator;
|
|
23
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
24
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
25
|
+
var _marked = _regeneratorRuntime2.mark(makeRowIterator);
|
|
26
|
+
function getTableLength(table) {
|
|
27
|
+
switch (table.shape) {
|
|
28
|
+
case 'array-row-table':
|
|
29
|
+
case 'object-row-table':
|
|
30
|
+
case 'geojson-row-table':
|
|
31
|
+
return table.data.length;
|
|
32
|
+
case 'arrow-table':
|
|
33
|
+
return table.data.numRows;
|
|
34
|
+
case 'columnar-table':
|
|
35
|
+
for (var _i = 0, _Object$values = Object.values(table.data); _i < _Object$values.length; _i++) {
|
|
36
|
+
var column = _Object$values[_i];
|
|
37
|
+
return column.length || 0;
|
|
38
|
+
}
|
|
39
|
+
return 0;
|
|
40
|
+
default:
|
|
41
|
+
throw new Error('table');
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
function getTableNumCols(table) {
|
|
45
|
+
if (table.schema) {
|
|
46
|
+
return table.schema.fields.length;
|
|
47
|
+
}
|
|
48
|
+
if (getTableLength(table) === 0) {
|
|
49
|
+
throw new Error('empty table');
|
|
50
|
+
}
|
|
51
|
+
switch (table.shape) {
|
|
52
|
+
case 'array-row-table':
|
|
53
|
+
return table.data[0].length;
|
|
54
|
+
case 'object-row-table':
|
|
55
|
+
case 'geojson-row-table':
|
|
56
|
+
return Object.keys(table.data[0]).length;
|
|
57
|
+
case 'columnar-table':
|
|
58
|
+
return Object.keys(table.data).length;
|
|
59
|
+
case 'arrow-table':
|
|
60
|
+
return table.data.numCols;
|
|
61
|
+
default:
|
|
62
|
+
throw new Error('table');
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
function getTableCell(table, rowIndex, columnName) {
|
|
66
|
+
var _table$data$getChildA;
|
|
67
|
+
switch (table.shape) {
|
|
68
|
+
case 'array-row-table':
|
|
69
|
+
var columnIndex = getTableColumnIndex(table, columnName);
|
|
70
|
+
return table.data[rowIndex][columnIndex];
|
|
71
|
+
case 'object-row-table':
|
|
72
|
+
case 'geojson-row-table':
|
|
73
|
+
return table.data[rowIndex][columnName];
|
|
74
|
+
case 'columnar-table':
|
|
75
|
+
var column = table.data[columnName];
|
|
76
|
+
return column[rowIndex];
|
|
77
|
+
case 'arrow-table':
|
|
78
|
+
var arrowColumnIndex = table.data.schema.fields.findIndex(function (field) {
|
|
79
|
+
return field.name === columnName;
|
|
80
|
+
});
|
|
81
|
+
return (_table$data$getChildA = table.data.getChildAt(arrowColumnIndex)) === null || _table$data$getChildA === void 0 ? void 0 : _table$data$getChildA.get(rowIndex);
|
|
82
|
+
default:
|
|
83
|
+
throw new Error('todo');
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
function getTableCellAt(table, rowIndex, columnIndex) {
|
|
87
|
+
var _table$data$getChildA2;
|
|
88
|
+
switch (table.shape) {
|
|
89
|
+
case 'array-row-table':
|
|
90
|
+
return table.data[rowIndex][columnIndex];
|
|
91
|
+
case 'object-row-table':
|
|
92
|
+
case 'geojson-row-table':
|
|
93
|
+
var _columnName = getTableColumnName(table, columnIndex);
|
|
94
|
+
return table.data[rowIndex][_columnName];
|
|
95
|
+
case 'columnar-table':
|
|
96
|
+
_columnName = getTableColumnName(table, columnIndex);
|
|
97
|
+
var column = table.data[_columnName];
|
|
98
|
+
return column[rowIndex];
|
|
99
|
+
case 'arrow-table':
|
|
100
|
+
return (_table$data$getChildA2 = table.data.getChildAt(columnIndex)) === null || _table$data$getChildA2 === void 0 ? void 0 : _table$data$getChildA2.get(rowIndex);
|
|
101
|
+
default:
|
|
102
|
+
throw new Error('todo');
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
function getTableRowShape(table) {
|
|
106
|
+
switch (table.shape) {
|
|
107
|
+
case 'array-row-table':
|
|
108
|
+
case 'object-row-table':
|
|
109
|
+
return table.shape;
|
|
110
|
+
case 'geojson-row-table':
|
|
111
|
+
return 'object-row-table';
|
|
112
|
+
case 'columnar-table':
|
|
113
|
+
default:
|
|
114
|
+
throw new Error('Not a row table');
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
function getTableColumnIndex(table, columnName) {
|
|
118
|
+
var _table$schema;
|
|
119
|
+
var columnIndex = (_table$schema = table.schema) === null || _table$schema === void 0 ? void 0 : _table$schema.fields.findIndex(function (field) {
|
|
120
|
+
return field.name === columnName;
|
|
121
|
+
});
|
|
122
|
+
if (columnIndex === undefined) {
|
|
123
|
+
throw new Error(columnName);
|
|
124
|
+
}
|
|
125
|
+
return columnIndex;
|
|
126
|
+
}
|
|
127
|
+
function getTableColumnName(table, columnIndex) {
|
|
128
|
+
var _table$schema2, _table$schema2$fields;
|
|
129
|
+
var columnName = (_table$schema2 = table.schema) === null || _table$schema2 === void 0 ? void 0 : (_table$schema2$fields = _table$schema2.fields[columnIndex]) === null || _table$schema2$fields === void 0 ? void 0 : _table$schema2$fields.name;
|
|
130
|
+
if (!columnName) {
|
|
131
|
+
throw new Error("".concat(columnIndex));
|
|
132
|
+
}
|
|
133
|
+
return columnName;
|
|
134
|
+
}
|
|
135
|
+
function getTableRowAsObject(table, rowIndex, target, copy) {
|
|
136
|
+
switch (table.shape) {
|
|
137
|
+
case 'object-row-table':
|
|
138
|
+
return copy ? Object.fromEntries(Object.entries(table.data[rowIndex])) : table.data[rowIndex];
|
|
139
|
+
case 'array-row-table':
|
|
140
|
+
case 'geojson-row-table':
|
|
141
|
+
if (table.schema) {
|
|
142
|
+
var _objectRow = target || {};
|
|
143
|
+
for (var i = 0; i < table.schema.fields.length; i++) {
|
|
144
|
+
_objectRow[table.schema.fields[i].name] = table.data[rowIndex][i];
|
|
145
|
+
}
|
|
146
|
+
return _objectRow;
|
|
147
|
+
}
|
|
148
|
+
throw new Error('no schema');
|
|
149
|
+
case 'columnar-table':
|
|
150
|
+
if (table.schema) {
|
|
151
|
+
var _objectRow2 = target || {};
|
|
152
|
+
for (var _i2 = 0; _i2 < table.schema.fields.length; _i2++) {
|
|
153
|
+
_objectRow2[table.schema.fields[_i2].name] = table.data[table.schema.fields[_i2].name][rowIndex];
|
|
154
|
+
}
|
|
155
|
+
return _objectRow2;
|
|
156
|
+
} else {
|
|
157
|
+
var _objectRow3 = target || {};
|
|
158
|
+
for (var _i3 = 0, _Object$entries = Object.entries(table.data); _i3 < _Object$entries.length; _i3++) {
|
|
159
|
+
var _Object$entries$_i = (0, _slicedToArray2.default)(_Object$entries[_i3], 2),
|
|
160
|
+
name = _Object$entries$_i[0],
|
|
161
|
+
column = _Object$entries$_i[1];
|
|
162
|
+
_objectRow3[name] = column[rowIndex];
|
|
163
|
+
}
|
|
164
|
+
return _objectRow3;
|
|
165
|
+
}
|
|
166
|
+
case 'arrow-table':
|
|
167
|
+
var objectRow = target || {};
|
|
168
|
+
var row = table.data.get(rowIndex);
|
|
169
|
+
var schema = table.data.schema;
|
|
170
|
+
for (var _i4 = 0; _i4 < schema.fields.length; _i4++) {
|
|
171
|
+
objectRow[schema.fields[_i4].name] = row === null || row === void 0 ? void 0 : row[schema.fields[_i4].name];
|
|
172
|
+
}
|
|
173
|
+
return objectRow;
|
|
174
|
+
default:
|
|
175
|
+
throw new Error('shape');
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
function getTableRowAsArray(table, rowIndex, target, copy) {
|
|
179
|
+
switch (table.shape) {
|
|
180
|
+
case 'array-row-table':
|
|
181
|
+
return copy ? Array.from(table.data[rowIndex]) : table.data[rowIndex];
|
|
182
|
+
case 'object-row-table':
|
|
183
|
+
case 'geojson-row-table':
|
|
184
|
+
if (table.schema) {
|
|
185
|
+
var _arrayRow = target || [];
|
|
186
|
+
for (var i = 0; i < table.schema.fields.length; i++) {
|
|
187
|
+
_arrayRow[i] = table.data[rowIndex][table.schema.fields[i].name];
|
|
188
|
+
}
|
|
189
|
+
return _arrayRow;
|
|
190
|
+
}
|
|
191
|
+
return Object.values(table.data[rowIndex]);
|
|
192
|
+
case 'columnar-table':
|
|
193
|
+
if (table.schema) {
|
|
194
|
+
var _arrayRow2 = target || [];
|
|
195
|
+
for (var _i5 = 0; _i5 < table.schema.fields.length; _i5++) {
|
|
196
|
+
_arrayRow2[_i5] = table.data[table.schema.fields[_i5].name][rowIndex];
|
|
197
|
+
}
|
|
198
|
+
return _arrayRow2;
|
|
199
|
+
} else {
|
|
200
|
+
var _arrayRow3 = target || [];
|
|
201
|
+
var _i6 = 0;
|
|
202
|
+
for (var _i7 = 0, _Object$values2 = Object.values(table.data); _i7 < _Object$values2.length; _i7++) {
|
|
203
|
+
var column = _Object$values2[_i7];
|
|
204
|
+
_arrayRow3[_i6] = column[rowIndex];
|
|
205
|
+
_i6++;
|
|
206
|
+
}
|
|
207
|
+
return _arrayRow3;
|
|
208
|
+
}
|
|
209
|
+
case 'arrow-table':
|
|
210
|
+
var arrayRow = target || [];
|
|
211
|
+
var row = table.data.get(rowIndex);
|
|
212
|
+
var schema = table.data.schema;
|
|
213
|
+
for (var _i8 = 0; _i8 < schema.fields.length; _i8++) {
|
|
214
|
+
arrayRow[_i8] = row === null || row === void 0 ? void 0 : row[schema.fields[_i8].name];
|
|
215
|
+
}
|
|
216
|
+
return arrayRow;
|
|
217
|
+
default:
|
|
218
|
+
throw new Error('shape');
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
function makeArrayRowTable(table) {
|
|
222
|
+
if (table.shape === 'array-row-table') {
|
|
223
|
+
return table;
|
|
224
|
+
}
|
|
225
|
+
var length = getTableLength(table);
|
|
226
|
+
var data = new Array(length);
|
|
227
|
+
for (var rowIndex = 0; rowIndex < length; rowIndex++) {
|
|
228
|
+
data[rowIndex] = getTableRowAsArray(table, rowIndex);
|
|
229
|
+
}
|
|
230
|
+
return {
|
|
231
|
+
shape: 'array-row-table',
|
|
232
|
+
schema: table.schema,
|
|
233
|
+
data: data
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
function makeObjectRowTable(table) {
|
|
237
|
+
if (table.shape === 'object-row-table') {
|
|
238
|
+
return table;
|
|
239
|
+
}
|
|
240
|
+
var length = getTableLength(table);
|
|
241
|
+
var data = new Array(length);
|
|
242
|
+
for (var rowIndex = 0; rowIndex < length; rowIndex++) {
|
|
243
|
+
data[rowIndex] = getTableRowAsObject(table, rowIndex);
|
|
244
|
+
}
|
|
245
|
+
return {
|
|
246
|
+
shape: 'object-row-table',
|
|
247
|
+
schema: table.schema,
|
|
248
|
+
data: data
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
function makeColumnarTable(table) {
|
|
252
|
+
if (table.shape === 'object-row-table') {
|
|
253
|
+
return table;
|
|
254
|
+
}
|
|
255
|
+
var length = getTableLength(table);
|
|
256
|
+
var data = new Array(length);
|
|
257
|
+
for (var rowIndex = 0; rowIndex < length; rowIndex++) {
|
|
258
|
+
data[rowIndex] = getTableRowAsObject(table, rowIndex);
|
|
259
|
+
}
|
|
260
|
+
return {
|
|
261
|
+
shape: 'object-row-table',
|
|
262
|
+
schema: table.schema,
|
|
263
|
+
data: data
|
|
264
|
+
};
|
|
265
|
+
}
|
|
266
|
+
function makeRowIterator(table, shape) {
|
|
267
|
+
return _regenerator.default.wrap(function makeRowIterator$(_context) {
|
|
268
|
+
while (1) switch (_context.prev = _context.next) {
|
|
269
|
+
case 0:
|
|
270
|
+
_context.t0 = shape;
|
|
271
|
+
_context.next = _context.t0 === 'array-row-table' ? 3 : _context.t0 === 'object-row-table' ? 5 : 7;
|
|
272
|
+
break;
|
|
273
|
+
case 3:
|
|
274
|
+
return _context.delegateYield(makeArrayRowIterator(table), "t1", 4);
|
|
275
|
+
case 4:
|
|
276
|
+
return _context.abrupt("break", 8);
|
|
277
|
+
case 5:
|
|
278
|
+
return _context.delegateYield(makeObjectRowIterator(table), "t2", 6);
|
|
279
|
+
case 6:
|
|
280
|
+
return _context.abrupt("break", 8);
|
|
281
|
+
case 7:
|
|
282
|
+
throw new Error("Unknown row type ".concat(shape));
|
|
283
|
+
case 8:
|
|
284
|
+
case "end":
|
|
285
|
+
return _context.stop();
|
|
286
|
+
}
|
|
287
|
+
}, _marked);
|
|
288
|
+
}
|
|
289
|
+
function makeArrayRowIterator(table) {
|
|
290
|
+
var target = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
|
291
|
+
return _regenerator.default.mark(function _callee() {
|
|
292
|
+
var length, rowIndex;
|
|
293
|
+
return _regenerator.default.wrap(function _callee$(_context2) {
|
|
294
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
295
|
+
case 0:
|
|
296
|
+
length = getTableLength(table);
|
|
297
|
+
rowIndex = 0;
|
|
298
|
+
case 2:
|
|
299
|
+
if (!(rowIndex < length)) {
|
|
300
|
+
_context2.next = 8;
|
|
301
|
+
break;
|
|
302
|
+
}
|
|
303
|
+
_context2.next = 5;
|
|
304
|
+
return getTableRowAsArray(table, rowIndex, target);
|
|
305
|
+
case 5:
|
|
306
|
+
rowIndex++;
|
|
307
|
+
_context2.next = 2;
|
|
308
|
+
break;
|
|
309
|
+
case 8:
|
|
310
|
+
case "end":
|
|
311
|
+
return _context2.stop();
|
|
312
|
+
}
|
|
313
|
+
}, _callee);
|
|
314
|
+
})();
|
|
315
|
+
}
|
|
316
|
+
function makeObjectRowIterator(table) {
|
|
317
|
+
var target = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
|
|
318
|
+
return _regenerator.default.mark(function _callee2() {
|
|
319
|
+
var length, rowIndex;
|
|
320
|
+
return _regenerator.default.wrap(function _callee2$(_context3) {
|
|
321
|
+
while (1) switch (_context3.prev = _context3.next) {
|
|
322
|
+
case 0:
|
|
323
|
+
length = getTableLength(table);
|
|
324
|
+
rowIndex = 0;
|
|
325
|
+
case 2:
|
|
326
|
+
if (!(rowIndex < length)) {
|
|
327
|
+
_context3.next = 8;
|
|
328
|
+
break;
|
|
329
|
+
}
|
|
330
|
+
_context3.next = 5;
|
|
331
|
+
return getTableRowAsObject(table, rowIndex, target);
|
|
332
|
+
case 5:
|
|
333
|
+
rowIndex++;
|
|
334
|
+
_context3.next = 2;
|
|
335
|
+
break;
|
|
336
|
+
case 8:
|
|
337
|
+
case "end":
|
|
338
|
+
return _context3.stop();
|
|
339
|
+
}
|
|
340
|
+
}, _callee2);
|
|
341
|
+
})();
|
|
342
|
+
}
|
|
343
|
+
//# sourceMappingURL=table-accessors.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-accessors.js","names":["makeRowIterator","getTableLength","table","shape","data","length","numRows","_i","_Object$values","Object","values","column","Error","getTableNumCols","schema","fields","keys","numCols","getTableCell","rowIndex","columnName","_table$data$getChildA","columnIndex","getTableColumnIndex","arrowColumnIndex","findIndex","field","name","getChildAt","get","getTableCellAt","_table$data$getChildA2","getTableColumnName","getTableRowShape","_table$schema","undefined","_table$schema2","_table$schema2$fields","concat","getTableRowAsObject","target","copy","fromEntries","entries","objectRow","i","_i3","_Object$entries","_Object$entries$_i","_slicedToArray2","default","row","getTableRowAsArray","Array","from","arrayRow","_i7","_Object$values2","makeArrayRowTable","makeObjectRowTable","makeColumnarTable","_regenerator","wrap","makeRowIterator$","_context","prev","next","t0","delegateYield","makeArrayRowIterator","abrupt","makeObjectRowIterator","stop","_marked","arguments","mark","_callee","_callee$","_context2","_callee2","_callee2$","_context3"],"sources":["../../../../../src/lib/table/simple-table/table-accessors.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n/* eslint-disable no-else-return */\n\nimport {Table, ArrayRowTable, ObjectRowTable} from '../../../types/category-table';\n\n/**\n * Returns the length of the table (i.e. the number of rows)\n */\nexport function getTableLength(table: Table): number {\n switch (table.shape) {\n case 'array-row-table':\n case 'object-row-table':\n case 'geojson-row-table':\n return table.data.length;\n\n case 'arrow-table':\n return table.data.numRows;\n\n case 'columnar-table':\n for (const column of Object.values(table.data)) {\n return column.length || 0;\n }\n return 0;\n default:\n throw new Error('table');\n }\n}\n\n/**\n * Returns the number of columns in the table\n * @throws Fails to deduce number of columns if the table has no schema and is empty\n */\nexport function getTableNumCols(table: Table): number {\n if (table.schema) {\n return table.schema.fields.length;\n }\n if (getTableLength(table) === 0) {\n throw new Error('empty table');\n }\n switch (table.shape) {\n case 'array-row-table':\n return table.data[0].length;\n case 'object-row-table':\n case 'geojson-row-table':\n return Object.keys(table.data[0]).length;\n\n case 'columnar-table':\n return Object.keys(table.data).length;\n\n case 'arrow-table':\n return table.data.numCols;\n default:\n throw new Error('table');\n }\n}\n\n/** Get a table cell value at row index and column name */\nexport function getTableCell(table: Table, rowIndex: number, columnName: string): unknown {\n switch (table.shape) {\n case 'array-row-table':\n const columnIndex = getTableColumnIndex(table, columnName);\n return table.data[rowIndex][columnIndex];\n\n case 'object-row-table':\n case 'geojson-row-table':\n return table.data[rowIndex][columnName];\n\n case 'columnar-table':\n const column = table.data[columnName];\n return column[rowIndex];\n\n case 'arrow-table':\n const arrowColumnIndex = table.data.schema.fields.findIndex(\n (field) => field.name === columnName\n );\n return table.data.getChildAt(arrowColumnIndex)?.get(rowIndex);\n\n default:\n throw new Error('todo');\n }\n}\n\n/** Get a table cell value at row index and column name */\nexport function getTableCellAt(table: Table, rowIndex: number, columnIndex: number): unknown {\n switch (table.shape) {\n case 'array-row-table':\n return table.data[rowIndex][columnIndex];\n\n case 'object-row-table':\n case 'geojson-row-table':\n let columnName = getTableColumnName(table, columnIndex);\n return table.data[rowIndex][columnName];\n\n case 'columnar-table':\n columnName = getTableColumnName(table, columnIndex);\n const column = table.data[columnName];\n return column[rowIndex];\n\n case 'arrow-table':\n return table.data.getChildAt(columnIndex)?.get(rowIndex);\n\n default:\n throw new Error('todo');\n }\n}\n\n/** Deduce the table row shape */\nexport function getTableRowShape(table: Table): 'array-row-table' | 'object-row-table' {\n switch (table.shape) {\n case 'array-row-table':\n case 'object-row-table':\n return table.shape;\n\n case 'geojson-row-table':\n return 'object-row-table';\n\n case 'columnar-table':\n default:\n throw new Error('Not a row table');\n }\n}\n\n/** Get the index of a named table column. Requires the table to have a schema */\nexport function getTableColumnIndex(table: Table, columnName: string): number {\n const columnIndex = table.schema?.fields.findIndex((field) => field.name === columnName);\n if (columnIndex === undefined) {\n throw new Error(columnName);\n }\n return columnIndex;\n}\n\n/** Get the name of a table column by index. Requires the table to have a schema */\nexport function getTableColumnName(table: Table, columnIndex: number): string {\n const columnName = table.schema?.fields[columnIndex]?.name;\n if (!columnName) {\n throw new Error(`${columnIndex}`);\n }\n return columnName;\n}\n\n/**\n * Returns one row of the table in object format.\n * @param target Optional parameter will be used if needed to store the row. Can be reused between calls to improve performance\n * @returns an array representing the row. May be the original array in the row, a new object, or the target parameter\n */\n// eslint-disable-next-line complexity\nexport function getTableRowAsObject(\n table: Table,\n rowIndex: number,\n target?: {[columnName: string]: unknown},\n copy?: 'copy'\n): {[columnName: string]: unknown} {\n switch (table.shape) {\n case 'object-row-table':\n return copy ? Object.fromEntries(Object.entries(table.data[rowIndex])) : table.data[rowIndex];\n\n case 'array-row-table':\n case 'geojson-row-table':\n if (table.schema) {\n const objectRow: {[columnName: string]: unknown} = target || {};\n for (let i = 0; i < table.schema.fields.length; i++) {\n objectRow[table.schema.fields[i].name] = table.data[rowIndex][i];\n }\n return objectRow;\n }\n throw new Error('no schema');\n\n case 'columnar-table':\n if (table.schema) {\n const objectRow: {[columnName: string]: unknown} = target || {};\n for (let i = 0; i < table.schema.fields.length; i++) {\n objectRow[table.schema.fields[i].name] =\n table.data[table.schema.fields[i].name][rowIndex];\n }\n return objectRow;\n } else {\n // eslint-disable-line no-else-return\n const objectRow: {[columnName: string]: unknown} = target || {};\n for (const [name, column] of Object.entries(table.data)) {\n objectRow[name] = column[rowIndex];\n }\n return objectRow;\n }\n\n case 'arrow-table':\n const objectRow: {[columnName: string]: unknown} = target || {};\n const row = table.data.get(rowIndex);\n const schema = table.data.schema;\n for (let i = 0; i < schema.fields.length; i++) {\n objectRow[schema.fields[i].name] = row?.[schema.fields[i].name];\n }\n return objectRow;\n\n default:\n throw new Error('shape');\n }\n}\n\n/**\n * Returns one row of the table in array format.\n * @param target Optional parameter will be used if needed to store the row. Can be reused between calls to improve performance.\n * @returns an array representing the row. May be the original array in the row, a new object, or the target parameter\n */\n// eslint-disable-next-line complexity\nexport function getTableRowAsArray(\n table: Table,\n rowIndex: number,\n target?: unknown[],\n copy?: 'copy'\n): unknown[] {\n switch (table.shape) {\n case 'array-row-table':\n return copy ? Array.from(table.data[rowIndex]) : table.data[rowIndex];\n\n case 'object-row-table':\n case 'geojson-row-table':\n if (table.schema) {\n const arrayRow: unknown[] = target || [];\n for (let i = 0; i < table.schema.fields.length; i++) {\n arrayRow[i] = table.data[rowIndex][table.schema.fields[i].name];\n }\n return arrayRow;\n }\n // Warning: just slap on the values, this risks mismatches between rows\n return Object.values(table.data[rowIndex]);\n\n case 'columnar-table':\n if (table.schema) {\n const arrayRow: unknown[] = target || [];\n for (let i = 0; i < table.schema.fields.length; i++) {\n arrayRow[i] = table.data[table.schema.fields[i].name][rowIndex];\n }\n return arrayRow;\n } else {\n // eslint-disable-line no-else-return\n const arrayRow: unknown[] = target || [];\n let i = 0;\n for (const column of Object.values(table.data)) {\n arrayRow[i] = column[rowIndex];\n i++;\n }\n return arrayRow;\n }\n\n case 'arrow-table':\n const arrayRow: unknown[] = target || [];\n const row = table.data.get(rowIndex);\n const schema = table.data.schema;\n for (let i = 0; i < schema.fields.length; i++) {\n arrayRow[i] = row?.[schema.fields[i].name];\n }\n return arrayRow;\n\n default:\n throw new Error('shape');\n }\n}\n\n/** Convert any table into array row format */\nexport function makeArrayRowTable(table: Table): ArrayRowTable {\n if (table.shape === 'array-row-table') {\n return table;\n }\n const length = getTableLength(table);\n const data = new Array<unknown[]>(length);\n for (let rowIndex = 0; rowIndex < length; rowIndex++) {\n data[rowIndex] = getTableRowAsArray(table, rowIndex);\n }\n return {\n shape: 'array-row-table',\n schema: table.schema,\n data\n };\n}\n\n/** Convert any table into object row format */\nexport function makeObjectRowTable(table: Table): ObjectRowTable {\n if (table.shape === 'object-row-table') {\n return table;\n }\n const length = getTableLength(table);\n const data = new Array<{[key: string]: unknown}>(length);\n for (let rowIndex = 0; rowIndex < length; rowIndex++) {\n data[rowIndex] = getTableRowAsObject(table, rowIndex);\n }\n return {\n shape: 'object-row-table',\n schema: table.schema,\n data\n };\n}\n\n/** Convert any table into object row format */\nexport function makeColumnarTable(table: Table): ObjectRowTable {\n if (table.shape === 'object-row-table') {\n return table;\n }\n const length = getTableLength(table);\n const data = new Array<{[key: string]: unknown}>(length);\n for (let rowIndex = 0; rowIndex < length; rowIndex++) {\n data[rowIndex] = getTableRowAsObject(table, rowIndex);\n }\n return {\n shape: 'object-row-table',\n schema: table.schema,\n data\n };\n}\n\n// Row Iterators\n\n/**\n * Iterate over table rows\n * @param table\n * @param shape\n */\nexport function* makeRowIterator(\n table: Table,\n shape: 'object-row-table' | 'array-row-table'\n): Iterable<unknown[] | {[key: string]: unknown}> {\n switch (shape) {\n case 'array-row-table':\n yield* makeArrayRowIterator(table);\n break;\n case 'object-row-table':\n yield* makeObjectRowIterator(table);\n break;\n\n default:\n throw new Error(`Unknown row type ${shape}`);\n }\n}\n\n/**\n * Streaming processing: Iterate over table, yielding array rows\n * @param table\n * @param shape\n */\nexport function* makeArrayRowIterator(table: Table, target: unknown[] = []): Iterable<unknown[]> {\n const length = getTableLength(table);\n for (let rowIndex = 0; rowIndex < length; rowIndex++) {\n yield getTableRowAsArray(table, rowIndex, target);\n }\n}\n\n/**\n * Streaming processing: Iterate over table, yielding object rows\n * @param table\n * @param shape\n */\nexport function* makeObjectRowIterator(\n table: Table,\n target: {[key: string]: unknown} = {}\n): Iterable<{[key: string]: unknown}> {\n const length = getTableLength(table);\n for (let rowIndex = 0; rowIndex < length; rowIndex++) {\n yield getTableRowAsObject(table, rowIndex, target);\n }\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.makeColumnFromField = makeColumnFromField;
|
|
7
|
+
var _dataType = require("./data-type");
|
|
8
|
+
function makeColumnFromField(field, length) {
|
|
9
|
+
var ArrayType = (0, _dataType.getArrayTypeFromDataType)(field.type, field.nullable);
|
|
10
|
+
return new ArrayType(length);
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=table-column.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-column.js","names":["_dataType","require","makeColumnFromField","field","length","ArrayType","getArrayTypeFromDataType","type","nullable"],"sources":["../../../../../src/lib/table/simple-table/table-column.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n// import type {TypedArray,} from '../../../types/types';\nimport {Field} from '../../../types/schema';\nimport {getArrayTypeFromDataType} from './data-type';\n\nexport interface ArrayType<T = unknown> {\n readonly length: number;\n [n: number]: T;\n}\n\nexport function makeColumnFromField(field: Field, length: number): ArrayType {\n const ArrayType = getArrayTypeFromDataType(field.type, field.nullable);\n return new ArrayType(length);\n}\n\n/*\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction deduceSchema(rows) {\n const row = rows[0];\n\n const schema = {};\n let i = 0;\n for (const columnName in row) {\n const value = row[columnName];\n switch (typeof value) {\n case 'number':\n case 'boolean':\n // TODO - booleans could be handled differently...\n schema[columnName] = {name: String(columnName), index: i, type: Float32Array};\n break;\n\n case 'object':\n schema[columnName] = {name: String(columnName), index: i, type: Array};\n break;\n\n case 'string':\n default:\n schema[columnName] = {name: String(columnName), index: i, type: Array};\n // We currently only handle numeric rows\n // TODO we could offer a function to map strings to numbers?\n }\n i++;\n }\n return schema;\n}\n*/\n"],"mappings":";;;;;;AAIA,IAAAA,SAAA,GAAAC,OAAA;AAOO,SAASC,mBAAmBA,CAACC,KAAY,EAAEC,MAAc,EAAa;EAC3E,IAAMC,SAAS,GAAG,IAAAC,kCAAwB,EAACH,KAAK,CAACI,IAAI,EAAEJ,KAAK,CAACK,QAAQ,CAAC;EACtE,OAAO,IAAIH,SAAS,CAACD,MAAM,CAAC;AAC9B"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.deduceSchema = deduceSchema;
|
|
8
|
+
exports.deduceTableSchema = deduceTableSchema;
|
|
9
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
10
|
+
var _dataType = require("./data-type");
|
|
11
|
+
function deduceTableSchema(table) {
|
|
12
|
+
switch (table.shape) {
|
|
13
|
+
case 'array-row-table':
|
|
14
|
+
case 'object-row-table':
|
|
15
|
+
return deduceSchemaFromRows(table.data);
|
|
16
|
+
case 'columnar-table':
|
|
17
|
+
return deduceSchemaFromColumns(table.data);
|
|
18
|
+
case 'arrow-table':
|
|
19
|
+
default:
|
|
20
|
+
throw new Error('Deduce schema');
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function deduceSchema(data) {
|
|
24
|
+
return Array.isArray(data) ? deduceSchemaFromRows(data) : deduceSchemaFromColumns(data);
|
|
25
|
+
}
|
|
26
|
+
function deduceSchemaFromColumns(columnarTable) {
|
|
27
|
+
var fields = [];
|
|
28
|
+
for (var _i = 0, _Object$entries = Object.entries(columnarTable); _i < _Object$entries.length; _i++) {
|
|
29
|
+
var _Object$entries$_i = (0, _slicedToArray2.default)(_Object$entries[_i], 2),
|
|
30
|
+
columnName = _Object$entries$_i[0],
|
|
31
|
+
column = _Object$entries$_i[1];
|
|
32
|
+
var field = deduceFieldFromColumn(column, columnName);
|
|
33
|
+
fields.push(field);
|
|
34
|
+
}
|
|
35
|
+
return {
|
|
36
|
+
fields: fields,
|
|
37
|
+
metadata: {}
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
function deduceSchemaFromRows(rowTable) {
|
|
41
|
+
if (!rowTable.length) {
|
|
42
|
+
throw new Error('deduce from empty table');
|
|
43
|
+
}
|
|
44
|
+
var fields = [];
|
|
45
|
+
var row0 = rowTable[0];
|
|
46
|
+
for (var _i2 = 0, _Object$entries2 = Object.entries(row0); _i2 < _Object$entries2.length; _i2++) {
|
|
47
|
+
var _Object$entries2$_i = (0, _slicedToArray2.default)(_Object$entries2[_i2], 2),
|
|
48
|
+
columnName = _Object$entries2$_i[0],
|
|
49
|
+
value = _Object$entries2$_i[1];
|
|
50
|
+
fields.push(deduceFieldFromValue(value, columnName));
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
fields: fields,
|
|
54
|
+
metadata: {}
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
function deduceFieldFromColumn(column, name) {
|
|
58
|
+
if (ArrayBuffer.isView(column)) {
|
|
59
|
+
var type = (0, _dataType.getDataTypeFromArray)(column);
|
|
60
|
+
return {
|
|
61
|
+
name: name,
|
|
62
|
+
type: type.type || 'null',
|
|
63
|
+
nullable: type.nullable
|
|
64
|
+
};
|
|
65
|
+
}
|
|
66
|
+
if (Array.isArray(column) && column.length > 0) {
|
|
67
|
+
var value = column[0];
|
|
68
|
+
var _type = (0, _dataType.getDataTypeFromValue)(value);
|
|
69
|
+
return {
|
|
70
|
+
name: name,
|
|
71
|
+
type: _type,
|
|
72
|
+
nullable: true
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
throw new Error('empty table');
|
|
76
|
+
}
|
|
77
|
+
function deduceFieldFromValue(value, name) {
|
|
78
|
+
var type = (0, _dataType.getDataTypeFromValue)(value);
|
|
79
|
+
return {
|
|
80
|
+
name: name,
|
|
81
|
+
type: type,
|
|
82
|
+
nullable: true
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=table-schema.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-schema.js","names":["_dataType","require","deduceTableSchema","table","shape","deduceSchemaFromRows","data","deduceSchemaFromColumns","Error","deduceSchema","Array","isArray","columnarTable","fields","_i","_Object$entries","Object","entries","length","_Object$entries$_i","_slicedToArray2","default","columnName","column","field","deduceFieldFromColumn","push","metadata","rowTable","row0","_i2","_Object$entries2","_Object$entries2$_i","value","deduceFieldFromValue","name","ArrayBuffer","isView","type","getDataTypeFromArray","nullable","getDataTypeFromValue"],"sources":["../../../../../src/lib/table/simple-table/table-schema.ts"],"sourcesContent":["// Type deduction\nimport {Schema, Field} from '../../../types/schema';\nimport {ArrayType} from '../../../types/types';\nimport {Table} from '../../../types/category-table';\nimport {getDataTypeFromArray, getDataTypeFromValue} from './data-type';\n\n/**\n * SCHEMA SUPPORT - AUTODEDUCTION\n * @param {*} table\n * @param {*} schema\n * @returns\n */\nexport function deduceTableSchema(table: Table): Schema {\n switch (table.shape) {\n case 'array-row-table':\n case 'object-row-table':\n return deduceSchemaFromRows(table.data);\n\n case 'columnar-table':\n return deduceSchemaFromColumns(table.data);\n\n case 'arrow-table':\n default:\n throw new Error('Deduce schema');\n }\n}\n\nexport function deduceSchema(\n data: unknown[][] | {[key: string]: unknown}[] | {[key: string]: unknown[]}\n): Schema {\n return Array.isArray(data) ? deduceSchemaFromRows(data) : deduceSchemaFromColumns(data);\n}\n\n/** Given an object with columnar arrays, try to deduce a schema */\nfunction deduceSchemaFromColumns(columnarTable: {[key: string]: ArrayType}): Schema {\n const fields: Field[] = [];\n for (const [columnName, column] of Object.entries(columnarTable)) {\n const field = deduceFieldFromColumn(column, columnName);\n fields.push(field);\n }\n return {fields, metadata: {}};\n}\n\n/** Given an array of rows, try to deduce a schema */\nfunction deduceSchemaFromRows(rowTable: unknown[][] | {[key: string]: unknown}[]): Schema {\n if (!rowTable.length) {\n throw new Error('deduce from empty table');\n }\n const fields: Field[] = [];\n const row0 = rowTable[0];\n // TODO - fields can be nullable, false detection...\n // Could look at additional rows if nulls in first row\n // TODO - if array, column names will be numbers\n for (const [columnName, value] of Object.entries(row0)) {\n fields.push(deduceFieldFromValue(value, columnName));\n }\n\n return {fields, metadata: {}};\n}\n\n/** Given a column (i.e. array), attempt to deduce an appropriate `Field` */\nfunction deduceFieldFromColumn(column: ArrayType, name: string): Field {\n if (ArrayBuffer.isView(column)) {\n const type = getDataTypeFromArray(column);\n return {\n name,\n type: type.type || 'null',\n nullable: type.nullable\n // metadata: {}\n };\n }\n\n if (Array.isArray(column) && column.length > 0) {\n const value = column[0];\n const type = getDataTypeFromValue(value);\n // TODO - support nested schemas?\n return {\n name,\n type,\n nullable: true\n // metadata: {},\n };\n }\n\n throw new Error('empty table');\n}\n\n/** Given a value, attempt to deduce an appropriate `Field` */\nfunction deduceFieldFromValue(value: unknown, name: string): Field {\n const type = getDataTypeFromValue(value);\n return {\n name,\n type,\n nullable: true\n // metadata: {}\n };\n}\n"],"mappings":";;;;;;;;;AAIA,IAAAA,SAAA,GAAAC,OAAA;AAQO,SAASC,iBAAiBA,CAACC,KAAY,EAAU;EACtD,QAAQA,KAAK,CAACC,KAAK;IACjB,KAAK,iBAAiB;IACtB,KAAK,kBAAkB;MACrB,OAAOC,oBAAoB,CAACF,KAAK,CAACG,IAAI,CAAC;IAEzC,KAAK,gBAAgB;MACnB,OAAOC,uBAAuB,CAACJ,KAAK,CAACG,IAAI,CAAC;IAE5C,KAAK,aAAa;IAClB;MACE,MAAM,IAAIE,KAAK,CAAC,eAAe,CAAC;EACpC;AACF;AAEO,SAASC,YAAYA,CAC1BH,IAA2E,EACnE;EACR,OAAOI,KAAK,CAACC,OAAO,CAACL,IAAI,CAAC,GAAGD,oBAAoB,CAACC,IAAI,CAAC,GAAGC,uBAAuB,CAACD,IAAI,CAAC;AACzF;AAGA,SAASC,uBAAuBA,CAACK,aAAyC,EAAU;EAClF,IAAMC,MAAe,GAAG,EAAE;EAC1B,SAAAC,EAAA,MAAAC,eAAA,GAAmCC,MAAM,CAACC,OAAO,CAACL,aAAa,CAAC,EAAAE,EAAA,GAAAC,eAAA,CAAAG,MAAA,EAAAJ,EAAA,IAAE;IAA7D,IAAAK,kBAAA,OAAAC,eAAA,CAAAC,OAAA,EAAAN,eAAA,CAAAD,EAAA;MAAOQ,UAAU,GAAAH,kBAAA;MAAEI,MAAM,GAAAJ,kBAAA;IAC5B,IAAMK,KAAK,GAAGC,qBAAqB,CAACF,MAAM,EAAED,UAAU,CAAC;IACvDT,MAAM,CAACa,IAAI,CAACF,KAAK,CAAC;EACpB;EACA,OAAO;IAACX,MAAM,EAANA,MAAM;IAAEc,QAAQ,EAAE,CAAC;EAAC,CAAC;AAC/B;AAGA,SAAStB,oBAAoBA,CAACuB,QAAkD,EAAU;EACxF,IAAI,CAACA,QAAQ,CAACV,MAAM,EAAE;IACpB,MAAM,IAAIV,KAAK,CAAC,yBAAyB,CAAC;EAC5C;EACA,IAAMK,MAAe,GAAG,EAAE;EAC1B,IAAMgB,IAAI,GAAGD,QAAQ,CAAC,CAAC,CAAC;EAIxB,SAAAE,GAAA,MAAAC,gBAAA,GAAkCf,MAAM,CAACC,OAAO,CAACY,IAAI,CAAC,EAAAC,GAAA,GAAAC,gBAAA,CAAAb,MAAA,EAAAY,GAAA,IAAE;IAAnD,IAAAE,mBAAA,OAAAZ,eAAA,CAAAC,OAAA,EAAAU,gBAAA,CAAAD,GAAA;MAAOR,UAAU,GAAAU,mBAAA;MAAEC,KAAK,GAAAD,mBAAA;IAC3BnB,MAAM,CAACa,IAAI,CAACQ,oBAAoB,CAACD,KAAK,EAAEX,UAAU,CAAC,CAAC;EACtD;EAEA,OAAO;IAACT,MAAM,EAANA,MAAM;IAAEc,QAAQ,EAAE,CAAC;EAAC,CAAC;AAC/B;AAGA,SAASF,qBAAqBA,CAACF,MAAiB,EAAEY,IAAY,EAAS;EACrE,IAAIC,WAAW,CAACC,MAAM,CAACd,MAAM,CAAC,EAAE;IAC9B,IAAMe,IAAI,GAAG,IAAAC,8BAAoB,EAAChB,MAAM,CAAC;IACzC,OAAO;MACLY,IAAI,EAAJA,IAAI;MACJG,IAAI,EAAEA,IAAI,CAACA,IAAI,IAAI,MAAM;MACzBE,QAAQ,EAAEF,IAAI,CAACE;IAEjB,CAAC;EACH;EAEA,IAAI9B,KAAK,CAACC,OAAO,CAACY,MAAM,CAAC,IAAIA,MAAM,CAACL,MAAM,GAAG,CAAC,EAAE;IAC9C,IAAMe,KAAK,GAAGV,MAAM,CAAC,CAAC,CAAC;IACvB,IAAMe,KAAI,GAAG,IAAAG,8BAAoB,EAACR,KAAK,CAAC;IAExC,OAAO;MACLE,IAAI,EAAJA,IAAI;MACJG,IAAI,EAAJA,KAAI;MACJE,QAAQ,EAAE;IAEZ,CAAC;EACH;EAEA,MAAM,IAAIhC,KAAK,CAAC,aAAa,CAAC;AAChC;AAGA,SAAS0B,oBAAoBA,CAACD,KAAc,EAAEE,IAAY,EAAS;EACjE,IAAMG,IAAI,GAAG,IAAAG,8BAAoB,EAACR,KAAK,CAAC;EACxC,OAAO;IACLE,IAAI,EAAJA,IAAI;IACJG,IAAI,EAAJA,IAAI;IACJE,QAAQ,EAAE;EAEZ,CAAC;AACH"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.assert = assert;
|
|
7
|
+
function assert(condition, message) {
|
|
8
|
+
if (!condition) {
|
|
9
|
+
throw new Error(message || 'loader assertion failed.');
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=assert.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"assert.js","names":["assert","condition","message","Error"],"sources":["../../../../src/lib/utils/assert.ts"],"sourcesContent":["// Replacement for the external assert method to reduce bundle size\n// Note: We don't use the second \"message\" argument in calling code,\n// so no need to support it here\nexport function assert(condition: boolean, message?: string) {\n if (!condition) {\n throw new Error(message || 'loader assertion failed.');\n }\n}\n"],"mappings":";;;;;;AAGO,SAASA,MAAMA,CAACC,SAAkB,EAAEC,OAAgB,EAAE;EAC3D,IAAI,CAACD,SAAS,EAAE;IACd,MAAM,IAAIE,KAAK,CAACD,OAAO,IAAI,0BAA0B,CAAC;EACxD;AACF"}
|