@itwin/core-bentley 4.0.0-dev.8 → 4.0.0-dev.81

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 (254) hide show
  1. package/CHANGELOG.md +50 -1
  2. package/lib/cjs/AccessToken.d.ts +10 -10
  3. package/lib/cjs/AccessToken.d.ts.map +1 -1
  4. package/lib/cjs/AccessToken.js +9 -9
  5. package/lib/cjs/AccessToken.js.map +1 -1
  6. package/lib/cjs/Assert.d.ts +25 -25
  7. package/lib/cjs/Assert.js +45 -45
  8. package/lib/cjs/Assert.js.map +1 -1
  9. package/lib/cjs/BeEvent.d.ts +81 -81
  10. package/lib/cjs/BeEvent.d.ts.map +1 -1
  11. package/lib/cjs/BeEvent.js +156 -156
  12. package/lib/cjs/BeEvent.js.map +1 -1
  13. package/lib/cjs/BeSQLite.d.ts +172 -170
  14. package/lib/cjs/BeSQLite.d.ts.map +1 -1
  15. package/lib/cjs/BeSQLite.js +185 -183
  16. package/lib/cjs/BeSQLite.js.map +1 -1
  17. package/lib/cjs/BentleyError.d.ts +378 -378
  18. package/lib/cjs/BentleyError.d.ts.map +1 -1
  19. package/lib/cjs/BentleyError.js +703 -702
  20. package/lib/cjs/BentleyError.js.map +1 -1
  21. package/lib/cjs/BentleyLoggerCategory.d.ts +11 -11
  22. package/lib/cjs/BentleyLoggerCategory.js +19 -19
  23. package/lib/cjs/BentleyLoggerCategory.js.map +1 -1
  24. package/lib/cjs/ByteStream.d.ts +110 -110
  25. package/lib/cjs/ByteStream.js +159 -159
  26. package/lib/cjs/ByteStream.js.map +1 -1
  27. package/lib/cjs/ClassUtils.d.ts +14 -14
  28. package/lib/cjs/ClassUtils.js +27 -27
  29. package/lib/cjs/ClassUtils.js.map +1 -1
  30. package/lib/cjs/Compare.d.ts +47 -47
  31. package/lib/cjs/Compare.d.ts.map +1 -1
  32. package/lib/cjs/Compare.js +75 -75
  33. package/lib/cjs/Compare.js.map +1 -1
  34. package/lib/cjs/CompressedId64Set.d.ts +134 -134
  35. package/lib/cjs/CompressedId64Set.d.ts.map +1 -1
  36. package/lib/cjs/CompressedId64Set.js +428 -428
  37. package/lib/cjs/CompressedId64Set.js.map +1 -1
  38. package/lib/cjs/Dictionary.d.ts +125 -125
  39. package/lib/cjs/Dictionary.js +203 -203
  40. package/lib/cjs/Dictionary.js.map +1 -1
  41. package/lib/cjs/Disposable.d.ts +80 -80
  42. package/lib/cjs/Disposable.d.ts.map +1 -1
  43. package/lib/cjs/Disposable.js +120 -120
  44. package/lib/cjs/Disposable.js.map +1 -1
  45. package/lib/cjs/Id.d.ts +285 -285
  46. package/lib/cjs/Id.d.ts.map +1 -1
  47. package/lib/cjs/Id.js +643 -643
  48. package/lib/cjs/Id.js.map +1 -1
  49. package/lib/cjs/IndexMap.d.ts +65 -65
  50. package/lib/cjs/IndexMap.js +91 -91
  51. package/lib/cjs/IndexMap.js.map +1 -1
  52. package/lib/cjs/JsonSchema.d.ts +77 -77
  53. package/lib/cjs/JsonSchema.d.ts.map +1 -1
  54. package/lib/cjs/JsonSchema.js +9 -9
  55. package/lib/cjs/JsonSchema.js.map +1 -1
  56. package/lib/cjs/JsonUtils.d.ts +78 -78
  57. package/lib/cjs/JsonUtils.js +151 -151
  58. package/lib/cjs/JsonUtils.js.map +1 -1
  59. package/lib/cjs/LRUMap.d.ts +129 -129
  60. package/lib/cjs/LRUMap.js +333 -333
  61. package/lib/cjs/LRUMap.js.map +1 -1
  62. package/lib/cjs/Logger.d.ts +143 -143
  63. package/lib/cjs/Logger.d.ts.map +1 -1
  64. package/lib/cjs/Logger.js +256 -258
  65. package/lib/cjs/Logger.js.map +1 -1
  66. package/lib/cjs/ObservableSet.d.ts +23 -23
  67. package/lib/cjs/ObservableSet.js +51 -51
  68. package/lib/cjs/ObservableSet.js.map +1 -1
  69. package/lib/cjs/OneAtATimeAction.d.ts +31 -31
  70. package/lib/cjs/OneAtATimeAction.js +94 -94
  71. package/lib/cjs/OneAtATimeAction.js.map +1 -1
  72. package/lib/cjs/OrderedId64Iterable.d.ts +74 -74
  73. package/lib/cjs/OrderedId64Iterable.d.ts.map +1 -1
  74. package/lib/cjs/OrderedId64Iterable.js +235 -235
  75. package/lib/cjs/OrderedId64Iterable.js.map +1 -1
  76. package/lib/cjs/OrderedSet.d.ts +40 -40
  77. package/lib/cjs/OrderedSet.js +64 -64
  78. package/lib/cjs/OrderedSet.js.map +1 -1
  79. package/lib/cjs/PriorityQueue.d.ts +70 -70
  80. package/lib/cjs/PriorityQueue.d.ts.map +1 -1
  81. package/lib/cjs/PriorityQueue.js +140 -140
  82. package/lib/cjs/PriorityQueue.js.map +1 -1
  83. package/lib/cjs/ProcessDetector.d.ts +59 -59
  84. package/lib/cjs/ProcessDetector.js +71 -71
  85. package/lib/cjs/ProcessDetector.js.map +1 -1
  86. package/lib/cjs/SortedArray.d.ts +236 -232
  87. package/lib/cjs/SortedArray.d.ts.map +1 -1
  88. package/lib/cjs/SortedArray.js +315 -303
  89. package/lib/cjs/SortedArray.js.map +1 -1
  90. package/lib/cjs/StatusCategory.d.ts +30 -30
  91. package/lib/cjs/StatusCategory.d.ts.map +1 -1
  92. package/lib/cjs/StatusCategory.js +460 -460
  93. package/lib/cjs/StatusCategory.js.map +1 -1
  94. package/lib/cjs/StringUtils.d.ts +22 -22
  95. package/lib/cjs/StringUtils.js +148 -148
  96. package/lib/cjs/StringUtils.js.map +1 -1
  97. package/lib/cjs/Time.d.ts +122 -122
  98. package/lib/cjs/Time.js +152 -152
  99. package/lib/cjs/Time.js.map +1 -1
  100. package/lib/cjs/Tracing.d.ts +43 -40
  101. package/lib/cjs/Tracing.d.ts.map +1 -1
  102. package/lib/cjs/Tracing.js +134 -130
  103. package/lib/cjs/Tracing.js.map +1 -1
  104. package/lib/cjs/TupleKeyedMap.d.ts +36 -36
  105. package/lib/cjs/TupleKeyedMap.js +102 -102
  106. package/lib/cjs/TupleKeyedMap.js.map +1 -1
  107. package/lib/cjs/TypedArrayBuilder.d.ts +155 -155
  108. package/lib/cjs/TypedArrayBuilder.d.ts.map +1 -1
  109. package/lib/cjs/TypedArrayBuilder.js +206 -208
  110. package/lib/cjs/TypedArrayBuilder.js.map +1 -1
  111. package/lib/cjs/UnexpectedErrors.d.ts +43 -43
  112. package/lib/cjs/UnexpectedErrors.d.ts.map +1 -1
  113. package/lib/cjs/UnexpectedErrors.js +68 -68
  114. package/lib/cjs/UnexpectedErrors.js.map +1 -1
  115. package/lib/cjs/UtilityTypes.d.ts +112 -96
  116. package/lib/cjs/UtilityTypes.d.ts.map +1 -1
  117. package/lib/cjs/UtilityTypes.js +40 -40
  118. package/lib/cjs/UtilityTypes.js.map +1 -1
  119. package/lib/cjs/YieldManager.d.ts +18 -18
  120. package/lib/cjs/YieldManager.js +34 -34
  121. package/lib/cjs/YieldManager.js.map +1 -1
  122. package/lib/cjs/core-bentley.d.ts +74 -74
  123. package/lib/cjs/core-bentley.js +94 -90
  124. package/lib/cjs/core-bentley.js.map +1 -1
  125. package/lib/cjs/partitionArray.d.ts +21 -21
  126. package/lib/cjs/partitionArray.js +43 -43
  127. package/lib/cjs/partitionArray.js.map +1 -1
  128. package/lib/esm/AccessToken.d.ts +10 -10
  129. package/lib/esm/AccessToken.d.ts.map +1 -1
  130. package/lib/esm/AccessToken.js +8 -8
  131. package/lib/esm/AccessToken.js.map +1 -1
  132. package/lib/esm/Assert.d.ts +25 -25
  133. package/lib/esm/Assert.js +41 -41
  134. package/lib/esm/Assert.js.map +1 -1
  135. package/lib/esm/BeEvent.d.ts +81 -81
  136. package/lib/esm/BeEvent.d.ts.map +1 -1
  137. package/lib/esm/BeEvent.js +150 -150
  138. package/lib/esm/BeEvent.js.map +1 -1
  139. package/lib/esm/BeSQLite.d.ts +172 -170
  140. package/lib/esm/BeSQLite.d.ts.map +1 -1
  141. package/lib/esm/BeSQLite.js +182 -180
  142. package/lib/esm/BeSQLite.js.map +1 -1
  143. package/lib/esm/BentleyError.d.ts +378 -378
  144. package/lib/esm/BentleyError.d.ts.map +1 -1
  145. package/lib/esm/BentleyError.js +699 -698
  146. package/lib/esm/BentleyError.js.map +1 -1
  147. package/lib/esm/BentleyLoggerCategory.d.ts +11 -11
  148. package/lib/esm/BentleyLoggerCategory.js +16 -16
  149. package/lib/esm/BentleyLoggerCategory.js.map +1 -1
  150. package/lib/esm/ByteStream.d.ts +110 -110
  151. package/lib/esm/ByteStream.js +155 -155
  152. package/lib/esm/ByteStream.js.map +1 -1
  153. package/lib/esm/ClassUtils.d.ts +14 -14
  154. package/lib/esm/ClassUtils.js +22 -22
  155. package/lib/esm/ClassUtils.js.map +1 -1
  156. package/lib/esm/Compare.d.ts +47 -47
  157. package/lib/esm/Compare.d.ts.map +1 -1
  158. package/lib/esm/Compare.js +63 -63
  159. package/lib/esm/Compare.js.map +1 -1
  160. package/lib/esm/CompressedId64Set.d.ts +134 -134
  161. package/lib/esm/CompressedId64Set.d.ts.map +1 -1
  162. package/lib/esm/CompressedId64Set.js +423 -423
  163. package/lib/esm/CompressedId64Set.js.map +1 -1
  164. package/lib/esm/Dictionary.d.ts +125 -125
  165. package/lib/esm/Dictionary.js +199 -199
  166. package/lib/esm/Dictionary.js.map +1 -1
  167. package/lib/esm/Disposable.d.ts +80 -80
  168. package/lib/esm/Disposable.d.ts.map +1 -1
  169. package/lib/esm/Disposable.js +112 -112
  170. package/lib/esm/Disposable.js.map +1 -1
  171. package/lib/esm/Id.d.ts +285 -285
  172. package/lib/esm/Id.d.ts.map +1 -1
  173. package/lib/esm/Id.js +639 -639
  174. package/lib/esm/Id.js.map +1 -1
  175. package/lib/esm/IndexMap.d.ts +65 -65
  176. package/lib/esm/IndexMap.js +86 -86
  177. package/lib/esm/IndexMap.js.map +1 -1
  178. package/lib/esm/JsonSchema.d.ts +77 -77
  179. package/lib/esm/JsonSchema.d.ts.map +1 -1
  180. package/lib/esm/JsonSchema.js +8 -8
  181. package/lib/esm/JsonSchema.js.map +1 -1
  182. package/lib/esm/JsonUtils.d.ts +78 -78
  183. package/lib/esm/JsonUtils.js +148 -148
  184. package/lib/esm/JsonUtils.js.map +1 -1
  185. package/lib/esm/LRUMap.d.ts +129 -129
  186. package/lib/esm/LRUMap.js +326 -326
  187. package/lib/esm/LRUMap.js.map +1 -1
  188. package/lib/esm/Logger.d.ts +143 -143
  189. package/lib/esm/Logger.d.ts.map +1 -1
  190. package/lib/esm/Logger.js +253 -253
  191. package/lib/esm/Logger.js.map +1 -1
  192. package/lib/esm/ObservableSet.d.ts +23 -23
  193. package/lib/esm/ObservableSet.js +47 -47
  194. package/lib/esm/ObservableSet.js.map +1 -1
  195. package/lib/esm/OneAtATimeAction.d.ts +31 -31
  196. package/lib/esm/OneAtATimeAction.js +89 -89
  197. package/lib/esm/OneAtATimeAction.js.map +1 -1
  198. package/lib/esm/OrderedId64Iterable.d.ts +74 -74
  199. package/lib/esm/OrderedId64Iterable.d.ts.map +1 -1
  200. package/lib/esm/OrderedId64Iterable.js +232 -232
  201. package/lib/esm/OrderedId64Iterable.js.map +1 -1
  202. package/lib/esm/OrderedSet.d.ts +40 -40
  203. package/lib/esm/OrderedSet.js +59 -59
  204. package/lib/esm/OrderedSet.js.map +1 -1
  205. package/lib/esm/PriorityQueue.d.ts +70 -70
  206. package/lib/esm/PriorityQueue.d.ts.map +1 -1
  207. package/lib/esm/PriorityQueue.js +136 -136
  208. package/lib/esm/PriorityQueue.js.map +1 -1
  209. package/lib/esm/ProcessDetector.d.ts +59 -59
  210. package/lib/esm/ProcessDetector.js +67 -67
  211. package/lib/esm/ProcessDetector.js.map +1 -1
  212. package/lib/esm/SortedArray.d.ts +236 -232
  213. package/lib/esm/SortedArray.d.ts.map +1 -1
  214. package/lib/esm/SortedArray.js +308 -296
  215. package/lib/esm/SortedArray.js.map +1 -1
  216. package/lib/esm/StatusCategory.d.ts +30 -30
  217. package/lib/esm/StatusCategory.d.ts.map +1 -1
  218. package/lib/esm/StatusCategory.js +455 -454
  219. package/lib/esm/StatusCategory.js.map +1 -1
  220. package/lib/esm/StringUtils.d.ts +22 -22
  221. package/lib/esm/StringUtils.js +142 -142
  222. package/lib/esm/StringUtils.js.map +1 -1
  223. package/lib/esm/Time.d.ts +122 -122
  224. package/lib/esm/Time.js +146 -146
  225. package/lib/esm/Time.js.map +1 -1
  226. package/lib/esm/Tracing.d.ts +43 -40
  227. package/lib/esm/Tracing.d.ts.map +1 -1
  228. package/lib/esm/Tracing.js +130 -126
  229. package/lib/esm/Tracing.js.map +1 -1
  230. package/lib/esm/TupleKeyedMap.d.ts +36 -36
  231. package/lib/esm/TupleKeyedMap.js +98 -98
  232. package/lib/esm/TupleKeyedMap.js.map +1 -1
  233. package/lib/esm/TypedArrayBuilder.d.ts +155 -155
  234. package/lib/esm/TypedArrayBuilder.d.ts.map +1 -1
  235. package/lib/esm/TypedArrayBuilder.js +198 -200
  236. package/lib/esm/TypedArrayBuilder.js.map +1 -1
  237. package/lib/esm/UnexpectedErrors.d.ts +43 -43
  238. package/lib/esm/UnexpectedErrors.d.ts.map +1 -1
  239. package/lib/esm/UnexpectedErrors.js +65 -64
  240. package/lib/esm/UnexpectedErrors.js.map +1 -1
  241. package/lib/esm/UtilityTypes.d.ts +112 -96
  242. package/lib/esm/UtilityTypes.d.ts.map +1 -1
  243. package/lib/esm/UtilityTypes.js +34 -34
  244. package/lib/esm/UtilityTypes.js.map +1 -1
  245. package/lib/esm/YieldManager.d.ts +18 -18
  246. package/lib/esm/YieldManager.js +30 -30
  247. package/lib/esm/YieldManager.js.map +1 -1
  248. package/lib/esm/core-bentley.d.ts +74 -74
  249. package/lib/esm/core-bentley.js +78 -78
  250. package/lib/esm/core-bentley.js.map +1 -1
  251. package/lib/esm/partitionArray.d.ts +21 -21
  252. package/lib/esm/partitionArray.js +39 -39
  253. package/lib/esm/partitionArray.js.map +1 -1
  254. package/package.json +9 -9
@@ -1,75 +1,75 @@
1
- /** @packageDocumentation
2
- * @module Ids
3
- */
4
- import { CompressedId64Set } from "./CompressedId64Set";
5
- import { Id64Array, Id64String } from "./Id";
6
- /** @public */
7
- export declare type OrderedId64Iterable = Iterable<Id64String>;
8
- /** A collection of **valid** [[Id64String]]s sorted in ascending order by the unsigned 64-bit integer value of the Ids.
9
- * This ordering is a requirement for several groups of APIs including [[CompressedId64Set]].
10
- * When used as input to a function, duplicate Ids are ignored; when returned as a function output, no duplicates are present.
11
- * @see [[CompressedId64Set]] for a compact string representation of such an ordered collection.
12
- * @see [[OrderedId64Iterable.compare]] for a function that compares Ids based on this criterion.
13
- * @see [[OrderedId64Array]] for a mutable implementation.
14
- * @public
15
- */
16
- export declare namespace OrderedId64Iterable {
17
- /** An ordered comparison of [[Id64String]]s suitable for use with sorting routines like
18
- * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) and sorted containers
19
- * like [[SortedArray]] and [[Dictionary]]. The comparison compares the 64-bit numerical values of the two Ids, returning a negative number if lhs < rhs,
20
- * a positive number if lhs > rhs, or zero if lhs == rhs.
21
- * The default string comparison is fine (and more efficient) when numerical ordering is not required; use this instead if you want e.g., "0x100" to be greater than "0xf".
22
- * @see [[OrderedId64Iterable.sortArray]] for a convenient way to sort an array of Id64Strings.
23
- */
24
- function compare(lhs: Id64String, rhs: Id64String): number;
25
- /** Sort an array of [[Id64String]]s **in-place** in ascending order by their 64-bit numerical values.
26
- * @see [[OrderedId64Iterable.compare]] for the comparison routine used.
27
- * @returns the input array.
28
- * @note This function returns its input for consistency with Javascript's
29
- * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) method.
30
- * It **does not** create a **new** array.
31
- */
32
- function sortArray(ids: Id64Array): Id64Array;
33
- /** Given two ordered collections of [[Id64String]]s, determine whether they are identical sets. Duplicate Ids are ignored.
34
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
35
- */
36
- function areEqualSets(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): boolean;
37
- /** Given an ordered collection of [[Id64String]]s, determine if it contains any Ids.
38
- * @param ids A well-formed, ordered collection of zero or more valid Ids.
39
- * @returns true if the input represents an empty set of Ids. The result is unspecified if the input does not meet the criteria for the input type.
40
- */
41
- function isEmptySet(ids: OrderedId64Iterable | CompressedId64Set): boolean;
42
- /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered collection containing no duplicates.
43
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
44
- */
45
- function unique(ids: OrderedId64Iterable): OrderedId64Iterable;
46
- /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered iterator over the distinct Ids, eliminating duplicates.
47
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
48
- */
49
- function uniqueIterator(ids: OrderedId64Iterable): Generator<string, void, unknown>;
50
- /** Given two ordered collections of [[Id64String]]s, produce a collection representing their union - i.e., the Ids that are present in either or both collections.
51
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
52
- */
53
- function union(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): OrderedId64Iterable;
54
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
55
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
56
- */
57
- function intersection(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): OrderedId64Iterable;
58
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
59
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
60
- */
61
- function difference(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): OrderedId64Iterable;
62
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their union - i.e., the Ids that are present in either or both collections.
63
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
64
- */
65
- function unionIterator(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): Generator<string, void, unknown>;
66
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
67
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
68
- */
69
- function intersectionIterator(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): Generator<string, void, unknown>;
70
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
71
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
72
- */
73
- function differenceIterator(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): Generator<string, void, unknown>;
74
- }
1
+ /** @packageDocumentation
2
+ * @module Ids
3
+ */
4
+ import { CompressedId64Set } from "./CompressedId64Set";
5
+ import { Id64Array, Id64String } from "./Id";
6
+ /** @public */
7
+ export type OrderedId64Iterable = Iterable<Id64String>;
8
+ /** A collection of **valid** [[Id64String]]s sorted in ascending order by the unsigned 64-bit integer value of the Ids.
9
+ * This ordering is a requirement for several groups of APIs including [[CompressedId64Set]].
10
+ * When used as input to a function, duplicate Ids are ignored; when returned as a function output, no duplicates are present.
11
+ * @see [[CompressedId64Set]] for a compact string representation of such an ordered collection.
12
+ * @see [[OrderedId64Iterable.compare]] for a function that compares Ids based on this criterion.
13
+ * @see [[OrderedId64Array]] for a mutable implementation.
14
+ * @public
15
+ */
16
+ export declare namespace OrderedId64Iterable {
17
+ /** An ordered comparison of [[Id64String]]s suitable for use with sorting routines like
18
+ * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) and sorted containers
19
+ * like [[SortedArray]] and [[Dictionary]]. The comparison compares the 64-bit numerical values of the two Ids, returning a negative number if lhs < rhs,
20
+ * a positive number if lhs > rhs, or zero if lhs == rhs.
21
+ * The default string comparison is fine (and more efficient) when numerical ordering is not required; use this instead if you want e.g., "0x100" to be greater than "0xf".
22
+ * @see [[OrderedId64Iterable.sortArray]] for a convenient way to sort an array of Id64Strings.
23
+ */
24
+ function compare(lhs: Id64String, rhs: Id64String): number;
25
+ /** Sort an array of [[Id64String]]s **in-place** in ascending order by their 64-bit numerical values.
26
+ * @see [[OrderedId64Iterable.compare]] for the comparison routine used.
27
+ * @returns the input array.
28
+ * @note This function returns its input for consistency with Javascript's
29
+ * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) method.
30
+ * It **does not** create a **new** array.
31
+ */
32
+ function sortArray(ids: Id64Array): Id64Array;
33
+ /** Given two ordered collections of [[Id64String]]s, determine whether they are identical sets. Duplicate Ids are ignored.
34
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
35
+ */
36
+ function areEqualSets(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): boolean;
37
+ /** Given an ordered collection of [[Id64String]]s, determine if it contains any Ids.
38
+ * @param ids A well-formed, ordered collection of zero or more valid Ids.
39
+ * @returns true if the input represents an empty set of Ids. The result is unspecified if the input does not meet the criteria for the input type.
40
+ */
41
+ function isEmptySet(ids: OrderedId64Iterable | CompressedId64Set): boolean;
42
+ /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered collection containing no duplicates.
43
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
44
+ */
45
+ function unique(ids: OrderedId64Iterable): OrderedId64Iterable;
46
+ /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered iterator over the distinct Ids, eliminating duplicates.
47
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
48
+ */
49
+ function uniqueIterator(ids: OrderedId64Iterable): Generator<string, void, unknown>;
50
+ /** Given two ordered collections of [[Id64String]]s, produce a collection representing their union - i.e., the Ids that are present in either or both collections.
51
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
52
+ */
53
+ function union(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): OrderedId64Iterable;
54
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
55
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
56
+ */
57
+ function intersection(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): OrderedId64Iterable;
58
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
59
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
60
+ */
61
+ function difference(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): OrderedId64Iterable;
62
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their union - i.e., the Ids that are present in either or both collections.
63
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
64
+ */
65
+ function unionIterator(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): Generator<string, void, unknown>;
66
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
67
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
68
+ */
69
+ function intersectionIterator(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): Generator<string, void, unknown>;
70
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
71
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
72
+ */
73
+ function differenceIterator(ids1: OrderedId64Iterable, ids2: OrderedId64Iterable): Generator<string, void, unknown>;
74
+ }
75
75
  //# sourceMappingURL=OrderedId64Iterable.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"OrderedId64Iterable.d.ts","sourceRoot":"","sources":["../../src/OrderedId64Iterable.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAE7C,cAAc;AACd,oBAAY,mBAAmB,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;AAEvD;;;;;;;GAOG;AACH,yBAAiB,mBAAmB,CAAC;IACnC;;;;;;OAMG;IACH,SAAgB,OAAO,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU,GAAG,MAAM,CAUhE;IAED;;;;;;OAMG;IACH,SAAgB,SAAS,CAAC,GAAG,EAAE,SAAS,GAAG,SAAS,CAGnD;IAED;;OAEG;IACH,SAAgB,YAAY,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAoB1F;IAED;;;OAGG;IACH,SAAgB,UAAU,CAAC,GAAG,EAAE,mBAAmB,GAAG,iBAAiB,GAAG,OAAO,CAKhF;IAED;;OAEG;IACH,SAAgB,MAAM,CAAC,GAAG,EAAE,mBAAmB,GAAG,mBAAmB,CAEpE;IAED;;OAEG;IACH,SAAiB,cAAc,CAAC,GAAG,EAAE,mBAAmB,oCAavD;IAED;;OAEG;IACH,SAAgB,KAAK,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,mBAAmB,CAE/F;IAED;;OAEG;IACH,SAAgB,YAAY,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,mBAAmB,CAEtG;IAED;;OAEG;IACH,SAAgB,UAAU,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,mBAAmB,CAEpG;IAED;;OAEG;IACH,SAAiB,aAAa,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,oCA0ClF;IAED;;OAEG;IACH,SAAiB,oBAAoB,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,oCA6BzF;IAED;;OAEG;IACH,SAAiB,kBAAkB,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,oCAiCvF;CACF"}
1
+ {"version":3,"file":"OrderedId64Iterable.d.ts","sourceRoot":"","sources":["../../src/OrderedId64Iterable.ts"],"names":[],"mappings":"AAIA;;GAEG;AAGH,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAE7C,cAAc;AACd,MAAM,MAAM,mBAAmB,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;AAEvD;;;;;;;GAOG;AACH,yBAAiB,mBAAmB,CAAC;IACnC;;;;;;OAMG;IACH,SAAgB,OAAO,CAAC,GAAG,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU,GAAG,MAAM,CAUhE;IAED;;;;;;OAMG;IACH,SAAgB,SAAS,CAAC,GAAG,EAAE,SAAS,GAAG,SAAS,CAGnD;IAED;;OAEG;IACH,SAAgB,YAAY,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,OAAO,CAoB1F;IAED;;;OAGG;IACH,SAAgB,UAAU,CAAC,GAAG,EAAE,mBAAmB,GAAG,iBAAiB,GAAG,OAAO,CAKhF;IAED;;OAEG;IACH,SAAgB,MAAM,CAAC,GAAG,EAAE,mBAAmB,GAAG,mBAAmB,CAEpE;IAED;;OAEG;IACH,SAAiB,cAAc,CAAC,GAAG,EAAE,mBAAmB,oCAavD;IAED;;OAEG;IACH,SAAgB,KAAK,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,mBAAmB,CAE/F;IAED;;OAEG;IACH,SAAgB,YAAY,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,mBAAmB,CAEtG;IAED;;OAEG;IACH,SAAgB,UAAU,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,GAAG,mBAAmB,CAEpG;IAED;;OAEG;IACH,SAAiB,aAAa,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,oCA0ClF;IAED;;OAEG;IACH,SAAiB,oBAAoB,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,oCA6BzF;IAED;;OAEG;IACH,SAAiB,kBAAkB,CAAC,IAAI,EAAE,mBAAmB,EAAE,IAAI,EAAE,mBAAmB,oCAiCvF;CACF"}
@@ -1,233 +1,233 @@
1
- /*---------------------------------------------------------------------------------------------
2
- * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
- * See LICENSE.md in the project root for license terms and full copyright notice.
4
- *--------------------------------------------------------------------------------------------*/
5
- /** @packageDocumentation
6
- * @module Ids
7
- */
8
- import { assert } from "./Assert";
9
- /** A collection of **valid** [[Id64String]]s sorted in ascending order by the unsigned 64-bit integer value of the Ids.
10
- * This ordering is a requirement for several groups of APIs including [[CompressedId64Set]].
11
- * When used as input to a function, duplicate Ids are ignored; when returned as a function output, no duplicates are present.
12
- * @see [[CompressedId64Set]] for a compact string representation of such an ordered collection.
13
- * @see [[OrderedId64Iterable.compare]] for a function that compares Ids based on this criterion.
14
- * @see [[OrderedId64Array]] for a mutable implementation.
15
- * @public
16
- */
17
- export var OrderedId64Iterable;
18
- (function (OrderedId64Iterable) {
19
- /** An ordered comparison of [[Id64String]]s suitable for use with sorting routines like
20
- * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) and sorted containers
21
- * like [[SortedArray]] and [[Dictionary]]. The comparison compares the 64-bit numerical values of the two Ids, returning a negative number if lhs < rhs,
22
- * a positive number if lhs > rhs, or zero if lhs == rhs.
23
- * The default string comparison is fine (and more efficient) when numerical ordering is not required; use this instead if you want e.g., "0x100" to be greater than "0xf".
24
- * @see [[OrderedId64Iterable.sortArray]] for a convenient way to sort an array of Id64Strings.
25
- */
26
- function compare(lhs, rhs) {
27
- if (lhs.length !== rhs.length)
28
- return lhs.length < rhs.length ? -1 : 1;
29
- // This is faster than localeCompare(). Unclear why there is no string.compare() - would be generally useful in
30
- // array sort functions...
31
- if (lhs !== rhs)
32
- return lhs < rhs ? -1 : 1;
33
- return 0;
34
- }
35
- OrderedId64Iterable.compare = compare;
36
- /** Sort an array of [[Id64String]]s **in-place** in ascending order by their 64-bit numerical values.
37
- * @see [[OrderedId64Iterable.compare]] for the comparison routine used.
38
- * @returns the input array.
39
- * @note This function returns its input for consistency with Javascript's
40
- * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) method.
41
- * It **does not** create a **new** array.
42
- */
43
- function sortArray(ids) {
44
- ids.sort((x, y) => compare(x, y));
45
- return ids;
46
- }
47
- OrderedId64Iterable.sortArray = sortArray;
48
- /** Given two ordered collections of [[Id64String]]s, determine whether they are identical sets. Duplicate Ids are ignored.
49
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
50
- */
51
- function areEqualSets(ids1, ids2) {
52
- const leftIter = uniqueIterator(ids1);
53
- const rightIter = uniqueIterator(ids2);
54
- let leftState = leftIter.next();
55
- let rightState = rightIter.next();
56
- while (!leftState.done && !rightState.done) {
57
- const left = leftState.value;
58
- const right = rightState.value;
59
- if (0 !== compare(left, right))
60
- return false;
61
- leftState = leftIter.next();
62
- rightState = rightIter.next();
63
- }
64
- if (leftState.done && rightState.done)
65
- return true;
66
- return false;
67
- }
68
- OrderedId64Iterable.areEqualSets = areEqualSets;
69
- /** Given an ordered collection of [[Id64String]]s, determine if it contains any Ids.
70
- * @param ids A well-formed, ordered collection of zero or more valid Ids.
71
- * @returns true if the input represents an empty set of Ids. The result is unspecified if the input does not meet the criteria for the input type.
72
- */
73
- function isEmptySet(ids) {
74
- if (typeof ids === "string")
75
- return "" === ids;
76
- return true === ids[Symbol.iterator]().next().done;
77
- }
78
- OrderedId64Iterable.isEmptySet = isEmptySet;
79
- /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered collection containing no duplicates.
80
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
81
- */
82
- function unique(ids) {
83
- return { [Symbol.iterator]: () => uniqueIterator(ids) };
84
- }
85
- OrderedId64Iterable.unique = unique;
86
- /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered iterator over the distinct Ids, eliminating duplicates.
87
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
88
- */
89
- function* uniqueIterator(ids) {
90
- const iter = ids[Symbol.iterator]();
91
- let state = iter.next();
92
- let prev;
93
- while (!state.done) {
94
- const id = state.value;
95
- state = iter.next();
96
- if (id !== prev) {
97
- prev = id;
98
- yield id;
99
- }
100
- }
101
- }
102
- OrderedId64Iterable.uniqueIterator = uniqueIterator;
103
- /** Given two ordered collections of [[Id64String]]s, produce a collection representing their union - i.e., the Ids that are present in either or both collections.
104
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
105
- */
106
- function union(ids1, ids2) {
107
- return { [Symbol.iterator]: () => unionIterator(ids1, ids2) };
108
- }
109
- OrderedId64Iterable.union = union;
110
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
111
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
112
- */
113
- function intersection(ids1, ids2) {
114
- return { [Symbol.iterator]: () => intersectionIterator(ids1, ids2) };
115
- }
116
- OrderedId64Iterable.intersection = intersection;
117
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
118
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
119
- */
120
- function difference(ids1, ids2) {
121
- return { [Symbol.iterator]: () => differenceIterator(ids1, ids2) };
122
- }
123
- OrderedId64Iterable.difference = difference;
124
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their union - i.e., the Ids that are present in either or both collections.
125
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
126
- */
127
- function* unionIterator(ids1, ids2) {
128
- const leftIter = ids1[Symbol.iterator]();
129
- const rightIter = ids2[Symbol.iterator]();
130
- let leftState = leftIter.next();
131
- let rightState = rightIter.next();
132
- let prev;
133
- while (!leftState.done || !rightState.done) {
134
- const left = leftState.done ? undefined : leftState.value;
135
- const right = rightState.done ? undefined : rightState.value;
136
- assert(undefined !== left || undefined !== right);
137
- if (undefined === left && undefined === right)
138
- break;
139
- let next;
140
- if (undefined === left) {
141
- assert(undefined !== right);
142
- next = right;
143
- rightState = rightIter.next();
144
- }
145
- else if (undefined === right) {
146
- next = left;
147
- leftState = leftIter.next();
148
- }
149
- else {
150
- const cmp = compare(left, right);
151
- if (cmp <= 0) {
152
- next = left;
153
- leftState = leftIter.next();
154
- if (0 === cmp)
155
- rightState = rightIter.next();
156
- }
157
- else {
158
- next = right;
159
- rightState = rightIter.next();
160
- }
161
- }
162
- if (prev === next)
163
- continue;
164
- prev = next;
165
- yield next;
166
- }
167
- }
168
- OrderedId64Iterable.unionIterator = unionIterator;
169
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
170
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
171
- */
172
- function* intersectionIterator(ids1, ids2) {
173
- const leftIter = ids1[Symbol.iterator]();
174
- const rightIter = ids2[Symbol.iterator]();
175
- let leftState = leftIter.next();
176
- let rightState = rightIter.next();
177
- let prev;
178
- while (!leftState.done && !rightState.done) {
179
- const left = leftState.value;
180
- leftState = leftIter.next();
181
- if (left === prev)
182
- continue;
183
- prev = left;
184
- let right = rightState.value;
185
- let cmp = compare(left, right);
186
- while (cmp > 0) {
187
- rightState = rightIter.next();
188
- if (rightState.done)
189
- return;
190
- right = rightState.value;
191
- cmp = compare(left, right);
192
- }
193
- if (0 === cmp)
194
- yield left;
195
- }
196
- }
197
- OrderedId64Iterable.intersectionIterator = intersectionIterator;
198
- /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
199
- * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
200
- */
201
- function* differenceIterator(ids1, ids2) {
202
- const leftIter = ids1[Symbol.iterator]();
203
- const rightIter = ids2[Symbol.iterator]();
204
- let leftState = leftIter.next();
205
- let rightState = rightIter.next();
206
- let prev;
207
- while (!leftState.done) {
208
- const left = leftState.value;
209
- leftState = leftIter.next();
210
- if (left === prev)
211
- continue;
212
- else if (rightState.done) {
213
- yield prev = left;
214
- continue;
215
- }
216
- let right = rightState.value;
217
- let cmp = compare(left, right);
218
- while (cmp > 0 && !rightState.done) {
219
- rightState = rightIter.next();
220
- if (rightState.done) {
221
- yield prev = left;
222
- continue;
223
- }
224
- right = rightState.value;
225
- cmp = compare(left, right);
226
- }
227
- if (cmp < 0)
228
- yield prev = left;
229
- }
230
- }
231
- OrderedId64Iterable.differenceIterator = differenceIterator;
232
- })(OrderedId64Iterable || (OrderedId64Iterable = {}));
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Bentley Systems, Incorporated. All rights reserved.
3
+ * See LICENSE.md in the project root for license terms and full copyright notice.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ /** @packageDocumentation
6
+ * @module Ids
7
+ */
8
+ import { assert } from "./Assert";
9
+ /** A collection of **valid** [[Id64String]]s sorted in ascending order by the unsigned 64-bit integer value of the Ids.
10
+ * This ordering is a requirement for several groups of APIs including [[CompressedId64Set]].
11
+ * When used as input to a function, duplicate Ids are ignored; when returned as a function output, no duplicates are present.
12
+ * @see [[CompressedId64Set]] for a compact string representation of such an ordered collection.
13
+ * @see [[OrderedId64Iterable.compare]] for a function that compares Ids based on this criterion.
14
+ * @see [[OrderedId64Array]] for a mutable implementation.
15
+ * @public
16
+ */
17
+ export var OrderedId64Iterable;
18
+ (function (OrderedId64Iterable) {
19
+ /** An ordered comparison of [[Id64String]]s suitable for use with sorting routines like
20
+ * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) and sorted containers
21
+ * like [[SortedArray]] and [[Dictionary]]. The comparison compares the 64-bit numerical values of the two Ids, returning a negative number if lhs < rhs,
22
+ * a positive number if lhs > rhs, or zero if lhs == rhs.
23
+ * The default string comparison is fine (and more efficient) when numerical ordering is not required; use this instead if you want e.g., "0x100" to be greater than "0xf".
24
+ * @see [[OrderedId64Iterable.sortArray]] for a convenient way to sort an array of Id64Strings.
25
+ */
26
+ function compare(lhs, rhs) {
27
+ if (lhs.length !== rhs.length)
28
+ return lhs.length < rhs.length ? -1 : 1;
29
+ // This is faster than localeCompare(). Unclear why there is no string.compare() - would be generally useful in
30
+ // array sort functions...
31
+ if (lhs !== rhs)
32
+ return lhs < rhs ? -1 : 1;
33
+ return 0;
34
+ }
35
+ OrderedId64Iterable.compare = compare;
36
+ /** Sort an array of [[Id64String]]s **in-place** in ascending order by their 64-bit numerical values.
37
+ * @see [[OrderedId64Iterable.compare]] for the comparison routine used.
38
+ * @returns the input array.
39
+ * @note This function returns its input for consistency with Javascript's
40
+ * [Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort) method.
41
+ * It **does not** create a **new** array.
42
+ */
43
+ function sortArray(ids) {
44
+ ids.sort((x, y) => compare(x, y));
45
+ return ids;
46
+ }
47
+ OrderedId64Iterable.sortArray = sortArray;
48
+ /** Given two ordered collections of [[Id64String]]s, determine whether they are identical sets. Duplicate Ids are ignored.
49
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
50
+ */
51
+ function areEqualSets(ids1, ids2) {
52
+ const leftIter = uniqueIterator(ids1);
53
+ const rightIter = uniqueIterator(ids2);
54
+ let leftState = leftIter.next();
55
+ let rightState = rightIter.next();
56
+ while (!leftState.done && !rightState.done) {
57
+ const left = leftState.value;
58
+ const right = rightState.value;
59
+ if (0 !== compare(left, right))
60
+ return false;
61
+ leftState = leftIter.next();
62
+ rightState = rightIter.next();
63
+ }
64
+ if (leftState.done && rightState.done)
65
+ return true;
66
+ return false;
67
+ }
68
+ OrderedId64Iterable.areEqualSets = areEqualSets;
69
+ /** Given an ordered collection of [[Id64String]]s, determine if it contains any Ids.
70
+ * @param ids A well-formed, ordered collection of zero or more valid Ids.
71
+ * @returns true if the input represents an empty set of Ids. The result is unspecified if the input does not meet the criteria for the input type.
72
+ */
73
+ function isEmptySet(ids) {
74
+ if (typeof ids === "string")
75
+ return "" === ids;
76
+ return true === ids[Symbol.iterator]().next().done;
77
+ }
78
+ OrderedId64Iterable.isEmptySet = isEmptySet;
79
+ /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered collection containing no duplicates.
80
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
81
+ */
82
+ function unique(ids) {
83
+ return { [Symbol.iterator]: () => uniqueIterator(ids) };
84
+ }
85
+ OrderedId64Iterable.unique = unique;
86
+ /** Given an ordered collection of [[Id64String]]s possibly containing duplicates, produce an ordered iterator over the distinct Ids, eliminating duplicates.
87
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
88
+ */
89
+ function* uniqueIterator(ids) {
90
+ const iter = ids[Symbol.iterator]();
91
+ let state = iter.next();
92
+ let prev;
93
+ while (!state.done) {
94
+ const id = state.value;
95
+ state = iter.next();
96
+ if (id !== prev) {
97
+ prev = id;
98
+ yield id;
99
+ }
100
+ }
101
+ }
102
+ OrderedId64Iterable.uniqueIterator = uniqueIterator;
103
+ /** Given two ordered collections of [[Id64String]]s, produce a collection representing their union - i.e., the Ids that are present in either or both collections.
104
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
105
+ */
106
+ function union(ids1, ids2) {
107
+ return { [Symbol.iterator]: () => unionIterator(ids1, ids2) };
108
+ }
109
+ OrderedId64Iterable.union = union;
110
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
111
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
112
+ */
113
+ function intersection(ids1, ids2) {
114
+ return { [Symbol.iterator]: () => intersectionIterator(ids1, ids2) };
115
+ }
116
+ OrderedId64Iterable.intersection = intersection;
117
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
118
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
119
+ */
120
+ function difference(ids1, ids2) {
121
+ return { [Symbol.iterator]: () => differenceIterator(ids1, ids2) };
122
+ }
123
+ OrderedId64Iterable.difference = difference;
124
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their union - i.e., the Ids that are present in either or both collections.
125
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
126
+ */
127
+ function* unionIterator(ids1, ids2) {
128
+ const leftIter = ids1[Symbol.iterator]();
129
+ const rightIter = ids2[Symbol.iterator]();
130
+ let leftState = leftIter.next();
131
+ let rightState = rightIter.next();
132
+ let prev;
133
+ while (!leftState.done || !rightState.done) {
134
+ const left = leftState.done ? undefined : leftState.value;
135
+ const right = rightState.done ? undefined : rightState.value;
136
+ assert(undefined !== left || undefined !== right);
137
+ if (undefined === left && undefined === right)
138
+ break;
139
+ let next;
140
+ if (undefined === left) {
141
+ assert(undefined !== right);
142
+ next = right;
143
+ rightState = rightIter.next();
144
+ }
145
+ else if (undefined === right) {
146
+ next = left;
147
+ leftState = leftIter.next();
148
+ }
149
+ else {
150
+ const cmp = compare(left, right);
151
+ if (cmp <= 0) {
152
+ next = left;
153
+ leftState = leftIter.next();
154
+ if (0 === cmp)
155
+ rightState = rightIter.next();
156
+ }
157
+ else {
158
+ next = right;
159
+ rightState = rightIter.next();
160
+ }
161
+ }
162
+ if (prev === next)
163
+ continue;
164
+ prev = next;
165
+ yield next;
166
+ }
167
+ }
168
+ OrderedId64Iterable.unionIterator = unionIterator;
169
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their intersection - i.e., the Ids that are present in both collections.
170
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
171
+ */
172
+ function* intersectionIterator(ids1, ids2) {
173
+ const leftIter = ids1[Symbol.iterator]();
174
+ const rightIter = ids2[Symbol.iterator]();
175
+ let leftState = leftIter.next();
176
+ let rightState = rightIter.next();
177
+ let prev;
178
+ while (!leftState.done && !rightState.done) {
179
+ const left = leftState.value;
180
+ leftState = leftIter.next();
181
+ if (left === prev)
182
+ continue;
183
+ prev = left;
184
+ let right = rightState.value;
185
+ let cmp = compare(left, right);
186
+ while (cmp > 0) {
187
+ rightState = rightIter.next();
188
+ if (rightState.done)
189
+ return;
190
+ right = rightState.value;
191
+ cmp = compare(left, right);
192
+ }
193
+ if (0 === cmp)
194
+ yield left;
195
+ }
196
+ }
197
+ OrderedId64Iterable.intersectionIterator = intersectionIterator;
198
+ /** Given two ordered collections of [[Id64String]]s, produce an iterator representing their difference - i.e., the Ids that are present in `ids1` but not present in `ids2`.
199
+ * @note If the inputs are not ordered as required by [[OrderedId64Iterable]], the results are unpredictable.
200
+ */
201
+ function* differenceIterator(ids1, ids2) {
202
+ const leftIter = ids1[Symbol.iterator]();
203
+ const rightIter = ids2[Symbol.iterator]();
204
+ let leftState = leftIter.next();
205
+ let rightState = rightIter.next();
206
+ let prev;
207
+ while (!leftState.done) {
208
+ const left = leftState.value;
209
+ leftState = leftIter.next();
210
+ if (left === prev)
211
+ continue;
212
+ else if (rightState.done) {
213
+ yield prev = left;
214
+ continue;
215
+ }
216
+ let right = rightState.value;
217
+ let cmp = compare(left, right);
218
+ while (cmp > 0 && !rightState.done) {
219
+ rightState = rightIter.next();
220
+ if (rightState.done) {
221
+ yield prev = left;
222
+ continue;
223
+ }
224
+ right = rightState.value;
225
+ cmp = compare(left, right);
226
+ }
227
+ if (cmp < 0)
228
+ yield prev = left;
229
+ }
230
+ }
231
+ OrderedId64Iterable.differenceIterator = differenceIterator;
232
+ })(OrderedId64Iterable || (OrderedId64Iterable = {}));
233
233
  //# sourceMappingURL=OrderedId64Iterable.js.map