@loaders.gl/wms 3.3.0-alpha.8 → 3.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (257) hide show
  1. package/dist/bundle.d.ts +2 -0
  2. package/dist/bundle.d.ts.map +1 -0
  3. package/dist/bundle.js +6 -0
  4. package/dist/dist.min.js +4141 -1479
  5. package/dist/es5/bundle.js.map +1 -1
  6. package/dist/es5/index.js +77 -0
  7. package/dist/es5/index.js.map +1 -1
  8. package/dist/es5/lerc-loader.js +74 -0
  9. package/dist/es5/lerc-loader.js.map +1 -0
  10. package/dist/es5/lib/data-sources/adhoc-image-service.js +129 -0
  11. package/dist/es5/lib/data-sources/adhoc-image-service.js.map +1 -0
  12. package/dist/es5/lib/data-sources/arcgis-image-service.js +180 -0
  13. package/dist/es5/lib/data-sources/arcgis-image-service.js.map +1 -0
  14. package/dist/es5/lib/data-sources/create-image-source.js +45 -0
  15. package/dist/es5/lib/data-sources/create-image-source.js.map +1 -0
  16. package/dist/es5/lib/data-sources/image-services/arcgis-image-service.js +179 -0
  17. package/dist/es5/lib/data-sources/image-services/arcgis-image-service.js.map +1 -0
  18. package/dist/es5/lib/data-sources/image-services/image-service.js +163 -0
  19. package/dist/es5/lib/data-sources/image-services/image-service.js.map +1 -0
  20. package/dist/es5/lib/data-sources/image-services/wms-service.js +400 -0
  21. package/dist/es5/lib/data-sources/image-services/wms-service.js.map +1 -0
  22. package/dist/es5/lib/data-sources/image-source.js +14 -0
  23. package/dist/es5/lib/data-sources/image-source.js.map +1 -0
  24. package/dist/es5/lib/gml/deep-strict-equal.js +64 -0
  25. package/dist/es5/lib/gml/deep-strict-equal.js.map +1 -0
  26. package/dist/es5/lib/gml/parse-gml.js +416 -0
  27. package/dist/es5/lib/gml/parse-gml.js.map +1 -0
  28. package/dist/es5/lib/lerc/lerc-types.js +2 -0
  29. package/dist/es5/lib/lerc/lerc-types.js.map +1 -0
  30. package/dist/es5/lib/wcs/parse-wcs.js +43 -0
  31. package/dist/es5/lib/wcs/parse-wcs.js.map +1 -0
  32. package/dist/es5/lib/wcs/wcs-types.js +2 -0
  33. package/dist/es5/lib/wcs/wcs-types.js.map +1 -0
  34. package/dist/es5/lib/wfs/parse-wfs.js +43 -0
  35. package/dist/es5/lib/wfs/parse-wfs.js.map +1 -0
  36. package/dist/es5/lib/wfs/wfs-types.js +2 -0
  37. package/dist/es5/lib/wfs/wfs-types.js.map +1 -0
  38. package/dist/es5/lib/wms/parse-wms.js +135 -0
  39. package/dist/es5/lib/wms/parse-wms.js.map +1 -0
  40. package/dist/es5/{wms-types.js → lib/wms/wms-types.js} +0 -0
  41. package/dist/{esm → es5/lib/wms}/wms-types.js.map +1 -1
  42. package/dist/es5/lib/wmts/parse-wmts.js +43 -0
  43. package/dist/es5/lib/wmts/parse-wmts.js.map +1 -0
  44. package/dist/es5/lib/wmts/wmts-types.js +2 -0
  45. package/dist/es5/lib/wmts/wmts-types.js.map +1 -0
  46. package/dist/es5/wip/arcgis-feature-service.js +45 -0
  47. package/dist/es5/wip/arcgis-feature-service.js.map +1 -0
  48. package/dist/es5/wip/data-source.js +4 -0
  49. package/dist/es5/wip/data-source.js.map +1 -0
  50. package/dist/es5/wip/gml-loader.js +54 -0
  51. package/dist/es5/wip/gml-loader.js.map +1 -0
  52. package/dist/es5/wip/wcs-capabilities-loader.js +54 -0
  53. package/dist/es5/wip/wcs-capabilities-loader.js.map +1 -0
  54. package/dist/es5/wip/wfs-capabilities-loader.js +54 -0
  55. package/dist/es5/wip/wfs-capabilities-loader.js.map +1 -0
  56. package/dist/es5/wip/wms-feature-info-loader.js +44 -0
  57. package/dist/es5/wip/wms-feature-info-loader.js.map +1 -0
  58. package/dist/es5/wip/wms-layer-description-loader.js +44 -0
  59. package/dist/es5/wip/wms-layer-description-loader.js.map +1 -0
  60. package/dist/es5/wip/wms-layer-description-loader.md.disabled.md +47 -0
  61. package/dist/es5/wip/wmts-capabilities-loader.js +54 -0
  62. package/dist/es5/wip/wmts-capabilities-loader.js.map +1 -0
  63. package/dist/es5/wms-capabilities-loader.js +7 -6
  64. package/dist/es5/wms-capabilities-loader.js.map +1 -1
  65. package/dist/es5/wms-error-loader.js +70 -0
  66. package/dist/es5/wms-error-loader.js.map +1 -0
  67. package/dist/esm/bundle.js +1 -0
  68. package/dist/esm/bundle.js.map +1 -1
  69. package/dist/esm/index.js +16 -0
  70. package/dist/esm/index.js.map +1 -1
  71. package/dist/esm/lerc-loader.js +25 -0
  72. package/dist/esm/lerc-loader.js.map +1 -0
  73. package/dist/esm/lib/data-sources/adhoc-image-service.js +43 -0
  74. package/dist/esm/lib/data-sources/adhoc-image-service.js.map +1 -0
  75. package/dist/esm/lib/data-sources/arcgis-image-service.js +62 -0
  76. package/dist/esm/lib/data-sources/arcgis-image-service.js.map +1 -0
  77. package/dist/esm/lib/data-sources/create-image-source.js +30 -0
  78. package/dist/esm/lib/data-sources/create-image-source.js.map +1 -0
  79. package/dist/esm/lib/data-sources/image-services/arcgis-image-service.js +61 -0
  80. package/dist/esm/lib/data-sources/image-services/arcgis-image-service.js.map +1 -0
  81. package/dist/esm/lib/data-sources/image-services/image-service.js +72 -0
  82. package/dist/esm/lib/data-sources/image-services/image-service.js.map +1 -0
  83. package/dist/esm/lib/data-sources/image-services/wms-service.js +190 -0
  84. package/dist/esm/lib/data-sources/image-services/wms-service.js.map +1 -0
  85. package/dist/esm/lib/data-sources/image-source.js +4 -0
  86. package/dist/esm/lib/data-sources/image-source.js.map +1 -0
  87. package/dist/esm/lib/gml/deep-strict-equal.js +57 -0
  88. package/dist/esm/lib/gml/deep-strict-equal.js.map +1 -0
  89. package/dist/esm/lib/gml/parse-gml.js +348 -0
  90. package/dist/esm/lib/gml/parse-gml.js.map +1 -0
  91. package/dist/esm/lib/lerc/lerc-types.js +2 -0
  92. package/dist/esm/lib/lerc/lerc-types.js.map +1 -0
  93. package/dist/esm/lib/wcs/parse-wcs.js +32 -0
  94. package/dist/esm/lib/wcs/parse-wcs.js.map +1 -0
  95. package/dist/esm/lib/wcs/wcs-types.js +2 -0
  96. package/dist/esm/lib/wcs/wcs-types.js.map +1 -0
  97. package/dist/esm/lib/wfs/parse-wfs.js +32 -0
  98. package/dist/esm/lib/wfs/parse-wfs.js.map +1 -0
  99. package/dist/esm/lib/wfs/wfs-types.js +2 -0
  100. package/dist/esm/lib/wfs/wfs-types.js.map +1 -0
  101. package/dist/esm/lib/wms/parse-wms.js +101 -0
  102. package/dist/esm/lib/wms/parse-wms.js.map +1 -0
  103. package/dist/esm/{wms-types.js → lib/wms/wms-types.js} +0 -0
  104. package/dist/{es5 → esm/lib/wms}/wms-types.js.map +1 -1
  105. package/dist/esm/lib/wmts/parse-wmts.js +32 -0
  106. package/dist/esm/lib/wmts/parse-wmts.js.map +1 -0
  107. package/dist/esm/lib/wmts/wmts-types.js +2 -0
  108. package/dist/esm/lib/wmts/wmts-types.js.map +1 -0
  109. package/dist/esm/wip/arcgis-feature-service.js +28 -0
  110. package/dist/esm/wip/arcgis-feature-service.js.map +1 -0
  111. package/dist/esm/wip/data-source.js +2 -0
  112. package/dist/esm/wip/data-source.js.map +1 -0
  113. package/dist/esm/wip/gml-loader.js +25 -0
  114. package/dist/esm/wip/gml-loader.js.map +1 -0
  115. package/dist/esm/wip/wcs-capabilities-loader.js +25 -0
  116. package/dist/esm/wip/wcs-capabilities-loader.js.map +1 -0
  117. package/dist/esm/wip/wfs-capabilities-loader.js +25 -0
  118. package/dist/esm/wip/wfs-capabilities-loader.js.map +1 -0
  119. package/dist/esm/wip/wms-feature-info-loader.js +14 -0
  120. package/dist/esm/wip/wms-feature-info-loader.js.map +1 -0
  121. package/dist/esm/wip/wms-layer-description-loader.js +14 -0
  122. package/dist/esm/wip/wms-layer-description-loader.js.map +1 -0
  123. package/dist/esm/wip/wms-layer-description-loader.md.disabled.md +47 -0
  124. package/dist/esm/wip/wmts-capabilities-loader.js +25 -0
  125. package/dist/esm/wip/wmts-capabilities-loader.js.map +1 -0
  126. package/dist/esm/wms-capabilities-loader.js +6 -4
  127. package/dist/esm/wms-capabilities-loader.js.map +1 -1
  128. package/dist/esm/wms-error-loader.js +40 -0
  129. package/dist/esm/wms-error-loader.js.map +1 -0
  130. package/dist/index.d.ts +27 -0
  131. package/dist/index.d.ts.map +1 -0
  132. package/dist/index.js +33 -0
  133. package/dist/lerc-loader.d.ts +30 -0
  134. package/dist/lerc-loader.d.ts.map +1 -0
  135. package/dist/lerc-loader.js +56 -0
  136. package/dist/lib/data-sources/adhoc-image-service.d.ts +24 -0
  137. package/dist/lib/data-sources/adhoc-image-service.d.ts.map +1 -0
  138. package/dist/lib/data-sources/adhoc-image-service.js +46 -0
  139. package/dist/lib/data-sources/arcgis-image-service.d.ts +79 -0
  140. package/dist/lib/data-sources/arcgis-image-service.d.ts.map +1 -0
  141. package/dist/lib/data-sources/arcgis-image-service.js +85 -0
  142. package/dist/lib/data-sources/create-image-source.d.ts +16 -0
  143. package/dist/lib/data-sources/create-image-source.d.ts.map +1 -0
  144. package/dist/lib/data-sources/create-image-source.js +39 -0
  145. package/dist/lib/data-sources/image-services/arcgis-image-service.d.ts +71 -0
  146. package/dist/lib/data-sources/image-services/arcgis-image-service.d.ts.map +1 -0
  147. package/dist/lib/data-sources/image-services/arcgis-image-service.js +85 -0
  148. package/dist/lib/data-sources/image-services/image-service.d.ts +39 -0
  149. package/dist/lib/data-sources/image-services/image-service.d.ts.map +1 -0
  150. package/dist/lib/data-sources/image-services/image-service.js +82 -0
  151. package/dist/lib/data-sources/image-services/wms-service.d.ts +188 -0
  152. package/dist/lib/data-sources/image-services/wms-service.d.ts.map +1 -0
  153. package/dist/lib/data-sources/image-services/wms-service.js +218 -0
  154. package/dist/lib/data-sources/image-source.d.ts +73 -0
  155. package/dist/lib/data-sources/image-source.d.ts.map +1 -0
  156. package/dist/lib/data-sources/image-source.js +12 -0
  157. package/dist/lib/gml/deep-strict-equal.d.ts +3 -0
  158. package/dist/lib/gml/deep-strict-equal.d.ts.map +1 -0
  159. package/dist/lib/gml/deep-strict-equal.js +119 -0
  160. package/dist/lib/gml/parse-gml.d.ts +28 -0
  161. package/dist/lib/gml/parse-gml.d.ts.map +1 -0
  162. package/dist/lib/gml/parse-gml.js +371 -0
  163. package/dist/lib/lerc/lerc-types.d.ts +30 -0
  164. package/dist/lib/lerc/lerc-types.d.ts.map +1 -0
  165. package/dist/lib/lerc/lerc-types.js +3 -0
  166. package/dist/lib/wcs/parse-wcs.d.ts +7 -0
  167. package/dist/lib/wcs/parse-wcs.d.ts.map +1 -0
  168. package/dist/lib/wcs/parse-wcs.js +36 -0
  169. package/dist/lib/wcs/wcs-types.d.ts +73 -0
  170. package/dist/lib/wcs/wcs-types.d.ts.map +1 -0
  171. package/dist/lib/wcs/wcs-types.js +3 -0
  172. package/dist/lib/wfs/parse-wfs.d.ts +7 -0
  173. package/dist/lib/wfs/parse-wfs.d.ts.map +1 -0
  174. package/dist/lib/wfs/parse-wfs.js +36 -0
  175. package/dist/lib/wfs/wfs-types.d.ts +73 -0
  176. package/dist/lib/wfs/wfs-types.d.ts.map +1 -0
  177. package/dist/lib/wfs/wfs-types.js +3 -0
  178. package/dist/lib/wms/parse-wms.d.ts +24 -0
  179. package/dist/lib/wms/parse-wms.d.ts.map +1 -0
  180. package/dist/lib/wms/parse-wms.js +115 -0
  181. package/dist/lib/wms/wms-types.d.ts +100 -0
  182. package/dist/lib/wms/wms-types.d.ts.map +1 -0
  183. package/dist/lib/wms/wms-types.js +1908 -0
  184. package/dist/lib/wmts/parse-wmts.d.ts +7 -0
  185. package/dist/lib/wmts/parse-wmts.d.ts.map +1 -0
  186. package/dist/lib/wmts/parse-wmts.js +36 -0
  187. package/dist/lib/wmts/wmts-types.d.ts +73 -0
  188. package/dist/lib/wmts/wmts-types.d.ts.map +1 -0
  189. package/dist/lib/wmts/wmts-types.js +3 -0
  190. package/dist/wip/arcgis-feature-service.d.ts +56 -0
  191. package/dist/wip/arcgis-feature-service.d.ts.map +1 -0
  192. package/dist/wip/arcgis-feature-service.js +28 -0
  193. package/dist/wip/data-source.d.ts +54 -0
  194. package/dist/wip/data-source.d.ts.map +1 -0
  195. package/dist/wip/data-source.js +59 -0
  196. package/dist/wip/gml-loader.d.ts +26 -0
  197. package/dist/wip/gml-loader.d.ts.map +1 -0
  198. package/dist/wip/gml-loader.js +31 -0
  199. package/dist/wip/wcs-capabilities-loader.d.ts +26 -0
  200. package/dist/wip/wcs-capabilities-loader.d.ts.map +1 -0
  201. package/dist/wip/wcs-capabilities-loader.js +31 -0
  202. package/dist/wip/wfs-capabilities-loader.d.ts +26 -0
  203. package/dist/wip/wfs-capabilities-loader.d.ts.map +1 -0
  204. package/dist/wip/wfs-capabilities-loader.js +31 -0
  205. package/dist/wip/wms-feature-info-loader.d.ts +22 -0
  206. package/dist/wip/wms-feature-info-loader.d.ts.map +1 -0
  207. package/dist/wip/wms-feature-info-loader.js +17 -0
  208. package/dist/wip/wms-layer-description-loader.d.ts +22 -0
  209. package/dist/wip/wms-layer-description-loader.d.ts.map +1 -0
  210. package/dist/wip/wms-layer-description-loader.js +17 -0
  211. package/dist/wip/wmts-capabilities-loader.d.ts +26 -0
  212. package/dist/wip/wmts-capabilities-loader.d.ts.map +1 -0
  213. package/dist/wip/wmts-capabilities-loader.js +31 -0
  214. package/dist/wms-capabilities-loader.d.ts +26 -0
  215. package/dist/wms-capabilities-loader.d.ts.map +1 -0
  216. package/dist/wms-capabilities-loader.js +31 -0
  217. package/dist/wms-error-loader.d.ts +34 -0
  218. package/dist/wms-error-loader.d.ts.map +1 -0
  219. package/dist/wms-error-loader.js +43 -0
  220. package/package.json +17 -6
  221. package/src/bundle.ts +2 -0
  222. package/src/index.ts +54 -2
  223. package/src/lerc-loader.ts +50 -0
  224. package/src/lib/data-sources/adhoc-image-service.ts +61 -0
  225. package/src/lib/data-sources/arcgis-image-service.ts +146 -0
  226. package/src/lib/data-sources/create-image-source.ts +46 -0
  227. package/src/lib/data-sources/image-services/arcgis-image-service.ts +136 -0
  228. package/src/lib/data-sources/image-services/image-service.ts +105 -0
  229. package/src/lib/data-sources/image-services/wms-service.ts +351 -0
  230. package/src/lib/data-sources/image-source.ts +82 -0
  231. package/src/lib/gml/deep-strict-equal.ts +119 -0
  232. package/src/lib/gml/parse-gml.ts +500 -0
  233. package/src/lib/lerc/lerc-types.ts +43 -0
  234. package/src/lib/wcs/parse-wcs.ts +39 -0
  235. package/src/lib/wcs/wcs-types.ts +77 -0
  236. package/src/lib/wfs/parse-wfs.ts +39 -0
  237. package/src/lib/wfs/wfs-types.ts +78 -0
  238. package/src/lib/wms/parse-wms.ts +142 -0
  239. package/src/{wms-types.ts → lib/wms/wms-types.ts} +76 -24
  240. package/src/lib/wmts/parse-wmts.ts +39 -0
  241. package/src/lib/wmts/wmts-types.ts +77 -0
  242. package/src/wip/arcgis-feature-service.ts +89 -0
  243. package/src/wip/data-source.ts +62 -0
  244. package/src/wip/gml-loader.ts +40 -0
  245. package/src/wip/wcs-capabilities-loader.ts +40 -0
  246. package/src/wip/wfs-capabilities-loader.ts +40 -0
  247. package/src/wip/wms-feature-info-loader.ts +21 -0
  248. package/src/wip/wms-layer-description-loader.md.disabled.md +47 -0
  249. package/src/wip/wms-layer-description-loader.ts +21 -0
  250. package/src/wip/wmts-capabilities-loader.ts +40 -0
  251. package/src/wms-capabilities-loader.ts +10 -8
  252. package/src/wms-error-loader.ts +59 -0
  253. package/dist/es5/lib/parse-wms-capabilities.js +0 -19
  254. package/dist/es5/lib/parse-wms-capabilities.js.map +0 -1
  255. package/dist/esm/lib/parse-wms-capabilities.js +0 -14
  256. package/dist/esm/lib/parse-wms-capabilities.js.map +0 -1
  257. package/src/lib/parse-wms-capabilities.ts +0 -14
@@ -0,0 +1,119 @@
1
+ // https://github.com/nodejs/node/commit/c1d82ac2ff15594840e2a1b9531b506ae067ed27;
2
+
3
+ // http://wiki.commonjs.org/wiki/Unit_Testing/1.0
4
+ //
5
+ // THIS IS NOT TESTED NOR LIKELY TO WORK OUTSIDE V8!
6
+ //
7
+ // Originally from narwhal.js (http://narwhaljs.org)
8
+ // Copyright (c) 2009 Thomas Robinson <280north.com>
9
+ //
10
+ // Permission is hereby granted, free of charge, to any person obtaining a copy
11
+ // of this software and associated documentation files (the 'Software'), to
12
+ // deal in the Software without restriction, including without limitation the
13
+ // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
14
+ // sell copies of the Software, and to permit persons to whom the Software is
15
+ // furnished to do so, subject to the following conditions:
16
+ //
17
+ // The above copyright notice and this permission notice shall be included in
18
+ // all copies or substantial portions of the Software.
19
+ //
20
+ // THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
21
+ // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
22
+ // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
23
+ // AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
24
+ // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
25
+ // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26
+
27
+ /** @todo replace this ridiculous choice of deepStrictEqual */
28
+ // eslint-disable-next-line complexity
29
+ export function deepStrictEqual(actual: unknown, expected: unknown, strict?: boolean) {
30
+ // 7.1. All identical values are equivalent, as determined by ===.
31
+ if (actual === expected) {
32
+ return true;
33
+ // } else if (actual instanceof Buffer && expected instanceof Buffer) {
34
+ // return compare(actual, expected) === 0;
35
+
36
+ // // 7.2. If the expected value is a Date object, the actual value is
37
+ // // equivalent if it is also a Date object that refers to the same time.
38
+ } else if (actual instanceof Date && expected instanceof Date) {
39
+ return actual.getTime() === expected.getTime();
40
+
41
+ // 7.3 If the expected value is a RegExp object, the actual value is
42
+ // equivalent if it is also a RegExp object with the same source and
43
+ // properties (`global`, `multiline`, `lastIndex`, `ignoreCase`).
44
+ } else if (actual instanceof RegExp && expected instanceof RegExp) {
45
+ return (
46
+ actual.source === expected.source &&
47
+ actual.global === expected.global &&
48
+ actual.multiline === expected.multiline &&
49
+ actual.lastIndex === expected.lastIndex &&
50
+ actual.ignoreCase === expected.ignoreCase
51
+ );
52
+
53
+ // 7.4. Other pairs that do not both pass typeof value == 'object',
54
+ // equivalence is determined by ==.
55
+ } else if (
56
+ (actual === null || typeof actual !== 'object') &&
57
+ (expected === null || typeof expected !== 'object')
58
+ ) {
59
+ // eslint-disable-next-line eqeqeq
60
+ return strict ? actual === expected : actual == expected;
61
+
62
+ // 7.5 For all other Object pairs, including Array objects, equivalence is
63
+ // determined by having the same number of owned properties (as verified
64
+ // with Object.prototype.hasOwnProperty.call), the same set of keys
65
+ // (although not necessarily the same order), equivalent values for every
66
+ // corresponding key, and an identical 'prototype' property. Note: this
67
+ // accounts for both named and indexed properties on Arrays.
68
+ }
69
+ return objEquiv(actual, expected, strict);
70
+ }
71
+
72
+ // eslint-disable-next-line @typescript-eslint/unbound-method
73
+ const pSlice = Array.prototype.slice;
74
+
75
+ function isPrimitive(arg) {
76
+ return arg === null || (typeof arg !== 'object' && typeof arg !== 'function');
77
+ }
78
+
79
+ function isArguments(object) {
80
+ // eslint-disable-next-line eqeqeq
81
+ return Object.prototype.toString.call(object) == '[object Arguments]';
82
+ }
83
+
84
+ // eslint-disable-next-line complexity
85
+ function objEquiv(a: unknown, b: unknown, strict) {
86
+ if (a === null || a === undefined || b === null || b === undefined) return false;
87
+ // if one is a primitive, the other must be same
88
+ if (isPrimitive(a) || isPrimitive(b)) return a === b;
89
+ if (strict && Object.getPrototypeOf(a) !== Object.getPrototypeOf(b)) return false;
90
+ const aIsArgs = isArguments(a);
91
+ const bIsArgs = isArguments(b);
92
+ if ((aIsArgs && !bIsArgs) || (!aIsArgs && bIsArgs)) return false;
93
+ if (aIsArgs) {
94
+ a = pSlice.call(a);
95
+ b = pSlice.call(b);
96
+ return deepStrictEqual(a, b, strict);
97
+ }
98
+ const ka = Object.keys(a);
99
+ const kb = Object.keys(b);
100
+ let key;
101
+ let i;
102
+ // having the same number of owned properties (keys incorporates
103
+ // hasOwnProperty)
104
+ if (ka.length !== kb.length) return false;
105
+ // the same set of keys (although not necessarily the same order),
106
+ ka.sort();
107
+ kb.sort();
108
+ // ~~~cheap key test
109
+ for (i = ka.length - 1; i >= 0; i--) {
110
+ if (ka[i] !== kb[i]) return false;
111
+ }
112
+ // equivalent values for every corresponding key, and
113
+ // ~~~possibly expensive deep test
114
+ for (i = ka.length - 1; i >= 0; i--) {
115
+ key = ka[i];
116
+ if (!deepStrictEqual(a[key], b[key], strict)) return false;
117
+ }
118
+ return true;
119
+ }
@@ -0,0 +1,500 @@
1
+ // loaders.gl, MIT license
2
+
3
+ // Forked from https://github.com/derhuerst/parse-gml-polygon/blob/master/index.js
4
+ // under ISC license
5
+
6
+ /* eslint-disable no-continue, default-case */
7
+
8
+ import type {
9
+ // GeoJSON,
10
+ // Feature,
11
+ // FeatureCollection,
12
+ Geometry,
13
+ Position
14
+ // GeoJsonProperties,
15
+ // Point,
16
+ // MultiPoint,
17
+ // LineString,
18
+ // MultiLineString,
19
+ // Polygon,
20
+ // MultiPolygon,
21
+ // GeometryCollection
22
+ } from '@loaders.gl/schema';
23
+
24
+ import {XMLLoader} from '@loaders.gl/xml';
25
+ import {deepStrictEqual} from './deep-strict-equal';
26
+ import rewind from '@turf/rewind';
27
+
28
+ function noTransform(...coords) {
29
+ return coords;
30
+ }
31
+
32
+ export type ParseGMLOptions = {
33
+ transformCoords?: Function;
34
+ stride?: 2 | 3 | 4;
35
+ };
36
+
37
+ export type ParseGMLContext = {
38
+ srsDimension?: number;
39
+ [key: string]: any;
40
+ };
41
+
42
+ /**
43
+ * Parses a typed data structure from raw XML for GML features
44
+ * @note Error handlings is fairly weak
45
+ */
46
+ export function parseGML(text: string, options) {
47
+ // GeoJSON | null {
48
+ const parsedXML = XMLLoader.parseTextSync(text, options);
49
+
50
+ options = {transformCoords: noTransform, stride: 2, ...options};
51
+ const context = createChildContext(parsedXML, options, {});
52
+
53
+ return parseGMLToGeometry(parsedXML, options, context);
54
+ }
55
+
56
+ /** Parse a GeoJSON geometry from GML XML */
57
+ export function parseGMLToGeometry(
58
+ inputXML: any,
59
+ options: ParseGMLOptions,
60
+ context: ParseGMLContext
61
+ ): Geometry | null {
62
+ const childContext = createChildContext(inputXML, options, context);
63
+
64
+ let geometry: Geometry | null = null;
65
+
66
+ const [name, xml] = getFirstKeyValue(inputXML);
67
+
68
+ switch (name) {
69
+ // case 'gml:MultiPoint':
70
+ // geometry = {
71
+ // type: 'MultiPoint',
72
+ // coordinates: parseMultiPoint(xml, options, childContext)
73
+ // };
74
+ // break;
75
+
76
+ case 'gml:LineString':
77
+ geometry = {
78
+ type: 'LineString',
79
+ coordinates: parseLinearRingOrLineString(xml, options, childContext)
80
+ };
81
+ break;
82
+
83
+ // case 'gml:MultiLineString':
84
+ // geometry = {
85
+ // type: 'MultiLineString',
86
+ // coordinates: parseMultiLineString(xml, options, childContext)
87
+ // };
88
+ // break;
89
+
90
+ case 'gml:Polygon':
91
+ case 'gml:Rectangle':
92
+ geometry = {
93
+ type: 'Polygon',
94
+ coordinates: parsePolygonOrRectangle(xml, options, childContext)
95
+ };
96
+ break;
97
+ case 'gml:Surface':
98
+ geometry = {
99
+ type: 'MultiPolygon',
100
+ coordinates: parseSurface(xml, options, childContext)
101
+ };
102
+ break;
103
+ case 'gml:MultiSurface':
104
+ geometry = {
105
+ type: 'MultiPolygon',
106
+ coordinates: parseMultiSurface(xml, options, childContext)
107
+ };
108
+ break;
109
+
110
+ default:
111
+ return null;
112
+ }
113
+
114
+ // todo
115
+ return rewind(geometry, {mutate: true});
116
+ }
117
+
118
+ /** Parse a list of coordinates from a string */
119
+ function parseCoords(s: string, options: ParseGMLOptions, context: ParseGMLContext): Position[] {
120
+ const stride = context.srsDimension || options.stride || 2;
121
+
122
+ // Handle white space
123
+ const coords = s.replace(/\s+/g, ' ').trim().split(' ');
124
+
125
+ if (coords.length === 0 || coords.length % stride !== 0) {
126
+ throw new Error(`invalid coordinates list (stride ${stride})`);
127
+ }
128
+
129
+ const points: Position[] = [];
130
+ for (let i = 0; i < coords.length - 1; i += stride) {
131
+ const point = coords.slice(i, i + stride).map(parseFloat);
132
+ points.push(options.transformCoords?.(...point) || point);
133
+ }
134
+
135
+ return points;
136
+ }
137
+
138
+ export function parsePosList(xml: any, options: ParseGMLOptions, context: ParseGMLContext) {
139
+ const childContext = createChildContext(xml, options, context);
140
+
141
+ const coords = textOf(xml);
142
+ if (!coords) {
143
+ throw new Error('invalid gml:posList element');
144
+ }
145
+
146
+ return parseCoords(coords, options, childContext);
147
+ }
148
+
149
+ export function parsePos(xml: any, options: ParseGMLOptions, context: ParseGMLContext): Position {
150
+ const childContext = createChildContext(xml, options, context);
151
+
152
+ const coords = textOf(xml);
153
+ if (!coords) {
154
+ throw new Error('invalid gml:pos element');
155
+ }
156
+
157
+ const points = parseCoords(coords, options, childContext);
158
+ if (points.length !== 1) {
159
+ throw new Error('gml:pos must have 1 point');
160
+ }
161
+ return points[0];
162
+ }
163
+
164
+ export function parsePoint(xml: any, options: ParseGMLOptions, context: ParseGMLContext): number[] {
165
+ const childContext = createChildContext(xml, options, context);
166
+
167
+ // TODO AV: Parse other gml:Point options
168
+ const pos = findIn(xml, 'gml:pos');
169
+ if (!pos) {
170
+ throw new Error('invalid gml:Point element, expected a gml:pos subelement');
171
+ }
172
+ return parsePos(pos, options, childContext);
173
+ }
174
+
175
+ export function parseLinearRingOrLineString(
176
+ xml: any,
177
+ options: ParseGMLOptions,
178
+ context: ParseGMLContext
179
+ ): Position[] {
180
+ // or a LineStringSegment
181
+ const childContext = createChildContext(xml, options, context);
182
+
183
+ let points: Position[] = [];
184
+
185
+ const posList = findIn(xml, 'gml:posList');
186
+ if (posList) {
187
+ points = parsePosList(posList, options, childContext);
188
+ } else {
189
+ for (const [childName, childXML] of Object.entries(xml)) {
190
+ switch (childName) {
191
+ case 'gml:Point':
192
+ points.push(parsePoint(childXML, options, childContext));
193
+ break;
194
+ case 'gml:pos':
195
+ points.push(parsePos(childXML, options, childContext));
196
+ break;
197
+ default:
198
+ continue;
199
+ }
200
+ }
201
+ }
202
+
203
+ if (points.length === 0) {
204
+ throw new Error(`${xml.name} must have > 0 points`);
205
+ }
206
+ return points;
207
+ }
208
+
209
+ export function parseCurveSegments(
210
+ xml: any,
211
+ options: ParseGMLOptions,
212
+ context: ParseGMLContext
213
+ ): Position[] {
214
+ const points: Position[] = [];
215
+
216
+ for (const [childName, childXML] of Object.entries(xml)) {
217
+ switch (childName) {
218
+ case 'gml:LineStringSegment':
219
+ const points2 = parseLinearRingOrLineString(childXML, options, context);
220
+
221
+ // remove overlapping
222
+ const end = points[points.length - 1];
223
+ const start = points2[0];
224
+ if (end && start && deepStrictEqual(end, start)) {
225
+ points2.shift();
226
+ }
227
+
228
+ points.push(...points2);
229
+ break;
230
+ default:
231
+ continue;
232
+ }
233
+ }
234
+
235
+ if (points.length === 0) {
236
+ throw new Error('gml:Curve > gml:segments must have > 0 points');
237
+ }
238
+ return points;
239
+ }
240
+
241
+ export function parseRing(
242
+ xml: any,
243
+ options: ParseGMLOptions,
244
+ context: ParseGMLContext
245
+ ): Position[] {
246
+ const childContext = createChildContext(xml, options, context);
247
+
248
+ const points: Position[] = [];
249
+
250
+ for (const [childName, childXML] of Object.entries(xml)) {
251
+ switch (childName) {
252
+ case 'gml:curveMember':
253
+ let points2;
254
+
255
+ const lineString = findIn(childXML, 'gml:LineString');
256
+ if (lineString) {
257
+ points2 = parseLinearRingOrLineString(lineString, options, childContext);
258
+ } else {
259
+ const segments = findIn(childXML, 'gml:Curve', 'gml:segments');
260
+ if (!segments) {
261
+ throw new Error(`invalid ${childName} element`);
262
+ }
263
+
264
+ points2 = parseCurveSegments(segments, options, childContext);
265
+ }
266
+
267
+ // remove overlapping
268
+ const end = points[points.length - 1];
269
+ const start = points2[0];
270
+ if (end && start && deepStrictEqual(end, start)) {
271
+ points2.shift();
272
+ }
273
+
274
+ points.push(...points2);
275
+
276
+ break;
277
+ }
278
+ }
279
+
280
+ if (points.length < 4) {
281
+ throw new Error(`${xml.name} must have >= 4 points`);
282
+ }
283
+ return points;
284
+ }
285
+
286
+ export function parseExteriorOrInterior(
287
+ xml: any,
288
+ options: ParseGMLOptions,
289
+ context: ParseGMLContext
290
+ ): Position[] {
291
+ const linearRing = findIn(xml, 'gml:LinearRing');
292
+ if (linearRing) {
293
+ return parseLinearRingOrLineString(linearRing, options, context);
294
+ }
295
+
296
+ const ring = findIn(xml, 'gml:Ring');
297
+ if (!ring) {
298
+ throw new Error(`invalid ${xml.name} element`);
299
+ }
300
+
301
+ return parseRing(ring, options, context);
302
+ }
303
+
304
+ export function parsePolygonOrRectangle(
305
+ xml: any,
306
+ options: ParseGMLOptions,
307
+ context: ParseGMLContext
308
+ ): Position[][] {
309
+ // or PolygonPatch
310
+ const childContext = createChildContext(xml, options, context);
311
+
312
+ const exterior = findIn(xml, 'gml:exterior');
313
+ if (!exterior) {
314
+ throw new Error(`invalid ${xml.name} element`);
315
+ }
316
+
317
+ const pointLists: Position[][] = [parseExteriorOrInterior(exterior, options, childContext)];
318
+
319
+ for (const [childName, childXML] of Object.entries(xml)) {
320
+ switch (childName) {
321
+ case 'gml:interior':
322
+ pointLists.push(parseExteriorOrInterior(childXML, options, childContext));
323
+ break;
324
+ }
325
+ }
326
+
327
+ return pointLists;
328
+ }
329
+
330
+ export function parseSurface(
331
+ xml: any,
332
+ options: ParseGMLOptions,
333
+ context: ParseGMLContext
334
+ ): Position[][][] {
335
+ const childContext = createChildContext(xml, options, context);
336
+
337
+ const patches = findIn(xml, 'gml:patches');
338
+ if (!patches) {
339
+ throw new Error(`invalid ${xml.name} element`);
340
+ }
341
+
342
+ const polygons: Position[][][] = [];
343
+ for (const [childName, childXML] of Object.entries(xml)) {
344
+ switch (childName) {
345
+ case 'gml:PolygonPatch':
346
+ case 'gml:Rectangle':
347
+ polygons.push(parsePolygonOrRectangle(childXML, options, childContext));
348
+ break;
349
+
350
+ default:
351
+ continue;
352
+ }
353
+ }
354
+
355
+ if (polygons.length === 0) {
356
+ throw new Error(`${xml.name} must have > 0 polygons`);
357
+ }
358
+
359
+ return polygons;
360
+ }
361
+
362
+ export function parseCompositeSurface(
363
+ xml: any,
364
+ options: ParseGMLOptions,
365
+ context: ParseGMLContext
366
+ ): Position[][][] {
367
+ const childContext = createChildContext(xml, options, context);
368
+
369
+ const polygons: Position[][][] = [];
370
+ for (const [childName, childXML] of Object.entries(xml)) {
371
+ switch (childName) {
372
+ case 'gml:surfaceMember':
373
+ case 'gml:surfaceMembers':
374
+ const [c2Name, c2Xml] = getFirstKeyValue(childXML);
375
+ switch (c2Name) {
376
+ case 'gml:Surface':
377
+ polygons.push(...parseSurface(c2Xml, options, childContext));
378
+ break;
379
+ case 'gml:Polygon':
380
+ polygons.push(parsePolygonOrRectangle(c2Xml, options, childContext));
381
+ break;
382
+ }
383
+ break;
384
+ }
385
+ }
386
+
387
+ if (polygons.length === 0) {
388
+ throw new Error(`${xml.name} must have > 0 polygons`);
389
+ }
390
+ return polygons;
391
+ }
392
+
393
+ export function parseMultiSurface(
394
+ xml: any,
395
+ options: ParseGMLOptions,
396
+ context: ParseGMLContext
397
+ ): Position[][][] {
398
+ let el = xml;
399
+
400
+ const surfaceMembers = findIn(xml, 'gml:LinearRing');
401
+ if (surfaceMembers) {
402
+ el = surfaceMembers;
403
+ }
404
+
405
+ const polygons: Position[][][] = [];
406
+ for (const [childName, childXML] of Object.entries(el)) {
407
+ switch (childName) {
408
+ case 'gml:Surface':
409
+ const polygons2 = parseSurface(childXML, options, context);
410
+ polygons.push(...polygons2);
411
+ break;
412
+ case 'gml:surfaceMember':
413
+ const polygons3 = parseSurfaceMember(childXML, options, context);
414
+ polygons.push(...polygons3);
415
+ break;
416
+
417
+ case 'gml:surfaceMembers':
418
+ const polygonXML = findIn(childXML, 'gml:Polygon');
419
+ for (const surfaceMemberXML of polygonXML as []) {
420
+ const polygons3 = parseSurfaceMember(surfaceMemberXML, options, context);
421
+ polygons.push(...polygons3);
422
+ }
423
+ break;
424
+ }
425
+ }
426
+
427
+ if (polygons.length === 0) {
428
+ throw new Error(`${xml.name} must have > 0 polygons`);
429
+ }
430
+
431
+ return polygons;
432
+ }
433
+
434
+ function parseSurfaceMember(
435
+ xml: any,
436
+ options: ParseGMLOptions,
437
+ context: ParseGMLContext
438
+ ): Position[][][] {
439
+ const [childName, childXml] = getFirstKeyValue(xml);
440
+ switch (childName) {
441
+ case 'gml:CompositeSurface':
442
+ return parseCompositeSurface(childXml, options, context);
443
+ case 'gml:Surface':
444
+ return parseSurface(childXml, options, context);
445
+ case 'gml:Polygon':
446
+ return [parsePolygonOrRectangle(childXml, options, context)];
447
+ }
448
+ throw new Error(`${childName} must have polygons`);
449
+ }
450
+
451
+ // Helpers
452
+
453
+ function textOf(el: any): string {
454
+ if (typeof el !== 'string') {
455
+ throw new Error('expected string');
456
+ }
457
+ return el;
458
+ }
459
+
460
+ function findIn(root: any, ...tags: string[]): any {
461
+ let el = root;
462
+ for (const tag of tags) {
463
+ const child = el[tag];
464
+ if (!child) {
465
+ return null;
466
+ }
467
+ el = child;
468
+ }
469
+ return el;
470
+ }
471
+
472
+ /** @returns the first [key, value] pair in an object, or ['', null] if empty object */
473
+ function getFirstKeyValue(object: any): [string, any] {
474
+ if (object && typeof object === 'object') {
475
+ for (const [key, value] of Object.entries(object)) {
476
+ return [key, value];
477
+ }
478
+ }
479
+ return ['', null];
480
+ }
481
+
482
+ /** A bit heavyweight for just tracking dimension? */
483
+ function createChildContext(xml, options, context): ParseGMLContext {
484
+ const srsDimensionAttribute = xml.attributes && xml.attributes.srsDimension;
485
+
486
+ if (srsDimensionAttribute) {
487
+ const srsDimension = parseInt(srsDimensionAttribute);
488
+ if (Number.isNaN(srsDimension) || srsDimension <= 0) {
489
+ throw new Error(
490
+ `invalid srsDimension attribute value "${srsDimensionAttribute}", expected a positive integer`
491
+ );
492
+ }
493
+
494
+ const childContext = Object.create(context);
495
+ childContext.srsDimension = srsDimension;
496
+ return childContext;
497
+ }
498
+
499
+ return context;
500
+ }
@@ -0,0 +1,43 @@
1
+ // loaders.gl, MIT license
2
+
3
+ /** Data returned by LERC loader */
4
+ export type LERCData = {
5
+ /** Width of decoded image */
6
+ width: number;
7
+ /** Height of decoded image */
8
+ height: number;
9
+ /** The type of pixels represented in the output */
10
+ pixelType: LercPixelType;
11
+ /** [statistics_band1, statistics_band2, …] Each element is a statistics object representing min and max values */
12
+ statistics: BandStats[];
13
+ /** [band1, band2, …] Each band is a typed array of width * height * depthCount */
14
+ pixels: TypedArray[];
15
+ /** Typed array with a size of width*height, or null if all pixels are valid */
16
+ mask: Uint8Array;
17
+ /** Depth count */
18
+ depthCount: number;
19
+ /** array [band1_mask, band2_mask, …] Each band is a Uint8Array of width * height * depthCount */
20
+ bandMasks?: Uint8Array[];
21
+ };
22
+
23
+ export type LercPixelType = 'S8' | 'U8' | 'S16' | 'U16' | 'S32' | 'U32' | 'F32' | 'F64';
24
+
25
+ export interface BandStats {
26
+ minValue: number;
27
+ maxValue: number;
28
+ depthStats?: {
29
+ minValues: Float64Array;
30
+ maxValues: Float64Array;
31
+ };
32
+ }
33
+
34
+ export type TypedArray =
35
+ | Int8Array
36
+ | Uint8Array
37
+ | Uint8ClampedArray
38
+ | Int16Array
39
+ | Uint16Array
40
+ | Int32Array
41
+ | Uint32Array
42
+ | Float32Array
43
+ | Float64Array;
@@ -0,0 +1,39 @@
1
+ // loaders.gl, MIT license
2
+
3
+ import type {WFSCapabilities} from './wcs-types';
4
+
5
+ import {XMLLoader} from '@loaders.gl/xml';
6
+
7
+ // GetCapabilities
8
+
9
+ /**
10
+ * Parses a typed data structure from raw XML for `GetCapabilities` response
11
+ * @note Error handlings is fairly weak
12
+ */
13
+ export function parseWFSCapabilities(text: string, options): WFSCapabilities {
14
+ // Remove namespaces in XML
15
+ options = {...options, xml: {...options?.xml, removeNSPrefix: true}};
16
+ const parsedXML = XMLLoader.parseTextSync(text, options);
17
+ const xmlCapabilities: any = parsedXML.Capabilities || parsedXML;
18
+ return uncapitalizeKeys(xmlCapabilities);
19
+ }
20
+
21
+ function uncapitalizeKeys(object: any): any {
22
+ if (object && typeof object === 'object') {
23
+ const newObject = {};
24
+ for (const [key, value] of Object.entries(object)) {
25
+ newObject[uncapitalize(key)] = uncapitalizeKeys(value);
26
+ }
27
+ return newObject;
28
+ }
29
+ return object;
30
+ }
31
+
32
+ /**
33
+ * Uncapitalize first letter of a string
34
+ * @param {string} str
35
+ * @returns {string}
36
+ */
37
+ function uncapitalize(str: string): string {
38
+ return typeof str === 'string' ? str.charAt(0).toLowerCase() + str.slice(1) : str;
39
+ }