@kalisio/kdk 2.6.4 → 2.6.6

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 (259) hide show
  1. package/core/api/hooks/hooks.model.js +1 -1
  2. package/core/client/directives/v-drop-file.js +6 -6
  3. package/core/client/utils/utils.shapes.js +8 -1
  4. package/package.json +1 -1
  5. package/test/api/core/test-log-2026-03-10.log +60 -0
  6. package/test/api/map/test-log-2026-03-10.log +56 -0
  7. package/.vscode/settings.json +0 -5
  8. package/coverage/base.css +0 -224
  9. package/coverage/block-navigation.js +0 -87
  10. package/coverage/core/api/application.js.html +0 -1870
  11. package/coverage/core/api/authentication.js.html +0 -742
  12. package/coverage/core/api/db.js.html +0 -778
  13. package/coverage/core/api/hooks/hooks.authentication.js.html +0 -313
  14. package/coverage/core/api/hooks/hooks.authorisations.js.html +0 -1243
  15. package/coverage/core/api/hooks/hooks.groups.js.html +0 -229
  16. package/coverage/core/api/hooks/hooks.logger.js.html +0 -163
  17. package/coverage/core/api/hooks/hooks.model.js.html +0 -955
  18. package/coverage/core/api/hooks/hooks.organisations.js.html +0 -541
  19. package/coverage/core/api/hooks/hooks.push.js.html +0 -253
  20. package/coverage/core/api/hooks/hooks.query.js.html +0 -862
  21. package/coverage/core/api/hooks/hooks.schemas.js.html +0 -298
  22. package/coverage/core/api/hooks/hooks.service.js.html +0 -319
  23. package/coverage/core/api/hooks/hooks.storage.js.html +0 -193
  24. package/coverage/core/api/hooks/hooks.users.js.html +0 -868
  25. package/coverage/core/api/hooks/index.html +0 -296
  26. package/coverage/core/api/hooks/index.js.html +0 -121
  27. package/coverage/core/api/index.html +0 -191
  28. package/coverage/core/api/index.js.html +0 -148
  29. package/coverage/core/api/marshall.js.html +0 -448
  30. package/coverage/core/api/models/groups.model.mongodb.js.html +0 -109
  31. package/coverage/core/api/models/index.html +0 -176
  32. package/coverage/core/api/models/messages.model.mongodb.js.html +0 -109
  33. package/coverage/core/api/models/organisations.model.mongodb.js.html +0 -94
  34. package/coverage/core/api/models/tags.model.mongodb.js.html +0 -115
  35. package/coverage/core/api/models/users.model.mongodb.js.html +0 -115
  36. package/coverage/core/api/services/account/account.hooks.js.html +0 -208
  37. package/coverage/core/api/services/account/account.service.js.html +0 -436
  38. package/coverage/core/api/services/account/index.html +0 -131
  39. package/coverage/core/api/services/authorisations/authorisations.hooks.js.html +0 -184
  40. package/coverage/core/api/services/authorisations/authorisations.service.js.html +0 -529
  41. package/coverage/core/api/services/authorisations/index.html +0 -131
  42. package/coverage/core/api/services/databases/databases.hooks.js.html +0 -193
  43. package/coverage/core/api/services/databases/databases.service.js.html +0 -100
  44. package/coverage/core/api/services/databases/index.html +0 -131
  45. package/coverage/core/api/services/groups/groups.hooks.js.html +0 -178
  46. package/coverage/core/api/services/groups/index.html +0 -116
  47. package/coverage/core/api/services/import-export/import-export.hooks.js.html +0 -184
  48. package/coverage/core/api/services/import-export/import-export.service.js.html +0 -118
  49. package/coverage/core/api/services/import-export/index.html +0 -131
  50. package/coverage/core/api/services/index.html +0 -116
  51. package/coverage/core/api/services/index.js.html +0 -556
  52. package/coverage/core/api/services/mailer/index.html +0 -131
  53. package/coverage/core/api/services/mailer/mailer.hooks.js.html +0 -190
  54. package/coverage/core/api/services/mailer/mailer.service.js.html +0 -118
  55. package/coverage/core/api/services/messages/index.html +0 -116
  56. package/coverage/core/api/services/messages/messages.hooks.js.html +0 -184
  57. package/coverage/core/api/services/organisations/index.html +0 -131
  58. package/coverage/core/api/services/organisations/organisations.hooks.js.html +0 -178
  59. package/coverage/core/api/services/organisations/organisations.service.js.html +0 -343
  60. package/coverage/core/api/services/push/index.html +0 -131
  61. package/coverage/core/api/services/push/push.hooks.js.html +0 -190
  62. package/coverage/core/api/services/push/push.service.js.html +0 -121
  63. package/coverage/core/api/services/storage/index.html +0 -131
  64. package/coverage/core/api/services/storage/storage.hooks.js.html +0 -190
  65. package/coverage/core/api/services/storage/storage.service.js.html +0 -172
  66. package/coverage/core/api/services/tags/index.html +0 -116
  67. package/coverage/core/api/services/tags/tags.hooks.js.html +0 -178
  68. package/coverage/core/api/services/users/index.html +0 -116
  69. package/coverage/core/api/services/users/users.hooks.js.html +0 -307
  70. package/coverage/core/api/utils.js.html +0 -118
  71. package/coverage/core/common/errors.js.html +0 -88
  72. package/coverage/core/common/index.html +0 -176
  73. package/coverage/core/common/index.js.html +0 -115
  74. package/coverage/core/common/permissions.js.html +0 -1048
  75. package/coverage/core/common/schema.js.html +0 -190
  76. package/coverage/core/common/utils.js.html +0 -220
  77. package/coverage/favicon.png +0 -0
  78. package/coverage/index.html +0 -506
  79. package/coverage/lcov-report/base.css +0 -224
  80. package/coverage/lcov-report/block-navigation.js +0 -87
  81. package/coverage/lcov-report/core/api/application.js.html +0 -1870
  82. package/coverage/lcov-report/core/api/authentication.js.html +0 -742
  83. package/coverage/lcov-report/core/api/db.js.html +0 -778
  84. package/coverage/lcov-report/core/api/hooks/hooks.authentication.js.html +0 -313
  85. package/coverage/lcov-report/core/api/hooks/hooks.authorisations.js.html +0 -1243
  86. package/coverage/lcov-report/core/api/hooks/hooks.groups.js.html +0 -229
  87. package/coverage/lcov-report/core/api/hooks/hooks.logger.js.html +0 -163
  88. package/coverage/lcov-report/core/api/hooks/hooks.model.js.html +0 -955
  89. package/coverage/lcov-report/core/api/hooks/hooks.organisations.js.html +0 -541
  90. package/coverage/lcov-report/core/api/hooks/hooks.push.js.html +0 -253
  91. package/coverage/lcov-report/core/api/hooks/hooks.query.js.html +0 -862
  92. package/coverage/lcov-report/core/api/hooks/hooks.schemas.js.html +0 -298
  93. package/coverage/lcov-report/core/api/hooks/hooks.service.js.html +0 -319
  94. package/coverage/lcov-report/core/api/hooks/hooks.storage.js.html +0 -193
  95. package/coverage/lcov-report/core/api/hooks/hooks.users.js.html +0 -868
  96. package/coverage/lcov-report/core/api/hooks/index.html +0 -296
  97. package/coverage/lcov-report/core/api/hooks/index.js.html +0 -121
  98. package/coverage/lcov-report/core/api/index.html +0 -191
  99. package/coverage/lcov-report/core/api/index.js.html +0 -148
  100. package/coverage/lcov-report/core/api/marshall.js.html +0 -448
  101. package/coverage/lcov-report/core/api/models/groups.model.mongodb.js.html +0 -109
  102. package/coverage/lcov-report/core/api/models/index.html +0 -176
  103. package/coverage/lcov-report/core/api/models/messages.model.mongodb.js.html +0 -109
  104. package/coverage/lcov-report/core/api/models/organisations.model.mongodb.js.html +0 -94
  105. package/coverage/lcov-report/core/api/models/tags.model.mongodb.js.html +0 -115
  106. package/coverage/lcov-report/core/api/models/users.model.mongodb.js.html +0 -115
  107. package/coverage/lcov-report/core/api/services/account/account.hooks.js.html +0 -208
  108. package/coverage/lcov-report/core/api/services/account/account.service.js.html +0 -436
  109. package/coverage/lcov-report/core/api/services/account/index.html +0 -131
  110. package/coverage/lcov-report/core/api/services/authorisations/authorisations.hooks.js.html +0 -184
  111. package/coverage/lcov-report/core/api/services/authorisations/authorisations.service.js.html +0 -529
  112. package/coverage/lcov-report/core/api/services/authorisations/index.html +0 -131
  113. package/coverage/lcov-report/core/api/services/databases/databases.hooks.js.html +0 -193
  114. package/coverage/lcov-report/core/api/services/databases/databases.service.js.html +0 -100
  115. package/coverage/lcov-report/core/api/services/databases/index.html +0 -131
  116. package/coverage/lcov-report/core/api/services/groups/groups.hooks.js.html +0 -178
  117. package/coverage/lcov-report/core/api/services/groups/index.html +0 -116
  118. package/coverage/lcov-report/core/api/services/import-export/import-export.hooks.js.html +0 -184
  119. package/coverage/lcov-report/core/api/services/import-export/import-export.service.js.html +0 -118
  120. package/coverage/lcov-report/core/api/services/import-export/index.html +0 -131
  121. package/coverage/lcov-report/core/api/services/index.html +0 -116
  122. package/coverage/lcov-report/core/api/services/index.js.html +0 -556
  123. package/coverage/lcov-report/core/api/services/mailer/index.html +0 -131
  124. package/coverage/lcov-report/core/api/services/mailer/mailer.hooks.js.html +0 -190
  125. package/coverage/lcov-report/core/api/services/mailer/mailer.service.js.html +0 -118
  126. package/coverage/lcov-report/core/api/services/messages/index.html +0 -116
  127. package/coverage/lcov-report/core/api/services/messages/messages.hooks.js.html +0 -184
  128. package/coverage/lcov-report/core/api/services/organisations/index.html +0 -131
  129. package/coverage/lcov-report/core/api/services/organisations/organisations.hooks.js.html +0 -178
  130. package/coverage/lcov-report/core/api/services/organisations/organisations.service.js.html +0 -343
  131. package/coverage/lcov-report/core/api/services/push/index.html +0 -131
  132. package/coverage/lcov-report/core/api/services/push/push.hooks.js.html +0 -190
  133. package/coverage/lcov-report/core/api/services/push/push.service.js.html +0 -121
  134. package/coverage/lcov-report/core/api/services/storage/index.html +0 -131
  135. package/coverage/lcov-report/core/api/services/storage/storage.hooks.js.html +0 -190
  136. package/coverage/lcov-report/core/api/services/storage/storage.service.js.html +0 -172
  137. package/coverage/lcov-report/core/api/services/tags/index.html +0 -116
  138. package/coverage/lcov-report/core/api/services/tags/tags.hooks.js.html +0 -178
  139. package/coverage/lcov-report/core/api/services/users/index.html +0 -116
  140. package/coverage/lcov-report/core/api/services/users/users.hooks.js.html +0 -307
  141. package/coverage/lcov-report/core/api/utils.js.html +0 -118
  142. package/coverage/lcov-report/core/common/errors.js.html +0 -88
  143. package/coverage/lcov-report/core/common/index.html +0 -176
  144. package/coverage/lcov-report/core/common/index.js.html +0 -115
  145. package/coverage/lcov-report/core/common/permissions.js.html +0 -1048
  146. package/coverage/lcov-report/core/common/schema.js.html +0 -190
  147. package/coverage/lcov-report/core/common/utils.js.html +0 -220
  148. package/coverage/lcov-report/favicon.png +0 -0
  149. package/coverage/lcov-report/index.html +0 -506
  150. package/coverage/lcov-report/map/api/hooks/hooks.catalog.js.html +0 -457
  151. package/coverage/lcov-report/map/api/hooks/hooks.features.js.html +0 -397
  152. package/coverage/lcov-report/map/api/hooks/hooks.query.js.html +0 -1309
  153. package/coverage/lcov-report/map/api/hooks/index.html +0 -161
  154. package/coverage/lcov-report/map/api/hooks/index.js.html +0 -94
  155. package/coverage/lcov-report/map/api/index.html +0 -131
  156. package/coverage/lcov-report/map/api/index.js.html +0 -139
  157. package/coverage/lcov-report/map/api/marshall.js.html +0 -178
  158. package/coverage/lcov-report/map/api/models/alerts.model.mongodb.js.html +0 -106
  159. package/coverage/lcov-report/map/api/models/catalog.model.mongodb.js.html +0 -127
  160. package/coverage/lcov-report/map/api/models/features.model.mongodb.js.html +0 -196
  161. package/coverage/lcov-report/map/api/models/index.html +0 -161
  162. package/coverage/lcov-report/map/api/models/projects.model.mongodb.js.html +0 -109
  163. package/coverage/lcov-report/map/api/services/alerts/alerts.hooks.js.html +0 -274
  164. package/coverage/lcov-report/map/api/services/alerts/alerts.service.js.html +0 -610
  165. package/coverage/lcov-report/map/api/services/alerts/index.html +0 -131
  166. package/coverage/lcov-report/map/api/services/catalog/catalog.hooks.js.html +0 -310
  167. package/coverage/lcov-report/map/api/services/catalog/index.html +0 -116
  168. package/coverage/lcov-report/map/api/services/daptiles/daptiles.service.js.html +0 -1510
  169. package/coverage/lcov-report/map/api/services/daptiles/index.html +0 -116
  170. package/coverage/lcov-report/map/api/services/features/features.hooks.js.html +0 -241
  171. package/coverage/lcov-report/map/api/services/features/features.service.js.html +0 -241
  172. package/coverage/lcov-report/map/api/services/features/index.html +0 -131
  173. package/coverage/lcov-report/map/api/services/index.html +0 -116
  174. package/coverage/lcov-report/map/api/services/index.js.html +0 -817
  175. package/coverage/lcov-report/map/api/services/projects/index.html +0 -116
  176. package/coverage/lcov-report/map/api/services/projects/projects.hooks.js.html +0 -439
  177. package/coverage/lcov-report/map/common/dynamic-grid-source.js.html +0 -466
  178. package/coverage/lcov-report/map/common/errors.js.html +0 -94
  179. package/coverage/lcov-report/map/common/geotiff-grid-source.js.html +0 -541
  180. package/coverage/lcov-report/map/common/grid.js.html +0 -1612
  181. package/coverage/lcov-report/map/common/index.html +0 -371
  182. package/coverage/lcov-report/map/common/index.js.html +0 -172
  183. package/coverage/lcov-report/map/common/meteo-model-grid-source.js.html +0 -556
  184. package/coverage/lcov-report/map/common/moment-utils.js.html +0 -157
  185. package/coverage/lcov-report/map/common/opendap-grid-source.js.html +0 -868
  186. package/coverage/lcov-report/map/common/opendap-utils.js.html +0 -826
  187. package/coverage/lcov-report/map/common/permissions.js.html +0 -124
  188. package/coverage/lcov-report/map/common/time-based-grid-source.js.html +0 -418
  189. package/coverage/lcov-report/map/common/tms-utils.js.html +0 -274
  190. package/coverage/lcov-report/map/common/wcs-grid-source.js.html +0 -364
  191. package/coverage/lcov-report/map/common/wcs-utils.js.html +0 -586
  192. package/coverage/lcov-report/map/common/weacast-grid-source.js.html +0 -1033
  193. package/coverage/lcov-report/map/common/wfs-utils.js.html +0 -574
  194. package/coverage/lcov-report/map/common/wms-utils.js.html +0 -451
  195. package/coverage/lcov-report/map/common/wmts-utils.js.html +0 -547
  196. package/coverage/lcov-report/prettify.css +0 -1
  197. package/coverage/lcov-report/prettify.js +0 -2
  198. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  199. package/coverage/lcov-report/sorter.js +0 -196
  200. package/coverage/lcov.info +0 -10749
  201. package/coverage/map/api/hooks/hooks.catalog.js.html +0 -457
  202. package/coverage/map/api/hooks/hooks.features.js.html +0 -397
  203. package/coverage/map/api/hooks/hooks.query.js.html +0 -1309
  204. package/coverage/map/api/hooks/index.html +0 -161
  205. package/coverage/map/api/hooks/index.js.html +0 -94
  206. package/coverage/map/api/index.html +0 -131
  207. package/coverage/map/api/index.js.html +0 -139
  208. package/coverage/map/api/marshall.js.html +0 -178
  209. package/coverage/map/api/models/alerts.model.mongodb.js.html +0 -106
  210. package/coverage/map/api/models/catalog.model.mongodb.js.html +0 -127
  211. package/coverage/map/api/models/features.model.mongodb.js.html +0 -196
  212. package/coverage/map/api/models/index.html +0 -161
  213. package/coverage/map/api/models/projects.model.mongodb.js.html +0 -109
  214. package/coverage/map/api/services/alerts/alerts.hooks.js.html +0 -274
  215. package/coverage/map/api/services/alerts/alerts.service.js.html +0 -610
  216. package/coverage/map/api/services/alerts/index.html +0 -131
  217. package/coverage/map/api/services/catalog/catalog.hooks.js.html +0 -310
  218. package/coverage/map/api/services/catalog/index.html +0 -116
  219. package/coverage/map/api/services/daptiles/daptiles.service.js.html +0 -1510
  220. package/coverage/map/api/services/daptiles/index.html +0 -116
  221. package/coverage/map/api/services/features/features.hooks.js.html +0 -241
  222. package/coverage/map/api/services/features/features.service.js.html +0 -241
  223. package/coverage/map/api/services/features/index.html +0 -131
  224. package/coverage/map/api/services/index.html +0 -116
  225. package/coverage/map/api/services/index.js.html +0 -817
  226. package/coverage/map/api/services/projects/index.html +0 -116
  227. package/coverage/map/api/services/projects/projects.hooks.js.html +0 -439
  228. package/coverage/map/common/dynamic-grid-source.js.html +0 -466
  229. package/coverage/map/common/errors.js.html +0 -94
  230. package/coverage/map/common/geotiff-grid-source.js.html +0 -541
  231. package/coverage/map/common/grid.js.html +0 -1612
  232. package/coverage/map/common/index.html +0 -371
  233. package/coverage/map/common/index.js.html +0 -172
  234. package/coverage/map/common/meteo-model-grid-source.js.html +0 -556
  235. package/coverage/map/common/moment-utils.js.html +0 -157
  236. package/coverage/map/common/opendap-grid-source.js.html +0 -868
  237. package/coverage/map/common/opendap-utils.js.html +0 -826
  238. package/coverage/map/common/permissions.js.html +0 -124
  239. package/coverage/map/common/time-based-grid-source.js.html +0 -418
  240. package/coverage/map/common/tms-utils.js.html +0 -274
  241. package/coverage/map/common/wcs-grid-source.js.html +0 -364
  242. package/coverage/map/common/wcs-utils.js.html +0 -586
  243. package/coverage/map/common/weacast-grid-source.js.html +0 -1033
  244. package/coverage/map/common/wfs-utils.js.html +0 -574
  245. package/coverage/map/common/wms-utils.js.html +0 -451
  246. package/coverage/map/common/wmts-utils.js.html +0 -547
  247. package/coverage/prettify.css +0 -1
  248. package/coverage/prettify.js +0 -2
  249. package/coverage/sort-arrow-sprite.png +0 -0
  250. package/coverage/sorter.js +0 -196
  251. package/coverage/tmp/coverage-151166-1723543324307-0.json +0 -1
  252. package/coverage/tmp/coverage-151178-1723543324283-0.json +0 -1
  253. package/coverage/tmp/coverage-151189-1723543324271-0.json +0 -1
  254. package/coverage/tmp/coverage-151201-1723543324248-0.json +0 -1
  255. package/coverage/tmp/coverage-151208-1723543324227-0.json +0 -1
  256. package/test/api/core/test-log-2024-04-22.log +0 -84
  257. package/test/api/core/test-log-2024-04-23.log +0 -23
  258. package/test/api/core/test-log-2024-08-13.log +0 -3
  259. package/test/api/map/test-log-2025-03-08.log +0 -0
@@ -1,1033 +0,0 @@
1
-
2
- <!doctype html>
3
- <html lang="en">
4
-
5
- <head>
6
- <title>Code coverage report for map/common/weacast-grid-source.js</title>
7
- <meta charset="utf-8" />
8
- <link rel="stylesheet" href="../../prettify.css" />
9
- <link rel="stylesheet" href="../../base.css" />
10
- <link rel="shortcut icon" type="image/x-icon" href="../../favicon.png" />
11
- <meta name="viewport" content="width=device-width, initial-scale=1" />
12
- <style type='text/css'>
13
- .coverage-summary .sorter {
14
- background-image: url(../../sort-arrow-sprite.png);
15
- }
16
- </style>
17
- </head>
18
-
19
- <body>
20
- <div class='wrapper'>
21
- <div class='pad1'>
22
- <h1><a href="../../index.html">All files</a> / <a href="index.html">map/common</a> weacast-grid-source.js</h1>
23
- <div class='clearfix'>
24
-
25
- <div class='fl pad1y space-right2'>
26
- <span class="strong">0% </span>
27
- <span class="quiet">Statements</span>
28
- <span class='fraction'>0/316</span>
29
- </div>
30
-
31
-
32
- <div class='fl pad1y space-right2'>
33
- <span class="strong">0% </span>
34
- <span class="quiet">Branches</span>
35
- <span class='fraction'>0/1</span>
36
- </div>
37
-
38
-
39
- <div class='fl pad1y space-right2'>
40
- <span class="strong">0% </span>
41
- <span class="quiet">Functions</span>
42
- <span class='fraction'>0/1</span>
43
- </div>
44
-
45
-
46
- <div class='fl pad1y space-right2'>
47
- <span class="strong">0% </span>
48
- <span class="quiet">Lines</span>
49
- <span class='fraction'>0/316</span>
50
- </div>
51
-
52
-
53
- </div>
54
- <p class="quiet">
55
- Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
- </p>
57
- <template id="filterTemplate">
58
- <div class="quiet">
59
- Filter:
60
- <input oninput="onInput()" type="search" id="fileSearch">
61
- </div>
62
- </template>
63
- </div>
64
- <div class='status-line low'></div>
65
- <pre><table class="coverage">
66
- <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
- <a name='L2'></a><a href='#L2'>2</a>
68
- <a name='L3'></a><a href='#L3'>3</a>
69
- <a name='L4'></a><a href='#L4'>4</a>
70
- <a name='L5'></a><a href='#L5'>5</a>
71
- <a name='L6'></a><a href='#L6'>6</a>
72
- <a name='L7'></a><a href='#L7'>7</a>
73
- <a name='L8'></a><a href='#L8'>8</a>
74
- <a name='L9'></a><a href='#L9'>9</a>
75
- <a name='L10'></a><a href='#L10'>10</a>
76
- <a name='L11'></a><a href='#L11'>11</a>
77
- <a name='L12'></a><a href='#L12'>12</a>
78
- <a name='L13'></a><a href='#L13'>13</a>
79
- <a name='L14'></a><a href='#L14'>14</a>
80
- <a name='L15'></a><a href='#L15'>15</a>
81
- <a name='L16'></a><a href='#L16'>16</a>
82
- <a name='L17'></a><a href='#L17'>17</a>
83
- <a name='L18'></a><a href='#L18'>18</a>
84
- <a name='L19'></a><a href='#L19'>19</a>
85
- <a name='L20'></a><a href='#L20'>20</a>
86
- <a name='L21'></a><a href='#L21'>21</a>
87
- <a name='L22'></a><a href='#L22'>22</a>
88
- <a name='L23'></a><a href='#L23'>23</a>
89
- <a name='L24'></a><a href='#L24'>24</a>
90
- <a name='L25'></a><a href='#L25'>25</a>
91
- <a name='L26'></a><a href='#L26'>26</a>
92
- <a name='L27'></a><a href='#L27'>27</a>
93
- <a name='L28'></a><a href='#L28'>28</a>
94
- <a name='L29'></a><a href='#L29'>29</a>
95
- <a name='L30'></a><a href='#L30'>30</a>
96
- <a name='L31'></a><a href='#L31'>31</a>
97
- <a name='L32'></a><a href='#L32'>32</a>
98
- <a name='L33'></a><a href='#L33'>33</a>
99
- <a name='L34'></a><a href='#L34'>34</a>
100
- <a name='L35'></a><a href='#L35'>35</a>
101
- <a name='L36'></a><a href='#L36'>36</a>
102
- <a name='L37'></a><a href='#L37'>37</a>
103
- <a name='L38'></a><a href='#L38'>38</a>
104
- <a name='L39'></a><a href='#L39'>39</a>
105
- <a name='L40'></a><a href='#L40'>40</a>
106
- <a name='L41'></a><a href='#L41'>41</a>
107
- <a name='L42'></a><a href='#L42'>42</a>
108
- <a name='L43'></a><a href='#L43'>43</a>
109
- <a name='L44'></a><a href='#L44'>44</a>
110
- <a name='L45'></a><a href='#L45'>45</a>
111
- <a name='L46'></a><a href='#L46'>46</a>
112
- <a name='L47'></a><a href='#L47'>47</a>
113
- <a name='L48'></a><a href='#L48'>48</a>
114
- <a name='L49'></a><a href='#L49'>49</a>
115
- <a name='L50'></a><a href='#L50'>50</a>
116
- <a name='L51'></a><a href='#L51'>51</a>
117
- <a name='L52'></a><a href='#L52'>52</a>
118
- <a name='L53'></a><a href='#L53'>53</a>
119
- <a name='L54'></a><a href='#L54'>54</a>
120
- <a name='L55'></a><a href='#L55'>55</a>
121
- <a name='L56'></a><a href='#L56'>56</a>
122
- <a name='L57'></a><a href='#L57'>57</a>
123
- <a name='L58'></a><a href='#L58'>58</a>
124
- <a name='L59'></a><a href='#L59'>59</a>
125
- <a name='L60'></a><a href='#L60'>60</a>
126
- <a name='L61'></a><a href='#L61'>61</a>
127
- <a name='L62'></a><a href='#L62'>62</a>
128
- <a name='L63'></a><a href='#L63'>63</a>
129
- <a name='L64'></a><a href='#L64'>64</a>
130
- <a name='L65'></a><a href='#L65'>65</a>
131
- <a name='L66'></a><a href='#L66'>66</a>
132
- <a name='L67'></a><a href='#L67'>67</a>
133
- <a name='L68'></a><a href='#L68'>68</a>
134
- <a name='L69'></a><a href='#L69'>69</a>
135
- <a name='L70'></a><a href='#L70'>70</a>
136
- <a name='L71'></a><a href='#L71'>71</a>
137
- <a name='L72'></a><a href='#L72'>72</a>
138
- <a name='L73'></a><a href='#L73'>73</a>
139
- <a name='L74'></a><a href='#L74'>74</a>
140
- <a name='L75'></a><a href='#L75'>75</a>
141
- <a name='L76'></a><a href='#L76'>76</a>
142
- <a name='L77'></a><a href='#L77'>77</a>
143
- <a name='L78'></a><a href='#L78'>78</a>
144
- <a name='L79'></a><a href='#L79'>79</a>
145
- <a name='L80'></a><a href='#L80'>80</a>
146
- <a name='L81'></a><a href='#L81'>81</a>
147
- <a name='L82'></a><a href='#L82'>82</a>
148
- <a name='L83'></a><a href='#L83'>83</a>
149
- <a name='L84'></a><a href='#L84'>84</a>
150
- <a name='L85'></a><a href='#L85'>85</a>
151
- <a name='L86'></a><a href='#L86'>86</a>
152
- <a name='L87'></a><a href='#L87'>87</a>
153
- <a name='L88'></a><a href='#L88'>88</a>
154
- <a name='L89'></a><a href='#L89'>89</a>
155
- <a name='L90'></a><a href='#L90'>90</a>
156
- <a name='L91'></a><a href='#L91'>91</a>
157
- <a name='L92'></a><a href='#L92'>92</a>
158
- <a name='L93'></a><a href='#L93'>93</a>
159
- <a name='L94'></a><a href='#L94'>94</a>
160
- <a name='L95'></a><a href='#L95'>95</a>
161
- <a name='L96'></a><a href='#L96'>96</a>
162
- <a name='L97'></a><a href='#L97'>97</a>
163
- <a name='L98'></a><a href='#L98'>98</a>
164
- <a name='L99'></a><a href='#L99'>99</a>
165
- <a name='L100'></a><a href='#L100'>100</a>
166
- <a name='L101'></a><a href='#L101'>101</a>
167
- <a name='L102'></a><a href='#L102'>102</a>
168
- <a name='L103'></a><a href='#L103'>103</a>
169
- <a name='L104'></a><a href='#L104'>104</a>
170
- <a name='L105'></a><a href='#L105'>105</a>
171
- <a name='L106'></a><a href='#L106'>106</a>
172
- <a name='L107'></a><a href='#L107'>107</a>
173
- <a name='L108'></a><a href='#L108'>108</a>
174
- <a name='L109'></a><a href='#L109'>109</a>
175
- <a name='L110'></a><a href='#L110'>110</a>
176
- <a name='L111'></a><a href='#L111'>111</a>
177
- <a name='L112'></a><a href='#L112'>112</a>
178
- <a name='L113'></a><a href='#L113'>113</a>
179
- <a name='L114'></a><a href='#L114'>114</a>
180
- <a name='L115'></a><a href='#L115'>115</a>
181
- <a name='L116'></a><a href='#L116'>116</a>
182
- <a name='L117'></a><a href='#L117'>117</a>
183
- <a name='L118'></a><a href='#L118'>118</a>
184
- <a name='L119'></a><a href='#L119'>119</a>
185
- <a name='L120'></a><a href='#L120'>120</a>
186
- <a name='L121'></a><a href='#L121'>121</a>
187
- <a name='L122'></a><a href='#L122'>122</a>
188
- <a name='L123'></a><a href='#L123'>123</a>
189
- <a name='L124'></a><a href='#L124'>124</a>
190
- <a name='L125'></a><a href='#L125'>125</a>
191
- <a name='L126'></a><a href='#L126'>126</a>
192
- <a name='L127'></a><a href='#L127'>127</a>
193
- <a name='L128'></a><a href='#L128'>128</a>
194
- <a name='L129'></a><a href='#L129'>129</a>
195
- <a name='L130'></a><a href='#L130'>130</a>
196
- <a name='L131'></a><a href='#L131'>131</a>
197
- <a name='L132'></a><a href='#L132'>132</a>
198
- <a name='L133'></a><a href='#L133'>133</a>
199
- <a name='L134'></a><a href='#L134'>134</a>
200
- <a name='L135'></a><a href='#L135'>135</a>
201
- <a name='L136'></a><a href='#L136'>136</a>
202
- <a name='L137'></a><a href='#L137'>137</a>
203
- <a name='L138'></a><a href='#L138'>138</a>
204
- <a name='L139'></a><a href='#L139'>139</a>
205
- <a name='L140'></a><a href='#L140'>140</a>
206
- <a name='L141'></a><a href='#L141'>141</a>
207
- <a name='L142'></a><a href='#L142'>142</a>
208
- <a name='L143'></a><a href='#L143'>143</a>
209
- <a name='L144'></a><a href='#L144'>144</a>
210
- <a name='L145'></a><a href='#L145'>145</a>
211
- <a name='L146'></a><a href='#L146'>146</a>
212
- <a name='L147'></a><a href='#L147'>147</a>
213
- <a name='L148'></a><a href='#L148'>148</a>
214
- <a name='L149'></a><a href='#L149'>149</a>
215
- <a name='L150'></a><a href='#L150'>150</a>
216
- <a name='L151'></a><a href='#L151'>151</a>
217
- <a name='L152'></a><a href='#L152'>152</a>
218
- <a name='L153'></a><a href='#L153'>153</a>
219
- <a name='L154'></a><a href='#L154'>154</a>
220
- <a name='L155'></a><a href='#L155'>155</a>
221
- <a name='L156'></a><a href='#L156'>156</a>
222
- <a name='L157'></a><a href='#L157'>157</a>
223
- <a name='L158'></a><a href='#L158'>158</a>
224
- <a name='L159'></a><a href='#L159'>159</a>
225
- <a name='L160'></a><a href='#L160'>160</a>
226
- <a name='L161'></a><a href='#L161'>161</a>
227
- <a name='L162'></a><a href='#L162'>162</a>
228
- <a name='L163'></a><a href='#L163'>163</a>
229
- <a name='L164'></a><a href='#L164'>164</a>
230
- <a name='L165'></a><a href='#L165'>165</a>
231
- <a name='L166'></a><a href='#L166'>166</a>
232
- <a name='L167'></a><a href='#L167'>167</a>
233
- <a name='L168'></a><a href='#L168'>168</a>
234
- <a name='L169'></a><a href='#L169'>169</a>
235
- <a name='L170'></a><a href='#L170'>170</a>
236
- <a name='L171'></a><a href='#L171'>171</a>
237
- <a name='L172'></a><a href='#L172'>172</a>
238
- <a name='L173'></a><a href='#L173'>173</a>
239
- <a name='L174'></a><a href='#L174'>174</a>
240
- <a name='L175'></a><a href='#L175'>175</a>
241
- <a name='L176'></a><a href='#L176'>176</a>
242
- <a name='L177'></a><a href='#L177'>177</a>
243
- <a name='L178'></a><a href='#L178'>178</a>
244
- <a name='L179'></a><a href='#L179'>179</a>
245
- <a name='L180'></a><a href='#L180'>180</a>
246
- <a name='L181'></a><a href='#L181'>181</a>
247
- <a name='L182'></a><a href='#L182'>182</a>
248
- <a name='L183'></a><a href='#L183'>183</a>
249
- <a name='L184'></a><a href='#L184'>184</a>
250
- <a name='L185'></a><a href='#L185'>185</a>
251
- <a name='L186'></a><a href='#L186'>186</a>
252
- <a name='L187'></a><a href='#L187'>187</a>
253
- <a name='L188'></a><a href='#L188'>188</a>
254
- <a name='L189'></a><a href='#L189'>189</a>
255
- <a name='L190'></a><a href='#L190'>190</a>
256
- <a name='L191'></a><a href='#L191'>191</a>
257
- <a name='L192'></a><a href='#L192'>192</a>
258
- <a name='L193'></a><a href='#L193'>193</a>
259
- <a name='L194'></a><a href='#L194'>194</a>
260
- <a name='L195'></a><a href='#L195'>195</a>
261
- <a name='L196'></a><a href='#L196'>196</a>
262
- <a name='L197'></a><a href='#L197'>197</a>
263
- <a name='L198'></a><a href='#L198'>198</a>
264
- <a name='L199'></a><a href='#L199'>199</a>
265
- <a name='L200'></a><a href='#L200'>200</a>
266
- <a name='L201'></a><a href='#L201'>201</a>
267
- <a name='L202'></a><a href='#L202'>202</a>
268
- <a name='L203'></a><a href='#L203'>203</a>
269
- <a name='L204'></a><a href='#L204'>204</a>
270
- <a name='L205'></a><a href='#L205'>205</a>
271
- <a name='L206'></a><a href='#L206'>206</a>
272
- <a name='L207'></a><a href='#L207'>207</a>
273
- <a name='L208'></a><a href='#L208'>208</a>
274
- <a name='L209'></a><a href='#L209'>209</a>
275
- <a name='L210'></a><a href='#L210'>210</a>
276
- <a name='L211'></a><a href='#L211'>211</a>
277
- <a name='L212'></a><a href='#L212'>212</a>
278
- <a name='L213'></a><a href='#L213'>213</a>
279
- <a name='L214'></a><a href='#L214'>214</a>
280
- <a name='L215'></a><a href='#L215'>215</a>
281
- <a name='L216'></a><a href='#L216'>216</a>
282
- <a name='L217'></a><a href='#L217'>217</a>
283
- <a name='L218'></a><a href='#L218'>218</a>
284
- <a name='L219'></a><a href='#L219'>219</a>
285
- <a name='L220'></a><a href='#L220'>220</a>
286
- <a name='L221'></a><a href='#L221'>221</a>
287
- <a name='L222'></a><a href='#L222'>222</a>
288
- <a name='L223'></a><a href='#L223'>223</a>
289
- <a name='L224'></a><a href='#L224'>224</a>
290
- <a name='L225'></a><a href='#L225'>225</a>
291
- <a name='L226'></a><a href='#L226'>226</a>
292
- <a name='L227'></a><a href='#L227'>227</a>
293
- <a name='L228'></a><a href='#L228'>228</a>
294
- <a name='L229'></a><a href='#L229'>229</a>
295
- <a name='L230'></a><a href='#L230'>230</a>
296
- <a name='L231'></a><a href='#L231'>231</a>
297
- <a name='L232'></a><a href='#L232'>232</a>
298
- <a name='L233'></a><a href='#L233'>233</a>
299
- <a name='L234'></a><a href='#L234'>234</a>
300
- <a name='L235'></a><a href='#L235'>235</a>
301
- <a name='L236'></a><a href='#L236'>236</a>
302
- <a name='L237'></a><a href='#L237'>237</a>
303
- <a name='L238'></a><a href='#L238'>238</a>
304
- <a name='L239'></a><a href='#L239'>239</a>
305
- <a name='L240'></a><a href='#L240'>240</a>
306
- <a name='L241'></a><a href='#L241'>241</a>
307
- <a name='L242'></a><a href='#L242'>242</a>
308
- <a name='L243'></a><a href='#L243'>243</a>
309
- <a name='L244'></a><a href='#L244'>244</a>
310
- <a name='L245'></a><a href='#L245'>245</a>
311
- <a name='L246'></a><a href='#L246'>246</a>
312
- <a name='L247'></a><a href='#L247'>247</a>
313
- <a name='L248'></a><a href='#L248'>248</a>
314
- <a name='L249'></a><a href='#L249'>249</a>
315
- <a name='L250'></a><a href='#L250'>250</a>
316
- <a name='L251'></a><a href='#L251'>251</a>
317
- <a name='L252'></a><a href='#L252'>252</a>
318
- <a name='L253'></a><a href='#L253'>253</a>
319
- <a name='L254'></a><a href='#L254'>254</a>
320
- <a name='L255'></a><a href='#L255'>255</a>
321
- <a name='L256'></a><a href='#L256'>256</a>
322
- <a name='L257'></a><a href='#L257'>257</a>
323
- <a name='L258'></a><a href='#L258'>258</a>
324
- <a name='L259'></a><a href='#L259'>259</a>
325
- <a name='L260'></a><a href='#L260'>260</a>
326
- <a name='L261'></a><a href='#L261'>261</a>
327
- <a name='L262'></a><a href='#L262'>262</a>
328
- <a name='L263'></a><a href='#L263'>263</a>
329
- <a name='L264'></a><a href='#L264'>264</a>
330
- <a name='L265'></a><a href='#L265'>265</a>
331
- <a name='L266'></a><a href='#L266'>266</a>
332
- <a name='L267'></a><a href='#L267'>267</a>
333
- <a name='L268'></a><a href='#L268'>268</a>
334
- <a name='L269'></a><a href='#L269'>269</a>
335
- <a name='L270'></a><a href='#L270'>270</a>
336
- <a name='L271'></a><a href='#L271'>271</a>
337
- <a name='L272'></a><a href='#L272'>272</a>
338
- <a name='L273'></a><a href='#L273'>273</a>
339
- <a name='L274'></a><a href='#L274'>274</a>
340
- <a name='L275'></a><a href='#L275'>275</a>
341
- <a name='L276'></a><a href='#L276'>276</a>
342
- <a name='L277'></a><a href='#L277'>277</a>
343
- <a name='L278'></a><a href='#L278'>278</a>
344
- <a name='L279'></a><a href='#L279'>279</a>
345
- <a name='L280'></a><a href='#L280'>280</a>
346
- <a name='L281'></a><a href='#L281'>281</a>
347
- <a name='L282'></a><a href='#L282'>282</a>
348
- <a name='L283'></a><a href='#L283'>283</a>
349
- <a name='L284'></a><a href='#L284'>284</a>
350
- <a name='L285'></a><a href='#L285'>285</a>
351
- <a name='L286'></a><a href='#L286'>286</a>
352
- <a name='L287'></a><a href='#L287'>287</a>
353
- <a name='L288'></a><a href='#L288'>288</a>
354
- <a name='L289'></a><a href='#L289'>289</a>
355
- <a name='L290'></a><a href='#L290'>290</a>
356
- <a name='L291'></a><a href='#L291'>291</a>
357
- <a name='L292'></a><a href='#L292'>292</a>
358
- <a name='L293'></a><a href='#L293'>293</a>
359
- <a name='L294'></a><a href='#L294'>294</a>
360
- <a name='L295'></a><a href='#L295'>295</a>
361
- <a name='L296'></a><a href='#L296'>296</a>
362
- <a name='L297'></a><a href='#L297'>297</a>
363
- <a name='L298'></a><a href='#L298'>298</a>
364
- <a name='L299'></a><a href='#L299'>299</a>
365
- <a name='L300'></a><a href='#L300'>300</a>
366
- <a name='L301'></a><a href='#L301'>301</a>
367
- <a name='L302'></a><a href='#L302'>302</a>
368
- <a name='L303'></a><a href='#L303'>303</a>
369
- <a name='L304'></a><a href='#L304'>304</a>
370
- <a name='L305'></a><a href='#L305'>305</a>
371
- <a name='L306'></a><a href='#L306'>306</a>
372
- <a name='L307'></a><a href='#L307'>307</a>
373
- <a name='L308'></a><a href='#L308'>308</a>
374
- <a name='L309'></a><a href='#L309'>309</a>
375
- <a name='L310'></a><a href='#L310'>310</a>
376
- <a name='L311'></a><a href='#L311'>311</a>
377
- <a name='L312'></a><a href='#L312'>312</a>
378
- <a name='L313'></a><a href='#L313'>313</a>
379
- <a name='L314'></a><a href='#L314'>314</a>
380
- <a name='L315'></a><a href='#L315'>315</a>
381
- <a name='L316'></a><a href='#L316'>316</a>
382
- <a name='L317'></a><a href='#L317'>317</a></td><td class="line-coverage quiet"><span class="cline-any cline-no">&nbsp;</span>
383
- <span class="cline-any cline-no">&nbsp;</span>
384
- <span class="cline-any cline-no">&nbsp;</span>
385
- <span class="cline-any cline-no">&nbsp;</span>
386
- <span class="cline-any cline-no">&nbsp;</span>
387
- <span class="cline-any cline-no">&nbsp;</span>
388
- <span class="cline-any cline-no">&nbsp;</span>
389
- <span class="cline-any cline-no">&nbsp;</span>
390
- <span class="cline-any cline-no">&nbsp;</span>
391
- <span class="cline-any cline-no">&nbsp;</span>
392
- <span class="cline-any cline-no">&nbsp;</span>
393
- <span class="cline-any cline-no">&nbsp;</span>
394
- <span class="cline-any cline-no">&nbsp;</span>
395
- <span class="cline-any cline-no">&nbsp;</span>
396
- <span class="cline-any cline-no">&nbsp;</span>
397
- <span class="cline-any cline-no">&nbsp;</span>
398
- <span class="cline-any cline-no">&nbsp;</span>
399
- <span class="cline-any cline-no">&nbsp;</span>
400
- <span class="cline-any cline-no">&nbsp;</span>
401
- <span class="cline-any cline-no">&nbsp;</span>
402
- <span class="cline-any cline-no">&nbsp;</span>
403
- <span class="cline-any cline-no">&nbsp;</span>
404
- <span class="cline-any cline-no">&nbsp;</span>
405
- <span class="cline-any cline-no">&nbsp;</span>
406
- <span class="cline-any cline-no">&nbsp;</span>
407
- <span class="cline-any cline-no">&nbsp;</span>
408
- <span class="cline-any cline-no">&nbsp;</span>
409
- <span class="cline-any cline-no">&nbsp;</span>
410
- <span class="cline-any cline-no">&nbsp;</span>
411
- <span class="cline-any cline-no">&nbsp;</span>
412
- <span class="cline-any cline-no">&nbsp;</span>
413
- <span class="cline-any cline-no">&nbsp;</span>
414
- <span class="cline-any cline-no">&nbsp;</span>
415
- <span class="cline-any cline-no">&nbsp;</span>
416
- <span class="cline-any cline-no">&nbsp;</span>
417
- <span class="cline-any cline-no">&nbsp;</span>
418
- <span class="cline-any cline-no">&nbsp;</span>
419
- <span class="cline-any cline-no">&nbsp;</span>
420
- <span class="cline-any cline-no">&nbsp;</span>
421
- <span class="cline-any cline-no">&nbsp;</span>
422
- <span class="cline-any cline-no">&nbsp;</span>
423
- <span class="cline-any cline-no">&nbsp;</span>
424
- <span class="cline-any cline-no">&nbsp;</span>
425
- <span class="cline-any cline-no">&nbsp;</span>
426
- <span class="cline-any cline-no">&nbsp;</span>
427
- <span class="cline-any cline-no">&nbsp;</span>
428
- <span class="cline-any cline-no">&nbsp;</span>
429
- <span class="cline-any cline-no">&nbsp;</span>
430
- <span class="cline-any cline-no">&nbsp;</span>
431
- <span class="cline-any cline-no">&nbsp;</span>
432
- <span class="cline-any cline-no">&nbsp;</span>
433
- <span class="cline-any cline-no">&nbsp;</span>
434
- <span class="cline-any cline-no">&nbsp;</span>
435
- <span class="cline-any cline-no">&nbsp;</span>
436
- <span class="cline-any cline-no">&nbsp;</span>
437
- <span class="cline-any cline-no">&nbsp;</span>
438
- <span class="cline-any cline-no">&nbsp;</span>
439
- <span class="cline-any cline-no">&nbsp;</span>
440
- <span class="cline-any cline-no">&nbsp;</span>
441
- <span class="cline-any cline-no">&nbsp;</span>
442
- <span class="cline-any cline-no">&nbsp;</span>
443
- <span class="cline-any cline-no">&nbsp;</span>
444
- <span class="cline-any cline-no">&nbsp;</span>
445
- <span class="cline-any cline-no">&nbsp;</span>
446
- <span class="cline-any cline-no">&nbsp;</span>
447
- <span class="cline-any cline-no">&nbsp;</span>
448
- <span class="cline-any cline-no">&nbsp;</span>
449
- <span class="cline-any cline-no">&nbsp;</span>
450
- <span class="cline-any cline-no">&nbsp;</span>
451
- <span class="cline-any cline-no">&nbsp;</span>
452
- <span class="cline-any cline-no">&nbsp;</span>
453
- <span class="cline-any cline-no">&nbsp;</span>
454
- <span class="cline-any cline-no">&nbsp;</span>
455
- <span class="cline-any cline-no">&nbsp;</span>
456
- <span class="cline-any cline-no">&nbsp;</span>
457
- <span class="cline-any cline-no">&nbsp;</span>
458
- <span class="cline-any cline-no">&nbsp;</span>
459
- <span class="cline-any cline-no">&nbsp;</span>
460
- <span class="cline-any cline-no">&nbsp;</span>
461
- <span class="cline-any cline-no">&nbsp;</span>
462
- <span class="cline-any cline-no">&nbsp;</span>
463
- <span class="cline-any cline-no">&nbsp;</span>
464
- <span class="cline-any cline-no">&nbsp;</span>
465
- <span class="cline-any cline-no">&nbsp;</span>
466
- <span class="cline-any cline-no">&nbsp;</span>
467
- <span class="cline-any cline-no">&nbsp;</span>
468
- <span class="cline-any cline-no">&nbsp;</span>
469
- <span class="cline-any cline-no">&nbsp;</span>
470
- <span class="cline-any cline-no">&nbsp;</span>
471
- <span class="cline-any cline-no">&nbsp;</span>
472
- <span class="cline-any cline-no">&nbsp;</span>
473
- <span class="cline-any cline-no">&nbsp;</span>
474
- <span class="cline-any cline-no">&nbsp;</span>
475
- <span class="cline-any cline-no">&nbsp;</span>
476
- <span class="cline-any cline-no">&nbsp;</span>
477
- <span class="cline-any cline-no">&nbsp;</span>
478
- <span class="cline-any cline-no">&nbsp;</span>
479
- <span class="cline-any cline-no">&nbsp;</span>
480
- <span class="cline-any cline-no">&nbsp;</span>
481
- <span class="cline-any cline-no">&nbsp;</span>
482
- <span class="cline-any cline-no">&nbsp;</span>
483
- <span class="cline-any cline-no">&nbsp;</span>
484
- <span class="cline-any cline-no">&nbsp;</span>
485
- <span class="cline-any cline-no">&nbsp;</span>
486
- <span class="cline-any cline-no">&nbsp;</span>
487
- <span class="cline-any cline-no">&nbsp;</span>
488
- <span class="cline-any cline-no">&nbsp;</span>
489
- <span class="cline-any cline-no">&nbsp;</span>
490
- <span class="cline-any cline-no">&nbsp;</span>
491
- <span class="cline-any cline-no">&nbsp;</span>
492
- <span class="cline-any cline-no">&nbsp;</span>
493
- <span class="cline-any cline-no">&nbsp;</span>
494
- <span class="cline-any cline-no">&nbsp;</span>
495
- <span class="cline-any cline-no">&nbsp;</span>
496
- <span class="cline-any cline-no">&nbsp;</span>
497
- <span class="cline-any cline-no">&nbsp;</span>
498
- <span class="cline-any cline-no">&nbsp;</span>
499
- <span class="cline-any cline-no">&nbsp;</span>
500
- <span class="cline-any cline-no">&nbsp;</span>
501
- <span class="cline-any cline-no">&nbsp;</span>
502
- <span class="cline-any cline-no">&nbsp;</span>
503
- <span class="cline-any cline-no">&nbsp;</span>
504
- <span class="cline-any cline-no">&nbsp;</span>
505
- <span class="cline-any cline-no">&nbsp;</span>
506
- <span class="cline-any cline-no">&nbsp;</span>
507
- <span class="cline-any cline-no">&nbsp;</span>
508
- <span class="cline-any cline-no">&nbsp;</span>
509
- <span class="cline-any cline-no">&nbsp;</span>
510
- <span class="cline-any cline-no">&nbsp;</span>
511
- <span class="cline-any cline-no">&nbsp;</span>
512
- <span class="cline-any cline-no">&nbsp;</span>
513
- <span class="cline-any cline-no">&nbsp;</span>
514
- <span class="cline-any cline-no">&nbsp;</span>
515
- <span class="cline-any cline-no">&nbsp;</span>
516
- <span class="cline-any cline-no">&nbsp;</span>
517
- <span class="cline-any cline-no">&nbsp;</span>
518
- <span class="cline-any cline-no">&nbsp;</span>
519
- <span class="cline-any cline-no">&nbsp;</span>
520
- <span class="cline-any cline-no">&nbsp;</span>
521
- <span class="cline-any cline-no">&nbsp;</span>
522
- <span class="cline-any cline-no">&nbsp;</span>
523
- <span class="cline-any cline-no">&nbsp;</span>
524
- <span class="cline-any cline-no">&nbsp;</span>
525
- <span class="cline-any cline-no">&nbsp;</span>
526
- <span class="cline-any cline-no">&nbsp;</span>
527
- <span class="cline-any cline-no">&nbsp;</span>
528
- <span class="cline-any cline-no">&nbsp;</span>
529
- <span class="cline-any cline-no">&nbsp;</span>
530
- <span class="cline-any cline-no">&nbsp;</span>
531
- <span class="cline-any cline-no">&nbsp;</span>
532
- <span class="cline-any cline-no">&nbsp;</span>
533
- <span class="cline-any cline-no">&nbsp;</span>
534
- <span class="cline-any cline-no">&nbsp;</span>
535
- <span class="cline-any cline-no">&nbsp;</span>
536
- <span class="cline-any cline-no">&nbsp;</span>
537
- <span class="cline-any cline-no">&nbsp;</span>
538
- <span class="cline-any cline-no">&nbsp;</span>
539
- <span class="cline-any cline-no">&nbsp;</span>
540
- <span class="cline-any cline-no">&nbsp;</span>
541
- <span class="cline-any cline-no">&nbsp;</span>
542
- <span class="cline-any cline-no">&nbsp;</span>
543
- <span class="cline-any cline-no">&nbsp;</span>
544
- <span class="cline-any cline-no">&nbsp;</span>
545
- <span class="cline-any cline-no">&nbsp;</span>
546
- <span class="cline-any cline-no">&nbsp;</span>
547
- <span class="cline-any cline-no">&nbsp;</span>
548
- <span class="cline-any cline-no">&nbsp;</span>
549
- <span class="cline-any cline-no">&nbsp;</span>
550
- <span class="cline-any cline-no">&nbsp;</span>
551
- <span class="cline-any cline-no">&nbsp;</span>
552
- <span class="cline-any cline-no">&nbsp;</span>
553
- <span class="cline-any cline-no">&nbsp;</span>
554
- <span class="cline-any cline-no">&nbsp;</span>
555
- <span class="cline-any cline-no">&nbsp;</span>
556
- <span class="cline-any cline-no">&nbsp;</span>
557
- <span class="cline-any cline-no">&nbsp;</span>
558
- <span class="cline-any cline-no">&nbsp;</span>
559
- <span class="cline-any cline-no">&nbsp;</span>
560
- <span class="cline-any cline-no">&nbsp;</span>
561
- <span class="cline-any cline-no">&nbsp;</span>
562
- <span class="cline-any cline-no">&nbsp;</span>
563
- <span class="cline-any cline-no">&nbsp;</span>
564
- <span class="cline-any cline-no">&nbsp;</span>
565
- <span class="cline-any cline-no">&nbsp;</span>
566
- <span class="cline-any cline-no">&nbsp;</span>
567
- <span class="cline-any cline-no">&nbsp;</span>
568
- <span class="cline-any cline-no">&nbsp;</span>
569
- <span class="cline-any cline-no">&nbsp;</span>
570
- <span class="cline-any cline-no">&nbsp;</span>
571
- <span class="cline-any cline-no">&nbsp;</span>
572
- <span class="cline-any cline-no">&nbsp;</span>
573
- <span class="cline-any cline-no">&nbsp;</span>
574
- <span class="cline-any cline-no">&nbsp;</span>
575
- <span class="cline-any cline-no">&nbsp;</span>
576
- <span class="cline-any cline-no">&nbsp;</span>
577
- <span class="cline-any cline-no">&nbsp;</span>
578
- <span class="cline-any cline-no">&nbsp;</span>
579
- <span class="cline-any cline-no">&nbsp;</span>
580
- <span class="cline-any cline-no">&nbsp;</span>
581
- <span class="cline-any cline-no">&nbsp;</span>
582
- <span class="cline-any cline-no">&nbsp;</span>
583
- <span class="cline-any cline-no">&nbsp;</span>
584
- <span class="cline-any cline-no">&nbsp;</span>
585
- <span class="cline-any cline-no">&nbsp;</span>
586
- <span class="cline-any cline-no">&nbsp;</span>
587
- <span class="cline-any cline-no">&nbsp;</span>
588
- <span class="cline-any cline-no">&nbsp;</span>
589
- <span class="cline-any cline-no">&nbsp;</span>
590
- <span class="cline-any cline-no">&nbsp;</span>
591
- <span class="cline-any cline-no">&nbsp;</span>
592
- <span class="cline-any cline-no">&nbsp;</span>
593
- <span class="cline-any cline-no">&nbsp;</span>
594
- <span class="cline-any cline-no">&nbsp;</span>
595
- <span class="cline-any cline-no">&nbsp;</span>
596
- <span class="cline-any cline-no">&nbsp;</span>
597
- <span class="cline-any cline-no">&nbsp;</span>
598
- <span class="cline-any cline-no">&nbsp;</span>
599
- <span class="cline-any cline-no">&nbsp;</span>
600
- <span class="cline-any cline-no">&nbsp;</span>
601
- <span class="cline-any cline-no">&nbsp;</span>
602
- <span class="cline-any cline-no">&nbsp;</span>
603
- <span class="cline-any cline-no">&nbsp;</span>
604
- <span class="cline-any cline-no">&nbsp;</span>
605
- <span class="cline-any cline-no">&nbsp;</span>
606
- <span class="cline-any cline-no">&nbsp;</span>
607
- <span class="cline-any cline-no">&nbsp;</span>
608
- <span class="cline-any cline-no">&nbsp;</span>
609
- <span class="cline-any cline-no">&nbsp;</span>
610
- <span class="cline-any cline-no">&nbsp;</span>
611
- <span class="cline-any cline-no">&nbsp;</span>
612
- <span class="cline-any cline-no">&nbsp;</span>
613
- <span class="cline-any cline-no">&nbsp;</span>
614
- <span class="cline-any cline-no">&nbsp;</span>
615
- <span class="cline-any cline-no">&nbsp;</span>
616
- <span class="cline-any cline-no">&nbsp;</span>
617
- <span class="cline-any cline-no">&nbsp;</span>
618
- <span class="cline-any cline-no">&nbsp;</span>
619
- <span class="cline-any cline-no">&nbsp;</span>
620
- <span class="cline-any cline-no">&nbsp;</span>
621
- <span class="cline-any cline-no">&nbsp;</span>
622
- <span class="cline-any cline-no">&nbsp;</span>
623
- <span class="cline-any cline-no">&nbsp;</span>
624
- <span class="cline-any cline-no">&nbsp;</span>
625
- <span class="cline-any cline-no">&nbsp;</span>
626
- <span class="cline-any cline-no">&nbsp;</span>
627
- <span class="cline-any cline-no">&nbsp;</span>
628
- <span class="cline-any cline-no">&nbsp;</span>
629
- <span class="cline-any cline-no">&nbsp;</span>
630
- <span class="cline-any cline-no">&nbsp;</span>
631
- <span class="cline-any cline-no">&nbsp;</span>
632
- <span class="cline-any cline-no">&nbsp;</span>
633
- <span class="cline-any cline-no">&nbsp;</span>
634
- <span class="cline-any cline-no">&nbsp;</span>
635
- <span class="cline-any cline-no">&nbsp;</span>
636
- <span class="cline-any cline-no">&nbsp;</span>
637
- <span class="cline-any cline-no">&nbsp;</span>
638
- <span class="cline-any cline-no">&nbsp;</span>
639
- <span class="cline-any cline-no">&nbsp;</span>
640
- <span class="cline-any cline-no">&nbsp;</span>
641
- <span class="cline-any cline-no">&nbsp;</span>
642
- <span class="cline-any cline-no">&nbsp;</span>
643
- <span class="cline-any cline-no">&nbsp;</span>
644
- <span class="cline-any cline-no">&nbsp;</span>
645
- <span class="cline-any cline-no">&nbsp;</span>
646
- <span class="cline-any cline-no">&nbsp;</span>
647
- <span class="cline-any cline-no">&nbsp;</span>
648
- <span class="cline-any cline-no">&nbsp;</span>
649
- <span class="cline-any cline-no">&nbsp;</span>
650
- <span class="cline-any cline-no">&nbsp;</span>
651
- <span class="cline-any cline-no">&nbsp;</span>
652
- <span class="cline-any cline-no">&nbsp;</span>
653
- <span class="cline-any cline-no">&nbsp;</span>
654
- <span class="cline-any cline-no">&nbsp;</span>
655
- <span class="cline-any cline-no">&nbsp;</span>
656
- <span class="cline-any cline-no">&nbsp;</span>
657
- <span class="cline-any cline-no">&nbsp;</span>
658
- <span class="cline-any cline-no">&nbsp;</span>
659
- <span class="cline-any cline-no">&nbsp;</span>
660
- <span class="cline-any cline-no">&nbsp;</span>
661
- <span class="cline-any cline-no">&nbsp;</span>
662
- <span class="cline-any cline-no">&nbsp;</span>
663
- <span class="cline-any cline-no">&nbsp;</span>
664
- <span class="cline-any cline-no">&nbsp;</span>
665
- <span class="cline-any cline-no">&nbsp;</span>
666
- <span class="cline-any cline-no">&nbsp;</span>
667
- <span class="cline-any cline-no">&nbsp;</span>
668
- <span class="cline-any cline-no">&nbsp;</span>
669
- <span class="cline-any cline-no">&nbsp;</span>
670
- <span class="cline-any cline-no">&nbsp;</span>
671
- <span class="cline-any cline-no">&nbsp;</span>
672
- <span class="cline-any cline-no">&nbsp;</span>
673
- <span class="cline-any cline-no">&nbsp;</span>
674
- <span class="cline-any cline-no">&nbsp;</span>
675
- <span class="cline-any cline-no">&nbsp;</span>
676
- <span class="cline-any cline-no">&nbsp;</span>
677
- <span class="cline-any cline-no">&nbsp;</span>
678
- <span class="cline-any cline-no">&nbsp;</span>
679
- <span class="cline-any cline-no">&nbsp;</span>
680
- <span class="cline-any cline-no">&nbsp;</span>
681
- <span class="cline-any cline-no">&nbsp;</span>
682
- <span class="cline-any cline-no">&nbsp;</span>
683
- <span class="cline-any cline-no">&nbsp;</span>
684
- <span class="cline-any cline-no">&nbsp;</span>
685
- <span class="cline-any cline-no">&nbsp;</span>
686
- <span class="cline-any cline-no">&nbsp;</span>
687
- <span class="cline-any cline-no">&nbsp;</span>
688
- <span class="cline-any cline-no">&nbsp;</span>
689
- <span class="cline-any cline-no">&nbsp;</span>
690
- <span class="cline-any cline-no">&nbsp;</span>
691
- <span class="cline-any cline-no">&nbsp;</span>
692
- <span class="cline-any cline-no">&nbsp;</span>
693
- <span class="cline-any cline-no">&nbsp;</span>
694
- <span class="cline-any cline-no">&nbsp;</span>
695
- <span class="cline-any cline-no">&nbsp;</span>
696
- <span class="cline-any cline-no">&nbsp;</span>
697
- <span class="cline-any cline-no">&nbsp;</span>
698
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js"><span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" ><span class="branch-0 cbranch-no" title="branch not covered" >import _ from 'lodash'</span></span></span>
699
- <span class="cstat-no" title="statement not covered" >import moment from 'moment'</span>
700
- <span class="cstat-no" title="statement not covered" >import { unitConverters, SortOrder, GridSource, Grid1D, TiledGrid, SubGrid } from './grid.js'</span>
701
- <span class="cstat-no" title="statement not covered" ></span>
702
- <span class="cstat-no" title="statement not covered" >// computes how many equidistant points are required to generate</span>
703
- <span class="cstat-no" title="statement not covered" >// points at most every 'precision' degrees</span>
704
- <span class="cstat-no" title="statement not covered" >function additionalPointsNeeded (lat, lon1, lon2, precision) {</span>
705
- <span class="cstat-no" title="statement not covered" > /*</span>
706
- <span class="cstat-no" title="statement not covered" > const p0 = [lon1, lat]</span>
707
- <span class="cstat-no" title="statement not covered" > const p1 = [lon2, lat]</span>
708
- <span class="cstat-no" title="statement not covered" > const dist = distance(p0, p1, { units: 'kilometers' })</span>
709
- <span class="cstat-no" title="statement not covered" > */</span>
710
- <span class="cstat-no" title="statement not covered" ></span>
711
- <span class="cstat-no" title="statement not covered" > const dist = lon2 - lon1</span>
712
- <span class="cstat-no" title="statement not covered" > const num = Math.ceil(dist / precision) - 1</span>
713
- <span class="cstat-no" title="statement not covered" > return Math.max(0, num)</span>
714
- <span class="cstat-no" title="statement not covered" >}</span>
715
- <span class="cstat-no" title="statement not covered" ></span>
716
- <span class="cstat-no" title="statement not covered" >// compute a query polygon where we make sure that</span>
717
- <span class="cstat-no" title="statement not covered" >// we'll have a point at most every 'precision' degrees</span>
718
- <span class="cstat-no" title="statement not covered" >// on longitudinal segments</span>
719
- <span class="cstat-no" title="statement not covered" >function makeMongoPolygon (bbox, precision) {</span>
720
- <span class="cstat-no" title="statement not covered" > const minLatPoints = additionalPointsNeeded(bbox[0], bbox[1], bbox[3], precision)</span>
721
- <span class="cstat-no" title="statement not covered" > const maxLatPoints = additionalPointsNeeded(bbox[2], bbox[1], bbox[3], precision)</span>
722
- <span class="cstat-no" title="statement not covered" > const deltaLon = bbox[3] - bbox[1]</span>
723
- <span class="cstat-no" title="statement not covered" ></span>
724
- <span class="cstat-no" title="statement not covered" > const polygon = []</span>
725
- <span class="cstat-no" title="statement not covered" > for (let i = 0; i &lt; minLatPoints + 2; ++i) {</span>
726
- <span class="cstat-no" title="statement not covered" > const lon = bbox[1] + (i / (minLatPoints + 1)) * deltaLon</span>
727
- <span class="cstat-no" title="statement not covered" > polygon.push([lon, bbox[0]])</span>
728
- <span class="cstat-no" title="statement not covered" > }</span>
729
- <span class="cstat-no" title="statement not covered" ></span>
730
- <span class="cstat-no" title="statement not covered" > for (let i = 0; i &lt; maxLatPoints + 2; ++i) {</span>
731
- <span class="cstat-no" title="statement not covered" > const lon = bbox[3] - (i / (maxLatPoints + 1)) * deltaLon</span>
732
- <span class="cstat-no" title="statement not covered" > polygon.push([lon, bbox[2]])</span>
733
- <span class="cstat-no" title="statement not covered" > }</span>
734
- <span class="cstat-no" title="statement not covered" ></span>
735
- <span class="cstat-no" title="statement not covered" > // closing point</span>
736
- <span class="cstat-no" title="statement not covered" > polygon.push([bbox[1], bbox[0]])</span>
737
- <span class="cstat-no" title="statement not covered" ></span>
738
- <span class="cstat-no" title="statement not covered" > return polygon</span>
739
- <span class="cstat-no" title="statement not covered" >}</span>
740
- <span class="cstat-no" title="statement not covered" ></span>
741
- <span class="cstat-no" title="statement not covered" >function tile2key (x, y) {</span>
742
- <span class="cstat-no" title="statement not covered" > return x * 4294967296 + y</span>
743
- <span class="cstat-no" title="statement not covered" >}</span>
744
- <span class="cstat-no" title="statement not covered" ></span>
745
- <span class="cstat-no" title="statement not covered" >function key2tile (k) {</span>
746
- <span class="cstat-no" title="statement not covered" > const x = Math.floor(k / 4294967296)</span>
747
- <span class="cstat-no" title="statement not covered" > return [x, k - (x * 4294967296)]</span>
748
- <span class="cstat-no" title="statement not covered" >}</span>
749
- <span class="cstat-no" title="statement not covered" ></span>
750
- <span class="cstat-no" title="statement not covered" >export class WeacastGridSource extends GridSource {</span>
751
- <span class="cstat-no" title="statement not covered" > static getKey () {</span>
752
- <span class="cstat-no" title="statement not covered" > return 'weacast'</span>
753
- <span class="cstat-no" title="statement not covered" > }</span>
754
- <span class="cstat-no" title="statement not covered" ></span>
755
- <span class="cstat-no" title="statement not covered" > constructor (options) {</span>
756
- <span class="cstat-no" title="statement not covered" > super(options)</span>
757
- <span class="cstat-no" title="statement not covered" ></span>
758
- <span class="cstat-no" title="statement not covered" > this.api = options.weacastApi</span>
759
- <span class="cstat-no" title="statement not covered" > this.usable = false</span>
760
- <span class="cstat-no" title="statement not covered" > }</span>
761
- <span class="cstat-no" title="statement not covered" ></span>
762
- <span class="cstat-no" title="statement not covered" > getBBox () {</span>
763
- <span class="cstat-no" title="statement not covered" > return this.usable ? [this.minMaxLat[0], this.minMaxLon[0], this.minMaxLat[1], this.minMaxLon[1]] : null</span>
764
- <span class="cstat-no" title="statement not covered" > }</span>
765
- <span class="cstat-no" title="statement not covered" ></span>
766
- <span class="cstat-no" title="statement not covered" > getDataBounds () {</span>
767
- <span class="cstat-no" title="statement not covered" > return this.usable ? this.minMaxVal : null</span>
768
- <span class="cstat-no" title="statement not covered" > }</span>
769
- <span class="cstat-no" title="statement not covered" ></span>
770
- <span class="cstat-no" title="statement not covered" > async setup (config) {</span>
771
- <span class="cstat-no" title="statement not covered" > this.usable = false</span>
772
- <span class="cstat-no" title="statement not covered" > ++this.sourceKey</span>
773
- <span class="cstat-no" title="statement not covered" ></span>
774
- <span class="cstat-no" title="statement not covered" > if (!this.api) return</span>
775
- <span class="cstat-no" title="statement not covered" ></span>
776
- <span class="cstat-no" title="statement not covered" > // find the model</span>
777
- <span class="cstat-no" title="statement not covered" > const model = this.api.models.find(model =&gt; model.name === config.model)</span>
778
- <span class="cstat-no" title="statement not covered" > if (!model) return</span>
779
- <span class="cstat-no" title="statement not covered" ></span>
780
- <span class="cstat-no" title="statement not covered" > this.converter = unitConverters[config.converter]</span>
781
- <span class="cstat-no" title="statement not covered" > this.time = moment(config.forecastTime).utc().format()</span>
782
- <span class="cstat-no" title="statement not covered" > this.service = config.model + '/' + config.element</span>
783
- <span class="cstat-no" title="statement not covered" > this.lonResolution = model.tileResolution[0]</span>
784
- <span class="cstat-no" title="statement not covered" ></span>
785
- <span class="cstat-no" title="statement not covered" > this.useCache = _.get(config, 'useCache', true)</span>
786
- <span class="cstat-no" title="statement not covered" > this.maxCacheSize = _.get(config, 'maxCacheSize', 0)</span>
787
- <span class="cstat-no" title="statement not covered" > if (this.useCache) {</span>
788
- <span class="cstat-no" title="statement not covered" > this.tileCache = new Map()</span>
789
- <span class="cstat-no" title="statement not covered" > this.tileCounter = 0</span>
790
- <span class="cstat-no" title="statement not covered" ></span>
791
- <span class="cstat-no" title="statement not covered" > this.tileOrigin = [model.origin[1], model.origin[0]]</span>
792
- <span class="cstat-no" title="statement not covered" > this.tileSize = [model.tileResolution[1], model.tileResolution[0]]</span>
793
- <span class="cstat-no" title="statement not covered" > this.wrapLon = model.bounds[2] &gt; 180.0</span>
794
- <span class="cstat-no" title="statement not covered" > this.maxTileX = ((model.bounds[2] - model.bounds[0]) / model.tileResolution[0]) - 1</span>
795
- <span class="cstat-no" title="statement not covered" > this.maxTileY = ((model.bounds[3] - model.bounds[1]) / model.tileResolution[1]) - 1</span>
796
- <span class="cstat-no" title="statement not covered" > } else {</span>
797
- <span class="cstat-no" title="statement not covered" > this.tileCache = null</span>
798
- <span class="cstat-no" title="statement not covered" > }</span>
799
- <span class="cstat-no" title="statement not covered" ></span>
800
- <span class="cstat-no" title="statement not covered" > this.minMaxLat = [model.bounds[1], model.bounds[3]]</span>
801
- <span class="cstat-no" title="statement not covered" > // Internal tile management requires longitude in [-180, 180]</span>
802
- <span class="cstat-no" title="statement not covered" > const wrapLongitude = (model.bounds[2] === 360)</span>
803
- <span class="cstat-no" title="statement not covered" > this.minMaxLon = [wrapLongitude ? -180 : model.bounds[0], wrapLongitude ? 180 : model.bounds[2]]</span>
804
- <span class="cstat-no" title="statement not covered" > this.minMaxVal = null</span>
805
- <span class="cstat-no" title="statement not covered" ></span>
806
- <span class="cstat-no" title="statement not covered" > const query = {</span>
807
- <span class="cstat-no" title="statement not covered" > time: this.time,</span>
808
- <span class="cstat-no" title="statement not covered" > $select: ['forecastTime', 'minValue', 'maxValue'],</span>
809
- <span class="cstat-no" title="statement not covered" > $paginate: false</span>
810
- <span class="cstat-no" title="statement not covered" > }</span>
811
- <span class="cstat-no" title="statement not covered" ></span>
812
- <span class="cstat-no" title="statement not covered" > const results = await this.api.getService(this.service).find({ query })</span>
813
- <span class="cstat-no" title="statement not covered" > if (results.length &gt; 0) this.minMaxVal = [results[0].minValue, results[0].maxValue]</span>
814
- <span class="cstat-no" title="statement not covered" ></span>
815
- <span class="cstat-no" title="statement not covered" > this.usable = true</span>
816
- <span class="cstat-no" title="statement not covered" ></span>
817
- <span class="cstat-no" title="statement not covered" > this.dataChanged()</span>
818
- <span class="cstat-no" title="statement not covered" > }</span>
819
- <span class="cstat-no" title="statement not covered" ></span>
820
- <span class="cstat-no" title="statement not covered" > fetch (abort, bbox, resolution) {</span>
821
- <span class="cstat-no" title="statement not covered" > if (!this.usable) { return null }</span>
822
- <span class="cstat-no" title="statement not covered" ></span>
823
- <span class="cstat-no" title="statement not covered" > return this.useCache</span>
824
- <span class="cstat-no" title="statement not covered" > ? this.fetchWithCache(abort, bbox, resolution)</span>
825
- <span class="cstat-no" title="statement not covered" > : this.fetchWithoutCache(abort, bbox, resolution)</span>
826
- <span class="cstat-no" title="statement not covered" > }</span>
827
- <span class="cstat-no" title="statement not covered" ></span>
828
- <span class="cstat-no" title="statement not covered" > async fetchWithCache (abort, bbox, resolution) {</span>
829
- <span class="cstat-no" title="statement not covered" > // compute which weacast tile(s) we're going to hit</span>
830
- <span class="cstat-no" title="statement not covered" > const minLon = this.wrapLon ? (bbox[1] &lt; 0 ? bbox[1] + 360.0 : bbox[1]) : bbox[1]</span>
831
- <span class="cstat-no" title="statement not covered" > const maxLon = this.wrapLon ? (bbox[3] &lt; 0 ? bbox[3] + 360.0 : bbox[3]) : bbox[3]</span>
832
- <span class="cstat-no" title="statement not covered" ></span>
833
- <span class="cstat-no" title="statement not covered" > const e = Math.min(Math.max(Math.floor((maxLon - this.tileOrigin[1]) / this.tileSize[1]), 0), this.maxTileX)</span>
834
- <span class="cstat-no" title="statement not covered" > const w = Math.min(Math.max(Math.floor((minLon - this.tileOrigin[1]) / this.tileSize[1]), 0), this.maxTileX)</span>
835
- <span class="cstat-no" title="statement not covered" > const n = Math.min(Math.max(Math.floor((this.tileOrigin[0] - bbox[2]) / this.tileSize[0]), 0), this.maxTileY)</span>
836
- <span class="cstat-no" title="statement not covered" > const s = Math.min(Math.max(Math.floor((this.tileOrigin[0] - bbox[0]) / this.tileSize[0]), 0), this.maxTileY)</span>
837
- <span class="cstat-no" title="statement not covered" ></span>
838
- <span class="cstat-no" title="statement not covered" > const hits = []</span>
839
- <span class="cstat-no" title="statement not covered" > for (let j = n; j &lt;= s; ++j) {</span>
840
- <span class="cstat-no" title="statement not covered" > if (w &gt; e) {</span>
841
- <span class="cstat-no" title="statement not covered" > for (let i = 0; i &lt;= e; ++i) hits.push(tile2key(i, j))</span>
842
- <span class="cstat-no" title="statement not covered" > for (let i = w; i &lt;= this.maxTileX; ++i) hits.push(tile2key(i, j))</span>
843
- <span class="cstat-no" title="statement not covered" > } else {</span>
844
- <span class="cstat-no" title="statement not covered" > for (let i = w; i &lt;= e; ++i) hits.push(tile2key(i, j))</span>
845
- <span class="cstat-no" title="statement not covered" > }</span>
846
- <span class="cstat-no" title="statement not covered" > }</span>
847
- <span class="cstat-no" title="statement not covered" ></span>
848
- <span class="cstat-no" title="statement not covered" > const waits = []</span>
849
- <span class="cstat-no" title="statement not covered" > const grids = []</span>
850
- <span class="cstat-no" title="statement not covered" > const requests = []</span>
851
- <span class="cstat-no" title="statement not covered" ></span>
852
- <span class="cstat-no" title="statement not covered" > // lookup in cache for stuff we know about those tiles</span>
853
- <span class="cstat-no" title="statement not covered" > const entries = hits.map(key =&gt; this.tileCache.get(key))</span>
854
- <span class="cstat-no" title="statement not covered" > for (let i = 0; i &lt; hits.length; ++i) {</span>
855
- <span class="cstat-no" title="statement not covered" > if (!entries[i]) {</span>
856
- <span class="cstat-no" title="statement not covered" > // nothing in cache so far, request must be made</span>
857
- <span class="cstat-no" title="statement not covered" > requests.push(hits[i])</span>
858
- <span class="cstat-no" title="statement not covered" > } else {</span>
859
- <span class="cstat-no" title="statement not covered" > // cache entry for tile</span>
860
- <span class="cstat-no" title="statement not covered" > if (entries[i].grid) {</span>
861
- <span class="cstat-no" title="statement not covered" > // grid data available</span>
862
- <span class="cstat-no" title="statement not covered" > grids.push(entries[i].grid)</span>
863
- <span class="cstat-no" title="statement not covered" > } else {</span>
864
- <span class="cstat-no" title="statement not covered" > // request in progress</span>
865
- <span class="cstat-no" title="statement not covered" > waits.push(entries[i].request)</span>
866
- <span class="cstat-no" title="statement not covered" > }</span>
867
- <span class="cstat-no" title="statement not covered" > }</span>
868
- <span class="cstat-no" title="statement not covered" > }</span>
869
- <span class="cstat-no" title="statement not covered" ></span>
870
- <span class="cstat-no" title="statement not covered" > const sourceKey = this.sourceKey</span>
871
- <span class="cstat-no" title="statement not covered" ></span>
872
- <span class="cstat-no" title="statement not covered" > // issue required request</span>
873
- <span class="cstat-no" title="statement not covered" > if (requests.length) {</span>
874
- <span class="cstat-no" title="statement not covered" > // generate a query with points intersecting required tiles</span>
875
- <span class="cstat-no" title="statement not covered" > const points = []</span>
876
- <span class="cstat-no" title="statement not covered" > const offset = [this.tileSize[1] * 0.5, this.tileSize[0] * 0.5]</span>
877
- <span class="cstat-no" title="statement not covered" > for (let i = 0; i &lt; requests.length; ++i) {</span>
878
- <span class="cstat-no" title="statement not covered" > const [x, y] = key2tile(requests[i])</span>
879
- <span class="cstat-no" title="statement not covered" > let tilex = this.tileOrigin[1] + (this.tileSize[1] * x)</span>
880
- <span class="cstat-no" title="statement not covered" > const tiley = this.tileOrigin[0] - (this.tileSize[0] * y)</span>
881
- <span class="cstat-no" title="statement not covered" ></span>
882
- <span class="cstat-no" title="statement not covered" > if (tilex &gt;= 180) tilex -= 360.0</span>
883
- <span class="cstat-no" title="statement not covered" ></span>
884
- <span class="cstat-no" title="statement not covered" > points.push([tilex + offset[0], tiley - offset[1]])</span>
885
- <span class="cstat-no" title="statement not covered" > }</span>
886
- <span class="cstat-no" title="statement not covered" > const query = {</span>
887
- <span class="cstat-no" title="statement not covered" > time: this.time,</span>
888
- <span class="cstat-no" title="statement not covered" > $select: ['forecastTime', 'data', 'geometry', 'size', 'x', 'y'],</span>
889
- <span class="cstat-no" title="statement not covered" > $paginate: false,</span>
890
- <span class="cstat-no" title="statement not covered" > geometry: {</span>
891
- <span class="cstat-no" title="statement not covered" > $geoIntersects: {</span>
892
- <span class="cstat-no" title="statement not covered" > $geometry: {</span>
893
- <span class="cstat-no" title="statement not covered" > type: 'MultiPoint',</span>
894
- <span class="cstat-no" title="statement not covered" > coordinates: points</span>
895
- <span class="cstat-no" title="statement not covered" > }</span>
896
- <span class="cstat-no" title="statement not covered" > }</span>
897
- <span class="cstat-no" title="statement not covered" > }</span>
898
- <span class="cstat-no" title="statement not covered" > }</span>
899
- <span class="cstat-no" title="statement not covered" ></span>
900
- <span class="cstat-no" title="statement not covered" > const request = new Promise((resolve, reject) =&gt; {</span>
901
- <span class="cstat-no" title="statement not covered" > this.api.getService(this.service).find({ query }).then(tiles =&gt; {</span>
902
- <span class="cstat-no" title="statement not covered" > const grids = []</span>
903
- <span class="cstat-no" title="statement not covered" ></span>
904
- <span class="cstat-no" title="statement not covered" > // only add to cache when there has been no setup() called since</span>
905
- <span class="cstat-no" title="statement not covered" > if (sourceKey === this.sourceKey) {</span>
906
- <span class="cstat-no" title="statement not covered" > for (const tile of tiles) {</span>
907
- <span class="cstat-no" title="statement not covered" > const tileBBox = tile.geometry.coordinates[0] // BBox as a polygon</span>
908
- <span class="cstat-no" title="statement not covered" > const tileBounds = [tileBBox[0][1], tileBBox[0][0], tileBBox[2][1], tileBBox[2][0]]</span>
909
- <span class="cstat-no" title="statement not covered" > // normalize bounds when crossing longitude 180/-180</span>
910
- <span class="cstat-no" title="statement not covered" > if (tileBounds[1] &gt; tileBounds[3]) tileBounds[1] -= 360.0</span>
911
- <span class="cstat-no" title="statement not covered" ></span>
912
- <span class="cstat-no" title="statement not covered" > const key = tile2key(tile.x, tile.y)</span>
913
- <span class="cstat-no" title="statement not covered" > const cached = this.tileCache.get(key)</span>
914
- <span class="cstat-no" title="statement not covered" > cached.grid = new Grid1D(</span>
915
- <span class="cstat-no" title="statement not covered" > sourceKey,</span>
916
- <span class="cstat-no" title="statement not covered" > tileBounds, tile.size,</span>
917
- <span class="cstat-no" title="statement not covered" > tile.data, true, SortOrder.DESCENDING, SortOrder.ASCENDING,</span>
918
- <span class="cstat-no" title="statement not covered" > this.nodata, this.converter)</span>
919
- <span class="cstat-no" title="statement not covered" > cached.request = null</span>
920
- <span class="cstat-no" title="statement not covered" ></span>
921
- <span class="cstat-no" title="statement not covered" > // take maxCacheSize into account</span>
922
- <span class="cstat-no" title="statement not covered" > if (this.maxCacheSize !== undefined) {</span>
923
- <span class="cstat-no" title="statement not covered" > // store a kind of timestamp on tiles</span>
924
- <span class="cstat-no" title="statement not covered" > cached.tileCounter = this.tileCounter</span>
925
- <span class="cstat-no" title="statement not covered" > ++this.tileCounter</span>
926
- <span class="cstat-no" title="statement not covered" ></span>
927
- <span class="cstat-no" title="statement not covered" > // make sure we keep cache size under control</span>
928
- <span class="cstat-no" title="statement not covered" > if (this.tileCounter &gt; this.maxCacheSize) {</span>
929
- <span class="cstat-no" title="statement not covered" > let oldestKey = key</span>
930
- <span class="cstat-no" title="statement not covered" > let oldestCounter = cached.tileCounter</span>
931
- <span class="cstat-no" title="statement not covered" > for (const [key, tile] of this.tileCache) {</span>
932
- <span class="cstat-no" title="statement not covered" > if (tile.tileCounter === undefined) continue</span>
933
- <span class="cstat-no" title="statement not covered" > if (tile.tileCounter &lt; oldestCounter) {</span>
934
- <span class="cstat-no" title="statement not covered" > oldestCounter = tile.tileCounter</span>
935
- <span class="cstat-no" title="statement not covered" > oldestKey = key</span>
936
- <span class="cstat-no" title="statement not covered" > }</span>
937
- <span class="cstat-no" title="statement not covered" > }</span>
938
- <span class="cstat-no" title="statement not covered" ></span>
939
- <span class="cstat-no" title="statement not covered" > this.tileCache.delete(oldestKey)</span>
940
- <span class="cstat-no" title="statement not covered" > }</span>
941
- <span class="cstat-no" title="statement not covered" > }</span>
942
- <span class="cstat-no" title="statement not covered" ></span>
943
- <span class="cstat-no" title="statement not covered" > grids.push(cached.grid)</span>
944
- <span class="cstat-no" title="statement not covered" > }</span>
945
- <span class="cstat-no" title="statement not covered" > }</span>
946
- <span class="cstat-no" title="statement not covered" ></span>
947
- <span class="cstat-no" title="statement not covered" > resolve(grids)</span>
948
- <span class="cstat-no" title="statement not covered" > })</span>
949
- <span class="cstat-no" title="statement not covered" > })</span>
950
- <span class="cstat-no" title="statement not covered" ></span>
951
- <span class="cstat-no" title="statement not covered" > // record pending request</span>
952
- <span class="cstat-no" title="statement not covered" > for (let i = 0; i &lt; requests.length; ++i) {</span>
953
- <span class="cstat-no" title="statement not covered" > this.tileCache.set(requests[i], { request })</span>
954
- <span class="cstat-no" title="statement not covered" > }</span>
955
- <span class="cstat-no" title="statement not covered" ></span>
956
- <span class="cstat-no" title="statement not covered" > waits.push(request)</span>
957
- <span class="cstat-no" title="statement not covered" > }</span>
958
- <span class="cstat-no" title="statement not covered" ></span>
959
- <span class="cstat-no" title="statement not covered" > // wait associated requests</span>
960
- <span class="cstat-no" title="statement not covered" > const newGrids = await Promise.all(waits)</span>
961
- <span class="cstat-no" title="statement not covered" > const allGrids = grids.concat(newGrids.flat())</span>
962
- <span class="cstat-no" title="statement not covered" > if (allGrids.length === 0) return null</span>
963
- <span class="cstat-no" title="statement not covered" ></span>
964
- <span class="cstat-no" title="statement not covered" > const grid = allGrids.length &gt; 1 ? new TiledGrid(sourceKey, allGrids) : allGrids[0]</span>
965
- <span class="cstat-no" title="statement not covered" > return new SubGrid(sourceKey, grid, bbox)</span>
966
- <span class="cstat-no" title="statement not covered" > }</span>
967
- <span class="cstat-no" title="statement not covered" ></span>
968
- <span class="cstat-no" title="statement not covered" > async fetchWithoutCache (abort, bbox, resolution) {</span>
969
- <span class="cstat-no" title="statement not covered" > const query = {</span>
970
- <span class="cstat-no" title="statement not covered" > time: this.time,</span>
971
- <span class="cstat-no" title="statement not covered" > $select: ['forecastTime', 'data', 'geometry', 'size'],</span>
972
- <span class="cstat-no" title="statement not covered" > $paginate: false,</span>
973
- <span class="cstat-no" title="statement not covered" > // build a polygon with points longitudaly spaced every lonResolution degrees</span>
974
- <span class="cstat-no" title="statement not covered" > // otherwise mongodb will connect points using shortest path on sphere</span>
975
- <span class="cstat-no" title="statement not covered" > // which is not going to be a square lat/lon box</span>
976
- <span class="cstat-no" title="statement not covered" > geometry: {</span>
977
- <span class="cstat-no" title="statement not covered" > $geoIntersects: {</span>
978
- <span class="cstat-no" title="statement not covered" > $geometry: {</span>
979
- <span class="cstat-no" title="statement not covered" > type: 'Polygon',</span>
980
- <span class="cstat-no" title="statement not covered" > coordinates: [makeMongoPolygon(bbox, this.lonResolution)]</span>
981
- <span class="cstat-no" title="statement not covered" > }</span>
982
- <span class="cstat-no" title="statement not covered" > }</span>
983
- <span class="cstat-no" title="statement not covered" > }</span>
984
- <span class="cstat-no" title="statement not covered" > }</span>
985
- <span class="cstat-no" title="statement not covered" ></span>
986
- <span class="cstat-no" title="statement not covered" > const sourceKey = this.sourceKey</span>
987
- <span class="cstat-no" title="statement not covered" > const results = await this.api.getService(this.service).find({ query })</span>
988
- <span class="cstat-no" title="statement not covered" > if (results.length === 0) return null</span>
989
- <span class="cstat-no" title="statement not covered" ></span>
990
- <span class="cstat-no" title="statement not covered" > // This is to target raw data</span>
991
- <span class="cstat-no" title="statement not covered" > // return new Grid1D(</span>
992
- <span class="cstat-no" title="statement not covered" > // bbox, [width, height],</span>
993
- <span class="cstat-no" title="statement not covered" > // results[0].data, true, SortOrder.DESCENDING, SortOrder.ASCENDING,</span>
994
- <span class="cstat-no" title="statement not covered" > // this.nodata, this.converter)</span>
995
- <span class="cstat-no" title="statement not covered" > // This is to target tiles instead of raw data</span>
996
- <span class="cstat-no" title="statement not covered" > const tiles = []</span>
997
- <span class="cstat-no" title="statement not covered" > for (const tile of results) {</span>
998
- <span class="cstat-no" title="statement not covered" > const tileBBox = tile.geometry.coordinates[0] // BBox as a polygon</span>
999
- <span class="cstat-no" title="statement not covered" > const tileBounds = [tileBBox[0][1], tileBBox[0][0], tileBBox[2][1], tileBBox[2][0]]</span>
1000
- <span class="cstat-no" title="statement not covered" > // normalize bounds when crossing longitude 180/-180</span>
1001
- <span class="cstat-no" title="statement not covered" > if (tileBounds[1] &gt; tileBounds[3]) tileBounds[1] -= 360.0</span>
1002
- <span class="cstat-no" title="statement not covered" ></span>
1003
- <span class="cstat-no" title="statement not covered" > const grid = new Grid1D(</span>
1004
- <span class="cstat-no" title="statement not covered" > sourceKey,</span>
1005
- <span class="cstat-no" title="statement not covered" > tileBounds, tile.size,</span>
1006
- <span class="cstat-no" title="statement not covered" > tile.data, true, SortOrder.DESCENDING, SortOrder.ASCENDING,</span>
1007
- <span class="cstat-no" title="statement not covered" > this.nodata, this.converter)</span>
1008
- <span class="cstat-no" title="statement not covered" > tiles.push(grid)</span>
1009
- <span class="cstat-no" title="statement not covered" > }</span>
1010
- <span class="cstat-no" title="statement not covered" ></span>
1011
- <span class="cstat-no" title="statement not covered" > return tiles.length &gt; 1 ? new TiledGrid(sourceKey, tiles) : tiles[0]</span>
1012
- <span class="cstat-no" title="statement not covered" > }</span>
1013
- <span class="cstat-no" title="statement not covered" >}</span>
1014
- &nbsp;</pre></td></tr></table></pre>
1015
-
1016
- <div class='push'></div><!-- for sticky footer -->
1017
- </div><!-- /wrapper -->
1018
- <div class='footer quiet pad2 space-top1 center small'>
1019
- Code coverage generated by
1020
- <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
1021
- at 2024-08-13T10:02:04.872Z
1022
- </div>
1023
- <script src="../../prettify.js"></script>
1024
- <script>
1025
- window.onload = function () {
1026
- prettyPrint();
1027
- };
1028
- </script>
1029
- <script src="../../sorter.js"></script>
1030
- <script src="../../block-navigation.js"></script>
1031
- </body>
1032
- </html>
1033
-