@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.
- package/dist/bundle.js +2 -2
- package/dist/bundle.js.map +1 -0
- package/dist/index.js +5 -13
- package/dist/index.js.map +1 -0
- package/dist/lib/encode-wkb.js +278 -245
- package/dist/lib/encode-wkb.js.map +1 -0
- package/dist/lib/encode-wkt.js +41 -35
- package/dist/lib/encode-wkt.js.map +1 -0
- package/dist/lib/parse-wkb.js +276 -208
- package/dist/lib/parse-wkb.js.map +1 -0
- package/dist/lib/parse-wkt.js +189 -218
- package/dist/lib/parse-wkt.js.map +1 -0
- package/dist/lib/utils/binary-writer.js +150 -117
- package/dist/lib/utils/binary-writer.js.map +1 -0
- package/dist/lib/utils/version.js +2 -7
- package/dist/lib/utils/version.js.map +1 -0
- package/dist/wkb-loader.js +20 -32
- package/dist/wkb-loader.js.map +1 -0
- package/dist/wkb-writer.js +13 -22
- package/dist/wkb-writer.js.map +1 -0
- package/dist/wkt-loader.js +19 -31
- package/dist/wkt-loader.js.map +1 -0
- package/dist/wkt-worker.js +1 -1
- package/dist/wkt-writer.js +13 -22
- package/dist/wkt-writer.js.map +1 -0
- package/dist/workers/wkb-worker.js +4 -5
- package/dist/workers/wkb-worker.js.map +1 -0
- package/dist/workers/wkt-worker.js +4 -5
- package/dist/workers/wkt-worker.js.map +1 -0
- package/package.json +7 -7
- package/dist/es5/bundle.js +0 -7
- package/dist/es5/bundle.js.map +0 -1
- package/dist/es5/index.js +0 -50
- package/dist/es5/index.js.map +0 -1
- package/dist/es5/lib/encode-wkb.js +0 -468
- package/dist/es5/lib/encode-wkb.js.map +0 -1
- package/dist/es5/lib/encode-wkt.js +0 -59
- package/dist/es5/lib/encode-wkt.js.map +0 -1
- package/dist/es5/lib/parse-wkb.js +0 -347
- package/dist/es5/lib/parse-wkb.js.map +0 -1
- package/dist/es5/lib/parse-wkt.js +0 -205
- package/dist/es5/lib/parse-wkt.js.map +0 -1
- package/dist/es5/lib/utils/binary-writer.js +0 -186
- package/dist/es5/lib/utils/binary-writer.js.map +0 -1
- package/dist/es5/lib/utils/version.js +0 -9
- package/dist/es5/lib/utils/version.js.map +0 -1
- package/dist/es5/wkb-loader.js +0 -70
- package/dist/es5/wkb-loader.js.map +0 -1
- package/dist/es5/wkb-writer.js +0 -26
- package/dist/es5/wkb-writer.js.map +0 -1
- package/dist/es5/wkt-loader.js +0 -67
- package/dist/es5/wkt-loader.js.map +0 -1
- package/dist/es5/wkt-writer.js +0 -26
- package/dist/es5/wkt-writer.js.map +0 -1
- package/dist/es5/workers/wkb-worker.js +0 -8
- package/dist/es5/workers/wkb-worker.js.map +0 -1
- package/dist/es5/workers/wkt-worker.js +0 -8
- package/dist/es5/workers/wkt-worker.js.map +0 -1
- package/dist/esm/bundle.js +0 -5
- package/dist/esm/bundle.js.map +0 -1
- package/dist/esm/index.js +0 -5
- package/dist/esm/index.js.map +0 -1
- package/dist/esm/lib/encode-wkb.js +0 -323
- package/dist/esm/lib/encode-wkb.js.map +0 -1
- package/dist/esm/lib/encode-wkt.js +0 -52
- package/dist/esm/lib/encode-wkt.js.map +0 -1
- package/dist/esm/lib/parse-wkb.js +0 -304
- package/dist/esm/lib/parse-wkb.js.map +0 -1
- package/dist/esm/lib/parse-wkt.js +0 -198
- package/dist/esm/lib/parse-wkt.js.map +0 -1
- package/dist/esm/lib/utils/binary-writer.js +0 -153
- package/dist/esm/lib/utils/binary-writer.js.map +0 -1
- package/dist/esm/lib/utils/version.js +0 -2
- package/dist/esm/lib/utils/version.js.map +0 -1
- package/dist/esm/wkb-loader.js +0 -22
- package/dist/esm/wkb-loader.js.map +0 -1
- package/dist/esm/wkb-writer.js +0 -14
- package/dist/esm/wkb-writer.js.map +0 -1
- package/dist/esm/wkt-loader.js +0 -21
- package/dist/esm/wkt-loader.js.map +0 -1
- package/dist/esm/wkt-writer.js +0 -14
- package/dist/esm/wkt-writer.js.map +0 -1
- package/dist/esm/workers/wkb-worker.js +0 -4
- package/dist/esm/workers/wkb-worker.js.map +0 -1
- package/dist/esm/workers/wkt-worker.js +0 -4
- package/dist/esm/workers/wkt-worker.js.map +0 -1
package/dist/lib/parse-wkt.js
CHANGED
|
@@ -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
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
const
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
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
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
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
|
-
|
|
103
|
-
list.push(item);
|
|
104
|
-
else
|
|
105
|
-
return null;
|
|
106
|
-
return list.length ? list : null;
|
|
27
|
+
};
|
|
107
28
|
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
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
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
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
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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"}
|