data-structure-typed 2.4.0 → 2.4.2

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 (750) hide show
  1. package/CHANGELOG.md +1 -1
  2. package/README.md +2 -3
  3. package/README_CN.md +0 -1
  4. package/dist/cjs/index.cjs +85 -30
  5. package/dist/cjs-legacy/index.cjs +85 -30
  6. package/dist/esm/index.mjs +85 -30
  7. package/dist/esm-legacy/index.mjs +85 -30
  8. package/dist/types/data-structures/binary-tree/tree-map.d.ts +17 -6
  9. package/dist/types/data-structures/binary-tree/tree-multi-map.d.ts +13 -5
  10. package/dist/types/data-structures/binary-tree/tree-multi-set.d.ts +12 -5
  11. package/dist/types/data-structures/binary-tree/tree-set.d.ts +15 -4
  12. package/dist/types/types/data-structures/binary-tree/tree-map.d.ts +6 -1
  13. package/dist/types/types/data-structures/binary-tree/tree-multi-set.d.ts +6 -1
  14. package/dist/types/types/data-structures/binary-tree/tree-set.d.ts +6 -1
  15. package/dist/umd/data-structure-typed.js +85 -29
  16. package/dist/umd/data-structure-typed.min.js +4 -4
  17. package/package.json +11 -5
  18. package/src/data-structures/binary-tree/tree-map.ts +35 -13
  19. package/src/data-structures/binary-tree/tree-multi-map.ts +41 -20
  20. package/src/data-structures/binary-tree/tree-multi-set.ts +17 -6
  21. package/src/data-structures/binary-tree/tree-set.ts +19 -6
  22. package/src/data-structures/trie/trie.ts +6 -8
  23. package/src/types/data-structures/binary-tree/tree-map.ts +7 -1
  24. package/src/types/data-structures/binary-tree/tree-multi-set.ts +7 -1
  25. package/src/types/data-structures/binary-tree/tree-set.ts +7 -1
  26. package/CMakeLists.txt +0 -52
  27. package/benchmark/report.html +0 -143
  28. package/benchmark/report.json +0 -1972
  29. package/build/CMakeCache.txt +0 -603
  30. package/build/CMakeFiles/4.0.3/CMakeCXXCompiler.cmake +0 -104
  31. package/build/CMakeFiles/4.0.3/CMakeDetermineCompilerABI_CXX.bin +0 -0
  32. package/build/CMakeFiles/4.0.3/CMakeSystem.cmake +0 -15
  33. package/build/CMakeFiles/4.0.3/CompilerIdCXX/CMakeCXXCompilerId.cpp +0 -920
  34. package/build/CMakeFiles/4.0.3/CompilerIdCXX/a.out +0 -0
  35. package/build/CMakeFiles/4.0.3/CompilerIdCXX/apple-sdk.cpp +0 -1
  36. package/build/CMakeFiles/CMakeConfigureLog.yaml +0 -2146
  37. package/build/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  38. package/build/CMakeFiles/InstallScripts.json +0 -9
  39. package/build/CMakeFiles/Makefile.cmake +0 -100
  40. package/build/CMakeFiles/Makefile2 +0 -720
  41. package/build/CMakeFiles/TargetDirectories.txt +0 -23
  42. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/DependInfo.cmake +0 -23
  43. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/build.make +0 -114
  44. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/cmake_clean.cmake +0 -11
  45. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/compiler_depend.internal +0 -839
  46. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/compiler_depend.make +0 -2506
  47. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/compiler_depend.ts +0 -2
  48. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/depend.make +0 -2
  49. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/flags.make +0 -10
  50. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/link.txt +0 -1
  51. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/progress.make +0 -3
  52. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/test/performance/data-structures/binary-tree/avl-rb-range-search.test.cpp.o +0 -0
  53. package/build/CMakeFiles/avl-rb-range-search-benchmark.dir/test/performance/data-structures/binary-tree/avl-rb-range-search.test.cpp.o.d +0 -835
  54. package/build/CMakeFiles/avl-tree-benchmark.dir/DependInfo.cmake +0 -23
  55. package/build/CMakeFiles/avl-tree-benchmark.dir/build.make +0 -114
  56. package/build/CMakeFiles/avl-tree-benchmark.dir/cmake_clean.cmake +0 -11
  57. package/build/CMakeFiles/avl-tree-benchmark.dir/compiler_depend.internal +0 -839
  58. package/build/CMakeFiles/avl-tree-benchmark.dir/compiler_depend.make +0 -2506
  59. package/build/CMakeFiles/avl-tree-benchmark.dir/compiler_depend.ts +0 -2
  60. package/build/CMakeFiles/avl-tree-benchmark.dir/depend.make +0 -2
  61. package/build/CMakeFiles/avl-tree-benchmark.dir/flags.make +0 -10
  62. package/build/CMakeFiles/avl-tree-benchmark.dir/link.txt +0 -1
  63. package/build/CMakeFiles/avl-tree-benchmark.dir/progress.make +0 -3
  64. package/build/CMakeFiles/avl-tree-benchmark.dir/test/performance/data-structures/binary-tree/avl-tree.test.cpp.o +0 -0
  65. package/build/CMakeFiles/avl-tree-benchmark.dir/test/performance/data-structures/binary-tree/avl-tree.test.cpp.o.d +0 -835
  66. package/build/CMakeFiles/cmake.check_cache +0 -1
  67. package/build/CMakeFiles/deque-benchmark.dir/DependInfo.cmake +0 -23
  68. package/build/CMakeFiles/deque-benchmark.dir/build.make +0 -114
  69. package/build/CMakeFiles/deque-benchmark.dir/cmake_clean.cmake +0 -11
  70. package/build/CMakeFiles/deque-benchmark.dir/compiler_depend.internal +0 -791
  71. package/build/CMakeFiles/deque-benchmark.dir/compiler_depend.make +0 -2362
  72. package/build/CMakeFiles/deque-benchmark.dir/compiler_depend.ts +0 -2
  73. package/build/CMakeFiles/deque-benchmark.dir/depend.make +0 -2
  74. package/build/CMakeFiles/deque-benchmark.dir/flags.make +0 -10
  75. package/build/CMakeFiles/deque-benchmark.dir/link.txt +0 -1
  76. package/build/CMakeFiles/deque-benchmark.dir/progress.make +0 -3
  77. package/build/CMakeFiles/deque-benchmark.dir/test/performance/data-structures/queue/deque.test.cpp.o +0 -0
  78. package/build/CMakeFiles/deque-benchmark.dir/test/performance/data-structures/queue/deque.test.cpp.o.d +0 -787
  79. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/DependInfo.cmake +0 -23
  80. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/build.make +0 -114
  81. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/cmake_clean.cmake +0 -11
  82. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/compiler_depend.internal +0 -790
  83. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/compiler_depend.make +0 -2359
  84. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/compiler_depend.ts +0 -2
  85. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/depend.make +0 -2
  86. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/flags.make +0 -10
  87. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/link.txt +0 -1
  88. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/progress.make +0 -3
  89. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/doubly-linked-list.test.cpp.o +0 -0
  90. package/build/CMakeFiles/doubly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/doubly-linked-list.test.cpp.o.d +0 -786
  91. package/build/CMakeFiles/hash-map-benchmark.dir/DependInfo.cmake +0 -23
  92. package/build/CMakeFiles/hash-map-benchmark.dir/build.make +0 -114
  93. package/build/CMakeFiles/hash-map-benchmark.dir/cmake_clean.cmake +0 -11
  94. package/build/CMakeFiles/hash-map-benchmark.dir/compiler_depend.internal +0 -790
  95. package/build/CMakeFiles/hash-map-benchmark.dir/compiler_depend.make +0 -2359
  96. package/build/CMakeFiles/hash-map-benchmark.dir/compiler_depend.ts +0 -2
  97. package/build/CMakeFiles/hash-map-benchmark.dir/depend.make +0 -2
  98. package/build/CMakeFiles/hash-map-benchmark.dir/flags.make +0 -10
  99. package/build/CMakeFiles/hash-map-benchmark.dir/link.txt +0 -1
  100. package/build/CMakeFiles/hash-map-benchmark.dir/progress.make +0 -3
  101. package/build/CMakeFiles/hash-map-benchmark.dir/test/performance/data-structures/hash/hash-map.test.cpp.o +0 -0
  102. package/build/CMakeFiles/hash-map-benchmark.dir/test/performance/data-structures/hash/hash-map.test.cpp.o.d +0 -786
  103. package/build/CMakeFiles/heap-benchmark.dir/DependInfo.cmake +0 -23
  104. package/build/CMakeFiles/heap-benchmark.dir/build.make +0 -114
  105. package/build/CMakeFiles/heap-benchmark.dir/cmake_clean.cmake +0 -11
  106. package/build/CMakeFiles/heap-benchmark.dir/compiler_depend.internal +0 -843
  107. package/build/CMakeFiles/heap-benchmark.dir/compiler_depend.make +0 -2518
  108. package/build/CMakeFiles/heap-benchmark.dir/compiler_depend.ts +0 -2
  109. package/build/CMakeFiles/heap-benchmark.dir/depend.make +0 -2
  110. package/build/CMakeFiles/heap-benchmark.dir/flags.make +0 -10
  111. package/build/CMakeFiles/heap-benchmark.dir/link.txt +0 -1
  112. package/build/CMakeFiles/heap-benchmark.dir/progress.make +0 -3
  113. package/build/CMakeFiles/heap-benchmark.dir/test/performance/data-structures/heap/heap.test.cpp.o +0 -0
  114. package/build/CMakeFiles/heap-benchmark.dir/test/performance/data-structures/heap/heap.test.cpp.o.d +0 -839
  115. package/build/CMakeFiles/priority-queue-benchmark.dir/DependInfo.cmake +0 -23
  116. package/build/CMakeFiles/priority-queue-benchmark.dir/build.make +0 -114
  117. package/build/CMakeFiles/priority-queue-benchmark.dir/cmake_clean.cmake +0 -11
  118. package/build/CMakeFiles/priority-queue-benchmark.dir/compiler_depend.internal +0 -793
  119. package/build/CMakeFiles/priority-queue-benchmark.dir/compiler_depend.make +0 -2368
  120. package/build/CMakeFiles/priority-queue-benchmark.dir/compiler_depend.ts +0 -2
  121. package/build/CMakeFiles/priority-queue-benchmark.dir/depend.make +0 -2
  122. package/build/CMakeFiles/priority-queue-benchmark.dir/flags.make +0 -10
  123. package/build/CMakeFiles/priority-queue-benchmark.dir/link.txt +0 -1
  124. package/build/CMakeFiles/priority-queue-benchmark.dir/progress.make +0 -3
  125. package/build/CMakeFiles/priority-queue-benchmark.dir/test/performance/data-structures/priority-queue/priority-queue.test.cpp.o +0 -0
  126. package/build/CMakeFiles/priority-queue-benchmark.dir/test/performance/data-structures/priority-queue/priority-queue.test.cpp.o.d +0 -789
  127. package/build/CMakeFiles/progress.marks +0 -1
  128. package/build/CMakeFiles/queue-benchmark.dir/DependInfo.cmake +0 -23
  129. package/build/CMakeFiles/queue-benchmark.dir/build.make +0 -114
  130. package/build/CMakeFiles/queue-benchmark.dir/cmake_clean.cmake +0 -11
  131. package/build/CMakeFiles/queue-benchmark.dir/compiler_depend.internal +0 -793
  132. package/build/CMakeFiles/queue-benchmark.dir/compiler_depend.make +0 -2368
  133. package/build/CMakeFiles/queue-benchmark.dir/compiler_depend.ts +0 -2
  134. package/build/CMakeFiles/queue-benchmark.dir/depend.make +0 -2
  135. package/build/CMakeFiles/queue-benchmark.dir/flags.make +0 -10
  136. package/build/CMakeFiles/queue-benchmark.dir/link.txt +0 -1
  137. package/build/CMakeFiles/queue-benchmark.dir/progress.make +0 -3
  138. package/build/CMakeFiles/queue-benchmark.dir/test/performance/data-structures/queue/queue.test.cpp.o +0 -0
  139. package/build/CMakeFiles/queue-benchmark.dir/test/performance/data-structures/queue/queue.test.cpp.o.d +0 -789
  140. package/build/CMakeFiles/red-black-tree-benchmark.dir/DependInfo.cmake +0 -23
  141. package/build/CMakeFiles/red-black-tree-benchmark.dir/build.make +0 -114
  142. package/build/CMakeFiles/red-black-tree-benchmark.dir/cmake_clean.cmake +0 -11
  143. package/build/CMakeFiles/red-black-tree-benchmark.dir/compiler_depend.internal +0 -839
  144. package/build/CMakeFiles/red-black-tree-benchmark.dir/compiler_depend.make +0 -2506
  145. package/build/CMakeFiles/red-black-tree-benchmark.dir/compiler_depend.ts +0 -2
  146. package/build/CMakeFiles/red-black-tree-benchmark.dir/depend.make +0 -2
  147. package/build/CMakeFiles/red-black-tree-benchmark.dir/flags.make +0 -10
  148. package/build/CMakeFiles/red-black-tree-benchmark.dir/link.txt +0 -1
  149. package/build/CMakeFiles/red-black-tree-benchmark.dir/progress.make +0 -3
  150. package/build/CMakeFiles/red-black-tree-benchmark.dir/test/performance/data-structures/binary-tree/red-black-tree.test.cpp.o +0 -0
  151. package/build/CMakeFiles/red-black-tree-benchmark.dir/test/performance/data-structures/binary-tree/red-black-tree.test.cpp.o.d +0 -835
  152. package/build/CMakeFiles/singly-linked-list-benchmark.dir/DependInfo.cmake +0 -23
  153. package/build/CMakeFiles/singly-linked-list-benchmark.dir/build.make +0 -114
  154. package/build/CMakeFiles/singly-linked-list-benchmark.dir/cmake_clean.cmake +0 -11
  155. package/build/CMakeFiles/singly-linked-list-benchmark.dir/compiler_depend.internal +0 -790
  156. package/build/CMakeFiles/singly-linked-list-benchmark.dir/compiler_depend.make +0 -2359
  157. package/build/CMakeFiles/singly-linked-list-benchmark.dir/compiler_depend.ts +0 -2
  158. package/build/CMakeFiles/singly-linked-list-benchmark.dir/depend.make +0 -2
  159. package/build/CMakeFiles/singly-linked-list-benchmark.dir/flags.make +0 -10
  160. package/build/CMakeFiles/singly-linked-list-benchmark.dir/link.txt +0 -1
  161. package/build/CMakeFiles/singly-linked-list-benchmark.dir/progress.make +0 -3
  162. package/build/CMakeFiles/singly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/singly-linked-list.test.cpp.o +0 -0
  163. package/build/CMakeFiles/singly-linked-list-benchmark.dir/test/performance/data-structures/linked-list/singly-linked-list.test.cpp.o.d +0 -786
  164. package/build/CMakeFiles/stack-benchmark.dir/DependInfo.cmake +0 -23
  165. package/build/CMakeFiles/stack-benchmark.dir/build.make +0 -114
  166. package/build/CMakeFiles/stack-benchmark.dir/cmake_clean.cmake +0 -11
  167. package/build/CMakeFiles/stack-benchmark.dir/compiler_depend.internal +0 -793
  168. package/build/CMakeFiles/stack-benchmark.dir/compiler_depend.make +0 -2368
  169. package/build/CMakeFiles/stack-benchmark.dir/compiler_depend.ts +0 -2
  170. package/build/CMakeFiles/stack-benchmark.dir/depend.make +0 -2
  171. package/build/CMakeFiles/stack-benchmark.dir/flags.make +0 -10
  172. package/build/CMakeFiles/stack-benchmark.dir/link.txt +0 -1
  173. package/build/CMakeFiles/stack-benchmark.dir/progress.make +0 -3
  174. package/build/CMakeFiles/stack-benchmark.dir/test/performance/data-structures/stack/stack.test.cpp.o +0 -0
  175. package/build/CMakeFiles/stack-benchmark.dir/test/performance/data-structures/stack/stack.test.cpp.o.d +0 -789
  176. package/build/CMakeFiles/tree-map-benchmark.dir/DependInfo.cmake +0 -23
  177. package/build/CMakeFiles/tree-map-benchmark.dir/build.make +0 -114
  178. package/build/CMakeFiles/tree-map-benchmark.dir/cmake_clean.cmake +0 -11
  179. package/build/CMakeFiles/tree-map-benchmark.dir/compiler_depend.internal +0 -839
  180. package/build/CMakeFiles/tree-map-benchmark.dir/compiler_depend.make +0 -2506
  181. package/build/CMakeFiles/tree-map-benchmark.dir/compiler_depend.ts +0 -2
  182. package/build/CMakeFiles/tree-map-benchmark.dir/depend.make +0 -2
  183. package/build/CMakeFiles/tree-map-benchmark.dir/flags.make +0 -10
  184. package/build/CMakeFiles/tree-map-benchmark.dir/link.txt +0 -1
  185. package/build/CMakeFiles/tree-map-benchmark.dir/progress.make +0 -3
  186. package/build/CMakeFiles/tree-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-map.test.cpp.o +0 -0
  187. package/build/CMakeFiles/tree-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-map.test.cpp.o.d +0 -835
  188. package/build/CMakeFiles/tree-multi-map-benchmark.dir/DependInfo.cmake +0 -23
  189. package/build/CMakeFiles/tree-multi-map-benchmark.dir/build.make +0 -114
  190. package/build/CMakeFiles/tree-multi-map-benchmark.dir/cmake_clean.cmake +0 -11
  191. package/build/CMakeFiles/tree-multi-map-benchmark.dir/compiler_depend.internal +0 -839
  192. package/build/CMakeFiles/tree-multi-map-benchmark.dir/compiler_depend.make +0 -2506
  193. package/build/CMakeFiles/tree-multi-map-benchmark.dir/compiler_depend.ts +0 -2
  194. package/build/CMakeFiles/tree-multi-map-benchmark.dir/depend.make +0 -2
  195. package/build/CMakeFiles/tree-multi-map-benchmark.dir/flags.make +0 -10
  196. package/build/CMakeFiles/tree-multi-map-benchmark.dir/link.txt +0 -1
  197. package/build/CMakeFiles/tree-multi-map-benchmark.dir/progress.make +0 -3
  198. package/build/CMakeFiles/tree-multi-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-map.test.cpp.o +0 -0
  199. package/build/CMakeFiles/tree-multi-map-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-map.test.cpp.o.d +0 -835
  200. package/build/CMakeFiles/tree-multi-set-benchmark.dir/DependInfo.cmake +0 -23
  201. package/build/CMakeFiles/tree-multi-set-benchmark.dir/build.make +0 -114
  202. package/build/CMakeFiles/tree-multi-set-benchmark.dir/cmake_clean.cmake +0 -11
  203. package/build/CMakeFiles/tree-multi-set-benchmark.dir/compiler_depend.internal +0 -839
  204. package/build/CMakeFiles/tree-multi-set-benchmark.dir/compiler_depend.make +0 -2506
  205. package/build/CMakeFiles/tree-multi-set-benchmark.dir/compiler_depend.ts +0 -2
  206. package/build/CMakeFiles/tree-multi-set-benchmark.dir/depend.make +0 -2
  207. package/build/CMakeFiles/tree-multi-set-benchmark.dir/flags.make +0 -10
  208. package/build/CMakeFiles/tree-multi-set-benchmark.dir/link.txt +0 -1
  209. package/build/CMakeFiles/tree-multi-set-benchmark.dir/progress.make +0 -3
  210. package/build/CMakeFiles/tree-multi-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-set.test.cpp.o +0 -0
  211. package/build/CMakeFiles/tree-multi-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-multi-set.test.cpp.o.d +0 -835
  212. package/build/CMakeFiles/tree-set-benchmark.dir/DependInfo.cmake +0 -23
  213. package/build/CMakeFiles/tree-set-benchmark.dir/build.make +0 -114
  214. package/build/CMakeFiles/tree-set-benchmark.dir/cmake_clean.cmake +0 -11
  215. package/build/CMakeFiles/tree-set-benchmark.dir/compiler_depend.internal +0 -839
  216. package/build/CMakeFiles/tree-set-benchmark.dir/compiler_depend.make +0 -2506
  217. package/build/CMakeFiles/tree-set-benchmark.dir/compiler_depend.ts +0 -2
  218. package/build/CMakeFiles/tree-set-benchmark.dir/depend.make +0 -2
  219. package/build/CMakeFiles/tree-set-benchmark.dir/flags.make +0 -10
  220. package/build/CMakeFiles/tree-set-benchmark.dir/link.txt +0 -1
  221. package/build/CMakeFiles/tree-set-benchmark.dir/progress.make +0 -3
  222. package/build/CMakeFiles/tree-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-set.test.cpp.o +0 -0
  223. package/build/CMakeFiles/tree-set-benchmark.dir/test/performance/data-structures/binary-tree/tree-set.test.cpp.o.d +0 -835
  224. package/build/Makefile +0 -783
  225. package/build/_deps/benchmark-build/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  226. package/build/_deps/benchmark-build/CMakeFiles/progress.marks +0 -1
  227. package/build/_deps/benchmark-build/Makefile +0 -140
  228. package/build/_deps/benchmark-build/benchmark.pc +0 -12
  229. package/build/_deps/benchmark-build/benchmarkConfig.cmake +0 -14
  230. package/build/_deps/benchmark-build/benchmarkConfigVersion.cmake +0 -65
  231. package/build/_deps/benchmark-build/benchmarkTargets.cmake +0 -84
  232. package/build/_deps/benchmark-build/cmake_install.cmake +0 -50
  233. package/build/_deps/benchmark-build/src/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  234. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/DependInfo.cmake +0 -41
  235. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark.cc.o +0 -0
  236. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark.cc.o.d +0 -875
  237. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_api_internal.cc.o +0 -0
  238. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_api_internal.cc.o.d +0 -802
  239. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_name.cc.o +0 -0
  240. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_name.cc.o.d +0 -772
  241. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_register.cc.o +0 -0
  242. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_register.cc.o.d +0 -841
  243. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_runner.cc.o +0 -0
  244. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/benchmark_runner.cc.o.d +0 -833
  245. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/build.make +0 -402
  246. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/check.cc.o +0 -0
  247. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/check.cc.o.d +0 -784
  248. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/cmake_clean.cmake +0 -47
  249. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/cmake_clean_target.cmake +0 -3
  250. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/colorprint.cc.o +0 -0
  251. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/colorprint.cc.o.d +0 -791
  252. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/commandlineflags.cc.o +0 -0
  253. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/commandlineflags.cc.o.d +0 -795
  254. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/compiler_depend.internal +0 -15519
  255. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/compiler_depend.make +0 -17500
  256. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/compiler_depend.ts +0 -2
  257. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/complexity.cc.o +0 -0
  258. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/complexity.cc.o.d +0 -793
  259. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/console_reporter.cc.o +0 -0
  260. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/console_reporter.cc.o.d +0 -802
  261. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/counter.cc.o +0 -0
  262. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/counter.cc.o.d +0 -773
  263. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/csv_reporter.cc.o +0 -0
  264. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/csv_reporter.cc.o.d +0 -799
  265. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/depend.make +0 -2
  266. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/flags.make +0 -10
  267. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/json_reporter.cc.o +0 -0
  268. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/json_reporter.cc.o.d +0 -800
  269. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/link.txt +0 -2
  270. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/perf_counters.cc.o +0 -0
  271. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/perf_counters.cc.o.d +0 -807
  272. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/progress.make +0 -21
  273. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/reporter.cc.o +0 -0
  274. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/reporter.cc.o.d +0 -798
  275. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/statistics.cc.o +0 -0
  276. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/statistics.cc.o.d +0 -800
  277. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/string_util.cc.o +0 -0
  278. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/string_util.cc.o.d +0 -795
  279. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/sysinfo.cc.o +0 -0
  280. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/sysinfo.cc.o.d +0 -933
  281. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/timers.cc.o +0 -0
  282. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark.dir/timers.cc.o.d +0 -904
  283. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/DependInfo.cmake +0 -23
  284. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/benchmark_main.cc.o +0 -0
  285. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/benchmark_main.cc.o.d +0 -772
  286. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/build.make +0 -114
  287. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/cmake_clean.cmake +0 -11
  288. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/cmake_clean_target.cmake +0 -3
  289. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/compiler_depend.internal +0 -776
  290. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/compiler_depend.make +0 -2317
  291. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/compiler_depend.ts +0 -2
  292. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/depend.make +0 -2
  293. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/flags.make +0 -10
  294. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/link.txt +0 -2
  295. package/build/_deps/benchmark-build/src/CMakeFiles/benchmark_main.dir/progress.make +0 -3
  296. package/build/_deps/benchmark-build/src/CMakeFiles/progress.marks +0 -1
  297. package/build/_deps/benchmark-build/src/Makefile +0 -710
  298. package/build/_deps/benchmark-build/src/cmake_install.cmake +0 -45
  299. package/build/_deps/benchmark-build/src/libbenchmark.a +0 -0
  300. package/build/_deps/benchmark-build/src/libbenchmark_main.a +0 -0
  301. package/build/_deps/benchmark-src/.clang-format +0 -5
  302. package/build/_deps/benchmark-src/.clang-tidy +0 -7
  303. package/build/_deps/benchmark-src/.github/ISSUE_TEMPLATE/bug_report.md +0 -32
  304. package/build/_deps/benchmark-src/.github/ISSUE_TEMPLATE/feature_request.md +0 -20
  305. package/build/_deps/benchmark-src/.github/install_bazel.sh +0 -13
  306. package/build/_deps/benchmark-src/.github/libcxx-setup.sh +0 -26
  307. package/build/_deps/benchmark-src/.github/workflows/bazel.yml +0 -35
  308. package/build/_deps/benchmark-src/.github/workflows/build-and-test-min-cmake.yml +0 -46
  309. package/build/_deps/benchmark-src/.github/workflows/build-and-test-perfcounters.yml +0 -51
  310. package/build/_deps/benchmark-src/.github/workflows/build-and-test.yml +0 -114
  311. package/build/_deps/benchmark-src/.github/workflows/clang-format-lint.yml +0 -17
  312. package/build/_deps/benchmark-src/.github/workflows/clang-tidy.yml +0 -38
  313. package/build/_deps/benchmark-src/.github/workflows/doxygen.yml +0 -28
  314. package/build/_deps/benchmark-src/.github/workflows/pylint.yml +0 -28
  315. package/build/_deps/benchmark-src/.github/workflows/sanitizer.yml +0 -96
  316. package/build/_deps/benchmark-src/.github/workflows/test_bindings.yml +0 -29
  317. package/build/_deps/benchmark-src/.github/workflows/wheels.yml +0 -79
  318. package/build/_deps/benchmark-src/.travis.yml +0 -208
  319. package/build/_deps/benchmark-src/.ycm_extra_conf.py +0 -115
  320. package/build/_deps/benchmark-src/AUTHORS +0 -71
  321. package/build/_deps/benchmark-src/BUILD.bazel +0 -87
  322. package/build/_deps/benchmark-src/CMakeLists.txt +0 -340
  323. package/build/_deps/benchmark-src/CONTRIBUTING.md +0 -58
  324. package/build/_deps/benchmark-src/CONTRIBUTORS +0 -95
  325. package/build/_deps/benchmark-src/LICENSE +0 -202
  326. package/build/_deps/benchmark-src/MODULE.bazel +0 -24
  327. package/build/_deps/benchmark-src/README.md +0 -223
  328. package/build/_deps/benchmark-src/WORKSPACE +0 -22
  329. package/build/_deps/benchmark-src/WORKSPACE.bzlmod +0 -2
  330. package/build/_deps/benchmark-src/_config.yml +0 -2
  331. package/build/_deps/benchmark-src/appveyor.yml +0 -50
  332. package/build/_deps/benchmark-src/bazel/benchmark_deps.bzl +0 -65
  333. package/build/_deps/benchmark-src/bindings/python/BUILD +0 -3
  334. package/build/_deps/benchmark-src/bindings/python/build_defs.bzl +0 -25
  335. package/build/_deps/benchmark-src/bindings/python/google_benchmark/BUILD +0 -40
  336. package/build/_deps/benchmark-src/bindings/python/google_benchmark/__init__.py +0 -162
  337. package/build/_deps/benchmark-src/bindings/python/google_benchmark/benchmark.cc +0 -184
  338. package/build/_deps/benchmark-src/bindings/python/google_benchmark/example.py +0 -136
  339. package/build/_deps/benchmark-src/bindings/python/nanobind.BUILD +0 -17
  340. package/build/_deps/benchmark-src/bindings/python/python_headers.BUILD +0 -6
  341. package/build/_deps/benchmark-src/cmake/AddCXXCompilerFlag.cmake +0 -78
  342. package/build/_deps/benchmark-src/cmake/CXXFeatureCheck.cmake +0 -82
  343. package/build/_deps/benchmark-src/cmake/Config.cmake.in +0 -7
  344. package/build/_deps/benchmark-src/cmake/GetGitVersion.cmake +0 -58
  345. package/build/_deps/benchmark-src/cmake/GoogleTest.cmake +0 -58
  346. package/build/_deps/benchmark-src/cmake/GoogleTest.cmake.in +0 -59
  347. package/build/_deps/benchmark-src/cmake/benchmark.pc.in +0 -12
  348. package/build/_deps/benchmark-src/cmake/gnu_posix_regex.cpp +0 -12
  349. package/build/_deps/benchmark-src/cmake/llvm-toolchain.cmake +0 -8
  350. package/build/_deps/benchmark-src/cmake/posix_regex.cpp +0 -14
  351. package/build/_deps/benchmark-src/cmake/pthread_affinity.cpp +0 -16
  352. package/build/_deps/benchmark-src/cmake/split_list.cmake +0 -3
  353. package/build/_deps/benchmark-src/cmake/std_regex.cpp +0 -10
  354. package/build/_deps/benchmark-src/cmake/steady_clock.cpp +0 -7
  355. package/build/_deps/benchmark-src/cmake/thread_safety_attributes.cpp +0 -4
  356. package/build/_deps/benchmark-src/docs/AssemblyTests.md +0 -149
  357. package/build/_deps/benchmark-src/docs/_config.yml +0 -3
  358. package/build/_deps/benchmark-src/docs/assets/images/icon.png +0 -0
  359. package/build/_deps/benchmark-src/docs/assets/images/icon.xcf +0 -0
  360. package/build/_deps/benchmark-src/docs/assets/images/icon_black.png +0 -0
  361. package/build/_deps/benchmark-src/docs/assets/images/icon_black.xcf +0 -0
  362. package/build/_deps/benchmark-src/docs/dependencies.md +0 -13
  363. package/build/_deps/benchmark-src/docs/index.md +0 -12
  364. package/build/_deps/benchmark-src/docs/perf_counters.md +0 -35
  365. package/build/_deps/benchmark-src/docs/platform_specific_build_instructions.md +0 -48
  366. package/build/_deps/benchmark-src/docs/python_bindings.md +0 -34
  367. package/build/_deps/benchmark-src/docs/random_interleaving.md +0 -13
  368. package/build/_deps/benchmark-src/docs/reducing_variance.md +0 -100
  369. package/build/_deps/benchmark-src/docs/releasing.md +0 -41
  370. package/build/_deps/benchmark-src/docs/tools.md +0 -343
  371. package/build/_deps/benchmark-src/docs/user_guide.md +0 -1266
  372. package/build/_deps/benchmark-src/include/benchmark/benchmark.h +0 -1991
  373. package/build/_deps/benchmark-src/include/benchmark/export.h +0 -47
  374. package/build/_deps/benchmark-src/pyproject.toml +0 -50
  375. package/build/_deps/benchmark-src/setup.py +0 -113
  376. package/build/_deps/benchmark-src/src/CMakeLists.txt +0 -170
  377. package/build/_deps/benchmark-src/src/arraysize.h +0 -33
  378. package/build/_deps/benchmark-src/src/benchmark.cc +0 -779
  379. package/build/_deps/benchmark-src/src/benchmark_api_internal.cc +0 -118
  380. package/build/_deps/benchmark-src/src/benchmark_api_internal.h +0 -87
  381. package/build/_deps/benchmark-src/src/benchmark_main.cc +0 -18
  382. package/build/_deps/benchmark-src/src/benchmark_name.cc +0 -59
  383. package/build/_deps/benchmark-src/src/benchmark_register.cc +0 -520
  384. package/build/_deps/benchmark-src/src/benchmark_register.h +0 -109
  385. package/build/_deps/benchmark-src/src/benchmark_runner.cc +0 -497
  386. package/build/_deps/benchmark-src/src/benchmark_runner.h +0 -131
  387. package/build/_deps/benchmark-src/src/check.cc +0 -11
  388. package/build/_deps/benchmark-src/src/check.h +0 -106
  389. package/build/_deps/benchmark-src/src/colorprint.cc +0 -200
  390. package/build/_deps/benchmark-src/src/colorprint.h +0 -33
  391. package/build/_deps/benchmark-src/src/commandlineflags.cc +0 -298
  392. package/build/_deps/benchmark-src/src/commandlineflags.h +0 -133
  393. package/build/_deps/benchmark-src/src/complexity.cc +0 -244
  394. package/build/_deps/benchmark-src/src/complexity.h +0 -55
  395. package/build/_deps/benchmark-src/src/console_reporter.cc +0 -206
  396. package/build/_deps/benchmark-src/src/counter.cc +0 -80
  397. package/build/_deps/benchmark-src/src/counter.h +0 -32
  398. package/build/_deps/benchmark-src/src/csv_reporter.cc +0 -161
  399. package/build/_deps/benchmark-src/src/cycleclock.h +0 -230
  400. package/build/_deps/benchmark-src/src/internal_macros.h +0 -115
  401. package/build/_deps/benchmark-src/src/json_reporter.cc +0 -320
  402. package/build/_deps/benchmark-src/src/log.h +0 -88
  403. package/build/_deps/benchmark-src/src/mutex.h +0 -155
  404. package/build/_deps/benchmark-src/src/perf_counters.cc +0 -282
  405. package/build/_deps/benchmark-src/src/perf_counters.h +0 -200
  406. package/build/_deps/benchmark-src/src/re.h +0 -158
  407. package/build/_deps/benchmark-src/src/reporter.cc +0 -118
  408. package/build/_deps/benchmark-src/src/statistics.cc +0 -209
  409. package/build/_deps/benchmark-src/src/statistics.h +0 -44
  410. package/build/_deps/benchmark-src/src/string_util.cc +0 -254
  411. package/build/_deps/benchmark-src/src/string_util.h +0 -70
  412. package/build/_deps/benchmark-src/src/sysinfo.cc +0 -855
  413. package/build/_deps/benchmark-src/src/thread_manager.h +0 -63
  414. package/build/_deps/benchmark-src/src/thread_timer.h +0 -86
  415. package/build/_deps/benchmark-src/src/timers.cc +0 -272
  416. package/build/_deps/benchmark-src/src/timers.h +0 -48
  417. package/build/_deps/benchmark-src/test/AssemblyTests.cmake +0 -67
  418. package/build/_deps/benchmark-src/test/BUILD +0 -127
  419. package/build/_deps/benchmark-src/test/CMakeLists.txt +0 -309
  420. package/build/_deps/benchmark-src/test/args_product_test.cc +0 -77
  421. package/build/_deps/benchmark-src/test/basic_test.cc +0 -180
  422. package/build/_deps/benchmark-src/test/benchmark_gtest.cc +0 -169
  423. package/build/_deps/benchmark-src/test/benchmark_min_time_flag_iters_test.cc +0 -66
  424. package/build/_deps/benchmark-src/test/benchmark_min_time_flag_time_test.cc +0 -90
  425. package/build/_deps/benchmark-src/test/benchmark_name_gtest.cc +0 -82
  426. package/build/_deps/benchmark-src/test/benchmark_random_interleaving_gtest.cc +0 -126
  427. package/build/_deps/benchmark-src/test/benchmark_setup_teardown_test.cc +0 -157
  428. package/build/_deps/benchmark-src/test/benchmark_test.cc +0 -274
  429. package/build/_deps/benchmark-src/test/clobber_memory_assembly_test.cc +0 -64
  430. package/build/_deps/benchmark-src/test/commandlineflags_gtest.cc +0 -228
  431. package/build/_deps/benchmark-src/test/complexity_test.cc +0 -228
  432. package/build/_deps/benchmark-src/test/cxx03_test.cc +0 -62
  433. package/build/_deps/benchmark-src/test/diagnostics_test.cc +0 -91
  434. package/build/_deps/benchmark-src/test/display_aggregates_only_test.cc +0 -45
  435. package/build/_deps/benchmark-src/test/donotoptimize_assembly_test.cc +0 -201
  436. package/build/_deps/benchmark-src/test/donotoptimize_test.cc +0 -69
  437. package/build/_deps/benchmark-src/test/filter_test.cc +0 -117
  438. package/build/_deps/benchmark-src/test/fixture_test.cc +0 -51
  439. package/build/_deps/benchmark-src/test/internal_threading_test.cc +0 -185
  440. package/build/_deps/benchmark-src/test/link_main_test.cc +0 -9
  441. package/build/_deps/benchmark-src/test/map_test.cc +0 -59
  442. package/build/_deps/benchmark-src/test/memory_manager_test.cc +0 -47
  443. package/build/_deps/benchmark-src/test/min_time_parse_gtest.cc +0 -30
  444. package/build/_deps/benchmark-src/test/multiple_ranges_test.cc +0 -96
  445. package/build/_deps/benchmark-src/test/options_test.cc +0 -77
  446. package/build/_deps/benchmark-src/test/output_test.h +0 -211
  447. package/build/_deps/benchmark-src/test/output_test_helper.cc +0 -519
  448. package/build/_deps/benchmark-src/test/perf_counters_gtest.cc +0 -307
  449. package/build/_deps/benchmark-src/test/perf_counters_test.cc +0 -92
  450. package/build/_deps/benchmark-src/test/register_benchmark_test.cc +0 -196
  451. package/build/_deps/benchmark-src/test/repetitions_test.cc +0 -214
  452. package/build/_deps/benchmark-src/test/report_aggregates_only_test.cc +0 -41
  453. package/build/_deps/benchmark-src/test/reporter_output_test.cc +0 -1130
  454. package/build/_deps/benchmark-src/test/skip_with_error_test.cc +0 -199
  455. package/build/_deps/benchmark-src/test/spec_arg_test.cc +0 -105
  456. package/build/_deps/benchmark-src/test/spec_arg_verbosity_test.cc +0 -43
  457. package/build/_deps/benchmark-src/test/state_assembly_test.cc +0 -68
  458. package/build/_deps/benchmark-src/test/statistics_gtest.cc +0 -35
  459. package/build/_deps/benchmark-src/test/string_util_gtest.cc +0 -199
  460. package/build/_deps/benchmark-src/test/templated_fixture_test.cc +0 -28
  461. package/build/_deps/benchmark-src/test/time_unit_gtest.cc +0 -37
  462. package/build/_deps/benchmark-src/test/user_counters_tabular_test.cc +0 -558
  463. package/build/_deps/benchmark-src/test/user_counters_test.cc +0 -561
  464. package/build/_deps/benchmark-src/test/user_counters_thousands_test.cc +0 -186
  465. package/build/_deps/benchmark-src/tools/BUILD.bazel +0 -19
  466. package/build/_deps/benchmark-src/tools/compare.py +0 -432
  467. package/build/_deps/benchmark-src/tools/gbench/Inputs/test1_run1.json +0 -127
  468. package/build/_deps/benchmark-src/tools/gbench/Inputs/test1_run2.json +0 -127
  469. package/build/_deps/benchmark-src/tools/gbench/Inputs/test2_run.json +0 -81
  470. package/build/_deps/benchmark-src/tools/gbench/Inputs/test3_run0.json +0 -65
  471. package/build/_deps/benchmark-src/tools/gbench/Inputs/test3_run1.json +0 -65
  472. package/build/_deps/benchmark-src/tools/gbench/Inputs/test4_run.json +0 -96
  473. package/build/_deps/benchmark-src/tools/gbench/Inputs/test4_run0.json +0 -21
  474. package/build/_deps/benchmark-src/tools/gbench/Inputs/test4_run1.json +0 -21
  475. package/build/_deps/benchmark-src/tools/gbench/__init__.py +0 -8
  476. package/build/_deps/benchmark-src/tools/gbench/report.py +0 -1201
  477. package/build/_deps/benchmark-src/tools/gbench/util.py +0 -203
  478. package/build/_deps/benchmark-src/tools/libpfm.BUILD.bazel +0 -22
  479. package/build/_deps/benchmark-src/tools/requirements.txt +0 -2
  480. package/build/_deps/benchmark-src/tools/strip_asm.py +0 -151
  481. package/build/_deps/benchmark-subbuild/CMakeCache.txt +0 -133
  482. package/build/_deps/benchmark-subbuild/CMakeFiles/4.0.3/CMakeSystem.cmake +0 -15
  483. package/build/_deps/benchmark-subbuild/CMakeFiles/CMakeConfigureLog.yaml +0 -11
  484. package/build/_deps/benchmark-subbuild/CMakeFiles/CMakeDirectoryInformation.cmake +0 -16
  485. package/build/_deps/benchmark-subbuild/CMakeFiles/CMakeRuleHashes.txt +0 -11
  486. package/build/_deps/benchmark-subbuild/CMakeFiles/InstallScripts.json +0 -7
  487. package/build/_deps/benchmark-subbuild/CMakeFiles/Makefile.cmake +0 -52
  488. package/build/_deps/benchmark-subbuild/CMakeFiles/Makefile2 +0 -122
  489. package/build/_deps/benchmark-subbuild/CMakeFiles/TargetDirectories.txt +0 -3
  490. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate-complete +0 -0
  491. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/DependInfo.cmake +0 -22
  492. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/Labels.json +0 -46
  493. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/Labels.txt +0 -14
  494. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/build.make +0 -162
  495. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/cmake_clean.cmake +0 -17
  496. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/compiler_depend.make +0 -2
  497. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/compiler_depend.ts +0 -2
  498. package/build/_deps/benchmark-subbuild/CMakeFiles/benchmark-populate.dir/progress.make +0 -10
  499. package/build/_deps/benchmark-subbuild/CMakeFiles/cmake.check_cache +0 -1
  500. package/build/_deps/benchmark-subbuild/CMakeFiles/progress.marks +0 -1
  501. package/build/_deps/benchmark-subbuild/CMakeLists.txt +0 -42
  502. package/build/_deps/benchmark-subbuild/Makefile +0 -162
  503. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-build +0 -0
  504. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-configure +0 -0
  505. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-done +0 -0
  506. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-download +0 -0
  507. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-gitclone-lastrun.txt +0 -15
  508. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-gitinfo.txt +0 -15
  509. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-install +0 -0
  510. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-mkdir +0 -0
  511. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-patch +0 -0
  512. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-patch-info.txt +0 -6
  513. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-test +0 -0
  514. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/src/benchmark-populate-stamp/benchmark-populate-update-info.txt +0 -7
  515. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-cfgcmd.txt +0 -1
  516. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-gitclone.cmake +0 -87
  517. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-gitupdate.cmake +0 -317
  518. package/build/_deps/benchmark-subbuild/benchmark-populate-prefix/tmp/benchmark-populate-mkdirs.cmake +0 -27
  519. package/build/_deps/benchmark-subbuild/cmake_install.cmake +0 -56
  520. package/build/bin/avl-rb-range-search-benchmark +0 -0
  521. package/build/bin/avl-tree-benchmark +0 -0
  522. package/build/bin/deque-benchmark +0 -0
  523. package/build/bin/doubly-linked-list-benchmark +0 -0
  524. package/build/bin/hash-map-benchmark +0 -0
  525. package/build/bin/heap-benchmark +0 -0
  526. package/build/bin/priority-queue-benchmark +0 -0
  527. package/build/bin/queue-benchmark +0 -0
  528. package/build/bin/red-black-tree-benchmark +0 -0
  529. package/build/bin/singly-linked-list-benchmark +0 -0
  530. package/build/bin/stack-benchmark +0 -0
  531. package/build/bin/tree-map-benchmark +0 -0
  532. package/build/bin/tree-multi-map-benchmark +0 -0
  533. package/build/bin/tree-multi-set-benchmark +0 -0
  534. package/build/bin/tree-set-benchmark +0 -0
  535. package/build/cmake_install.cmake +0 -66
  536. package/dist/cjs/index.cjs.map +0 -1
  537. package/dist/cjs-legacy/index.cjs.map +0 -1
  538. package/dist/esm/index.mjs.map +0 -1
  539. package/dist/esm-legacy/index.mjs.map +0 -1
  540. package/dist/umd/data-structure-typed.js.map +0 -1
  541. package/dist/umd/data-structure-typed.min.js.map +0 -1
  542. package/eslint.config.mjs +0 -73
  543. package/test/config.ts +0 -4
  544. package/test/integration/all-in-one.test.ts +0 -110
  545. package/test/integration/avl-tree.test.ts +0 -127
  546. package/test/integration/bst.test.ts +0 -385
  547. package/test/integration/compile.test.mjs +0 -159
  548. package/test/integration/compile.test.ts +0 -176
  549. package/test/integration/heap.test.js +0 -21
  550. package/test/integration/index.html +0 -462
  551. package/test/performance/benchmark-runner-enhanced.mjs +0 -818
  552. package/test/performance/cmake-benchmark-runner.mjs +0 -234
  553. package/test/performance/data-structures/binary-tree/avl-rb-range-search.test.cpp +0 -112
  554. package/test/performance/data-structures/binary-tree/avl-rb-range-search.test.mjs +0 -51
  555. package/test/performance/data-structures/binary-tree/avl-tree.test.cpp +0 -181
  556. package/test/performance/data-structures/binary-tree/avl-tree.test.mjs +0 -138
  557. package/test/performance/data-structures/binary-tree/binary-tree-overall.test.mjs +0 -85
  558. package/test/performance/data-structures/binary-tree/binary-tree.test.mjs +0 -100
  559. package/test/performance/data-structures/binary-tree/bst.test.mjs +0 -61
  560. package/test/performance/data-structures/binary-tree/red-black-tree-cjs.test.mjs +0 -259
  561. package/test/performance/data-structures/binary-tree/red-black-tree.test.cpp +0 -213
  562. package/test/performance/data-structures/binary-tree/red-black-tree.test.mjs +0 -275
  563. package/test/performance/data-structures/binary-tree/tree-map.test.cpp +0 -129
  564. package/test/performance/data-structures/binary-tree/tree-map.test.mjs +0 -171
  565. package/test/performance/data-structures/binary-tree/tree-multi-map.test.cpp +0 -205
  566. package/test/performance/data-structures/binary-tree/tree-multi-map.test.mjs +0 -106
  567. package/test/performance/data-structures/binary-tree/tree-multi-set.test.cpp +0 -217
  568. package/test/performance/data-structures/binary-tree/tree-multi-set.test.mjs +0 -91
  569. package/test/performance/data-structures/binary-tree/tree-set.test.cpp +0 -127
  570. package/test/performance/data-structures/binary-tree/tree-set.test.mjs +0 -174
  571. package/test/performance/data-structures/comparison/comparison.test.mjs +0 -99
  572. package/test/performance/data-structures/graph/directed-graph.test.mjs +0 -38
  573. package/test/performance/data-structures/hash/hash-map.test.cpp +0 -183
  574. package/test/performance/data-structures/hash/hash-map.test.mjs +0 -187
  575. package/test/performance/data-structures/heap/heap.test.cpp +0 -61
  576. package/test/performance/data-structures/heap/heap.test.mjs +0 -31
  577. package/test/performance/data-structures/linked-list/doubly-linked-list.test.cpp +0 -84
  578. package/test/performance/data-structures/linked-list/doubly-linked-list.test.mjs +0 -125
  579. package/test/performance/data-structures/linked-list/singly-linked-list.test.cpp +0 -77
  580. package/test/performance/data-structures/linked-list/singly-linked-list.test.mjs +0 -84
  581. package/test/performance/data-structures/priority-queue/max-priority-queue.test.mjs +0 -40
  582. package/test/performance/data-structures/priority-queue/priority-queue.test.cpp +0 -59
  583. package/test/performance/data-structures/priority-queue/priority-queue.test.mjs +0 -64
  584. package/test/performance/data-structures/queue/deque.test.cpp +0 -119
  585. package/test/performance/data-structures/queue/deque.test.mjs +0 -144
  586. package/test/performance/data-structures/queue/queue.test.cpp +0 -59
  587. package/test/performance/data-structures/queue/queue.test.mjs +0 -77
  588. package/test/performance/data-structures/stack/stack.test.cpp +0 -40
  589. package/test/performance/data-structures/stack/stack.test.mjs +0 -69
  590. package/test/performance/data-structures/trie/trie.test.mjs +0 -43
  591. package/test/performance/reportor-enhanced.mjs +0 -871
  592. package/test/performance/runner-config.json +0 -51
  593. package/test/types/index.ts +0 -1
  594. package/test/types/utils/big-o.ts +0 -1
  595. package/test/types/utils/index.ts +0 -2
  596. package/test/types/utils/json2html.ts +0 -5
  597. package/test/unit/data-structures/base/iterable-element-base.coverage.test.ts +0 -106
  598. package/test/unit/data-structures/base/iterable-element-base.more-branches.coverage.test.ts +0 -61
  599. package/test/unit/data-structures/base/linear-base.array.coverage.test.ts +0 -168
  600. package/test/unit/data-structures/base/linear-base.concat-else.coverage.test.ts +0 -82
  601. package/test/unit/data-structures/base/linear-base.coverage.test.ts +0 -72
  602. package/test/unit/data-structures/base/linear-base.more-branches.coverage.test.ts +0 -414
  603. package/test/unit/data-structures/binary-tree/avl-tree-node.familyPosition-root-left.coverage.test.ts +0 -17
  604. package/test/unit/data-structures/binary-tree/avl-tree.more-branches-2.coverage.test.ts +0 -99
  605. package/test/unit/data-structures/binary-tree/avl-tree.test.ts +0 -729
  606. package/test/unit/data-structures/binary-tree/binary-index-tree.test.ts +0 -345
  607. package/test/unit/data-structures/binary-tree/binary-indexed-tree.more-branches.coverage.test.ts +0 -18
  608. package/test/unit/data-structures/binary-tree/binary-tree.more-branches.coverage.test.ts +0 -56
  609. package/test/unit/data-structures/binary-tree/binary-tree.remaining-branches.coverage.test.ts +0 -232
  610. package/test/unit/data-structures/binary-tree/binary-tree.test.ts +0 -1912
  611. package/test/unit/data-structures/binary-tree/bst.bound-by-predicate.coverage.test.ts +0 -33
  612. package/test/unit/data-structures/binary-tree/bst.coverage.test.ts +0 -94
  613. package/test/unit/data-structures/binary-tree/bst.deletebykey.coverage.test.ts +0 -70
  614. package/test/unit/data-structures/binary-tree/bst.deletewhere.coverage.test.ts +0 -37
  615. package/test/unit/data-structures/binary-tree/bst.floor-lower-predicate.coverage.test.ts +0 -29
  616. package/test/unit/data-structures/binary-tree/bst.floor-setmany.coverage.test.ts +0 -72
  617. package/test/unit/data-structures/binary-tree/bst.getnode.range-ensure.coverage.test.ts +0 -22
  618. package/test/unit/data-structures/binary-tree/bst.misc-branches.coverage.test.ts +0 -100
  619. package/test/unit/data-structures/binary-tree/bst.more-branches-2.coverage.test.ts +0 -133
  620. package/test/unit/data-structures/binary-tree/bst.more-branches-3.coverage.test.ts +0 -45
  621. package/test/unit/data-structures/binary-tree/bst.more-branches-4.coverage.test.ts +0 -36
  622. package/test/unit/data-structures/binary-tree/bst.more-branches-5.coverage.test.ts +0 -40
  623. package/test/unit/data-structures/binary-tree/bst.more.coverage.test.ts +0 -39
  624. package/test/unit/data-structures/binary-tree/bst.node-family.coverage.test.ts +0 -29
  625. package/test/unit/data-structures/binary-tree/bst.range-pruning.coverage.test.ts +0 -43
  626. package/test/unit/data-structures/binary-tree/bst.search-fastpath.coverage.test.ts +0 -30
  627. package/test/unit/data-structures/binary-tree/bst.test.ts +0 -3472
  628. package/test/unit/data-structures/binary-tree/data/cost-of-living-by-country.ts +0 -259
  629. package/test/unit/data-structures/binary-tree/overall.test.ts +0 -219
  630. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-corruption-repair.coverage.test.ts +0 -66
  631. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-max-update.coverage.test.ts +0 -18
  632. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-null.coverage.test.ts +0 -53
  633. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-stale-cache.coverage.test.ts +0 -25
  634. package/test/unit/data-structures/binary-tree/red-black-tree.boundary-update.coverage.test.ts +0 -23
  635. package/test/unit/data-structures/binary-tree/red-black-tree.cache-delete.coverage.test.ts +0 -49
  636. package/test/unit/data-structures/binary-tree/red-black-tree.cache-edge.coverage.test.ts +0 -37
  637. package/test/unit/data-structures/binary-tree/red-black-tree.cache-stale-insert.coverage.test.ts +0 -39
  638. package/test/unit/data-structures/binary-tree/red-black-tree.coverage.test.ts +0 -334
  639. package/test/unit/data-structures/binary-tree/red-black-tree.delete-fixup.coverage.test.ts +0 -68
  640. package/test/unit/data-structures/binary-tree/red-black-tree.delete-successor.coverage.test.ts +0 -75
  641. package/test/unit/data-structures/binary-tree/red-black-tree.factories.coverage.test.ts +0 -26
  642. package/test/unit/data-structures/binary-tree/red-black-tree.hint-cache-compare-update.coverage.test.ts +0 -74
  643. package/test/unit/data-structures/binary-tree/red-black-tree.hint-cache-no-update.coverage.test.ts +0 -44
  644. package/test/unit/data-structures/binary-tree/red-black-tree.hint-cache-nullish.coverage.test.ts +0 -61
  645. package/test/unit/data-structures/binary-tree/red-black-tree.hint-mapmode-defined.coverage.test.ts +0 -35
  646. package/test/unit/data-structures/binary-tree/red-black-tree.hint-mapmode-undefined.coverage.test.ts +0 -43
  647. package/test/unit/data-structures/binary-tree/red-black-tree.hint-more.coverage.test.ts +0 -99
  648. package/test/unit/data-structures/binary-tree/red-black-tree.hint.coverage.test.ts +0 -60
  649. package/test/unit/data-structures/binary-tree/red-black-tree.insert-cache-nullish.coverage.test.ts +0 -29
  650. package/test/unit/data-structures/binary-tree/red-black-tree.insert-header-parent-nullish.coverage.test.ts +0 -17
  651. package/test/unit/data-structures/binary-tree/red-black-tree.internal-walk.coverage.test.ts +0 -57
  652. package/test/unit/data-structures/binary-tree/red-black-tree.minmax-cache.test.ts +0 -65
  653. package/test/unit/data-structures/binary-tree/red-black-tree.misc-inputs.coverage.test.ts +0 -17
  654. package/test/unit/data-structures/binary-tree/red-black-tree.more-branches-2.coverage.test.ts +0 -121
  655. package/test/unit/data-structures/binary-tree/red-black-tree.more-branches-3.coverage.test.ts +0 -55
  656. package/test/unit/data-structures/binary-tree/red-black-tree.more-branches-4.coverage.test.ts +0 -44
  657. package/test/unit/data-structures/binary-tree/red-black-tree.predsucc.coverage.test.ts +0 -40
  658. package/test/unit/data-structures/binary-tree/red-black-tree.remaining-branches.coverage.test.ts +0 -123
  659. package/test/unit/data-structures/binary-tree/red-black-tree.set-inputs.coverage.test.ts +0 -64
  660. package/test/unit/data-structures/binary-tree/red-black-tree.setkvnode-parent-cache.coverage.test.ts +0 -79
  661. package/test/unit/data-structures/binary-tree/red-black-tree.setkvnode-remaining.coverage.test.ts +0 -44
  662. package/test/unit/data-structures/binary-tree/red-black-tree.setkvnode-uncovered.coverage.test.ts +0 -74
  663. package/test/unit/data-structures/binary-tree/red-black-tree.test.ts +0 -936
  664. package/test/unit/data-structures/binary-tree/red-black-tree.update-branches.coverage.test.ts +0 -30
  665. package/test/unit/data-structures/binary-tree/segment-tree.more-branches.coverage.test.ts +0 -31
  666. package/test/unit/data-structures/binary-tree/segment-tree.test.ts +0 -104
  667. package/test/unit/data-structures/binary-tree/tree-map.test.ts +0 -270
  668. package/test/unit/data-structures/binary-tree/tree-multi-map.coverage.test.ts +0 -245
  669. package/test/unit/data-structures/binary-tree/tree-multi-map.legacy.test.ts.skip +0 -1115
  670. package/test/unit/data-structures/binary-tree/tree-multi-map.more-branches-2.coverage.test.ts.skip +0 -59
  671. package/test/unit/data-structures/binary-tree/tree-multi-map.rfc.test.ts +0 -99
  672. package/test/unit/data-structures/binary-tree/tree-multi-map.simplified.test.ts +0 -482
  673. package/test/unit/data-structures/binary-tree/tree-multi-set.test.ts +0 -545
  674. package/test/unit/data-structures/binary-tree/tree-set.test.ts +0 -187
  675. package/test/unit/data-structures/graph/abstract-graph.more-branches-2.coverage.test.ts +0 -40
  676. package/test/unit/data-structures/graph/abstract-graph.more-branches-3.coverage.test.ts +0 -65
  677. package/test/unit/data-structures/graph/abstract-graph.more-branches-4.coverage.test.ts +0 -98
  678. package/test/unit/data-structures/graph/abstract-graph.more-branches-5.coverage.test.ts +0 -51
  679. package/test/unit/data-structures/graph/abstract-graph.more-branches.coverage.test.ts +0 -62
  680. package/test/unit/data-structures/graph/abstract-graph.test.ts +0 -117
  681. package/test/unit/data-structures/graph/directed-graph.more-branches-2.coverage.test.ts +0 -38
  682. package/test/unit/data-structures/graph/directed-graph.more-branches-3.coverage.test.ts +0 -25
  683. package/test/unit/data-structures/graph/directed-graph.more-branches.coverage.test.ts +0 -82
  684. package/test/unit/data-structures/graph/directed-graph.test.ts +0 -1185
  685. package/test/unit/data-structures/graph/map-graph.more-branches.coverage.test.ts +0 -22
  686. package/test/unit/data-structures/graph/map-graph.test.ts +0 -148
  687. package/test/unit/data-structures/graph/overall.test.ts +0 -49
  688. package/test/unit/data-structures/graph/salty-edges.json +0 -875
  689. package/test/unit/data-structures/graph/salty-vertexes.json +0 -200
  690. package/test/unit/data-structures/graph/undirected-graph.more-branches-2.coverage.test.ts +0 -35
  691. package/test/unit/data-structures/graph/undirected-graph.more-branches.coverage.test.ts +0 -87
  692. package/test/unit/data-structures/graph/undirected-graph.test.ts +0 -782
  693. package/test/unit/data-structures/hash/hash-map.more-branches.coverage.test.ts +0 -64
  694. package/test/unit/data-structures/hash/hash-map.test.ts +0 -1125
  695. package/test/unit/data-structures/hash/hash-map.toEntryFn-branch.coverage.test.ts +0 -9
  696. package/test/unit/data-structures/heap/heap.misc-branches.coverage.test.ts +0 -110
  697. package/test/unit/data-structures/heap/heap.remaining-branches.coverage.test.ts +0 -22
  698. package/test/unit/data-structures/heap/heap.test.ts +0 -760
  699. package/test/unit/data-structures/heap/max-heap.coverage.test.ts +0 -29
  700. package/test/unit/data-structures/heap/max-heap.test.ts +0 -98
  701. package/test/unit/data-structures/heap/min-heap.test.ts +0 -117
  702. package/test/unit/data-structures/linked-list/doubly-linked-list.more-branches.coverage.test.ts +0 -72
  703. package/test/unit/data-structures/linked-list/doubly-linked-list.test.ts +0 -1150
  704. package/test/unit/data-structures/linked-list/linked-list.test.ts +0 -8
  705. package/test/unit/data-structures/linked-list/linked-list.unshiftMany-else.coverage.test.ts +0 -15
  706. package/test/unit/data-structures/linked-list/singly-linked-list.coverage.test.ts +0 -221
  707. package/test/unit/data-structures/linked-list/singly-linked-list.more-branches.coverage.test.ts +0 -86
  708. package/test/unit/data-structures/linked-list/singly-linked-list.test.ts +0 -836
  709. package/test/unit/data-structures/linked-list/skip-linked-list.more-branches.coverage.test.ts +0 -31
  710. package/test/unit/data-structures/linked-list/skip-linked-list.test.ts +0 -13
  711. package/test/unit/data-structures/linked-list/skip-list.test.ts +0 -86
  712. package/test/unit/data-structures/matrix/matrix.more-branches.coverage.test.ts +0 -81
  713. package/test/unit/data-structures/matrix/matrix.pivotElement-nullish.coverage.test.ts +0 -28
  714. package/test/unit/data-structures/matrix/matrix.test.ts +0 -377
  715. package/test/unit/data-structures/matrix/navigator.test.ts +0 -244
  716. package/test/unit/data-structures/priority-queue/max-priority-queue.more-branches.coverage.test.ts +0 -10
  717. package/test/unit/data-structures/priority-queue/max-priority-queue.test.ts +0 -160
  718. package/test/unit/data-structures/priority-queue/min-priority-queue.test.ts +0 -78
  719. package/test/unit/data-structures/priority-queue/priority-queue.coverage.test.ts +0 -21
  720. package/test/unit/data-structures/priority-queue/priority-queue.test.ts +0 -101
  721. package/test/unit/data-structures/queue/deque.coverage.test.ts +0 -173
  722. package/test/unit/data-structures/queue/deque.more-branches-2.coverage.test.ts +0 -39
  723. package/test/unit/data-structures/queue/deque.more-branches-3.coverage.test.ts +0 -9
  724. package/test/unit/data-structures/queue/deque.more-branches.coverage.test.ts +0 -95
  725. package/test/unit/data-structures/queue/deque.test.ts +0 -936
  726. package/test/unit/data-structures/queue/queue.coverage.test.ts +0 -138
  727. package/test/unit/data-structures/queue/queue.more-branches-2.coverage.test.ts +0 -27
  728. package/test/unit/data-structures/queue/queue.test.ts +0 -703
  729. package/test/unit/data-structures/stack/stack.coverage.test.ts +0 -112
  730. package/test/unit/data-structures/stack/stack.test.ts +0 -438
  731. package/test/unit/data-structures/tree/tree.more-branches.coverage.test.ts +0 -9
  732. package/test/unit/data-structures/tree/tree.test.ts +0 -58
  733. package/test/unit/data-structures/trie/trie.more-branches-2.coverage.test.ts +0 -51
  734. package/test/unit/data-structures/trie/trie.test.ts +0 -1181
  735. package/test/unit/unrestricted-interconversion.test.ts +0 -299
  736. package/test/unit/utils/utils.test.ts +0 -174
  737. package/test/utils/array.ts +0 -5517
  738. package/test/utils/big-o.ts +0 -228
  739. package/test/utils/console.ts +0 -31
  740. package/test/utils/index.ts +0 -8
  741. package/test/utils/is.ts +0 -56
  742. package/test/utils/json2html.ts +0 -164
  743. package/test/utils/number.ts +0 -13
  744. package/test/utils/patch.ts +0 -33
  745. package/test/utils/perf.mjs +0 -34
  746. package/test/utils/performanc.ts +0 -7
  747. package/test/utils/string.ts +0 -49
  748. package/tsconfig.types.json +0 -15
  749. package/tsup.config.js +0 -63
  750. package/tsup.umd.config.js +0 -29
@@ -1,1125 +0,0 @@
1
- import { HashMap, LinkedHashMap } from '../../../../src';
2
- import { getRandomInt, getRandomIntArray } from '../../../utils';
3
-
4
- describe('HashMap', () => {
5
- let hashMap: HashMap<string, number>;
6
-
7
- beforeEach(() => {
8
- hashMap = new HashMap<string, number>();
9
- });
10
-
11
- it('should initialize correctly', () => {
12
- expect(hashMap.size).toBe(0);
13
- expect(hashMap.isEmpty()).toBe(true);
14
- });
15
-
16
- it('should set and get values', () => {
17
- hashMap.set('one', 1);
18
- hashMap.set('two', 2);
19
- hashMap.set('three', 3);
20
-
21
- expect(hashMap.get('one')).toBe(1);
22
- expect(hashMap.get('two')).toBe(2);
23
- expect(hashMap.get('three')).toBe(3);
24
- });
25
-
26
- it('should handle key collisions', () => {
27
- // Force a collision by setting two different keys to the same bucket
28
- hashMap.set('key1', 1);
29
- hashMap.set('key2', 2);
30
-
31
- expect(hashMap.get('key1')).toBe(1);
32
- expect(hashMap.get('key2')).toBe(2);
33
- });
34
-
35
- it('should delete values', () => {
36
- hashMap.set('one', 1);
37
- hashMap.set('two', 2);
38
-
39
- hashMap.delete('one');
40
- expect(hashMap.get('one')).toBeUndefined();
41
- expect(hashMap.size).toBe(1);
42
- });
43
-
44
- it('should clear the HashMap', () => {
45
- hashMap.set('one', 1);
46
- hashMap.set('two', 2);
47
-
48
- hashMap.clear();
49
- expect(hashMap.size).toBe(0);
50
- expect(hashMap.isEmpty()).toBe(true);
51
- });
52
-
53
- it('should iterate over entries', () => {
54
- hashMap.set('one', 1);
55
- hashMap.set('two', 2);
56
- hashMap.set('three', 3);
57
- });
58
-
59
- it('should resize the table when load factor is exceeded', () => {
60
- // Set a small initial capacity for testing resizing
61
- hashMap = new HashMap<string, number>();
62
-
63
- hashMap.set('one', 1);
64
- hashMap.set('two', 2);
65
- hashMap.set('three', 3);
66
- hashMap.set('four', 4); // This should trigger a resize
67
-
68
- // expect(hashMap.table.length).toBe(8);
69
- expect(hashMap.get('one')).toBe(1);
70
- expect(hashMap.get('two')).toBe(2);
71
- expect(hashMap.get('three')).toBe(3);
72
- expect(hashMap.get('four')).toBe(4);
73
- });
74
-
75
- it('should allow using a custom hash function', () => {
76
- hashMap = new HashMap<string, number>();
77
-
78
- hashMap.set('one', 1);
79
- hashMap.set('two', 2);
80
-
81
- expect(hashMap.get('one')).toBe(1);
82
- expect(hashMap.get('two')).toBe(2);
83
- // Since the custom hash function always returns 0, these keys will collide.
84
- // Make sure they are stored separately.
85
- // expect(hashMap.table[0].length).toBe(2);
86
- });
87
-
88
- it('should clone', () => {
89
- hashMap = new HashMap<string, number>();
90
-
91
- hashMap.set('one', 1);
92
- hashMap.set('two', 2);
93
- for (let i = 3; i <= 100; i++) {
94
- hashMap.set(i.toString(), i);
95
- }
96
-
97
- expect(hashMap.get('one')).toBe(1);
98
- expect(hashMap.get('two')).toBe(2);
99
- expect(hashMap.get('86')).toBe(86);
100
- expect(hashMap.size).toBe(100);
101
- hashMap.delete('two');
102
- expect(hashMap.size).toBe(99);
103
-
104
- const cloned = hashMap.clone();
105
- expect(cloned.get('one')).toBe(1);
106
- expect(cloned.get('two')).toBe(undefined);
107
- expect(cloned.get('86')).toBe(86);
108
- expect(cloned.size).toBe(99);
109
- });
110
-
111
- describe('HashMap Test2', () => {
112
- let hashMap: HashMap;
113
-
114
- beforeEach(() => {
115
- hashMap = new HashMap();
116
- });
117
-
118
- it('should create an empty map', () => {
119
- expect(hashMap.size).toBe(0);
120
- });
121
-
122
- it('should add a key-value pair', () => {
123
- hashMap.set('key1', 'value1');
124
- expect(hashMap.get('key1')).toBe('value1');
125
- expect(hashMap.hasValue('value1')).toBe(true);
126
- expect(hashMap.hasValue('value2')).toBe(false);
127
- });
128
-
129
- it('should handle object keys correctly', () => {
130
- const keyObj = { id: 1 };
131
- hashMap.set(keyObj, 'objectValue');
132
- expect(hashMap.has(keyObj)).toBe(true);
133
- expect(hashMap.get(keyObj)).toBe('objectValue');
134
- });
135
-
136
- it('Inheritability test', () => {
137
- class ExtendedHashMap<K, V> extends HashMap<K, V> {
138
- someOtherParam?: string;
139
-
140
- constructor(
141
- elements: Iterable<[K, V]> = [],
142
- options?: {
143
- hashFn?: (key: K) => string;
144
- someOtherParam: string;
145
- }
146
- ) {
147
- const { someOtherParam, ...restOptions } = options || {};
148
- super(elements, restOptions);
149
- this.someOtherParam = someOtherParam;
150
- }
151
- }
152
-
153
- const eHM = new ExtendedHashMap<string, number>([], {
154
- someOtherParam: 'someOtherParam'
155
- });
156
- eHM.set('one', 1);
157
- expect(eHM.get('one')).toBe(1);
158
- });
159
-
160
- it('should raw elements toEntry', () => {
161
- const rawCollection = [
162
- { id: 1, name: 'item 1' },
163
- { id: 2, name: 'item 2' }
164
- ];
165
- const hm = new HashMap<number, string, { id: number; name: string }>(rawCollection, {
166
- toEntryFn: rawElement => [rawElement.id, rawElement.name]
167
- });
168
-
169
- expect(hm.has(1)).toBe(true);
170
- expect(hm.get(2)).toBe('item 2');
171
- expect(hm.size).toBe(2);
172
- });
173
-
174
- it('should update the value for an existing key', () => {
175
- hashMap.set('key1', 'value1');
176
- hashMap.set('key1', 'newValue');
177
- expect(hashMap.get('key1')).toBe('newValue');
178
- });
179
-
180
- it('should return undefined for a non-existent key', () => {
181
- expect(hashMap.get('nonExistentKey')).toBeUndefined();
182
- });
183
-
184
- it('should remove a key-value pair', () => {
185
- hashMap.set('key1', 'value1');
186
- hashMap.delete('key1');
187
- expect(hashMap.get('key1')).toBeUndefined();
188
- });
189
-
190
- it('should clear the map', () => {
191
- hashMap.set('key1', 'value1');
192
- expect(hashMap.size).toBe(1);
193
-
194
- hashMap.clear();
195
- expect(hashMap.size).toBe(0);
196
- });
197
-
198
- it('should iterate over values', () => {
199
- hashMap.set('key1', 'value1');
200
- hashMap.set('key2', 'value2');
201
- const values = [];
202
- for (const value of hashMap) {
203
- values.push(value);
204
- }
205
- expect(values).toEqual([
206
- ['key1', 'value1'],
207
- ['key2', 'value2']
208
- ]);
209
- });
210
-
211
- function compareHashMaps(hashMap: HashMap<unknown, unknown>, stdMap: Map<unknown, unknown>) {
212
- expect(hashMap.size).toEqual(stdMap.size);
213
- stdMap.forEach((value, key) => {
214
- expect(hashMap.get(key)).toEqual(value);
215
- });
216
- }
217
-
218
- const stdMap: Map<unknown, unknown> = new Map();
219
- const arr: number[] = getRandomIntArray(1000, 1, 10000);
220
-
221
- it('delete test', () => {
222
- for (const item of arr) {
223
- stdMap.set(item, item);
224
- hashMap.set(item, item);
225
- }
226
- for (const item of arr) {
227
- if (Math.random() > 0.6) {
228
- expect(hashMap.delete(item)).toEqual(stdMap.delete(item));
229
- }
230
- }
231
- compareHashMaps(hashMap, stdMap);
232
-
233
- for (let i = 0; i < 1000; ++i) {
234
- const random = getRandomInt(0, 100);
235
- expect(hashMap.delete(random)).toEqual(stdMap.delete(random));
236
- }
237
- compareHashMaps(hashMap, stdMap);
238
- });
239
- });
240
-
241
- describe('HashMap for coordinate object keys', () => {
242
- const hashMap: HashMap<[number, number], number> = new HashMap();
243
- const codObjs: [number, number][] = [];
244
- for (let i = 0; i < 10; i++) {
245
- const codObj: [number, number] = [getRandomInt(-10000, 10000), i];
246
- codObjs.push(codObj);
247
- }
248
- it('set elements in hash map', () => {
249
- for (let i = 0; i < codObjs.length; i++) {
250
- const codObj = codObjs[i];
251
- hashMap.set(codObj, i);
252
- }
253
- });
254
-
255
- it('get elements in hash map', () => {
256
- for (let i = 0; i < codObjs.length; i++) {
257
- const codObj = codObjs[i];
258
- if (codObj) {
259
- expect(hashMap.get(codObj)).toBe(i);
260
- }
261
- }
262
- });
263
-
264
- it('should spread elements in hash map', () => {
265
- expect([...hashMap]).toEqual(codObjs.map(codObj => [codObj, codObj[1]]));
266
- });
267
-
268
- it('delete elements in hash map', () => {
269
- for (let i = 0; i < 10; i++) {
270
- if (i === 500) expect(hashMap.size).toBe(500);
271
- const codObj = codObjs[i];
272
- if (codObj) hashMap.delete(codObj);
273
- }
274
- expect(hashMap.size).toBe(0);
275
- });
276
- });
277
-
278
- describe('HashMap setMany, keys, values', () => {
279
- const hm: HashMap<number, number> = new HashMap<number, number>();
280
-
281
- beforeEach(() => {
282
- hm.clear();
283
- hm.setMany([
284
- [2, 2],
285
- [3, 3],
286
- [4, 4],
287
- [5, 5]
288
- ]);
289
- hm.setMany([
290
- [2, 2],
291
- [3, 3],
292
- [4, 4],
293
- [6, 6]
294
- ]);
295
- });
296
-
297
- it('keys', () => {
298
- expect([...hm.keys()]).toEqual([2, 3, 4, 5, 6]);
299
- });
300
-
301
- it('values', () => {
302
- expect([...hm.values()]).toEqual([2, 3, 4, 5, 6]);
303
- });
304
-
305
- it('print', () => {
306
- expect(hm.toVisual()).toEqual([
307
- [2, 2],
308
- [3, 3],
309
- [4, 4],
310
- [5, 5],
311
- [6, 6]
312
- ]);
313
- });
314
- });
315
-
316
- describe('HashMap HOF', () => {
317
- let hashMap: HashMap<string, string>;
318
-
319
- beforeEach(() => {
320
- hashMap = new HashMap<string, string>();
321
- hashMap.set('key1', 'value1');
322
- hashMap.set('key2', 'value2');
323
- hashMap.set('key3', 'value3');
324
- });
325
-
326
- it('every() returns true if all elements match the condition', () => {
327
- expect(hashMap.every(value => typeof value === 'string')).toBe(true);
328
- });
329
-
330
- it('some() returns true if any element matches the condition', () => {
331
- expect(hashMap.some((_value, key) => key === 'key1')).toBe(true);
332
- });
333
-
334
- it('forEach() should execute a function for each element', () => {
335
- const mockCallback = jest.fn();
336
- hashMap.forEach(mockCallback);
337
- expect(mockCallback.mock.calls.length).toBe(3);
338
- });
339
-
340
- it('map() should transform each element', () => {
341
- const newHashMap = hashMap.map(value => value.toUpperCase());
342
- expect(newHashMap.get('key1')).toBe('VALUE1');
343
- });
344
-
345
- it('filter() should remove elements that do not match the condition', () => {
346
- const filteredHashMap = hashMap.filter((_, key) => key !== 'key1');
347
- expect(filteredHashMap.has('key1')).toBe(false);
348
- });
349
-
350
- it('reduce() should accumulate values', () => {
351
- const result = hashMap.reduce((acc, value) => acc + value, '');
352
- expect(result).toBe('value1value2value3');
353
- });
354
-
355
- it('should spread in an array', () => {
356
- expect([...hashMap]).toEqual([
357
- ['key1', 'value1'],
358
- ['key2', 'value2'],
359
- ['key3', 'value3']
360
- ]);
361
- });
362
-
363
- it('should find', () => {
364
- const found = hashMap.find(value => value === 'value1');
365
- expect(found).toEqual(['key1', 'value1']);
366
- const notFound = hashMap.find(value => value === 'value6');
367
- expect(notFound).toEqual(undefined);
368
- });
369
-
370
- it('should every', () => {
371
- const isEvery = hashMap.every(value => value.substring(0, 5) === 'value');
372
- expect(isEvery).toEqual(true);
373
- const isEvery4 = hashMap.every(value => value.substring(0, 4) === 'value');
374
- expect(isEvery4).toEqual(false);
375
- });
376
-
377
- it('should some', () => {
378
- const isSome = hashMap.some(value => value.substring(5, 6) === '2');
379
- expect(isSome).toEqual(true);
380
- const isSome4 = hashMap.some(value => value.substring(0, 5) === 'value');
381
- expect(isSome4).toEqual(true);
382
- });
383
-
384
- it('should forEach', () => {
385
- hashMap.forEach((value, key, index) => expect(value.substring(5, 6)).toBe(String(index + 1)));
386
- });
387
-
388
- it('should entries', () => {
389
- const entries = hashMap.entries();
390
- expect(entries.next()).toEqual({ done: false, value: ['key1', 'value1'] });
391
- expect(entries.next()).toEqual({ done: false, value: ['key2', 'value2'] });
392
- expect(entries.next()).toEqual({ done: false, value: ['key3', 'value3'] });
393
- expect(entries.next()).toEqual({ done: true, value: undefined });
394
- });
395
-
396
- it('should keys', () => {
397
- const keys = hashMap.keys();
398
- expect(keys.next()).toEqual({ done: false, value: 'key1' });
399
- expect(keys.next()).toEqual({ done: false, value: 'key2' });
400
- expect(keys.next()).toEqual({ done: false, value: 'key3' });
401
- expect(keys.next()).toEqual({ done: true, value: undefined });
402
- });
403
-
404
- it('should values', () => {
405
- const values = hashMap.values();
406
- expect(values.next()).toEqual({ done: false, value: 'value1' });
407
- expect(values.next()).toEqual({ done: false, value: 'value2' });
408
- expect(values.next()).toEqual({ done: false, value: 'value3' });
409
- expect(values.next()).toEqual({ done: true, value: undefined });
410
- });
411
- });
412
- });
413
-
414
- describe('LinkedHashMap', () => {
415
- let hashMap: LinkedHashMap;
416
-
417
- beforeEach(() => {
418
- hashMap = new LinkedHashMap();
419
- });
420
-
421
- it('should create an empty map', () => {
422
- expect(hashMap.size).toBe(0);
423
- });
424
-
425
- it('should add a key-value pair', () => {
426
- expect(hashMap.first).toBe(undefined);
427
- hashMap.set('key1', 'value1');
428
- expect(hashMap.get('key1')).toBe('value1');
429
- });
430
-
431
- it('should handle object keys correctly', () => {
432
- const keyObj = { id: 1 };
433
- hashMap.set(keyObj, 'objectValue');
434
- expect(hashMap.get(keyObj)).toBe('objectValue');
435
- });
436
-
437
- it('should handle number keys correctly', () => {
438
- hashMap.set(999, { a: '999Value' });
439
- expect(hashMap.get(999)).toEqual({
440
- a: '999Value'
441
- });
442
- });
443
-
444
- it('should update the value for an existing key', () => {
445
- hashMap.set('key1', 'value1');
446
- hashMap.set('key1', 'newValue');
447
- expect(hashMap.get('key1')).toBe('newValue');
448
- });
449
-
450
- it('should return undefined for a non-existent key', () => {
451
- expect(hashMap.get('nonExistentKey')).toBeUndefined();
452
- });
453
-
454
- it('should remove a key-value pair', () => {
455
- hashMap.set('key1', 'value1');
456
- hashMap.delete('key1');
457
- expect(hashMap.get('key1')).toBeUndefined();
458
- });
459
-
460
- it('should clear the map', () => {
461
- hashMap.set('key1', 'value1');
462
- expect(hashMap.size).toBe(1);
463
-
464
- hashMap.clear();
465
- expect(hashMap.size).toBe(0);
466
- });
467
-
468
- it('should iterate over values', () => {
469
- hashMap.set('key1', 'value1');
470
- hashMap.set('key2', 'value2');
471
- const values = [];
472
- for (const value of hashMap) {
473
- values.push(value);
474
- }
475
- expect(values).toEqual([
476
- ['key1', 'value1'],
477
- ['key2', 'value2']
478
- ]);
479
- });
480
-
481
- function compareHashMaps(hashMap: LinkedHashMap<unknown, unknown>, stdMap: Map<unknown, unknown>) {
482
- expect(hashMap.size).toEqual(stdMap.size);
483
- let index = 0;
484
- stdMap.forEach((value, key) => {
485
- if (index === 0) {
486
- expect(hashMap.first).toEqual([key, value]);
487
- expect(hashMap.begin().next().value).toEqual([key, value]);
488
- } else if (index === hashMap.size - 1) {
489
- expect(hashMap.last).toEqual([key, value]);
490
- expect(hashMap.reverseBegin().next().value).toEqual([key, value]);
491
- } else if (index <= 1000) {
492
- expect(hashMap.at(index)).toBe(value);
493
- }
494
- expect(hashMap.get(key)).toEqual(value);
495
- index++;
496
- });
497
- }
498
-
499
- const stdMap: Map<unknown, unknown> = new Map();
500
- const arr: number[] = getRandomIntArray(1000, 1, 10000);
501
-
502
- it('delete test', () => {
503
- for (const item of arr) {
504
- stdMap.set(item, item);
505
- hashMap.set(item, item);
506
- }
507
- for (const item of arr) {
508
- if (Math.random() > 0.6) {
509
- expect(hashMap.delete(item)).toEqual(stdMap.delete(item));
510
- }
511
- }
512
- compareHashMaps(hashMap, stdMap);
513
-
514
- for (let i = 0; i < 1000; ++i) {
515
- const random = getRandomInt(0, 100);
516
- expect(hashMap.delete(random)).toEqual(stdMap.delete(random));
517
- }
518
- compareHashMaps(hashMap, stdMap);
519
- });
520
-
521
- it('should iterate correctly with reverse iterators', () => {
522
- hashMap.set('key1', 'value1');
523
- hashMap.set('key2', 'value2');
524
- const iterator = hashMap.reverseBegin();
525
- expect(iterator.next().value).toEqual(['key2', 'value2']);
526
- });
527
-
528
- it('should return the last element', () => {
529
- hashMap.set('key1', 'value1');
530
- hashMap.set('key2', 'value2');
531
- expect(hashMap.last).toEqual(['key2', 'value2']);
532
- });
533
-
534
- it('should return undefined for empty map', () => {
535
- expect(hashMap.last).toBeUndefined();
536
- });
537
-
538
- it('should get element at specific index', () => {
539
- hashMap.set('key1', 'value1');
540
- hashMap.set('key2', 'value2');
541
- expect(hashMap.at(1)).toBe('value2');
542
- });
543
-
544
- it('should hashFn, objHashFn, toEntryFn work well', () => {
545
- const data: Array<{ name: number }> = [{ name: 1 }, { name: 2 }, { name: 3 }];
546
- const hm = new LinkedHashMap(data, {
547
- hashFn: key => String(key),
548
- objHashFn: obj => obj,
549
- toEntryFn: ({ name }) => [{ name }, name]
550
- });
551
-
552
- expect(hm.hashFn).toBeTruthy();
553
- expect(hm.objHashFn).toBeTruthy();
554
- expect(hm.toEntryFn).toBeTruthy();
555
- expect([...hm]).toEqual([
556
- [{ name: 1 }, 1],
557
- [{ name: 2 }, 2],
558
- [{ name: 3 }, 3]
559
- ]);
560
- });
561
-
562
- it('should begin, reverseBegin', () => {
563
- const data: Array<{ name: number }> = [{ name: 1 }, { name: 2 }, { name: 3 }];
564
- const hm = new LinkedHashMap(data, {
565
- hashFn: key => String(key),
566
- objHashFn: obj => obj,
567
- toEntryFn: ({ name }) => [{ name }, name]
568
- });
569
-
570
- expect(hm.begin().next()).toEqual({
571
- done: false,
572
- value: [
573
- {
574
- name: 1
575
- },
576
- 1
577
- ]
578
- });
579
-
580
- expect(hm.reverseBegin().next()).toEqual({
581
- done: false,
582
- value: [
583
- {
584
- name: 3
585
- },
586
- 3
587
- ]
588
- });
589
- });
590
-
591
- it('should clone', () => {
592
- hashMap = new LinkedHashMap<string, number>();
593
-
594
- hashMap.set('one', 1);
595
- hashMap.set('two', 2);
596
- for (let i = 3; i <= 100; i++) {
597
- hashMap.set(i.toString(), i);
598
- }
599
-
600
- expect(hashMap.get('one')).toBe(1);
601
- expect(hashMap.get('two')).toBe(2);
602
- expect(hashMap.get('86')).toBe(86);
603
- expect(hashMap.size).toBe(100);
604
- hashMap.delete('two');
605
- expect(hashMap.size).toBe(99);
606
-
607
- const cloned = hashMap.clone();
608
- expect(cloned.get('one')).toBe(1);
609
- expect(cloned.get('two')).toBe(undefined);
610
- expect(cloned.get('86')).toBe(86);
611
- expect(cloned.size).toBe(99);
612
- });
613
-
614
- describe('LinkedHashMap basic', () => {
615
- let hashMap: LinkedHashMap<string, number>;
616
-
617
- beforeEach(() => {
618
- hashMap = new LinkedHashMap<string, number>();
619
- });
620
-
621
- it('should initialize correctly', () => {
622
- expect(hashMap.size).toBe(0);
623
- // expect(hashMap.table.length).toBe(16);
624
- // expect(hashMap.loadFactor).toBe(0.75);
625
- // expect(hashMap.capacityMultiplier).toBe(2);
626
- // expect(hashMap.initialCapacity).toBe(16);
627
- expect(hashMap.isEmpty()).toBe(true);
628
- });
629
-
630
- it('should put and get values', () => {
631
- hashMap.set('one', 1);
632
- hashMap.set('two', 2);
633
- hashMap.set('three', 3);
634
-
635
- expect(hashMap.get('one')).toBe(1);
636
- expect(hashMap.get('two')).toBe(2);
637
- expect(hashMap.get('three')).toBe(3);
638
- });
639
-
640
- it('should handle key collisions', () => {
641
- // Force a collision by setting two different keys to the same bucket
642
- hashMap.set('key1', 1);
643
- hashMap.set('key2', 2);
644
-
645
- expect(hashMap.get('key1')).toBe(1);
646
- expect(hashMap.get('key2')).toBe(2);
647
- });
648
-
649
- it('should delete values', () => {
650
- hashMap.set('one', 1);
651
- hashMap.set('two', 2);
652
-
653
- hashMap.delete('one');
654
- expect(hashMap.get('one')).toBeUndefined();
655
- expect(hashMap.size).toBe(1);
656
- hashMap.deleteAt(0);
657
- // expect(hashMap.get('two')).toBe(undefined); // TODO #99
658
- expect(hashMap.size).toBe(0);
659
- });
660
-
661
- it('should clear the LinkedHashMap', () => {
662
- hashMap.set('one', 1);
663
- hashMap.set('two', 2);
664
-
665
- hashMap.clear();
666
- expect(hashMap.size).toBe(0);
667
- expect(hashMap.isEmpty()).toBe(true);
668
- });
669
-
670
- it('should iterate over entries', () => {
671
- hashMap.set('one', 1);
672
- hashMap.set('two', 2);
673
- hashMap.set('three', 3);
674
-
675
- // const entries = Array.from(hashMap.entries());
676
- // expect(entries).toContainEqual(['one', 1]);
677
- // expect(entries).toContainEqual(['two', 2]);
678
- // expect(entries).toContainEqual(['three', 3]);
679
- });
680
-
681
- it('should resize the table when load factor is exceeded', () => {
682
- // Set a small initial capacity for testing resizing
683
- hashMap = new LinkedHashMap<string, number>();
684
-
685
- hashMap.set('one', 1);
686
- hashMap.set('two', 2);
687
- hashMap.set('three', 3);
688
- hashMap.set('four', 4); // This should trigger a resize
689
-
690
- // expect(hashMap.table.length).toBe(8);
691
- expect(hashMap.get('one')).toBe(1);
692
- expect(hashMap.get('two')).toBe(2);
693
- expect(hashMap.get('three')).toBe(3);
694
- expect(hashMap.get('four')).toBe(4);
695
- });
696
-
697
- it('should allow using a custom hash function', () => {
698
- hashMap = new LinkedHashMap<string, number>();
699
-
700
- hashMap.set('one', 1);
701
- hashMap.set('two', 2);
702
-
703
- expect(hashMap.get('one')).toBe(1);
704
- expect(hashMap.get('two')).toBe(2);
705
- // Since the custom hash function always returns 0, these keys will collide.
706
- // Make sure they are stored separately.
707
- // expect(hashMap.table[0].length).toBe(2);
708
- });
709
-
710
- // it('should handle number keys correctly', () => {
711
- // const hm = new LinkedHashMap();
712
- // hm.set(999, { a: '999Value' });
713
- // hm.set('999', {a: '999StrValue'})
714
- // expect(hm.get(999)).toEqual({ a: '999Value' });
715
- // expect(hm.get('999')).toEqual({ a: '999StrValue1' });
716
- // });
717
- });
718
-
719
- describe('coordinate object keys', () => {
720
- const hashMap: LinkedHashMap<[number, number], number> = new LinkedHashMap();
721
- const codObjs: [number, number][] = [];
722
-
723
- it('set elements in hash map', () => {
724
- for (let i = 0; i < 1000; i++) {
725
- const codObj: [number, number] = [getRandomInt(-10000, 10000), i];
726
- codObjs.push(codObj);
727
- hashMap.set(codObj, i);
728
- }
729
- });
730
-
731
- it('get elements in hash map', () => {
732
- for (let i = 0; i < 1000; i++) {
733
- const codObj = codObjs[i];
734
- if (codObj) {
735
- expect(hashMap.get(codObj)).toBe(i);
736
- }
737
- }
738
- });
739
-
740
- it('delete elements in hash map', () => {
741
- for (let i = 0; i < 1000; i++) {
742
- if (i === 500) expect(hashMap.size).toBe(500);
743
- const codObj = codObjs[i];
744
- if (codObj) hashMap.delete(codObj);
745
- }
746
- expect(hashMap.size).toBe(0);
747
- });
748
- });
749
-
750
- describe('setMany, keys, values', () => {
751
- const hm: LinkedHashMap<number, number> = new LinkedHashMap<number, number>();
752
-
753
- beforeEach(() => {
754
- hm.clear();
755
- hm.setMany([
756
- [2, 2],
757
- [3, 3],
758
- [4, 4],
759
- [5, 5]
760
- ]);
761
- hm.setMany([
762
- [2, 2],
763
- [3, 3],
764
- [4, 4],
765
- [6, 6]
766
- ]);
767
- });
768
-
769
- it('keys', () => {
770
- expect([...hm.keys()]).toEqual([2, 3, 4, 5, 6]);
771
- });
772
-
773
- it('values', () => {
774
- expect([...hm.values()]).toEqual([2, 3, 4, 5, 6]);
775
- });
776
-
777
- it('entries', () => {
778
- expect([...hm.entries()]).toEqual([
779
- [2, 2],
780
- [3, 3],
781
- [4, 4],
782
- [5, 5],
783
- [6, 6]
784
- ]);
785
- });
786
-
787
- it('every', () => {
788
- expect(hm.every(value => value > 4)).toBe(false);
789
- });
790
-
791
- it('some', () => {
792
- expect(hm.some(value => value > 6)).toBe(false);
793
- });
794
-
795
- it('hasValue', () => {
796
- expect(hm.hasValue(3)).toBe(true);
797
- expect(hm.hasValue(7)).toBe(false);
798
- });
799
-
800
- it('print', () => {
801
- // hm.print();
802
- });
803
- });
804
-
805
- describe('HashMap HOF', () => {
806
- let hashMap: LinkedHashMap;
807
-
808
- beforeEach(() => {
809
- hashMap = new LinkedHashMap<string, string>();
810
- hashMap.set('key1', 'value1');
811
- hashMap.set('key2', 'value2');
812
- hashMap.set('key3', 'value3');
813
- });
814
-
815
- it('every() returns true if all elements match the condition', () => {
816
- expect(hashMap.every(value => typeof value === 'string')).toBe(true);
817
- });
818
-
819
- it('some() returns true if any element matches the condition', () => {
820
- expect(hashMap.some((_value, key) => key === 'key1')).toBe(true);
821
- });
822
-
823
- it('forEach() should execute a function for each element', () => {
824
- const mockCallback = jest.fn();
825
- hashMap.forEach(mockCallback);
826
- expect(mockCallback.mock.calls.length).toBe(3);
827
- });
828
-
829
- it('map() should transform each element', () => {
830
- const newHashMap = hashMap.map((value, key) => [key, value.toUpperCase()]);
831
- expect(newHashMap.get('key1')).toBe('VALUE1');
832
- });
833
-
834
- it('filter() should remove elements that do not match the condition', () => {
835
- const filteredHashMap = hashMap.filter((_v, key) => key !== 'key1');
836
- expect(filteredHashMap.has('key1')).toBe(false);
837
- });
838
-
839
- it('reduce() should accumulate values', () => {
840
- const result = hashMap.reduce((acc, value) => acc + value, '');
841
- expect(result).toBe('value1value2value3');
842
- });
843
- });
844
- });
845
-
846
- describe('classic uses', () => {
847
- it('@example should maintain insertion order', () => {
848
- const linkedHashMap = new LinkedHashMap<number, string>();
849
- linkedHashMap.set(1, 'A');
850
- linkedHashMap.set(2, 'B');
851
- linkedHashMap.set(3, 'C');
852
-
853
- const result = Array.from(linkedHashMap);
854
- expect(result).toEqual([
855
- [1, 'A'],
856
- [2, 'B'],
857
- [3, 'C']
858
- ]);
859
- });
860
-
861
- it('should allow reverse iteration', () => {
862
- const linkedHashMap = new LinkedHashMap<number, string>();
863
- linkedHashMap.set(1, 'A');
864
- linkedHashMap.set(2, 'B');
865
- linkedHashMap.set(3, 'C');
866
-
867
- const result = Array.from(linkedHashMap.reverseBegin());
868
- expect(result).toEqual([
869
- [3, 'C'],
870
- [2, 'B'],
871
- [1, 'A']
872
- ]);
873
- });
874
-
875
- it('should allow fast deletion at an index', () => {
876
- const linkedHashMap = new LinkedHashMap<number, string>();
877
- linkedHashMap.set(1, 'A');
878
- linkedHashMap.set(2, 'B');
879
- linkedHashMap.set(3, 'C');
880
-
881
- linkedHashMap.deleteAt(1);
882
-
883
- const result = Array.from(linkedHashMap);
884
- expect(result).toEqual([
885
- [1, 'A'],
886
- [3, 'C']
887
- ]);
888
- });
889
-
890
- it('should filter entries correctly', () => {
891
- const linkedHashMap = new LinkedHashMap<number, string>();
892
- linkedHashMap.set(1, 'A');
893
- linkedHashMap.set(2, 'B');
894
- linkedHashMap.set(3, 'C');
895
-
896
- const filteredMap = linkedHashMap.filter(value => value !== 'B');
897
-
898
- const result = Array.from(filteredMap);
899
- expect(result).toEqual([
900
- [1, 'A'],
901
- [3, 'C']
902
- ]);
903
- });
904
-
905
- it('should map entries to a new LinkedHashMap', () => {
906
- const linkedHashMap = new LinkedHashMap<number, string>();
907
- linkedHashMap.set(1, 'A');
908
- linkedHashMap.set(2, 'B');
909
-
910
- const mappedMap = linkedHashMap.map((value, key) => [value, key]);
911
-
912
- const result = Array.from(mappedMap);
913
- expect(result).toEqual([
914
- ['A', 1],
915
- ['B', 2]
916
- ]);
917
- });
918
- });
919
-
920
- describe('classic uses', () => {
921
- it('@example basic HashMap creation and set operation', () => {
922
- // Create a simple HashMap with key-value pairs
923
- const map = new HashMap<number, string>([
924
- [1, 'one'],
925
- [2, 'two'],
926
- [3, 'three']
927
- ]);
928
-
929
- // Verify size
930
- expect(map.size).toBe(3);
931
-
932
- // Set a new key-value pair
933
- map.set(4, 'four');
934
- expect(map.size).toBe(4);
935
-
936
- // Verify entries
937
- expect([...map.entries()]).toHaveLength(4);
938
- });
939
-
940
- it('@example HashMap get and has operations', () => {
941
- const map = new HashMap<string, number>([
942
- ['apple', 1],
943
- ['banana', 2],
944
- ['cherry', 3]
945
- ]);
946
-
947
- // Check if key exists
948
- expect(map.has('apple')).toBe(true);
949
- expect(map.has('date')).toBe(false);
950
-
951
- // Get value by key
952
- expect(map.get('banana')).toBe(2);
953
- expect(map.get('grape')).toBeUndefined();
954
-
955
- // Get all keys and values
956
- const keys = [...map.keys()];
957
- const values = [...map.values()];
958
- expect(keys).toContain('apple');
959
- expect(values).toContain(3);
960
- });
961
-
962
- it('@example HashMap iteration and filter operations', () => {
963
- const map = new HashMap<number, string>([
964
- [1, 'Alice'],
965
- [2, 'Bob'],
966
- [3, 'Charlie'],
967
- [4, 'Diana'],
968
- [5, 'Eve']
969
- ]);
970
-
971
- // Iterate through entries
972
- const entries: [number, string][] = [];
973
- for (const [key, value] of map) {
974
- entries.push([key, value]);
975
- }
976
- expect(entries).toHaveLength(5);
977
-
978
- // Filter operation (for iteration with collection methods)
979
- const filtered = [...map].filter(([key]) => key > 2);
980
- expect(filtered.length).toBe(3);
981
-
982
- // Map operation
983
- const values = [...map.values()].map(v => v.length);
984
- expect(values).toContain(3); // 'Bob', 'Eve'
985
- expect(values).toContain(7); // 'Charlie'
986
- });
987
-
988
- it('@example HashMap for user session caching O(1) performance', () => {
989
- interface UserSession {
990
- userId: number;
991
- username: string;
992
- loginTime: number;
993
- lastActivity: number;
994
- }
995
-
996
- // HashMap provides O(1) average-case performance for set/get/delete
997
- // Perfect for session management with fast lookups
998
- const sessionCache = new HashMap<string, UserSession>();
999
-
1000
- // Simulate user sessions
1001
- const sessions: [string, UserSession][] = [
1002
- ['session_001', { userId: 1, username: 'alice', loginTime: 1000, lastActivity: 1050 }],
1003
- ['session_002', { userId: 2, username: 'bob', loginTime: 1100, lastActivity: 1150 }],
1004
- ['session_003', { userId: 3, username: 'charlie', loginTime: 1200, lastActivity: 1250 }]
1005
- ];
1006
-
1007
- // Store sessions with O(1) insertion
1008
- for (const [token, session] of sessions) {
1009
- sessionCache.set(token, session);
1010
- }
1011
-
1012
- expect(sessionCache.size).toBe(3);
1013
-
1014
- // Retrieve session with O(1) lookup
1015
- const userSession = sessionCache.get('session_001');
1016
- expect(userSession?.username).toBe('alice');
1017
- expect(userSession?.userId).toBe(1);
1018
-
1019
- // Update session with O(1) operation
1020
- if (userSession) {
1021
- userSession.lastActivity = 2000;
1022
- sessionCache.set('session_001', userSession);
1023
- }
1024
-
1025
- // Check updated value
1026
- const updated = sessionCache.get('session_001');
1027
- expect(updated?.lastActivity).toBe(2000);
1028
-
1029
- // Cleanup: delete expired sessions
1030
- sessionCache.delete('session_002');
1031
- expect(sessionCache.has('session_002')).toBe(false);
1032
-
1033
- // Verify remaining sessions
1034
- expect(sessionCache.size).toBe(2);
1035
-
1036
- // Get all active sessions
1037
- const activeCount = [...sessionCache.values()].length;
1038
- expect(activeCount).toBe(2);
1039
- });
1040
-
1041
- it('Fast lookup of values by key', () => {
1042
- const hashMap = new HashMap<number, string>();
1043
- hashMap.set(1, 'A');
1044
- hashMap.set(2, 'B');
1045
- hashMap.set(3, 'C');
1046
-
1047
- expect(hashMap.get(1)).toBe('A');
1048
- expect(hashMap.get(2)).toBe('B');
1049
- expect(hashMap.get(3)).toBe('C');
1050
- expect(hashMap.get(99)).toBeUndefined(); // Key not present
1051
- });
1052
-
1053
- it('Remove duplicates when adding multiple entries', () => {
1054
- const hashMap = new HashMap<number, string>();
1055
- hashMap.set(1, 'A');
1056
- hashMap.set(2, 'B');
1057
- hashMap.set(1, 'C'); // Update value for key 1
1058
-
1059
- expect(hashMap.size).toBe(2);
1060
- expect(hashMap.get(1)).toBe('C');
1061
- expect(hashMap.get(2)).toBe('B');
1062
- });
1063
-
1064
- it('Count occurrences of keys', () => {
1065
- const data = [1, 2, 1, 3, 2, 1];
1066
-
1067
- const countMap = new HashMap<number, number>();
1068
- for (const key of data) {
1069
- countMap.set(key, (countMap.get(key) || 0) + 1);
1070
- }
1071
-
1072
- expect(countMap.get(1)).toBe(3);
1073
- expect(countMap.get(2)).toBe(2);
1074
- expect(countMap.get(3)).toBe(1);
1075
- });
1076
-
1077
- it('should group entries by a key-derived property', () => {
1078
- const entries = [
1079
- { id: 1, group: 'A' },
1080
- { id: 2, group: 'B' },
1081
- { id: 3, group: 'A' },
1082
- { id: 4, group: 'B' }
1083
- ];
1084
-
1085
- const groupedMap = new HashMap<string, number[]>();
1086
-
1087
- for (const entry of entries) {
1088
- const group = entry.group;
1089
- const id = entry.id;
1090
- if (!groupedMap.has(group)) {
1091
- groupedMap.set(group, []);
1092
- }
1093
- groupedMap.get(group)?.push(id);
1094
- }
1095
-
1096
- expect(groupedMap.get('A')).toEqual([1, 3]);
1097
- expect(groupedMap.get('B')).toEqual([2, 4]);
1098
- });
1099
-
1100
- it('HashMap delete and clear operations', () => {
1101
- const map = new HashMap<string, number>([
1102
- ['a', 10],
1103
- ['b', 20],
1104
- ['c', 30],
1105
- ['d', 40]
1106
- ]);
1107
-
1108
- // Delete a key
1109
- map.delete('b');
1110
- expect(map.has('b')).toBe(false);
1111
- expect(map.size).toBe(3);
1112
-
1113
- // Value for deleted key is undefined
1114
- expect(map.get('b')).toBeUndefined();
1115
-
1116
- // Other entries remain
1117
- expect(map.get('a')).toBe(10);
1118
- expect(map.get('c')).toBe(30);
1119
-
1120
- // Clear all entries
1121
- map.clear();
1122
- expect(map.size).toBe(0);
1123
- expect(map.has('a')).toBe(false);
1124
- });
1125
- });