@loaders.gl/gis 4.3.4 → 4.4.0-alpha.10
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/index.cjs +2411 -469
- package/dist/index.cjs.map +4 -4
- package/dist/index.d.ts +31 -12
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +39 -15
- package/dist/index.js.map +1 -0
- package/dist/lib/binary-geometry-api/binary-geometry-info.d.ts +21 -0
- package/dist/lib/binary-geometry-api/binary-geometry-info.d.ts.map +1 -0
- package/dist/lib/binary-geometry-api/binary-geometry-info.js +49 -0
- package/dist/lib/binary-geometry-api/binary-geometry-info.js.map +1 -0
- package/dist/lib/binary-geometry-api/concat-binary-geometry.d.ts +5 -0
- package/dist/lib/binary-geometry-api/concat-binary-geometry.d.ts.map +1 -0
- package/dist/lib/binary-geometry-api/concat-binary-geometry.js +51 -0
- package/dist/lib/binary-geometry-api/concat-binary-geometry.js.map +1 -0
- package/dist/lib/{binary-features/transform.d.ts → binary-geometry-api/transform-coordinates.d.ts} +1 -2
- package/dist/lib/binary-geometry-api/transform-coordinates.d.ts.map +1 -0
- package/dist/lib/{binary-features/transform.js → binary-geometry-api/transform-coordinates.js} +1 -1
- package/dist/lib/binary-geometry-api/transform-coordinates.js.map +1 -0
- package/dist/lib/feature-collection-converters/convert-binary-features-to-geojson.d.ts +16 -0
- package/dist/lib/feature-collection-converters/convert-binary-features-to-geojson.d.ts.map +1 -0
- package/dist/lib/{binary-features/binary-to-geojson.js → feature-collection-converters/convert-binary-features-to-geojson.js} +4 -90
- package/dist/lib/feature-collection-converters/convert-binary-features-to-geojson.js.map +1 -0
- package/dist/lib/{binary-features/flat-geojson-to-binary.d.ts → feature-collection-converters/convert-flat-geojson-to-binary-features.d.ts} +6 -9
- package/dist/lib/feature-collection-converters/convert-flat-geojson-to-binary-features.d.ts.map +1 -0
- package/dist/lib/{binary-features/flat-geojson-to-binary.js → feature-collection-converters/convert-flat-geojson-to-binary-features.js} +6 -5
- package/dist/lib/feature-collection-converters/convert-flat-geojson-to-binary-features.js.map +1 -0
- package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.d.ts +74 -0
- package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.d.ts.map +1 -0
- package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.js +378 -0
- package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.js.map +1 -0
- package/dist/lib/{binary-features/geojson-to-binary.d.ts → feature-collection-converters/convert-geojson-to-binary-features.d.ts} +2 -2
- package/dist/lib/feature-collection-converters/convert-geojson-to-binary-features.d.ts.map +1 -0
- package/dist/lib/feature-collection-converters/convert-geojson-to-binary-features.js +25 -0
- package/dist/lib/feature-collection-converters/convert-geojson-to-binary-features.js.map +1 -0
- package/dist/lib/{binary-features/geojson-to-flat-geojson.d.ts → feature-collection-converters/convert-geojson-to-flat-geojson.d.ts} +2 -2
- package/dist/lib/feature-collection-converters/convert-geojson-to-flat-geojson.d.ts.map +1 -0
- package/dist/lib/{binary-features/geojson-to-flat-geojson.js → feature-collection-converters/convert-geojson-to-flat-geojson.js} +5 -1
- package/dist/lib/feature-collection-converters/convert-geojson-to-flat-geojson.js.map +1 -0
- package/dist/lib/feature-collection-converters/helpers/flat-geojson-to-binary-types.d.ts.map +1 -0
- package/dist/lib/feature-collection-converters/helpers/flat-geojson-to-binary-types.js +5 -0
- package/dist/lib/feature-collection-converters/helpers/flat-geojson-to-binary-types.js.map +1 -0
- package/dist/lib/geometry-api/geometry-info.d.ts +21 -0
- package/dist/lib/geometry-api/geometry-info.d.ts.map +1 -0
- package/dist/lib/{binary-features/extract-geometry-info.js → geometry-api/geometry-info.js} +5 -1
- package/dist/lib/geometry-api/geometry-info.js.map +1 -0
- package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.d.ts +4 -0
- package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.d.ts.map +1 -0
- package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.js +92 -0
- package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.js.map +1 -0
- package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.d.ts +13 -0
- package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.d.ts.map +1 -0
- package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.js +165 -0
- package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.js.map +1 -0
- package/dist/lib/geometry-converters/convert-to-geojson.d.ts +6 -0
- package/dist/lib/geometry-converters/convert-to-geojson.d.ts.map +1 -0
- package/dist/lib/geometry-converters/convert-to-geojson.js +40 -0
- package/dist/lib/geometry-converters/convert-to-geojson.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.d.ts +6 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.js +196 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.d.ts +9 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.js +274 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.d.ts +8 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.js +45 -0
- package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.d.ts +10 -0
- package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.js +255 -0
- package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.d.ts +3 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.js +165 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.d.ts +11 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.js +10 -0
- package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.d.ts +16 -0
- package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.js +259 -0
- package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.d.ts +43 -0
- package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.js +175 -0
- package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-types.d.ts +64 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-types.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-types.js +47 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-types.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.d.ts +21 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.js +65 -0
- package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.js.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.d.ts +8 -0
- package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.d.ts.map +1 -0
- package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.js +34 -0
- package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.js.map +1 -0
- package/dist/lib/table-converters/convert-geoarrow-table.d.ts +27 -0
- package/dist/lib/table-converters/convert-geoarrow-table.d.ts.map +1 -0
- package/dist/lib/table-converters/convert-geoarrow-table.js +155 -0
- package/dist/lib/table-converters/convert-geoarrow-table.js.map +1 -0
- package/dist/lib/table-converters/convert-wkb-table-to-geojson.d.ts +4 -0
- package/dist/lib/table-converters/convert-wkb-table-to-geojson.d.ts.map +1 -0
- package/dist/lib/{tables/convert-table-to-geojson.js → table-converters/convert-wkb-table-to-geojson.js} +11 -16
- package/dist/lib/table-converters/convert-wkb-table-to-geojson.js.map +1 -0
- package/dist/lib/table-converters/make-arrow-batch-iterator.d.ts +6 -0
- package/dist/lib/table-converters/make-arrow-batch-iterator.d.ts.map +1 -0
- package/dist/lib/table-converters/make-arrow-batch-iterator.js +36 -0
- package/dist/lib/table-converters/make-arrow-batch-iterator.js.map +1 -0
- package/dist/lib/utils/base64-encoder.d.ts +5 -0
- package/dist/lib/utils/base64-encoder.d.ts.map +1 -0
- package/dist/lib/utils/base64-encoder.js +154 -0
- package/dist/lib/utils/base64-encoder.js.map +1 -0
- package/dist/lib/utils/binary-reader.d.ts +18 -0
- package/dist/lib/utils/binary-reader.d.ts.map +1 -0
- package/dist/lib/utils/binary-reader.js +70 -0
- package/dist/lib/utils/binary-reader.js.map +1 -0
- package/dist/lib/utils/binary-writer.d.ts +30 -0
- package/dist/lib/utils/binary-writer.d.ts.map +1 -0
- package/dist/lib/utils/binary-writer.js +128 -0
- package/dist/lib/utils/binary-writer.js.map +1 -0
- package/dist/lib/utils/concat-typed-arrays.d.ts +3 -0
- package/dist/lib/utils/concat-typed-arrays.d.ts.map +1 -0
- package/dist/lib/utils/concat-typed-arrays.js +19 -0
- package/dist/lib/utils/concat-typed-arrays.js.map +1 -0
- package/dist/lib/utils/hex-encoder.d.ts +15 -0
- package/dist/lib/utils/hex-encoder.d.ts.map +1 -0
- package/dist/lib/utils/hex-encoder.js +55 -0
- package/dist/lib/utils/hex-encoder.js.map +1 -0
- package/dist/lib/utils/hex-transcoder.d.ts +15 -0
- package/dist/lib/utils/hex-transcoder.d.ts.map +1 -0
- package/dist/lib/utils/hex-transcoder.js +51 -0
- package/dist/lib/utils/hex-transcoder.js.map +1 -0
- package/dist/lib/wkt-crs/encode-wkt-crs.d.ts +10 -0
- package/dist/lib/wkt-crs/encode-wkt-crs.d.ts.map +1 -0
- package/dist/lib/wkt-crs/encode-wkt-crs.js +36 -0
- package/dist/lib/wkt-crs/encode-wkt-crs.js.map +1 -0
- package/dist/lib/wkt-crs/parse-wkt-crs.d.ts +15 -0
- package/dist/lib/wkt-crs/parse-wkt-crs.d.ts.map +1 -0
- package/dist/lib/wkt-crs/parse-wkt-crs.js +121 -0
- package/dist/lib/wkt-crs/parse-wkt-crs.js.map +1 -0
- package/package.json +7 -5
- package/src/index.ts +87 -14
- package/src/lib/binary-geometry-api/binary-geometry-info.ts +75 -0
- package/src/lib/binary-geometry-api/concat-binary-geometry.ts +78 -0
- package/src/lib/{binary-features/transform.ts → binary-geometry-api/transform-coordinates.ts} +0 -1
- package/src/lib/{binary-features/binary-to-geojson.ts → feature-collection-converters/convert-binary-features-to-geojson.ts} +5 -142
- package/src/lib/{binary-features/flat-geojson-to-binary.ts → feature-collection-converters/convert-flat-geojson-to-binary-features.ts} +14 -9
- package/src/lib/feature-collection-converters/convert-geoarrow-to-binary-features.ts +496 -0
- package/src/lib/{binary-features/geojson-to-binary.ts → feature-collection-converters/convert-geojson-to-binary-features.ts} +11 -7
- package/src/lib/{binary-features/geojson-to-flat-geojson.ts → feature-collection-converters/convert-geojson-to-flat-geojson.ts} +5 -1
- package/src/lib/{binary-features → feature-collection-converters/helpers}/flat-geojson-to-binary-types.ts +4 -0
- package/src/lib/{binary-features/extract-geometry-info.ts → geometry-api/geometry-info.ts} +20 -2
- package/src/lib/geometry-converters/convert-binary-geometry-to-geojson.ts +148 -0
- package/src/lib/geometry-converters/convert-geoarrow-to-geojson.ts +193 -0
- package/src/lib/geometry-converters/convert-to-geojson.ts +52 -0
- package/src/lib/geometry-converters/wkb/convert-geometry-to-twkb.ts +308 -0
- package/src/lib/geometry-converters/wkb/convert-geometry-to-wkb.ts +365 -0
- package/src/lib/geometry-converters/wkb/convert-geometry-to-wkt.ts +54 -0
- package/src/lib/geometry-converters/wkb/convert-twkb-to-geometry.ts +366 -0
- package/src/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.ts +238 -0
- package/src/lib/geometry-converters/wkb/convert-wkb-to-geometry.ts +23 -0
- package/src/lib/geometry-converters/wkb/convert-wkt-to-geometry.ts +294 -0
- package/src/lib/geometry-converters/wkb/helpers/parse-wkb-header.ts +213 -0
- package/src/lib/geometry-converters/wkb/helpers/wkb-types.ts +82 -0
- package/src/lib/geometry-converters/wkb/helpers/wkb-utils.ts +85 -0
- package/src/lib/geometry-converters/wkb/helpers/write-wkb-header.ts +41 -0
- package/src/lib/table-converters/convert-geoarrow-table.ts +218 -0
- package/src/lib/{tables/convert-table-to-geojson.ts → table-converters/convert-wkb-table-to-geojson.ts} +10 -23
- package/src/lib/table-converters/make-arrow-batch-iterator.ts +53 -0
- package/src/lib/utils/base64-encoder.ts +157 -0
- package/src/lib/utils/binary-reader.ts +76 -0
- package/src/lib/utils/binary-writer.ts +136 -0
- package/src/lib/utils/concat-typed-arrays.ts +24 -0
- package/src/lib/utils/hex-encoder.ts +60 -0
- package/src/lib/utils/hex-transcoder.ts +54 -0
- package/src/lib/wkt-crs/encode-wkt-crs.ts +41 -0
- package/src/lib/wkt-crs/parse-wkt-crs.ts +149 -0
- package/dist/lib/binary-features/binary-to-geojson.d.ts +0 -18
- package/dist/lib/binary-features/binary-to-geojson.d.ts.map +0 -1
- package/dist/lib/binary-features/extract-geometry-info.d.ts +0 -8
- package/dist/lib/binary-features/extract-geometry-info.d.ts.map +0 -1
- package/dist/lib/binary-features/flat-geojson-to-binary-types.d.ts.map +0 -1
- package/dist/lib/binary-features/flat-geojson-to-binary-types.js +0 -1
- package/dist/lib/binary-features/flat-geojson-to-binary.d.ts.map +0 -1
- package/dist/lib/binary-features/geojson-to-binary.d.ts.map +0 -1
- package/dist/lib/binary-features/geojson-to-binary.js +0 -21
- package/dist/lib/binary-features/geojson-to-flat-geojson.d.ts.map +0 -1
- package/dist/lib/binary-features/transform.d.ts.map +0 -1
- package/dist/lib/geo/geoarrow-metadata.d.ts +0 -27
- package/dist/lib/geo/geoarrow-metadata.d.ts.map +0 -1
- package/dist/lib/geo/geoarrow-metadata.js +0 -70
- package/dist/lib/geo/geoparquet-metadata-schema.d.ts +0 -79
- package/dist/lib/geo/geoparquet-metadata-schema.d.ts.map +0 -1
- package/dist/lib/geo/geoparquet-metadata-schema.js +0 -69
- package/dist/lib/geo/geoparquet-metadata.d.ts +0 -45
- package/dist/lib/geo/geoparquet-metadata.d.ts.map +0 -1
- package/dist/lib/geo/geoparquet-metadata.js +0 -117
- package/dist/lib/tables/convert-table-to-geojson.d.ts +0 -5
- package/dist/lib/tables/convert-table-to-geojson.d.ts.map +0 -1
- package/src/lib/geo/geoarrow-metadata.ts +0 -100
- package/src/lib/geo/geoparquet-metadata-schema.json +0 -60
- package/src/lib/geo/geoparquet-metadata-schema.ts +0 -71
- package/src/lib/geo/geoparquet-metadata.ts +0 -191
- /package/dist/lib/{binary-features → feature-collection-converters/helpers}/flat-geojson-to-binary-types.d.ts +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convert-geoarrow-table.js","sourceRoot":"","sources":["../../../src/lib/table-converters/convert-geoarrow-table.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { ArrayRowTable, GeoJSONTable, ObjectRowTable, Schema } from '@loaders.gl/schema';
|
|
2
|
+
/** TODO - move to loaders.gl/gis? */
|
|
3
|
+
export declare function convertWKBTableToGeoJSON(table: ArrayRowTable | ObjectRowTable, schema: Schema): GeoJSONTable;
|
|
4
|
+
//# sourceMappingURL=convert-wkb-table-to-geojson.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convert-wkb-table-to-geojson.d.ts","sourceRoot":"","sources":["../../../src/lib/table-converters/convert-wkb-table-to-geojson.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,aAAa,EACb,YAAY,EACZ,cAAc,EACd,MAAM,EAGP,MAAM,oBAAoB,CAAC;AAM5B,qCAAqC;AACrC,wBAAgB,wBAAwB,CACtC,KAAK,EAAE,aAAa,GAAG,cAAc,EACrC,MAAM,EAAE,MAAM,GACb,YAAY,CAoBd"}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
// loaders.gl
|
|
2
2
|
// SPDX-License-Identifier: MIT
|
|
3
3
|
// Copyright (c) vis.gl contributors
|
|
4
|
-
import { getTableLength, getTableRowAsObject } from '@loaders.gl/schema';
|
|
5
|
-
import { getGeoMetadata } from
|
|
4
|
+
import { getTableLength, getTableRowAsObject } from '@loaders.gl/schema-utils';
|
|
5
|
+
import { getGeoMetadata } from '@loaders.gl/geoarrow';
|
|
6
|
+
import { convertWKBToGeometry } from "../geometry-converters/wkb/convert-wkb-to-geometry.js";
|
|
7
|
+
import { convertWKTToGeometry } from "../geometry-converters/wkb/convert-wkt-to-geometry.js";
|
|
6
8
|
/** TODO - move to loaders.gl/gis? */
|
|
7
|
-
export function convertWKBTableToGeoJSON(table, schema
|
|
8
|
-
const geoMetadata = getGeoMetadata(schema);
|
|
9
|
+
export function convertWKBTableToGeoJSON(table, schema) {
|
|
10
|
+
const geoMetadata = getGeoMetadata(schema.metadata);
|
|
9
11
|
const primaryColumn = geoMetadata?.primary_column;
|
|
10
12
|
if (!primaryColumn) {
|
|
11
13
|
throw new Error('no geometry column');
|
|
@@ -15,30 +17,23 @@ export function convertWKBTableToGeoJSON(table, schema, loaders) {
|
|
|
15
17
|
const length = getTableLength(table);
|
|
16
18
|
for (let rowIndex = 0; rowIndex < length; rowIndex++) {
|
|
17
19
|
const row = getTableRowAsObject(table, rowIndex);
|
|
18
|
-
const geometry = parseGeometry(row[primaryColumn], columnMetadata
|
|
20
|
+
const geometry = parseGeometry(row[primaryColumn], columnMetadata);
|
|
19
21
|
delete row[primaryColumn];
|
|
20
22
|
const feature = { type: 'Feature', geometry: geometry, properties: row };
|
|
21
23
|
features.push(feature);
|
|
22
24
|
}
|
|
23
25
|
return { shape: 'geojson-table', schema, type: 'FeatureCollection', features };
|
|
24
26
|
}
|
|
25
|
-
function parseGeometry(geometry, columnMetadata
|
|
27
|
+
function parseGeometry(geometry, columnMetadata) {
|
|
26
28
|
switch (columnMetadata.encoding) {
|
|
27
29
|
case 'wkt':
|
|
28
|
-
|
|
29
|
-
return wktLoader?.parseTextSync?.(geometry) || null;
|
|
30
|
+
return convertWKTToGeometry(geometry) || null;
|
|
30
31
|
case 'wkb':
|
|
31
32
|
default:
|
|
32
|
-
const wkbLoader = loaders.find((loader) => loader.id === 'wkb');
|
|
33
33
|
const arrayBuffer = ArrayBuffer.isView(geometry)
|
|
34
34
|
? geometry.buffer.slice(geometry.byteOffset, geometry.byteOffset + geometry.byteLength)
|
|
35
35
|
: geometry;
|
|
36
|
-
|
|
37
|
-
wkb: { shape: 'geojson-geometry' }
|
|
38
|
-
});
|
|
39
|
-
return geojson; // binaryGeometry ? binaryToGeometry(binaryGeometry) : null;
|
|
40
|
-
// const binaryGeometry = WKBLoader.parseSync?.(geometry);
|
|
41
|
-
// ts-ignore
|
|
42
|
-
// return binaryGeometry ? binaryToGeometry(binaryGeometry) : null;
|
|
36
|
+
return convertWKBToGeometry(arrayBuffer);
|
|
43
37
|
}
|
|
44
38
|
}
|
|
39
|
+
//# sourceMappingURL=convert-wkb-table-to-geojson.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"convert-wkb-table-to-geojson.js","sourceRoot":"","sources":["../../../src/lib/table-converters/convert-wkb-table-to-geojson.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,+BAA+B;AAC/B,oCAAoC;AAUpC,OAAO,EAAC,cAAc,EAAE,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAC7E,OAAO,EAAoB,cAAc,EAAC,MAAM,sBAAsB,CAAC;AACvE,OAAO,EAAC,oBAAoB,EAAC,8DAA2D;AACxF,OAAO,EAAC,oBAAoB,EAAC,8DAA2D;AAExF,qCAAqC;AACrC,MAAM,UAAU,wBAAwB,CACtC,KAAqC,EACrC,MAAc;IAEd,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;IACpD,MAAM,aAAa,GAAG,WAAW,EAAE,cAAc,CAAC;IAClD,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;IACxC,CAAC;IACD,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAE1D,MAAM,QAAQ,GAAc,EAAE,CAAC;IAE/B,MAAM,MAAM,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;IACrC,KAAK,IAAI,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,MAAM,EAAE,QAAQ,EAAE,EAAE,CAAC;QACrD,MAAM,GAAG,GAAG,mBAAmB,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QACjD,MAAM,QAAQ,GAAG,aAAa,CAAC,GAAG,CAAC,aAAa,CAAC,EAAE,cAAc,CAAC,CAAC;QACnE,OAAO,GAAG,CAAC,aAAa,CAAC,CAAC;QAC1B,MAAM,OAAO,GAAY,EAAC,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAS,EAAE,UAAU,EAAE,GAAG,EAAC,CAAC;QACjF,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACzB,CAAC;IAED,OAAO,EAAC,KAAK,EAAE,eAAe,EAAE,MAAM,EAAE,IAAI,EAAE,mBAAmB,EAAE,QAAQ,EAAC,CAAC;AAC/E,CAAC;AAED,SAAS,aAAa,CAAC,QAAiB,EAAE,cAAiC;IACzE,QAAQ,cAAc,CAAC,QAAQ,EAAE,CAAC;QAChC,KAAK,KAAK;YACR,OAAO,oBAAoB,CAAC,QAAkB,CAAC,IAAI,IAAI,CAAC;QAC1D,KAAK,KAAK,CAAC;QACX;YACE,MAAM,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC;gBAC9C,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,UAAU,EAAE,QAAQ,CAAC,UAAU,GAAG,QAAQ,CAAC,UAAU,CAAC;gBACvF,CAAC,CAAE,QAAwB,CAAC;YAC9B,OAAO,oBAAoB,CAAC,WAAW,CAAC,CAAC;IAC7C,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import * as arrow from 'apache-arrow';
|
|
2
|
+
import type { Table } from '@loaders.gl/schema';
|
|
3
|
+
export declare function makeTableToArrowBatchesIterator(table: Table, options?: {
|
|
4
|
+
batchSize?: number;
|
|
5
|
+
}): IterableIterator<arrow.RecordBatch>;
|
|
6
|
+
//# sourceMappingURL=make-arrow-batch-iterator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"make-arrow-batch-iterator.d.ts","sourceRoot":"","sources":["../../../src/lib/table-converters/make-arrow-batch-iterator.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,KAAK,EAAC,KAAK,EAAC,MAAM,oBAAoB,CAAC;AAQ9C,wBAAiB,+BAA+B,CAC9C,KAAK,EAAE,KAAK,EACZ,OAAO,CAAC,EAAE;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAC,GAC7B,gBAAgB,CAAC,KAAK,CAAC,WAAW,CAAC,CAoCrC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
// loaders.gl
|
|
2
|
+
// SPDX-License-Identifier: MIT
|
|
3
|
+
// Copyright (c) vis.gl contributors
|
|
4
|
+
import * as arrow from 'apache-arrow';
|
|
5
|
+
import { convertSchemaToArrow, getTableLength, getTableNumCols, getTableCellAt } from '@loaders.gl/schema-utils';
|
|
6
|
+
export function* makeTableToArrowBatchesIterator(table, options) {
|
|
7
|
+
const arrowSchema = convertSchemaToArrow(table.schema);
|
|
8
|
+
const length = getTableLength(table);
|
|
9
|
+
const numColumns = getTableNumCols(table);
|
|
10
|
+
const batchSize = options?.batchSize || length;
|
|
11
|
+
const builders = arrowSchema?.fields.map((arrowField) => arrow.makeBuilder(arrowField));
|
|
12
|
+
const structField = new arrow.Struct(arrowSchema.fields);
|
|
13
|
+
let batchLength = 0;
|
|
14
|
+
for (let rowIndex = 0; rowIndex < length; rowIndex++) {
|
|
15
|
+
for (let columnIndex = 0; columnIndex < numColumns; ++columnIndex) {
|
|
16
|
+
const value = getTableCellAt(table, rowIndex, columnIndex);
|
|
17
|
+
const builder = builders[columnIndex];
|
|
18
|
+
builder.append(value);
|
|
19
|
+
batchLength++;
|
|
20
|
+
if (batchLength >= batchSize) {
|
|
21
|
+
const datas = builders.map((builder) => builder.flush());
|
|
22
|
+
const structData = new arrow.Data(structField, 0, batchLength, 0, undefined, datas);
|
|
23
|
+
yield new arrow.RecordBatch(arrowSchema, structData);
|
|
24
|
+
batchLength = 0;
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
if (batchLength > 0) {
|
|
29
|
+
const datas = builders.map((builder) => builder.flush());
|
|
30
|
+
const structData = new arrow.Data(structField, 0, batchLength, 0, undefined, datas);
|
|
31
|
+
yield new arrow.RecordBatch(arrowSchema, structData);
|
|
32
|
+
batchLength = 0;
|
|
33
|
+
}
|
|
34
|
+
builders.map((builder) => builder.finish());
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=make-arrow-batch-iterator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"make-arrow-batch-iterator.js","sourceRoot":"","sources":["../../../src/lib/table-converters/make-arrow-batch-iterator.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,+BAA+B;AAC/B,oCAAoC;AAEpC,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAEtC,OAAO,EACL,oBAAoB,EACpB,cAAc,EACd,eAAe,EACf,cAAc,EACf,MAAM,0BAA0B,CAAC;AAElC,MAAM,SAAS,CAAC,CAAC,+BAA+B,CAC9C,KAAY,EACZ,OAA8B;IAE9B,MAAM,WAAW,GAAG,oBAAoB,CAAC,KAAK,CAAC,MAAO,CAAC,CAAC;IAExD,MAAM,MAAM,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;IACrC,MAAM,UAAU,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;IAC1C,MAAM,SAAS,GAAG,OAAO,EAAE,SAAS,IAAI,MAAM,CAAC;IAE/C,MAAM,QAAQ,GAAG,WAAW,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC;IACxF,MAAM,WAAW,GAAG,IAAI,KAAK,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAEzD,IAAI,WAAW,GAAG,CAAC,CAAC;IACpB,KAAK,IAAI,QAAQ,GAAG,CAAC,EAAE,QAAQ,GAAG,MAAM,EAAE,QAAQ,EAAE,EAAE,CAAC;QACrD,KAAK,IAAI,WAAW,GAAG,CAAC,EAAE,WAAW,GAAG,UAAU,EAAE,EAAE,WAAW,EAAE,CAAC;YAClE,MAAM,KAAK,GAAG,cAAc,CAAC,KAAK,EAAE,QAAQ,EAAE,WAAW,CAAC,CAAC;YAE3D,MAAM,OAAO,GAAG,QAAQ,CAAC,WAAW,CAAC,CAAC;YACtC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACtB,WAAW,EAAE,CAAC;YAEd,IAAI,WAAW,IAAI,SAAS,EAAE,CAAC;gBAC7B,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;gBACzD,MAAM,UAAU,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;gBACpF,MAAM,IAAI,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;gBACrD,WAAW,GAAG,CAAC,CAAC;YAClB,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;QACpB,MAAM,KAAK,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;QACzD,MAAM,UAAU,GAAG,IAAI,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,EAAE,WAAW,EAAE,CAAC,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC;QACpF,MAAM,IAAI,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;QACrD,WAAW,GAAG,CAAC,CAAC;IAClB,CAAC;IAED,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;AAC9C,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base64-encoder.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/base64-encoder.ts"],"names":[],"mappings":"AA0BA,qBAAa,aAAa;IACxB,gBAAgB,CAAC,KAAK,EAAE,UAAU,GAAG,MAAM;IAI3C,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,WAAW;CAC/C"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
// loaders.gl
|
|
2
|
+
// SPDX-License-Identifier: MIT
|
|
3
|
+
// Copyright (c) vis.gl contributors
|
|
4
|
+
/*
|
|
5
|
+
const binary_to_b64_map = [
|
|
6
|
+
'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I',
|
|
7
|
+
'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R',
|
|
8
|
+
'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'a',
|
|
9
|
+
'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j',
|
|
10
|
+
'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's',
|
|
11
|
+
't', 'u', 'v', 'w', 'x', 'y', 'z', '0', '1',
|
|
12
|
+
'2', '3', '4', '5', '6', '7', '8', '9', '+',
|
|
13
|
+
'/', '='
|
|
14
|
+
];
|
|
15
|
+
const b64_to_binary_map = {
|
|
16
|
+
'0': 52, '1': 53, '2': 54, '3': 55, '4': 56, '5': 57, '6': 58, '7': 59, '8': 60, '9': 61,
|
|
17
|
+
A: 0, B: 1, C: 2, D: 3, E: 4, F: 5, G: 6, H: 7, I: 8, J: 9, K: 10, L: 11, M: 12, N: 13, O: 14,
|
|
18
|
+
P: 15, Q: 16, R: 17, S: 18, T: 19, U: 20, V: 21, W: 22, X: 23, Y: 24, Z: 25, a: 26, b: 27,
|
|
19
|
+
c: 28, d: 29, e: 30, f: 31, g: 32, h: 33, i: 34, j: 35, k: 36, l: 37, m: 38, n: 39, o: 40,
|
|
20
|
+
p: 41, q: 42, r: 43, s: 44, t: 45, u: 46, v: 47, w: 48, x: 49, y: 50, z: 51, '+': 62, '/': 63,
|
|
21
|
+
'=': 64
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
*/
|
|
25
|
+
export class Base64Encoder {
|
|
26
|
+
getDecodedLength(array) {
|
|
27
|
+
return Math.ceil(array.byteLength / 4) * 3;
|
|
28
|
+
}
|
|
29
|
+
decode(array, target) { } // eslint-disable-line
|
|
30
|
+
}
|
|
31
|
+
/*
|
|
32
|
+
|
|
33
|
+
//generates an array iterator that returns 3 elements at a time. Use to loop through the Uint8Array Array Buffer
|
|
34
|
+
// to be converted to Base64. (binary array buffer) 8bits * 3 = 6bits * 4 (base64 representation)
|
|
35
|
+
const generateTripleIterator = (arr) => {
|
|
36
|
+
return {
|
|
37
|
+
*[Symbol.iterator]() {
|
|
38
|
+
for(let n = 0; n < arr.length; n+=3) {
|
|
39
|
+
let result = [];
|
|
40
|
+
result.push(arr[n]);
|
|
41
|
+
|
|
42
|
+
if(n+1 < arr.length)
|
|
43
|
+
result.push(arr[n+1]);
|
|
44
|
+
if(n+2 < arr.length)
|
|
45
|
+
result.push(arr[n+2]);
|
|
46
|
+
|
|
47
|
+
yield result;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
//generates an array iterator that returns 4 elements at a time. Use to loop through
|
|
54
|
+
// Base64 string because Base64 string is multiples of 4 characters.
|
|
55
|
+
const generateQuadrupleIterator = (arr) => {
|
|
56
|
+
return {
|
|
57
|
+
*[Symbol.iterator]() {
|
|
58
|
+
for(let n = 0; n < arr.length; n+=4) {
|
|
59
|
+
yield [...arr.slice(n, n+4)];
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
// Converts a triple of 8 bits into a quadruple of 6 bits. use to convert binary to base64 representation
|
|
66
|
+
const tripleConvert = (first, second, third) => {
|
|
67
|
+
let [] = triple;
|
|
68
|
+
let binary = null, a = null, b = null, c = null, d = null;
|
|
69
|
+
if (triple.length === 1) {
|
|
70
|
+
binary = (first << 4);
|
|
71
|
+
a = ((binary & 4032) >>> 6);
|
|
72
|
+
b = (binary & 63);
|
|
73
|
+
c = 64;
|
|
74
|
+
d = 64;
|
|
75
|
+
} else if (triple.length === 2) {
|
|
76
|
+
binary = ((first << 10) | (second << 2));
|
|
77
|
+
a = ((binary & 258048) >>> 12);
|
|
78
|
+
b = ((binary & 4032) >>> 6);
|
|
79
|
+
c = (binary & 63);
|
|
80
|
+
d = 64;
|
|
81
|
+
} else {
|
|
82
|
+
binary = ((first << 16) | (second << 8) | third);
|
|
83
|
+
a = ((binary & 16515072) >>> 18);
|
|
84
|
+
b = ((binary & 258048) >>> 12);
|
|
85
|
+
c = ((binary & 4032) >>> 6);
|
|
86
|
+
d = (binary & 63);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
return [a, b, c, d];
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
// Converts a quadruple of 6 bits into a triple of 8 bits. use to convert base64 representation into binary
|
|
93
|
+
const quadrupleConvert = (quadruple) => {
|
|
94
|
+
let [a, b, c, d] = quadruple;
|
|
95
|
+
let binary = null, first = null, second = null, third = null;
|
|
96
|
+
|
|
97
|
+
if(c === 64 && d === 64) {
|
|
98
|
+
//two padding
|
|
99
|
+
binary = ((a << 6) | b);
|
|
100
|
+
first = (binary >> 4); //shift off 4 bits, 2 bits per padding
|
|
101
|
+
} else if(d === 64) {
|
|
102
|
+
//one padding
|
|
103
|
+
binary = ((a << 12) | (b << 6) | c );
|
|
104
|
+
binary = (binary >> 2); //shift off 2 bits
|
|
105
|
+
first = binary >> 8;
|
|
106
|
+
second = ((binary << 24) >>> 24);
|
|
107
|
+
} else {
|
|
108
|
+
//no padding
|
|
109
|
+
binary = ((a << 18) | (b << 12) | (c << 6) | d );
|
|
110
|
+
first = (binary >>> 16);
|
|
111
|
+
second = ((binary << 16) >>> 24);
|
|
112
|
+
third = ((binary << 24) >>> 24);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
return [first, second, third];
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
// Convert 8Bits Array Buffer to Base64 string
|
|
119
|
+
export const ab2b64 = (buffer) => {
|
|
120
|
+
const b64strArray = [];
|
|
121
|
+
const view = new Uint8Array(buffer);
|
|
122
|
+
let iterator = generateTripleIterator(view);
|
|
123
|
+
for(let triple of iterator) {
|
|
124
|
+
b64strArray.push(...tripleConvert(triple));
|
|
125
|
+
}
|
|
126
|
+
return b64strArray.map(b64CharCodePoint => binary_to_b64_map[b64CharCodePoint]).join("");
|
|
127
|
+
};
|
|
128
|
+
|
|
129
|
+
// Convert Base64 String to 8Bits Array Buffer
|
|
130
|
+
export const b642ab = (b64str) => {
|
|
131
|
+
let buffer_length = (b64str.length / 4) * 3;
|
|
132
|
+
if(b64str.slice(-2) === '==') {
|
|
133
|
+
buffer_length -= 2;
|
|
134
|
+
} else if(b64str.slice(-1) === '=') {
|
|
135
|
+
buffer_length -= 1;
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
let buffer = new ArrayBuffer(buffer_length);
|
|
139
|
+
const view = new Uint8Array(buffer);
|
|
140
|
+
let iterator = generateQuadrupleIterator(b64str.split("").map(b64char => b64_to_binary_map[b64char]));
|
|
141
|
+
let byteIndex = 0;
|
|
142
|
+
for(let quadruple of iterator) {
|
|
143
|
+
quadrupleConvert(quadruple).forEach(byte => {
|
|
144
|
+
if(byte != null) {
|
|
145
|
+
view[byteIndex] = byte;
|
|
146
|
+
byteIndex++;
|
|
147
|
+
}
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
return buffer;
|
|
151
|
+
};
|
|
152
|
+
|
|
153
|
+
*/
|
|
154
|
+
//# sourceMappingURL=base64-encoder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base64-encoder.js","sourceRoot":"","sources":["../../../src/lib/utils/base64-encoder.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,+BAA+B;AAC/B,oCAAoC;AAEpC;;;;;;;;;;;;;;;;;;;;EAoBE;AAEF,MAAM,OAAO,aAAa;IACxB,gBAAgB,CAAC,KAAiB;QAChC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC;IAC7C,CAAC;IAED,MAAM,CAAC,KAAiB,EAAE,MAAoB,IAAG,CAAC,CAAC,sBAAsB;CAC1E;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA0HE"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/** A DataView that tracks byte offset when reading. */
|
|
2
|
+
export declare class BinaryReader {
|
|
3
|
+
arrayBuffer: ArrayBuffer;
|
|
4
|
+
dataView: DataView;
|
|
5
|
+
byteOffset: number;
|
|
6
|
+
littleEndian: boolean;
|
|
7
|
+
constructor(arrayBuffer: ArrayBuffer, isBigEndian?: boolean);
|
|
8
|
+
readUInt8(): number;
|
|
9
|
+
readUInt16(): number;
|
|
10
|
+
readUInt32(): number;
|
|
11
|
+
readInt8(): number;
|
|
12
|
+
readInt16(): number;
|
|
13
|
+
readInt32(): number;
|
|
14
|
+
readFloat(): number;
|
|
15
|
+
readDouble(): number;
|
|
16
|
+
readVarInt(): number;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=binary-reader.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"binary-reader.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/binary-reader.ts"],"names":[],"mappings":"AAIA,uDAAuD;AACvD,qBAAa,YAAY;IACvB,WAAW,EAAE,WAAW,CAAC;IACzB,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,OAAO,CAAC;gBAEV,WAAW,EAAE,WAAW,EAAE,WAAW,GAAE,OAAe;IAOlE,SAAS;IAKT,UAAU;IAKV,UAAU;IAKV,QAAQ;IAKR,SAAS;IAKT,SAAS;IAKT,SAAS;IAKT,UAAU;IAMV,UAAU;CAgBX"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
// loaders.gl
|
|
2
|
+
// SPDX-License-Identifier: MIT
|
|
3
|
+
// Copyright (c) vis.gl contributors
|
|
4
|
+
/** A DataView that tracks byte offset when reading. */
|
|
5
|
+
export class BinaryReader {
|
|
6
|
+
arrayBuffer;
|
|
7
|
+
dataView;
|
|
8
|
+
byteOffset;
|
|
9
|
+
littleEndian;
|
|
10
|
+
constructor(arrayBuffer, isBigEndian = false) {
|
|
11
|
+
this.arrayBuffer = arrayBuffer;
|
|
12
|
+
this.dataView = new DataView(arrayBuffer);
|
|
13
|
+
this.byteOffset = 0;
|
|
14
|
+
this.littleEndian = !isBigEndian;
|
|
15
|
+
}
|
|
16
|
+
readUInt8() {
|
|
17
|
+
const value = this.dataView.getUint8(this.byteOffset);
|
|
18
|
+
this.byteOffset += 1;
|
|
19
|
+
return value;
|
|
20
|
+
}
|
|
21
|
+
readUInt16() {
|
|
22
|
+
const value = this.dataView.getUint16(this.byteOffset, this.littleEndian);
|
|
23
|
+
this.byteOffset += 2;
|
|
24
|
+
return value;
|
|
25
|
+
}
|
|
26
|
+
readUInt32() {
|
|
27
|
+
const value = this.dataView.getUint32(this.byteOffset, this.littleEndian);
|
|
28
|
+
this.byteOffset += 4;
|
|
29
|
+
return value;
|
|
30
|
+
}
|
|
31
|
+
readInt8() {
|
|
32
|
+
const value = this.dataView.getInt8(this.byteOffset);
|
|
33
|
+
this.byteOffset += 1;
|
|
34
|
+
return value;
|
|
35
|
+
}
|
|
36
|
+
readInt16() {
|
|
37
|
+
const value = this.dataView.getInt16(this.byteOffset, this.littleEndian);
|
|
38
|
+
this.byteOffset += 2;
|
|
39
|
+
return value;
|
|
40
|
+
}
|
|
41
|
+
readInt32() {
|
|
42
|
+
const value = this.dataView.getInt32(this.byteOffset, this.littleEndian);
|
|
43
|
+
this.byteOffset += 4;
|
|
44
|
+
return value;
|
|
45
|
+
}
|
|
46
|
+
readFloat() {
|
|
47
|
+
const value = this.dataView.getFloat32(this.byteOffset, this.littleEndian);
|
|
48
|
+
this.byteOffset += 4;
|
|
49
|
+
return value;
|
|
50
|
+
}
|
|
51
|
+
readDouble() {
|
|
52
|
+
const value = this.dataView.getFloat64(this.byteOffset, this.littleEndian);
|
|
53
|
+
this.byteOffset += 8;
|
|
54
|
+
return value;
|
|
55
|
+
}
|
|
56
|
+
readVarInt() {
|
|
57
|
+
let result = 0;
|
|
58
|
+
let bytesRead = 0;
|
|
59
|
+
let nextByte;
|
|
60
|
+
do {
|
|
61
|
+
// TODO - this needs to be accessed via data view?
|
|
62
|
+
nextByte = this.dataView.getUint8(this.byteOffset + bytesRead);
|
|
63
|
+
result += (nextByte & 0x7f) << (7 * bytesRead);
|
|
64
|
+
bytesRead++;
|
|
65
|
+
} while (nextByte >= 0x80);
|
|
66
|
+
this.byteOffset += bytesRead;
|
|
67
|
+
return result;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
//# sourceMappingURL=binary-reader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"binary-reader.js","sourceRoot":"","sources":["../../../src/lib/utils/binary-reader.ts"],"names":[],"mappings":"AAAA,aAAa;AACb,+BAA+B;AAC/B,oCAAoC;AAEpC,uDAAuD;AACvD,MAAM,OAAO,YAAY;IACvB,WAAW,CAAc;IACzB,QAAQ,CAAW;IACnB,UAAU,CAAS;IACnB,YAAY,CAAU;IAEtB,YAAY,WAAwB,EAAE,cAAuB,KAAK;QAChE,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,QAAQ,GAAG,IAAI,QAAQ,CAAC,WAAW,CAAC,CAAC;QAC1C,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,YAAY,GAAG,CAAC,WAAW,CAAC;IACnC,CAAC;IAED,SAAS;QACP,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACtD,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,UAAU;QACR,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1E,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,UAAU;QACR,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC1E,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,QAAQ;QACN,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrD,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,SAAS;QACP,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACzE,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,SAAS;QACP,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACzE,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,SAAS;QACP,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC3E,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IACD,UAAU;QACR,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAC3E,IAAI,CAAC,UAAU,IAAI,CAAC,CAAC;QACrB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,UAAU;QACR,IAAI,MAAM,GAAG,CAAC,CAAC;QACf,IAAI,SAAS,GAAG,CAAC,CAAC;QAElB,IAAI,QAAQ,CAAC;QACb,GAAG,CAAC;YACF,kDAAkD;YAClD,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC,CAAC;YAC/D,MAAM,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC;YAC/C,SAAS,EAAE,CAAC;QACd,CAAC,QAAQ,QAAQ,IAAI,IAAI,EAAE;QAE3B,IAAI,CAAC,UAAU,IAAI,SAAS,CAAC;QAE7B,OAAO,MAAM,CAAC;IAChB,CAAC;CACF"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { TypedArray } from '@math.gl/types';
|
|
2
|
+
export declare class BinaryWriter {
|
|
3
|
+
arrayBuffer: ArrayBuffer;
|
|
4
|
+
dataView: DataView;
|
|
5
|
+
byteOffset: number;
|
|
6
|
+
allowResize: boolean;
|
|
7
|
+
constructor(size: number, allowResize?: boolean);
|
|
8
|
+
writeUInt8(value: number): void;
|
|
9
|
+
writeUInt16LE(value: number): void;
|
|
10
|
+
writeUInt16BE(value: number): void;
|
|
11
|
+
writeUInt32LE(value: number): void;
|
|
12
|
+
writeUInt32BE(value: number): void;
|
|
13
|
+
writeInt8(value: number): void;
|
|
14
|
+
writeInt16LE(value: number): void;
|
|
15
|
+
writeInt16BE(value: number): void;
|
|
16
|
+
writeInt32LE(value: number): void;
|
|
17
|
+
writeInt32BE(value: number): void;
|
|
18
|
+
writeFloatLE(value: number): void;
|
|
19
|
+
writeFloatBE(value: number): void;
|
|
20
|
+
writeDoubleLE(value: number): void;
|
|
21
|
+
writeDoubleBE(value: number): void;
|
|
22
|
+
/** A varint uses a variable number of bytes */
|
|
23
|
+
writeVarInt(value: number): number;
|
|
24
|
+
writeTypedArray(typedArray: TypedArray): void;
|
|
25
|
+
/** Append another ArrayBuffer to this ArrayBuffer */
|
|
26
|
+
writeBuffer(arrayBuffer: ArrayBuffer): void;
|
|
27
|
+
/** Resizes this.arrayBuffer if not enough space */
|
|
28
|
+
_ensureSize(size: number): void;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=binary-writer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"binary-writer.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/binary-writer.ts"],"names":[],"mappings":"AAKA,OAAO,EAAC,UAAU,EAAC,MAAM,gBAAgB,CAAC;AAK1C,qBAAa,YAAY;IACvB,WAAW,EAAE,WAAW,CAAC;IACzB,QAAQ,EAAE,QAAQ,CAAC;IACnB,UAAU,EAAE,MAAM,CAAK;IACvB,WAAW,EAAE,OAAO,CAAS;gBAEjB,IAAI,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,OAAO;IAO/C,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAK/B,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKlC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKlC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKlC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKlC,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAK9B,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKjC,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKjC,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKjC,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKjC,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKjC,YAAY,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKjC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAKlC,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMlC,+CAA+C;IAC/C,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM;IAYlC,eAAe,CAAC,UAAU,EAAE,UAAU;IAOtC,qDAAqD;IACrD,WAAW,CAAC,WAAW,EAAE,WAAW,GAAG,IAAI;IAO3C,mDAAmD;IACnD,WAAW,CAAC,IAAI,EAAE,MAAM;CAYzB"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
// loaders.gl
|
|
2
|
+
// SPDX-License-Identifier: MIT
|
|
3
|
+
// Copyright (c) vis.gl contributors
|
|
4
|
+
// Forked from https://github.com/cschwarz/wkx under MIT license, Copyright (c) 2013 Christian Schwarz
|
|
5
|
+
const LE = true;
|
|
6
|
+
const BE = false;
|
|
7
|
+
export class BinaryWriter {
|
|
8
|
+
arrayBuffer;
|
|
9
|
+
dataView;
|
|
10
|
+
byteOffset = 0;
|
|
11
|
+
allowResize = false;
|
|
12
|
+
constructor(size, allowResize) {
|
|
13
|
+
this.arrayBuffer = new ArrayBuffer(size);
|
|
14
|
+
this.dataView = new DataView(this.arrayBuffer);
|
|
15
|
+
this.byteOffset = 0;
|
|
16
|
+
this.allowResize = allowResize || false;
|
|
17
|
+
}
|
|
18
|
+
writeUInt8(value) {
|
|
19
|
+
this._ensureSize(1);
|
|
20
|
+
this.dataView.setUint8(this.byteOffset, value);
|
|
21
|
+
this.byteOffset += 1;
|
|
22
|
+
}
|
|
23
|
+
writeUInt16LE(value) {
|
|
24
|
+
this._ensureSize(2);
|
|
25
|
+
this.dataView.setUint16(this.byteOffset, value, LE);
|
|
26
|
+
this.byteOffset += 2;
|
|
27
|
+
}
|
|
28
|
+
writeUInt16BE(value) {
|
|
29
|
+
this._ensureSize(2);
|
|
30
|
+
this.dataView.setUint16(this.byteOffset, value, BE);
|
|
31
|
+
this.byteOffset += 2;
|
|
32
|
+
}
|
|
33
|
+
writeUInt32LE(value) {
|
|
34
|
+
this._ensureSize(4);
|
|
35
|
+
this.dataView.setUint32(this.byteOffset, value, LE);
|
|
36
|
+
this.byteOffset += 4;
|
|
37
|
+
}
|
|
38
|
+
writeUInt32BE(value) {
|
|
39
|
+
this._ensureSize(4);
|
|
40
|
+
this.dataView.setUint32(this.byteOffset, value, BE);
|
|
41
|
+
this.byteOffset += 4;
|
|
42
|
+
}
|
|
43
|
+
writeInt8(value) {
|
|
44
|
+
this._ensureSize(1);
|
|
45
|
+
this.dataView.setInt8(this.byteOffset, value);
|
|
46
|
+
this.byteOffset += 1;
|
|
47
|
+
}
|
|
48
|
+
writeInt16LE(value) {
|
|
49
|
+
this._ensureSize(2);
|
|
50
|
+
this.dataView.setInt16(this.byteOffset, value, LE);
|
|
51
|
+
this.byteOffset += 2;
|
|
52
|
+
}
|
|
53
|
+
writeInt16BE(value) {
|
|
54
|
+
this._ensureSize(2);
|
|
55
|
+
this.dataView.setInt16(this.byteOffset, value, BE);
|
|
56
|
+
this.byteOffset += 2;
|
|
57
|
+
}
|
|
58
|
+
writeInt32LE(value) {
|
|
59
|
+
this._ensureSize(4);
|
|
60
|
+
this.dataView.setInt32(this.byteOffset, value, LE);
|
|
61
|
+
this.byteOffset += 4;
|
|
62
|
+
}
|
|
63
|
+
writeInt32BE(value) {
|
|
64
|
+
this._ensureSize(4);
|
|
65
|
+
this.dataView.setInt32(this.byteOffset, value, BE);
|
|
66
|
+
this.byteOffset += 4;
|
|
67
|
+
}
|
|
68
|
+
writeFloatLE(value) {
|
|
69
|
+
this._ensureSize(4);
|
|
70
|
+
this.dataView.setFloat32(this.byteOffset, value, LE);
|
|
71
|
+
this.byteOffset += 4;
|
|
72
|
+
}
|
|
73
|
+
writeFloatBE(value) {
|
|
74
|
+
this._ensureSize(4);
|
|
75
|
+
this.dataView.setFloat32(this.byteOffset, value, BE);
|
|
76
|
+
this.byteOffset += 4;
|
|
77
|
+
}
|
|
78
|
+
writeDoubleLE(value) {
|
|
79
|
+
this._ensureSize(8);
|
|
80
|
+
this.dataView.setFloat64(this.byteOffset, value, LE);
|
|
81
|
+
this.byteOffset += 8;
|
|
82
|
+
}
|
|
83
|
+
writeDoubleBE(value) {
|
|
84
|
+
this._ensureSize(8);
|
|
85
|
+
this.dataView.setFloat64(this.byteOffset, value, BE);
|
|
86
|
+
this.byteOffset += 8;
|
|
87
|
+
}
|
|
88
|
+
/** A varint uses a variable number of bytes */
|
|
89
|
+
writeVarInt(value) {
|
|
90
|
+
// TODO - ensure size?
|
|
91
|
+
let length = 1;
|
|
92
|
+
while ((value & 0xffffff80) !== 0) {
|
|
93
|
+
this.writeUInt8((value & 0x7f) | 0x80);
|
|
94
|
+
value >>>= 7;
|
|
95
|
+
length++;
|
|
96
|
+
}
|
|
97
|
+
this.writeUInt8(value & 0x7f);
|
|
98
|
+
return length;
|
|
99
|
+
}
|
|
100
|
+
writeTypedArray(typedArray) {
|
|
101
|
+
this._ensureSize(typedArray.byteLength);
|
|
102
|
+
const tempArray = new Uint8Array(this.arrayBuffer);
|
|
103
|
+
tempArray.set(typedArray, this.byteOffset);
|
|
104
|
+
this.byteOffset += typedArray.byteLength;
|
|
105
|
+
}
|
|
106
|
+
/** Append another ArrayBuffer to this ArrayBuffer */
|
|
107
|
+
writeBuffer(arrayBuffer) {
|
|
108
|
+
this._ensureSize(arrayBuffer.byteLength);
|
|
109
|
+
const tempArray = new Uint8Array(this.arrayBuffer);
|
|
110
|
+
tempArray.set(new Uint8Array(arrayBuffer), this.byteOffset);
|
|
111
|
+
this.byteOffset += arrayBuffer.byteLength;
|
|
112
|
+
}
|
|
113
|
+
/** Resizes this.arrayBuffer if not enough space */
|
|
114
|
+
_ensureSize(size) {
|
|
115
|
+
if (this.arrayBuffer.byteLength < this.byteOffset + size) {
|
|
116
|
+
if (this.allowResize) {
|
|
117
|
+
const newArrayBuffer = new ArrayBuffer(this.byteOffset + size);
|
|
118
|
+
const tempArray = new Uint8Array(newArrayBuffer);
|
|
119
|
+
tempArray.set(new Uint8Array(this.arrayBuffer));
|
|
120
|
+
this.arrayBuffer = newArrayBuffer;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
throw new Error('BinaryWriter overflow');
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=binary-writer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"binary-writer.js","sourceRoot":"","sources":["../../../src/lib/utils/binary-writer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"concat-typed-arrays.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/concat-typed-arrays.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,oBAAoB,CAAC;AAInD,wBAAgB,iBAAiB,CAAC,MAAM,EAAE,UAAU,EAAE,GAAG,UAAU,CAgBlE"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
// TODO: remove copy; import from typed-array-utils
|
|
2
|
+
// modules/math/src/geometry/typed-arrays/typed-array-utils.js
|
|
3
|
+
export function concatTypedArrays(arrays) {
|
|
4
|
+
let byteLength = 0;
|
|
5
|
+
for (let i = 0; i < arrays.length; ++i) {
|
|
6
|
+
byteLength += arrays[i].byteLength;
|
|
7
|
+
}
|
|
8
|
+
const buffer = new Uint8Array(byteLength);
|
|
9
|
+
let byteOffset = 0;
|
|
10
|
+
for (let i = 0; i < arrays.length; ++i) {
|
|
11
|
+
const data = new Uint8Array(arrays[i].buffer);
|
|
12
|
+
byteLength = data.length;
|
|
13
|
+
for (let j = 0; j < byteLength; ++j) {
|
|
14
|
+
buffer[byteOffset++] = data[j];
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
return buffer;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=concat-typed-arrays.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"concat-typed-arrays.js","sourceRoot":"","sources":["../../../src/lib/utils/concat-typed-arrays.ts"],"names":[],"mappings":"AAKA,mDAAmD;AACnD,8DAA8D;AAC9D,MAAM,UAAU,iBAAiB,CAAC,MAAoB;IACpD,IAAI,UAAU,GAAG,CAAC,CAAC;IACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC;QACvC,UAAU,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;IACrC,CAAC;IACD,MAAM,MAAM,GAAG,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC;IAE1C,IAAI,UAAU,GAAG,CAAC,CAAC;IACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE,CAAC;QACvC,MAAM,IAAI,GAAG,IAAI,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QAC9C,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;QACzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,EAAE,CAAC,EAAE,CAAC;YACpC,MAAM,CAAC,UAAU,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC;IACH,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Simple helper to decode and encode "hex encoded" binary buffers
|
|
3
|
+
* without first converting to string.
|
|
4
|
+
*/
|
|
5
|
+
export declare class HexEncoder {
|
|
6
|
+
/** Get length in bytes required to store encoded data */
|
|
7
|
+
getEncodedLength(array: Uint8Array): number;
|
|
8
|
+
/** Get length in bytes required to store decoded data */
|
|
9
|
+
getDecodedLength(array: Uint8Array): number;
|
|
10
|
+
/** Decode hexadecimal */
|
|
11
|
+
decode(array: Uint8Array, result: Uint8Array): Uint8Array;
|
|
12
|
+
/** Encode hexadecimal */
|
|
13
|
+
encode(array: Uint8Array, result: Uint8Array): Uint8Array;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=hex-encoder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hex-encoder.d.ts","sourceRoot":"","sources":["../../../src/lib/utils/hex-encoder.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,qBAAa,UAAU;IACrB,yDAAyD;IACzD,gBAAgB,CAAC,KAAK,EAAE,UAAU,GAAG,MAAM;IAI3C,yDAAyD;IACzD,gBAAgB,CAAC,KAAK,EAAE,UAAU,GAAG,MAAM;IAI3C,yBAAyB;IACzB,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,GAAG,UAAU;IAazD,yBAAyB;IACzB,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,GAAG,UAAU;CAQ1D"}
|