@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.
Files changed (209) hide show
  1. package/dist/index.cjs +2411 -469
  2. package/dist/index.cjs.map +4 -4
  3. package/dist/index.d.ts +31 -12
  4. package/dist/index.d.ts.map +1 -1
  5. package/dist/index.js +39 -15
  6. package/dist/index.js.map +1 -0
  7. package/dist/lib/binary-geometry-api/binary-geometry-info.d.ts +21 -0
  8. package/dist/lib/binary-geometry-api/binary-geometry-info.d.ts.map +1 -0
  9. package/dist/lib/binary-geometry-api/binary-geometry-info.js +49 -0
  10. package/dist/lib/binary-geometry-api/binary-geometry-info.js.map +1 -0
  11. package/dist/lib/binary-geometry-api/concat-binary-geometry.d.ts +5 -0
  12. package/dist/lib/binary-geometry-api/concat-binary-geometry.d.ts.map +1 -0
  13. package/dist/lib/binary-geometry-api/concat-binary-geometry.js +51 -0
  14. package/dist/lib/binary-geometry-api/concat-binary-geometry.js.map +1 -0
  15. package/dist/lib/{binary-features/transform.d.ts → binary-geometry-api/transform-coordinates.d.ts} +1 -2
  16. package/dist/lib/binary-geometry-api/transform-coordinates.d.ts.map +1 -0
  17. package/dist/lib/{binary-features/transform.js → binary-geometry-api/transform-coordinates.js} +1 -1
  18. package/dist/lib/binary-geometry-api/transform-coordinates.js.map +1 -0
  19. package/dist/lib/feature-collection-converters/convert-binary-features-to-geojson.d.ts +16 -0
  20. package/dist/lib/feature-collection-converters/convert-binary-features-to-geojson.d.ts.map +1 -0
  21. package/dist/lib/{binary-features/binary-to-geojson.js → feature-collection-converters/convert-binary-features-to-geojson.js} +4 -90
  22. package/dist/lib/feature-collection-converters/convert-binary-features-to-geojson.js.map +1 -0
  23. package/dist/lib/{binary-features/flat-geojson-to-binary.d.ts → feature-collection-converters/convert-flat-geojson-to-binary-features.d.ts} +6 -9
  24. package/dist/lib/feature-collection-converters/convert-flat-geojson-to-binary-features.d.ts.map +1 -0
  25. package/dist/lib/{binary-features/flat-geojson-to-binary.js → feature-collection-converters/convert-flat-geojson-to-binary-features.js} +6 -5
  26. package/dist/lib/feature-collection-converters/convert-flat-geojson-to-binary-features.js.map +1 -0
  27. package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.d.ts +74 -0
  28. package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.d.ts.map +1 -0
  29. package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.js +378 -0
  30. package/dist/lib/feature-collection-converters/convert-geoarrow-to-binary-features.js.map +1 -0
  31. package/dist/lib/{binary-features/geojson-to-binary.d.ts → feature-collection-converters/convert-geojson-to-binary-features.d.ts} +2 -2
  32. package/dist/lib/feature-collection-converters/convert-geojson-to-binary-features.d.ts.map +1 -0
  33. package/dist/lib/feature-collection-converters/convert-geojson-to-binary-features.js +25 -0
  34. package/dist/lib/feature-collection-converters/convert-geojson-to-binary-features.js.map +1 -0
  35. package/dist/lib/{binary-features/geojson-to-flat-geojson.d.ts → feature-collection-converters/convert-geojson-to-flat-geojson.d.ts} +2 -2
  36. package/dist/lib/feature-collection-converters/convert-geojson-to-flat-geojson.d.ts.map +1 -0
  37. package/dist/lib/{binary-features/geojson-to-flat-geojson.js → feature-collection-converters/convert-geojson-to-flat-geojson.js} +5 -1
  38. package/dist/lib/feature-collection-converters/convert-geojson-to-flat-geojson.js.map +1 -0
  39. package/dist/lib/feature-collection-converters/helpers/flat-geojson-to-binary-types.d.ts.map +1 -0
  40. package/dist/lib/feature-collection-converters/helpers/flat-geojson-to-binary-types.js +5 -0
  41. package/dist/lib/feature-collection-converters/helpers/flat-geojson-to-binary-types.js.map +1 -0
  42. package/dist/lib/geometry-api/geometry-info.d.ts +21 -0
  43. package/dist/lib/geometry-api/geometry-info.d.ts.map +1 -0
  44. package/dist/lib/{binary-features/extract-geometry-info.js → geometry-api/geometry-info.js} +5 -1
  45. package/dist/lib/geometry-api/geometry-info.js.map +1 -0
  46. package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.d.ts +4 -0
  47. package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.d.ts.map +1 -0
  48. package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.js +92 -0
  49. package/dist/lib/geometry-converters/convert-binary-geometry-to-geojson.js.map +1 -0
  50. package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.d.ts +13 -0
  51. package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.d.ts.map +1 -0
  52. package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.js +165 -0
  53. package/dist/lib/geometry-converters/convert-geoarrow-to-geojson.js.map +1 -0
  54. package/dist/lib/geometry-converters/convert-to-geojson.d.ts +6 -0
  55. package/dist/lib/geometry-converters/convert-to-geojson.d.ts.map +1 -0
  56. package/dist/lib/geometry-converters/convert-to-geojson.js +40 -0
  57. package/dist/lib/geometry-converters/convert-to-geojson.js.map +1 -0
  58. package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.d.ts +6 -0
  59. package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.d.ts.map +1 -0
  60. package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.js +196 -0
  61. package/dist/lib/geometry-converters/wkb/convert-geometry-to-twkb.js.map +1 -0
  62. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.d.ts +9 -0
  63. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.d.ts.map +1 -0
  64. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.js +274 -0
  65. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkb.js.map +1 -0
  66. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.d.ts +8 -0
  67. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.d.ts.map +1 -0
  68. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.js +45 -0
  69. package/dist/lib/geometry-converters/wkb/convert-geometry-to-wkt.js.map +1 -0
  70. package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.d.ts +10 -0
  71. package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.d.ts.map +1 -0
  72. package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.js +255 -0
  73. package/dist/lib/geometry-converters/wkb/convert-twkb-to-geometry.js.map +1 -0
  74. package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.d.ts +3 -0
  75. package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.d.ts.map +1 -0
  76. package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.js +165 -0
  77. package/dist/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.js.map +1 -0
  78. package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.d.ts +11 -0
  79. package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.d.ts.map +1 -0
  80. package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.js +10 -0
  81. package/dist/lib/geometry-converters/wkb/convert-wkb-to-geometry.js.map +1 -0
  82. package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.d.ts +16 -0
  83. package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.d.ts.map +1 -0
  84. package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.js +259 -0
  85. package/dist/lib/geometry-converters/wkb/convert-wkt-to-geometry.js.map +1 -0
  86. package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.d.ts +43 -0
  87. package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.d.ts.map +1 -0
  88. package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.js +175 -0
  89. package/dist/lib/geometry-converters/wkb/helpers/parse-wkb-header.js.map +1 -0
  90. package/dist/lib/geometry-converters/wkb/helpers/wkb-types.d.ts +64 -0
  91. package/dist/lib/geometry-converters/wkb/helpers/wkb-types.d.ts.map +1 -0
  92. package/dist/lib/geometry-converters/wkb/helpers/wkb-types.js +47 -0
  93. package/dist/lib/geometry-converters/wkb/helpers/wkb-types.js.map +1 -0
  94. package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.d.ts +21 -0
  95. package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.d.ts.map +1 -0
  96. package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.js +65 -0
  97. package/dist/lib/geometry-converters/wkb/helpers/wkb-utils.js.map +1 -0
  98. package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.d.ts +8 -0
  99. package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.d.ts.map +1 -0
  100. package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.js +34 -0
  101. package/dist/lib/geometry-converters/wkb/helpers/write-wkb-header.js.map +1 -0
  102. package/dist/lib/table-converters/convert-geoarrow-table.d.ts +27 -0
  103. package/dist/lib/table-converters/convert-geoarrow-table.d.ts.map +1 -0
  104. package/dist/lib/table-converters/convert-geoarrow-table.js +155 -0
  105. package/dist/lib/table-converters/convert-geoarrow-table.js.map +1 -0
  106. package/dist/lib/table-converters/convert-wkb-table-to-geojson.d.ts +4 -0
  107. package/dist/lib/table-converters/convert-wkb-table-to-geojson.d.ts.map +1 -0
  108. package/dist/lib/{tables/convert-table-to-geojson.js → table-converters/convert-wkb-table-to-geojson.js} +11 -16
  109. package/dist/lib/table-converters/convert-wkb-table-to-geojson.js.map +1 -0
  110. package/dist/lib/table-converters/make-arrow-batch-iterator.d.ts +6 -0
  111. package/dist/lib/table-converters/make-arrow-batch-iterator.d.ts.map +1 -0
  112. package/dist/lib/table-converters/make-arrow-batch-iterator.js +36 -0
  113. package/dist/lib/table-converters/make-arrow-batch-iterator.js.map +1 -0
  114. package/dist/lib/utils/base64-encoder.d.ts +5 -0
  115. package/dist/lib/utils/base64-encoder.d.ts.map +1 -0
  116. package/dist/lib/utils/base64-encoder.js +154 -0
  117. package/dist/lib/utils/base64-encoder.js.map +1 -0
  118. package/dist/lib/utils/binary-reader.d.ts +18 -0
  119. package/dist/lib/utils/binary-reader.d.ts.map +1 -0
  120. package/dist/lib/utils/binary-reader.js +70 -0
  121. package/dist/lib/utils/binary-reader.js.map +1 -0
  122. package/dist/lib/utils/binary-writer.d.ts +30 -0
  123. package/dist/lib/utils/binary-writer.d.ts.map +1 -0
  124. package/dist/lib/utils/binary-writer.js +128 -0
  125. package/dist/lib/utils/binary-writer.js.map +1 -0
  126. package/dist/lib/utils/concat-typed-arrays.d.ts +3 -0
  127. package/dist/lib/utils/concat-typed-arrays.d.ts.map +1 -0
  128. package/dist/lib/utils/concat-typed-arrays.js +19 -0
  129. package/dist/lib/utils/concat-typed-arrays.js.map +1 -0
  130. package/dist/lib/utils/hex-encoder.d.ts +15 -0
  131. package/dist/lib/utils/hex-encoder.d.ts.map +1 -0
  132. package/dist/lib/utils/hex-encoder.js +55 -0
  133. package/dist/lib/utils/hex-encoder.js.map +1 -0
  134. package/dist/lib/utils/hex-transcoder.d.ts +15 -0
  135. package/dist/lib/utils/hex-transcoder.d.ts.map +1 -0
  136. package/dist/lib/utils/hex-transcoder.js +51 -0
  137. package/dist/lib/utils/hex-transcoder.js.map +1 -0
  138. package/dist/lib/wkt-crs/encode-wkt-crs.d.ts +10 -0
  139. package/dist/lib/wkt-crs/encode-wkt-crs.d.ts.map +1 -0
  140. package/dist/lib/wkt-crs/encode-wkt-crs.js +36 -0
  141. package/dist/lib/wkt-crs/encode-wkt-crs.js.map +1 -0
  142. package/dist/lib/wkt-crs/parse-wkt-crs.d.ts +15 -0
  143. package/dist/lib/wkt-crs/parse-wkt-crs.d.ts.map +1 -0
  144. package/dist/lib/wkt-crs/parse-wkt-crs.js +121 -0
  145. package/dist/lib/wkt-crs/parse-wkt-crs.js.map +1 -0
  146. package/package.json +7 -5
  147. package/src/index.ts +87 -14
  148. package/src/lib/binary-geometry-api/binary-geometry-info.ts +75 -0
  149. package/src/lib/binary-geometry-api/concat-binary-geometry.ts +78 -0
  150. package/src/lib/{binary-features/transform.ts → binary-geometry-api/transform-coordinates.ts} +0 -1
  151. package/src/lib/{binary-features/binary-to-geojson.ts → feature-collection-converters/convert-binary-features-to-geojson.ts} +5 -142
  152. package/src/lib/{binary-features/flat-geojson-to-binary.ts → feature-collection-converters/convert-flat-geojson-to-binary-features.ts} +14 -9
  153. package/src/lib/feature-collection-converters/convert-geoarrow-to-binary-features.ts +496 -0
  154. package/src/lib/{binary-features/geojson-to-binary.ts → feature-collection-converters/convert-geojson-to-binary-features.ts} +11 -7
  155. package/src/lib/{binary-features/geojson-to-flat-geojson.ts → feature-collection-converters/convert-geojson-to-flat-geojson.ts} +5 -1
  156. package/src/lib/{binary-features → feature-collection-converters/helpers}/flat-geojson-to-binary-types.ts +4 -0
  157. package/src/lib/{binary-features/extract-geometry-info.ts → geometry-api/geometry-info.ts} +20 -2
  158. package/src/lib/geometry-converters/convert-binary-geometry-to-geojson.ts +148 -0
  159. package/src/lib/geometry-converters/convert-geoarrow-to-geojson.ts +193 -0
  160. package/src/lib/geometry-converters/convert-to-geojson.ts +52 -0
  161. package/src/lib/geometry-converters/wkb/convert-geometry-to-twkb.ts +308 -0
  162. package/src/lib/geometry-converters/wkb/convert-geometry-to-wkb.ts +365 -0
  163. package/src/lib/geometry-converters/wkb/convert-geometry-to-wkt.ts +54 -0
  164. package/src/lib/geometry-converters/wkb/convert-twkb-to-geometry.ts +366 -0
  165. package/src/lib/geometry-converters/wkb/convert-wkb-to-binary-geometry.ts +238 -0
  166. package/src/lib/geometry-converters/wkb/convert-wkb-to-geometry.ts +23 -0
  167. package/src/lib/geometry-converters/wkb/convert-wkt-to-geometry.ts +294 -0
  168. package/src/lib/geometry-converters/wkb/helpers/parse-wkb-header.ts +213 -0
  169. package/src/lib/geometry-converters/wkb/helpers/wkb-types.ts +82 -0
  170. package/src/lib/geometry-converters/wkb/helpers/wkb-utils.ts +85 -0
  171. package/src/lib/geometry-converters/wkb/helpers/write-wkb-header.ts +41 -0
  172. package/src/lib/table-converters/convert-geoarrow-table.ts +218 -0
  173. package/src/lib/{tables/convert-table-to-geojson.ts → table-converters/convert-wkb-table-to-geojson.ts} +10 -23
  174. package/src/lib/table-converters/make-arrow-batch-iterator.ts +53 -0
  175. package/src/lib/utils/base64-encoder.ts +157 -0
  176. package/src/lib/utils/binary-reader.ts +76 -0
  177. package/src/lib/utils/binary-writer.ts +136 -0
  178. package/src/lib/utils/concat-typed-arrays.ts +24 -0
  179. package/src/lib/utils/hex-encoder.ts +60 -0
  180. package/src/lib/utils/hex-transcoder.ts +54 -0
  181. package/src/lib/wkt-crs/encode-wkt-crs.ts +41 -0
  182. package/src/lib/wkt-crs/parse-wkt-crs.ts +149 -0
  183. package/dist/lib/binary-features/binary-to-geojson.d.ts +0 -18
  184. package/dist/lib/binary-features/binary-to-geojson.d.ts.map +0 -1
  185. package/dist/lib/binary-features/extract-geometry-info.d.ts +0 -8
  186. package/dist/lib/binary-features/extract-geometry-info.d.ts.map +0 -1
  187. package/dist/lib/binary-features/flat-geojson-to-binary-types.d.ts.map +0 -1
  188. package/dist/lib/binary-features/flat-geojson-to-binary-types.js +0 -1
  189. package/dist/lib/binary-features/flat-geojson-to-binary.d.ts.map +0 -1
  190. package/dist/lib/binary-features/geojson-to-binary.d.ts.map +0 -1
  191. package/dist/lib/binary-features/geojson-to-binary.js +0 -21
  192. package/dist/lib/binary-features/geojson-to-flat-geojson.d.ts.map +0 -1
  193. package/dist/lib/binary-features/transform.d.ts.map +0 -1
  194. package/dist/lib/geo/geoarrow-metadata.d.ts +0 -27
  195. package/dist/lib/geo/geoarrow-metadata.d.ts.map +0 -1
  196. package/dist/lib/geo/geoarrow-metadata.js +0 -70
  197. package/dist/lib/geo/geoparquet-metadata-schema.d.ts +0 -79
  198. package/dist/lib/geo/geoparquet-metadata-schema.d.ts.map +0 -1
  199. package/dist/lib/geo/geoparquet-metadata-schema.js +0 -69
  200. package/dist/lib/geo/geoparquet-metadata.d.ts +0 -45
  201. package/dist/lib/geo/geoparquet-metadata.d.ts.map +0 -1
  202. package/dist/lib/geo/geoparquet-metadata.js +0 -117
  203. package/dist/lib/tables/convert-table-to-geojson.d.ts +0 -5
  204. package/dist/lib/tables/convert-table-to-geojson.d.ts.map +0 -1
  205. package/src/lib/geo/geoarrow-metadata.ts +0 -100
  206. package/src/lib/geo/geoparquet-metadata-schema.json +0 -60
  207. package/src/lib/geo/geoparquet-metadata-schema.ts +0 -71
  208. package/src/lib/geo/geoparquet-metadata.ts +0 -191
  209. /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":"AAAA,aAAa;AACb,+BAA+B;AAC/B,oCAAoC;AAEpC,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAWtC,OAAO,EACL,YAAY,EACZ,oBAAoB,EACpB,oBAAoB,EACpB,cAAc,EACd,eAAe,EACf,cAAc,EACf,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAC,4BAA4B,EAAC,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAC,gCAAgC,EAAC,8DAA2D;AAEpG;;;;;;GAMG;AACH,MAAM,UAAU,mBAAmB,CAAC,KAAY,EAAE,OAA8B;IAC9E,QAAQ,KAAK,CAAC,KAAK,EAAE,CAAC;QACpB,KAAK,aAAa;YAChB,OAAO,KAAK,CAAC,IAAI,CAAC;QAEpB,KAAK,gBAAgB,CAAC;QACtB,8CAA8C;QAC9C,sDAAsD;QAEtD,eAAe;QAEf;YACE,MAAM,kBAAkB,GAAG,+BAA+B,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAC3E,OAAO,IAAI,KAAK,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;IAC/C,CAAC;AACH,CAAC;AAED,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;AAiBD;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CAAC,UAAuB,EAAE,KAAqB;IACnF,QAAQ,KAAK,EAAE,CAAC;QACd,KAAK,aAAa;YAChB,OAAO,wBAAwB,CAAC,UAAU,CAAC,CAAC;QAC9C,KAAK,iBAAiB;YACpB,OAAO,2BAA2B,CAAC,UAAU,CAAC,CAAC;QACjD,KAAK,kBAAkB;YACrB,OAAO,4BAA4B,CAAC,UAAU,CAAC,CAAC;QAClD,KAAK,gBAAgB;YACnB,OAAO,2BAA2B,CAAC,UAAU,CAAC,CAAC;QACjD,KAAK,eAAe;YAClB,OAAO,0BAA0B,CAAC,UAAU,CAAC,CAAC;QAChD;YACE,MAAM,IAAI,KAAK,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;AACH,CAAC;AAED;;;;;GAKG;AACH,SAAS,wBAAwB,CAAC,UAAuB;IACvD,OAAO;QACL,KAAK,EAAE,aAAa;QACpB,MAAM,EAAE,oBAAoB,CAAC,UAAU,CAAC,MAAM,CAAC;QAC/C,IAAI,EAAE,UAAU;KACjB,CAAC;AACJ,CAAC;AAED,SAAS,2BAA2B,CAAC,UAAuB;IAC1D,MAAM,aAAa,GAAG,2BAA2B,CAAC,UAAU,CAAC,CAAC;IAC9D,OAAO,YAAY,CAAC,aAAa,EAAE,iBAAiB,CAAC,CAAC;AACxD,CAAC;AAED,SAAS,4BAA4B,CAAC,UAAuB;IAC3D,MAAM,aAAa,GAAG,2BAA2B,CAAC,UAAU,CAAC,CAAC;IAC9D,OAAO,YAAY,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAAC;AACzD,CAAC;AAED;;;GAGG;AACH,SAAS,2BAA2B,CAAC,UAAuB;IAC1D,wEAAwE;IACxE,sBAAsB;IAEtB,MAAM,OAAO,GAA0B,EAAE,CAAC;IAE1C,KAAK,MAAM,KAAK,IAAI,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;QAC7C,8EAA8E;QAC9E,MAAM,WAAW,GAAG,UAAU,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACpD,MAAM,MAAM,GAAG,WAAW,EAAE,OAAO,EAAE,CAAC;QACtC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC;IAC/B,CAAC;IAED,MAAM,MAAM,GAAG,oBAAoB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IAEvD,OAAO;QACL,KAAK,EAAE,gBAAgB;QACvB,MAAM;QACN,IAAI,EAAE,OAAO;KACd,CAAC;AACJ,CAAC;AAED;;;GAGG;AACH,SAAS,0BAA0B,CAAC,UAAuB;IACzD,MAAM,MAAM,GAAG,oBAAoB,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;IACvD,MAAM,eAAe,GAAG,4BAA4B,CAAC,MAAM,CAAC,CAAC;IAE7D,gDAAgD;IAChD,MAAM,QAAQ,GAAG,eAAe,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAEnD,MAAM,QAAQ,GAAc,EAAE,CAAC;IAE/B,0BAA0B;IAC1B,MAAM,mBAAmB,GAAG,UAAU,CAAC,MAAM,CAAC,MAAM;SACjD,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC;QAC3B,2CAA2C;SAC1C,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,eAAe,CAAC,CAAC,CAAC;IAChD,MAAM,eAAe,GAAG,UAAU,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;IAE/D,MAAM,mBAAmB,GAAG,UAAU,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;IAE5D,KAAK,IAAI,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,UAAU,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,CAAC;QAClD,oDAAoD;QACpD,0BAA0B;QAC1B,MAAM,aAAa,GAAG,mBAAmB,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;QACpD,0CAA0C;QAC1C,MAAM,OAAO,GAAG,gCAAgC,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;QAC1E,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,UAAU,GAAG,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;YAC5D,QAAQ,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAC,CAAC,CAAC;QAClE,CAAC;IACH,CAAC;IAED,OAAO;QACL,KAAK,EAAE,eAAe;QACtB,IAAI,EAAE,mBAAmB;QACzB,MAAM;QACN,QAAQ;KACT,CAAC;AACJ,CAAC"}
@@ -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 "../geo/geoparquet-metadata.js";
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, loaders) {
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, loaders);
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, loaders) {
27
+ function parseGeometry(geometry, columnMetadata) {
26
28
  switch (columnMetadata.encoding) {
27
29
  case 'wkt':
28
- const wktLoader = loaders.find((loader) => loader.id === 'wkt');
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
- const geojson = wkbLoader?.parseSync?.(arrayBuffer, {
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,5 @@
1
+ export declare class Base64Encoder {
2
+ getDecodedLength(array: Uint8Array): number;
3
+ decode(array: Uint8Array, target?: ArrayBuffer): void;
4
+ }
5
+ //# sourceMappingURL=base64-encoder.d.ts.map
@@ -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":"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"}
@@ -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,3 @@
1
+ import type { TypedArray } from '@loaders.gl/schema';
2
+ export declare function concatTypedArrays(arrays: TypedArray[]): TypedArray;
3
+ //# sourceMappingURL=concat-typed-arrays.d.ts.map
@@ -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"}