nodes2ts 1.1.9 → 3.0.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 (105) hide show
  1. package/.eslintignore +3 -0
  2. package/.eslintrc.cjs +11 -0
  3. package/.github/workflows/lint.js.yml +22 -0
  4. package/.github/workflows/node.js.yml +22 -0
  5. package/.mocharc.js +7 -0
  6. package/README.md +22 -5
  7. package/dist/Interval.d.ts +7 -8
  8. package/dist/Interval.js +12 -12
  9. package/dist/Interval.js.map +1 -1
  10. package/dist/MutableInteger.js +5 -4
  11. package/dist/MutableInteger.js.map +1 -1
  12. package/dist/Platform.d.ts +15 -0
  13. package/dist/Platform.js +53 -0
  14. package/dist/Platform.js.map +1 -0
  15. package/dist/R1Interval.d.ts +8 -9
  16. package/dist/R1Interval.js +59 -78
  17. package/dist/R1Interval.js.map +1 -1
  18. package/dist/R2Vector.d.ts +12 -13
  19. package/dist/R2Vector.js +65 -85
  20. package/dist/R2Vector.js.map +1 -1
  21. package/dist/S1Angle.d.ts +38 -5
  22. package/dist/S1Angle.js +89 -37
  23. package/dist/S1Angle.js.map +1 -1
  24. package/dist/S1ChordAngle.d.ts +166 -0
  25. package/dist/S1ChordAngle.js +318 -0
  26. package/dist/S1ChordAngle.js.map +1 -0
  27. package/dist/S1Interval.d.ts +11 -12
  28. package/dist/S1Interval.js +134 -140
  29. package/dist/S1Interval.js.map +1 -1
  30. package/dist/S2.d.ts +8 -5
  31. package/dist/S2.js +91 -108
  32. package/dist/S2.js.map +1 -1
  33. package/dist/S2Cap.d.ts +33 -25
  34. package/dist/S2Cap.js +199 -203
  35. package/dist/S2Cap.js.map +1 -1
  36. package/dist/S2Cell.d.ts +15 -13
  37. package/dist/S2Cell.js +196 -206
  38. package/dist/S2Cell.js.map +1 -1
  39. package/dist/S2CellId.d.ts +37 -14
  40. package/dist/S2CellId.js +407 -359
  41. package/dist/S2CellId.js.map +1 -1
  42. package/dist/S2CellUnion.d.ts +1 -2
  43. package/dist/S2CellUnion.js +137 -133
  44. package/dist/S2CellUnion.js.map +1 -1
  45. package/dist/S2EdgeUtil.js +14 -17
  46. package/dist/S2EdgeUtil.js.map +1 -1
  47. package/dist/S2LatLng.d.ts +15 -11
  48. package/dist/S2LatLng.js +100 -114
  49. package/dist/S2LatLng.js.map +1 -1
  50. package/dist/S2LatLngRect.d.ts +8 -4
  51. package/dist/S2LatLngRect.js +215 -197
  52. package/dist/S2LatLngRect.js.map +1 -1
  53. package/dist/S2Metric.d.ts +4 -5
  54. package/dist/S2Metric.js +30 -27
  55. package/dist/S2Metric.js.map +1 -1
  56. package/dist/S2Point.d.ts +48 -14
  57. package/dist/S2Point.js +156 -109
  58. package/dist/S2Point.js.map +1 -1
  59. package/dist/S2Projections.d.ts +43 -9
  60. package/dist/S2Projections.js +226 -47
  61. package/dist/S2Projections.js.map +1 -1
  62. package/dist/S2Region.js +2 -1
  63. package/dist/S2Region.js.map +1 -1
  64. package/dist/S2RegionCoverer.d.ts +21 -6
  65. package/dist/S2RegionCoverer.js +144 -109
  66. package/dist/S2RegionCoverer.js.map +1 -1
  67. package/dist/export.d.ts +0 -1
  68. package/dist/export.js +42 -32
  69. package/dist/export.js.map +1 -1
  70. package/dist/utils/preconditions.d.ts +2 -0
  71. package/dist/utils/preconditions.js +16 -0
  72. package/dist/utils/preconditions.js.map +1 -0
  73. package/package.json +28 -34
  74. package/.npmignore +0 -8
  75. package/.nyc_output/1eb1f420a13c15f529aac41a40bcaa21.json +0 -1
  76. package/.nyc_output/5ff62256eb1c111254ba0b469fb547da.json +0 -1
  77. package/.nyc_output/949d6e8c2061067f3bdfd27dfff5ba83.json +0 -1
  78. package/coverage/Interval.ts.html +0 -203
  79. package/coverage/MutableInteger.ts.html +0 -77
  80. package/coverage/R1Interval.ts.html +0 -647
  81. package/coverage/R2Vector.ts.html +0 -587
  82. package/coverage/S1Angle.ts.html +0 -344
  83. package/coverage/S1Interval.ts.html +0 -1349
  84. package/coverage/S2.ts.html +0 -1178
  85. package/coverage/S2Cap.ts.html +0 -1433
  86. package/coverage/S2Cell.ts.html +0 -1415
  87. package/coverage/S2CellId.ts.html +0 -3329
  88. package/coverage/S2EdgeUtil.ts.html +0 -2534
  89. package/coverage/S2LatLng.ts.html +0 -848
  90. package/coverage/S2LatLngRect.ts.html +0 -2222
  91. package/coverage/S2Point.ts.html +0 -758
  92. package/coverage/S2Projections.ts.html +0 -518
  93. package/coverage/base.css +0 -212
  94. package/coverage/decimal.ts.html +0 -68
  95. package/coverage/index.html +0 -288
  96. package/coverage/prettify.css +0 -1
  97. package/coverage/prettify.js +0 -1
  98. package/coverage/sort-arrow-sprite.png +0 -0
  99. package/coverage/sorter.js +0 -158
  100. package/dist/decimal.d.ts +0 -3
  101. package/dist/decimal.js +0 -4
  102. package/dist/decimal.js.map +0 -1
  103. package/dist/decimal_augmentation.d.ts +0 -24
  104. package/dist/decimal_augmentation.js +0 -2
  105. package/dist/decimal_augmentation.js.map +0 -1
@@ -1,647 +0,0 @@
1
- <!doctype html>
2
- <html lang="en">
3
- <head>
4
- <title>Code coverage report for R1Interval.ts</title>
5
- <meta charset="utf-8" />
6
- <link rel="stylesheet" href="prettify.css" />
7
- <link rel="stylesheet" href="base.css" />
8
- <meta name="viewport" content="width=device-width, initial-scale=1">
9
- <style type='text/css'>
10
- .coverage-summary .sorter {
11
- background-image: url(sort-arrow-sprite.png);
12
- }
13
- </style>
14
- </head>
15
- <body>
16
- <div class='wrapper'>
17
- <div class='pad1'>
18
- <h1>
19
- <a href="index.html">All files</a> R1Interval.ts
20
- </h1>
21
- <div class='clearfix'>
22
- <div class='fl pad1y space-right2'>
23
- <span class="strong">79.17% </span>
24
- <span class="quiet">Statements</span>
25
- <span class='fraction'>57/72</span>
26
- </div>
27
- <div class='fl pad1y space-right2'>
28
- <span class="strong">64.29% </span>
29
- <span class="quiet">Branches</span>
30
- <span class='fraction'>27/42</span>
31
- </div>
32
- <div class='fl pad1y space-right2'>
33
- <span class="strong">83.33% </span>
34
- <span class="quiet">Functions</span>
35
- <span class='fraction'>15/18</span>
36
- </div>
37
- <div class='fl pad1y space-right2'>
38
- <span class="strong">78.26% </span>
39
- <span class="quiet">Lines</span>
40
- <span class='fraction'>54/69</span>
41
- </div>
42
- </div>
43
- </div>
44
- <div class='status-line medium'></div>
45
- <pre><table class="coverage">
46
- <tr><td class="line-count quiet">1
47
- 2
48
- 3
49
- 4
50
- 5
51
- 6
52
- 7
53
- 8
54
- 9
55
- 10
56
- 11
57
- 12
58
- 13
59
- 14
60
- 15
61
- 16
62
- 17
63
- 18
64
- 19
65
- 20
66
- 21
67
- 22
68
- 23
69
- 24
70
- 25
71
- 26
72
- 27
73
- 28
74
- 29
75
- 30
76
- 31
77
- 32
78
- 33
79
- 34
80
- 35
81
- 36
82
- 37
83
- 38
84
- 39
85
- 40
86
- 41
87
- 42
88
- 43
89
- 44
90
- 45
91
- 46
92
- 47
93
- 48
94
- 49
95
- 50
96
- 51
97
- 52
98
- 53
99
- 54
100
- 55
101
- 56
102
- 57
103
- 58
104
- 59
105
- 60
106
- 61
107
- 62
108
- 63
109
- 64
110
- 65
111
- 66
112
- 67
113
- 68
114
- 69
115
- 70
116
- 71
117
- 72
118
- 73
119
- 74
120
- 75
121
- 76
122
- 77
123
- 78
124
- 79
125
- 80
126
- 81
127
- 82
128
- 83
129
- 84
130
- 85
131
- 86
132
- 87
133
- 88
134
- 89
135
- 90
136
- 91
137
- 92
138
- 93
139
- 94
140
- 95
141
- 96
142
- 97
143
- 98
144
- 99
145
- 100
146
- 101
147
- 102
148
- 103
149
- 104
150
- 105
151
- 106
152
- 107
153
- 108
154
- 109
155
- 110
156
- 111
157
- 112
158
- 113
159
- 114
160
- 115
161
- 116
162
- 117
163
- 118
164
- 119
165
- 120
166
- 121
167
- 122
168
- 123
169
- 124
170
- 125
171
- 126
172
- 127
173
- 128
174
- 129
175
- 130
176
- 131
177
- 132
178
- 133
179
- 134
180
- 135
181
- 136
182
- 137
183
- 138
184
- 139
185
- 140
186
- 141
187
- 142
188
- 143
189
- 144
190
- 145
191
- 146
192
- 147
193
- 148
194
- 149
195
- 150
196
- 151
197
- 152
198
- 153
199
- 154
200
- 155
201
- 156
202
- 157
203
- 158
204
- 159
205
- 160
206
- 161
207
- 162
208
- 163
209
- 164
210
- 165
211
- 166
212
- 167
213
- 168
214
- 169
215
- 170
216
- 171
217
- 172
218
- 173
219
- 174
220
- 175
221
- 176
222
- 177
223
- 178
224
- 179
225
- 180
226
- 181
227
- 182
228
- 183
229
- 184
230
- 185
231
- 186
232
- 187
233
- 188
234
- 189
235
- 190
236
- 191
237
- 192
238
- 193
239
- 194
240
- 195</td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
241
- <span class="cline-any cline-yes">1x</span>
242
- <span class="cline-any cline-yes">1x</span>
243
- <span class="cline-any cline-neutral">&nbsp;</span>
244
- <span class="cline-any cline-neutral">&nbsp;</span>
245
- <span class="cline-any cline-neutral">&nbsp;</span>
246
- <span class="cline-any cline-neutral">&nbsp;</span>
247
- <span class="cline-any cline-neutral">&nbsp;</span>
248
- <span class="cline-any cline-neutral">&nbsp;</span>
249
- <span class="cline-any cline-neutral">&nbsp;</span>
250
- <span class="cline-any cline-neutral">&nbsp;</span>
251
- <span class="cline-any cline-neutral">&nbsp;</span>
252
- <span class="cline-any cline-neutral">&nbsp;</span>
253
- <span class="cline-any cline-neutral">&nbsp;</span>
254
- <span class="cline-any cline-neutral">&nbsp;</span>
255
- <span class="cline-any cline-neutral">&nbsp;</span>
256
- <span class="cline-any cline-neutral">&nbsp;</span>
257
- <span class="cline-any cline-neutral">&nbsp;</span>
258
- <span class="cline-any cline-neutral">&nbsp;</span>
259
- <span class="cline-any cline-neutral">&nbsp;</span>
260
- <span class="cline-any cline-neutral">&nbsp;</span>
261
- <span class="cline-any cline-neutral">&nbsp;</span>
262
- <span class="cline-any cline-neutral">&nbsp;</span>
263
- <span class="cline-any cline-neutral">&nbsp;</span>
264
- <span class="cline-any cline-yes">1057x</span>
265
- <span class="cline-any cline-neutral">&nbsp;</span>
266
- <span class="cline-any cline-neutral">&nbsp;</span>
267
- <span class="cline-any cline-neutral">&nbsp;</span>
268
- <span class="cline-any cline-neutral">&nbsp;</span>
269
- <span class="cline-any cline-neutral">&nbsp;</span>
270
- <span class="cline-any cline-neutral">&nbsp;</span>
271
- <span class="cline-any cline-yes">1x</span>
272
- <span class="cline-any cline-yes">708x</span>
273
- <span class="cline-any cline-neutral">&nbsp;</span>
274
- <span class="cline-any cline-neutral">&nbsp;</span>
275
- <span class="cline-any cline-yes">1x</span>
276
- <span class="cline-any cline-yes">170x</span>
277
- <span class="cline-any cline-neutral">&nbsp;</span>
278
- <span class="cline-any cline-neutral">&nbsp;</span>
279
- <span class="cline-any cline-yes">1x</span>
280
- <span class="cline-any cline-no">&nbsp;</span>
281
- <span class="cline-any cline-neutral">&nbsp;</span>
282
- <span class="cline-any cline-neutral">&nbsp;</span>
283
- <span class="cline-any cline-yes">1x</span>
284
- <span class="cline-any cline-yes">5x</span>
285
- <span class="cline-any cline-yes">5x</span>
286
- <span class="cline-any cline-neutral">&nbsp;</span>
287
- <span class="cline-any cline-neutral">&nbsp;</span>
288
- <span class="cline-any cline-neutral">&nbsp;</span>
289
- <span class="cline-any cline-neutral">&nbsp;</span>
290
- <span class="cline-any cline-yes">1x</span>
291
- <span class="cline-any cline-yes">5x</span>
292
- <span class="cline-any cline-yes">5x</span>
293
- <span class="cline-any cline-neutral">&nbsp;</span>
294
- <span class="cline-any cline-neutral">&nbsp;</span>
295
- <span class="cline-any cline-neutral">&nbsp;</span>
296
- <span class="cline-any cline-neutral">&nbsp;</span>
297
- <span class="cline-any cline-neutral">&nbsp;</span>
298
- <span class="cline-any cline-yes">1x</span>
299
- <span class="cline-any cline-yes">1x</span>
300
- <span class="cline-any cline-no">&nbsp;</span>
301
- <span class="cline-any cline-neutral">&nbsp;</span>
302
- <span class="cline-any cline-yes">1x</span>
303
- <span class="cline-any cline-neutral">&nbsp;</span>
304
- <span class="cline-any cline-neutral">&nbsp;</span>
305
- <span class="cline-any cline-neutral">&nbsp;</span>
306
- <span class="cline-any cline-yes">1x</span>
307
- <span class="cline-any cline-yes">3x</span>
308
- <span class="cline-any cline-no">&nbsp;</span>
309
- <span class="cline-any cline-neutral">&nbsp;</span>
310
- <span class="cline-any cline-yes">3x</span>
311
- <span class="cline-any cline-neutral">&nbsp;</span>
312
- <span class="cline-any cline-neutral">&nbsp;</span>
313
- <span class="cline-any cline-neutral">&nbsp;</span>
314
- <span class="cline-any cline-neutral">&nbsp;</span>
315
- <span class="cline-any cline-neutral">&nbsp;</span>
316
- <span class="cline-any cline-neutral">&nbsp;</span>
317
- <span class="cline-any cline-yes">1x</span>
318
- <span class="cline-any cline-yes">4x</span>
319
- <span class="cline-any cline-yes">2x</span>
320
- <span class="cline-any cline-neutral">&nbsp;</span>
321
- <span class="cline-any cline-yes">2x</span>
322
- <span class="cline-any cline-neutral">&nbsp;</span>
323
- <span class="cline-any cline-neutral">&nbsp;</span>
324
- <span class="cline-any cline-neutral">&nbsp;</span>
325
- <span class="cline-any cline-neutral">&nbsp;</span>
326
- <span class="cline-any cline-neutral">&nbsp;</span>
327
- <span class="cline-any cline-neutral">&nbsp;</span>
328
- <span class="cline-any cline-neutral">&nbsp;</span>
329
- <span class="cline-any cline-yes">1x</span>
330
- <span class="cline-any cline-yes">2x</span>
331
- <span class="cline-any cline-neutral">&nbsp;</span>
332
- <span class="cline-any cline-neutral">&nbsp;</span>
333
- <span class="cline-any cline-neutral">&nbsp;</span>
334
- <span class="cline-any cline-yes">1x</span>
335
- <span class="cline-any cline-yes">5x</span>
336
- <span class="cline-any cline-yes">5x</span>
337
- <span class="cline-any cline-no">&nbsp;</span>
338
- <span class="cline-any cline-yes">5x</span>
339
- <span class="cline-any cline-no">&nbsp;</span>
340
- <span class="cline-any cline-yes">5x</span>
341
- <span class="cline-any cline-no">&nbsp;</span>
342
- <span class="cline-any cline-neutral">&nbsp;</span>
343
- <span class="cline-any cline-yes">5x</span>
344
- <span class="cline-any cline-neutral">&nbsp;</span>
345
- <span class="cline-any cline-neutral">&nbsp;</span>
346
- <span class="cline-any cline-neutral">&nbsp;</span>
347
- <span class="cline-any cline-neutral">&nbsp;</span>
348
- <span class="cline-any cline-neutral">&nbsp;</span>
349
- <span class="cline-any cline-neutral">&nbsp;</span>
350
- <span class="cline-any cline-neutral">&nbsp;</span>
351
- <span class="cline-any cline-neutral">&nbsp;</span>
352
- <span class="cline-any cline-yes">1x</span>
353
- <span class="cline-any cline-yes">176x</span>
354
- <span class="cline-any cline-neutral">&nbsp;</span>
355
- <span class="cline-any cline-yes">176x</span>
356
- <span class="cline-any cline-no">&nbsp;</span>
357
- <span class="cline-any cline-neutral">&nbsp;</span>
358
- <span class="cline-any cline-yes">176x</span>
359
- <span class="cline-any cline-neutral">&nbsp;</span>
360
- <span class="cline-any cline-neutral">&nbsp;</span>
361
- <span class="cline-any cline-neutral">&nbsp;</span>
362
- <span class="cline-any cline-neutral">&nbsp;</span>
363
- <span class="cline-any cline-neutral">&nbsp;</span>
364
- <span class="cline-any cline-neutral">&nbsp;</span>
365
- <span class="cline-any cline-yes">1x</span>
366
- <span class="cline-any cline-no">&nbsp;</span>
367
- <span class="cline-any cline-no">&nbsp;</span>
368
- <span class="cline-any cline-neutral">&nbsp;</span>
369
- <span class="cline-any cline-no">&nbsp;</span>
370
- <span class="cline-any cline-no">&nbsp;</span>
371
- <span class="cline-any cline-neutral">&nbsp;</span>
372
- <span class="cline-any cline-no">&nbsp;</span>
373
- <span class="cline-any cline-neutral">&nbsp;</span>
374
- <span class="cline-any cline-neutral">&nbsp;</span>
375
- <span class="cline-any cline-neutral">&nbsp;</span>
376
- <span class="cline-any cline-neutral">&nbsp;</span>
377
- <span class="cline-any cline-neutral">&nbsp;</span>
378
- <span class="cline-any cline-neutral">&nbsp;</span>
379
- <span class="cline-any cline-neutral">&nbsp;</span>
380
- <span class="cline-any cline-neutral">&nbsp;</span>
381
- <span class="cline-any cline-neutral">&nbsp;</span>
382
- <span class="cline-any cline-yes">1x</span>
383
- <span class="cline-any cline-yes">176x</span>
384
- <span class="cline-any cline-neutral">&nbsp;</span>
385
- <span class="cline-any cline-neutral">&nbsp;</span>
386
- <span class="cline-any cline-neutral">&nbsp;</span>
387
- <span class="cline-any cline-neutral">&nbsp;</span>
388
- <span class="cline-any cline-neutral">&nbsp;</span>
389
- <span class="cline-any cline-neutral">&nbsp;</span>
390
- <span class="cline-any cline-neutral">&nbsp;</span>
391
- <span class="cline-any cline-neutral">&nbsp;</span>
392
- <span class="cline-any cline-neutral">&nbsp;</span>
393
- <span class="cline-any cline-yes">169x</span>
394
- <span class="cline-any cline-yes">169x</span>
395
- <span class="cline-any cline-no">&nbsp;</span>
396
- <span class="cline-any cline-neutral">&nbsp;</span>
397
- <span class="cline-any cline-yes">169x</span>
398
- <span class="cline-any cline-no">&nbsp;</span>
399
- <span class="cline-any cline-neutral">&nbsp;</span>
400
- <span class="cline-any cline-yes">169x</span>
401
- <span class="cline-any cline-neutral">&nbsp;</span>
402
- <span class="cline-any cline-neutral">&nbsp;</span>
403
- <span class="cline-any cline-neutral">&nbsp;</span>
404
- <span class="cline-any cline-neutral">&nbsp;</span>
405
- <span class="cline-any cline-neutral">&nbsp;</span>
406
- <span class="cline-any cline-neutral">&nbsp;</span>
407
- <span class="cline-any cline-yes">1x</span>
408
- <span class="cline-any cline-yes">2x</span>
409
- <span class="cline-any cline-neutral">&nbsp;</span>
410
- <span class="cline-any cline-neutral">&nbsp;</span>
411
- <span class="cline-any cline-neutral">&nbsp;</span>
412
- <span class="cline-any cline-yes">1x</span>
413
- <span class="cline-any cline-no">&nbsp;</span>
414
- <span class="cline-any cline-neutral">&nbsp;</span>
415
- <span class="cline-any cline-neutral">&nbsp;</span>
416
- <span class="cline-any cline-neutral">&nbsp;</span>
417
- <span class="cline-any cline-neutral">&nbsp;</span>
418
- <span class="cline-any cline-neutral">&nbsp;</span>
419
- <span class="cline-any cline-neutral">&nbsp;</span>
420
- <span class="cline-any cline-neutral">&nbsp;</span>
421
- <span class="cline-any cline-yes">1x</span>
422
- <span class="cline-any cline-yes">338x</span>
423
- <span class="cline-any cline-yes">338x</span>
424
- <span class="cline-any cline-yes">338x</span>
425
- <span class="cline-any cline-yes">254x</span>
426
- <span class="cline-any cline-neutral">&nbsp;</span>
427
- <span class="cline-any cline-yes">84x</span>
428
- <span class="cline-any cline-neutral">&nbsp;</span>
429
- <span class="cline-any cline-neutral">&nbsp;</span>
430
- <span class="cline-any cline-neutral">&nbsp;</span>
431
- <span class="cline-any cline-neutral">&nbsp;</span>
432
- <span class="cline-any cline-neutral">&nbsp;</span>
433
- <span class="cline-any cline-neutral">&nbsp;</span>
434
- <span class="cline-any cline-yes">1x</span></td><td class="text"><pre class="prettyprint lang-js">import {Interval} from "./Interval";
435
- import {S2} from "./S2";
436
- import {Decimal} from './decimal';
437
- &nbsp;
438
- /**
439
- * An R1Interval represents a closed interval on a unit circle (also known as a
440
- * 1-dimensional sphere). It is capable of representing the empty interval
441
- * (containing no points), the full interval (containing all points), and
442
- * zero-length intervals (containing a single point).
443
- *
444
- * Points are represented by the angle they make with the positive x-axis in
445
- * the range [-Pi, Pi]. An interval is represented by its lower and upper bounds
446
- * (both inclusive, since the interval is closed). The lower bound may be
447
- * greater than the upper bound, in which case the interval is "inverted" (i.e.
448
- * it passes through the point (-1, 0)).
449
- *
450
- * Note that the point (-1, 0) has two valid representations, Pi and -Pi. The
451
- * normalized representation of this point internally is Pi, so that endpoints
452
- * of normal intervals are in the range (-Pi, Pi]. However, we take advantage of
453
- * the point -Pi to construct two special intervals: the Full() interval is
454
- * [-Pi, Pi], and the Empty() interval is [Pi, -Pi].
455
- *
456
- */
457
- &nbsp;
458
- export class R1Interval extends Interval {
459
- &nbsp;
460
- &nbsp;
461
- &nbsp;
462
- &nbsp;
463
- &nbsp;
464
- /** Return true if the interval is empty, i.e. it contains no points. */
465
- public isEmpty() {
466
- return this.lo.gt(this.hi);
467
- }
468
- &nbsp;
469
- public getCenter():decimal.Decimal {
470
- return this.lo.plus(this.hi).dividedBy(2);
471
- }
472
- &nbsp;
473
- <span class="fstat-no" title="function not covered" > public getLength():decimal.Decimal {</span>
474
- <span class="cstat-no" title="statement not covered" > return this.hi.minus(this.lo);</span>
475
- }
476
- &nbsp;
477
- public contains(_p:number|decimal.Decimal):boolean {
478
- const p = S2.toDecimal(_p);
479
- return p.gte(this.lo) &amp;&amp; p.lte(this.hi);
480
- &nbsp;
481
- }
482
- &nbsp;
483
- /** Return true if the interior of the interval contains the point 'p'. */
484
- public interiorContains(_p:number|decimal.Decimal):boolean {
485
- const p = S2.toDecimal(_p);
486
- return p.gt(this.lo) &amp;&amp; p.lt(this.hi); }
487
- &nbsp;
488
- /**
489
- * Return true if the interval contains the given interval 'y'. Works for
490
- * empty, full, and singleton intervals.
491
- */
492
- public containsI(y:R1Interval):boolean {
493
- <span class="missing-if-branch" title="if path not taken" >I</span>if (y.isEmpty()) {
494
- <span class="cstat-no" title="statement not covered" > return true;</span>
495
- }
496
- return y.lo.gte(this.lo) &amp;&amp; y.hi.lte(this.hi);
497
- }
498
- &nbsp;
499
- &nbsp;
500
- public interiorContainsI(y:R1Interval):boolean {
501
- <span class="missing-if-branch" title="if path not taken" >I</span>if (y.isEmpty()) {
502
- <span class="cstat-no" title="statement not covered" > return true;</span>
503
- }
504
- return y.lo.gt(this.lo) &amp;&amp; y.hi.lt(this.hi);
505
- }
506
- &nbsp;
507
- /**
508
- * Return true if this interval intersects the given interval, i.e. if they
509
- * have any points in common.
510
- */
511
- public intersects(y:R1Interval):boolean {
512
- if (this.lo.lte(y.lo)) {
513
- return y.lo.lte(this.hi) &amp;&amp; y.lo.lte(y.hi);
514
- } else {
515
- return this.lo.lte(y.hi) &amp;&amp; this.lo.lte(this.hi);
516
- }
517
- }
518
- &nbsp;
519
- /**
520
- * Return true if the interior of this interval intersects any point of the
521
- * given interval (including its boundary).
522
- */
523
- public interiorIntersects(y:R1Interval):boolean {
524
- return y.lo.lt( this.hi) &amp;&amp; this.lo.lt(y.hi) &amp;&amp; <span class="branch-2 cbranch-no" title="branch not covered" >this.lo.lt(this.hi) </span>&amp;&amp; <span class="branch-3 cbranch-no" title="branch not covered" >y.lo.lte(y.hi);</span>
525
- }
526
- &nbsp;
527
- /** Expand the interval so that it contains the given point "p". */
528
- public addPoint(_p:number|decimal.Decimal):R1Interval {
529
- const p = S2.toDecimal(_p);
530
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isEmpty()) {
531
- <span class="cstat-no" title="statement not covered" > return R1Interval.fromPoint(p);</span>
532
- } else <span class="missing-if-branch" title="if path not taken" >I</span>if (p.lt(this.lo)) {
533
- <span class="cstat-no" title="statement not covered" > return new R1Interval(p, this.hi);</span>
534
- } else <span class="missing-if-branch" title="if path not taken" >I</span>if (p.gt(this.hi)) {
535
- <span class="cstat-no" title="statement not covered" > return new R1Interval(this.lo, p);</span>
536
- } else {
537
- return new R1Interval(this.lo, this.hi);
538
- }
539
- }
540
- &nbsp;
541
- /**
542
- * Return an interval that contains all points with a distance "radius" of a
543
- * point in this interval. Note that the expansion of an empty interval is
544
- * always empty.
545
- */
546
- public expanded(_radius:number|decimal.Decimal):R1Interval {
547
- const radius = S2.toDecimal(_radius);
548
- // assert (radius &gt;= 0);
549
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isEmpty()) {
550
- <span class="cstat-no" title="statement not covered" > return this;</span>
551
- }
552
- return new R1Interval(this.lo.minus(radius), this.hi.plus(radius));
553
- }
554
- &nbsp;
555
- /**
556
- * Return the smallest interval that contains this interval and the given
557
- * interval "y".
558
- */
559
- <span class="fstat-no" title="function not covered" > public union(</span>y:R1Interval):R1Interval {
560
- <span class="cstat-no" title="statement not covered" > if (this.isEmpty()) {</span>
561
- <span class="cstat-no" title="statement not covered" > return y;</span>
562
- }
563
- <span class="cstat-no" title="statement not covered" > if (y.isEmpty()) {</span>
564
- <span class="cstat-no" title="statement not covered" > return this;</span>
565
- }
566
- <span class="cstat-no" title="statement not covered" > return new R1Interval(</span>
567
- Decimal.min(this.lo, y.lo),
568
- Decimal.max(this.hi, y.hi)
569
- );
570
- }
571
- &nbsp;
572
- /**
573
- * Return the intersection of this interval with the given interval. Empty
574
- * intervals do not need to be special-cased.
575
- */
576
- public intersection(y:R1Interval):R1Interval {
577
- return new R1Interval(
578
- Decimal.max(this.lo, y.lo),
579
- Decimal.min(this.hi, y.hi)
580
- );
581
- }
582
- &nbsp;
583
- /**
584
- * Return true if the length of the symmetric difference between the two
585
- * intervals is at most the given tolerance.
586
- */
587
- public approxEquals(y:R1Interval, <span class="missing-if-branch" title="if path not taken" >I</span>maxError:number=1e-15):boolean {
588
- <span class="missing-if-branch" title="if path not taken" >I</span>if (this.isEmpty()) {
589
- <span class="cstat-no" title="statement not covered" > return y.getLength().lte(maxError);</span>
590
- }
591
- <span class="missing-if-branch" title="if path not taken" >I</span>if (y.isEmpty()) {
592
- <span class="cstat-no" title="statement not covered" > return this.getLength().lte( maxError);</span>
593
- }
594
- return y.lo.minus(this.lo).abs()
595
- .plus(y.hi.minus(this.hi).abs())
596
- .lte(maxError);
597
- }
598
- &nbsp;
599
- &nbsp;
600
- &nbsp;
601
- static empty():R1Interval {
602
- return new R1Interval(1, 0);
603
- }
604
- &nbsp;
605
- &nbsp;
606
- <span class="fstat-no" title="function not covered" > static fromPoint(</span>p:number|decimal.Decimal):R1Interval {
607
- <span class="cstat-no" title="statement not covered" > return new R1Interval(p, p);</span>
608
- }
609
- &nbsp;
610
- /**
611
- * Convenience method to construct the minimal interval containing the two
612
- * given points. This is equivalent to starting with an empty interval and
613
- * calling AddPoint() twice, but it is more efficient.
614
- */
615
- static fromPointPair(_p1:number|decimal.Decimal, _p2:number|decimal.Decimal):R1Interval {
616
- const p1 = S2.toDecimal(_p1);
617
- const p2 = S2.toDecimal(_p2);
618
- if (p1.lte(p2)) {
619
- return new R1Interval(p1, p2);
620
- } else {
621
- return new R1Interval(p2, p1);
622
- }
623
- }
624
- &nbsp;
625
- &nbsp;
626
- &nbsp;
627
- &nbsp;
628
- }</pre></td></tr>
629
- </table></pre>
630
- <div class='push'></div><!-- for sticky footer -->
631
- </div><!-- /wrapper -->
632
- <div class='footer quiet pad2 space-top1 center small'>
633
- Code coverage
634
- generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Wed Sep 28 2016 14:48:27 GMT+0200 (CEST)
635
- </div>
636
- </div>
637
- <script src="prettify.js"></script>
638
- <script>
639
- window.onload = function () {
640
- if (typeof prettyPrint === 'function') {
641
- prettyPrint();
642
- }
643
- };
644
- </script>
645
- <script src="sorter.js"></script>
646
- </body>
647
- </html>