@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,149 +1,149 @@
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 Json
7
- */
8
- /** Utility functions for converting from JSON objects, with default values.
9
- * @public
10
- */
11
- export var JsonUtils;
12
- (function (JsonUtils) {
13
- /** Get a value as a boolean.
14
- * @param json the input JSON object
15
- * @param defaultVal default value if json cannot be converted to boolean
16
- * @returns the value of json as a boolean, or default value
17
- */
18
- function asBool(json, defaultVal = false) {
19
- return isNullOrUndefined(json) ? defaultVal : !!json;
20
- }
21
- JsonUtils.asBool = asBool;
22
- /** Get a value as an integer.
23
- * @param json the input JSON object
24
- * @param defaultVal default value if json cannot be converted to integer
25
- * @returns the value of json as an integer, or default value
26
- */
27
- function asInt(json, defaultVal = 0) {
28
- return (typeof json === "number") ? Math.trunc(json) : defaultVal;
29
- }
30
- JsonUtils.asInt = asInt;
31
- /** Get a value as a double.
32
- * @param json the input JSON object
33
- * @param defaultVal default value if json cannot be converted to double
34
- * @returns the value of json as a double, or default value
35
- */
36
- function asDouble(json, defaultVal = 0) {
37
- return (typeof json === "number") ? json : defaultVal;
38
- }
39
- JsonUtils.asDouble = asDouble;
40
- /** Get a value as a string.
41
- * @param json the input JSON object
42
- * @param defaultVal default value if json cannot be converted to string
43
- * @returns the value of json as a string, or default value
44
- */
45
- function asString(json, defaultVal = "") {
46
- return isNullOrUndefined(json) ? defaultVal : json.toString();
47
- }
48
- JsonUtils.asString = asString;
49
- /** Get a value as an array.
50
- * @param json the input JSON object
51
- * @returns the input JSON object if it is an array, otherwise undefined
52
- */
53
- function asArray(json) {
54
- return Array.isArray(json) ? json : undefined;
55
- }
56
- JsonUtils.asArray = asArray;
57
- /** Get a value as an object.
58
- * @param json the input JSON object
59
- * @returns the input JSON object if it is an object, otherwise undefined
60
- */
61
- function asObject(json) {
62
- return "object" === typeof json ? json : undefined;
63
- }
64
- JsonUtils.asObject = asObject;
65
- /** Set or remove a number on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,
66
- * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.
67
- * @param json the JSON object to affect
68
- * @param key the name of the member to set or remove
69
- * @param val the value to set
70
- * @param defaultVal the default value.
71
- */
72
- function setOrRemoveNumber(json, key, val, defaultVal) {
73
- if (val === defaultVal)
74
- delete json[key];
75
- else
76
- json[key] = val;
77
- }
78
- JsonUtils.setOrRemoveNumber = setOrRemoveNumber;
79
- /** Set or remove a boolean on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,
80
- * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.
81
- * @param json the JSON object to affect
82
- * @param key the name of the member to set or remove
83
- * @param val the value to set
84
- * @param defaultVal the default value.
85
- */
86
- function setOrRemoveBoolean(json, key, val, defaultVal) {
87
- if (val === defaultVal)
88
- delete json[key];
89
- else
90
- json[key] = val;
91
- }
92
- JsonUtils.setOrRemoveBoolean = setOrRemoveBoolean;
93
- /** Determine if a Javascript object is equivalent to `{}`.
94
- * @param json The JSON object to test.
95
- * @returns true if `json` is an Object with no keys.
96
- */
97
- function isEmptyObject(json) {
98
- return "object" === typeof json && 0 === Object.keys(json).length;
99
- }
100
- JsonUtils.isEmptyObject = isEmptyObject;
101
- /** Determine if the input is undefined or an empty Javascript object.
102
- * @param json The JSON object to test.
103
- * @returns true if `json` is undefined or is an Object with no keys (equivalent to `{}`).
104
- */
105
- function isEmptyObjectOrUndefined(json) {
106
- return undefined === json || isEmptyObject(json);
107
- }
108
- JsonUtils.isEmptyObjectOrUndefined = isEmptyObjectOrUndefined;
109
- function isNullOrUndefined(json) {
110
- return null === json || undefined === json;
111
- }
112
- /** Determine if the input is a non-empty Javascript object.
113
- * @param value The value to test.
114
- * @returns true if `value` is an Object with at least one key.
115
- */
116
- function isNonEmptyObject(value) {
117
- return !isEmptyObjectOrUndefined(value);
118
- }
119
- JsonUtils.isNonEmptyObject = isNonEmptyObject;
120
- /**
121
- * Convert the input object into a "pure" JavaScript object, with only instances of "object" or primitives in the returned value.
122
- * Works recursively for object members, and over arrays entries. Calls "toJSON" on any members that implement it.
123
- */
124
- function toObject(val) {
125
- if (typeof val === "boolean" || typeof val === "number" || typeof val === "string")
126
- return val;
127
- if (typeof val !== "object")
128
- return undefined;
129
- // See if the object has toJSON() function defined.
130
- if (typeof val.toJSON !== "undefined")
131
- return toObject(val.toJSON());
132
- // if it's an array, convert each member.
133
- if (Array.isArray(val)) {
134
- const arr = new Array(val.length);
135
- val.forEach((el, i) => arr[i] = toObject(el));
136
- return arr;
137
- }
138
- // Convert each property
139
- const out = {};
140
- Object.getOwnPropertyNames(val).forEach((prop) => {
141
- const transformVal = toObject(val[prop]);
142
- if (transformVal !== undefined)
143
- out[prop] = transformVal;
144
- });
145
- return out;
146
- }
147
- JsonUtils.toObject = toObject;
148
- })(JsonUtils || (JsonUtils = {}));
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 Json
7
+ */
8
+ /** Utility functions for converting from JSON objects, with default values.
9
+ * @public
10
+ */
11
+ export var JsonUtils;
12
+ (function (JsonUtils) {
13
+ /** Get a value as a boolean.
14
+ * @param json the input JSON object
15
+ * @param defaultVal default value if json cannot be converted to boolean
16
+ * @returns the value of json as a boolean, or default value
17
+ */
18
+ function asBool(json, defaultVal = false) {
19
+ return isNullOrUndefined(json) ? defaultVal : !!json;
20
+ }
21
+ JsonUtils.asBool = asBool;
22
+ /** Get a value as an integer.
23
+ * @param json the input JSON object
24
+ * @param defaultVal default value if json cannot be converted to integer
25
+ * @returns the value of json as an integer, or default value
26
+ */
27
+ function asInt(json, defaultVal = 0) {
28
+ return (typeof json === "number") ? Math.trunc(json) : defaultVal;
29
+ }
30
+ JsonUtils.asInt = asInt;
31
+ /** Get a value as a double.
32
+ * @param json the input JSON object
33
+ * @param defaultVal default value if json cannot be converted to double
34
+ * @returns the value of json as a double, or default value
35
+ */
36
+ function asDouble(json, defaultVal = 0) {
37
+ return (typeof json === "number") ? json : defaultVal;
38
+ }
39
+ JsonUtils.asDouble = asDouble;
40
+ /** Get a value as a string.
41
+ * @param json the input JSON object
42
+ * @param defaultVal default value if json cannot be converted to string
43
+ * @returns the value of json as a string, or default value
44
+ */
45
+ function asString(json, defaultVal = "") {
46
+ return isNullOrUndefined(json) ? defaultVal : json.toString();
47
+ }
48
+ JsonUtils.asString = asString;
49
+ /** Get a value as an array.
50
+ * @param json the input JSON object
51
+ * @returns the input JSON object if it is an array, otherwise undefined
52
+ */
53
+ function asArray(json) {
54
+ return Array.isArray(json) ? json : undefined;
55
+ }
56
+ JsonUtils.asArray = asArray;
57
+ /** Get a value as an object.
58
+ * @param json the input JSON object
59
+ * @returns the input JSON object if it is an object, otherwise undefined
60
+ */
61
+ function asObject(json) {
62
+ return "object" === typeof json ? json : undefined;
63
+ }
64
+ JsonUtils.asObject = asObject;
65
+ /** Set or remove a number on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,
66
+ * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.
67
+ * @param json the JSON object to affect
68
+ * @param key the name of the member to set or remove
69
+ * @param val the value to set
70
+ * @param defaultVal the default value.
71
+ */
72
+ function setOrRemoveNumber(json, key, val, defaultVal) {
73
+ if (val === defaultVal)
74
+ delete json[key];
75
+ else
76
+ json[key] = val;
77
+ }
78
+ JsonUtils.setOrRemoveNumber = setOrRemoveNumber;
79
+ /** Set or remove a boolean on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,
80
+ * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.
81
+ * @param json the JSON object to affect
82
+ * @param key the name of the member to set or remove
83
+ * @param val the value to set
84
+ * @param defaultVal the default value.
85
+ */
86
+ function setOrRemoveBoolean(json, key, val, defaultVal) {
87
+ if (val === defaultVal)
88
+ delete json[key];
89
+ else
90
+ json[key] = val;
91
+ }
92
+ JsonUtils.setOrRemoveBoolean = setOrRemoveBoolean;
93
+ /** Determine if a Javascript object is equivalent to `{}`.
94
+ * @param json The JSON object to test.
95
+ * @returns true if `json` is an Object with no keys.
96
+ */
97
+ function isEmptyObject(json) {
98
+ return "object" === typeof json && 0 === Object.keys(json).length;
99
+ }
100
+ JsonUtils.isEmptyObject = isEmptyObject;
101
+ /** Determine if the input is undefined or an empty Javascript object.
102
+ * @param json The JSON object to test.
103
+ * @returns true if `json` is undefined or is an Object with no keys (equivalent to `{}`).
104
+ */
105
+ function isEmptyObjectOrUndefined(json) {
106
+ return undefined === json || isEmptyObject(json);
107
+ }
108
+ JsonUtils.isEmptyObjectOrUndefined = isEmptyObjectOrUndefined;
109
+ function isNullOrUndefined(json) {
110
+ return null === json || undefined === json;
111
+ }
112
+ /** Determine if the input is a non-empty Javascript object.
113
+ * @param value The value to test.
114
+ * @returns true if `value` is an Object with at least one key.
115
+ */
116
+ function isNonEmptyObject(value) {
117
+ return !isEmptyObjectOrUndefined(value);
118
+ }
119
+ JsonUtils.isNonEmptyObject = isNonEmptyObject;
120
+ /**
121
+ * Convert the input object into a "pure" JavaScript object, with only instances of "object" or primitives in the returned value.
122
+ * Works recursively for object members, and over arrays entries. Calls "toJSON" on any members that implement it.
123
+ */
124
+ function toObject(val) {
125
+ if (typeof val === "boolean" || typeof val === "number" || typeof val === "string")
126
+ return val;
127
+ if (typeof val !== "object")
128
+ return undefined;
129
+ // See if the object has toJSON() function defined.
130
+ if (typeof val.toJSON !== "undefined")
131
+ return toObject(val.toJSON());
132
+ // if it's an array, convert each member.
133
+ if (Array.isArray(val)) {
134
+ const arr = new Array(val.length);
135
+ val.forEach((el, i) => arr[i] = toObject(el));
136
+ return arr;
137
+ }
138
+ // Convert each property
139
+ const out = {};
140
+ Object.getOwnPropertyNames(val).forEach((prop) => {
141
+ const transformVal = toObject(val[prop]);
142
+ if (transformVal !== undefined)
143
+ out[prop] = transformVal;
144
+ });
145
+ return out;
146
+ }
147
+ JsonUtils.toObject = toObject;
148
+ })(JsonUtils || (JsonUtils = {}));
149
149
  //# sourceMappingURL=JsonUtils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"JsonUtils.js","sourceRoot":"","sources":["../../src/JsonUtils.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH;;GAEG;AACH,MAAM,KAAW,SAAS,CA2IzB;AA3ID,WAAiB,SAAS;IACxB;;;;OAIG;IACH,SAAgB,MAAM,CAAC,IAAS,EAAE,UAAU,GAAG,KAAK;QAClD,OAAO,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACvD,CAAC;IAFe,gBAAM,SAErB,CAAA;IACD;;;;OAIG;IACH,SAAgB,KAAK,CAAC,IAAS,EAAE,UAAU,GAAG,CAAC;QAC7C,OAAO,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC;IACpE,CAAC;IAFe,eAAK,QAEpB,CAAA;IACD;;;;OAIG;IACH,SAAgB,QAAQ,CAAC,IAAS,EAAE,UAAU,GAAG,CAAC;QAChD,OAAO,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC;IACxD,CAAC;IAFe,kBAAQ,WAEvB,CAAA;IACD;;;;OAIG;IACH,SAAgB,QAAQ,CAAC,IAAS,EAAE,UAAU,GAAG,EAAE;QACjD,OAAO,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;IAChE,CAAC;IAFe,kBAAQ,WAEvB,CAAA;IAED;;;OAGG;IACH,SAAgB,OAAO,CAAC,IAAS;QAC/B,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;IAChD,CAAC;IAFe,iBAAO,UAEtB,CAAA;IAED;;;OAGG;IACH,SAAgB,QAAQ,CAAC,IAAS;QAChC,OAAO,QAAQ,KAAK,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;IACrD,CAAC;IAFe,kBAAQ,WAEvB,CAAA;IAED;;;;;;OAMG;IACH,SAAgB,iBAAiB,CAAC,IAAS,EAAE,GAAW,EAAE,GAAW,EAAE,UAAkB;QACvF,IAAI,GAAG,KAAK,UAAU;YACpB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;;YAEjB,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;IACpB,CAAC;IALe,2BAAiB,oBAKhC,CAAA;IAED;;;;;;OAMG;IACH,SAAgB,kBAAkB,CAAC,IAAS,EAAE,GAAW,EAAE,GAAY,EAAE,UAAmB;QAC1F,IAAI,GAAG,KAAK,UAAU;YACpB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC;;YAEjB,IAAI,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;IACpB,CAAC;IALe,4BAAkB,qBAKjC,CAAA;IAED;;;OAGG;IACH,SAAgB,aAAa,CAAC,IAAS;QACrC,OAAO,QAAQ,KAAK,OAAO,IAAI,IAAI,CAAC,KAAK,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC;IACpE,CAAC;IAFe,uBAAa,gBAE5B,CAAA;IAED;;;OAGG;IACH,SAAgB,wBAAwB,CAAC,IAAS;QAChD,OAAO,SAAS,KAAK,IAAI,IAAI,aAAa,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC;IAFe,kCAAwB,2BAEvC,CAAA;IAED,SAAS,iBAAiB,CAAC,IAAS;QAClC,OAAO,IAAI,KAAK,IAAI,IAAI,SAAS,KAAK,IAAI,CAAC;IAC7C,CAAC;IAED;;;OAGG;IACH,SAAgB,gBAAgB,CAAC,KAAU;QACzC,OAAO,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC;IAC1C,CAAC;IAFe,0BAAgB,mBAE/B,CAAA;IAED;;;OAGG;IACH,SAAgB,QAAQ,CAAC,GAAQ;QAC/B,IAAI,OAAO,GAAG,KAAK,SAAS,IAAI,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,QAAQ;YAChF,OAAO,GAAG,CAAC;QAEb,IAAI,OAAO,GAAG,KAAK,QAAQ;YACzB,OAAO,SAAS,CAAC;QAEnB,mDAAmD;QACnD,IAAI,OAAO,GAAG,CAAC,MAAM,KAAK,WAAW;YACnC,OAAO,QAAQ,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;QAEhC,yCAAyC;QACzC,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACtB,MAAM,GAAG,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAClC,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;YAC9C,OAAO,GAAG,CAAC;SACZ;QAED,wBAAwB;QACxB,MAAM,GAAG,GAAQ,EAAE,CAAC;QACpB,MAAM,CAAC,mBAAmB,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YAC/C,MAAM,YAAY,GAAG,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;YACzC,IAAI,YAAY,KAAK,SAAS;gBAC5B,GAAG,CAAC,IAAI,CAAC,GAAG,YAAY,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,OAAO,GAAG,CAAC;IACb,CAAC;IA3Be,kBAAQ,WA2BvB,CAAA;AAEH,CAAC,EA3IgB,SAAS,KAAT,SAAS,QA2IzB","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 Json\r\n */\r\n\r\n/** Utility functions for converting from JSON objects, with default values.\r\n * @public\r\n */\r\nexport namespace JsonUtils {\r\n /** Get a value as a boolean.\r\n * @param json the input JSON object\r\n * @param defaultVal default value if json cannot be converted to boolean\r\n * @returns the value of json as a boolean, or default value\r\n */\r\n export function asBool(json: any, defaultVal = false): boolean {\r\n return isNullOrUndefined(json) ? defaultVal : !!json;\r\n }\r\n /** Get a value as an integer.\r\n * @param json the input JSON object\r\n * @param defaultVal default value if json cannot be converted to integer\r\n * @returns the value of json as an integer, or default value\r\n */\r\n export function asInt(json: any, defaultVal = 0): number {\r\n return (typeof json === \"number\") ? Math.trunc(json) : defaultVal;\r\n }\r\n /** Get a value as a double.\r\n * @param json the input JSON object\r\n * @param defaultVal default value if json cannot be converted to double\r\n * @returns the value of json as a double, or default value\r\n */\r\n export function asDouble(json: any, defaultVal = 0): number {\r\n return (typeof json === \"number\") ? json : defaultVal;\r\n }\r\n /** Get a value as a string.\r\n * @param json the input JSON object\r\n * @param defaultVal default value if json cannot be converted to string\r\n * @returns the value of json as a string, or default value\r\n */\r\n export function asString(json: any, defaultVal = \"\"): string {\r\n return isNullOrUndefined(json) ? defaultVal : json.toString();\r\n }\r\n\r\n /** Get a value as an array.\r\n * @param json the input JSON object\r\n * @returns the input JSON object if it is an array, otherwise undefined\r\n */\r\n export function asArray(json: any): any {\r\n return Array.isArray(json) ? json : undefined;\r\n }\r\n\r\n /** Get a value as an object.\r\n * @param json the input JSON object\r\n * @returns the input JSON object if it is an object, otherwise undefined\r\n */\r\n export function asObject(json: any): any {\r\n return \"object\" === typeof json ? json : undefined;\r\n }\r\n\r\n /** Set or remove a number on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,\r\n * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.\r\n * @param json the JSON object to affect\r\n * @param key the name of the member to set or remove\r\n * @param val the value to set\r\n * @param defaultVal the default value.\r\n */\r\n export function setOrRemoveNumber(json: any, key: string, val: number, defaultVal: number) {\r\n if (val === defaultVal)\r\n delete json[key];\r\n else\r\n json[key] = val;\r\n }\r\n\r\n /** Set or remove a boolean on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,\r\n * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.\r\n * @param json the JSON object to affect\r\n * @param key the name of the member to set or remove\r\n * @param val the value to set\r\n * @param defaultVal the default value.\r\n */\r\n export function setOrRemoveBoolean(json: any, key: string, val: boolean, defaultVal: boolean) {\r\n if (val === defaultVal)\r\n delete json[key];\r\n else\r\n json[key] = val;\r\n }\r\n\r\n /** Determine if a Javascript object is equivalent to `{}`.\r\n * @param json The JSON object to test.\r\n * @returns true if `json` is an Object with no keys.\r\n */\r\n export function isEmptyObject(json: any): boolean {\r\n return \"object\" === typeof json && 0 === Object.keys(json).length;\r\n }\r\n\r\n /** Determine if the input is undefined or an empty Javascript object.\r\n * @param json The JSON object to test.\r\n * @returns true if `json` is undefined or is an Object with no keys (equivalent to `{}`).\r\n */\r\n export function isEmptyObjectOrUndefined(json: any): boolean {\r\n return undefined === json || isEmptyObject(json);\r\n }\r\n\r\n function isNullOrUndefined(json: any): boolean {\r\n return null === json || undefined === json;\r\n }\r\n\r\n /** Determine if the input is a non-empty Javascript object.\r\n * @param value The value to test.\r\n * @returns true if `value` is an Object with at least one key.\r\n */\r\n export function isNonEmptyObject(value: any): value is Object {\r\n return !isEmptyObjectOrUndefined(value);\r\n }\r\n\r\n /**\r\n * Convert the input object into a \"pure\" JavaScript object, with only instances of \"object\" or primitives in the returned value.\r\n * Works recursively for object members, and over arrays entries. Calls \"toJSON\" on any members that implement it.\r\n */\r\n export function toObject(val: any): any {\r\n if (typeof val === \"boolean\" || typeof val === \"number\" || typeof val === \"string\")\r\n return val;\r\n\r\n if (typeof val !== \"object\")\r\n return undefined;\r\n\r\n // See if the object has toJSON() function defined.\r\n if (typeof val.toJSON !== \"undefined\")\r\n return toObject(val.toJSON());\r\n\r\n // if it's an array, convert each member.\r\n if (Array.isArray(val)) {\r\n const arr = new Array(val.length);\r\n val.forEach((el, i) => arr[i] = toObject(el));\r\n return arr;\r\n }\r\n\r\n // Convert each property\r\n const out: any = {};\r\n Object.getOwnPropertyNames(val).forEach((prop) => {\r\n const transformVal = toObject(val[prop]);\r\n if (transformVal !== undefined)\r\n out[prop] = transformVal;\r\n });\r\n\r\n return out;\r\n }\r\n\r\n}\r\n"]}
1
+ {"version":3,"file":"JsonUtils.js","sourceRoot":"","sources":["../../src/JsonUtils.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 Json\n */\n\n/** Utility functions for converting from JSON objects, with default values.\n * @public\n */\nexport namespace JsonUtils {\n /** Get a value as a boolean.\n * @param json the input JSON object\n * @param defaultVal default value if json cannot be converted to boolean\n * @returns the value of json as a boolean, or default value\n */\n export function asBool(json: any, defaultVal = false): boolean {\n return isNullOrUndefined(json) ? defaultVal : !!json;\n }\n /** Get a value as an integer.\n * @param json the input JSON object\n * @param defaultVal default value if json cannot be converted to integer\n * @returns the value of json as an integer, or default value\n */\n export function asInt(json: any, defaultVal = 0): number {\n return (typeof json === \"number\") ? Math.trunc(json) : defaultVal;\n }\n /** Get a value as a double.\n * @param json the input JSON object\n * @param defaultVal default value if json cannot be converted to double\n * @returns the value of json as a double, or default value\n */\n export function asDouble(json: any, defaultVal = 0): number {\n return (typeof json === \"number\") ? json : defaultVal;\n }\n /** Get a value as a string.\n * @param json the input JSON object\n * @param defaultVal default value if json cannot be converted to string\n * @returns the value of json as a string, or default value\n */\n export function asString(json: any, defaultVal = \"\"): string {\n return isNullOrUndefined(json) ? defaultVal : json.toString();\n }\n\n /** Get a value as an array.\n * @param json the input JSON object\n * @returns the input JSON object if it is an array, otherwise undefined\n */\n export function asArray(json: any): any {\n return Array.isArray(json) ? json : undefined;\n }\n\n /** Get a value as an object.\n * @param json the input JSON object\n * @returns the input JSON object if it is an object, otherwise undefined\n */\n export function asObject(json: any): any {\n return \"object\" === typeof json ? json : undefined;\n }\n\n /** Set or remove a number on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,\n * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.\n * @param json the JSON object to affect\n * @param key the name of the member to set or remove\n * @param val the value to set\n * @param defaultVal the default value.\n */\n export function setOrRemoveNumber(json: any, key: string, val: number, defaultVal: number) {\n if (val === defaultVal)\n delete json[key];\n else\n json[key] = val;\n }\n\n /** Set or remove a boolean on a json object, given a key name, a value, and a default value. Sets `json[key] = val` if val is *not* equal to the default,\n * otherwise `delete json[key]`. This is used to omit values from JSON strings that are of known defaults.\n * @param json the JSON object to affect\n * @param key the name of the member to set or remove\n * @param val the value to set\n * @param defaultVal the default value.\n */\n export function setOrRemoveBoolean(json: any, key: string, val: boolean, defaultVal: boolean) {\n if (val === defaultVal)\n delete json[key];\n else\n json[key] = val;\n }\n\n /** Determine if a Javascript object is equivalent to `{}`.\n * @param json The JSON object to test.\n * @returns true if `json` is an Object with no keys.\n */\n export function isEmptyObject(json: any): boolean {\n return \"object\" === typeof json && 0 === Object.keys(json).length;\n }\n\n /** Determine if the input is undefined or an empty Javascript object.\n * @param json The JSON object to test.\n * @returns true if `json` is undefined or is an Object with no keys (equivalent to `{}`).\n */\n export function isEmptyObjectOrUndefined(json: any): boolean {\n return undefined === json || isEmptyObject(json);\n }\n\n function isNullOrUndefined(json: any): boolean {\n return null === json || undefined === json;\n }\n\n /** Determine if the input is a non-empty Javascript object.\n * @param value The value to test.\n * @returns true if `value` is an Object with at least one key.\n */\n export function isNonEmptyObject(value: any): value is Object {\n return !isEmptyObjectOrUndefined(value);\n }\n\n /**\n * Convert the input object into a \"pure\" JavaScript object, with only instances of \"object\" or primitives in the returned value.\n * Works recursively for object members, and over arrays entries. Calls \"toJSON\" on any members that implement it.\n */\n export function toObject(val: any): any {\n if (typeof val === \"boolean\" || typeof val === \"number\" || typeof val === \"string\")\n return val;\n\n if (typeof val !== \"object\")\n return undefined;\n\n // See if the object has toJSON() function defined.\n if (typeof val.toJSON !== \"undefined\")\n return toObject(val.toJSON());\n\n // if it's an array, convert each member.\n if (Array.isArray(val)) {\n const arr = new Array(val.length);\n val.forEach((el, i) => arr[i] = toObject(el));\n return arr;\n }\n\n // Convert each property\n const out: any = {};\n Object.getOwnPropertyNames(val).forEach((prop) => {\n const transformVal = toObject(val[prop]);\n if (transformVal !== undefined)\n out[prop] = transformVal;\n });\n\n return out;\n }\n\n}\n"]}
@@ -1,130 +1,130 @@
1
- /** @packageDocumentation
2
- * @module Collections
3
- */
4
- import { OrderedComparator } from "./Compare";
5
- /**
6
- * Derived from:
7
- * Licensed under MIT. Copyright (c) 2010 Rasmus Andersson <http://hunch.se/>
8
- * See README.md at https://github.com/rsms/js-lru for details.
9
- */
10
- /** An entry holds the key and value, and pointers to any older and newer entries.
11
- * @public
12
- */
13
- export declare class Entry<K, V> {
14
- key: K;
15
- value: V;
16
- newer?: Entry<K, V>;
17
- older?: Entry<K, V>;
18
- constructor(key: K, value: V);
19
- }
20
- /** The interface that must be satisfied by the underlying container type used by a LRUCache.
21
- * Compatible with a [[Dictionary]] or a standard Map.
22
- * @public
23
- */
24
- export interface EntryContainer<K, V> {
25
- readonly size: number;
26
- clear(): void;
27
- get(key: K): Entry<K, V> | undefined;
28
- set(key: K, value: Entry<K, V>): void;
29
- has(key: K): boolean;
30
- delete(key: K): void;
31
- }
32
- /**
33
- * A mapping of a key/value pairs, where the size of the cache can be limited.
34
- *
35
- * When entries are inserted, if the cache is "full", the
36
- * least-recently-used (LRU) value is dropped. When entries are retrieved, they are moved to the front of the LRU list.
37
- *
38
- * Illustration of the design:
39
- *
40
- * ```
41
- *
42
- * entry entry entry entry
43
- * ______ ______ ______ ______
44
- * | head |.newer => | |.newer => | |.newer => | tail |
45
- * | A | | B | | C | | D |
46
- * |______| <= older.|______| <= older.|______| <= older.|______|
47
- *
48
- * removed <-- <-- <-- <-- <-- <-- <-- <-- <-- <-- <-- added
49
- * ```
50
- * @public
51
- */
52
- export declare class LRUCache<K, V> {
53
- private _container;
54
- /** Current number of items */
55
- size: number;
56
- /** Maximum number of items this cache can hold */
57
- limit: number;
58
- /** Least recently-used entry. Invalidated when cache is modified. */
59
- oldest?: Entry<K, V>;
60
- /** Most recently-used entry. Invalidated when cache is modified. */
61
- newest?: Entry<K, V>;
62
- /**
63
- * Construct a new LRUCache to hold up to `limit` entries.
64
- */
65
- constructor(limit: number, container: EntryContainer<K, V>);
66
- private markEntryAsUsed;
67
- /** Replace all values in this cache with key-value pairs (2-element Arrays) from provided iterable. */
68
- assign(entries: Iterable<[K, V]>): void;
69
- /** Get and register recent use of <key>.
70
- * Returns the value associated with <key> or undefined if not in cache.
71
- */
72
- get(key: K): V | undefined;
73
- /** Put <value> into the cache associated with <key>. Replaces any existing entry with the same key.
74
- * @returns `this`.
75
- */
76
- set(key: K, value: V): LRUCache<K, V>;
77
- /** Purge the least recently used (oldest) entry from the cache.
78
- * @returns The removed entry or undefined if the cache was empty.
79
- */
80
- shift(): [K, V] | undefined;
81
- /** Access value for `key` without registering recent use. Useful if you do not
82
- * want to change the state of the cache, but only "peek" at it.
83
- * @returns The value associated with `key` if found, or undefined if not found.
84
- */
85
- find(key: K): V | undefined;
86
- /** Check if there's a value for key in the cache without registering recent use. */
87
- has(key: K): boolean;
88
- /** Remove entry `key` from cache and return its value.
89
- * @returns The removed value, or undefined if not found.
90
- */
91
- delete(key: K): V | undefined;
92
- /** Removes all entries */
93
- clear(): void;
94
- /** Returns an iterator over all keys, starting with the oldest. */
95
- keys(): Iterator<K | undefined> | undefined;
96
- /** Returns an iterator over all values, starting with the oldest. */
97
- values(): Iterator<V | undefined> | undefined;
98
- /** Returns an iterator over all entries, starting with the oldest. */
99
- entries(): Iterator<[K, V] | undefined> | undefined;
100
- /** Call `fun` for each entry, starting with the oldest entry. */
101
- forEach(fun: (value: V, key: K, m: LRUCache<K, V>) => void, thisObj?: any): void;
102
- /** Returns a JSON (array) representation */
103
- toJSON(): Array<{
104
- key: K;
105
- value: V;
106
- }>;
107
- /** Returns a String representation */
108
- toString(): string;
109
- }
110
- /** A [[LRUCache]] using a standard Map as its internal storage.
111
- * @public
112
- */
113
- export declare class LRUMap<K, V> extends LRUCache<K, V> {
114
- /**
115
- * Construct a new LRUMap to hold up to `limit` entries.
116
- */
117
- constructor(limit: number);
118
- }
119
- /** A [[LRUCache]] using a [[Dictionary]] as its internal storage, permitting custom key comparison logic.
120
- * @public
121
- */
122
- export declare class LRUDictionary<K, V> extends LRUCache<K, V> {
123
- /**
124
- * Construct a new LRUDictionary to hold up to `limit` entries.
125
- * @param limit The maximum number of entries permitted in the dictionary.
126
- * @param compareKeys The function used to compare keys within the dictionary.
127
- */
128
- constructor(limit: number, compareKeys: OrderedComparator<K>);
129
- }
1
+ /** @packageDocumentation
2
+ * @module Collections
3
+ */
4
+ import { OrderedComparator } from "./Compare";
5
+ /**
6
+ * Derived from:
7
+ * Licensed under MIT. Copyright (c) 2010 Rasmus Andersson <http://hunch.se/>
8
+ * See README.md at https://github.com/rsms/js-lru for details.
9
+ */
10
+ /** An entry holds the key and value, and pointers to any older and newer entries.
11
+ * @public
12
+ */
13
+ export declare class Entry<K, V> {
14
+ key: K;
15
+ value: V;
16
+ newer?: Entry<K, V>;
17
+ older?: Entry<K, V>;
18
+ constructor(key: K, value: V);
19
+ }
20
+ /** The interface that must be satisfied by the underlying container type used by a LRUCache.
21
+ * Compatible with a [[Dictionary]] or a standard Map.
22
+ * @public
23
+ */
24
+ export interface EntryContainer<K, V> {
25
+ readonly size: number;
26
+ clear(): void;
27
+ get(key: K): Entry<K, V> | undefined;
28
+ set(key: K, value: Entry<K, V>): void;
29
+ has(key: K): boolean;
30
+ delete(key: K): void;
31
+ }
32
+ /**
33
+ * A mapping of a key/value pairs, where the size of the cache can be limited.
34
+ *
35
+ * When entries are inserted, if the cache is "full", the
36
+ * least-recently-used (LRU) value is dropped. When entries are retrieved, they are moved to the front of the LRU list.
37
+ *
38
+ * Illustration of the design:
39
+ *
40
+ * ```
41
+ *
42
+ * entry entry entry entry
43
+ * ______ ______ ______ ______
44
+ * | head |.newer => | |.newer => | |.newer => | tail |
45
+ * | A | | B | | C | | D |
46
+ * |______| <= older.|______| <= older.|______| <= older.|______|
47
+ *
48
+ * removed <-- <-- <-- <-- <-- <-- <-- <-- <-- <-- <-- added
49
+ * ```
50
+ * @public
51
+ */
52
+ export declare class LRUCache<K, V> {
53
+ private _container;
54
+ /** Current number of items */
55
+ size: number;
56
+ /** Maximum number of items this cache can hold */
57
+ limit: number;
58
+ /** Least recently-used entry. Invalidated when cache is modified. */
59
+ oldest?: Entry<K, V>;
60
+ /** Most recently-used entry. Invalidated when cache is modified. */
61
+ newest?: Entry<K, V>;
62
+ /**
63
+ * Construct a new LRUCache to hold up to `limit` entries.
64
+ */
65
+ constructor(limit: number, container: EntryContainer<K, V>);
66
+ private markEntryAsUsed;
67
+ /** Replace all values in this cache with key-value pairs (2-element Arrays) from provided iterable. */
68
+ assign(entries: Iterable<[K, V]>): void;
69
+ /** Get and register recent use of <key>.
70
+ * Returns the value associated with <key> or undefined if not in cache.
71
+ */
72
+ get(key: K): V | undefined;
73
+ /** Put <value> into the cache associated with <key>. Replaces any existing entry with the same key.
74
+ * @returns `this`.
75
+ */
76
+ set(key: K, value: V): LRUCache<K, V>;
77
+ /** Purge the least recently used (oldest) entry from the cache.
78
+ * @returns The removed entry or undefined if the cache was empty.
79
+ */
80
+ shift(): [K, V] | undefined;
81
+ /** Access value for `key` without registering recent use. Useful if you do not
82
+ * want to change the state of the cache, but only "peek" at it.
83
+ * @returns The value associated with `key` if found, or undefined if not found.
84
+ */
85
+ find(key: K): V | undefined;
86
+ /** Check if there's a value for key in the cache without registering recent use. */
87
+ has(key: K): boolean;
88
+ /** Remove entry `key` from cache and return its value.
89
+ * @returns The removed value, or undefined if not found.
90
+ */
91
+ delete(key: K): V | undefined;
92
+ /** Removes all entries */
93
+ clear(): void;
94
+ /** Returns an iterator over all keys, starting with the oldest. */
95
+ keys(): Iterator<K | undefined> | undefined;
96
+ /** Returns an iterator over all values, starting with the oldest. */
97
+ values(): Iterator<V | undefined> | undefined;
98
+ /** Returns an iterator over all entries, starting with the oldest. */
99
+ entries(): Iterator<[K, V] | undefined> | undefined;
100
+ /** Call `fun` for each entry, starting with the oldest entry. */
101
+ forEach(fun: (value: V, key: K, m: LRUCache<K, V>) => void, thisObj?: any): void;
102
+ /** Returns a JSON (array) representation */
103
+ toJSON(): Array<{
104
+ key: K;
105
+ value: V;
106
+ }>;
107
+ /** Returns a String representation */
108
+ toString(): string;
109
+ }
110
+ /** A [[LRUCache]] using a standard Map as its internal storage.
111
+ * @public
112
+ */
113
+ export declare class LRUMap<K, V> extends LRUCache<K, V> {
114
+ /**
115
+ * Construct a new LRUMap to hold up to `limit` entries.
116
+ */
117
+ constructor(limit: number);
118
+ }
119
+ /** A [[LRUCache]] using a [[Dictionary]] as its internal storage, permitting custom key comparison logic.
120
+ * @public
121
+ */
122
+ export declare class LRUDictionary<K, V> extends LRUCache<K, V> {
123
+ /**
124
+ * Construct a new LRUDictionary to hold up to `limit` entries.
125
+ * @param limit The maximum number of entries permitted in the dictionary.
126
+ * @param compareKeys The function used to compare keys within the dictionary.
127
+ */
128
+ constructor(limit: number, compareKeys: OrderedComparator<K>);
129
+ }
130
130
  //# sourceMappingURL=LRUMap.d.ts.map