@itwin/core-bentley 4.0.0-dev.24 → 4.0.0-dev.28

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 (222) hide show
  1. package/CHANGELOG.md +18 -11
  2. package/lib/cjs/AccessToken.d.ts +10 -10
  3. package/lib/cjs/AccessToken.js +9 -9
  4. package/lib/cjs/AccessToken.js.map +1 -1
  5. package/lib/cjs/Assert.d.ts +25 -25
  6. package/lib/cjs/Assert.js +45 -45
  7. package/lib/cjs/Assert.js.map +1 -1
  8. package/lib/cjs/BeEvent.d.ts +81 -81
  9. package/lib/cjs/BeEvent.js +156 -156
  10. package/lib/cjs/BeEvent.js.map +1 -1
  11. package/lib/cjs/BeSQLite.d.ts +172 -170
  12. package/lib/cjs/BeSQLite.d.ts.map +1 -1
  13. package/lib/cjs/BeSQLite.js +185 -183
  14. package/lib/cjs/BeSQLite.js.map +1 -1
  15. package/lib/cjs/BentleyError.d.ts +378 -378
  16. package/lib/cjs/BentleyError.d.ts.map +1 -1
  17. package/lib/cjs/BentleyError.js +703 -702
  18. package/lib/cjs/BentleyError.js.map +1 -1
  19. package/lib/cjs/BentleyLoggerCategory.d.ts +11 -11
  20. package/lib/cjs/BentleyLoggerCategory.js +19 -19
  21. package/lib/cjs/BentleyLoggerCategory.js.map +1 -1
  22. package/lib/cjs/ByteStream.d.ts +110 -110
  23. package/lib/cjs/ByteStream.js +159 -159
  24. package/lib/cjs/ByteStream.js.map +1 -1
  25. package/lib/cjs/ClassUtils.d.ts +14 -14
  26. package/lib/cjs/ClassUtils.js +27 -27
  27. package/lib/cjs/ClassUtils.js.map +1 -1
  28. package/lib/cjs/Compare.d.ts +47 -47
  29. package/lib/cjs/Compare.js +75 -75
  30. package/lib/cjs/Compare.js.map +1 -1
  31. package/lib/cjs/CompressedId64Set.d.ts +134 -134
  32. package/lib/cjs/CompressedId64Set.js +428 -428
  33. package/lib/cjs/CompressedId64Set.js.map +1 -1
  34. package/lib/cjs/Dictionary.d.ts +125 -125
  35. package/lib/cjs/Dictionary.js +203 -203
  36. package/lib/cjs/Dictionary.js.map +1 -1
  37. package/lib/cjs/Disposable.d.ts +80 -80
  38. package/lib/cjs/Disposable.js +120 -120
  39. package/lib/cjs/Disposable.js.map +1 -1
  40. package/lib/cjs/Id.d.ts +285 -285
  41. package/lib/cjs/Id.js +643 -643
  42. package/lib/cjs/Id.js.map +1 -1
  43. package/lib/cjs/IndexMap.d.ts +65 -65
  44. package/lib/cjs/IndexMap.js +91 -91
  45. package/lib/cjs/IndexMap.js.map +1 -1
  46. package/lib/cjs/JsonSchema.d.ts +77 -77
  47. package/lib/cjs/JsonSchema.js +9 -9
  48. package/lib/cjs/JsonSchema.js.map +1 -1
  49. package/lib/cjs/JsonUtils.d.ts +78 -78
  50. package/lib/cjs/JsonUtils.js +151 -151
  51. package/lib/cjs/JsonUtils.js.map +1 -1
  52. package/lib/cjs/LRUMap.d.ts +129 -129
  53. package/lib/cjs/LRUMap.js +333 -333
  54. package/lib/cjs/LRUMap.js.map +1 -1
  55. package/lib/cjs/Logger.d.ts +143 -143
  56. package/lib/cjs/Logger.js +256 -258
  57. package/lib/cjs/Logger.js.map +1 -1
  58. package/lib/cjs/ObservableSet.d.ts +23 -23
  59. package/lib/cjs/ObservableSet.js +51 -51
  60. package/lib/cjs/ObservableSet.js.map +1 -1
  61. package/lib/cjs/OneAtATimeAction.d.ts +31 -31
  62. package/lib/cjs/OneAtATimeAction.js +94 -94
  63. package/lib/cjs/OneAtATimeAction.js.map +1 -1
  64. package/lib/cjs/OrderedId64Iterable.d.ts +74 -74
  65. package/lib/cjs/OrderedId64Iterable.js +235 -235
  66. package/lib/cjs/OrderedId64Iterable.js.map +1 -1
  67. package/lib/cjs/OrderedSet.d.ts +40 -40
  68. package/lib/cjs/OrderedSet.js +64 -64
  69. package/lib/cjs/OrderedSet.js.map +1 -1
  70. package/lib/cjs/PriorityQueue.d.ts +70 -70
  71. package/lib/cjs/PriorityQueue.js +140 -140
  72. package/lib/cjs/PriorityQueue.js.map +1 -1
  73. package/lib/cjs/ProcessDetector.d.ts +59 -59
  74. package/lib/cjs/ProcessDetector.js +71 -71
  75. package/lib/cjs/ProcessDetector.js.map +1 -1
  76. package/lib/cjs/SortedArray.d.ts +236 -236
  77. package/lib/cjs/SortedArray.js +315 -315
  78. package/lib/cjs/SortedArray.js.map +1 -1
  79. package/lib/cjs/StatusCategory.d.ts +30 -30
  80. package/lib/cjs/StatusCategory.js +460 -460
  81. package/lib/cjs/StatusCategory.js.map +1 -1
  82. package/lib/cjs/StringUtils.d.ts +22 -22
  83. package/lib/cjs/StringUtils.js +148 -148
  84. package/lib/cjs/StringUtils.js.map +1 -1
  85. package/lib/cjs/Time.d.ts +122 -122
  86. package/lib/cjs/Time.js +152 -152
  87. package/lib/cjs/Time.js.map +1 -1
  88. package/lib/cjs/Tracing.d.ts +40 -40
  89. package/lib/cjs/Tracing.js +127 -130
  90. package/lib/cjs/Tracing.js.map +1 -1
  91. package/lib/cjs/TupleKeyedMap.d.ts +36 -36
  92. package/lib/cjs/TupleKeyedMap.js +102 -102
  93. package/lib/cjs/TupleKeyedMap.js.map +1 -1
  94. package/lib/cjs/TypedArrayBuilder.d.ts +155 -155
  95. package/lib/cjs/TypedArrayBuilder.js +206 -208
  96. package/lib/cjs/TypedArrayBuilder.js.map +1 -1
  97. package/lib/cjs/UnexpectedErrors.d.ts +43 -43
  98. package/lib/cjs/UnexpectedErrors.js +68 -68
  99. package/lib/cjs/UnexpectedErrors.js.map +1 -1
  100. package/lib/cjs/UtilityTypes.d.ts +96 -96
  101. package/lib/cjs/UtilityTypes.js +40 -40
  102. package/lib/cjs/UtilityTypes.js.map +1 -1
  103. package/lib/cjs/YieldManager.d.ts +18 -18
  104. package/lib/cjs/YieldManager.js +34 -34
  105. package/lib/cjs/YieldManager.js.map +1 -1
  106. package/lib/cjs/core-bentley.d.ts +74 -74
  107. package/lib/cjs/core-bentley.js +90 -90
  108. package/lib/cjs/core-bentley.js.map +1 -1
  109. package/lib/cjs/partitionArray.d.ts +21 -21
  110. package/lib/cjs/partitionArray.js +43 -43
  111. package/lib/cjs/partitionArray.js.map +1 -1
  112. package/lib/esm/AccessToken.d.ts +10 -10
  113. package/lib/esm/AccessToken.js +8 -8
  114. package/lib/esm/AccessToken.js.map +1 -1
  115. package/lib/esm/Assert.d.ts +25 -25
  116. package/lib/esm/Assert.js +41 -41
  117. package/lib/esm/Assert.js.map +1 -1
  118. package/lib/esm/BeEvent.d.ts +81 -81
  119. package/lib/esm/BeEvent.js +150 -150
  120. package/lib/esm/BeEvent.js.map +1 -1
  121. package/lib/esm/BeSQLite.d.ts +172 -170
  122. package/lib/esm/BeSQLite.d.ts.map +1 -1
  123. package/lib/esm/BeSQLite.js +182 -180
  124. package/lib/esm/BeSQLite.js.map +1 -1
  125. package/lib/esm/BentleyError.d.ts +378 -378
  126. package/lib/esm/BentleyError.d.ts.map +1 -1
  127. package/lib/esm/BentleyError.js +699 -698
  128. package/lib/esm/BentleyError.js.map +1 -1
  129. package/lib/esm/BentleyLoggerCategory.d.ts +11 -11
  130. package/lib/esm/BentleyLoggerCategory.js +16 -16
  131. package/lib/esm/BentleyLoggerCategory.js.map +1 -1
  132. package/lib/esm/ByteStream.d.ts +110 -110
  133. package/lib/esm/ByteStream.js +155 -155
  134. package/lib/esm/ByteStream.js.map +1 -1
  135. package/lib/esm/ClassUtils.d.ts +14 -14
  136. package/lib/esm/ClassUtils.js +22 -22
  137. package/lib/esm/ClassUtils.js.map +1 -1
  138. package/lib/esm/Compare.d.ts +47 -47
  139. package/lib/esm/Compare.js +63 -63
  140. package/lib/esm/Compare.js.map +1 -1
  141. package/lib/esm/CompressedId64Set.d.ts +134 -134
  142. package/lib/esm/CompressedId64Set.js +423 -423
  143. package/lib/esm/CompressedId64Set.js.map +1 -1
  144. package/lib/esm/Dictionary.d.ts +125 -125
  145. package/lib/esm/Dictionary.js +199 -199
  146. package/lib/esm/Dictionary.js.map +1 -1
  147. package/lib/esm/Disposable.d.ts +80 -80
  148. package/lib/esm/Disposable.js +112 -112
  149. package/lib/esm/Disposable.js.map +1 -1
  150. package/lib/esm/Id.d.ts +285 -285
  151. package/lib/esm/Id.js +639 -639
  152. package/lib/esm/Id.js.map +1 -1
  153. package/lib/esm/IndexMap.d.ts +65 -65
  154. package/lib/esm/IndexMap.js +86 -86
  155. package/lib/esm/IndexMap.js.map +1 -1
  156. package/lib/esm/JsonSchema.d.ts +77 -77
  157. package/lib/esm/JsonSchema.js +8 -8
  158. package/lib/esm/JsonSchema.js.map +1 -1
  159. package/lib/esm/JsonUtils.d.ts +78 -78
  160. package/lib/esm/JsonUtils.js +148 -148
  161. package/lib/esm/JsonUtils.js.map +1 -1
  162. package/lib/esm/LRUMap.d.ts +129 -129
  163. package/lib/esm/LRUMap.js +326 -326
  164. package/lib/esm/LRUMap.js.map +1 -1
  165. package/lib/esm/Logger.d.ts +143 -143
  166. package/lib/esm/Logger.js +251 -253
  167. package/lib/esm/Logger.js.map +1 -1
  168. package/lib/esm/ObservableSet.d.ts +23 -23
  169. package/lib/esm/ObservableSet.js +47 -47
  170. package/lib/esm/ObservableSet.js.map +1 -1
  171. package/lib/esm/OneAtATimeAction.d.ts +31 -31
  172. package/lib/esm/OneAtATimeAction.js +89 -89
  173. package/lib/esm/OneAtATimeAction.js.map +1 -1
  174. package/lib/esm/OrderedId64Iterable.d.ts +74 -74
  175. package/lib/esm/OrderedId64Iterable.js +232 -232
  176. package/lib/esm/OrderedId64Iterable.js.map +1 -1
  177. package/lib/esm/OrderedSet.d.ts +40 -40
  178. package/lib/esm/OrderedSet.js +59 -59
  179. package/lib/esm/OrderedSet.js.map +1 -1
  180. package/lib/esm/PriorityQueue.d.ts +70 -70
  181. package/lib/esm/PriorityQueue.js +136 -136
  182. package/lib/esm/PriorityQueue.js.map +1 -1
  183. package/lib/esm/ProcessDetector.d.ts +59 -59
  184. package/lib/esm/ProcessDetector.js +67 -67
  185. package/lib/esm/ProcessDetector.js.map +1 -1
  186. package/lib/esm/SortedArray.d.ts +236 -236
  187. package/lib/esm/SortedArray.js +308 -308
  188. package/lib/esm/SortedArray.js.map +1 -1
  189. package/lib/esm/StatusCategory.d.ts +30 -30
  190. package/lib/esm/StatusCategory.js +454 -454
  191. package/lib/esm/StatusCategory.js.map +1 -1
  192. package/lib/esm/StringUtils.d.ts +22 -22
  193. package/lib/esm/StringUtils.js +142 -142
  194. package/lib/esm/StringUtils.js.map +1 -1
  195. package/lib/esm/Time.d.ts +122 -122
  196. package/lib/esm/Time.js +146 -146
  197. package/lib/esm/Time.js.map +1 -1
  198. package/lib/esm/Tracing.d.ts +40 -40
  199. package/lib/esm/Tracing.js +123 -126
  200. package/lib/esm/Tracing.js.map +1 -1
  201. package/lib/esm/TupleKeyedMap.d.ts +36 -36
  202. package/lib/esm/TupleKeyedMap.js +98 -98
  203. package/lib/esm/TupleKeyedMap.js.map +1 -1
  204. package/lib/esm/TypedArrayBuilder.d.ts +155 -155
  205. package/lib/esm/TypedArrayBuilder.js +198 -200
  206. package/lib/esm/TypedArrayBuilder.js.map +1 -1
  207. package/lib/esm/UnexpectedErrors.d.ts +43 -43
  208. package/lib/esm/UnexpectedErrors.js +64 -64
  209. package/lib/esm/UnexpectedErrors.js.map +1 -1
  210. package/lib/esm/UtilityTypes.d.ts +96 -96
  211. package/lib/esm/UtilityTypes.js +34 -34
  212. package/lib/esm/UtilityTypes.js.map +1 -1
  213. package/lib/esm/YieldManager.d.ts +18 -18
  214. package/lib/esm/YieldManager.js +30 -30
  215. package/lib/esm/YieldManager.js.map +1 -1
  216. package/lib/esm/core-bentley.d.ts +74 -74
  217. package/lib/esm/core-bentley.js +78 -78
  218. package/lib/esm/core-bentley.js.map +1 -1
  219. package/lib/esm/partitionArray.d.ts +21 -21
  220. package/lib/esm/partitionArray.js +39 -39
  221. package/lib/esm/partitionArray.js.map +1 -1
  222. package/package.json +3 -3
package/lib/esm/Assert.js CHANGED
@@ -1,42 +1,42 @@
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 Utils
7
- */
8
- const assertionsEnabled = process.env.NODE_ENV === "development";
9
- /** Asserts that a condition is `true` and - when enabled - throws an error if it is not.
10
- * Assertions are enabled only if the build configuration defines `process.env.NODE_ENV` as `development` at build time.
11
- *
12
- * Assertions exist solely to assist programmers during development, in the following ways:
13
- * 1 They allow the programmer to declare conditions that they believe cannot possibly occur. If such conditions occur, they indicate
14
- * a serious flaw in the programmer's logic.
15
- * 2 They allow the programmer to assure the TypeScript compiler of the truth of some condition that the compiler cannot itself infer.
16
- * 3 They allow the author of an API to indicate to consumers of the API a serious misuse that should be corrected during development.
17
- *
18
- * Assertions should **never** be used to test for conditions - however unlikely - that could be expected to occur at run-time,
19
- * such as failing to write to a file or load a resource over the network. If the condition asserted ever fails in a production environment,
20
- * the programmer has made a serious mistake.
21
- *
22
- * Note that even when assertions are disabled, calls to `assert` remain in the code and their arguments will be evaluated at run-time.
23
- * Therefore, if your condition or message requires computation, prefer to pass it as a function to prevent it from being evaluated when assertions are disabled.
24
- *
25
- * @param condition The condition that is asserted to be `true`. If the condition is more complex than a simple `boolean` variable, pass it as a function to prevent it from being evaluated when assertions are disabled.
26
- * @param message An optional description of the condition being asserted, to be included in the exception if `condition` is `false`. If the message must be computed, pass it as a function to prevent it from being evaluated when assertions are disabled. Defaults to "Programmer Error".
27
- * @throws Error containing the specified `message` if `condition` is `false`.
28
- * @public
29
- */
30
- export function assert(condition, message) {
31
- if (!assertionsEnabled)
32
- return;
33
- if ("boolean" !== typeof condition)
34
- condition = condition();
35
- if (condition)
36
- return;
37
- message = message !== null && message !== void 0 ? message : "Programmer Error";
38
- if ("string" !== typeof message)
39
- message = message();
40
- throw new Error(`Assert: ${message}`);
41
- }
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 Utils
7
+ */
8
+ const assertionsEnabled = process.env.NODE_ENV === "development";
9
+ /** Asserts that a condition is `true` and - when enabled - throws an error if it is not.
10
+ * Assertions are enabled only if the build configuration defines `process.env.NODE_ENV` as `development` at build time.
11
+ *
12
+ * Assertions exist solely to assist programmers during development, in the following ways:
13
+ * 1 They allow the programmer to declare conditions that they believe cannot possibly occur. If such conditions occur, they indicate
14
+ * a serious flaw in the programmer's logic.
15
+ * 2 They allow the programmer to assure the TypeScript compiler of the truth of some condition that the compiler cannot itself infer.
16
+ * 3 They allow the author of an API to indicate to consumers of the API a serious misuse that should be corrected during development.
17
+ *
18
+ * Assertions should **never** be used to test for conditions - however unlikely - that could be expected to occur at run-time,
19
+ * such as failing to write to a file or load a resource over the network. If the condition asserted ever fails in a production environment,
20
+ * the programmer has made a serious mistake.
21
+ *
22
+ * Note that even when assertions are disabled, calls to `assert` remain in the code and their arguments will be evaluated at run-time.
23
+ * Therefore, if your condition or message requires computation, prefer to pass it as a function to prevent it from being evaluated when assertions are disabled.
24
+ *
25
+ * @param condition The condition that is asserted to be `true`. If the condition is more complex than a simple `boolean` variable, pass it as a function to prevent it from being evaluated when assertions are disabled.
26
+ * @param message An optional description of the condition being asserted, to be included in the exception if `condition` is `false`. If the message must be computed, pass it as a function to prevent it from being evaluated when assertions are disabled. Defaults to "Programmer Error".
27
+ * @throws Error containing the specified `message` if `condition` is `false`.
28
+ * @public
29
+ */
30
+ export function assert(condition, message) {
31
+ if (!assertionsEnabled)
32
+ return;
33
+ if ("boolean" !== typeof condition)
34
+ condition = condition();
35
+ if (condition)
36
+ return;
37
+ message = message ?? "Programmer Error";
38
+ if ("string" !== typeof message)
39
+ message = message();
40
+ throw new Error(`Assert: ${message}`);
41
+ }
42
42
  //# sourceMappingURL=Assert.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Assert.js","sourceRoot":"","sources":["../../src/Assert.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,CAAC;AAEjE;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,UAAU,MAAM,CAAC,SAAoC,EAAE,OAAiC;IAC5F,IAAI,CAAC,iBAAiB;QACpB,OAAO;IAET,IAAI,SAAS,KAAK,OAAO,SAAS;QAChC,SAAS,GAAG,SAAS,EAAE,CAAC;IAE1B,IAAI,SAAS;QACX,OAAO;IAET,OAAO,GAAG,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,kBAAkB,CAAC;IACxC,IAAI,QAAQ,KAAK,OAAO,OAAO;QAC7B,OAAO,GAAG,OAAO,EAAE,CAAC;IAEtB,MAAM,IAAI,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;AACxC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Utils\r\n */\r\n\r\nconst assertionsEnabled = process.env.NODE_ENV === \"development\";\r\n\r\n/** Asserts that a condition is `true` and - when enabled - throws an error if it is not.\r\n * Assertions are enabled only if the build configuration defines `process.env.NODE_ENV` as `development` at build time.\r\n *\r\n * Assertions exist solely to assist programmers during development, in the following ways:\r\n * 1 They allow the programmer to declare conditions that they believe cannot possibly occur. If such conditions occur, they indicate\r\n * a serious flaw in the programmer's logic.\r\n * 2 They allow the programmer to assure the TypeScript compiler of the truth of some condition that the compiler cannot itself infer.\r\n * 3 They allow the author of an API to indicate to consumers of the API a serious misuse that should be corrected during development.\r\n *\r\n * Assertions should **never** be used to test for conditions - however unlikely - that could be expected to occur at run-time,\r\n * such as failing to write to a file or load a resource over the network. If the condition asserted ever fails in a production environment,\r\n * the programmer has made a serious mistake.\r\n *\r\n * Note that even when assertions are disabled, calls to `assert` remain in the code and their arguments will be evaluated at run-time.\r\n * Therefore, if your condition or message requires computation, prefer to pass it as a function to prevent it from being evaluated when assertions are disabled.\r\n *\r\n * @param condition The condition that is asserted to be `true`. If the condition is more complex than a simple `boolean` variable, pass it as a function to prevent it from being evaluated when assertions are disabled.\r\n * @param message An optional description of the condition being asserted, to be included in the exception if `condition` is `false`. If the message must be computed, pass it as a function to prevent it from being evaluated when assertions are disabled. Defaults to \"Programmer Error\".\r\n * @throws Error containing the specified `message` if `condition` is `false`.\r\n * @public\r\n */\r\nexport function assert(condition: boolean | (() => boolean), message?: string | (() => string)): asserts condition {\r\n if (!assertionsEnabled)\r\n return;\r\n\r\n if (\"boolean\" !== typeof condition)\r\n condition = condition();\r\n\r\n if (condition)\r\n return;\r\n\r\n message = message ?? \"Programmer Error\";\r\n if (\"string\" !== typeof message)\r\n message = message();\r\n\r\n throw new Error(`Assert: ${message}`);\r\n}\r\n"]}
1
+ {"version":3,"file":"Assert.js","sourceRoot":"","sources":["../../src/Assert.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,aAAa,CAAC;AAEjE;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,UAAU,MAAM,CAAC,SAAoC,EAAE,OAAiC;IAC5F,IAAI,CAAC,iBAAiB;QACpB,OAAO;IAET,IAAI,SAAS,KAAK,OAAO,SAAS;QAChC,SAAS,GAAG,SAAS,EAAE,CAAC;IAE1B,IAAI,SAAS;QACX,OAAO;IAET,OAAO,GAAG,OAAO,IAAI,kBAAkB,CAAC;IACxC,IAAI,QAAQ,KAAK,OAAO,OAAO;QAC7B,OAAO,GAAG,OAAO,EAAE,CAAC;IAEtB,MAAM,IAAI,KAAK,CAAC,WAAW,OAAO,EAAE,CAAC,CAAC;AACxC,CAAC","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Utils\n */\n\nconst assertionsEnabled = process.env.NODE_ENV === \"development\";\n\n/** Asserts that a condition is `true` and - when enabled - throws an error if it is not.\n * Assertions are enabled only if the build configuration defines `process.env.NODE_ENV` as `development` at build time.\n *\n * Assertions exist solely to assist programmers during development, in the following ways:\n * 1 They allow the programmer to declare conditions that they believe cannot possibly occur. If such conditions occur, they indicate\n * a serious flaw in the programmer's logic.\n * 2 They allow the programmer to assure the TypeScript compiler of the truth of some condition that the compiler cannot itself infer.\n * 3 They allow the author of an API to indicate to consumers of the API a serious misuse that should be corrected during development.\n *\n * Assertions should **never** be used to test for conditions - however unlikely - that could be expected to occur at run-time,\n * such as failing to write to a file or load a resource over the network. If the condition asserted ever fails in a production environment,\n * the programmer has made a serious mistake.\n *\n * Note that even when assertions are disabled, calls to `assert` remain in the code and their arguments will be evaluated at run-time.\n * Therefore, if your condition or message requires computation, prefer to pass it as a function to prevent it from being evaluated when assertions are disabled.\n *\n * @param condition The condition that is asserted to be `true`. If the condition is more complex than a simple `boolean` variable, pass it as a function to prevent it from being evaluated when assertions are disabled.\n * @param message An optional description of the condition being asserted, to be included in the exception if `condition` is `false`. If the message must be computed, pass it as a function to prevent it from being evaluated when assertions are disabled. Defaults to \"Programmer Error\".\n * @throws Error containing the specified `message` if `condition` is `false`.\n * @public\n */\nexport function assert(condition: boolean | (() => boolean), message?: string | (() => string)): asserts condition {\n if (!assertionsEnabled)\n return;\n\n if (\"boolean\" !== typeof condition)\n condition = condition();\n\n if (condition)\n return;\n\n message = message ?? \"Programmer Error\";\n if (\"string\" !== typeof message)\n message = message();\n\n throw new Error(`Assert: ${message}`);\n}\n"]}
@@ -1,82 +1,82 @@
1
- /** @packageDocumentation
2
- * @module Events
3
- */
4
- /** A function invoked when a BeEvent is raised.
5
- * @public
6
- */
7
- export declare type Listener = (...arg: any[]) => void;
8
- /**
9
- * Manages a set of *listeners* for a particular event and notifies them when the event is raised.
10
- * This class is usually instantiated inside of a container class and
11
- * exposed as a property for others to *subscribe* via [[BeEvent.addListener]].
12
- * @public
13
- */
14
- export declare class BeEvent<T extends Listener> {
15
- private _listeners;
16
- private _insideRaiseEvent;
17
- /** The number of listeners currently subscribed to the event. */
18
- get numberOfListeners(): number;
19
- /**
20
- * Registers a Listener to be executed whenever this event is raised.
21
- * @param listener The function to be executed when the event is raised.
22
- * @param scope An optional object scope to serve as the 'this' pointer when listener is invoked.
23
- * @returns A function that will remove this event listener.
24
- * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
25
- */
26
- addListener(listener: T, scope?: any): () => void;
27
- /**
28
- * Registers a callback function to be executed *only once* when the event is raised.
29
- * @param listener The function to be executed once when the event is raised.
30
- * @param scope An optional object scope to serve as the `this` pointer in which the listener function will execute.
31
- * @returns A function that will remove this event listener.
32
- * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
33
- */
34
- addOnce(listener: T, scope?: any): () => void;
35
- /**
36
- * Un-register a previously registered listener.
37
- * @param listener The listener to be unregistered.
38
- * @param scope The scope that was originally passed to addListener.
39
- * @returns 'true' if the listener was removed; 'false' if the listener and scope are not registered with the event.
40
- * @see [[BeEvent.raiseEvent]], [[BeEvent.addListener]]
41
- */
42
- removeListener(listener: T, scope?: any): boolean;
43
- /**
44
- * Raises the event by calling each registered listener with the supplied arguments.
45
- * @param args This method takes any number of parameters and passes them through to the listeners.
46
- * @see [[BeEvent.removeListener]], [[BeEvent.addListener]]
47
- */
48
- raiseEvent(...args: Parameters<T>): void;
49
- /** Determine whether this BeEvent has a specified listener registered.
50
- * @param listener The listener to check.
51
- * @param scope optional scope argument to match call to addListener
52
- */
53
- has(listener: T, scope?: any): boolean;
54
- /** Clear all Listeners from this BeEvent. */
55
- clear(): void;
56
- }
57
- /** Specialization of BeEvent for events that take a single strongly typed argument, primarily used for UI events.
58
- * @public
59
- */
60
- export declare class BeUiEvent<TEventArgs> extends BeEvent<(args: TEventArgs) => void> {
61
- /** Raises event with single strongly typed argument. */
62
- emit(args: TEventArgs): void;
63
- }
64
- /**
65
- * A list of BeEvent objects, accessible by an event name.
66
- * This class may be used instead of explicitly declaring each BeEvent as a member of a containing class.
67
- * @public
68
- */
69
- export declare class BeEventList<T extends Listener> {
70
- private _events;
71
- /**
72
- * Gets the event associated with the specified name, creating the event if it does not already exist.
73
- * @param name The name of the event.
74
- */
75
- get(name: string): BeEvent<T>;
76
- /**
77
- * Removes the event associated with a name.
78
- * @param name The name of the event.
79
- */
80
- remove(name: string): void;
81
- }
1
+ /** @packageDocumentation
2
+ * @module Events
3
+ */
4
+ /** A function invoked when a BeEvent is raised.
5
+ * @public
6
+ */
7
+ export declare type Listener = (...arg: any[]) => void;
8
+ /**
9
+ * Manages a set of *listeners* for a particular event and notifies them when the event is raised.
10
+ * This class is usually instantiated inside of a container class and
11
+ * exposed as a property for others to *subscribe* via [[BeEvent.addListener]].
12
+ * @public
13
+ */
14
+ export declare class BeEvent<T extends Listener> {
15
+ private _listeners;
16
+ private _insideRaiseEvent;
17
+ /** The number of listeners currently subscribed to the event. */
18
+ get numberOfListeners(): number;
19
+ /**
20
+ * Registers a Listener to be executed whenever this event is raised.
21
+ * @param listener The function to be executed when the event is raised.
22
+ * @param scope An optional object scope to serve as the 'this' pointer when listener is invoked.
23
+ * @returns A function that will remove this event listener.
24
+ * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
25
+ */
26
+ addListener(listener: T, scope?: any): () => void;
27
+ /**
28
+ * Registers a callback function to be executed *only once* when the event is raised.
29
+ * @param listener The function to be executed once when the event is raised.
30
+ * @param scope An optional object scope to serve as the `this` pointer in which the listener function will execute.
31
+ * @returns A function that will remove this event listener.
32
+ * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
33
+ */
34
+ addOnce(listener: T, scope?: any): () => void;
35
+ /**
36
+ * Un-register a previously registered listener.
37
+ * @param listener The listener to be unregistered.
38
+ * @param scope The scope that was originally passed to addListener.
39
+ * @returns 'true' if the listener was removed; 'false' if the listener and scope are not registered with the event.
40
+ * @see [[BeEvent.raiseEvent]], [[BeEvent.addListener]]
41
+ */
42
+ removeListener(listener: T, scope?: any): boolean;
43
+ /**
44
+ * Raises the event by calling each registered listener with the supplied arguments.
45
+ * @param args This method takes any number of parameters and passes them through to the listeners.
46
+ * @see [[BeEvent.removeListener]], [[BeEvent.addListener]]
47
+ */
48
+ raiseEvent(...args: Parameters<T>): void;
49
+ /** Determine whether this BeEvent has a specified listener registered.
50
+ * @param listener The listener to check.
51
+ * @param scope optional scope argument to match call to addListener
52
+ */
53
+ has(listener: T, scope?: any): boolean;
54
+ /** Clear all Listeners from this BeEvent. */
55
+ clear(): void;
56
+ }
57
+ /** Specialization of BeEvent for events that take a single strongly typed argument, primarily used for UI events.
58
+ * @public
59
+ */
60
+ export declare class BeUiEvent<TEventArgs> extends BeEvent<(args: TEventArgs) => void> {
61
+ /** Raises event with single strongly typed argument. */
62
+ emit(args: TEventArgs): void;
63
+ }
64
+ /**
65
+ * A list of BeEvent objects, accessible by an event name.
66
+ * This class may be used instead of explicitly declaring each BeEvent as a member of a containing class.
67
+ * @public
68
+ */
69
+ export declare class BeEventList<T extends Listener> {
70
+ private _events;
71
+ /**
72
+ * Gets the event associated with the specified name, creating the event if it does not already exist.
73
+ * @param name The name of the event.
74
+ */
75
+ get(name: string): BeEvent<T>;
76
+ /**
77
+ * Removes the event associated with a name.
78
+ * @param name The name of the event.
79
+ */
80
+ remove(name: string): void;
81
+ }
82
82
  //# sourceMappingURL=BeEvent.d.ts.map
@@ -1,151 +1,151 @@
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 Events
7
- */
8
- import { UnexpectedErrors } from "./UnexpectedErrors";
9
- /**
10
- * Manages a set of *listeners* for a particular event and notifies them when the event is raised.
11
- * This class is usually instantiated inside of a container class and
12
- * exposed as a property for others to *subscribe* via [[BeEvent.addListener]].
13
- * @public
14
- */
15
- export class BeEvent {
16
- constructor() {
17
- this._listeners = [];
18
- this._insideRaiseEvent = false;
19
- }
20
- /** The number of listeners currently subscribed to the event. */
21
- get numberOfListeners() { return this._listeners.length; }
22
- /**
23
- * Registers a Listener to be executed whenever this event is raised.
24
- * @param listener The function to be executed when the event is raised.
25
- * @param scope An optional object scope to serve as the 'this' pointer when listener is invoked.
26
- * @returns A function that will remove this event listener.
27
- * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
28
- */
29
- addListener(listener, scope) {
30
- this._listeners.push({ listener, scope, once: false });
31
- return () => this.removeListener(listener, scope);
32
- }
33
- /**
34
- * Registers a callback function to be executed *only once* when the event is raised.
35
- * @param listener The function to be executed once when the event is raised.
36
- * @param scope An optional object scope to serve as the `this` pointer in which the listener function will execute.
37
- * @returns A function that will remove this event listener.
38
- * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
39
- */
40
- addOnce(listener, scope) {
41
- this._listeners.push({ listener, scope, once: true });
42
- return () => this.removeListener(listener, scope);
43
- }
44
- /**
45
- * Un-register a previously registered listener.
46
- * @param listener The listener to be unregistered.
47
- * @param scope The scope that was originally passed to addListener.
48
- * @returns 'true' if the listener was removed; 'false' if the listener and scope are not registered with the event.
49
- * @see [[BeEvent.raiseEvent]], [[BeEvent.addListener]]
50
- */
51
- removeListener(listener, scope) {
52
- const listeners = this._listeners;
53
- for (let i = 0; i < listeners.length; ++i) {
54
- const context = listeners[i];
55
- if (context.listener === listener && context.scope === scope) {
56
- if (this._insideRaiseEvent) {
57
- context.listener = undefined;
58
- }
59
- else {
60
- listeners.splice(i, 1);
61
- }
62
- return true;
63
- }
64
- }
65
- return false;
66
- }
67
- /**
68
- * Raises the event by calling each registered listener with the supplied arguments.
69
- * @param args This method takes any number of parameters and passes them through to the listeners.
70
- * @see [[BeEvent.removeListener]], [[BeEvent.addListener]]
71
- */
72
- raiseEvent(...args) {
73
- this._insideRaiseEvent = true;
74
- const listeners = this._listeners;
75
- const length = listeners.length;
76
- let dropped = false;
77
- for (let i = 0; i < length; ++i) {
78
- const context = listeners[i];
79
- if (!context.listener) {
80
- dropped = true;
81
- }
82
- else {
83
- try {
84
- context.listener.apply(context.scope, args);
85
- }
86
- catch (e) {
87
- UnexpectedErrors.handle(e);
88
- }
89
- if (context.once) {
90
- context.listener = undefined;
91
- dropped = true;
92
- }
93
- }
94
- }
95
- // if we had dropped listeners, remove them now
96
- if (dropped)
97
- this._listeners = this._listeners.filter((ctx) => ctx.listener !== undefined);
98
- this._insideRaiseEvent = false;
99
- }
100
- /** Determine whether this BeEvent has a specified listener registered.
101
- * @param listener The listener to check.
102
- * @param scope optional scope argument to match call to addListener
103
- */
104
- has(listener, scope) {
105
- for (const ctx of this._listeners) {
106
- if (ctx.listener === listener && ctx.scope === scope) {
107
- return true;
108
- }
109
- }
110
- return false;
111
- }
112
- /** Clear all Listeners from this BeEvent. */
113
- clear() { this._listeners.length = 0; }
114
- }
115
- /** Specialization of BeEvent for events that take a single strongly typed argument, primarily used for UI events.
116
- * @public
117
- */
118
- export class BeUiEvent extends BeEvent {
119
- /** Raises event with single strongly typed argument. */
120
- emit(args) { this.raiseEvent(args); }
121
- }
122
- /**
123
- * A list of BeEvent objects, accessible by an event name.
124
- * This class may be used instead of explicitly declaring each BeEvent as a member of a containing class.
125
- * @public
126
- */
127
- export class BeEventList {
128
- constructor() {
129
- this._events = {};
130
- }
131
- /**
132
- * Gets the event associated with the specified name, creating the event if it does not already exist.
133
- * @param name The name of the event.
134
- */
135
- get(name) {
136
- let event = this._events[name];
137
- if (event)
138
- return event;
139
- event = new BeEvent();
140
- this._events[name] = event;
141
- return event;
142
- }
143
- /**
144
- * Removes the event associated with a name.
145
- * @param name The name of the event.
146
- */
147
- remove(name) {
148
- this._events[name] = undefined;
149
- }
150
- }
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 Events
7
+ */
8
+ import { UnexpectedErrors } from "./UnexpectedErrors";
9
+ /**
10
+ * Manages a set of *listeners* for a particular event and notifies them when the event is raised.
11
+ * This class is usually instantiated inside of a container class and
12
+ * exposed as a property for others to *subscribe* via [[BeEvent.addListener]].
13
+ * @public
14
+ */
15
+ export class BeEvent {
16
+ constructor() {
17
+ this._listeners = [];
18
+ this._insideRaiseEvent = false;
19
+ }
20
+ /** The number of listeners currently subscribed to the event. */
21
+ get numberOfListeners() { return this._listeners.length; }
22
+ /**
23
+ * Registers a Listener to be executed whenever this event is raised.
24
+ * @param listener The function to be executed when the event is raised.
25
+ * @param scope An optional object scope to serve as the 'this' pointer when listener is invoked.
26
+ * @returns A function that will remove this event listener.
27
+ * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
28
+ */
29
+ addListener(listener, scope) {
30
+ this._listeners.push({ listener, scope, once: false });
31
+ return () => this.removeListener(listener, scope);
32
+ }
33
+ /**
34
+ * Registers a callback function to be executed *only once* when the event is raised.
35
+ * @param listener The function to be executed once when the event is raised.
36
+ * @param scope An optional object scope to serve as the `this` pointer in which the listener function will execute.
37
+ * @returns A function that will remove this event listener.
38
+ * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]
39
+ */
40
+ addOnce(listener, scope) {
41
+ this._listeners.push({ listener, scope, once: true });
42
+ return () => this.removeListener(listener, scope);
43
+ }
44
+ /**
45
+ * Un-register a previously registered listener.
46
+ * @param listener The listener to be unregistered.
47
+ * @param scope The scope that was originally passed to addListener.
48
+ * @returns 'true' if the listener was removed; 'false' if the listener and scope are not registered with the event.
49
+ * @see [[BeEvent.raiseEvent]], [[BeEvent.addListener]]
50
+ */
51
+ removeListener(listener, scope) {
52
+ const listeners = this._listeners;
53
+ for (let i = 0; i < listeners.length; ++i) {
54
+ const context = listeners[i];
55
+ if (context.listener === listener && context.scope === scope) {
56
+ if (this._insideRaiseEvent) {
57
+ context.listener = undefined;
58
+ }
59
+ else {
60
+ listeners.splice(i, 1);
61
+ }
62
+ return true;
63
+ }
64
+ }
65
+ return false;
66
+ }
67
+ /**
68
+ * Raises the event by calling each registered listener with the supplied arguments.
69
+ * @param args This method takes any number of parameters and passes them through to the listeners.
70
+ * @see [[BeEvent.removeListener]], [[BeEvent.addListener]]
71
+ */
72
+ raiseEvent(...args) {
73
+ this._insideRaiseEvent = true;
74
+ const listeners = this._listeners;
75
+ const length = listeners.length;
76
+ let dropped = false;
77
+ for (let i = 0; i < length; ++i) {
78
+ const context = listeners[i];
79
+ if (!context.listener) {
80
+ dropped = true;
81
+ }
82
+ else {
83
+ try {
84
+ context.listener.apply(context.scope, args);
85
+ }
86
+ catch (e) {
87
+ UnexpectedErrors.handle(e);
88
+ }
89
+ if (context.once) {
90
+ context.listener = undefined;
91
+ dropped = true;
92
+ }
93
+ }
94
+ }
95
+ // if we had dropped listeners, remove them now
96
+ if (dropped)
97
+ this._listeners = this._listeners.filter((ctx) => ctx.listener !== undefined);
98
+ this._insideRaiseEvent = false;
99
+ }
100
+ /** Determine whether this BeEvent has a specified listener registered.
101
+ * @param listener The listener to check.
102
+ * @param scope optional scope argument to match call to addListener
103
+ */
104
+ has(listener, scope) {
105
+ for (const ctx of this._listeners) {
106
+ if (ctx.listener === listener && ctx.scope === scope) {
107
+ return true;
108
+ }
109
+ }
110
+ return false;
111
+ }
112
+ /** Clear all Listeners from this BeEvent. */
113
+ clear() { this._listeners.length = 0; }
114
+ }
115
+ /** Specialization of BeEvent for events that take a single strongly typed argument, primarily used for UI events.
116
+ * @public
117
+ */
118
+ export class BeUiEvent extends BeEvent {
119
+ /** Raises event with single strongly typed argument. */
120
+ emit(args) { this.raiseEvent(args); }
121
+ }
122
+ /**
123
+ * A list of BeEvent objects, accessible by an event name.
124
+ * This class may be used instead of explicitly declaring each BeEvent as a member of a containing class.
125
+ * @public
126
+ */
127
+ export class BeEventList {
128
+ constructor() {
129
+ this._events = {};
130
+ }
131
+ /**
132
+ * Gets the event associated with the specified name, creating the event if it does not already exist.
133
+ * @param name The name of the event.
134
+ */
135
+ get(name) {
136
+ let event = this._events[name];
137
+ if (event)
138
+ return event;
139
+ event = new BeEvent();
140
+ this._events[name] = event;
141
+ return event;
142
+ }
143
+ /**
144
+ * Removes the event associated with a name.
145
+ * @param name The name of the event.
146
+ */
147
+ remove(name) {
148
+ this._events[name] = undefined;
149
+ }
150
+ }
151
151
  //# sourceMappingURL=BeEvent.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"BeEvent.js","sourceRoot":"","sources":["../../src/BeEvent.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n/** @packageDocumentation\r\n * @module Events\r\n */\r\n\r\nimport { UnexpectedErrors } from \"./UnexpectedErrors\";\r\n\r\n/** A function invoked when a BeEvent is raised.\r\n * @public\r\n */\r\nexport type Listener = (...arg: any[]) => void;\r\n\r\ninterface EventContext {\r\n listener: Listener | undefined;\r\n scope: any;\r\n once: boolean;\r\n}\r\n\r\n/**\r\n * Manages a set of *listeners* for a particular event and notifies them when the event is raised.\r\n * This class is usually instantiated inside of a container class and\r\n * exposed as a property for others to *subscribe* via [[BeEvent.addListener]].\r\n * @public\r\n */\r\nexport class BeEvent<T extends Listener> {\r\n private _listeners: EventContext[] = [];\r\n private _insideRaiseEvent: boolean = false;\r\n\r\n /** The number of listeners currently subscribed to the event. */\r\n public get numberOfListeners() { return this._listeners.length; }\r\n\r\n /**\r\n * Registers a Listener to be executed whenever this event is raised.\r\n * @param listener The function to be executed when the event is raised.\r\n * @param scope An optional object scope to serve as the 'this' pointer when listener is invoked.\r\n * @returns A function that will remove this event listener.\r\n * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]\r\n */\r\n public addListener(listener: T, scope?: any): () => void {\r\n this._listeners.push({ listener, scope, once: false });\r\n return () => this.removeListener(listener, scope);\r\n }\r\n\r\n /**\r\n * Registers a callback function to be executed *only once* when the event is raised.\r\n * @param listener The function to be executed once when the event is raised.\r\n * @param scope An optional object scope to serve as the `this` pointer in which the listener function will execute.\r\n * @returns A function that will remove this event listener.\r\n * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]\r\n */\r\n public addOnce(listener: T, scope?: any): () => void {\r\n this._listeners.push({ listener, scope, once: true });\r\n return () => this.removeListener(listener, scope);\r\n }\r\n\r\n /**\r\n * Un-register a previously registered listener.\r\n * @param listener The listener to be unregistered.\r\n * @param scope The scope that was originally passed to addListener.\r\n * @returns 'true' if the listener was removed; 'false' if the listener and scope are not registered with the event.\r\n * @see [[BeEvent.raiseEvent]], [[BeEvent.addListener]]\r\n */\r\n public removeListener(listener: T, scope?: any): boolean {\r\n const listeners = this._listeners;\r\n\r\n for (let i = 0; i < listeners.length; ++i) {\r\n const context = listeners[i];\r\n if (context.listener === listener && context.scope === scope) {\r\n if (this._insideRaiseEvent) {\r\n context.listener = undefined;\r\n } else {\r\n listeners.splice(i, 1);\r\n }\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n /**\r\n * Raises the event by calling each registered listener with the supplied arguments.\r\n * @param args This method takes any number of parameters and passes them through to the listeners.\r\n * @see [[BeEvent.removeListener]], [[BeEvent.addListener]]\r\n */\r\n public raiseEvent(...args: Parameters<T>) {\r\n this._insideRaiseEvent = true;\r\n\r\n const listeners = this._listeners;\r\n const length = listeners.length;\r\n let dropped = false;\r\n\r\n for (let i = 0; i < length; ++i) {\r\n const context = listeners[i];\r\n if (!context.listener) {\r\n dropped = true;\r\n } else {\r\n try {\r\n context.listener.apply(context.scope, args);\r\n } catch (e) {\r\n UnexpectedErrors.handle(e);\r\n }\r\n if (context.once) {\r\n context.listener = undefined;\r\n dropped = true;\r\n }\r\n }\r\n }\r\n\r\n // if we had dropped listeners, remove them now\r\n if (dropped)\r\n this._listeners = this._listeners.filter((ctx) => ctx.listener !== undefined);\r\n\r\n this._insideRaiseEvent = false;\r\n }\r\n\r\n /** Determine whether this BeEvent has a specified listener registered.\r\n * @param listener The listener to check.\r\n * @param scope optional scope argument to match call to addListener\r\n */\r\n public has(listener: T, scope?: any): boolean {\r\n for (const ctx of this._listeners) {\r\n if (ctx.listener === listener && ctx.scope === scope) {\r\n return true;\r\n }\r\n }\r\n return false;\r\n }\r\n\r\n /** Clear all Listeners from this BeEvent. */\r\n public clear(): void { this._listeners.length = 0; }\r\n}\r\n\r\n/** Specialization of BeEvent for events that take a single strongly typed argument, primarily used for UI events.\r\n * @public\r\n */\r\nexport class BeUiEvent<TEventArgs> extends BeEvent<(args: TEventArgs) => void> {\r\n /** Raises event with single strongly typed argument. */\r\n public emit(args: TEventArgs): void { this.raiseEvent(args); }\r\n}\r\n\r\n/**\r\n * A list of BeEvent objects, accessible by an event name.\r\n * This class may be used instead of explicitly declaring each BeEvent as a member of a containing class.\r\n * @public\r\n */\r\nexport class BeEventList<T extends Listener> {\r\n private _events: { [name: string]: BeEvent<T> | undefined } = {};\r\n\r\n /**\r\n * Gets the event associated with the specified name, creating the event if it does not already exist.\r\n * @param name The name of the event.\r\n */\r\n public get(name: string): BeEvent<T> {\r\n let event = this._events[name];\r\n if (event)\r\n return event;\r\n\r\n event = new BeEvent();\r\n this._events[name] = event;\r\n return event;\r\n }\r\n\r\n /**\r\n * Removes the event associated with a name.\r\n * @param name The name of the event.\r\n */\r\n public remove(name: string): void {\r\n this._events[name] = undefined;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"BeEvent.js","sourceRoot":"","sources":["../../src/BeEvent.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n/** @packageDocumentation\n * @module Events\n */\n\nimport { UnexpectedErrors } from \"./UnexpectedErrors\";\n\n/** A function invoked when a BeEvent is raised.\n * @public\n */\nexport type Listener = (...arg: any[]) => void;\n\ninterface EventContext {\n listener: Listener | undefined;\n scope: any;\n once: boolean;\n}\n\n/**\n * Manages a set of *listeners* for a particular event and notifies them when the event is raised.\n * This class is usually instantiated inside of a container class and\n * exposed as a property for others to *subscribe* via [[BeEvent.addListener]].\n * @public\n */\nexport class BeEvent<T extends Listener> {\n private _listeners: EventContext[] = [];\n private _insideRaiseEvent: boolean = false;\n\n /** The number of listeners currently subscribed to the event. */\n public get numberOfListeners() { return this._listeners.length; }\n\n /**\n * Registers a Listener to be executed whenever this event is raised.\n * @param listener The function to be executed when the event is raised.\n * @param scope An optional object scope to serve as the 'this' pointer when listener is invoked.\n * @returns A function that will remove this event listener.\n * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]\n */\n public addListener(listener: T, scope?: any): () => void {\n this._listeners.push({ listener, scope, once: false });\n return () => this.removeListener(listener, scope);\n }\n\n /**\n * Registers a callback function to be executed *only once* when the event is raised.\n * @param listener The function to be executed once when the event is raised.\n * @param scope An optional object scope to serve as the `this` pointer in which the listener function will execute.\n * @returns A function that will remove this event listener.\n * @see [[BeEvent.raiseEvent]], [[BeEvent.removeListener]]\n */\n public addOnce(listener: T, scope?: any): () => void {\n this._listeners.push({ listener, scope, once: true });\n return () => this.removeListener(listener, scope);\n }\n\n /**\n * Un-register a previously registered listener.\n * @param listener The listener to be unregistered.\n * @param scope The scope that was originally passed to addListener.\n * @returns 'true' if the listener was removed; 'false' if the listener and scope are not registered with the event.\n * @see [[BeEvent.raiseEvent]], [[BeEvent.addListener]]\n */\n public removeListener(listener: T, scope?: any): boolean {\n const listeners = this._listeners;\n\n for (let i = 0; i < listeners.length; ++i) {\n const context = listeners[i];\n if (context.listener === listener && context.scope === scope) {\n if (this._insideRaiseEvent) {\n context.listener = undefined;\n } else {\n listeners.splice(i, 1);\n }\n return true;\n }\n }\n return false;\n }\n\n /**\n * Raises the event by calling each registered listener with the supplied arguments.\n * @param args This method takes any number of parameters and passes them through to the listeners.\n * @see [[BeEvent.removeListener]], [[BeEvent.addListener]]\n */\n public raiseEvent(...args: Parameters<T>) {\n this._insideRaiseEvent = true;\n\n const listeners = this._listeners;\n const length = listeners.length;\n let dropped = false;\n\n for (let i = 0; i < length; ++i) {\n const context = listeners[i];\n if (!context.listener) {\n dropped = true;\n } else {\n try {\n context.listener.apply(context.scope, args);\n } catch (e) {\n UnexpectedErrors.handle(e);\n }\n if (context.once) {\n context.listener = undefined;\n dropped = true;\n }\n }\n }\n\n // if we had dropped listeners, remove them now\n if (dropped)\n this._listeners = this._listeners.filter((ctx) => ctx.listener !== undefined);\n\n this._insideRaiseEvent = false;\n }\n\n /** Determine whether this BeEvent has a specified listener registered.\n * @param listener The listener to check.\n * @param scope optional scope argument to match call to addListener\n */\n public has(listener: T, scope?: any): boolean {\n for (const ctx of this._listeners) {\n if (ctx.listener === listener && ctx.scope === scope) {\n return true;\n }\n }\n return false;\n }\n\n /** Clear all Listeners from this BeEvent. */\n public clear(): void { this._listeners.length = 0; }\n}\n\n/** Specialization of BeEvent for events that take a single strongly typed argument, primarily used for UI events.\n * @public\n */\nexport class BeUiEvent<TEventArgs> extends BeEvent<(args: TEventArgs) => void> {\n /** Raises event with single strongly typed argument. */\n public emit(args: TEventArgs): void { this.raiseEvent(args); }\n}\n\n/**\n * A list of BeEvent objects, accessible by an event name.\n * This class may be used instead of explicitly declaring each BeEvent as a member of a containing class.\n * @public\n */\nexport class BeEventList<T extends Listener> {\n private _events: { [name: string]: BeEvent<T> | undefined } = {};\n\n /**\n * Gets the event associated with the specified name, creating the event if it does not already exist.\n * @param name The name of the event.\n */\n public get(name: string): BeEvent<T> {\n let event = this._events[name];\n if (event)\n return event;\n\n event = new BeEvent();\n this._events[name] = event;\n return event;\n }\n\n /**\n * Removes the event associated with a name.\n * @param name The name of the event.\n */\n public remove(name: string): void {\n this._events[name] = undefined;\n }\n}\n"]}