@loaders.gl/wms 4.0.0-alpha.23 → 4.0.0-alpha.24
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/es5/csw-capabilities-loader.js +1 -1
- package/dist/es5/csw-domain-loader.js +1 -1
- package/dist/es5/csw-records-loader.js +1 -1
- package/dist/es5/gml-loader.js +1 -1
- package/dist/es5/gml-loader.js.map +1 -1
- package/dist/es5/lerc-loader.js +1 -1
- package/dist/es5/lerc-loader.js.map +1 -1
- package/dist/es5/lib/parsers/gml/parse-gml.js.map +1 -1
- package/dist/es5/wip/wcs-capabilities-loader.js +1 -1
- package/dist/es5/wip/wfs-capabilities-loader.js +1 -1
- package/dist/es5/wip/wmts-capabilities-loader.js +1 -1
- package/dist/es5/wms-capabilities-loader.js +1 -1
- package/dist/es5/wms-error-loader.js +1 -1
- package/dist/esm/csw-capabilities-loader.js +1 -1
- package/dist/esm/csw-domain-loader.js +1 -1
- package/dist/esm/csw-records-loader.js +1 -1
- package/dist/esm/gml-loader.js +1 -1
- package/dist/esm/gml-loader.js.map +1 -1
- package/dist/esm/lerc-loader.js +1 -1
- package/dist/esm/lerc-loader.js.map +1 -1
- package/dist/esm/lib/parsers/gml/parse-gml.js.map +1 -1
- package/dist/esm/wip/wcs-capabilities-loader.js +1 -1
- package/dist/esm/wip/wfs-capabilities-loader.js +1 -1
- package/dist/esm/wip/wmts-capabilities-loader.js +1 -1
- package/dist/esm/wms-capabilities-loader.js +1 -1
- package/dist/esm/wms-error-loader.js +1 -1
- package/dist/gml-loader.d.ts +2 -1
- package/dist/gml-loader.d.ts.map +1 -1
- package/dist/lerc-loader.d.ts +2 -1
- package/dist/lerc-loader.d.ts.map +1 -1
- package/dist/lib/parsers/gml/parse-gml.d.ts +1 -0
- package/dist/lib/parsers/gml/parse-gml.d.ts.map +1 -1
- package/package.json +6 -6
- package/src/gml-loader.ts +2 -1
- package/src/lerc-loader.ts +1 -1
- package/src/lib/parsers/gml/parse-gml.ts +2 -0
- package/dist/bundle.js +0 -6
- package/dist/csw-capabilities-loader.js +0 -30
- package/dist/csw-domain-loader.js +0 -30
- package/dist/csw-records-loader.js +0 -30
- package/dist/gml-loader.js +0 -30
- package/dist/index.js +0 -39
- package/dist/lerc-loader.js +0 -55
- package/dist/lib/create-image-source.js +0 -39
- package/dist/lib/parsers/csw/parse-csw-capabilities.js +0 -24
- package/dist/lib/parsers/csw/parse-csw-domain.js +0 -33
- package/dist/lib/parsers/csw/parse-csw-records.js +0 -58
- package/dist/lib/parsers/csw/parse-exception-report.js +0 -30
- package/dist/lib/parsers/gml/deep-strict-equal.js +0 -119
- package/dist/lib/parsers/gml/parse-gml.js +0 -371
- package/dist/lib/parsers/lerc/lerc-types.js +0 -3
- package/dist/lib/parsers/wms/parse-wms-capabilities.js +0 -233
- package/dist/lib/parsers/wms/parse-wms-error.js +0 -22
- package/dist/lib/parsers/wms/parse-wms-features.js +0 -27
- package/dist/lib/parsers/wms/parse-wms-layer-description.js +0 -15
- package/dist/lib/parsers/xml/parse-xml-helpers.js +0 -68
- package/dist/lib/services/arcgis/arcgis-image-service.js +0 -94
- package/dist/lib/services/arcgis/arcgis-server.js +0 -42
- package/dist/lib/services/generic/image-service.js +0 -47
- package/dist/lib/services/ogc/csw-service.js +0 -168
- package/dist/lib/services/ogc/wms-service.js +0 -309
- package/dist/lib/sources/data-source.js +0 -56
- package/dist/lib/sources/image-source.js +0 -13
- package/dist/lib/sources/tile-source.js +0 -13
- package/dist/lib/sources/utils/utils.js +0 -38
- package/dist/lib/wfs/parse-wfs.js +0 -32
- package/dist/lib/wmts/parse-wmts.js +0 -35
- package/dist/wip/arcgis-feature-service.js +0 -28
- package/dist/wip/data-source.js +0 -59
- package/dist/wip/lib/wcs/parse-wcs-capabilities.js +0 -15
- package/dist/wip/lib/wfs/parse-wfs-capabilities.js +0 -19
- package/dist/wip/lib/wmts/parse-wmts-capabilities.js +0 -77
- package/dist/wip/wcs-capabilities-loader.js +0 -31
- package/dist/wip/wfs-capabilities-loader.js +0 -31
- package/dist/wip/wms-feature-info-loader.js +0 -18
- package/dist/wip/wms-layer-description-loader.js +0 -17
- package/dist/wip/wmts-capabilities-loader.js +0 -32
- package/dist/wms-capabilities-loader.js +0 -34
- package/dist/wms-error-loader.js +0 -42
|
@@ -8,7 +8,7 @@ exports.CSWCapabilitiesLoader = void 0;
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseCswCapabilities = require("./lib/parsers/csw/parse-csw-capabilities");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var CSWCapabilitiesLoader = {
|
|
13
13
|
id: 'csw-capabilities',
|
|
14
14
|
name: 'CSW Capabilities',
|
|
@@ -8,7 +8,7 @@ exports.CSWDomainLoader = void 0;
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseCswDomain = require("./lib/parsers/csw/parse-csw-domain");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var CSWDomainLoader = {
|
|
13
13
|
id: 'csw-domain',
|
|
14
14
|
name: 'CSW Domain',
|
|
@@ -8,7 +8,7 @@ exports.CSWRecordsLoader = void 0;
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseCswRecords = require("./lib/parsers/csw/parse-csw-records");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var CSWRecordsLoader = {
|
|
13
13
|
id: 'csw-records',
|
|
14
14
|
name: 'CSW Records',
|
package/dist/es5/gml-loader.js
CHANGED
|
@@ -8,7 +8,7 @@ exports.GMLLoader = void 0;
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseGml = require("./lib/parsers/gml/parse-gml");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var GMLLoader = {
|
|
13
13
|
name: 'GML',
|
|
14
14
|
id: 'gml',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gml-loader.js","names":["_parseGml","require","VERSION","GMLLoader","name","id","module","version","worker","extensions","mimeTypes","testText","testXMLFile","options","gml","parse","_parse","_asyncToGenerator2","default","_regenerator","mark","_callee","arrayBuffer","wrap","_callee$","_context","prev","next","abrupt","parseGML","TextDecoder","decode","stop","_x","_x2","apply","arguments","parseTextSync","text","exports","startsWith"],"sources":["../../src/gml-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport {parseGML} from './lib/parsers/gml/parse-gml';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type GMLLoaderOptions = LoaderOptions & {\n gml?: {};\n};\n\n/**\n * Loader for the response to the GML GetCapability request\n */\nexport const GMLLoader: LoaderWithParser = {\n name: 'GML',\n id: 'gml',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['xml'],\n mimeTypes: ['application/vnd.ogc.gml', 'application/xml', 'text/xml'],\n testText: testXMLFile,\n options: {\n gml: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: GMLLoaderOptions) =>\n parseGML(new TextDecoder().decode(arrayBuffer), options),\n parseTextSync: (text: string, options?: GMLLoaderOptions) => parseGML(text, options)\n};\n\nfunction testXMLFile(text: string): boolean {\n // TODO - There could be space first.\n return text.startsWith('<?xml');\n}\n"],"mappings":";;;;;;;;;
|
|
1
|
+
{"version":3,"file":"gml-loader.js","names":["_parseGml","require","VERSION","GMLLoader","name","id","module","version","worker","extensions","mimeTypes","testText","testXMLFile","options","gml","parse","_parse","_asyncToGenerator2","default","_regenerator","mark","_callee","arrayBuffer","wrap","_callee$","_context","prev","next","abrupt","parseGML","TextDecoder","decode","stop","_x","_x2","apply","arguments","parseTextSync","text","exports","startsWith"],"sources":["../../src/gml-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport type {Geometry} from './lib/parsers/gml/parse-gml';\nimport {parseGML} from './lib/parsers/gml/parse-gml';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type GMLLoaderOptions = LoaderOptions & {\n gml?: {};\n};\n\n/**\n * Loader for the response to the GML GetCapability request\n */\nexport const GMLLoader: LoaderWithParser<Geometry | null, never, GMLLoaderOptions> = {\n name: 'GML',\n id: 'gml',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['xml'],\n mimeTypes: ['application/vnd.ogc.gml', 'application/xml', 'text/xml'],\n testText: testXMLFile,\n options: {\n gml: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: GMLLoaderOptions) =>\n parseGML(new TextDecoder().decode(arrayBuffer), options),\n parseTextSync: (text: string, options?: GMLLoaderOptions) => parseGML(text, options)\n};\n\nfunction testXMLFile(text: string): boolean {\n // TODO - There could be space first.\n return text.startsWith('<?xml');\n}\n"],"mappings":";;;;;;;;;AAIA,IAAAA,SAAA,GAAAC,OAAA;AAIA,IAAMC,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AASpE,IAAMC,SAAqE,GAAG;EACnFC,IAAI,EAAE,KAAK;EACXC,EAAE,EAAE,KAAK;EAETC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEL,OAAO;EAChBM,MAAM,EAAE,KAAK;EACbC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,SAAS,EAAE,CAAC,yBAAyB,EAAE,iBAAiB,EAAE,UAAU,CAAC;EACrEC,QAAQ,EAAEC,WAAW;EACrBC,OAAO,EAAE;IACPC,GAAG,EAAE,CAAC;EACR,CAAC;EACDC,KAAK;IAAA,IAAAC,MAAA,OAAAC,kBAAA,CAAAC,OAAA,EAAAC,YAAA,CAAAD,OAAA,CAAAE,IAAA,CAAE,SAAAC,QAAOC,WAAwB,EAAET,OAA0B;MAAA,OAAAM,YAAA,CAAAD,OAAA,CAAAK,IAAA,UAAAC,SAAAC,QAAA;QAAA,kBAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;UAAA;YAAA,OAAAF,QAAA,CAAAG,MAAA,WAChE,IAAAC,kBAAQ,EAAC,IAAIC,WAAW,CAAC,CAAC,CAACC,MAAM,CAACT,WAAW,CAAC,EAAET,OAAO,CAAC;UAAA;UAAA;YAAA,OAAAY,QAAA,CAAAO,IAAA;QAAA;MAAA,GAAAX,OAAA;IAAA;IAAA,SAAAN,MAAAkB,EAAA,EAAAC,GAAA;MAAA,OAAAlB,MAAA,CAAAmB,KAAA,OAAAC,SAAA;IAAA;IAAA,OAAArB,KAAA;EAAA;EAC1DsB,aAAa,EAAE,SAAAA,cAACC,IAAY,EAAEzB,OAA0B;IAAA,OAAK,IAAAgB,kBAAQ,EAACS,IAAI,EAAEzB,OAAO,CAAC;EAAA;AACtF,CAAC;AAAC0B,OAAA,CAAApC,SAAA,GAAAA,SAAA;AAEF,SAASS,WAAWA,CAAC0B,IAAY,EAAW;EAE1C,OAAOA,IAAI,CAACE,UAAU,CAAC,OAAO,CAAC;AACjC"}
|
package/dist/es5/lerc-loader.js
CHANGED
|
@@ -11,7 +11,7 @@ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/
|
|
|
11
11
|
var Lerc = _interopRequireWildcard(require("lerc"));
|
|
12
12
|
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
13
13
|
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
14
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
14
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
15
15
|
var LERCLoader = {
|
|
16
16
|
id: 'lerc',
|
|
17
17
|
name: 'LERC',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lerc-loader.js","names":["Lerc","_interopRequireWildcard","require","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","VERSION","LERCLoader","id","name","module","version","worker","extensions","mimeTypes","options","wms","parse","_parse","_asyncToGenerator2","_regenerator","mark","_callee","arrayBuffer","wrap","_callee$","_context","prev","next","abrupt","parseLERC","stop","_x","_x2","apply","arguments","exports","_x3","_x4","_parseLERC","_callee2","pixelBlock","_callee2$","_context2","load","decode","lerc"],"sources":["../../src/lerc-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport type {LERCData} from './lib/parsers/lerc/lerc-types';\nimport * as Lerc from 'lerc';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type LERCLoaderOptions = LoaderOptions & {\n lerc?: {\n /**\tThe number of bytes to skip in the input byte stream. A valid Lerc file is expected at that position. */\n inputOffset?: number;\n /**\tIt is recommended to use the returned mask instead of setting this value. */\n noDataValue?: number;\n /**\t(ndepth LERC2 only) If true, returned depth values are pixel-interleaved. */\n returnInterleaved?: boolean;\n };\n};\n\n/**\n * Loader for the LERC raster format\n */\nexport const LERCLoader: LoaderWithParser = {\n id: 'lerc',\n name: 'LERC',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['lrc', 'lerc', 'lerc2', 'lerc1'],\n mimeTypes: ['application/octet-stream'],\n // test: ?,\n options: {\n wms: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions) =>\n parseLERC(arrayBuffer, options)\n};\n\nasync function parseLERC(arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions): Promise<LERCData> {\n // Load the WASM library\n await Lerc.load();\n // Perform the decode\n const pixelBlock = Lerc.decode(arrayBuffer, options?.lerc);\n return pixelBlock;\n}\n"],"mappings":";;;;;;;;;;AAIA,IAAAA,IAAA,GAAAC,uBAAA,CAAAC,OAAA;AAA6B,SAAAC,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAH,wBAAAO,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAI7B,IAAMW,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAgBpE,IAAMC,
|
|
1
|
+
{"version":3,"file":"lerc-loader.js","names":["Lerc","_interopRequireWildcard","require","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","VERSION","LERCLoader","id","name","module","version","worker","extensions","mimeTypes","options","wms","parse","_parse","_asyncToGenerator2","_regenerator","mark","_callee","arrayBuffer","wrap","_callee$","_context","prev","next","abrupt","parseLERC","stop","_x","_x2","apply","arguments","exports","_x3","_x4","_parseLERC","_callee2","pixelBlock","_callee2$","_context2","load","decode","lerc"],"sources":["../../src/lerc-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport type {LERCData} from './lib/parsers/lerc/lerc-types';\nimport * as Lerc from 'lerc';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type LERCLoaderOptions = LoaderOptions & {\n lerc?: {\n /**\tThe number of bytes to skip in the input byte stream. A valid Lerc file is expected at that position. */\n inputOffset?: number;\n /**\tIt is recommended to use the returned mask instead of setting this value. */\n noDataValue?: number;\n /**\t(ndepth LERC2 only) If true, returned depth values are pixel-interleaved. */\n returnInterleaved?: boolean;\n };\n};\n\n/**\n * Loader for the LERC raster format\n */\nexport const LERCLoader: LoaderWithParser<LERCData, never, LERCLoaderOptions> = {\n id: 'lerc',\n name: 'LERC',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['lrc', 'lerc', 'lerc2', 'lerc1'],\n mimeTypes: ['application/octet-stream'],\n // test: ?,\n options: {\n wms: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions) =>\n parseLERC(arrayBuffer, options)\n};\n\nasync function parseLERC(arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions): Promise<LERCData> {\n // Load the WASM library\n await Lerc.load();\n // Perform the decode\n const pixelBlock = Lerc.decode(arrayBuffer, options?.lerc);\n return pixelBlock;\n}\n"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse-gml.js","names":["_xml","require","_deepStrictEqual","_rewind","_interopRequireDefault","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","arguments","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","noTransform","_len","coords","_key","parseGML","text","options","_XMLLoader$parseTextS","parsedXML","XMLLoader","parseTextSync","transformCoords","stride","context","createChildContext","parseGMLToGeometry","inputXML","childContext","geometry","_getFirstKeyValue","getFirstKeyValue","_getFirstKeyValue2","_slicedToArray2","xml","type","coordinates","parseLinearRingOrLineString","parsePolygonOrRectangle","parseSurface","parseMultiSurface","rewind","mutate","parseCoords","srsDimension","replace","trim","split","Error","concat","points","_options$transformCoo","_options$transformCoo2","point","map","parseFloat","_toConsumableArray2","parsePosList","textOf","parsePos","parsePoint","pos","findIn","posList","_i","_Object$entries","entries","_Object$entries$_i","childName","childXML","parseCurveSegments","_i2","_Object$entries2","_Object$entries2$_i","points2","end","start","deepStrictEqual","shift","parseRing","_i3","_Object$entries3","_Object$entries3$_i","lineString","segments","parseExteriorOrInterior","linearRing","ring","exterior","pointLists","_i4","_Object$entries4","_Object$entries4$_i","patches","polygons","_i5","_Object$entries5","_Object$entries5$_i","parseCompositeSurface","_i6","_Object$entries6","_Object$entries6$_i","_getFirstKeyValue3","_getFirstKeyValue4","c2Name","c2Xml","el","surfaceMembers","_i7","_Object$entries7","_Object$entries7$_i","polygons2","polygons3","parseSurfaceMember","polygonXML","_iterator","_step","surfaceMemberXML","_getFirstKeyValue5","_getFirstKeyValue6","childXml","root","_len2","tags","_key2","_i8","_tags","tag","child","_typeof2","_i9","_Object$entries8","_Object$entries8$_i","srsDimensionAttribute","attributes","parseInt","Number","isNaN","create"],"sources":["../../../../../src/lib/parsers/gml/parse-gml.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n// Forked from https://github.com/derhuerst/parse-gml-polygon/blob/master/index.js\n// under ISC license\n\n/* eslint-disable no-continue, default-case */\n\nimport type {\n // GeoJSON,\n // Feature,\n // FeatureCollection,\n Geometry,\n Position\n // GeoJsonProperties,\n // Point,\n // MultiPoint,\n // LineString,\n // MultiLineString,\n // Polygon,\n // MultiPolygon,\n // GeometryCollection\n} from '@loaders.gl/schema';\n\nimport {XMLLoader} from '@loaders.gl/xml';\nimport {deepStrictEqual} from './deep-strict-equal';\nimport rewind from '@turf/rewind';\n\nfunction noTransform(...coords) {\n return coords;\n}\n\nexport type ParseGMLOptions = {\n transformCoords?: Function;\n stride?: 2 | 3 | 4;\n};\n\nexport type ParseGMLContext = {\n srsDimension?: number;\n [key: string]: any;\n};\n\n/**\n * Parses a typed data structure from raw XML for GML features\n * @note Error handlings is fairly weak\n */\nexport function parseGML(text: string, options) {\n // GeoJSON | null {\n const parsedXML = XMLLoader.parseTextSync?.(text, options);\n\n options = {transformCoords: noTransform, stride: 2, ...options};\n const context = createChildContext(parsedXML, options, {});\n\n return parseGMLToGeometry(parsedXML, options, context);\n}\n\n/** Parse a GeoJSON geometry from GML XML */\nexport function parseGMLToGeometry(\n inputXML: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Geometry | null {\n const childContext = createChildContext(inputXML, options, context);\n\n let geometry: Geometry | null = null;\n\n const [name, xml] = getFirstKeyValue(inputXML);\n\n switch (name) {\n // case 'gml:MultiPoint':\n // geometry = {\n // type: 'MultiPoint',\n // coordinates: parseMultiPoint(xml, options, childContext)\n // };\n // break;\n\n case 'gml:LineString':\n geometry = {\n type: 'LineString',\n coordinates: parseLinearRingOrLineString(xml, options, childContext)\n };\n break;\n\n // case 'gml:MultiLineString':\n // geometry = {\n // type: 'MultiLineString',\n // coordinates: parseMultiLineString(xml, options, childContext)\n // };\n // break;\n\n case 'gml:Polygon':\n case 'gml:Rectangle':\n geometry = {\n type: 'Polygon',\n coordinates: parsePolygonOrRectangle(xml, options, childContext)\n };\n break;\n case 'gml:Surface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseSurface(xml, options, childContext)\n };\n break;\n case 'gml:MultiSurface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseMultiSurface(xml, options, childContext)\n };\n break;\n\n default:\n return null;\n }\n\n // todo\n return rewind(geometry, {mutate: true});\n}\n\n/** Parse a list of coordinates from a string */\nfunction parseCoords(s: string, options: ParseGMLOptions, context: ParseGMLContext): Position[] {\n const stride = context.srsDimension || options.stride || 2;\n\n // Handle white space\n const coords = s.replace(/\\s+/g, ' ').trim().split(' ');\n\n if (coords.length === 0 || coords.length % stride !== 0) {\n throw new Error(`invalid coordinates list (stride ${stride})`);\n }\n\n const points: Position[] = [];\n for (let i = 0; i < coords.length - 1; i += stride) {\n const point = coords.slice(i, i + stride).map(parseFloat);\n points.push(options.transformCoords?.(...point) || point);\n }\n\n return points;\n}\n\nexport function parsePosList(xml: any, options: ParseGMLOptions, context: ParseGMLContext) {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:posList element');\n }\n\n return parseCoords(coords, options, childContext);\n}\n\nexport function parsePos(xml: any, options: ParseGMLOptions, context: ParseGMLContext): Position {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:pos element');\n }\n\n const points = parseCoords(coords, options, childContext);\n if (points.length !== 1) {\n throw new Error('gml:pos must have 1 point');\n }\n return points[0];\n}\n\nexport function parsePoint(xml: any, options: ParseGMLOptions, context: ParseGMLContext): number[] {\n const childContext = createChildContext(xml, options, context);\n\n // TODO AV: Parse other gml:Point options\n const pos = findIn(xml, 'gml:pos');\n if (!pos) {\n throw new Error('invalid gml:Point element, expected a gml:pos subelement');\n }\n return parsePos(pos, options, childContext);\n}\n\nexport function parseLinearRingOrLineString(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n // or a LineStringSegment\n const childContext = createChildContext(xml, options, context);\n\n let points: Position[] = [];\n\n const posList = findIn(xml, 'gml:posList');\n if (posList) {\n points = parsePosList(posList, options, childContext);\n } else {\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:Point':\n points.push(parsePoint(childXML, options, childContext));\n break;\n case 'gml:pos':\n points.push(parsePos(childXML, options, childContext));\n break;\n default:\n continue;\n }\n }\n }\n\n if (points.length === 0) {\n throw new Error(`${xml.name} must have > 0 points`);\n }\n return points;\n}\n\nexport function parseCurveSegments(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:LineStringSegment':\n const points2 = parseLinearRingOrLineString(childXML, options, context);\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n break;\n default:\n continue;\n }\n }\n\n if (points.length === 0) {\n throw new Error('gml:Curve > gml:segments must have > 0 points');\n }\n return points;\n}\n\nexport function parseRing(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const childContext = createChildContext(xml, options, context);\n\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:curveMember':\n let points2;\n\n const lineString = findIn(childXML, 'gml:LineString');\n if (lineString) {\n points2 = parseLinearRingOrLineString(lineString, options, childContext);\n } else {\n const segments = findIn(childXML, 'gml:Curve', 'gml:segments');\n if (!segments) {\n throw new Error(`invalid ${childName} element`);\n }\n\n points2 = parseCurveSegments(segments, options, childContext);\n }\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n\n break;\n }\n }\n\n if (points.length < 4) {\n throw new Error(`${xml.name} must have >= 4 points`);\n }\n return points;\n}\n\nexport function parseExteriorOrInterior(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const linearRing = findIn(xml, 'gml:LinearRing');\n if (linearRing) {\n return parseLinearRingOrLineString(linearRing, options, context);\n }\n\n const ring = findIn(xml, 'gml:Ring');\n if (!ring) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n return parseRing(ring, options, context);\n}\n\nexport function parsePolygonOrRectangle(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][] {\n // or PolygonPatch\n const childContext = createChildContext(xml, options, context);\n\n const exterior = findIn(xml, 'gml:exterior');\n if (!exterior) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const pointLists: Position[][] = [parseExteriorOrInterior(exterior, options, childContext)];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:interior':\n pointLists.push(parseExteriorOrInterior(childXML, options, childContext));\n break;\n }\n }\n\n return pointLists;\n}\n\nexport function parseSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const patches = findIn(xml, 'gml:patches');\n if (!patches) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:PolygonPatch':\n case 'gml:Rectangle':\n polygons.push(parsePolygonOrRectangle(childXML, options, childContext));\n break;\n\n default:\n continue;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nexport function parseCompositeSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:surfaceMember':\n case 'gml:surfaceMembers':\n const [c2Name, c2Xml] = getFirstKeyValue(childXML);\n switch (c2Name) {\n case 'gml:Surface':\n polygons.push(...parseSurface(c2Xml, options, childContext));\n break;\n case 'gml:Polygon':\n polygons.push(parsePolygonOrRectangle(c2Xml, options, childContext));\n break;\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n return polygons;\n}\n\nexport function parseMultiSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n let el = xml;\n\n const surfaceMembers = findIn(xml, 'gml:LinearRing');\n if (surfaceMembers) {\n el = surfaceMembers;\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(el)) {\n switch (childName) {\n case 'gml:Surface':\n const polygons2 = parseSurface(childXML, options, context);\n polygons.push(...polygons2);\n break;\n case 'gml:surfaceMember':\n const polygons3 = parseSurfaceMember(childXML, options, context);\n polygons.push(...polygons3);\n break;\n\n case 'gml:surfaceMembers':\n const polygonXML = findIn(childXML, 'gml:Polygon');\n for (const surfaceMemberXML of polygonXML as []) {\n const polygons3 = parseSurfaceMember(surfaceMemberXML, options, context);\n polygons.push(...polygons3);\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nfunction parseSurfaceMember(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const [childName, childXml] = getFirstKeyValue(xml);\n switch (childName) {\n case 'gml:CompositeSurface':\n return parseCompositeSurface(childXml, options, context);\n case 'gml:Surface':\n return parseSurface(childXml, options, context);\n case 'gml:Polygon':\n return [parsePolygonOrRectangle(childXml, options, context)];\n }\n throw new Error(`${childName} must have polygons`);\n}\n\n// Helpers\n\nfunction textOf(el: any): string {\n if (typeof el !== 'string') {\n throw new Error('expected string');\n }\n return el;\n}\n\nfunction findIn(root: any, ...tags: string[]): any {\n let el = root;\n for (const tag of tags) {\n const child = el[tag];\n if (!child) {\n return null;\n }\n el = child;\n }\n return el;\n}\n\n/** @returns the first [key, value] pair in an object, or ['', null] if empty object */\nfunction getFirstKeyValue(object: any): [string, any] {\n if (object && typeof object === 'object') {\n for (const [key, value] of Object.entries(object)) {\n return [key, value];\n }\n }\n return ['', null];\n}\n\n/** A bit heavyweight for just tracking dimension? */\nfunction createChildContext(xml, options, context): ParseGMLContext {\n const srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;\n\n if (srsDimensionAttribute) {\n const srsDimension = parseInt(srsDimensionAttribute);\n if (Number.isNaN(srsDimension) || srsDimension <= 0) {\n throw new Error(\n `invalid srsDimension attribute value \"${srsDimensionAttribute}\", expected a positive integer`\n );\n }\n\n const childContext = Object.create(context);\n childContext.srsDimension = srsDimension;\n return childContext;\n }\n\n return context;\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"parse-gml.js","names":["_xml","require","_deepStrictEqual","_rewind","_interopRequireDefault","_createForOfIteratorHelper","o","allowArrayLike","it","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","i","F","s","n","done","value","e","_e","f","TypeError","normalCompletion","didErr","err","call","step","next","_e2","return","minLen","_arrayLikeToArray","Object","prototype","toString","slice","constructor","name","from","test","arr","len","arr2","ownKeys","object","enumerableOnly","keys","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","arguments","source","forEach","key","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","noTransform","_len","coords","_key","parseGML","text","options","_XMLLoader$parseTextS","parsedXML","XMLLoader","parseTextSync","transformCoords","stride","context","createChildContext","parseGMLToGeometry","inputXML","childContext","geometry","_getFirstKeyValue","getFirstKeyValue","_getFirstKeyValue2","_slicedToArray2","xml","type","coordinates","parseLinearRingOrLineString","parsePolygonOrRectangle","parseSurface","parseMultiSurface","rewind","mutate","parseCoords","srsDimension","replace","trim","split","Error","concat","points","_options$transformCoo","_options$transformCoo2","point","map","parseFloat","_toConsumableArray2","parsePosList","textOf","parsePos","parsePoint","pos","findIn","posList","_i","_Object$entries","entries","_Object$entries$_i","childName","childXML","parseCurveSegments","_i2","_Object$entries2","_Object$entries2$_i","points2","end","start","deepStrictEqual","shift","parseRing","_i3","_Object$entries3","_Object$entries3$_i","lineString","segments","parseExteriorOrInterior","linearRing","ring","exterior","pointLists","_i4","_Object$entries4","_Object$entries4$_i","patches","polygons","_i5","_Object$entries5","_Object$entries5$_i","parseCompositeSurface","_i6","_Object$entries6","_Object$entries6$_i","_getFirstKeyValue3","_getFirstKeyValue4","c2Name","c2Xml","el","surfaceMembers","_i7","_Object$entries7","_Object$entries7$_i","polygons2","polygons3","parseSurfaceMember","polygonXML","_iterator","_step","surfaceMemberXML","_getFirstKeyValue5","_getFirstKeyValue6","childXml","root","_len2","tags","_key2","_i8","_tags","tag","child","_typeof2","_i9","_Object$entries8","_Object$entries8$_i","srsDimensionAttribute","attributes","parseInt","Number","isNaN","create"],"sources":["../../../../../src/lib/parsers/gml/parse-gml.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n// Forked from https://github.com/derhuerst/parse-gml-polygon/blob/master/index.js\n// under ISC license\n\n/* eslint-disable no-continue, default-case */\n\nimport type {\n // GeoJSON,\n // Feature,\n // FeatureCollection,\n Geometry,\n Position\n // GeoJsonProperties,\n // Point,\n // MultiPoint,\n // LineString,\n // MultiLineString,\n // Polygon,\n // MultiPolygon,\n // GeometryCollection\n} from '@loaders.gl/schema';\n\nimport {XMLLoader} from '@loaders.gl/xml';\nimport {deepStrictEqual} from './deep-strict-equal';\nimport rewind from '@turf/rewind';\n\nfunction noTransform(...coords) {\n return coords;\n}\n\nexport type {Geometry};\n\nexport type ParseGMLOptions = {\n transformCoords?: Function;\n stride?: 2 | 3 | 4;\n};\n\nexport type ParseGMLContext = {\n srsDimension?: number;\n [key: string]: any;\n};\n\n/**\n * Parses a typed data structure from raw XML for GML features\n * @note Error handlings is fairly weak\n */\nexport function parseGML(text: string, options) {\n // GeoJSON | null {\n const parsedXML = XMLLoader.parseTextSync?.(text, options);\n\n options = {transformCoords: noTransform, stride: 2, ...options};\n const context = createChildContext(parsedXML, options, {});\n\n return parseGMLToGeometry(parsedXML, options, context);\n}\n\n/** Parse a GeoJSON geometry from GML XML */\nexport function parseGMLToGeometry(\n inputXML: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Geometry | null {\n const childContext = createChildContext(inputXML, options, context);\n\n let geometry: Geometry | null = null;\n\n const [name, xml] = getFirstKeyValue(inputXML);\n\n switch (name) {\n // case 'gml:MultiPoint':\n // geometry = {\n // type: 'MultiPoint',\n // coordinates: parseMultiPoint(xml, options, childContext)\n // };\n // break;\n\n case 'gml:LineString':\n geometry = {\n type: 'LineString',\n coordinates: parseLinearRingOrLineString(xml, options, childContext)\n };\n break;\n\n // case 'gml:MultiLineString':\n // geometry = {\n // type: 'MultiLineString',\n // coordinates: parseMultiLineString(xml, options, childContext)\n // };\n // break;\n\n case 'gml:Polygon':\n case 'gml:Rectangle':\n geometry = {\n type: 'Polygon',\n coordinates: parsePolygonOrRectangle(xml, options, childContext)\n };\n break;\n case 'gml:Surface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseSurface(xml, options, childContext)\n };\n break;\n case 'gml:MultiSurface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseMultiSurface(xml, options, childContext)\n };\n break;\n\n default:\n return null;\n }\n\n // todo\n return rewind(geometry, {mutate: true});\n}\n\n/** Parse a list of coordinates from a string */\nfunction parseCoords(s: string, options: ParseGMLOptions, context: ParseGMLContext): Position[] {\n const stride = context.srsDimension || options.stride || 2;\n\n // Handle white space\n const coords = s.replace(/\\s+/g, ' ').trim().split(' ');\n\n if (coords.length === 0 || coords.length % stride !== 0) {\n throw new Error(`invalid coordinates list (stride ${stride})`);\n }\n\n const points: Position[] = [];\n for (let i = 0; i < coords.length - 1; i += stride) {\n const point = coords.slice(i, i + stride).map(parseFloat);\n points.push(options.transformCoords?.(...point) || point);\n }\n\n return points;\n}\n\nexport function parsePosList(xml: any, options: ParseGMLOptions, context: ParseGMLContext) {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:posList element');\n }\n\n return parseCoords(coords, options, childContext);\n}\n\nexport function parsePos(xml: any, options: ParseGMLOptions, context: ParseGMLContext): Position {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:pos element');\n }\n\n const points = parseCoords(coords, options, childContext);\n if (points.length !== 1) {\n throw new Error('gml:pos must have 1 point');\n }\n return points[0];\n}\n\nexport function parsePoint(xml: any, options: ParseGMLOptions, context: ParseGMLContext): number[] {\n const childContext = createChildContext(xml, options, context);\n\n // TODO AV: Parse other gml:Point options\n const pos = findIn(xml, 'gml:pos');\n if (!pos) {\n throw new Error('invalid gml:Point element, expected a gml:pos subelement');\n }\n return parsePos(pos, options, childContext);\n}\n\nexport function parseLinearRingOrLineString(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n // or a LineStringSegment\n const childContext = createChildContext(xml, options, context);\n\n let points: Position[] = [];\n\n const posList = findIn(xml, 'gml:posList');\n if (posList) {\n points = parsePosList(posList, options, childContext);\n } else {\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:Point':\n points.push(parsePoint(childXML, options, childContext));\n break;\n case 'gml:pos':\n points.push(parsePos(childXML, options, childContext));\n break;\n default:\n continue;\n }\n }\n }\n\n if (points.length === 0) {\n throw new Error(`${xml.name} must have > 0 points`);\n }\n return points;\n}\n\nexport function parseCurveSegments(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:LineStringSegment':\n const points2 = parseLinearRingOrLineString(childXML, options, context);\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n break;\n default:\n continue;\n }\n }\n\n if (points.length === 0) {\n throw new Error('gml:Curve > gml:segments must have > 0 points');\n }\n return points;\n}\n\nexport function parseRing(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const childContext = createChildContext(xml, options, context);\n\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:curveMember':\n let points2;\n\n const lineString = findIn(childXML, 'gml:LineString');\n if (lineString) {\n points2 = parseLinearRingOrLineString(lineString, options, childContext);\n } else {\n const segments = findIn(childXML, 'gml:Curve', 'gml:segments');\n if (!segments) {\n throw new Error(`invalid ${childName} element`);\n }\n\n points2 = parseCurveSegments(segments, options, childContext);\n }\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n\n break;\n }\n }\n\n if (points.length < 4) {\n throw new Error(`${xml.name} must have >= 4 points`);\n }\n return points;\n}\n\nexport function parseExteriorOrInterior(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const linearRing = findIn(xml, 'gml:LinearRing');\n if (linearRing) {\n return parseLinearRingOrLineString(linearRing, options, context);\n }\n\n const ring = findIn(xml, 'gml:Ring');\n if (!ring) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n return parseRing(ring, options, context);\n}\n\nexport function parsePolygonOrRectangle(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][] {\n // or PolygonPatch\n const childContext = createChildContext(xml, options, context);\n\n const exterior = findIn(xml, 'gml:exterior');\n if (!exterior) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const pointLists: Position[][] = [parseExteriorOrInterior(exterior, options, childContext)];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:interior':\n pointLists.push(parseExteriorOrInterior(childXML, options, childContext));\n break;\n }\n }\n\n return pointLists;\n}\n\nexport function parseSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const patches = findIn(xml, 'gml:patches');\n if (!patches) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:PolygonPatch':\n case 'gml:Rectangle':\n polygons.push(parsePolygonOrRectangle(childXML, options, childContext));\n break;\n\n default:\n continue;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nexport function parseCompositeSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:surfaceMember':\n case 'gml:surfaceMembers':\n const [c2Name, c2Xml] = getFirstKeyValue(childXML);\n switch (c2Name) {\n case 'gml:Surface':\n polygons.push(...parseSurface(c2Xml, options, childContext));\n break;\n case 'gml:Polygon':\n polygons.push(parsePolygonOrRectangle(c2Xml, options, childContext));\n break;\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n return polygons;\n}\n\nexport function parseMultiSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n let el = xml;\n\n const surfaceMembers = findIn(xml, 'gml:LinearRing');\n if (surfaceMembers) {\n el = surfaceMembers;\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(el)) {\n switch (childName) {\n case 'gml:Surface':\n const polygons2 = parseSurface(childXML, options, context);\n polygons.push(...polygons2);\n break;\n case 'gml:surfaceMember':\n const polygons3 = parseSurfaceMember(childXML, options, context);\n polygons.push(...polygons3);\n break;\n\n case 'gml:surfaceMembers':\n const polygonXML = findIn(childXML, 'gml:Polygon');\n for (const surfaceMemberXML of polygonXML as []) {\n const polygons3 = parseSurfaceMember(surfaceMemberXML, options, context);\n polygons.push(...polygons3);\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nfunction parseSurfaceMember(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const [childName, childXml] = getFirstKeyValue(xml);\n switch (childName) {\n case 'gml:CompositeSurface':\n return parseCompositeSurface(childXml, options, context);\n case 'gml:Surface':\n return parseSurface(childXml, options, context);\n case 'gml:Polygon':\n return [parsePolygonOrRectangle(childXml, options, context)];\n }\n throw new Error(`${childName} must have polygons`);\n}\n\n// Helpers\n\nfunction textOf(el: any): string {\n if (typeof el !== 'string') {\n throw new Error('expected string');\n }\n return el;\n}\n\nfunction findIn(root: any, ...tags: string[]): any {\n let el = root;\n for (const tag of tags) {\n const child = el[tag];\n if (!child) {\n return null;\n }\n el = child;\n }\n return el;\n}\n\n/** @returns the first [key, value] pair in an object, or ['', null] if empty object */\nfunction getFirstKeyValue(object: any): [string, any] {\n if (object && typeof object === 'object') {\n for (const [key, value] of Object.entries(object)) {\n return [key, value];\n }\n }\n return ['', null];\n}\n\n/** A bit heavyweight for just tracking dimension? */\nfunction createChildContext(xml, options, context): ParseGMLContext {\n const srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;\n\n if (srsDimensionAttribute) {\n const srsDimension = parseInt(srsDimensionAttribute);\n if (Number.isNaN(srsDimension) || srsDimension <= 0) {\n throw new Error(\n `invalid srsDimension attribute value \"${srsDimensionAttribute}\", expected a positive integer`\n );\n }\n\n const childContext = Object.create(context);\n childContext.srsDimension = srsDimension;\n return childContext;\n }\n\n return context;\n}\n"],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ exports._typecheckWFSCapabilitiesLoader = exports.WCSCapabilitiesLoader = void 0
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseWcsCapabilities = require("./lib/wcs/parse-wcs-capabilities");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var WCSCapabilitiesLoader = {
|
|
13
13
|
id: 'wcs-capabilities',
|
|
14
14
|
name: 'WFS Capabilities',
|
|
@@ -8,7 +8,7 @@ exports._typecheckWFSCapabilitiesLoader = exports.WFSCapabilitiesLoader = void 0
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseWfsCapabilities = require("./lib/wfs/parse-wfs-capabilities");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var WFSCapabilitiesLoader = {
|
|
13
13
|
id: 'wfs-capabilities',
|
|
14
14
|
name: 'WFS Capabilities',
|
|
@@ -8,7 +8,7 @@ exports._typecheckWMTSCapabilitiesLoader = exports.WMTSCapabilitiesLoader = void
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseWmtsCapabilities = require("./lib/wmts/parse-wmts-capabilities");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var WMTSCapabilitiesLoader = {
|
|
13
13
|
id: 'wmts-capabilities',
|
|
14
14
|
name: 'WMTS Capabilities',
|
|
@@ -8,7 +8,7 @@ exports.WMSCapabilitiesLoader = void 0;
|
|
|
8
8
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
9
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
10
10
|
var _parseWmsCapabilities = require("./lib/parsers/wms/parse-wms-capabilities");
|
|
11
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
11
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
12
12
|
var WMSCapabilitiesLoader = {
|
|
13
13
|
id: 'wms-capabilities',
|
|
14
14
|
name: 'WMS Capabilities',
|
|
@@ -11,7 +11,7 @@ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/
|
|
|
11
11
|
var _parseWmsError = require("./lib/parsers/wms/parse-wms-error");
|
|
12
12
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
13
13
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
14
|
-
var VERSION = typeof "4.0.0-alpha.
|
|
14
|
+
var VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
15
15
|
var WMSErrorLoader = {
|
|
16
16
|
id: 'wms-error',
|
|
17
17
|
name: 'WMS Error',
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseCSWCapabilities } from './lib/parsers/csw/parse-csw-capabilities';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const CSWCapabilitiesLoader = {
|
|
4
4
|
id: 'csw-capabilities',
|
|
5
5
|
name: 'CSW Capabilities',
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseCSWDomain } from './lib/parsers/csw/parse-csw-domain';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const CSWDomainLoader = {
|
|
4
4
|
id: 'csw-domain',
|
|
5
5
|
name: 'CSW Domain',
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseCSWRecords } from './lib/parsers/csw/parse-csw-records';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const CSWRecordsLoader = {
|
|
4
4
|
id: 'csw-records',
|
|
5
5
|
name: 'CSW Records',
|
package/dist/esm/gml-loader.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseGML } from './lib/parsers/gml/parse-gml';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const GMLLoader = {
|
|
4
4
|
name: 'GML',
|
|
5
5
|
id: 'gml',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"gml-loader.js","names":["parseGML","VERSION","GMLLoader","name","id","module","version","worker","extensions","mimeTypes","testText","testXMLFile","options","gml","parse","arrayBuffer","TextDecoder","decode","parseTextSync","text","startsWith"],"sources":["../../src/gml-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport {parseGML} from './lib/parsers/gml/parse-gml';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type GMLLoaderOptions = LoaderOptions & {\n gml?: {};\n};\n\n/**\n * Loader for the response to the GML GetCapability request\n */\nexport const GMLLoader: LoaderWithParser = {\n name: 'GML',\n id: 'gml',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['xml'],\n mimeTypes: ['application/vnd.ogc.gml', 'application/xml', 'text/xml'],\n testText: testXMLFile,\n options: {\n gml: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: GMLLoaderOptions) =>\n parseGML(new TextDecoder().decode(arrayBuffer), options),\n parseTextSync: (text: string, options?: GMLLoaderOptions) => parseGML(text, options)\n};\n\nfunction testXMLFile(text: string): boolean {\n // TODO - There could be space first.\n return text.startsWith('<?xml');\n}\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"gml-loader.js","names":["parseGML","VERSION","GMLLoader","name","id","module","version","worker","extensions","mimeTypes","testText","testXMLFile","options","gml","parse","arrayBuffer","TextDecoder","decode","parseTextSync","text","startsWith"],"sources":["../../src/gml-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport type {Geometry} from './lib/parsers/gml/parse-gml';\nimport {parseGML} from './lib/parsers/gml/parse-gml';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type GMLLoaderOptions = LoaderOptions & {\n gml?: {};\n};\n\n/**\n * Loader for the response to the GML GetCapability request\n */\nexport const GMLLoader: LoaderWithParser<Geometry | null, never, GMLLoaderOptions> = {\n name: 'GML',\n id: 'gml',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['xml'],\n mimeTypes: ['application/vnd.ogc.gml', 'application/xml', 'text/xml'],\n testText: testXMLFile,\n options: {\n gml: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: GMLLoaderOptions) =>\n parseGML(new TextDecoder().decode(arrayBuffer), options),\n parseTextSync: (text: string, options?: GMLLoaderOptions) => parseGML(text, options)\n};\n\nfunction testXMLFile(text: string): boolean {\n // TODO - There could be space first.\n return text.startsWith('<?xml');\n}\n"],"mappings":"AAIA,SAAQA,QAAQ,QAAO,6BAA6B;AAIpD,MAAMC,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAS3E,OAAO,MAAMC,SAAqE,GAAG;EACnFC,IAAI,EAAE,KAAK;EACXC,EAAE,EAAE,KAAK;EAETC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEL,OAAO;EAChBM,MAAM,EAAE,KAAK;EACbC,UAAU,EAAE,CAAC,KAAK,CAAC;EACnBC,SAAS,EAAE,CAAC,yBAAyB,EAAE,iBAAiB,EAAE,UAAU,CAAC;EACrEC,QAAQ,EAAEC,WAAW;EACrBC,OAAO,EAAE;IACPC,GAAG,EAAE,CAAC;EACR,CAAC;EACDC,KAAK,EAAE,MAAAA,CAAOC,WAAwB,EAAEH,OAA0B,KAChEZ,QAAQ,CAAC,IAAIgB,WAAW,CAAC,CAAC,CAACC,MAAM,CAACF,WAAW,CAAC,EAAEH,OAAO,CAAC;EAC1DM,aAAa,EAAEA,CAACC,IAAY,EAAEP,OAA0B,KAAKZ,QAAQ,CAACmB,IAAI,EAAEP,OAAO;AACrF,CAAC;AAED,SAASD,WAAWA,CAACQ,IAAY,EAAW;EAE1C,OAAOA,IAAI,CAACC,UAAU,CAAC,OAAO,CAAC;AACjC"}
|
package/dist/esm/lerc-loader.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lerc-loader.js","names":["Lerc","VERSION","LERCLoader","id","name","module","version","worker","extensions","mimeTypes","options","wms","parse","arrayBuffer","parseLERC","load","pixelBlock","decode","lerc"],"sources":["../../src/lerc-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport type {LERCData} from './lib/parsers/lerc/lerc-types';\nimport * as Lerc from 'lerc';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type LERCLoaderOptions = LoaderOptions & {\n lerc?: {\n /**\tThe number of bytes to skip in the input byte stream. A valid Lerc file is expected at that position. */\n inputOffset?: number;\n /**\tIt is recommended to use the returned mask instead of setting this value. */\n noDataValue?: number;\n /**\t(ndepth LERC2 only) If true, returned depth values are pixel-interleaved. */\n returnInterleaved?: boolean;\n };\n};\n\n/**\n * Loader for the LERC raster format\n */\nexport const LERCLoader: LoaderWithParser = {\n id: 'lerc',\n name: 'LERC',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['lrc', 'lerc', 'lerc2', 'lerc1'],\n mimeTypes: ['application/octet-stream'],\n // test: ?,\n options: {\n wms: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions) =>\n parseLERC(arrayBuffer, options)\n};\n\nasync function parseLERC(arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions): Promise<LERCData> {\n // Load the WASM library\n await Lerc.load();\n // Perform the decode\n const pixelBlock = Lerc.decode(arrayBuffer, options?.lerc);\n return pixelBlock;\n}\n"],"mappings":"AAIA,OAAO,KAAKA,IAAI,MAAM,MAAM;AAI5B,MAAMC,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAgB3E,OAAO,MAAMC,
|
|
1
|
+
{"version":3,"file":"lerc-loader.js","names":["Lerc","VERSION","LERCLoader","id","name","module","version","worker","extensions","mimeTypes","options","wms","parse","arrayBuffer","parseLERC","load","pixelBlock","decode","lerc"],"sources":["../../src/lerc-loader.ts"],"sourcesContent":["// loaders.gl, MIT license\n\nimport type {LoaderWithParser, LoaderOptions} from '@loaders.gl/loader-utils';\nimport type {LERCData} from './lib/parsers/lerc/lerc-types';\nimport * as Lerc from 'lerc';\n\n// __VERSION__ is injected by babel-plugin-version-inline\n// @ts-ignore TS2304: Cannot find name '__VERSION__'.\nconst VERSION = typeof __VERSION__ !== 'undefined' ? __VERSION__ : 'latest';\n\nexport type LERCLoaderOptions = LoaderOptions & {\n lerc?: {\n /**\tThe number of bytes to skip in the input byte stream. A valid Lerc file is expected at that position. */\n inputOffset?: number;\n /**\tIt is recommended to use the returned mask instead of setting this value. */\n noDataValue?: number;\n /**\t(ndepth LERC2 only) If true, returned depth values are pixel-interleaved. */\n returnInterleaved?: boolean;\n };\n};\n\n/**\n * Loader for the LERC raster format\n */\nexport const LERCLoader: LoaderWithParser<LERCData, never, LERCLoaderOptions> = {\n id: 'lerc',\n name: 'LERC',\n\n module: 'wms',\n version: VERSION,\n worker: false,\n extensions: ['lrc', 'lerc', 'lerc2', 'lerc1'],\n mimeTypes: ['application/octet-stream'],\n // test: ?,\n options: {\n wms: {}\n },\n parse: async (arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions) =>\n parseLERC(arrayBuffer, options)\n};\n\nasync function parseLERC(arrayBuffer: ArrayBuffer, options?: LERCLoaderOptions): Promise<LERCData> {\n // Load the WASM library\n await Lerc.load();\n // Perform the decode\n const pixelBlock = Lerc.decode(arrayBuffer, options?.lerc);\n return pixelBlock;\n}\n"],"mappings":"AAIA,OAAO,KAAKA,IAAI,MAAM,MAAM;AAI5B,MAAMC,OAAO,GAAG,uBAAkB,KAAK,WAAW,sBAAiB,QAAQ;AAgB3E,OAAO,MAAMC,UAAgE,GAAG;EAC9EC,EAAE,EAAE,MAAM;EACVC,IAAI,EAAE,MAAM;EAEZC,MAAM,EAAE,KAAK;EACbC,OAAO,EAAEL,OAAO;EAChBM,MAAM,EAAE,KAAK;EACbC,UAAU,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC;EAC7CC,SAAS,EAAE,CAAC,0BAA0B,CAAC;EAEvCC,OAAO,EAAE;IACPC,GAAG,EAAE,CAAC;EACR,CAAC;EACDC,KAAK,EAAE,MAAAA,CAAOC,WAAwB,EAAEH,OAA2B,KACjEI,SAAS,CAACD,WAAW,EAAEH,OAAO;AAClC,CAAC;AAED,eAAeI,SAASA,CAACD,WAAwB,EAAEH,OAA2B,EAAqB;EAEjG,MAAMV,IAAI,CAACe,IAAI,CAAC,CAAC;EAEjB,MAAMC,UAAU,GAAGhB,IAAI,CAACiB,MAAM,CAACJ,WAAW,EAAEH,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEQ,IAAI,CAAC;EAC1D,OAAOF,UAAU;AACnB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse-gml.js","names":["XMLLoader","deepStrictEqual","rewind","noTransform","_len","arguments","length","coords","Array","_key","parseGML","text","options","_XMLLoader$parseTextS","parsedXML","parseTextSync","call","transformCoords","stride","context","createChildContext","parseGMLToGeometry","inputXML","childContext","geometry","name","xml","getFirstKeyValue","type","coordinates","parseLinearRingOrLineString","parsePolygonOrRectangle","parseSurface","parseMultiSurface","mutate","parseCoords","s","srsDimension","replace","trim","split","Error","concat","points","i","_options$transformCoo","point","slice","map","parseFloat","push","parsePosList","textOf","parsePos","parsePoint","pos","findIn","posList","childName","childXML","Object","entries","parseCurveSegments","points2","end","start","shift","parseRing","lineString","segments","parseExteriorOrInterior","linearRing","ring","exterior","pointLists","patches","polygons","parseCompositeSurface","c2Name","c2Xml","el","surfaceMembers","polygons2","polygons3","parseSurfaceMember","polygonXML","surfaceMemberXML","childXml","root","_len2","tags","_key2","tag","child","object","key","value","srsDimensionAttribute","attributes","parseInt","Number","isNaN","create"],"sources":["../../../../../src/lib/parsers/gml/parse-gml.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n// Forked from https://github.com/derhuerst/parse-gml-polygon/blob/master/index.js\n// under ISC license\n\n/* eslint-disable no-continue, default-case */\n\nimport type {\n // GeoJSON,\n // Feature,\n // FeatureCollection,\n Geometry,\n Position\n // GeoJsonProperties,\n // Point,\n // MultiPoint,\n // LineString,\n // MultiLineString,\n // Polygon,\n // MultiPolygon,\n // GeometryCollection\n} from '@loaders.gl/schema';\n\nimport {XMLLoader} from '@loaders.gl/xml';\nimport {deepStrictEqual} from './deep-strict-equal';\nimport rewind from '@turf/rewind';\n\nfunction noTransform(...coords) {\n return coords;\n}\n\nexport type ParseGMLOptions = {\n transformCoords?: Function;\n stride?: 2 | 3 | 4;\n};\n\nexport type ParseGMLContext = {\n srsDimension?: number;\n [key: string]: any;\n};\n\n/**\n * Parses a typed data structure from raw XML for GML features\n * @note Error handlings is fairly weak\n */\nexport function parseGML(text: string, options) {\n // GeoJSON | null {\n const parsedXML = XMLLoader.parseTextSync?.(text, options);\n\n options = {transformCoords: noTransform, stride: 2, ...options};\n const context = createChildContext(parsedXML, options, {});\n\n return parseGMLToGeometry(parsedXML, options, context);\n}\n\n/** Parse a GeoJSON geometry from GML XML */\nexport function parseGMLToGeometry(\n inputXML: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Geometry | null {\n const childContext = createChildContext(inputXML, options, context);\n\n let geometry: Geometry | null = null;\n\n const [name, xml] = getFirstKeyValue(inputXML);\n\n switch (name) {\n // case 'gml:MultiPoint':\n // geometry = {\n // type: 'MultiPoint',\n // coordinates: parseMultiPoint(xml, options, childContext)\n // };\n // break;\n\n case 'gml:LineString':\n geometry = {\n type: 'LineString',\n coordinates: parseLinearRingOrLineString(xml, options, childContext)\n };\n break;\n\n // case 'gml:MultiLineString':\n // geometry = {\n // type: 'MultiLineString',\n // coordinates: parseMultiLineString(xml, options, childContext)\n // };\n // break;\n\n case 'gml:Polygon':\n case 'gml:Rectangle':\n geometry = {\n type: 'Polygon',\n coordinates: parsePolygonOrRectangle(xml, options, childContext)\n };\n break;\n case 'gml:Surface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseSurface(xml, options, childContext)\n };\n break;\n case 'gml:MultiSurface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseMultiSurface(xml, options, childContext)\n };\n break;\n\n default:\n return null;\n }\n\n // todo\n return rewind(geometry, {mutate: true});\n}\n\n/** Parse a list of coordinates from a string */\nfunction parseCoords(s: string, options: ParseGMLOptions, context: ParseGMLContext): Position[] {\n const stride = context.srsDimension || options.stride || 2;\n\n // Handle white space\n const coords = s.replace(/\\s+/g, ' ').trim().split(' ');\n\n if (coords.length === 0 || coords.length % stride !== 0) {\n throw new Error(`invalid coordinates list (stride ${stride})`);\n }\n\n const points: Position[] = [];\n for (let i = 0; i < coords.length - 1; i += stride) {\n const point = coords.slice(i, i + stride).map(parseFloat);\n points.push(options.transformCoords?.(...point) || point);\n }\n\n return points;\n}\n\nexport function parsePosList(xml: any, options: ParseGMLOptions, context: ParseGMLContext) {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:posList element');\n }\n\n return parseCoords(coords, options, childContext);\n}\n\nexport function parsePos(xml: any, options: ParseGMLOptions, context: ParseGMLContext): Position {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:pos element');\n }\n\n const points = parseCoords(coords, options, childContext);\n if (points.length !== 1) {\n throw new Error('gml:pos must have 1 point');\n }\n return points[0];\n}\n\nexport function parsePoint(xml: any, options: ParseGMLOptions, context: ParseGMLContext): number[] {\n const childContext = createChildContext(xml, options, context);\n\n // TODO AV: Parse other gml:Point options\n const pos = findIn(xml, 'gml:pos');\n if (!pos) {\n throw new Error('invalid gml:Point element, expected a gml:pos subelement');\n }\n return parsePos(pos, options, childContext);\n}\n\nexport function parseLinearRingOrLineString(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n // or a LineStringSegment\n const childContext = createChildContext(xml, options, context);\n\n let points: Position[] = [];\n\n const posList = findIn(xml, 'gml:posList');\n if (posList) {\n points = parsePosList(posList, options, childContext);\n } else {\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:Point':\n points.push(parsePoint(childXML, options, childContext));\n break;\n case 'gml:pos':\n points.push(parsePos(childXML, options, childContext));\n break;\n default:\n continue;\n }\n }\n }\n\n if (points.length === 0) {\n throw new Error(`${xml.name} must have > 0 points`);\n }\n return points;\n}\n\nexport function parseCurveSegments(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:LineStringSegment':\n const points2 = parseLinearRingOrLineString(childXML, options, context);\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n break;\n default:\n continue;\n }\n }\n\n if (points.length === 0) {\n throw new Error('gml:Curve > gml:segments must have > 0 points');\n }\n return points;\n}\n\nexport function parseRing(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const childContext = createChildContext(xml, options, context);\n\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:curveMember':\n let points2;\n\n const lineString = findIn(childXML, 'gml:LineString');\n if (lineString) {\n points2 = parseLinearRingOrLineString(lineString, options, childContext);\n } else {\n const segments = findIn(childXML, 'gml:Curve', 'gml:segments');\n if (!segments) {\n throw new Error(`invalid ${childName} element`);\n }\n\n points2 = parseCurveSegments(segments, options, childContext);\n }\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n\n break;\n }\n }\n\n if (points.length < 4) {\n throw new Error(`${xml.name} must have >= 4 points`);\n }\n return points;\n}\n\nexport function parseExteriorOrInterior(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const linearRing = findIn(xml, 'gml:LinearRing');\n if (linearRing) {\n return parseLinearRingOrLineString(linearRing, options, context);\n }\n\n const ring = findIn(xml, 'gml:Ring');\n if (!ring) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n return parseRing(ring, options, context);\n}\n\nexport function parsePolygonOrRectangle(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][] {\n // or PolygonPatch\n const childContext = createChildContext(xml, options, context);\n\n const exterior = findIn(xml, 'gml:exterior');\n if (!exterior) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const pointLists: Position[][] = [parseExteriorOrInterior(exterior, options, childContext)];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:interior':\n pointLists.push(parseExteriorOrInterior(childXML, options, childContext));\n break;\n }\n }\n\n return pointLists;\n}\n\nexport function parseSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const patches = findIn(xml, 'gml:patches');\n if (!patches) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:PolygonPatch':\n case 'gml:Rectangle':\n polygons.push(parsePolygonOrRectangle(childXML, options, childContext));\n break;\n\n default:\n continue;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nexport function parseCompositeSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:surfaceMember':\n case 'gml:surfaceMembers':\n const [c2Name, c2Xml] = getFirstKeyValue(childXML);\n switch (c2Name) {\n case 'gml:Surface':\n polygons.push(...parseSurface(c2Xml, options, childContext));\n break;\n case 'gml:Polygon':\n polygons.push(parsePolygonOrRectangle(c2Xml, options, childContext));\n break;\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n return polygons;\n}\n\nexport function parseMultiSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n let el = xml;\n\n const surfaceMembers = findIn(xml, 'gml:LinearRing');\n if (surfaceMembers) {\n el = surfaceMembers;\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(el)) {\n switch (childName) {\n case 'gml:Surface':\n const polygons2 = parseSurface(childXML, options, context);\n polygons.push(...polygons2);\n break;\n case 'gml:surfaceMember':\n const polygons3 = parseSurfaceMember(childXML, options, context);\n polygons.push(...polygons3);\n break;\n\n case 'gml:surfaceMembers':\n const polygonXML = findIn(childXML, 'gml:Polygon');\n for (const surfaceMemberXML of polygonXML as []) {\n const polygons3 = parseSurfaceMember(surfaceMemberXML, options, context);\n polygons.push(...polygons3);\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nfunction parseSurfaceMember(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const [childName, childXml] = getFirstKeyValue(xml);\n switch (childName) {\n case 'gml:CompositeSurface':\n return parseCompositeSurface(childXml, options, context);\n case 'gml:Surface':\n return parseSurface(childXml, options, context);\n case 'gml:Polygon':\n return [parsePolygonOrRectangle(childXml, options, context)];\n }\n throw new Error(`${childName} must have polygons`);\n}\n\n// Helpers\n\nfunction textOf(el: any): string {\n if (typeof el !== 'string') {\n throw new Error('expected string');\n }\n return el;\n}\n\nfunction findIn(root: any, ...tags: string[]): any {\n let el = root;\n for (const tag of tags) {\n const child = el[tag];\n if (!child) {\n return null;\n }\n el = child;\n }\n return el;\n}\n\n/** @returns the first [key, value] pair in an object, or ['', null] if empty object */\nfunction getFirstKeyValue(object: any): [string, any] {\n if (object && typeof object === 'object') {\n for (const [key, value] of Object.entries(object)) {\n return [key, value];\n }\n }\n return ['', null];\n}\n\n/** A bit heavyweight for just tracking dimension? */\nfunction createChildContext(xml, options, context): ParseGMLContext {\n const srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;\n\n if (srsDimensionAttribute) {\n const srsDimension = parseInt(srsDimensionAttribute);\n if (Number.isNaN(srsDimension) || srsDimension <= 0) {\n throw new Error(\n `invalid srsDimension attribute value \"${srsDimensionAttribute}\", expected a positive integer`\n );\n }\n\n const childContext = Object.create(context);\n childContext.srsDimension = srsDimension;\n return childContext;\n }\n\n return context;\n}\n"],"mappings":"AAuBA,SAAQA,SAAS,QAAO,iBAAiB;AACzC,SAAQC,eAAe,QAAO,qBAAqB;AACnD,OAAOC,MAAM,MAAM,cAAc;AAEjC,SAASC,WAAWA,CAAA,EAAY;EAAA,SAAAC,IAAA,GAAAC,SAAA,CAAAC,MAAA,EAARC,MAAM,OAAAC,KAAA,CAAAJ,IAAA,GAAAK,IAAA,MAAAA,IAAA,GAAAL,IAAA,EAAAK,IAAA;IAANF,MAAM,CAAAE,IAAA,IAAAJ,SAAA,CAAAI,IAAA;EAAA;EAC5B,OAAOF,MAAM;AACf;AAgBA,OAAO,SAASG,QAAQA,CAACC,IAAY,EAAEC,OAAO,EAAE;EAAA,IAAAC,qBAAA;EAE9C,MAAMC,SAAS,IAAAD,qBAAA,GAAGb,SAAS,CAACe,aAAa,cAAAF,qBAAA,uBAAvBA,qBAAA,CAAAG,IAAA,CAAAhB,SAAS,EAAiBW,IAAI,EAAEC,OAAO,CAAC;EAE1DA,OAAO,GAAG;IAACK,eAAe,EAAEd,WAAW;IAAEe,MAAM,EAAE,CAAC;IAAE,GAAGN;EAAO,CAAC;EAC/D,MAAMO,OAAO,GAAGC,kBAAkB,CAACN,SAAS,EAAEF,OAAO,EAAE,CAAC,CAAC,CAAC;EAE1D,OAAOS,kBAAkB,CAACP,SAAS,EAAEF,OAAO,EAAEO,OAAO,CAAC;AACxD;AAGA,OAAO,SAASE,kBAAkBA,CAChCC,QAAa,EACbV,OAAwB,EACxBO,OAAwB,EACP;EACjB,MAAMI,YAAY,GAAGH,kBAAkB,CAACE,QAAQ,EAAEV,OAAO,EAAEO,OAAO,CAAC;EAEnE,IAAIK,QAAyB,GAAG,IAAI;EAEpC,MAAM,CAACC,IAAI,EAAEC,GAAG,CAAC,GAAGC,gBAAgB,CAACL,QAAQ,CAAC;EAE9C,QAAQG,IAAI;IAQV,KAAK,gBAAgB;MACnBD,QAAQ,GAAG;QACTI,IAAI,EAAE,YAAY;QAClBC,WAAW,EAAEC,2BAA2B,CAACJ,GAAG,EAAEd,OAAO,EAAEW,YAAY;MACrE,CAAC;MACD;IASF,KAAK,aAAa;IAClB,KAAK,eAAe;MAClBC,QAAQ,GAAG;QACTI,IAAI,EAAE,SAAS;QACfC,WAAW,EAAEE,uBAAuB,CAACL,GAAG,EAAEd,OAAO,EAAEW,YAAY;MACjE,CAAC;MACD;IACF,KAAK,aAAa;MAChBC,QAAQ,GAAG;QACTI,IAAI,EAAE,cAAc;QACpBC,WAAW,EAAEG,YAAY,CAACN,GAAG,EAAEd,OAAO,EAAEW,YAAY;MACtD,CAAC;MACD;IACF,KAAK,kBAAkB;MACrBC,QAAQ,GAAG;QACTI,IAAI,EAAE,cAAc;QACpBC,WAAW,EAAEI,iBAAiB,CAACP,GAAG,EAAEd,OAAO,EAAEW,YAAY;MAC3D,CAAC;MACD;IAEF;MACE,OAAO,IAAI;EACf;EAGA,OAAOrB,MAAM,CAACsB,QAAQ,EAAE;IAACU,MAAM,EAAE;EAAI,CAAC,CAAC;AACzC;AAGA,SAASC,WAAWA,CAACC,CAAS,EAAExB,OAAwB,EAAEO,OAAwB,EAAc;EAC9F,MAAMD,MAAM,GAAGC,OAAO,CAACkB,YAAY,IAAIzB,OAAO,CAACM,MAAM,IAAI,CAAC;EAG1D,MAAMX,MAAM,GAAG6B,CAAC,CAACE,OAAO,CAAC,MAAM,EAAE,GAAG,CAAC,CAACC,IAAI,CAAC,CAAC,CAACC,KAAK,CAAC,GAAG,CAAC;EAEvD,IAAIjC,MAAM,CAACD,MAAM,KAAK,CAAC,IAAIC,MAAM,CAACD,MAAM,GAAGY,MAAM,KAAK,CAAC,EAAE;IACvD,MAAM,IAAIuB,KAAK,qCAAAC,MAAA,CAAqCxB,MAAM,MAAG,CAAC;EAChE;EAEA,MAAMyB,MAAkB,GAAG,EAAE;EAC7B,KAAK,IAAIC,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGrC,MAAM,CAACD,MAAM,GAAG,CAAC,EAAEsC,CAAC,IAAI1B,MAAM,EAAE;IAAA,IAAA2B,qBAAA;IAClD,MAAMC,KAAK,GAAGvC,MAAM,CAACwC,KAAK,CAACH,CAAC,EAAEA,CAAC,GAAG1B,MAAM,CAAC,CAAC8B,GAAG,CAACC,UAAU,CAAC;IACzDN,MAAM,CAACO,IAAI,CAAC,EAAAL,qBAAA,GAAAjC,OAAO,CAACK,eAAe,cAAA4B,qBAAA,uBAAvBA,qBAAA,CAAA7B,IAAA,CAAAJ,OAAO,EAAmB,GAAGkC,KAAK,CAAC,KAAIA,KAAK,CAAC;EAC3D;EAEA,OAAOH,MAAM;AACf;AAEA,OAAO,SAASQ,YAAYA,CAACzB,GAAQ,EAAEd,OAAwB,EAAEO,OAAwB,EAAE;EACzF,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAE9D,MAAMZ,MAAM,GAAG6C,MAAM,CAAC1B,GAAG,CAAC;EAC1B,IAAI,CAACnB,MAAM,EAAE;IACX,MAAM,IAAIkC,KAAK,CAAC,6BAA6B,CAAC;EAChD;EAEA,OAAON,WAAW,CAAC5B,MAAM,EAAEK,OAAO,EAAEW,YAAY,CAAC;AACnD;AAEA,OAAO,SAAS8B,QAAQA,CAAC3B,GAAQ,EAAEd,OAAwB,EAAEO,OAAwB,EAAY;EAC/F,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAE9D,MAAMZ,MAAM,GAAG6C,MAAM,CAAC1B,GAAG,CAAC;EAC1B,IAAI,CAACnB,MAAM,EAAE;IACX,MAAM,IAAIkC,KAAK,CAAC,yBAAyB,CAAC;EAC5C;EAEA,MAAME,MAAM,GAAGR,WAAW,CAAC5B,MAAM,EAAEK,OAAO,EAAEW,YAAY,CAAC;EACzD,IAAIoB,MAAM,CAACrC,MAAM,KAAK,CAAC,EAAE;IACvB,MAAM,IAAImC,KAAK,CAAC,2BAA2B,CAAC;EAC9C;EACA,OAAOE,MAAM,CAAC,CAAC,CAAC;AAClB;AAEA,OAAO,SAASW,UAAUA,CAAC5B,GAAQ,EAAEd,OAAwB,EAAEO,OAAwB,EAAY;EACjG,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAG9D,MAAMoC,GAAG,GAAGC,MAAM,CAAC9B,GAAG,EAAE,SAAS,CAAC;EAClC,IAAI,CAAC6B,GAAG,EAAE;IACR,MAAM,IAAId,KAAK,CAAC,0DAA0D,CAAC;EAC7E;EACA,OAAOY,QAAQ,CAACE,GAAG,EAAE3C,OAAO,EAAEW,YAAY,CAAC;AAC7C;AAEA,OAAO,SAASO,2BAA2BA,CACzCJ,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACZ;EAEZ,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAE9D,IAAIwB,MAAkB,GAAG,EAAE;EAE3B,MAAMc,OAAO,GAAGD,MAAM,CAAC9B,GAAG,EAAE,aAAa,CAAC;EAC1C,IAAI+B,OAAO,EAAE;IACXd,MAAM,GAAGQ,YAAY,CAACM,OAAO,EAAE7C,OAAO,EAAEW,YAAY,CAAC;EACvD,CAAC,MAAM;IACL,KAAK,MAAM,CAACmC,SAAS,EAAEC,QAAQ,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACnC,GAAG,CAAC,EAAE;MACvD,QAAQgC,SAAS;QACf,KAAK,WAAW;UACdf,MAAM,CAACO,IAAI,CAACI,UAAU,CAACK,QAAQ,EAAE/C,OAAO,EAAEW,YAAY,CAAC,CAAC;UACxD;QACF,KAAK,SAAS;UACZoB,MAAM,CAACO,IAAI,CAACG,QAAQ,CAACM,QAAQ,EAAE/C,OAAO,EAAEW,YAAY,CAAC,CAAC;UACtD;QACF;UACE;MACJ;IACF;EACF;EAEA,IAAIoB,MAAM,CAACrC,MAAM,KAAK,CAAC,EAAE;IACvB,MAAM,IAAImC,KAAK,IAAAC,MAAA,CAAIhB,GAAG,CAACD,IAAI,0BAAuB,CAAC;EACrD;EACA,OAAOkB,MAAM;AACf;AAEA,OAAO,SAASmB,kBAAkBA,CAChCpC,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACZ;EACZ,MAAMwB,MAAkB,GAAG,EAAE;EAE7B,KAAK,MAAM,CAACe,SAAS,EAAEC,QAAQ,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACnC,GAAG,CAAC,EAAE;IACvD,QAAQgC,SAAS;MACf,KAAK,uBAAuB;QAC1B,MAAMK,OAAO,GAAGjC,2BAA2B,CAAC6B,QAAQ,EAAE/C,OAAO,EAAEO,OAAO,CAAC;QAGvE,MAAM6C,GAAG,GAAGrB,MAAM,CAACA,MAAM,CAACrC,MAAM,GAAG,CAAC,CAAC;QACrC,MAAM2D,KAAK,GAAGF,OAAO,CAAC,CAAC,CAAC;QACxB,IAAIC,GAAG,IAAIC,KAAK,IAAIhE,eAAe,CAAC+D,GAAG,EAAEC,KAAK,CAAC,EAAE;UAC/CF,OAAO,CAACG,KAAK,CAAC,CAAC;QACjB;QAEAvB,MAAM,CAACO,IAAI,CAAC,GAAGa,OAAO,CAAC;QACvB;MACF;QACE;IACJ;EACF;EAEA,IAAIpB,MAAM,CAACrC,MAAM,KAAK,CAAC,EAAE;IACvB,MAAM,IAAImC,KAAK,CAAC,+CAA+C,CAAC;EAClE;EACA,OAAOE,MAAM;AACf;AAEA,OAAO,SAASwB,SAASA,CACvBzC,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACZ;EACZ,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAE9D,MAAMwB,MAAkB,GAAG,EAAE;EAE7B,KAAK,MAAM,CAACe,SAAS,EAAEC,QAAQ,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACnC,GAAG,CAAC,EAAE;IACvD,QAAQgC,SAAS;MACf,KAAK,iBAAiB;QACpB,IAAIK,OAAO;QAEX,MAAMK,UAAU,GAAGZ,MAAM,CAACG,QAAQ,EAAE,gBAAgB,CAAC;QACrD,IAAIS,UAAU,EAAE;UACdL,OAAO,GAAGjC,2BAA2B,CAACsC,UAAU,EAAExD,OAAO,EAAEW,YAAY,CAAC;QAC1E,CAAC,MAAM;UACL,MAAM8C,QAAQ,GAAGb,MAAM,CAACG,QAAQ,EAAE,WAAW,EAAE,cAAc,CAAC;UAC9D,IAAI,CAACU,QAAQ,EAAE;YACb,MAAM,IAAI5B,KAAK,YAAAC,MAAA,CAAYgB,SAAS,aAAU,CAAC;UACjD;UAEAK,OAAO,GAAGD,kBAAkB,CAACO,QAAQ,EAAEzD,OAAO,EAAEW,YAAY,CAAC;QAC/D;QAGA,MAAMyC,GAAG,GAAGrB,MAAM,CAACA,MAAM,CAACrC,MAAM,GAAG,CAAC,CAAC;QACrC,MAAM2D,KAAK,GAAGF,OAAO,CAAC,CAAC,CAAC;QACxB,IAAIC,GAAG,IAAIC,KAAK,IAAIhE,eAAe,CAAC+D,GAAG,EAAEC,KAAK,CAAC,EAAE;UAC/CF,OAAO,CAACG,KAAK,CAAC,CAAC;QACjB;QAEAvB,MAAM,CAACO,IAAI,CAAC,GAAGa,OAAO,CAAC;QAEvB;IACJ;EACF;EAEA,IAAIpB,MAAM,CAACrC,MAAM,GAAG,CAAC,EAAE;IACrB,MAAM,IAAImC,KAAK,IAAAC,MAAA,CAAIhB,GAAG,CAACD,IAAI,2BAAwB,CAAC;EACtD;EACA,OAAOkB,MAAM;AACf;AAEA,OAAO,SAAS2B,uBAAuBA,CACrC5C,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACZ;EACZ,MAAMoD,UAAU,GAAGf,MAAM,CAAC9B,GAAG,EAAE,gBAAgB,CAAC;EAChD,IAAI6C,UAAU,EAAE;IACd,OAAOzC,2BAA2B,CAACyC,UAAU,EAAE3D,OAAO,EAAEO,OAAO,CAAC;EAClE;EAEA,MAAMqD,IAAI,GAAGhB,MAAM,CAAC9B,GAAG,EAAE,UAAU,CAAC;EACpC,IAAI,CAAC8C,IAAI,EAAE;IACT,MAAM,IAAI/B,KAAK,YAAAC,MAAA,CAAYhB,GAAG,CAACD,IAAI,aAAU,CAAC;EAChD;EAEA,OAAO0C,SAAS,CAACK,IAAI,EAAE5D,OAAO,EAAEO,OAAO,CAAC;AAC1C;AAEA,OAAO,SAASY,uBAAuBA,CACrCL,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACV;EAEd,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAE9D,MAAMsD,QAAQ,GAAGjB,MAAM,CAAC9B,GAAG,EAAE,cAAc,CAAC;EAC5C,IAAI,CAAC+C,QAAQ,EAAE;IACb,MAAM,IAAIhC,KAAK,YAAAC,MAAA,CAAYhB,GAAG,CAACD,IAAI,aAAU,CAAC;EAChD;EAEA,MAAMiD,UAAwB,GAAG,CAACJ,uBAAuB,CAACG,QAAQ,EAAE7D,OAAO,EAAEW,YAAY,CAAC,CAAC;EAE3F,KAAK,MAAM,CAACmC,SAAS,EAAEC,QAAQ,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACnC,GAAG,CAAC,EAAE;IACvD,QAAQgC,SAAS;MACf,KAAK,cAAc;QACjBgB,UAAU,CAACxB,IAAI,CAACoB,uBAAuB,CAACX,QAAQ,EAAE/C,OAAO,EAAEW,YAAY,CAAC,CAAC;QACzE;IACJ;EACF;EAEA,OAAOmD,UAAU;AACnB;AAEA,OAAO,SAAS1C,YAAYA,CAC1BN,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACR;EAChB,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAE9D,MAAMwD,OAAO,GAAGnB,MAAM,CAAC9B,GAAG,EAAE,aAAa,CAAC;EAC1C,IAAI,CAACiD,OAAO,EAAE;IACZ,MAAM,IAAIlC,KAAK,YAAAC,MAAA,CAAYhB,GAAG,CAACD,IAAI,aAAU,CAAC;EAChD;EAEA,MAAMmD,QAAwB,GAAG,EAAE;EACnC,KAAK,MAAM,CAAClB,SAAS,EAAEC,QAAQ,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACnC,GAAG,CAAC,EAAE;IACvD,QAAQgC,SAAS;MACf,KAAK,kBAAkB;MACvB,KAAK,eAAe;QAClBkB,QAAQ,CAAC1B,IAAI,CAACnB,uBAAuB,CAAC4B,QAAQ,EAAE/C,OAAO,EAAEW,YAAY,CAAC,CAAC;QACvE;MAEF;QACE;IACJ;EACF;EAEA,IAAIqD,QAAQ,CAACtE,MAAM,KAAK,CAAC,EAAE;IACzB,MAAM,IAAImC,KAAK,IAAAC,MAAA,CAAIhB,GAAG,CAACD,IAAI,4BAAyB,CAAC;EACvD;EAEA,OAAOmD,QAAQ;AACjB;AAEA,OAAO,SAASC,qBAAqBA,CACnCnD,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACR;EAChB,MAAMI,YAAY,GAAGH,kBAAkB,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,CAAC;EAE9D,MAAMyD,QAAwB,GAAG,EAAE;EACnC,KAAK,MAAM,CAAClB,SAAS,EAAEC,QAAQ,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACnC,GAAG,CAAC,EAAE;IACvD,QAAQgC,SAAS;MACf,KAAK,mBAAmB;MACxB,KAAK,oBAAoB;QACvB,MAAM,CAACoB,MAAM,EAAEC,KAAK,CAAC,GAAGpD,gBAAgB,CAACgC,QAAQ,CAAC;QAClD,QAAQmB,MAAM;UACZ,KAAK,aAAa;YAChBF,QAAQ,CAAC1B,IAAI,CAAC,GAAGlB,YAAY,CAAC+C,KAAK,EAAEnE,OAAO,EAAEW,YAAY,CAAC,CAAC;YAC5D;UACF,KAAK,aAAa;YAChBqD,QAAQ,CAAC1B,IAAI,CAACnB,uBAAuB,CAACgD,KAAK,EAAEnE,OAAO,EAAEW,YAAY,CAAC,CAAC;YACpE;QACJ;QACA;IACJ;EACF;EAEA,IAAIqD,QAAQ,CAACtE,MAAM,KAAK,CAAC,EAAE;IACzB,MAAM,IAAImC,KAAK,IAAAC,MAAA,CAAIhB,GAAG,CAACD,IAAI,4BAAyB,CAAC;EACvD;EACA,OAAOmD,QAAQ;AACjB;AAEA,OAAO,SAAS3C,iBAAiBA,CAC/BP,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACR;EAChB,IAAI6D,EAAE,GAAGtD,GAAG;EAEZ,MAAMuD,cAAc,GAAGzB,MAAM,CAAC9B,GAAG,EAAE,gBAAgB,CAAC;EACpD,IAAIuD,cAAc,EAAE;IAClBD,EAAE,GAAGC,cAAc;EACrB;EAEA,MAAML,QAAwB,GAAG,EAAE;EACnC,KAAK,MAAM,CAAClB,SAAS,EAAEC,QAAQ,CAAC,IAAIC,MAAM,CAACC,OAAO,CAACmB,EAAE,CAAC,EAAE;IACtD,QAAQtB,SAAS;MACf,KAAK,aAAa;QAChB,MAAMwB,SAAS,GAAGlD,YAAY,CAAC2B,QAAQ,EAAE/C,OAAO,EAAEO,OAAO,CAAC;QAC1DyD,QAAQ,CAAC1B,IAAI,CAAC,GAAGgC,SAAS,CAAC;QAC3B;MACF,KAAK,mBAAmB;QACtB,MAAMC,SAAS,GAAGC,kBAAkB,CAACzB,QAAQ,EAAE/C,OAAO,EAAEO,OAAO,CAAC;QAChEyD,QAAQ,CAAC1B,IAAI,CAAC,GAAGiC,SAAS,CAAC;QAC3B;MAEF,KAAK,oBAAoB;QACvB,MAAME,UAAU,GAAG7B,MAAM,CAACG,QAAQ,EAAE,aAAa,CAAC;QAClD,KAAK,MAAM2B,gBAAgB,IAAID,UAAU,EAAQ;UAC/C,MAAMF,SAAS,GAAGC,kBAAkB,CAACE,gBAAgB,EAAE1E,OAAO,EAAEO,OAAO,CAAC;UACxEyD,QAAQ,CAAC1B,IAAI,CAAC,GAAGiC,SAAS,CAAC;QAC7B;QACA;IACJ;EACF;EAEA,IAAIP,QAAQ,CAACtE,MAAM,KAAK,CAAC,EAAE;IACzB,MAAM,IAAImC,KAAK,IAAAC,MAAA,CAAIhB,GAAG,CAACD,IAAI,4BAAyB,CAAC;EACvD;EAEA,OAAOmD,QAAQ;AACjB;AAEA,SAASQ,kBAAkBA,CACzB1D,GAAQ,EACRd,OAAwB,EACxBO,OAAwB,EACR;EAChB,MAAM,CAACuC,SAAS,EAAE6B,QAAQ,CAAC,GAAG5D,gBAAgB,CAACD,GAAG,CAAC;EACnD,QAAQgC,SAAS;IACf,KAAK,sBAAsB;MACzB,OAAOmB,qBAAqB,CAACU,QAAQ,EAAE3E,OAAO,EAAEO,OAAO,CAAC;IAC1D,KAAK,aAAa;MAChB,OAAOa,YAAY,CAACuD,QAAQ,EAAE3E,OAAO,EAAEO,OAAO,CAAC;IACjD,KAAK,aAAa;MAChB,OAAO,CAACY,uBAAuB,CAACwD,QAAQ,EAAE3E,OAAO,EAAEO,OAAO,CAAC,CAAC;EAChE;EACA,MAAM,IAAIsB,KAAK,IAAAC,MAAA,CAAIgB,SAAS,wBAAqB,CAAC;AACpD;AAIA,SAASN,MAAMA,CAAC4B,EAAO,EAAU;EAC/B,IAAI,OAAOA,EAAE,KAAK,QAAQ,EAAE;IAC1B,MAAM,IAAIvC,KAAK,CAAC,iBAAiB,CAAC;EACpC;EACA,OAAOuC,EAAE;AACX;AAEA,SAASxB,MAAMA,CAACgC,IAAS,EAA0B;EACjD,IAAIR,EAAE,GAAGQ,IAAI;EAAC,SAAAC,KAAA,GAAApF,SAAA,CAAAC,MAAA,EADcoF,IAAI,OAAAlF,KAAA,CAAAiF,KAAA,OAAAA,KAAA,WAAAE,KAAA,MAAAA,KAAA,GAAAF,KAAA,EAAAE,KAAA;IAAJD,IAAI,CAAAC,KAAA,QAAAtF,SAAA,CAAAsF,KAAA;EAAA;EAEhC,KAAK,MAAMC,GAAG,IAAIF,IAAI,EAAE;IACtB,MAAMG,KAAK,GAAGb,EAAE,CAACY,GAAG,CAAC;IACrB,IAAI,CAACC,KAAK,EAAE;MACV,OAAO,IAAI;IACb;IACAb,EAAE,GAAGa,KAAK;EACZ;EACA,OAAOb,EAAE;AACX;AAGA,SAASrD,gBAAgBA,CAACmE,MAAW,EAAiB;EACpD,IAAIA,MAAM,IAAI,OAAOA,MAAM,KAAK,QAAQ,EAAE;IACxC,KAAK,MAAM,CAACC,GAAG,EAAEC,KAAK,CAAC,IAAIpC,MAAM,CAACC,OAAO,CAACiC,MAAM,CAAC,EAAE;MACjD,OAAO,CAACC,GAAG,EAAEC,KAAK,CAAC;IACrB;EACF;EACA,OAAO,CAAC,EAAE,EAAE,IAAI,CAAC;AACnB;AAGA,SAAS5E,kBAAkBA,CAACM,GAAG,EAAEd,OAAO,EAAEO,OAAO,EAAmB;EAClE,MAAM8E,qBAAqB,GAAGvE,GAAG,CAACwE,UAAU,IAAIxE,GAAG,CAACwE,UAAU,CAAC7D,YAAY;EAE3E,IAAI4D,qBAAqB,EAAE;IACzB,MAAM5D,YAAY,GAAG8D,QAAQ,CAACF,qBAAqB,CAAC;IACpD,IAAIG,MAAM,CAACC,KAAK,CAAChE,YAAY,CAAC,IAAIA,YAAY,IAAI,CAAC,EAAE;MACnD,MAAM,IAAII,KAAK,2CAAAC,MAAA,CAC4BuD,qBAAqB,oCAChE,CAAC;IACH;IAEA,MAAM1E,YAAY,GAAGqC,MAAM,CAAC0C,MAAM,CAACnF,OAAO,CAAC;IAC3CI,YAAY,CAACc,YAAY,GAAGA,YAAY;IACxC,OAAOd,YAAY;EACrB;EAEA,OAAOJ,OAAO;AAChB"}
|
|
1
|
+
{"version":3,"file":"parse-gml.js","names":["XMLLoader","deepStrictEqual","rewind","noTransform","_len","arguments","length","coords","Array","_key","parseGML","text","options","_XMLLoader$parseTextS","parsedXML","parseTextSync","call","transformCoords","stride","context","createChildContext","parseGMLToGeometry","inputXML","childContext","geometry","name","xml","getFirstKeyValue","type","coordinates","parseLinearRingOrLineString","parsePolygonOrRectangle","parseSurface","parseMultiSurface","mutate","parseCoords","s","srsDimension","replace","trim","split","Error","concat","points","i","_options$transformCoo","point","slice","map","parseFloat","push","parsePosList","textOf","parsePos","parsePoint","pos","findIn","posList","childName","childXML","Object","entries","parseCurveSegments","points2","end","start","shift","parseRing","lineString","segments","parseExteriorOrInterior","linearRing","ring","exterior","pointLists","patches","polygons","parseCompositeSurface","c2Name","c2Xml","el","surfaceMembers","polygons2","polygons3","parseSurfaceMember","polygonXML","surfaceMemberXML","childXml","root","_len2","tags","_key2","tag","child","object","key","value","srsDimensionAttribute","attributes","parseInt","Number","isNaN","create"],"sources":["../../../../../src/lib/parsers/gml/parse-gml.ts"],"sourcesContent":["// loaders.gl, MIT license\n\n// Forked from https://github.com/derhuerst/parse-gml-polygon/blob/master/index.js\n// under ISC license\n\n/* eslint-disable no-continue, default-case */\n\nimport type {\n // GeoJSON,\n // Feature,\n // FeatureCollection,\n Geometry,\n Position\n // GeoJsonProperties,\n // Point,\n // MultiPoint,\n // LineString,\n // MultiLineString,\n // Polygon,\n // MultiPolygon,\n // GeometryCollection\n} from '@loaders.gl/schema';\n\nimport {XMLLoader} from '@loaders.gl/xml';\nimport {deepStrictEqual} from './deep-strict-equal';\nimport rewind from '@turf/rewind';\n\nfunction noTransform(...coords) {\n return coords;\n}\n\nexport type {Geometry};\n\nexport type ParseGMLOptions = {\n transformCoords?: Function;\n stride?: 2 | 3 | 4;\n};\n\nexport type ParseGMLContext = {\n srsDimension?: number;\n [key: string]: any;\n};\n\n/**\n * Parses a typed data structure from raw XML for GML features\n * @note Error handlings is fairly weak\n */\nexport function parseGML(text: string, options) {\n // GeoJSON | null {\n const parsedXML = XMLLoader.parseTextSync?.(text, options);\n\n options = {transformCoords: noTransform, stride: 2, ...options};\n const context = createChildContext(parsedXML, options, {});\n\n return parseGMLToGeometry(parsedXML, options, context);\n}\n\n/** Parse a GeoJSON geometry from GML XML */\nexport function parseGMLToGeometry(\n inputXML: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Geometry | null {\n const childContext = createChildContext(inputXML, options, context);\n\n let geometry: Geometry | null = null;\n\n const [name, xml] = getFirstKeyValue(inputXML);\n\n switch (name) {\n // case 'gml:MultiPoint':\n // geometry = {\n // type: 'MultiPoint',\n // coordinates: parseMultiPoint(xml, options, childContext)\n // };\n // break;\n\n case 'gml:LineString':\n geometry = {\n type: 'LineString',\n coordinates: parseLinearRingOrLineString(xml, options, childContext)\n };\n break;\n\n // case 'gml:MultiLineString':\n // geometry = {\n // type: 'MultiLineString',\n // coordinates: parseMultiLineString(xml, options, childContext)\n // };\n // break;\n\n case 'gml:Polygon':\n case 'gml:Rectangle':\n geometry = {\n type: 'Polygon',\n coordinates: parsePolygonOrRectangle(xml, options, childContext)\n };\n break;\n case 'gml:Surface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseSurface(xml, options, childContext)\n };\n break;\n case 'gml:MultiSurface':\n geometry = {\n type: 'MultiPolygon',\n coordinates: parseMultiSurface(xml, options, childContext)\n };\n break;\n\n default:\n return null;\n }\n\n // todo\n return rewind(geometry, {mutate: true});\n}\n\n/** Parse a list of coordinates from a string */\nfunction parseCoords(s: string, options: ParseGMLOptions, context: ParseGMLContext): Position[] {\n const stride = context.srsDimension || options.stride || 2;\n\n // Handle white space\n const coords = s.replace(/\\s+/g, ' ').trim().split(' ');\n\n if (coords.length === 0 || coords.length % stride !== 0) {\n throw new Error(`invalid coordinates list (stride ${stride})`);\n }\n\n const points: Position[] = [];\n for (let i = 0; i < coords.length - 1; i += stride) {\n const point = coords.slice(i, i + stride).map(parseFloat);\n points.push(options.transformCoords?.(...point) || point);\n }\n\n return points;\n}\n\nexport function parsePosList(xml: any, options: ParseGMLOptions, context: ParseGMLContext) {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:posList element');\n }\n\n return parseCoords(coords, options, childContext);\n}\n\nexport function parsePos(xml: any, options: ParseGMLOptions, context: ParseGMLContext): Position {\n const childContext = createChildContext(xml, options, context);\n\n const coords = textOf(xml);\n if (!coords) {\n throw new Error('invalid gml:pos element');\n }\n\n const points = parseCoords(coords, options, childContext);\n if (points.length !== 1) {\n throw new Error('gml:pos must have 1 point');\n }\n return points[0];\n}\n\nexport function parsePoint(xml: any, options: ParseGMLOptions, context: ParseGMLContext): number[] {\n const childContext = createChildContext(xml, options, context);\n\n // TODO AV: Parse other gml:Point options\n const pos = findIn(xml, 'gml:pos');\n if (!pos) {\n throw new Error('invalid gml:Point element, expected a gml:pos subelement');\n }\n return parsePos(pos, options, childContext);\n}\n\nexport function parseLinearRingOrLineString(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n // or a LineStringSegment\n const childContext = createChildContext(xml, options, context);\n\n let points: Position[] = [];\n\n const posList = findIn(xml, 'gml:posList');\n if (posList) {\n points = parsePosList(posList, options, childContext);\n } else {\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:Point':\n points.push(parsePoint(childXML, options, childContext));\n break;\n case 'gml:pos':\n points.push(parsePos(childXML, options, childContext));\n break;\n default:\n continue;\n }\n }\n }\n\n if (points.length === 0) {\n throw new Error(`${xml.name} must have > 0 points`);\n }\n return points;\n}\n\nexport function parseCurveSegments(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:LineStringSegment':\n const points2 = parseLinearRingOrLineString(childXML, options, context);\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n break;\n default:\n continue;\n }\n }\n\n if (points.length === 0) {\n throw new Error('gml:Curve > gml:segments must have > 0 points');\n }\n return points;\n}\n\nexport function parseRing(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const childContext = createChildContext(xml, options, context);\n\n const points: Position[] = [];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:curveMember':\n let points2;\n\n const lineString = findIn(childXML, 'gml:LineString');\n if (lineString) {\n points2 = parseLinearRingOrLineString(lineString, options, childContext);\n } else {\n const segments = findIn(childXML, 'gml:Curve', 'gml:segments');\n if (!segments) {\n throw new Error(`invalid ${childName} element`);\n }\n\n points2 = parseCurveSegments(segments, options, childContext);\n }\n\n // remove overlapping\n const end = points[points.length - 1];\n const start = points2[0];\n if (end && start && deepStrictEqual(end, start)) {\n points2.shift();\n }\n\n points.push(...points2);\n\n break;\n }\n }\n\n if (points.length < 4) {\n throw new Error(`${xml.name} must have >= 4 points`);\n }\n return points;\n}\n\nexport function parseExteriorOrInterior(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[] {\n const linearRing = findIn(xml, 'gml:LinearRing');\n if (linearRing) {\n return parseLinearRingOrLineString(linearRing, options, context);\n }\n\n const ring = findIn(xml, 'gml:Ring');\n if (!ring) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n return parseRing(ring, options, context);\n}\n\nexport function parsePolygonOrRectangle(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][] {\n // or PolygonPatch\n const childContext = createChildContext(xml, options, context);\n\n const exterior = findIn(xml, 'gml:exterior');\n if (!exterior) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const pointLists: Position[][] = [parseExteriorOrInterior(exterior, options, childContext)];\n\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:interior':\n pointLists.push(parseExteriorOrInterior(childXML, options, childContext));\n break;\n }\n }\n\n return pointLists;\n}\n\nexport function parseSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const patches = findIn(xml, 'gml:patches');\n if (!patches) {\n throw new Error(`invalid ${xml.name} element`);\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:PolygonPatch':\n case 'gml:Rectangle':\n polygons.push(parsePolygonOrRectangle(childXML, options, childContext));\n break;\n\n default:\n continue;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nexport function parseCompositeSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const childContext = createChildContext(xml, options, context);\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(xml)) {\n switch (childName) {\n case 'gml:surfaceMember':\n case 'gml:surfaceMembers':\n const [c2Name, c2Xml] = getFirstKeyValue(childXML);\n switch (c2Name) {\n case 'gml:Surface':\n polygons.push(...parseSurface(c2Xml, options, childContext));\n break;\n case 'gml:Polygon':\n polygons.push(parsePolygonOrRectangle(c2Xml, options, childContext));\n break;\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n return polygons;\n}\n\nexport function parseMultiSurface(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n let el = xml;\n\n const surfaceMembers = findIn(xml, 'gml:LinearRing');\n if (surfaceMembers) {\n el = surfaceMembers;\n }\n\n const polygons: Position[][][] = [];\n for (const [childName, childXML] of Object.entries(el)) {\n switch (childName) {\n case 'gml:Surface':\n const polygons2 = parseSurface(childXML, options, context);\n polygons.push(...polygons2);\n break;\n case 'gml:surfaceMember':\n const polygons3 = parseSurfaceMember(childXML, options, context);\n polygons.push(...polygons3);\n break;\n\n case 'gml:surfaceMembers':\n const polygonXML = findIn(childXML, 'gml:Polygon');\n for (const surfaceMemberXML of polygonXML as []) {\n const polygons3 = parseSurfaceMember(surfaceMemberXML, options, context);\n polygons.push(...polygons3);\n }\n break;\n }\n }\n\n if (polygons.length === 0) {\n throw new Error(`${xml.name} must have > 0 polygons`);\n }\n\n return polygons;\n}\n\nfunction parseSurfaceMember(\n xml: any,\n options: ParseGMLOptions,\n context: ParseGMLContext\n): Position[][][] {\n const [childName, childXml] = getFirstKeyValue(xml);\n switch (childName) {\n case 'gml:CompositeSurface':\n return parseCompositeSurface(childXml, options, context);\n case 'gml:Surface':\n return parseSurface(childXml, options, context);\n case 'gml:Polygon':\n return [parsePolygonOrRectangle(childXml, options, context)];\n }\n throw new Error(`${childName} must have polygons`);\n}\n\n// Helpers\n\nfunction textOf(el: any): string {\n if (typeof el !== 'string') {\n throw new Error('expected string');\n }\n return el;\n}\n\nfunction findIn(root: any, ...tags: string[]): any {\n let el = root;\n for (const tag of tags) {\n const child = el[tag];\n if (!child) {\n return null;\n }\n el = child;\n }\n return el;\n}\n\n/** @returns the first [key, value] pair in an object, or ['', null] if empty object */\nfunction getFirstKeyValue(object: any): [string, any] {\n if (object && typeof object === 'object') {\n for (const [key, value] of Object.entries(object)) {\n return [key, value];\n }\n }\n return ['', null];\n}\n\n/** A bit heavyweight for just tracking dimension? */\nfunction createChildContext(xml, options, context): ParseGMLContext {\n const srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;\n\n if (srsDimensionAttribute) {\n const srsDimension = parseInt(srsDimensionAttribute);\n if (Number.isNaN(srsDimension) || srsDimension <= 0) {\n throw new Error(\n `invalid srsDimension attribute value \"${srsDimensionAttribute}\", expected a positive integer`\n );\n }\n\n const childContext = Object.create(context);\n childContext.srsDimension = srsDimension;\n return childContext;\n }\n\n return context;\n}\n"],"mappings":"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"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseWCSCapabilities } from './lib/wcs/parse-wcs-capabilities';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const WCSCapabilitiesLoader = {
|
|
4
4
|
id: 'wcs-capabilities',
|
|
5
5
|
name: 'WFS Capabilities',
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseWFSCapabilities } from './lib/wfs/parse-wfs-capabilities';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const WFSCapabilitiesLoader = {
|
|
4
4
|
id: 'wfs-capabilities',
|
|
5
5
|
name: 'WFS Capabilities',
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseWMTSCapabilities } from './lib/wmts/parse-wmts-capabilities';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const WMTSCapabilitiesLoader = {
|
|
4
4
|
id: 'wmts-capabilities',
|
|
5
5
|
name: 'WMTS Capabilities',
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseWMSCapabilities } from './lib/parsers/wms/parse-wms-capabilities';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const WMSCapabilitiesLoader = {
|
|
4
4
|
id: 'wms-capabilities',
|
|
5
5
|
name: 'WMS Capabilities',
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { parseWMSError } from './lib/parsers/wms/parse-wms-error';
|
|
2
|
-
const VERSION = typeof "4.0.0-alpha.
|
|
2
|
+
const VERSION = typeof "4.0.0-alpha.24" !== 'undefined' ? "4.0.0-alpha.24" : 'latest';
|
|
3
3
|
export const WMSErrorLoader = {
|
|
4
4
|
id: 'wms-error',
|
|
5
5
|
name: 'WMS Error',
|
package/dist/gml-loader.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import type { LoaderWithParser, LoaderOptions } from '@loaders.gl/loader-utils';
|
|
2
|
+
import type { Geometry } from './lib/parsers/gml/parse-gml';
|
|
2
3
|
export type GMLLoaderOptions = LoaderOptions & {
|
|
3
4
|
gml?: {};
|
|
4
5
|
};
|
|
5
6
|
/**
|
|
6
7
|
* Loader for the response to the GML GetCapability request
|
|
7
8
|
*/
|
|
8
|
-
export declare const GMLLoader: LoaderWithParser
|
|
9
|
+
export declare const GMLLoader: LoaderWithParser<Geometry | null, never, GMLLoaderOptions>;
|
|
9
10
|
//# sourceMappingURL=gml-loader.d.ts.map
|