@loaders.gl/wkt 3.1.3 → 4.0.0-alpha.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (86) hide show
  1. package/dist/bundle.js +2 -2
  2. package/dist/bundle.js.map +1 -0
  3. package/dist/index.js +5 -13
  4. package/dist/index.js.map +1 -0
  5. package/dist/lib/encode-wkb.js +278 -245
  6. package/dist/lib/encode-wkb.js.map +1 -0
  7. package/dist/lib/encode-wkt.js +41 -35
  8. package/dist/lib/encode-wkt.js.map +1 -0
  9. package/dist/lib/parse-wkb.js +276 -208
  10. package/dist/lib/parse-wkb.js.map +1 -0
  11. package/dist/lib/parse-wkt.js +189 -218
  12. package/dist/lib/parse-wkt.js.map +1 -0
  13. package/dist/lib/utils/binary-writer.js +150 -117
  14. package/dist/lib/utils/binary-writer.js.map +1 -0
  15. package/dist/lib/utils/version.js +2 -7
  16. package/dist/lib/utils/version.js.map +1 -0
  17. package/dist/wkb-loader.js +20 -32
  18. package/dist/wkb-loader.js.map +1 -0
  19. package/dist/wkb-writer.js +13 -22
  20. package/dist/wkb-writer.js.map +1 -0
  21. package/dist/wkt-loader.js +19 -31
  22. package/dist/wkt-loader.js.map +1 -0
  23. package/dist/wkt-worker.js +1 -1
  24. package/dist/wkt-writer.js +13 -22
  25. package/dist/wkt-writer.js.map +1 -0
  26. package/dist/workers/wkb-worker.js +4 -5
  27. package/dist/workers/wkb-worker.js.map +1 -0
  28. package/dist/workers/wkt-worker.js +4 -5
  29. package/dist/workers/wkt-worker.js.map +1 -0
  30. package/package.json +7 -7
  31. package/dist/es5/bundle.js +0 -7
  32. package/dist/es5/bundle.js.map +0 -1
  33. package/dist/es5/index.js +0 -50
  34. package/dist/es5/index.js.map +0 -1
  35. package/dist/es5/lib/encode-wkb.js +0 -468
  36. package/dist/es5/lib/encode-wkb.js.map +0 -1
  37. package/dist/es5/lib/encode-wkt.js +0 -59
  38. package/dist/es5/lib/encode-wkt.js.map +0 -1
  39. package/dist/es5/lib/parse-wkb.js +0 -347
  40. package/dist/es5/lib/parse-wkb.js.map +0 -1
  41. package/dist/es5/lib/parse-wkt.js +0 -205
  42. package/dist/es5/lib/parse-wkt.js.map +0 -1
  43. package/dist/es5/lib/utils/binary-writer.js +0 -186
  44. package/dist/es5/lib/utils/binary-writer.js.map +0 -1
  45. package/dist/es5/lib/utils/version.js +0 -9
  46. package/dist/es5/lib/utils/version.js.map +0 -1
  47. package/dist/es5/wkb-loader.js +0 -70
  48. package/dist/es5/wkb-loader.js.map +0 -1
  49. package/dist/es5/wkb-writer.js +0 -26
  50. package/dist/es5/wkb-writer.js.map +0 -1
  51. package/dist/es5/wkt-loader.js +0 -67
  52. package/dist/es5/wkt-loader.js.map +0 -1
  53. package/dist/es5/wkt-writer.js +0 -26
  54. package/dist/es5/wkt-writer.js.map +0 -1
  55. package/dist/es5/workers/wkb-worker.js +0 -8
  56. package/dist/es5/workers/wkb-worker.js.map +0 -1
  57. package/dist/es5/workers/wkt-worker.js +0 -8
  58. package/dist/es5/workers/wkt-worker.js.map +0 -1
  59. package/dist/esm/bundle.js +0 -5
  60. package/dist/esm/bundle.js.map +0 -1
  61. package/dist/esm/index.js +0 -5
  62. package/dist/esm/index.js.map +0 -1
  63. package/dist/esm/lib/encode-wkb.js +0 -323
  64. package/dist/esm/lib/encode-wkb.js.map +0 -1
  65. package/dist/esm/lib/encode-wkt.js +0 -52
  66. package/dist/esm/lib/encode-wkt.js.map +0 -1
  67. package/dist/esm/lib/parse-wkb.js +0 -304
  68. package/dist/esm/lib/parse-wkb.js.map +0 -1
  69. package/dist/esm/lib/parse-wkt.js +0 -198
  70. package/dist/esm/lib/parse-wkt.js.map +0 -1
  71. package/dist/esm/lib/utils/binary-writer.js +0 -153
  72. package/dist/esm/lib/utils/binary-writer.js.map +0 -1
  73. package/dist/esm/lib/utils/version.js +0 -2
  74. package/dist/esm/lib/utils/version.js.map +0 -1
  75. package/dist/esm/wkb-loader.js +0 -22
  76. package/dist/esm/wkb-loader.js.map +0 -1
  77. package/dist/esm/wkb-writer.js +0 -14
  78. package/dist/esm/wkb-writer.js.map +0 -1
  79. package/dist/esm/wkt-loader.js +0 -21
  80. package/dist/esm/wkt-loader.js.map +0 -1
  81. package/dist/esm/wkt-writer.js +0 -14
  82. package/dist/esm/wkt-writer.js.map +0 -1
  83. package/dist/esm/workers/wkb-worker.js +0 -4
  84. package/dist/esm/workers/wkb-worker.js.map +0 -1
  85. package/dist/esm/workers/wkt-worker.js +0 -4
  86. package/dist/esm/workers/wkt-worker.js.map +0 -1
@@ -1,227 +1,198 @@
1
- "use strict";
2
- // Fork of https://github.com/mapbox/wellknown under ISC license (MIT/BSD-2-clause equivalent)
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- /* eslint-disable */
5
- // @ts-nocheck
6
1
  const numberRegexp = /[-+]?([0-9]*\.[0-9]+|[0-9]+)([eE][-+]?[0-9]+)?/;
7
- // Matches sequences like '100 100' or '100 100 100'.
8
2
  const tuples = new RegExp('^' + numberRegexp.source + '(\\s' + numberRegexp.source + '){1,}');
9
- /**
10
- * Parse WKT and return GeoJSON.
11
- *
12
- * @param {string} _ A WKT geometry
13
- * @return {?Object} A GeoJSON geometry object
14
- **/
15
- function parseWKT(input) {
16
- const parts = input.split(';');
17
- let _ = parts.pop();
18
- const srid = (parts.shift() || '').split('=').pop();
19
- let i = 0;
20
- function $(re) {
21
- const match = _.substring(i).match(re);
22
- if (!match)
23
- return null;
24
- else {
25
- i += match[0].length;
26
- return match[0];
27
- }
28
- }
29
- function crs(obj) {
30
- if (obj && srid.match(/\d+/)) {
31
- obj.crs = {
32
- type: 'name',
33
- properties: {
34
- name: 'urn:ogc:def:crs:EPSG::' + srid
35
- }
36
- };
37
- }
38
- return obj;
39
- }
40
- function white() {
41
- $(/^\s*/);
42
- }
43
- function multicoords() {
44
- white();
45
- let depth = 0;
46
- const rings = [];
47
- const stack = [rings];
48
- let pointer = rings;
49
- let elem;
50
- while ((elem = $(/^(\()/) || $(/^(\))/) || $(/^(,)/) || $(tuples))) {
51
- if (elem === '(') {
52
- stack.push(pointer);
53
- pointer = [];
54
- stack[stack.length - 1].push(pointer);
55
- depth++;
56
- }
57
- else if (elem === ')') {
58
- // For the case: Polygon(), ...
59
- if (pointer.length === 0)
60
- return null;
61
- // @ts-ignore
62
- pointer = stack.pop();
63
- // the stack was empty, input was malformed
64
- if (!pointer)
65
- return null;
66
- depth--;
67
- if (depth === 0)
68
- break;
69
- }
70
- else if (elem === ',') {
71
- pointer = [];
72
- stack[stack.length - 1].push(pointer);
73
- }
74
- else if (!elem.split(/\s/g).some(isNaN)) {
75
- Array.prototype.push.apply(pointer, elem.split(/\s/g).map(parseFloat));
76
- }
77
- else {
78
- return null;
79
- }
80
- white();
81
- }
82
- if (depth !== 0)
83
- return null;
84
- return rings;
3
+ export default function parseWKT(input) {
4
+ const parts = input.split(';');
5
+
6
+ let _ = parts.pop();
7
+
8
+ const srid = (parts.shift() || '').split('=').pop();
9
+ let i = 0;
10
+
11
+ function $(re) {
12
+ const match = _.substring(i).match(re);
13
+
14
+ if (!match) return null;else {
15
+ i += match[0].length;
16
+ return match[0];
85
17
  }
86
- function coords() {
87
- const list = [];
88
- let item;
89
- let pt;
90
- while ((pt = $(tuples) || $(/^(,)/))) {
91
- if (pt === ',') {
92
- list.push(item);
93
- item = [];
94
- }
95
- else if (!pt.split(/\s/g).some(isNaN)) {
96
- if (!item)
97
- item = [];
98
- Array.prototype.push.apply(item, pt.split(/\s/g).map(parseFloat));
99
- }
100
- white();
18
+ }
19
+
20
+ function crs(obj) {
21
+ if (obj && srid.match(/\d+/)) {
22
+ obj.crs = {
23
+ type: 'name',
24
+ properties: {
25
+ name: 'urn:ogc:def:crs:EPSG::' + srid
101
26
  }
102
- if (item)
103
- list.push(item);
104
- else
105
- return null;
106
- return list.length ? list : null;
27
+ };
107
28
  }
108
- function point() {
109
- if (!$(/^(point(\sz)?)/i))
110
- return null;
111
- white();
112
- if (!$(/^(\()/))
113
- return null;
114
- const c = coords();
115
- if (!c)
116
- return null;
117
- white();
118
- if (!$(/^(\))/))
119
- return null;
120
- return {
121
- type: 'Point',
122
- coordinates: c[0]
123
- };
29
+
30
+ return obj;
31
+ }
32
+
33
+ function white() {
34
+ $(/^\s*/);
35
+ }
36
+
37
+ function multicoords() {
38
+ white();
39
+ let depth = 0;
40
+ const rings = [];
41
+ const stack = [rings];
42
+ let pointer = rings;
43
+ let elem;
44
+
45
+ while (elem = $(/^(\()/) || $(/^(\))/) || $(/^(,)/) || $(tuples)) {
46
+ if (elem === '(') {
47
+ stack.push(pointer);
48
+ pointer = [];
49
+ stack[stack.length - 1].push(pointer);
50
+ depth++;
51
+ } else if (elem === ')') {
52
+ if (pointer.length === 0) return null;
53
+ pointer = stack.pop();
54
+ if (!pointer) return null;
55
+ depth--;
56
+ if (depth === 0) break;
57
+ } else if (elem === ',') {
58
+ pointer = [];
59
+ stack[stack.length - 1].push(pointer);
60
+ } else if (!elem.split(/\s/g).some(isNaN)) {
61
+ Array.prototype.push.apply(pointer, elem.split(/\s/g).map(parseFloat));
62
+ } else {
63
+ return null;
64
+ }
65
+
66
+ white();
124
67
  }
125
- function multipoint() {
126
- if (!$(/^(multipoint)/i))
127
- return null;
128
- white();
129
- const newCoordsFormat = _.substring(_.indexOf('(') + 1, _.length - 1)
130
- .replace(/\(/g, '')
131
- .replace(/\)/g, '');
132
- _ = 'MULTIPOINT (' + newCoordsFormat + ')';
133
- const c = multicoords();
134
- if (!c)
135
- return null;
136
- white();
137
- return {
138
- type: 'MultiPoint',
139
- coordinates: c
140
- };
141
- }
142
- function multilinestring() {
143
- if (!$(/^(multilinestring)/i))
144
- return null;
145
- white();
146
- const c = multicoords();
147
- if (!c)
148
- return null;
149
- white();
150
- return {
151
- type: 'MultiLineString',
152
- coordinates: c
153
- };
154
- }
155
- function linestring() {
156
- if (!$(/^(linestring(\sz)?)/i))
157
- return null;
158
- white();
159
- if (!$(/^(\()/))
160
- return null;
161
- const c = coords();
162
- if (!c)
163
- return null;
164
- if (!$(/^(\))/))
165
- return null;
166
- return {
167
- type: 'LineString',
168
- coordinates: c
169
- };
170
- }
171
- function polygon() {
172
- if (!$(/^(polygon(\sz)?)/i))
173
- return null;
174
- white();
175
- const c = multicoords();
176
- if (!c)
177
- return null;
178
- return {
179
- type: 'Polygon',
180
- coordinates: c
181
- };
182
- }
183
- function multipolygon() {
184
- if (!$(/^(multipolygon)/i))
185
- return null;
186
- white();
187
- const c = multicoords();
188
- if (!c)
189
- return null;
190
- return {
191
- type: 'MultiPolygon',
192
- coordinates: c
193
- };
194
- }
195
- function geometrycollection() {
196
- const geometries = [];
197
- let geometry;
198
- if (!$(/^(geometrycollection)/i))
199
- return null;
200
- white();
201
- if (!$(/^(\()/))
202
- return null;
203
- while ((geometry = root())) {
204
- geometries.push(geometry);
205
- white();
206
- $(/^(,)/);
207
- white();
208
- }
209
- if (!$(/^(\))/))
210
- return null;
211
- return {
212
- type: 'GeometryCollection',
213
- geometries: geometries
214
- };
68
+
69
+ if (depth !== 0) return null;
70
+ return rings;
71
+ }
72
+
73
+ function coords() {
74
+ const list = [];
75
+ let item;
76
+ let pt;
77
+
78
+ while (pt = $(tuples) || $(/^(,)/)) {
79
+ if (pt === ',') {
80
+ list.push(item);
81
+ item = [];
82
+ } else if (!pt.split(/\s/g).some(isNaN)) {
83
+ if (!item) item = [];
84
+ Array.prototype.push.apply(item, pt.split(/\s/g).map(parseFloat));
85
+ }
86
+
87
+ white();
215
88
  }
216
- function root() {
217
- return (point() ||
218
- linestring() ||
219
- polygon() ||
220
- multipoint() ||
221
- multilinestring() ||
222
- multipolygon() ||
223
- geometrycollection());
89
+
90
+ if (item) list.push(item);else return null;
91
+ return list.length ? list : null;
92
+ }
93
+
94
+ function point() {
95
+ if (!$(/^(point(\sz)?)/i)) return null;
96
+ white();
97
+ if (!$(/^(\()/)) return null;
98
+ const c = coords();
99
+ if (!c) return null;
100
+ white();
101
+ if (!$(/^(\))/)) return null;
102
+ return {
103
+ type: 'Point',
104
+ coordinates: c[0]
105
+ };
106
+ }
107
+
108
+ function multipoint() {
109
+ if (!$(/^(multipoint)/i)) return null;
110
+ white();
111
+
112
+ const newCoordsFormat = _.substring(_.indexOf('(') + 1, _.length - 1).replace(/\(/g, '').replace(/\)/g, '');
113
+
114
+ _ = 'MULTIPOINT (' + newCoordsFormat + ')';
115
+ const c = multicoords();
116
+ if (!c) return null;
117
+ white();
118
+ return {
119
+ type: 'MultiPoint',
120
+ coordinates: c
121
+ };
122
+ }
123
+
124
+ function multilinestring() {
125
+ if (!$(/^(multilinestring)/i)) return null;
126
+ white();
127
+ const c = multicoords();
128
+ if (!c) return null;
129
+ white();
130
+ return {
131
+ type: 'MultiLineString',
132
+ coordinates: c
133
+ };
134
+ }
135
+
136
+ function linestring() {
137
+ if (!$(/^(linestring(\sz)?)/i)) return null;
138
+ white();
139
+ if (!$(/^(\()/)) return null;
140
+ const c = coords();
141
+ if (!c) return null;
142
+ if (!$(/^(\))/)) return null;
143
+ return {
144
+ type: 'LineString',
145
+ coordinates: c
146
+ };
147
+ }
148
+
149
+ function polygon() {
150
+ if (!$(/^(polygon(\sz)?)/i)) return null;
151
+ white();
152
+ const c = multicoords();
153
+ if (!c) return null;
154
+ return {
155
+ type: 'Polygon',
156
+ coordinates: c
157
+ };
158
+ }
159
+
160
+ function multipolygon() {
161
+ if (!$(/^(multipolygon)/i)) return null;
162
+ white();
163
+ const c = multicoords();
164
+ if (!c) return null;
165
+ return {
166
+ type: 'MultiPolygon',
167
+ coordinates: c
168
+ };
169
+ }
170
+
171
+ function geometrycollection() {
172
+ const geometries = [];
173
+ let geometry;
174
+ if (!$(/^(geometrycollection)/i)) return null;
175
+ white();
176
+ if (!$(/^(\()/)) return null;
177
+
178
+ while (geometry = root()) {
179
+ geometries.push(geometry);
180
+ white();
181
+ $(/^(,)/);
182
+ white();
224
183
  }
225
- return crs(root());
184
+
185
+ if (!$(/^(\))/)) return null;
186
+ return {
187
+ type: 'GeometryCollection',
188
+ geometries: geometries
189
+ };
190
+ }
191
+
192
+ function root() {
193
+ return point() || linestring() || polygon() || multipoint() || multilinestring() || multipolygon() || geometrycollection();
194
+ }
195
+
196
+ return crs(root());
226
197
  }
227
- exports.default = parseWKT;
198
+ //# sourceMappingURL=parse-wkt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/lib/parse-wkt.ts"],"names":["numberRegexp","tuples","RegExp","source","parseWKT","input","parts","split","_","pop","srid","shift","i","$","re","match","substring","length","crs","obj","type","properties","name","white","multicoords","depth","rings","stack","pointer","elem","push","some","isNaN","Array","prototype","apply","map","parseFloat","coords","list","item","pt","point","c","coordinates","multipoint","newCoordsFormat","indexOf","replace","multilinestring","linestring","polygon","multipolygon","geometrycollection","geometries","geometry","root"],"mappings":"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","sourcesContent":["// Fork of https://github.com/mapbox/wellknown under ISC license (MIT/BSD-2-clause equivalent)\n\n/* eslint-disable */\n// @ts-nocheck\n\nconst numberRegexp = /[-+]?([0-9]*\\.[0-9]+|[0-9]+)([eE][-+]?[0-9]+)?/;\n// Matches sequences like '100 100' or '100 100 100'.\nconst tuples = new RegExp('^' + numberRegexp.source + '(\\\\s' + numberRegexp.source + '){1,}');\n\n/**\n * Parse WKT and return GeoJSON.\n *\n * @param {string} _ A WKT geometry\n * @return {?Object} A GeoJSON geometry object\n **/\nexport default function parseWKT(input) {\n const parts = input.split(';');\n let _ = parts.pop();\n const srid = (parts.shift() || '').split('=').pop();\n\n let i = 0;\n\n function $(re) {\n const match = _.substring(i).match(re);\n if (!match) return null;\n else {\n i += match[0].length;\n return match[0];\n }\n }\n\n function crs(obj) {\n if (obj && srid.match(/\\d+/)) {\n obj.crs = {\n type: 'name',\n properties: {\n name: 'urn:ogc:def:crs:EPSG::' + srid\n }\n };\n }\n\n return obj;\n }\n\n function white() {\n $(/^\\s*/);\n }\n\n function multicoords() {\n white();\n let depth = 0;\n const rings = [];\n const stack = [rings];\n let pointer = rings;\n let elem;\n\n while ((elem = $(/^(\\()/) || $(/^(\\))/) || $(/^(,)/) || $(tuples))) {\n if (elem === '(') {\n stack.push(pointer);\n pointer = [];\n stack[stack.length - 1].push(pointer);\n depth++;\n } else if (elem === ')') {\n // For the case: Polygon(), ...\n if (pointer.length === 0) return null;\n\n // @ts-ignore\n pointer = stack.pop();\n // the stack was empty, input was malformed\n if (!pointer) return null;\n depth--;\n if (depth === 0) break;\n } else if (elem === ',') {\n pointer = [];\n stack[stack.length - 1].push(pointer);\n } else if (!elem.split(/\\s/g).some(isNaN)) {\n Array.prototype.push.apply(pointer, elem.split(/\\s/g).map(parseFloat));\n } else {\n return null;\n }\n white();\n }\n\n if (depth !== 0) return null;\n\n return rings;\n }\n\n function coords() {\n const list = [];\n let item;\n let pt;\n while ((pt = $(tuples) || $(/^(,)/))) {\n if (pt === ',') {\n list.push(item);\n item = [];\n } else if (!pt.split(/\\s/g).some(isNaN)) {\n if (!item) item = [];\n Array.prototype.push.apply(item, pt.split(/\\s/g).map(parseFloat));\n }\n white();\n }\n\n if (item) list.push(item);\n else return null;\n\n return list.length ? list : null;\n }\n\n function point() {\n if (!$(/^(point(\\sz)?)/i)) return null;\n white();\n if (!$(/^(\\()/)) return null;\n const c = coords();\n if (!c) return null;\n white();\n if (!$(/^(\\))/)) return null;\n return {\n type: 'Point',\n coordinates: c[0]\n };\n }\n\n function multipoint() {\n if (!$(/^(multipoint)/i)) return null;\n white();\n const newCoordsFormat = _.substring(_.indexOf('(') + 1, _.length - 1)\n .replace(/\\(/g, '')\n .replace(/\\)/g, '');\n _ = 'MULTIPOINT (' + newCoordsFormat + ')';\n const c = multicoords();\n if (!c) return null;\n white();\n return {\n type: 'MultiPoint',\n coordinates: c\n };\n }\n\n function multilinestring() {\n if (!$(/^(multilinestring)/i)) return null;\n white();\n const c = multicoords();\n if (!c) return null;\n white();\n return {\n type: 'MultiLineString',\n coordinates: c\n };\n }\n\n function linestring() {\n if (!$(/^(linestring(\\sz)?)/i)) return null;\n white();\n if (!$(/^(\\()/)) return null;\n const c = coords();\n if (!c) return null;\n if (!$(/^(\\))/)) return null;\n return {\n type: 'LineString',\n coordinates: c\n };\n }\n\n function polygon() {\n if (!$(/^(polygon(\\sz)?)/i)) return null;\n white();\n const c = multicoords();\n if (!c) return null;\n return {\n type: 'Polygon',\n coordinates: c\n };\n }\n\n function multipolygon() {\n if (!$(/^(multipolygon)/i)) return null;\n white();\n const c = multicoords();\n if (!c) return null;\n return {\n type: 'MultiPolygon',\n coordinates: c\n };\n }\n\n function geometrycollection() {\n const geometries = [];\n let geometry;\n\n if (!$(/^(geometrycollection)/i)) return null;\n white();\n\n if (!$(/^(\\()/)) return null;\n while ((geometry = root())) {\n geometries.push(geometry);\n white();\n $(/^(,)/);\n white();\n }\n if (!$(/^(\\))/)) return null;\n\n return {\n type: 'GeometryCollection',\n geometries: geometries\n };\n }\n\n function root() {\n return (\n point() ||\n linestring() ||\n polygon() ||\n multipoint() ||\n multilinestring() ||\n multipolygon() ||\n geometrycollection()\n );\n }\n\n return crs(root());\n}\n"],"file":"parse-wkt.js"}