zcw-shared 1.21.0 → 1.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (474) hide show
  1. package/dist/functions/algorithm/binarySearch.d.ts +3 -0
  2. package/dist/functions/algorithm/binarySearch.js +58 -0
  3. package/dist/functions/algorithm/binarySearch.js.map +1 -0
  4. package/dist/functions/algorithm/canJump.d.ts +2 -0
  5. package/dist/functions/algorithm/canJump.js +27 -0
  6. package/dist/functions/algorithm/canJump.js.map +1 -0
  7. package/dist/functions/algorithm/climbStairs.d.ts +2 -0
  8. package/dist/functions/algorithm/climbStairs.js +27 -0
  9. package/dist/functions/algorithm/climbStairs.js.map +1 -0
  10. package/dist/functions/algorithm/coinChange.d.ts +2 -0
  11. package/dist/functions/algorithm/coinChange.js +25 -0
  12. package/dist/functions/algorithm/coinChange.js.map +1 -0
  13. package/dist/functions/algorithm/combinationSum.d.ts +1 -0
  14. package/dist/functions/algorithm/combinationSum.js +24 -0
  15. package/dist/functions/algorithm/combinationSum.js.map +1 -0
  16. package/dist/functions/algorithm/editDistance.d.ts +2 -0
  17. package/dist/functions/algorithm/editDistance.js +96 -0
  18. package/dist/functions/algorithm/editDistance.js.map +1 -0
  19. package/dist/functions/algorithm/generateParenthesis.d.ts +1 -0
  20. package/dist/functions/algorithm/generateParenthesis.js +18 -0
  21. package/dist/functions/algorithm/generateParenthesis.js.map +1 -0
  22. package/dist/functions/algorithm/kmp.d.ts +2 -0
  23. package/dist/functions/algorithm/kmp.js +58 -0
  24. package/dist/functions/algorithm/kmp.js.map +1 -0
  25. package/dist/functions/algorithm/knapsack01.d.ts +2 -0
  26. package/dist/functions/algorithm/knapsack01.js +34 -0
  27. package/dist/functions/algorithm/knapsack01.js.map +1 -0
  28. package/dist/functions/algorithm/lengthOfLongestSubstring.d.ts +2 -0
  29. package/dist/functions/algorithm/lengthOfLongestSubstring.js +33 -0
  30. package/dist/functions/algorithm/lengthOfLongestSubstring.js.map +1 -0
  31. package/dist/functions/algorithm/longestCommonSubsequence.d.ts +2 -0
  32. package/dist/functions/algorithm/longestCommonSubsequence.js +37 -0
  33. package/dist/functions/algorithm/longestCommonSubsequence.js.map +1 -0
  34. package/dist/functions/algorithm/longestIncreasingSubsequence.d.ts +2 -0
  35. package/dist/functions/algorithm/longestIncreasingSubsequence.js +49 -0
  36. package/dist/functions/algorithm/longestIncreasingSubsequence.js.map +1 -0
  37. package/dist/functions/algorithm/maxArea.d.ts +1 -0
  38. package/dist/functions/algorithm/maxArea.js +19 -0
  39. package/dist/functions/algorithm/maxArea.js.map +1 -0
  40. package/dist/functions/algorithm/maxProfit.d.ts +2 -0
  41. package/dist/functions/algorithm/maxProfit.js +23 -0
  42. package/dist/functions/algorithm/maxProfit.js.map +1 -0
  43. package/dist/functions/algorithm/meetingRooms.d.ts +6 -0
  44. package/dist/functions/algorithm/meetingRooms.js +31 -0
  45. package/dist/functions/algorithm/meetingRooms.js.map +1 -0
  46. package/dist/functions/algorithm/mergeSort.d.ts +2 -0
  47. package/dist/functions/algorithm/mergeSort.js +72 -0
  48. package/dist/functions/algorithm/mergeSort.js.map +1 -0
  49. package/dist/functions/algorithm/minPathSum.d.ts +2 -0
  50. package/dist/functions/algorithm/minPathSum.js +39 -0
  51. package/dist/functions/algorithm/minPathSum.js.map +1 -0
  52. package/dist/functions/algorithm/minWindow.d.ts +1 -0
  53. package/dist/functions/algorithm/minWindow.js +40 -0
  54. package/dist/functions/algorithm/minWindow.js.map +1 -0
  55. package/dist/functions/algorithm/nQueens.d.ts +1 -0
  56. package/dist/functions/algorithm/nQueens.js +30 -0
  57. package/dist/functions/algorithm/nQueens.js.map +1 -0
  58. package/dist/functions/algorithm/numIslands.d.ts +2 -0
  59. package/dist/functions/algorithm/numIslands.js +59 -0
  60. package/dist/functions/algorithm/numIslands.js.map +1 -0
  61. package/dist/functions/algorithm/permutations.d.ts +1 -0
  62. package/dist/functions/algorithm/permutations.js +22 -0
  63. package/dist/functions/algorithm/permutations.js.map +1 -0
  64. package/dist/functions/algorithm/quickSort.d.ts +3 -0
  65. package/dist/functions/algorithm/quickSort.js +68 -0
  66. package/dist/functions/algorithm/quickSort.js.map +1 -0
  67. package/dist/functions/algorithm/rabinKarp.d.ts +1 -0
  68. package/dist/functions/algorithm/rabinKarp.js +40 -0
  69. package/dist/functions/algorithm/rabinKarp.js.map +1 -0
  70. package/dist/functions/algorithm/taskScheduler.d.ts +1 -0
  71. package/dist/functions/algorithm/taskScheduler.js +15 -0
  72. package/dist/functions/algorithm/taskScheduler.js.map +1 -0
  73. package/dist/functions/algorithm/threeSum.d.ts +2 -0
  74. package/dist/functions/algorithm/threeSum.js +56 -0
  75. package/dist/functions/algorithm/threeSum.js.map +1 -0
  76. package/dist/functions/algorithm/topologicalSort.d.ts +6 -0
  77. package/dist/functions/algorithm/topologicalSort.js +68 -0
  78. package/dist/functions/algorithm/topologicalSort.js.map +1 -0
  79. package/dist/functions/algorithm/trap.d.ts +2 -0
  80. package/dist/functions/algorithm/trap.js +51 -0
  81. package/dist/functions/algorithm/trap.js.map +1 -0
  82. package/dist/functions/algorithm/visualizeGarbageCollection.d.ts +44 -0
  83. package/dist/functions/algorithm/visualizeGarbageCollection.js +263 -0
  84. package/dist/functions/algorithm/visualizeGarbageCollection.js.map +1 -0
  85. package/dist/functions/array-object/chunk.d.ts +1 -0
  86. package/dist/functions/array-object/chunk.js +11 -0
  87. package/dist/functions/array-object/chunk.js.map +1 -0
  88. package/dist/functions/array-object/evolve.d.ts +3 -0
  89. package/dist/functions/array-object/evolve.js +15 -0
  90. package/dist/functions/array-object/evolve.js.map +1 -0
  91. package/dist/functions/array-object/flattenObject.d.ts +5 -0
  92. package/dist/functions/array-object/flattenObject.js +102 -0
  93. package/dist/functions/array-object/flattenObject.js.map +1 -0
  94. package/dist/functions/array-object/groupBy.d.ts +1 -0
  95. package/dist/functions/array-object/groupBy.js +14 -0
  96. package/dist/functions/array-object/groupBy.js.map +1 -0
  97. package/dist/functions/array-object/omit.d.ts +1 -0
  98. package/dist/functions/array-object/omit.js +8 -0
  99. package/dist/functions/array-object/omit.js.map +1 -0
  100. package/dist/functions/array-object/pick.d.ts +1 -0
  101. package/dist/functions/array-object/pick.js +10 -0
  102. package/dist/functions/array-object/pick.js.map +1 -0
  103. package/dist/functions/array-object/shuffle.d.ts +1 -0
  104. package/dist/functions/array-object/shuffle.js +9 -0
  105. package/dist/functions/array-object/shuffle.js.map +1 -0
  106. package/dist/functions/array-object/sortBy.d.ts +1 -0
  107. package/dist/functions/array-object/sortBy.js +13 -0
  108. package/dist/functions/array-object/sortBy.js.map +1 -0
  109. package/dist/functions/async/cachedAsync.d.ts +27 -0
  110. package/dist/functions/async/cachedAsync.js +123 -0
  111. package/dist/functions/async/cachedAsync.js.map +1 -0
  112. package/dist/functions/async/promiseLimit.d.ts +10 -0
  113. package/dist/functions/async/promiseLimit.js +125 -0
  114. package/dist/functions/async/promiseLimit.js.map +1 -0
  115. package/dist/functions/async/retryWithBackoff.d.ts +12 -0
  116. package/dist/functions/async/retryWithBackoff.js +29 -0
  117. package/dist/functions/async/retryWithBackoff.js.map +1 -0
  118. package/dist/functions/browser/detectBrowser.d.ts +39 -0
  119. package/dist/functions/browser/detectBrowser.js +193 -0
  120. package/dist/functions/browser/detectBrowser.js.map +1 -0
  121. package/dist/functions/browser/detectOS.d.ts +5 -0
  122. package/dist/functions/browser/detectOS.js +20 -0
  123. package/dist/functions/browser/detectOS.js.map +1 -0
  124. package/dist/functions/browser/isMobile.d.ts +6 -0
  125. package/dist/functions/browser/isMobile.js +5 -0
  126. package/dist/functions/browser/isMobile.js.map +1 -0
  127. package/dist/functions/data-structures/AVLTree.d.ts +19 -0
  128. package/dist/functions/data-structures/AVLTree.js +197 -0
  129. package/dist/functions/data-structures/AVLTree.js.map +1 -0
  130. package/dist/functions/data-structures/BinarySearchTree.d.ts +19 -0
  131. package/dist/functions/data-structures/BinarySearchTree.js +150 -0
  132. package/dist/functions/data-structures/BinarySearchTree.js.map +1 -0
  133. package/dist/functions/data-structures/Graph.d.ts +19 -0
  134. package/dist/functions/data-structures/Graph.js +190 -0
  135. package/dist/functions/data-structures/Graph.js.map +1 -0
  136. package/dist/functions/data-structures/HashMap.d.ts +13 -0
  137. package/dist/functions/data-structures/HashMap.js +128 -0
  138. package/dist/functions/data-structures/HashMap.js.map +1 -0
  139. package/dist/functions/data-structures/LRUCache.d.ts +41 -0
  140. package/dist/functions/data-structures/LRUCache.js +182 -0
  141. package/dist/functions/data-structures/LRUCache.js.map +1 -0
  142. package/dist/functions/data-structures/Trie.d.ts +16 -0
  143. package/dist/functions/data-structures/Trie.js +127 -0
  144. package/dist/functions/data-structures/Trie.js.map +1 -0
  145. package/dist/functions/data-structures/UnionFind.d.ts +8 -0
  146. package/dist/functions/data-structures/UnionFind.js +53 -0
  147. package/dist/functions/data-structures/UnionFind.js.map +1 -0
  148. package/dist/functions/date/dateRange.d.ts +1 -0
  149. package/dist/functions/date/dateRange.js +18 -0
  150. package/dist/functions/date/dateRange.js.map +1 -0
  151. package/dist/functions/date/formatDate.d.ts +1 -0
  152. package/dist/functions/date/formatDate.js +21 -0
  153. package/dist/functions/date/formatDate.js.map +1 -0
  154. package/dist/functions/date/timeAgo.d.ts +1 -0
  155. package/dist/functions/date/timeAgo.js +49 -0
  156. package/dist/functions/date/timeAgo.js.map +1 -0
  157. package/dist/functions/dom/createThrottledEventListener.d.ts +11 -0
  158. package/dist/functions/dom/createThrottledEventListener.js +51 -0
  159. package/dist/functions/dom/createThrottledEventListener.js.map +1 -0
  160. package/dist/functions/file/formatFileSize.d.ts +1 -0
  161. package/dist/functions/file/formatFileSize.js +16 -0
  162. package/dist/functions/file/formatFileSize.js.map +1 -0
  163. package/dist/functions/file/getFileExtension.d.ts +5 -0
  164. package/dist/functions/file/getFileExtension.js +18 -0
  165. package/dist/functions/file/getFileExtension.js.map +1 -0
  166. package/dist/functions/functional/cond.d.ts +1 -0
  167. package/dist/functions/functional/cond.js +15 -0
  168. package/dist/functions/functional/cond.js.map +1 -0
  169. package/dist/functions/functional/curryAdvanced.d.ts +8 -0
  170. package/dist/functions/functional/curryAdvanced.js +87 -0
  171. package/dist/functions/functional/curryAdvanced.js.map +1 -0
  172. package/dist/functions/functional/flow.d.ts +1 -0
  173. package/dist/functions/functional/flow.js +14 -0
  174. package/dist/functions/functional/flow.js.map +1 -0
  175. package/dist/functions/functional/partial.d.ts +1 -0
  176. package/dist/functions/functional/partial.js +13 -0
  177. package/dist/functions/functional/partial.js.map +1 -0
  178. package/dist/functions/functional/tap.d.ts +1 -0
  179. package/dist/functions/functional/tap.js +14 -0
  180. package/dist/functions/functional/tap.js.map +1 -0
  181. package/dist/functions/functional/until.d.ts +1 -0
  182. package/dist/functions/functional/until.js +10 -0
  183. package/dist/functions/functional/until.js.map +1 -0
  184. package/dist/functions/math/average.d.ts +1 -0
  185. package/dist/functions/math/average.js +8 -0
  186. package/dist/functions/math/average.js.map +1 -0
  187. package/dist/functions/math/median.d.ts +1 -0
  188. package/dist/functions/math/median.js +14 -0
  189. package/dist/functions/math/median.js.map +1 -0
  190. package/dist/functions/math/percentile.d.ts +1 -0
  191. package/dist/functions/math/percentile.js +18 -0
  192. package/dist/functions/math/percentile.js.map +1 -0
  193. package/dist/functions/math/sum.d.ts +1 -0
  194. package/dist/functions/math/sum.js +4 -0
  195. package/dist/functions/math/sum.js.map +1 -0
  196. package/dist/functions/number/clamp.d.ts +1 -0
  197. package/dist/functions/number/clamp.js +7 -0
  198. package/dist/functions/number/clamp.js.map +1 -0
  199. package/dist/functions/number/formatNumber.d.ts +8 -0
  200. package/dist/functions/number/formatNumber.js +16 -0
  201. package/dist/functions/number/formatNumber.js.map +1 -0
  202. package/dist/functions/number/random.d.ts +4 -0
  203. package/dist/functions/number/random.js +9 -0
  204. package/dist/functions/number/random.js.map +1 -0
  205. package/dist/functions/number/range.d.ts +1 -0
  206. package/dist/functions/number/range.js +18 -0
  207. package/dist/functions/number/range.js.map +1 -0
  208. package/dist/functions/patterns/EventEmitter.d.ts +32 -0
  209. package/dist/functions/patterns/EventEmitter.js +108 -0
  210. package/dist/functions/patterns/EventEmitter.js.map +1 -0
  211. package/dist/functions/patterns/adapter.d.ts +8 -0
  212. package/dist/functions/patterns/adapter.js +14 -0
  213. package/dist/functions/patterns/adapter.js.map +1 -0
  214. package/dist/functions/patterns/builder.d.ts +9 -0
  215. package/dist/functions/patterns/builder.js +28 -0
  216. package/dist/functions/patterns/builder.js.map +1 -0
  217. package/dist/functions/patterns/chainOfResponsibility.d.ts +9 -0
  218. package/dist/functions/patterns/chainOfResponsibility.js +19 -0
  219. package/dist/functions/patterns/chainOfResponsibility.js.map +1 -0
  220. package/dist/functions/patterns/command.d.ts +15 -0
  221. package/dist/functions/patterns/command.js +49 -0
  222. package/dist/functions/patterns/command.js.map +1 -0
  223. package/dist/functions/patterns/decorator.d.ts +10 -0
  224. package/dist/functions/patterns/decorator.js +72 -0
  225. package/dist/functions/patterns/decorator.js.map +1 -0
  226. package/dist/functions/patterns/factory.d.ts +8 -0
  227. package/dist/functions/patterns/factory.js +25 -0
  228. package/dist/functions/patterns/factory.js.map +1 -0
  229. package/dist/functions/patterns/observer.d.ts +19 -0
  230. package/dist/functions/patterns/observer.js +89 -0
  231. package/dist/functions/patterns/observer.js.map +1 -0
  232. package/dist/functions/patterns/prototype.d.ts +4 -0
  233. package/dist/functions/patterns/prototype.js +30 -0
  234. package/dist/functions/patterns/prototype.js.map +1 -0
  235. package/dist/functions/patterns/proxy.d.ts +8 -0
  236. package/dist/functions/patterns/proxy.js +41 -0
  237. package/dist/functions/patterns/proxy.js.map +1 -0
  238. package/dist/functions/patterns/singleton.d.ts +11 -0
  239. package/dist/functions/patterns/singleton.js +32 -0
  240. package/dist/functions/patterns/singleton.js.map +1 -0
  241. package/dist/functions/patterns/strategy.d.ts +12 -0
  242. package/dist/functions/patterns/strategy.js +34 -0
  243. package/dist/functions/patterns/strategy.js.map +1 -0
  244. package/dist/functions/patterns/templateMethod.d.ts +8 -0
  245. package/dist/functions/patterns/templateMethod.js +19 -0
  246. package/dist/functions/patterns/templateMethod.js.map +1 -0
  247. package/dist/functions/patterns/usePluginSystem.d.ts +11 -0
  248. package/dist/functions/patterns/usePluginSystem.js +34 -0
  249. package/dist/functions/patterns/usePluginSystem.js.map +1 -0
  250. package/dist/functions/performance/once.d.ts +1 -0
  251. package/dist/functions/performance/once.js +13 -0
  252. package/dist/functions/performance/once.js.map +1 -0
  253. package/dist/functions/performance/useCache.d.ts +18 -0
  254. package/dist/functions/performance/useCache.js +82 -0
  255. package/dist/functions/performance/useCache.js.map +1 -0
  256. package/dist/functions/principles/MyPromise.d.ts +32 -0
  257. package/dist/functions/principles/MyPromise.js +254 -0
  258. package/dist/functions/principles/MyPromise.js.map +1 -0
  259. package/dist/functions/promise/sleep.d.ts +5 -0
  260. package/dist/functions/promise/sleep.js +6 -0
  261. package/dist/functions/promise/sleep.js.map +1 -0
  262. package/dist/functions/promise/timeout.d.ts +6 -0
  263. package/dist/functions/promise/timeout.js +12 -0
  264. package/dist/functions/promise/timeout.js.map +1 -0
  265. package/dist/functions/storage/useLocalStorage.d.ts +8 -0
  266. package/dist/functions/storage/useLocalStorage.js +101 -0
  267. package/dist/functions/storage/useLocalStorage.js.map +1 -0
  268. package/dist/functions/storage/useSessionStorage.d.ts +8 -0
  269. package/dist/functions/storage/useSessionStorage.js +101 -0
  270. package/dist/functions/storage/useSessionStorage.js.map +1 -0
  271. package/dist/functions/storage/useStorage.d.ts +13 -0
  272. package/dist/functions/storage/useStorage.js +62 -0
  273. package/dist/functions/storage/useStorage.js.map +1 -0
  274. package/dist/functions/storage/useStorageWithIndexedDB.d.ts +8 -0
  275. package/dist/functions/storage/useStorageWithIndexedDB.js +132 -0
  276. package/dist/functions/storage/useStorageWithIndexedDB.js.map +1 -0
  277. package/dist/functions/string/testRegex.d.ts +20 -0
  278. package/dist/functions/string/testRegex.js +300 -0
  279. package/dist/functions/string/testRegex.js.map +1 -0
  280. package/dist/functions/string/visualizeRegexSteps.d.ts +39 -0
  281. package/dist/functions/string/visualizeRegexSteps.js +446 -0
  282. package/dist/functions/string/visualizeRegexSteps.js.map +1 -0
  283. package/dist/functions/tencent-cloud/upload.cos.d.ts +20 -0
  284. package/dist/functions/tencent-cloud/upload.cos.js +127 -0
  285. package/dist/functions/tencent-cloud/upload.cos.js.map +1 -0
  286. package/dist/functions/tree/buildTree.d.ts +7 -0
  287. package/dist/functions/tree/buildTree.js +27 -0
  288. package/dist/functions/tree/buildTree.js.map +1 -0
  289. package/dist/functions/tree/filterTree.d.ts +4 -0
  290. package/dist/functions/tree/filterTree.js +21 -0
  291. package/dist/functions/tree/filterTree.js.map +1 -0
  292. package/dist/functions/tree/findNode.d.ts +4 -0
  293. package/dist/functions/tree/findNode.js +21 -0
  294. package/dist/functions/tree/findNode.js.map +1 -0
  295. package/dist/functions/tree/flattenTree.d.ts +6 -0
  296. package/dist/functions/tree/flattenTree.js +21 -0
  297. package/dist/functions/tree/flattenTree.js.map +1 -0
  298. package/dist/functions/url/buildQueryString.d.ts +5 -0
  299. package/dist/functions/url/buildQueryString.js +15 -0
  300. package/dist/functions/url/buildQueryString.js.map +1 -0
  301. package/dist/functions/url/parseUrl.d.ts +11 -0
  302. package/dist/functions/url/parseUrl.js +34 -0
  303. package/dist/functions/url/parseUrl.js.map +1 -0
  304. package/dist/functions/utils/cachedAsync.d.ts +27 -0
  305. package/dist/functions/utils/cachedAsync.js +123 -0
  306. package/dist/functions/utils/cachedAsync.js.map +1 -0
  307. package/dist/functions/utils/errorManager.d.ts +63 -0
  308. package/dist/functions/utils/errorManager.js +199 -0
  309. package/dist/functions/utils/errorManager.js.map +1 -0
  310. package/dist/functions/utils/useAltool.d.ts +39 -0
  311. package/dist/functions/utils/useAltool.js +350 -0
  312. package/dist/functions/utils/useAltool.js.map +1 -0
  313. package/dist/functions/utils/vueDiff.d.ts +38 -0
  314. package/dist/functions/utils/vueDiff.js +333 -0
  315. package/dist/functions/utils/vueDiff.js.map +1 -0
  316. package/dist/functions/validation/isEmail.d.ts +1 -0
  317. package/dist/functions/validation/isEmail.js +8 -0
  318. package/dist/functions/validation/isEmail.js.map +1 -0
  319. package/dist/functions/validation/isIdCard.d.ts +1 -0
  320. package/dist/functions/validation/isIdCard.js +49 -0
  321. package/dist/functions/validation/isIdCard.js.map +1 -0
  322. package/dist/functions/validation/isIpAddress.d.ts +1 -0
  323. package/dist/functions/validation/isIpAddress.js +15 -0
  324. package/dist/functions/validation/isIpAddress.js.map +1 -0
  325. package/dist/functions/validation/isPhone.d.ts +1 -0
  326. package/dist/functions/validation/isPhone.js +12 -0
  327. package/dist/functions/validation/isPhone.js.map +1 -0
  328. package/dist/functions/validation/isUrl.d.ts +5 -0
  329. package/dist/functions/validation/isUrl.js +33 -0
  330. package/dist/functions/validation/isUrl.js.map +1 -0
  331. package/dist/reactive/createReactive.d.ts +10 -0
  332. package/dist/reactive/createReactive.js +50 -0
  333. package/dist/reactive/createReactive.js.map +1 -0
  334. package/dist/reactive/createReactiveErrorManager.d.ts +63 -0
  335. package/dist/reactive/createReactiveErrorManager.js +199 -0
  336. package/dist/reactive/createReactiveErrorManager.js.map +1 -0
  337. package/dist/reactive/createReactiveI18n.d.ts +27 -0
  338. package/dist/reactive/createReactiveI18n.js +119 -0
  339. package/dist/reactive/createReactiveI18n.js.map +1 -0
  340. package/dist/reactive/createReactivePermission.d.ts +40 -0
  341. package/dist/reactive/createReactivePermission.js +189 -0
  342. package/dist/reactive/createReactivePermission.js.map +1 -0
  343. package/dist/reactive/createReactivePinia.d.ts +52 -0
  344. package/dist/reactive/createReactivePinia.js +183 -0
  345. package/dist/reactive/createReactivePinia.js.map +1 -0
  346. package/dist/reactive/useReactiveCookie.d.ts +19 -0
  347. package/dist/reactive/useReactiveCookie.js +84 -0
  348. package/dist/reactive/useReactiveCookie.js.map +1 -0
  349. package/dist/reactive/useReactiveSSE.d.ts +46 -0
  350. package/dist/reactive/useReactiveSSE.js +212 -0
  351. package/dist/reactive/useReactiveSSE.js.map +1 -0
  352. package/dist/reactive/useReactiveWebsocket.d.ts +50 -0
  353. package/dist/reactive/useReactiveWebsocket.js +250 -0
  354. package/dist/reactive/useReactiveWebsocket.js.map +1 -0
  355. package/dist/vue-hooks/browser/useBattery.d.ts +16 -0
  356. package/dist/vue-hooks/browser/useBattery.js +70 -0
  357. package/dist/vue-hooks/browser/useBattery.js.map +1 -0
  358. package/dist/vue-hooks/browser/useBluetooth.d.ts +25 -0
  359. package/dist/vue-hooks/browser/useBluetooth.js +72 -0
  360. package/dist/vue-hooks/browser/useBluetooth.js.map +1 -0
  361. package/dist/vue-hooks/browser/useCamera.d.ts +21 -0
  362. package/dist/vue-hooks/browser/useCamera.js +52 -0
  363. package/dist/vue-hooks/browser/useCamera.js.map +1 -0
  364. package/dist/vue-hooks/browser/useClipboard.d.ts +18 -0
  365. package/dist/vue-hooks/browser/useClipboard.js +33 -0
  366. package/dist/vue-hooks/browser/useClipboard.js.map +1 -0
  367. package/dist/vue-hooks/browser/useFullscreen.d.ts +20 -0
  368. package/dist/vue-hooks/browser/useFullscreen.js +73 -0
  369. package/dist/vue-hooks/browser/useFullscreen.js.map +1 -0
  370. package/dist/vue-hooks/browser/useGamepad.d.ts +25 -0
  371. package/dist/vue-hooks/browser/useGamepad.js +69 -0
  372. package/dist/vue-hooks/browser/useGamepad.js.map +1 -0
  373. package/dist/vue-hooks/browser/useGeolocation.d.ts +24 -0
  374. package/dist/vue-hooks/browser/useGeolocation.js +85 -0
  375. package/dist/vue-hooks/browser/useGeolocation.js.map +1 -0
  376. package/dist/vue-hooks/browser/useMediaSession.d.ts +19 -0
  377. package/dist/vue-hooks/browser/useMediaSession.js +71 -0
  378. package/dist/vue-hooks/browser/useMediaSession.js.map +1 -0
  379. package/dist/vue-hooks/browser/useMicrophone.d.ts +23 -0
  380. package/dist/vue-hooks/browser/useMicrophone.js +66 -0
  381. package/dist/vue-hooks/browser/useMicrophone.js.map +1 -0
  382. package/dist/vue-hooks/browser/useNetwork.d.ts +23 -0
  383. package/dist/vue-hooks/browser/useNetwork.js +57 -0
  384. package/dist/vue-hooks/browser/useNetwork.js.map +1 -0
  385. package/dist/vue-hooks/browser/useOrientation.d.ts +22 -0
  386. package/dist/vue-hooks/browser/useOrientation.js +54 -0
  387. package/dist/vue-hooks/browser/useOrientation.js.map +1 -0
  388. package/dist/vue-hooks/browser/usePageVisibility.d.ts +15 -0
  389. package/dist/vue-hooks/browser/usePageVisibility.js +25 -0
  390. package/dist/vue-hooks/browser/usePageVisibility.js.map +1 -0
  391. package/dist/vue-hooks/browser/useScreenOrientation.d.ts +24 -0
  392. package/dist/vue-hooks/browser/useScreenOrientation.js +67 -0
  393. package/dist/vue-hooks/browser/useScreenOrientation.js.map +1 -0
  394. package/dist/vue-hooks/browser/useScreenWakeLock.d.ts +15 -0
  395. package/dist/vue-hooks/browser/useScreenWakeLock.js +57 -0
  396. package/dist/vue-hooks/browser/useScreenWakeLock.js.map +1 -0
  397. package/dist/vue-hooks/browser/useShare.d.ts +21 -0
  398. package/dist/vue-hooks/browser/useShare.js +39 -0
  399. package/dist/vue-hooks/browser/useShare.js.map +1 -0
  400. package/dist/vue-hooks/browser/useVibration.d.ts +17 -0
  401. package/dist/vue-hooks/browser/useVibration.js +40 -0
  402. package/dist/vue-hooks/browser/useVibration.js.map +1 -0
  403. package/dist/vue-hooks/dom/useClickOutside.d.ts +9 -0
  404. package/dist/vue-hooks/dom/useClickOutside.js +16 -0
  405. package/dist/vue-hooks/dom/useClickOutside.js.map +1 -0
  406. package/dist/vue-hooks/dom/useDraggable.d.ts +33 -0
  407. package/dist/vue-hooks/dom/useDraggable.js +163 -0
  408. package/dist/vue-hooks/dom/useDraggable.js.map +1 -0
  409. package/dist/vue-hooks/dom/useEventListener.d.ts +11 -0
  410. package/dist/vue-hooks/dom/useEventListener.js +18 -0
  411. package/dist/vue-hooks/dom/useEventListener.js.map +1 -0
  412. package/dist/vue-hooks/dom/useResizable.d.ts +50 -0
  413. package/dist/vue-hooks/dom/useResizable.js +178 -0
  414. package/dist/vue-hooks/dom/useResizable.js.map +1 -0
  415. package/dist/vue-hooks/history/useDebouncedRefHistory.d.ts +17 -0
  416. package/dist/vue-hooks/history/useDebouncedRefHistory.js +46 -0
  417. package/dist/vue-hooks/history/useDebouncedRefHistory.js.map +1 -0
  418. package/dist/vue-hooks/history/useManualRefHistory.d.ts +26 -0
  419. package/dist/vue-hooks/history/useManualRefHistory.js +80 -0
  420. package/dist/vue-hooks/history/useManualRefHistory.js.map +1 -0
  421. package/dist/vue-hooks/history/useRefHistory.d.ts +15 -0
  422. package/dist/vue-hooks/history/useRefHistory.js +41 -0
  423. package/dist/vue-hooks/history/useRefHistory.js.map +1 -0
  424. package/dist/vue-hooks/state/createGlobalState.d.ts +2 -0
  425. package/dist/vue-hooks/state/createGlobalState.js +11 -0
  426. package/dist/vue-hooks/state/createGlobalState.js.map +1 -0
  427. package/dist/vue-hooks/state/createInjectionState.d.ts +10 -0
  428. package/dist/vue-hooks/state/createInjectionState.js +20 -0
  429. package/dist/vue-hooks/state/createInjectionState.js.map +1 -0
  430. package/dist/vue-hooks/state/createSharedComposable.d.ts +2 -0
  431. package/dist/vue-hooks/state/createSharedComposable.js +13 -0
  432. package/dist/vue-hooks/state/createSharedComposable.js.map +1 -0
  433. package/dist/vue-hooks/state/injectLocal.d.ts +8 -0
  434. package/dist/vue-hooks/state/injectLocal.js +12 -0
  435. package/dist/vue-hooks/state/injectLocal.js.map +1 -0
  436. package/dist/vue-hooks/state/provideLocal.d.ts +7 -0
  437. package/dist/vue-hooks/state/provideLocal.js +7 -0
  438. package/dist/vue-hooks/state/provideLocal.js.map +1 -0
  439. package/dist/vue-hooks/state/useAsyncState.d.ts +27 -0
  440. package/dist/vue-hooks/state/useAsyncState.js +46 -0
  441. package/dist/vue-hooks/state/useAsyncState.js.map +1 -0
  442. package/dist/vue-hooks/state/useCounter.d.ts +17 -0
  443. package/dist/vue-hooks/state/useCounter.js +44 -0
  444. package/dist/vue-hooks/state/useCounter.js.map +1 -0
  445. package/dist/vue-hooks/state/useToggle.d.ts +13 -0
  446. package/dist/vue-hooks/state/useToggle.js +23 -0
  447. package/dist/vue-hooks/state/useToggle.js.map +1 -0
  448. package/dist/vue-hooks/time/useInterval.d.ts +16 -0
  449. package/dist/vue-hooks/time/useInterval.js +33 -0
  450. package/dist/vue-hooks/time/useInterval.js.map +1 -0
  451. package/dist/vue-hooks/time/useTimeout.d.ts +17 -0
  452. package/dist/vue-hooks/time/useTimeout.js +40 -0
  453. package/dist/vue-hooks/time/useTimeout.js.map +1 -0
  454. package/dist/vue-hooks/worker/useWebWorker.d.ts +25 -0
  455. package/dist/vue-hooks/worker/useWebWorker.js +207 -0
  456. package/dist/vue-hooks/worker/useWebWorker.js.map +1 -0
  457. package/dist/vue-hooks/worker/useWorkerFunction.d.ts +26 -0
  458. package/dist/vue-hooks/worker/useWorkerFunction.js +191 -0
  459. package/dist/vue-hooks/worker/useWorkerFunction.js.map +1 -0
  460. package/dist/vue-hooks/worker/useWorkerPool.d.ts +33 -0
  461. package/dist/vue-hooks/worker/useWorkerPool.js +247 -0
  462. package/dist/vue-hooks/worker/useWorkerPool.js.map +1 -0
  463. package/package.json +178 -65
  464. package/references/browser.d.ts +16 -0
  465. package/references/device.d.ts +340 -0
  466. package/references/dom.d.ts +31 -6
  467. package/references/eventsource.d.ts +121 -0
  468. package/references/node.d.ts +2 -0
  469. package/references/tencent-cloud.d.ts +38 -0
  470. package/references/websocket.d.ts +121 -0
  471. package/types/algorithm-visual.d.ts +79 -0
  472. package/types/algorithm.d.ts +85 -0
  473. package/types/tencent-cloud.d.ts +29 -0
  474. package/types/vue.d.ts +22 -0
@@ -0,0 +1,68 @@
1
+ export function topologicalSort(numCourses, prerequisites) {
2
+ const graph = Array.from({ length: numCourses }, () => []);
3
+ const inDegree = Array(numCourses).fill(0);
4
+ for (const [course, prereq] of prerequisites) {
5
+ graph[prereq].push(course);
6
+ inDegree[course]++;
7
+ }
8
+ const queue = [];
9
+ for (let i = 0; i < numCourses; i++) {
10
+ if (inDegree[i] === 0) {
11
+ queue.push(i);
12
+ }
13
+ }
14
+ const order = [];
15
+ while (queue.length > 0) {
16
+ const course = queue.shift();
17
+ order.push(course);
18
+ for (const next of graph[course]) {
19
+ inDegree[next]--;
20
+ if (inDegree[next] === 0) {
21
+ queue.push(next);
22
+ }
23
+ }
24
+ }
25
+ return {
26
+ canFinish: order.length === numCourses,
27
+ order: order.length === numCourses ? order : []
28
+ };
29
+ }
30
+ export function topologicalSortDFS(numCourses, prerequisites) {
31
+ const graph = Array.from({ length: numCourses }, () => []);
32
+ for (const [course, prereq] of prerequisites) {
33
+ graph[prereq].push(course);
34
+ }
35
+ const visited = Array(numCourses).fill(false);
36
+ const visiting = Array(numCourses).fill(false);
37
+ const order = [];
38
+ let hasCycle = false;
39
+ function dfs(course) {
40
+ if (visiting[course]) {
41
+ hasCycle = true;
42
+ return;
43
+ }
44
+ if (visited[course])
45
+ return;
46
+ visiting[course] = true;
47
+ for (const next of graph[course]) {
48
+ dfs(next);
49
+ if (hasCycle)
50
+ return;
51
+ }
52
+ visiting[course] = false;
53
+ visited[course] = true;
54
+ order.push(course);
55
+ }
56
+ for (let i = 0; i < numCourses; i++) {
57
+ if (!visited[i]) {
58
+ dfs(i);
59
+ if (hasCycle)
60
+ break;
61
+ }
62
+ }
63
+ return {
64
+ canFinish: !hasCycle,
65
+ order: hasCycle ? [] : order.reverse()
66
+ };
67
+ }
68
+ //# sourceMappingURL=topologicalSort.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"topologicalSort.js","sourceRoot":"","sources":["../../../src/functions/algorithm/topologicalSort.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function trap(height: number[]): number;
2
+ export declare function trapDP(height: number[]): number;
@@ -0,0 +1,51 @@
1
+ export function trap(height) {
2
+ if (height.length === 0)
3
+ return 0;
4
+ let left = 0;
5
+ let right = height.length - 1;
6
+ let leftMax = 0;
7
+ let rightMax = 0;
8
+ let water = 0;
9
+ while (left < right) {
10
+ if (height[left] < height[right]) {
11
+ if (height[left] >= leftMax) {
12
+ leftMax = height[left];
13
+ }
14
+ else {
15
+ water += leftMax - height[left];
16
+ }
17
+ left++;
18
+ }
19
+ else {
20
+ if (height[right] >= rightMax) {
21
+ rightMax = height[right];
22
+ }
23
+ else {
24
+ water += rightMax - height[right];
25
+ }
26
+ right--;
27
+ }
28
+ }
29
+ return water;
30
+ }
31
+ export function trapDP(height) {
32
+ if (height.length === 0)
33
+ return 0;
34
+ const n = height.length;
35
+ const leftMax = Array(n).fill(0);
36
+ const rightMax = Array(n).fill(0);
37
+ leftMax[0] = height[0];
38
+ for (let i = 1; i < n; i++) {
39
+ leftMax[i] = Math.max(leftMax[i - 1], height[i]);
40
+ }
41
+ rightMax[n - 1] = height[n - 1];
42
+ for (let i = n - 2; i >= 0; i--) {
43
+ rightMax[i] = Math.max(rightMax[i + 1], height[i]);
44
+ }
45
+ let water = 0;
46
+ for (let i = 0; i < n; i++) {
47
+ water += Math.min(leftMax[i], rightMax[i]) - height[i];
48
+ }
49
+ return water;
50
+ }
51
+ //# sourceMappingURL=trap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"trap.js","sourceRoot":"","sources":["../../../src/functions/algorithm/trap.ts"],"names":[],"mappings":"AAgBA,MAAM,UAAU,IAAI,CAAC,MAAgB;IACnC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,CAAC,CAAA;IAEjC,IAAI,IAAI,GAAG,CAAC,CAAA;IACZ,IAAI,KAAK,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,CAAA;IAC7B,IAAI,OAAO,GAAG,CAAC,CAAA;IACf,IAAI,QAAQ,GAAG,CAAC,CAAA;IAChB,IAAI,KAAK,GAAG,CAAC,CAAA;IAEb,OAAO,IAAI,GAAG,KAAK,EAAE,CAAC;QACpB,IAAI,MAAM,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;YACjC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,OAAO,EAAE,CAAC;gBAC5B,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;YACxB,CAAC;iBAAM,CAAC;gBACN,KAAK,IAAI,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,CAAA;YACjC,CAAC;YACD,IAAI,EAAE,CAAA;QACR,CAAC;aAAM,CAAC;YACN,IAAI,MAAM,CAAC,KAAK,CAAC,IAAI,QAAQ,EAAE,CAAC;gBAC9B,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;YAC1B,CAAC;iBAAM,CAAC;gBACN,KAAK,IAAI,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;YACnC,CAAC;YACD,KAAK,EAAE,CAAA;QACT,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAA;AACd,CAAC;AAKD,MAAM,UAAU,MAAM,CAAC,MAAgB;IACrC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,CAAC,CAAA;IAEjC,MAAM,CAAC,GAAG,MAAM,CAAC,MAAM,CAAA;IACvB,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAChC,MAAM,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;IAGjC,OAAO,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAA;IACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAC3B,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;IAClD,CAAC;IAGD,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAA;IAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAChC,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;IACpD,CAAC;IAGD,IAAI,KAAK,GAAG,CAAC,CAAA;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAC3B,KAAK,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,CAAA;IACxD,CAAC;IAED,OAAO,KAAK,CAAA;AACd,CAAC"}
@@ -0,0 +1,44 @@
1
+ export interface GCObject {
2
+ id: string;
3
+ name: string;
4
+ references: string[];
5
+ isRoot: boolean;
6
+ size: number;
7
+ age: number;
8
+ generation: 'young' | 'old';
9
+ space?: 'from' | 'to';
10
+ marked: boolean;
11
+ }
12
+ export interface GCStep {
13
+ stepNumber: number;
14
+ gcType: 'scavenge' | 'mark-sweep' | 'full';
15
+ action: 'init' | 'scan' | 'copy' | 'swap' | 'promote' | 'mark' | 'sweep' | 'compact' | 'complete';
16
+ currentObjectId?: string;
17
+ objects: GCObject[];
18
+ explanation: string;
19
+ collected: string[];
20
+ promoted: string[];
21
+ memoryStats: {
22
+ youngTotal: number;
23
+ youngUsed: number;
24
+ oldTotal: number;
25
+ oldUsed: number;
26
+ freed: number;
27
+ };
28
+ }
29
+ export interface GCResult {
30
+ steps: GCStep[];
31
+ survivors: string[];
32
+ collected: string[];
33
+ promoted: string[];
34
+ freedMemory: number;
35
+ }
36
+ export declare function visualizeGarbageCollection(initialObjects: Array<{
37
+ id: string;
38
+ name: string;
39
+ references: string[];
40
+ isRoot: boolean;
41
+ generation: 'young' | 'old';
42
+ age: number;
43
+ size: number;
44
+ }>, gcType?: 'scavenge' | 'full'): GCResult;
@@ -0,0 +1,263 @@
1
+ function scavengeGC(objects, steps, stepNum, collected, promoted) {
2
+ const allObjects = Array.from(objects.values());
3
+ const youngObjects = allObjects.filter(o => o.generation === 'young');
4
+ steps.push({
5
+ stepNumber: stepNum.value++,
6
+ gcType: 'scavenge',
7
+ action: 'init',
8
+ objects: allObjects.map(o => ({ ...o })),
9
+ explanation: `启动新生代 GC (Scavenge):检测到 ${youngObjects.length} 个年轻对象`,
10
+ collected: [...collected],
11
+ promoted: [...promoted],
12
+ memoryStats: calculateMemoryStats(allObjects, 0)
13
+ });
14
+ const reachableYoung = new Set();
15
+ for (const obj of allObjects) {
16
+ if (obj.isRoot && obj.generation === 'young' && obj.space === 'from') {
17
+ scanYoungObject(obj.id, objects, reachableYoung, steps, stepNum, collected, promoted, allObjects);
18
+ }
19
+ if (obj.generation === 'old') {
20
+ for (const refId of obj.references) {
21
+ const refObj = objects.get(refId);
22
+ if (refObj && refObj.generation === 'young' && refObj.space === 'from') {
23
+ scanYoungObject(refId, objects, reachableYoung, steps, stepNum, collected, promoted, allObjects);
24
+ }
25
+ }
26
+ }
27
+ }
28
+ for (const objId of reachableYoung) {
29
+ const obj = objects.get(objId);
30
+ if (!obj)
31
+ continue;
32
+ if (obj.age >= 2) {
33
+ obj.generation = 'old';
34
+ obj.space = undefined;
35
+ promoted.push(objId);
36
+ const currentObjects = Array.from(objects.values());
37
+ steps.push({
38
+ stepNumber: stepNum.value++,
39
+ gcType: 'scavenge',
40
+ action: 'promote',
41
+ currentObjectId: objId,
42
+ objects: currentObjects.map(o => ({ ...o })),
43
+ explanation: `对象 ${obj.name} 年龄达到 ${obj.age},晋升到老生代`,
44
+ collected: [...collected],
45
+ promoted: [...promoted],
46
+ memoryStats: calculateMemoryStats(currentObjects, 0)
47
+ });
48
+ }
49
+ else {
50
+ obj.space = 'to';
51
+ obj.age++;
52
+ const currentObjects = Array.from(objects.values());
53
+ steps.push({
54
+ stepNumber: stepNum.value++,
55
+ gcType: 'scavenge',
56
+ action: 'copy',
57
+ currentObjectId: objId,
58
+ objects: currentObjects.map(o => ({ ...o })),
59
+ explanation: `复制对象 ${obj.name} 到 To 空间,年龄 ${obj.age - 1} → ${obj.age}`,
60
+ collected: [...collected],
61
+ promoted: [...promoted],
62
+ memoryStats: calculateMemoryStats(currentObjects, 0)
63
+ });
64
+ }
65
+ }
66
+ let freedMemory = 0;
67
+ for (const obj of youngObjects) {
68
+ if (obj.space === 'from' && !reachableYoung.has(obj.id)) {
69
+ freedMemory += obj.size;
70
+ collected.push(obj.id);
71
+ objects.delete(obj.id);
72
+ const currentObjects = Array.from(objects.values());
73
+ steps.push({
74
+ stepNumber: stepNum.value++,
75
+ gcType: 'scavenge',
76
+ action: 'sweep',
77
+ currentObjectId: obj.id,
78
+ objects: currentObjects.map(o => ({ ...o })),
79
+ explanation: `回收 From 空间中的对象 ${obj.name} (${obj.size} KB)`,
80
+ collected: [...collected],
81
+ promoted: [...promoted],
82
+ memoryStats: calculateMemoryStats(currentObjects, freedMemory)
83
+ });
84
+ }
85
+ }
86
+ for (const obj of objects.values()) {
87
+ if (obj.generation === 'young' && obj.space === 'to') {
88
+ obj.space = 'from';
89
+ }
90
+ }
91
+ const finalObjects = Array.from(objects.values());
92
+ steps.push({
93
+ stepNumber: stepNum.value++,
94
+ gcType: 'scavenge',
95
+ action: 'swap',
96
+ objects: finalObjects.map(o => ({ ...o })),
97
+ explanation: `交换 From/To 空间:To 空间变为新的 From 空间`,
98
+ collected: [...collected],
99
+ promoted: [...promoted],
100
+ memoryStats: calculateMemoryStats(finalObjects, freedMemory)
101
+ });
102
+ }
103
+ function scanYoungObject(objId, objects, reachable, steps, stepNum, collected, promoted, allObjects) {
104
+ if (reachable.has(objId))
105
+ return;
106
+ const obj = objects.get(objId);
107
+ if (!obj || obj.generation !== 'young' || obj.space !== 'from')
108
+ return;
109
+ reachable.add(objId);
110
+ steps.push({
111
+ stepNumber: stepNum.value++,
112
+ gcType: 'scavenge',
113
+ action: 'scan',
114
+ currentObjectId: objId,
115
+ objects: allObjects.map(o => ({ ...o })),
116
+ explanation: `扫描年轻对象 ${obj.name},标记为可达`,
117
+ collected: [...collected],
118
+ promoted: [...promoted],
119
+ memoryStats: calculateMemoryStats(allObjects, 0)
120
+ });
121
+ for (const refId of obj.references) {
122
+ scanYoungObject(refId, objects, reachable, steps, stepNum, collected, promoted, allObjects);
123
+ }
124
+ }
125
+ function markSweepGC(objects, steps, stepNum, collected, promoted) {
126
+ const allObjects = Array.from(objects.values());
127
+ const oldObjects = allObjects.filter(o => o.generation === 'old');
128
+ steps.push({
129
+ stepNumber: stepNum.value++,
130
+ gcType: 'mark-sweep',
131
+ action: 'init',
132
+ objects: allObjects.map(o => ({ ...o })),
133
+ explanation: `启动老生代 GC (Mark-Sweep):检测到 ${oldObjects.length} 个老对象`,
134
+ collected: [...collected],
135
+ promoted: [...promoted],
136
+ memoryStats: calculateMemoryStats(allObjects, 0)
137
+ });
138
+ for (const obj of allObjects) {
139
+ if (obj.isRoot) {
140
+ markObject(obj.id, objects, steps, stepNum, collected, promoted, allObjects);
141
+ }
142
+ }
143
+ let freedMemory = 0;
144
+ for (const obj of oldObjects) {
145
+ if (!obj.marked) {
146
+ freedMemory += obj.size;
147
+ collected.push(obj.id);
148
+ objects.delete(obj.id);
149
+ const currentObjects = Array.from(objects.values());
150
+ steps.push({
151
+ stepNumber: stepNum.value++,
152
+ gcType: 'mark-sweep',
153
+ action: 'sweep',
154
+ currentObjectId: obj.id,
155
+ objects: currentObjects.map(o => ({ ...o })),
156
+ explanation: `清除未标记的老对象 ${obj.name} (${obj.size} KB)`,
157
+ collected: [...collected],
158
+ promoted: [...promoted],
159
+ memoryStats: calculateMemoryStats(currentObjects, freedMemory)
160
+ });
161
+ }
162
+ }
163
+ for (const obj of objects.values()) {
164
+ obj.marked = false;
165
+ }
166
+ }
167
+ function markObject(objId, objects, steps, stepNum, collected, promoted, allObjects) {
168
+ const obj = objects.get(objId);
169
+ if (!obj || obj.marked)
170
+ return;
171
+ obj.marked = true;
172
+ steps.push({
173
+ stepNumber: stepNum.value++,
174
+ gcType: 'mark-sweep',
175
+ action: 'mark',
176
+ currentObjectId: objId,
177
+ objects: allObjects.map(o => ({ ...o })),
178
+ explanation: `标记 ${obj.generation === 'old' ? '老' : '年轻'}对象 ${obj.name} 为可达`,
179
+ collected: [...collected],
180
+ promoted: [...promoted],
181
+ memoryStats: calculateMemoryStats(allObjects, 0)
182
+ });
183
+ for (const refId of obj.references) {
184
+ markObject(refId, objects, steps, stepNum, collected, promoted, allObjects);
185
+ }
186
+ }
187
+ function calculateMemoryStats(objects, freed) {
188
+ const youngObjs = objects.filter(o => o.generation === 'young');
189
+ const oldObjs = objects.filter(o => o.generation === 'old');
190
+ return {
191
+ youngTotal: 1024,
192
+ youngUsed: youngObjs.reduce((sum, o) => sum + o.size, 0),
193
+ oldTotal: 4096,
194
+ oldUsed: oldObjs.reduce((sum, o) => sum + o.size, 0),
195
+ freed
196
+ };
197
+ }
198
+ export function visualizeGarbageCollection(initialObjects, gcType = 'scavenge') {
199
+ const steps = [];
200
+ const stepNum = { value: 0 };
201
+ const collected = [];
202
+ const promoted = [];
203
+ const objects = new Map();
204
+ initialObjects.forEach(obj => {
205
+ objects.set(obj.id, {
206
+ ...obj,
207
+ space: obj.generation === 'young' ? 'from' : undefined,
208
+ marked: false
209
+ });
210
+ });
211
+ const allObjects = Array.from(objects.values());
212
+ steps.push({
213
+ stepNumber: stepNum.value++,
214
+ gcType,
215
+ action: 'init',
216
+ objects: allObjects.map(o => ({ ...o })),
217
+ explanation: `初始化 ${gcType === 'scavenge' ? '新生代' : '完整'} GC:${allObjects.filter(o => o.generation === 'young').length} 个年轻对象,${allObjects.filter(o => o.generation === 'old').length} 个老对象`,
218
+ collected: [],
219
+ promoted: [],
220
+ memoryStats: calculateMemoryStats(allObjects, 0)
221
+ });
222
+ if (gcType === 'scavenge') {
223
+ scavengeGC(objects, steps, stepNum, collected, promoted);
224
+ }
225
+ else {
226
+ scavengeGC(objects, steps, stepNum, collected, promoted);
227
+ const afterScavenge = Array.from(objects.values());
228
+ steps.push({
229
+ stepNumber: stepNum.value++,
230
+ gcType: 'mark-sweep',
231
+ action: 'init',
232
+ objects: afterScavenge.map(o => ({ ...o })),
233
+ explanation: `新生代 GC 完成,开始老生代 GC`,
234
+ collected: [...collected],
235
+ promoted: [...promoted],
236
+ memoryStats: calculateMemoryStats(afterScavenge, 0)
237
+ });
238
+ markSweepGC(objects, steps, stepNum, collected, promoted);
239
+ }
240
+ const finalObjects = Array.from(objects.values());
241
+ const totalFreed = collected.reduce((sum, id) => {
242
+ const obj = initialObjects.find(o => o.id === id);
243
+ return sum + (obj?.size || 0);
244
+ }, 0);
245
+ steps.push({
246
+ stepNumber: stepNum.value++,
247
+ gcType,
248
+ action: 'complete',
249
+ objects: finalObjects.map(o => ({ ...o })),
250
+ explanation: `GC 完成:回收 ${collected.length} 个对象,晋升 ${promoted.length} 个对象,释放 ${totalFreed} KB`,
251
+ collected: [...collected],
252
+ promoted: [...promoted],
253
+ memoryStats: calculateMemoryStats(finalObjects, totalFreed)
254
+ });
255
+ return {
256
+ steps,
257
+ survivors: Array.from(objects.keys()),
258
+ collected,
259
+ promoted,
260
+ freedMemory: totalFreed
261
+ };
262
+ }
263
+ //# sourceMappingURL=visualizeGarbageCollection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"visualizeGarbageCollection.js","sourceRoot":"","sources":["../../../src/functions/algorithm/visualizeGarbageCollection.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare function chunk<T>(array: T[], size: number): T[][];
@@ -0,0 +1,11 @@
1
+ export function chunk(array, size) {
2
+ if (size <= 0) {
3
+ throw new Error('Chunk size must be greater than 0');
4
+ }
5
+ const result = [];
6
+ for (let i = 0; i < array.length; i += size) {
7
+ result.push(array.slice(i, i + size));
8
+ }
9
+ return result;
10
+ }
11
+ //# sourceMappingURL=chunk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chunk.js","sourceRoot":"","sources":["../../../src/functions/array-object/chunk.ts"],"names":[],"mappings":"AAkBA,MAAM,UAAU,KAAK,CAAI,KAAU,EAAE,IAAY;IAC/C,IAAI,IAAI,IAAI,CAAC,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAA;IACtD,CAAC;IAED,MAAM,MAAM,GAAU,EAAE,CAAA;IAExB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC;QAC5C,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC,CAAA;IACvC,CAAC;IAED,OAAO,MAAM,CAAA;AACf,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare function evolve<T extends Record<string, any>>(transformations: {
2
+ [K in keyof T]?: T[K] extends (infer U)[] ? (value: T[K]) => U[] : T[K] extends Record<string, any> ? (value: T[K]) => any : (value: T[K]) => any;
3
+ }): (obj: T) => any;
@@ -0,0 +1,15 @@
1
+ export function evolve(transformations) {
2
+ return (obj) => {
3
+ if (!obj || typeof obj !== 'object')
4
+ return obj;
5
+ const result = { ...obj };
6
+ for (const key in transformations) {
7
+ if (obj.hasOwnProperty(key) && transformations[key]) {
8
+ const transform = transformations[key];
9
+ result[key] = transform(obj[key]);
10
+ }
11
+ }
12
+ return result;
13
+ };
14
+ }
15
+ //# sourceMappingURL=evolve.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"evolve.js","sourceRoot":"","sources":["../../../src/functions/array-object/evolve.ts"],"names":[],"mappings":"AAaA,MAAM,UAAU,MAAM,CACpB,eAMC;IAED,OAAO,CAAC,GAAM,EAAO,EAAE;QACrB,IAAI,CAAC,GAAG,IAAI,OAAO,GAAG,KAAK,QAAQ;YAAE,OAAO,GAAG,CAAA;QAE/C,MAAM,MAAM,GAAQ,EAAE,GAAG,GAAG,EAAE,CAAA;QAE9B,KAAK,MAAM,GAAG,IAAI,eAAe,EAAE,CAAC;YAClC,IAAI,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC;gBACpD,MAAM,SAAS,GAAG,eAAe,CAAC,GAAG,CAAa,CAAA;gBAClD,MAAM,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAA;YACnC,CAAC;QACH,CAAC;QAED,OAAO,MAAM,CAAA;IACf,CAAC,CAAA;AACH,CAAC"}
@@ -0,0 +1,5 @@
1
+ export declare function flattenObject(obj: Record<string, any>, prefix?: string): Record<string, any>;
2
+ export declare function flattenObjectWithArray(obj: Record<string, any>, prefix?: string): Record<string, any>;
3
+ export declare function unflattenObject(obj: Record<string, any>): Record<string, any>;
4
+ export declare function flattenObjectKeepArray(obj: Record<string, any>, prefix?: string): Record<string, any>;
5
+ export declare function flattenObjectDeep(obj: any, prefix?: string): Record<string, any>;
@@ -0,0 +1,102 @@
1
+ export function flattenObject(obj, prefix = '') {
2
+ const result = {};
3
+ for (const key in obj) {
4
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
5
+ const newKey = prefix ? `${prefix}.${key}` : key;
6
+ const value = obj[key];
7
+ if (value !== null && typeof value === 'object' && !Array.isArray(value)) {
8
+ Object.assign(result, flattenObject(value, newKey));
9
+ }
10
+ else {
11
+ result[newKey] = value;
12
+ }
13
+ }
14
+ }
15
+ return result;
16
+ }
17
+ export function flattenObjectWithArray(obj, prefix = '') {
18
+ const result = {};
19
+ for (const key in obj) {
20
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
21
+ const newKey = prefix ? `${prefix}[${key}]` : key;
22
+ const value = obj[key];
23
+ if (value !== null && typeof value === 'object' && !Array.isArray(value)) {
24
+ Object.assign(result, flattenObjectWithArray(value, newKey));
25
+ }
26
+ else {
27
+ result[newKey] = value;
28
+ }
29
+ }
30
+ }
31
+ return result;
32
+ }
33
+ export function unflattenObject(obj) {
34
+ const result = {};
35
+ for (const key in obj) {
36
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
37
+ const keys = key.split('.');
38
+ let current = result;
39
+ for (let i = 0; i < keys.length - 1; i++) {
40
+ const k = keys[i];
41
+ if (!(k in current)) {
42
+ current[k] = {};
43
+ }
44
+ current = current[k];
45
+ }
46
+ current[keys[keys.length - 1]] = obj[key];
47
+ }
48
+ }
49
+ return result;
50
+ }
51
+ export function flattenObjectKeepArray(obj, prefix = '') {
52
+ const result = {};
53
+ for (const key in obj) {
54
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
55
+ const newKey = prefix ? `${prefix}.${key}` : key;
56
+ const value = obj[key];
57
+ if (Array.isArray(value)) {
58
+ result[newKey] = value;
59
+ }
60
+ else if (value !== null && typeof value === 'object') {
61
+ Object.assign(result, flattenObjectKeepArray(value, newKey));
62
+ }
63
+ else {
64
+ result[newKey] = value;
65
+ }
66
+ }
67
+ }
68
+ return result;
69
+ }
70
+ export function flattenObjectDeep(obj, prefix = '') {
71
+ const result = {};
72
+ if (Array.isArray(obj)) {
73
+ obj.forEach((item, index) => {
74
+ const newKey = prefix ? `${prefix}.${index}` : String(index);
75
+ if (item !== null && typeof item === 'object') {
76
+ Object.assign(result, flattenObjectDeep(item, newKey));
77
+ }
78
+ else {
79
+ result[newKey] = item;
80
+ }
81
+ });
82
+ }
83
+ else if (obj !== null && typeof obj === 'object') {
84
+ for (const key in obj) {
85
+ if (Object.prototype.hasOwnProperty.call(obj, key)) {
86
+ const newKey = prefix ? `${prefix}.${key}` : key;
87
+ const value = obj[key];
88
+ if (value !== null && typeof value === 'object') {
89
+ Object.assign(result, flattenObjectDeep(value, newKey));
90
+ }
91
+ else {
92
+ result[newKey] = value;
93
+ }
94
+ }
95
+ }
96
+ }
97
+ else {
98
+ result[prefix] = obj;
99
+ }
100
+ return result;
101
+ }
102
+ //# sourceMappingURL=flattenObject.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"flattenObject.js","sourceRoot":"","sources":["../../../src/functions/array-object/flattenObject.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare function groupBy<T>(array: T[], keyOrFn: keyof T | ((item: T) => string | number)): Record<string, T[]>;
@@ -0,0 +1,14 @@
1
+ export function groupBy(array, keyOrFn) {
2
+ const result = {};
3
+ for (const item of array) {
4
+ const key = typeof keyOrFn === 'function'
5
+ ? String(keyOrFn(item))
6
+ : String(item[keyOrFn]);
7
+ if (!result[key]) {
8
+ result[key] = [];
9
+ }
10
+ result[key].push(item);
11
+ }
12
+ return result;
13
+ }
14
+ //# sourceMappingURL=groupBy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"groupBy.js","sourceRoot":"","sources":["../../../src/functions/array-object/groupBy.ts"],"names":[],"mappings":"AAwBA,MAAM,UAAU,OAAO,CACrB,KAAU,EACV,OAAiD;IAEjD,MAAM,MAAM,GAAwB,EAAE,CAAA;IAEtC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;QACzB,MAAM,GAAG,GAAG,OAAO,OAAO,KAAK,UAAU;YACvC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACvB,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAA;QAEzB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC;YACjB,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAA;QAClB,CAAC;QAED,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACxB,CAAC;IAED,OAAO,MAAM,CAAA;AACf,CAAC"}
@@ -0,0 +1 @@
1
+ export declare function omit<T extends object, K extends keyof T>(obj: T, keys: K[]): Omit<T, K>;