ts-data-forge 5.0.1 → 5.1.1

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 (539) hide show
  1. package/README.md +101 -50
  2. package/dist/array/impl/array-utils-creation.d.mts +14 -0
  3. package/dist/array/impl/array-utils-creation.d.mts.map +1 -1
  4. package/dist/array/impl/array-utils-creation.mjs +12 -0
  5. package/dist/array/impl/array-utils-creation.mjs.map +1 -1
  6. package/dist/array/impl/array-utils-element-access.d.mts +10 -0
  7. package/dist/array/impl/array-utils-element-access.d.mts.map +1 -1
  8. package/dist/array/impl/array-utils-element-access.mjs +6 -0
  9. package/dist/array/impl/array-utils-element-access.mjs.map +1 -1
  10. package/dist/array/impl/array-utils-modification.d.mts +14 -0
  11. package/dist/array/impl/array-utils-modification.d.mts.map +1 -1
  12. package/dist/array/impl/array-utils-modification.mjs.map +1 -1
  13. package/dist/array/impl/array-utils-reducing-value.d.mts +34 -10
  14. package/dist/array/impl/array-utils-reducing-value.d.mts.map +1 -1
  15. package/dist/array/impl/array-utils-reducing-value.mjs.map +1 -1
  16. package/dist/array/impl/array-utils-search.d.mts +34 -4
  17. package/dist/array/impl/array-utils-search.d.mts.map +1 -1
  18. package/dist/array/impl/array-utils-search.mjs.map +1 -1
  19. package/dist/array/impl/array-utils-set-op.d.mts +20 -7
  20. package/dist/array/impl/array-utils-set-op.d.mts.map +1 -1
  21. package/dist/array/impl/array-utils-set-op.mjs +20 -7
  22. package/dist/array/impl/array-utils-set-op.mjs.map +1 -1
  23. package/dist/array/impl/array-utils-size.d.mts +5 -2
  24. package/dist/array/impl/array-utils-size.d.mts.map +1 -1
  25. package/dist/array/impl/array-utils-size.mjs +5 -2
  26. package/dist/array/impl/array-utils-size.mjs.map +1 -1
  27. package/dist/array/impl/array-utils-slice-clamped.d.mts +2 -0
  28. package/dist/array/impl/array-utils-slice-clamped.d.mts.map +1 -1
  29. package/dist/array/impl/array-utils-slice-clamped.mjs.map +1 -1
  30. package/dist/array/impl/array-utils-slicing.d.mts +17 -2
  31. package/dist/array/impl/array-utils-slicing.d.mts.map +1 -1
  32. package/dist/array/impl/array-utils-slicing.mjs +9 -2
  33. package/dist/array/impl/array-utils-slicing.mjs.map +1 -1
  34. package/dist/array/impl/array-utils-transformation.d.mts +27 -0
  35. package/dist/array/impl/array-utils-transformation.d.mts.map +1 -1
  36. package/dist/array/impl/array-utils-transformation.mjs +6 -0
  37. package/dist/array/impl/array-utils-transformation.mjs.map +1 -1
  38. package/dist/array/impl/array-utils-validation.d.mts +35 -18
  39. package/dist/array/impl/array-utils-validation.d.mts.map +1 -1
  40. package/dist/array/impl/array-utils-validation.mjs +25 -14
  41. package/dist/array/impl/array-utils-validation.mjs.map +1 -1
  42. package/dist/collections/imap-mapped.mjs.map +1 -1
  43. package/dist/collections/imap.d.mts +35 -15
  44. package/dist/collections/imap.d.mts.map +1 -1
  45. package/dist/collections/imap.mjs +5 -3
  46. package/dist/collections/imap.mjs.map +1 -1
  47. package/dist/collections/iset-mapped.d.mts +46 -19
  48. package/dist/collections/iset-mapped.d.mts.map +1 -1
  49. package/dist/collections/iset-mapped.mjs +9 -2
  50. package/dist/collections/iset-mapped.mjs.map +1 -1
  51. package/dist/collections/iset.d.mts +48 -19
  52. package/dist/collections/iset.d.mts.map +1 -1
  53. package/dist/collections/iset.mjs +9 -2
  54. package/dist/collections/iset.mjs.map +1 -1
  55. package/dist/collections/queue.d.mts +65 -25
  56. package/dist/collections/queue.d.mts.map +1 -1
  57. package/dist/collections/queue.mjs +13 -5
  58. package/dist/collections/queue.mjs.map +1 -1
  59. package/dist/collections/stack.d.mts +60 -25
  60. package/dist/collections/stack.d.mts.map +1 -1
  61. package/dist/collections/stack.mjs +12 -5
  62. package/dist/collections/stack.mjs.map +1 -1
  63. package/dist/entry-point.mjs +1 -1
  64. package/dist/functional/match.d.mts +1 -1
  65. package/dist/functional/match.d.mts.map +1 -1
  66. package/dist/functional/match.mjs.map +1 -1
  67. package/dist/functional/optional/impl/optional-expect-to-be.d.mts +3 -2
  68. package/dist/functional/optional/impl/optional-expect-to-be.d.mts.map +1 -1
  69. package/dist/functional/optional/impl/optional-expect-to-be.mjs.map +1 -1
  70. package/dist/functional/optional/impl/optional-filter.d.mts +3 -0
  71. package/dist/functional/optional/impl/optional-filter.d.mts.map +1 -1
  72. package/dist/functional/optional/impl/optional-filter.mjs.map +1 -1
  73. package/dist/functional/optional/impl/optional-flat-map.d.mts +2 -0
  74. package/dist/functional/optional/impl/optional-flat-map.d.mts.map +1 -1
  75. package/dist/functional/optional/impl/optional-flat-map.mjs.map +1 -1
  76. package/dist/functional/optional/impl/optional-from-nullable.d.mts +2 -0
  77. package/dist/functional/optional/impl/optional-from-nullable.d.mts.map +1 -1
  78. package/dist/functional/optional/impl/optional-from-nullable.mjs +2 -0
  79. package/dist/functional/optional/impl/optional-from-nullable.mjs.map +1 -1
  80. package/dist/functional/optional/impl/optional-is-none.d.mts +1 -1
  81. package/dist/functional/optional/impl/optional-is-none.mjs +1 -1
  82. package/dist/functional/optional/impl/optional-is-optional.d.mts +4 -2
  83. package/dist/functional/optional/impl/optional-is-optional.d.mts.map +1 -1
  84. package/dist/functional/optional/impl/optional-is-optional.mjs +4 -2
  85. package/dist/functional/optional/impl/optional-is-optional.mjs.map +1 -1
  86. package/dist/functional/optional/impl/optional-is-some.d.mts +2 -1
  87. package/dist/functional/optional/impl/optional-is-some.d.mts.map +1 -1
  88. package/dist/functional/optional/impl/optional-is-some.mjs +2 -1
  89. package/dist/functional/optional/impl/optional-is-some.mjs.map +1 -1
  90. package/dist/functional/optional/impl/optional-map.d.mts +2 -0
  91. package/dist/functional/optional/impl/optional-map.d.mts.map +1 -1
  92. package/dist/functional/optional/impl/optional-map.mjs.map +1 -1
  93. package/dist/functional/optional/impl/optional-none.d.mts +4 -2
  94. package/dist/functional/optional/impl/optional-none.d.mts.map +1 -1
  95. package/dist/functional/optional/impl/optional-none.mjs +4 -2
  96. package/dist/functional/optional/impl/optional-none.mjs.map +1 -1
  97. package/dist/functional/optional/impl/optional-or-else.d.mts +4 -0
  98. package/dist/functional/optional/impl/optional-or-else.d.mts.map +1 -1
  99. package/dist/functional/optional/impl/optional-or-else.mjs.map +1 -1
  100. package/dist/functional/optional/impl/optional-some.d.mts +5 -3
  101. package/dist/functional/optional/impl/optional-some.d.mts.map +1 -1
  102. package/dist/functional/optional/impl/optional-some.mjs +4 -2
  103. package/dist/functional/optional/impl/optional-some.mjs.map +1 -1
  104. package/dist/functional/optional/impl/optional-to-nullable.d.mts +4 -2
  105. package/dist/functional/optional/impl/optional-to-nullable.d.mts.map +1 -1
  106. package/dist/functional/optional/impl/optional-to-nullable.mjs +4 -2
  107. package/dist/functional/optional/impl/optional-to-nullable.mjs.map +1 -1
  108. package/dist/functional/optional/impl/optional-unwrap-or.d.mts +7 -4
  109. package/dist/functional/optional/impl/optional-unwrap-or.d.mts.map +1 -1
  110. package/dist/functional/optional/impl/optional-unwrap-or.mjs.map +1 -1
  111. package/dist/functional/optional/impl/optional-unwrap-throw.d.mts +2 -1
  112. package/dist/functional/optional/impl/optional-unwrap-throw.d.mts.map +1 -1
  113. package/dist/functional/optional/impl/optional-unwrap-throw.mjs +2 -1
  114. package/dist/functional/optional/impl/optional-unwrap-throw.mjs.map +1 -1
  115. package/dist/functional/optional/impl/optional-unwrap.d.mts +4 -2
  116. package/dist/functional/optional/impl/optional-unwrap.d.mts.map +1 -1
  117. package/dist/functional/optional/impl/optional-unwrap.mjs.map +1 -1
  118. package/dist/functional/optional/impl/optional-zip.d.mts +3 -1
  119. package/dist/functional/optional/impl/optional-zip.d.mts.map +1 -1
  120. package/dist/functional/optional/impl/optional-zip.mjs +3 -1
  121. package/dist/functional/optional/impl/optional-zip.mjs.map +1 -1
  122. package/dist/functional/pipe.d.mts +2 -2
  123. package/dist/functional/result/impl/result-err.d.mts +4 -2
  124. package/dist/functional/result/impl/result-err.d.mts.map +1 -1
  125. package/dist/functional/result/impl/result-err.mjs +3 -1
  126. package/dist/functional/result/impl/result-err.mjs.map +1 -1
  127. package/dist/functional/result/impl/result-expect-to-be.d.mts +3 -2
  128. package/dist/functional/result/impl/result-expect-to-be.d.mts.map +1 -1
  129. package/dist/functional/result/impl/result-expect-to-be.mjs.map +1 -1
  130. package/dist/functional/result/impl/result-flat-map.d.mts +5 -0
  131. package/dist/functional/result/impl/result-flat-map.d.mts.map +1 -1
  132. package/dist/functional/result/impl/result-flat-map.mjs.map +1 -1
  133. package/dist/functional/result/impl/result-fold.d.mts +4 -0
  134. package/dist/functional/result/impl/result-fold.d.mts.map +1 -1
  135. package/dist/functional/result/impl/result-fold.mjs.map +1 -1
  136. package/dist/functional/result/impl/result-from-promise.d.mts +4 -1
  137. package/dist/functional/result/impl/result-from-promise.d.mts.map +1 -1
  138. package/dist/functional/result/impl/result-from-promise.mjs +4 -1
  139. package/dist/functional/result/impl/result-from-promise.mjs.map +1 -1
  140. package/dist/functional/result/impl/result-from-throwable.d.mts +3 -1
  141. package/dist/functional/result/impl/result-from-throwable.d.mts.map +1 -1
  142. package/dist/functional/result/impl/result-from-throwable.mjs +3 -1
  143. package/dist/functional/result/impl/result-from-throwable.mjs.map +1 -1
  144. package/dist/functional/result/impl/result-is-err.d.mts +4 -2
  145. package/dist/functional/result/impl/result-is-err.d.mts.map +1 -1
  146. package/dist/functional/result/impl/result-is-err.mjs +4 -2
  147. package/dist/functional/result/impl/result-is-err.mjs.map +1 -1
  148. package/dist/functional/result/impl/result-is-ok.d.mts +4 -2
  149. package/dist/functional/result/impl/result-is-ok.d.mts.map +1 -1
  150. package/dist/functional/result/impl/result-is-ok.mjs +4 -2
  151. package/dist/functional/result/impl/result-is-ok.mjs.map +1 -1
  152. package/dist/functional/result/impl/result-is-result.d.mts +7 -3
  153. package/dist/functional/result/impl/result-is-result.d.mts.map +1 -1
  154. package/dist/functional/result/impl/result-is-result.mjs +7 -3
  155. package/dist/functional/result/impl/result-is-result.mjs.map +1 -1
  156. package/dist/functional/result/impl/result-map-err.d.mts +3 -0
  157. package/dist/functional/result/impl/result-map-err.d.mts.map +1 -1
  158. package/dist/functional/result/impl/result-map-err.mjs.map +1 -1
  159. package/dist/functional/result/impl/result-map.d.mts +4 -0
  160. package/dist/functional/result/impl/result-map.d.mts.map +1 -1
  161. package/dist/functional/result/impl/result-map.mjs.map +1 -1
  162. package/dist/functional/result/impl/result-ok.d.mts +4 -2
  163. package/dist/functional/result/impl/result-ok.d.mts.map +1 -1
  164. package/dist/functional/result/impl/result-ok.mjs +3 -1
  165. package/dist/functional/result/impl/result-ok.mjs.map +1 -1
  166. package/dist/functional/result/impl/result-or-else.d.mts +4 -0
  167. package/dist/functional/result/impl/result-or-else.d.mts.map +1 -1
  168. package/dist/functional/result/impl/result-or-else.mjs.map +1 -1
  169. package/dist/functional/result/impl/result-swap.d.mts +2 -0
  170. package/dist/functional/result/impl/result-swap.d.mts.map +1 -1
  171. package/dist/functional/result/impl/result-swap.mjs +2 -0
  172. package/dist/functional/result/impl/result-swap.mjs.map +1 -1
  173. package/dist/functional/result/impl/result-to-optional.d.mts +2 -0
  174. package/dist/functional/result/impl/result-to-optional.d.mts.map +1 -1
  175. package/dist/functional/result/impl/result-to-optional.mjs +2 -0
  176. package/dist/functional/result/impl/result-to-optional.mjs.map +1 -1
  177. package/dist/functional/result/impl/result-unwrap-err-or.d.mts +7 -4
  178. package/dist/functional/result/impl/result-unwrap-err-or.d.mts.map +1 -1
  179. package/dist/functional/result/impl/result-unwrap-err-or.mjs.map +1 -1
  180. package/dist/functional/result/impl/result-unwrap-err-throw.d.mts +3 -1
  181. package/dist/functional/result/impl/result-unwrap-err-throw.d.mts.map +1 -1
  182. package/dist/functional/result/impl/result-unwrap-err-throw.mjs +3 -1
  183. package/dist/functional/result/impl/result-unwrap-err-throw.mjs.map +1 -1
  184. package/dist/functional/result/impl/result-unwrap-err.d.mts +3 -2
  185. package/dist/functional/result/impl/result-unwrap-err.d.mts.map +1 -1
  186. package/dist/functional/result/impl/result-unwrap-err.mjs +3 -2
  187. package/dist/functional/result/impl/result-unwrap-err.mjs.map +1 -1
  188. package/dist/functional/result/impl/result-unwrap-ok-or.d.mts +7 -4
  189. package/dist/functional/result/impl/result-unwrap-ok-or.d.mts.map +1 -1
  190. package/dist/functional/result/impl/result-unwrap-ok-or.mjs.map +1 -1
  191. package/dist/functional/result/impl/result-unwrap-ok.d.mts +3 -2
  192. package/dist/functional/result/impl/result-unwrap-ok.d.mts.map +1 -1
  193. package/dist/functional/result/impl/result-unwrap-ok.mjs.map +1 -1
  194. package/dist/functional/result/impl/result-unwrap-throw.d.mts +3 -1
  195. package/dist/functional/result/impl/result-unwrap-throw.d.mts.map +1 -1
  196. package/dist/functional/result/impl/result-unwrap-throw.mjs +3 -1
  197. package/dist/functional/result/impl/result-unwrap-throw.mjs.map +1 -1
  198. package/dist/functional/result/impl/result-zip.d.mts +3 -1
  199. package/dist/functional/result/impl/result-zip.d.mts.map +1 -1
  200. package/dist/functional/result/impl/result-zip.mjs +3 -1
  201. package/dist/functional/result/impl/result-zip.mjs.map +1 -1
  202. package/dist/functional/ternary-result/impl/ternary-result-err.d.mts +3 -2
  203. package/dist/functional/ternary-result/impl/ternary-result-err.d.mts.map +1 -1
  204. package/dist/functional/ternary-result/impl/ternary-result-err.mjs +2 -1
  205. package/dist/functional/ternary-result/impl/ternary-result-err.mjs.map +1 -1
  206. package/dist/functional/ternary-result/impl/ternary-result-expect-to-be.d.mts +1 -0
  207. package/dist/functional/ternary-result/impl/ternary-result-expect-to-be.d.mts.map +1 -1
  208. package/dist/functional/ternary-result/impl/ternary-result-expect-to-be.mjs.map +1 -1
  209. package/dist/functional/ternary-result/impl/ternary-result-flat-map.d.mts +4 -0
  210. package/dist/functional/ternary-result/impl/ternary-result-flat-map.d.mts.map +1 -1
  211. package/dist/functional/ternary-result/impl/ternary-result-flat-map.mjs.map +1 -1
  212. package/dist/functional/ternary-result/impl/ternary-result-fold.d.mts +2 -0
  213. package/dist/functional/ternary-result/impl/ternary-result-fold.d.mts.map +1 -1
  214. package/dist/functional/ternary-result/impl/ternary-result-fold.mjs.map +1 -1
  215. package/dist/functional/ternary-result/impl/ternary-result-from-promise.d.mts +3 -1
  216. package/dist/functional/ternary-result/impl/ternary-result-from-promise.d.mts.map +1 -1
  217. package/dist/functional/ternary-result/impl/ternary-result-from-promise.mjs +3 -1
  218. package/dist/functional/ternary-result/impl/ternary-result-from-promise.mjs.map +1 -1
  219. package/dist/functional/ternary-result/impl/ternary-result-from-throwable.d.mts +3 -1
  220. package/dist/functional/ternary-result/impl/ternary-result-from-throwable.d.mts.map +1 -1
  221. package/dist/functional/ternary-result/impl/ternary-result-from-throwable.mjs +3 -1
  222. package/dist/functional/ternary-result/impl/ternary-result-from-throwable.mjs.map +1 -1
  223. package/dist/functional/ternary-result/impl/ternary-result-is-ok.d.mts +1 -0
  224. package/dist/functional/ternary-result/impl/ternary-result-is-ok.d.mts.map +1 -1
  225. package/dist/functional/ternary-result/impl/ternary-result-is-ok.mjs +1 -0
  226. package/dist/functional/ternary-result/impl/ternary-result-is-ok.mjs.map +1 -1
  227. package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.d.mts +7 -3
  228. package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.d.mts.map +1 -1
  229. package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.mjs +7 -3
  230. package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.mjs.map +1 -1
  231. package/dist/functional/ternary-result/impl/ternary-result-is-warn.d.mts +1 -0
  232. package/dist/functional/ternary-result/impl/ternary-result-is-warn.d.mts.map +1 -1
  233. package/dist/functional/ternary-result/impl/ternary-result-is-warn.mjs +1 -0
  234. package/dist/functional/ternary-result/impl/ternary-result-is-warn.mjs.map +1 -1
  235. package/dist/functional/ternary-result/impl/ternary-result-map-err.d.mts +3 -0
  236. package/dist/functional/ternary-result/impl/ternary-result-map-err.d.mts.map +1 -1
  237. package/dist/functional/ternary-result/impl/ternary-result-map-err.mjs.map +1 -1
  238. package/dist/functional/ternary-result/impl/ternary-result-map-warn.d.mts +3 -0
  239. package/dist/functional/ternary-result/impl/ternary-result-map-warn.d.mts.map +1 -1
  240. package/dist/functional/ternary-result/impl/ternary-result-map-warn.mjs.map +1 -1
  241. package/dist/functional/ternary-result/impl/ternary-result-map.d.mts +6 -0
  242. package/dist/functional/ternary-result/impl/ternary-result-map.d.mts.map +1 -1
  243. package/dist/functional/ternary-result/impl/ternary-result-map.mjs.map +1 -1
  244. package/dist/functional/ternary-result/impl/ternary-result-ok.d.mts +1 -1
  245. package/dist/functional/ternary-result/impl/ternary-result-ok.d.mts.map +1 -1
  246. package/dist/functional/ternary-result/impl/ternary-result-ok.mjs.map +1 -1
  247. package/dist/functional/ternary-result/impl/ternary-result-or-else.d.mts +2 -0
  248. package/dist/functional/ternary-result/impl/ternary-result-or-else.d.mts.map +1 -1
  249. package/dist/functional/ternary-result/impl/ternary-result-or-else.mjs.map +1 -1
  250. package/dist/functional/ternary-result/impl/ternary-result-to-optional.d.mts +2 -0
  251. package/dist/functional/ternary-result/impl/ternary-result-to-optional.d.mts.map +1 -1
  252. package/dist/functional/ternary-result/impl/ternary-result-to-optional.mjs +2 -0
  253. package/dist/functional/ternary-result/impl/ternary-result-to-optional.mjs.map +1 -1
  254. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-or.d.mts +2 -0
  255. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-or.d.mts.map +1 -1
  256. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-or.mjs.map +1 -1
  257. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.d.mts +1 -0
  258. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.d.mts.map +1 -1
  259. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.mjs +1 -0
  260. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.mjs.map +1 -1
  261. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.d.mts +2 -0
  262. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.d.mts.map +1 -1
  263. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.mjs +2 -0
  264. package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.mjs.map +1 -1
  265. package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok-or.d.mts +2 -0
  266. package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok-or.d.mts.map +1 -1
  267. package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok-or.mjs.map +1 -1
  268. package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok.d.mts +2 -0
  269. package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok.d.mts.map +1 -1
  270. package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok.mjs.map +1 -1
  271. package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.d.mts +1 -0
  272. package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.d.mts.map +1 -1
  273. package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.mjs +1 -0
  274. package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.mjs.map +1 -1
  275. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-or.d.mts +2 -0
  276. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-or.d.mts.map +1 -1
  277. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-or.mjs.map +1 -1
  278. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.d.mts +1 -0
  279. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.d.mts.map +1 -1
  280. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.mjs +1 -0
  281. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.mjs.map +1 -1
  282. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.d.mts +2 -0
  283. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.d.mts.map +1 -1
  284. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.mjs +2 -0
  285. package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.mjs.map +1 -1
  286. package/dist/functional/ternary-result/impl/ternary-result-warn.d.mts +1 -1
  287. package/dist/functional/ternary-result/impl/ternary-result-warn.d.mts.map +1 -1
  288. package/dist/functional/ternary-result/impl/ternary-result-warn.mjs.map +1 -1
  289. package/dist/functional/ternary-result/impl/ternary-result-zip.d.mts +4 -0
  290. package/dist/functional/ternary-result/impl/ternary-result-zip.d.mts.map +1 -1
  291. package/dist/functional/ternary-result/impl/ternary-result-zip.mjs +4 -0
  292. package/dist/functional/ternary-result/impl/ternary-result-zip.mjs.map +1 -1
  293. package/dist/globals.d.mts +12 -1
  294. package/dist/guard/has-key.d.mts +6 -3
  295. package/dist/guard/has-key.d.mts.map +1 -1
  296. package/dist/guard/has-key.mjs +2 -2
  297. package/dist/guard/index.mjs +1 -1
  298. package/dist/guard/is-record.d.mts +31 -0
  299. package/dist/guard/is-record.d.mts.map +1 -1
  300. package/dist/guard/is-record.mjs +32 -1
  301. package/dist/guard/is-record.mjs.map +1 -1
  302. package/dist/guard/is-type.d.mts +3 -0
  303. package/dist/guard/is-type.d.mts.map +1 -1
  304. package/dist/guard/is-type.mjs +3 -0
  305. package/dist/guard/is-type.mjs.map +1 -1
  306. package/dist/guard/key-is-in.d.mts +3 -2
  307. package/dist/guard/key-is-in.d.mts.map +1 -1
  308. package/dist/guard/key-is-in.mjs +3 -2
  309. package/dist/guard/key-is-in.mjs.map +1 -1
  310. package/dist/index.mjs +1 -1
  311. package/dist/iterator/range.d.mts +4 -0
  312. package/dist/iterator/range.d.mts.map +1 -1
  313. package/dist/iterator/range.mjs +1 -0
  314. package/dist/iterator/range.mjs.map +1 -1
  315. package/dist/json/json.d.mts +42 -21
  316. package/dist/json/json.d.mts.map +1 -1
  317. package/dist/json/json.mjs +42 -21
  318. package/dist/json/json.mjs.map +1 -1
  319. package/dist/number/branded-types/int.d.mts +33 -19
  320. package/dist/number/branded-types/int.d.mts.map +1 -1
  321. package/dist/number/branded-types/int.mjs +33 -19
  322. package/dist/number/branded-types/int.mjs.map +1 -1
  323. package/dist/number/branded-types/non-zero-safe-int.mjs +2 -2
  324. package/dist/number/branded-types/positive-int.d.mts +34 -20
  325. package/dist/number/branded-types/positive-int.d.mts.map +1 -1
  326. package/dist/number/branded-types/positive-int.mjs +34 -20
  327. package/dist/number/branded-types/positive-int.mjs.map +1 -1
  328. package/dist/number/branded-types/positive-safe-int.d.mts +47 -26
  329. package/dist/number/branded-types/positive-safe-int.d.mts.map +1 -1
  330. package/dist/number/branded-types/positive-safe-int.mjs +48 -27
  331. package/dist/number/branded-types/positive-safe-int.mjs.map +1 -1
  332. package/dist/number/branded-types/safe-int.d.mts +48 -27
  333. package/dist/number/branded-types/safe-int.d.mts.map +1 -1
  334. package/dist/number/branded-types/safe-int.mjs +50 -29
  335. package/dist/number/branded-types/safe-int.mjs.map +1 -1
  336. package/dist/number/branded-types/safe-uint.mjs +1 -1
  337. package/dist/number/branded-types/uint.d.mts +31 -19
  338. package/dist/number/branded-types/uint.d.mts.map +1 -1
  339. package/dist/number/branded-types/uint.mjs +31 -19
  340. package/dist/number/branded-types/uint.mjs.map +1 -1
  341. package/dist/number/num.d.mts +29 -20
  342. package/dist/number/num.d.mts.map +1 -1
  343. package/dist/number/num.mjs +24 -17
  344. package/dist/number/num.mjs.map +1 -1
  345. package/dist/number/refined-number-utils.d.mts +33 -11
  346. package/dist/number/refined-number-utils.d.mts.map +1 -1
  347. package/dist/number/refined-number-utils.mjs +33 -11
  348. package/dist/number/refined-number-utils.mjs.map +1 -1
  349. package/dist/object/object.d.mts +12 -3
  350. package/dist/object/object.d.mts.map +1 -1
  351. package/dist/object/object.mjs +10 -3
  352. package/dist/object/object.mjs.map +1 -1
  353. package/dist/others/map-nullable.mjs.map +1 -1
  354. package/dist/others/tuple.d.mts +14 -3
  355. package/dist/others/tuple.d.mts.map +1 -1
  356. package/dist/others/tuple.mjs +14 -3
  357. package/dist/others/tuple.mjs.map +1 -1
  358. package/dist/others/unknown-to-string.d.mts.map +1 -1
  359. package/dist/others/unknown-to-string.mjs.map +1 -1
  360. package/dist/promise/promise.d.mts +8 -4
  361. package/dist/promise/promise.d.mts.map +1 -1
  362. package/dist/promise/promise.mjs +8 -4
  363. package/dist/promise/promise.mjs.map +1 -1
  364. package/package.json +26 -28
  365. package/src/array/impl/array-utils-creation.mts +20 -0
  366. package/src/array/impl/array-utils-creation.test.mts +72 -1
  367. package/src/array/impl/array-utils-element-access.mts +13 -0
  368. package/src/array/impl/array-utils-element-access.test.mts +36 -15
  369. package/src/array/impl/array-utils-iterators.test.mts +17 -0
  370. package/src/array/impl/array-utils-modification.mts +78 -19
  371. package/src/array/impl/array-utils-modification.test.mts +75 -0
  372. package/src/array/impl/array-utils-overload-type-error.test.mts +19 -0
  373. package/src/array/impl/array-utils-reducing-value.mts +61 -16
  374. package/src/array/impl/array-utils-reducing-value.test.mts +107 -25
  375. package/src/array/impl/array-utils-search.mts +57 -4
  376. package/src/array/impl/array-utils-search.test.mts +61 -10
  377. package/src/array/impl/array-utils-set-op.mts +26 -7
  378. package/src/array/impl/array-utils-set-op.test.mts +129 -13
  379. package/src/array/impl/array-utils-size.mts +5 -2
  380. package/src/array/impl/array-utils-size.test.mts +1 -0
  381. package/src/array/impl/array-utils-slice-clamped.mts +7 -0
  382. package/src/array/impl/array-utils-slice-clamped.test.mts +20 -0
  383. package/src/array/impl/array-utils-slicing.mts +29 -2
  384. package/src/array/impl/array-utils-slicing.test.mts +57 -0
  385. package/src/array/impl/array-utils-transformation.mts +58 -0
  386. package/src/array/impl/array-utils-transformation.test.mts +115 -3
  387. package/src/array/impl/array-utils-validation.mts +41 -18
  388. package/src/array/impl/array-utils-validation.test.mts +176 -78
  389. package/src/array/impl/array.test.mts +18 -6
  390. package/src/collections/imap-mapped.mts +11 -0
  391. package/src/collections/imap-mapped.test.mts +86 -18
  392. package/src/collections/imap.mts +47 -15
  393. package/src/collections/imap.test.mts +137 -31
  394. package/src/collections/iset-mapped.mts +54 -19
  395. package/src/collections/iset-mapped.test.mts +163 -52
  396. package/src/collections/iset.mts +53 -19
  397. package/src/collections/iset.test.mts +323 -130
  398. package/src/collections/queue.mts +78 -25
  399. package/src/collections/queue.test.mts +65 -35
  400. package/src/collections/stack.mts +67 -25
  401. package/src/collections/stack.test.mts +59 -15
  402. package/src/functional/match.mts +17 -1
  403. package/src/functional/match.test.mts +2 -0
  404. package/src/functional/optional/impl/optional-expect-to-be.mts +5 -2
  405. package/src/functional/optional/impl/optional-filter.mts +6 -0
  406. package/src/functional/optional/impl/optional-flat-map.mts +4 -0
  407. package/src/functional/optional/impl/optional-from-nullable.mts +2 -0
  408. package/src/functional/optional/impl/optional-is-none.mts +1 -1
  409. package/src/functional/optional/impl/optional-is-optional.mts +4 -2
  410. package/src/functional/optional/impl/optional-is-some.mts +2 -1
  411. package/src/functional/optional/impl/optional-map.mts +5 -0
  412. package/src/functional/optional/impl/optional-none.mts +4 -2
  413. package/src/functional/optional/impl/optional-or-else.mts +6 -0
  414. package/src/functional/optional/impl/optional-some.mts +5 -3
  415. package/src/functional/optional/impl/optional-to-nullable.mts +4 -2
  416. package/src/functional/optional/impl/optional-unwrap-or.mts +9 -4
  417. package/src/functional/optional/impl/optional-unwrap-throw.mts +2 -1
  418. package/src/functional/optional/impl/optional-unwrap.mts +4 -2
  419. package/src/functional/optional/impl/optional-zip.mts +3 -1
  420. package/src/functional/optional.test.mts +126 -54
  421. package/src/functional/pipe.mts +2 -2
  422. package/src/functional/pipe.test.mts +7 -4
  423. package/src/functional/result/impl/result-err.mts +4 -2
  424. package/src/functional/result/impl/result-expect-to-be.mts +5 -2
  425. package/src/functional/result/impl/result-flat-map.mts +7 -0
  426. package/src/functional/result/impl/result-fold.mts +6 -0
  427. package/src/functional/result/impl/result-from-promise.mts +4 -1
  428. package/src/functional/result/impl/result-from-throwable.mts +5 -1
  429. package/src/functional/result/impl/result-is-err.mts +4 -2
  430. package/src/functional/result/impl/result-is-ok.mts +4 -2
  431. package/src/functional/result/impl/result-is-result.mts +7 -3
  432. package/src/functional/result/impl/result-map-err.mts +5 -0
  433. package/src/functional/result/impl/result-map.mts +6 -0
  434. package/src/functional/result/impl/result-ok.mts +4 -2
  435. package/src/functional/result/impl/result-or-else.mts +6 -0
  436. package/src/functional/result/impl/result-swap.mts +2 -0
  437. package/src/functional/result/impl/result-to-optional.mts +2 -0
  438. package/src/functional/result/impl/result-unwrap-err-or.mts +9 -4
  439. package/src/functional/result/impl/result-unwrap-err-throw.mts +3 -1
  440. package/src/functional/result/impl/result-unwrap-err.mts +3 -2
  441. package/src/functional/result/impl/result-unwrap-ok-or.mts +9 -4
  442. package/src/functional/result/impl/result-unwrap-ok.mts +4 -2
  443. package/src/functional/result/impl/result-unwrap-throw.mts +3 -1
  444. package/src/functional/result/impl/result-zip.mts +3 -1
  445. package/src/functional/result.test.mts +182 -152
  446. package/src/functional/ternary-result/impl/ternary-result-err.mts +3 -2
  447. package/src/functional/ternary-result/impl/ternary-result-expect-to-be.mts +4 -0
  448. package/src/functional/ternary-result/impl/ternary-result-flat-map.mts +7 -0
  449. package/src/functional/ternary-result/impl/ternary-result-fold.mts +5 -0
  450. package/src/functional/ternary-result/impl/ternary-result-from-promise.mts +3 -1
  451. package/src/functional/ternary-result/impl/ternary-result-from-throwable.mts +4 -1
  452. package/src/functional/ternary-result/impl/ternary-result-is-ok.mts +1 -0
  453. package/src/functional/ternary-result/impl/ternary-result-is-ternary-result.mts +7 -3
  454. package/src/functional/ternary-result/impl/ternary-result-is-warn.mts +1 -0
  455. package/src/functional/ternary-result/impl/ternary-result-map-err.mts +6 -0
  456. package/src/functional/ternary-result/impl/ternary-result-map-warn.mts +6 -0
  457. package/src/functional/ternary-result/impl/ternary-result-map.mts +9 -0
  458. package/src/functional/ternary-result/impl/ternary-result-ok.mts +1 -1
  459. package/src/functional/ternary-result/impl/ternary-result-or-else.mts +5 -0
  460. package/src/functional/ternary-result/impl/ternary-result-to-optional.mts +2 -0
  461. package/src/functional/ternary-result/impl/ternary-result-unwrap-err-or.mts +5 -0
  462. package/src/functional/ternary-result/impl/ternary-result-unwrap-err-throw.mts +1 -0
  463. package/src/functional/ternary-result/impl/ternary-result-unwrap-err.mts +2 -0
  464. package/src/functional/ternary-result/impl/ternary-result-unwrap-ok-or.mts +5 -0
  465. package/src/functional/ternary-result/impl/ternary-result-unwrap-ok.mts +3 -0
  466. package/src/functional/ternary-result/impl/ternary-result-unwrap-throw.mts +1 -0
  467. package/src/functional/ternary-result/impl/ternary-result-unwrap-warn-or.mts +5 -0
  468. package/src/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.mts +1 -0
  469. package/src/functional/ternary-result/impl/ternary-result-unwrap-warn.mts +2 -0
  470. package/src/functional/ternary-result/impl/ternary-result-warn.mts +4 -1
  471. package/src/functional/ternary-result/impl/ternary-result-zip.mts +4 -0
  472. package/src/functional/ternary-result.test.mts +99 -8
  473. package/src/globals.d.mts +12 -1
  474. package/src/guard/has-key.mts +8 -5
  475. package/src/guard/has-key.test.mts +9 -5
  476. package/src/guard/is-error.test.mts +143 -0
  477. package/src/guard/is-non-empty-string.test.mts +44 -24
  478. package/src/guard/is-non-null-object.test.mts +45 -26
  479. package/src/guard/is-primitive.test.mts +51 -28
  480. package/src/guard/is-record.mts +34 -0
  481. package/src/guard/is-record.test.mts +28 -7
  482. package/src/guard/is-type.mts +3 -0
  483. package/src/guard/is-type.test.mts +285 -155
  484. package/src/guard/key-is-in.mts +3 -2
  485. package/src/guard/key-is-in.test.mts +2 -2
  486. package/src/iterator/range.mts +9 -0
  487. package/src/json/json.mts +50 -21
  488. package/src/json/json.test.mts +224 -176
  489. package/src/number/branded-types/finite-number.test.mts +51 -11
  490. package/src/number/branded-types/int.mts +33 -19
  491. package/src/number/branded-types/int.test.mts +56 -14
  492. package/src/number/branded-types/int16.test.mts +63 -16
  493. package/src/number/branded-types/int32.test.mts +63 -16
  494. package/src/number/branded-types/non-negative-finite-number.test.mts +52 -12
  495. package/src/number/branded-types/non-negative-int16.test.mts +59 -16
  496. package/src/number/branded-types/non-negative-int32.test.mts +59 -16
  497. package/src/number/branded-types/non-zero-finite-number.test.mts +65 -14
  498. package/src/number/branded-types/non-zero-int.test.mts +72 -19
  499. package/src/number/branded-types/non-zero-int16.test.mts +60 -16
  500. package/src/number/branded-types/non-zero-int32.test.mts +60 -16
  501. package/src/number/branded-types/non-zero-safe-int.mts +2 -2
  502. package/src/number/branded-types/non-zero-safe-int.test.mts +85 -23
  503. package/src/number/branded-types/non-zero-uint16.test.mts +53 -16
  504. package/src/number/branded-types/non-zero-uint32.test.mts +53 -16
  505. package/src/number/branded-types/positive-finite-number.test.mts +59 -14
  506. package/src/number/branded-types/positive-int.mts +34 -20
  507. package/src/number/branded-types/positive-int.test.mts +64 -17
  508. package/src/number/branded-types/positive-int16.test.mts +50 -15
  509. package/src/number/branded-types/positive-int32.test.mts +50 -15
  510. package/src/number/branded-types/positive-safe-int.mts +48 -27
  511. package/src/number/branded-types/positive-safe-int.test.mts +68 -19
  512. package/src/number/branded-types/positive-uint16.test.mts +53 -16
  513. package/src/number/branded-types/positive-uint32.test.mts +53 -16
  514. package/src/number/branded-types/safe-int.mts +50 -29
  515. package/src/number/branded-types/safe-int.test.mts +70 -18
  516. package/src/number/branded-types/safe-uint.mts +1 -1
  517. package/src/number/branded-types/safe-uint.test.mts +65 -17
  518. package/src/number/branded-types/uint.mts +31 -19
  519. package/src/number/branded-types/uint.test.mts +58 -15
  520. package/src/number/branded-types/uint16.test.mts +56 -15
  521. package/src/number/branded-types/uint32.test.mts +56 -15
  522. package/src/number/enum/int8.test.mts +7 -1
  523. package/src/number/enum/uint8.test.mts +7 -1
  524. package/src/number/num.mts +32 -21
  525. package/src/number/num.test.mts +88 -26
  526. package/src/number/refined-number-utils.mts +38 -13
  527. package/src/object/object.mts +19 -3
  528. package/src/object/object.test.mts +16 -6
  529. package/src/others/cast-mutable.test.mts +8 -1
  530. package/src/others/cast-readonly.test.mts +21 -4
  531. package/src/others/if-then.test.mts +40 -24
  532. package/src/others/map-nullable.mts +3 -0
  533. package/src/others/map-nullable.test.mts +27 -0
  534. package/src/others/memoize-function.test.mts +41 -0
  535. package/src/others/tuple.mts +14 -3
  536. package/src/others/unknown-to-string.mts +2 -0
  537. package/src/others/unknown-to-string.test.mts +10 -0
  538. package/src/promise/promise.mts +8 -4
  539. package/src/promise/promise.test.mts +8 -13
@@ -10,7 +10,9 @@ describe('PositiveInt16 test', () => {
10
10
  describe(asPositiveInt16, () => {
11
11
  test('accepts valid positive int16 values', () => {
12
12
  expect(() => asPositiveInt16(1)).not.toThrow();
13
+
13
14
  expect(() => asPositiveInt16(1000)).not.toThrow();
15
+
14
16
  expect(() => asPositiveInt16(32_767)).not.toThrow(); // 2^15 - 1
15
17
  });
16
18
 
@@ -20,29 +22,37 @@ describe('PositiveInt16 test', () => {
20
22
 
21
23
  test('rejects values outside int16 range', () => {
22
24
  expect(() => asPositiveInt16(32_768)).toThrow(TypeError); // 2^15
25
+
23
26
  expect(() => asPositiveInt16(65_536)).toThrow(TypeError);
24
27
  });
25
28
 
26
29
  test('rejects negative integers', () => {
27
30
  expect(() => asPositiveInt16(-1)).toThrow(TypeError);
31
+
28
32
  expect(() => asPositiveInt16(-42)).toThrow(TypeError);
29
33
  });
30
34
 
31
35
  test('rejects non-integers', () => {
32
36
  expect(() => asPositiveInt16(Number.NaN)).toThrow(TypeError);
37
+
33
38
  expect(() => asPositiveInt16(Number.POSITIVE_INFINITY)).toThrow(
34
39
  TypeError,
35
40
  );
41
+
36
42
  expect(() => asPositiveInt16(Number.NEGATIVE_INFINITY)).toThrow(
37
43
  TypeError,
38
44
  );
45
+
39
46
  expect(() => asPositiveInt16(1.2)).toThrow(TypeError);
47
+
40
48
  expect(() => asPositiveInt16(-3.4)).toThrow(TypeError);
41
49
  });
42
50
 
43
51
  test('returns the same value for valid inputs', () => {
44
52
  expect(asPositiveInt16(5)).toBe(5);
53
+
45
54
  expect(asPositiveInt16(1)).toBe(1);
55
+
46
56
  expect(asPositiveInt16(32_767)).toBe(32_767);
47
57
  });
48
58
 
@@ -69,38 +79,48 @@ describe('PositiveInt16 test', () => {
69
79
 
70
80
  describe(isPositiveInt16, () => {
71
81
  test('correctly identifies positive int16 values', () => {
72
- expect(isPositiveInt16(1)).toBe(true);
73
- expect(isPositiveInt16(1000)).toBe(true);
74
- expect(isPositiveInt16(32_767)).toBe(true);
82
+ assert.isTrue(isPositiveInt16(1));
83
+
84
+ assert.isTrue(isPositiveInt16(1000));
85
+
86
+ assert.isTrue(isPositiveInt16(32_767));
75
87
  });
76
88
 
77
89
  test('correctly identifies zero', () => {
78
- expect(isPositiveInt16(0)).toBe(false);
90
+ assert.isFalse(isPositiveInt16(0));
79
91
  });
80
92
 
81
93
  test('correctly identifies values outside int16 range', () => {
82
- expect(isPositiveInt16(32_768)).toBe(false);
83
- expect(isPositiveInt16(65_536)).toBe(false);
94
+ assert.isFalse(isPositiveInt16(32_768));
95
+
96
+ assert.isFalse(isPositiveInt16(65_536));
84
97
  });
85
98
 
86
99
  test('correctly identifies negative integers', () => {
87
- expect(isPositiveInt16(-1)).toBe(false);
88
- expect(isPositiveInt16(-42)).toBe(false);
100
+ assert.isFalse(isPositiveInt16(-1));
101
+
102
+ assert.isFalse(isPositiveInt16(-42));
89
103
  });
90
104
 
91
105
  test('correctly identifies non-integers', () => {
92
- expect(isPositiveInt16(Number.NaN)).toBe(false);
93
- expect(isPositiveInt16(Number.POSITIVE_INFINITY)).toBe(false);
94
- expect(isPositiveInt16(Number.NEGATIVE_INFINITY)).toBe(false);
95
- expect(isPositiveInt16(1.2)).toBe(false);
96
- expect(isPositiveInt16(-3.4)).toBe(false);
106
+ assert.isFalse(isPositiveInt16(Number.NaN));
107
+
108
+ assert.isFalse(isPositiveInt16(Number.POSITIVE_INFINITY));
109
+
110
+ assert.isFalse(isPositiveInt16(Number.NEGATIVE_INFINITY));
111
+
112
+ assert.isFalse(isPositiveInt16(1.2));
113
+
114
+ assert.isFalse(isPositiveInt16(-3.4));
97
115
  });
98
116
  });
99
117
 
100
118
  describe('PositiveInt16.is', () => {
101
119
  test('same as isPositiveInt16 function', () => {
102
120
  expect(PositiveInt16.is(5)).toBe(isPositiveInt16(5));
121
+
103
122
  expect(PositiveInt16.is(0)).toBe(isPositiveInt16(0));
123
+
104
124
  expect(PositiveInt16.is(-1)).toBe(isPositiveInt16(-1));
105
125
  });
106
126
  });
@@ -108,16 +128,19 @@ describe('PositiveInt16 test', () => {
108
128
  describe('constants', () => {
109
129
  test('MIN_VALUE and MAX_VALUE', () => {
110
130
  expect(PositiveInt16.MIN_VALUE).toBe(1);
131
+
111
132
  expect(PositiveInt16.MAX_VALUE).toBe(32_767);
112
133
  });
113
134
  });
114
135
 
115
136
  describe('mathematical operations', () => {
116
137
  const a = asPositiveInt16(100);
138
+
117
139
  const b = asPositiveInt16(50);
118
140
 
119
141
  test('min and max', () => {
120
142
  expect(PositiveInt16.min(a, b)).toBe(50);
143
+
121
144
  expect(PositiveInt16.max(a, b)).toBe(100);
122
145
  });
123
146
 
@@ -128,11 +151,13 @@ describe('PositiveInt16 test', () => {
128
151
  );
129
152
 
130
153
  expect(result).toBe(32_767); // clamped to max
154
+
131
155
  expect(PositiveInt16.add(a, b)).toBe(150);
132
156
  });
133
157
 
134
158
  test('sub (never goes below 1)', () => {
135
159
  expect(PositiveInt16.sub(a, b)).toBe(50);
160
+
136
161
  expect(PositiveInt16.sub(b, a)).toBe(1); // clamped to 1
137
162
  });
138
163
 
@@ -143,6 +168,7 @@ describe('PositiveInt16 test', () => {
143
168
  );
144
169
 
145
170
  expect(result).toBe(32_767); // clamped to max
171
+
146
172
  expect(PositiveInt16.mul(asPositiveInt16(10), asPositiveInt16(5))).toBe(
147
173
  50,
148
174
  );
@@ -150,7 +176,9 @@ describe('PositiveInt16 test', () => {
150
176
 
151
177
  test('div (floor division, never goes below 1)', () => {
152
178
  expect(PositiveInt16.div(a, asPositiveInt16(50))).toBe(2);
179
+
153
180
  expect(PositiveInt16.div(asPositiveInt16(7), asPositiveInt16(3))).toBe(2);
181
+
154
182
  expect(PositiveInt16.div(asPositiveInt16(50), asPositiveInt16(100))).toBe(
155
183
  1,
156
184
  ); // floor(50/100) = 0, clamped to 1
@@ -163,6 +191,7 @@ describe('PositiveInt16 test', () => {
163
191
  );
164
192
 
165
193
  expect(result).toBe(32_767); // clamped to max
194
+
166
195
  expect(PositiveInt16.pow(asPositiveInt16(2), asPositiveInt16(3))).toBe(8);
167
196
  });
168
197
  });
@@ -170,15 +199,20 @@ describe('PositiveInt16 test', () => {
170
199
  describe('random', () => {
171
200
  test('generates positive int16 values within specified range', () => {
172
201
  const min = 1;
202
+
173
203
  const max = 20;
174
204
 
175
205
  for (const _ of range(10)) {
176
206
  const result = PositiveInt16.random(min, max);
177
207
 
178
208
  expect(result).toBeGreaterThanOrEqual(min);
209
+
179
210
  expect(result).toBeLessThanOrEqual(max);
180
- expect(PositiveInt16.is(result)).toBe(true);
181
- expect(Number.isInteger(result)).toBe(true);
211
+
212
+ assert.isTrue(PositiveInt16.is(result));
213
+
214
+ assert.isTrue(Number.isInteger(result));
215
+
182
216
  expect(result).toBeGreaterThan(0);
183
217
  }
184
218
  });
@@ -188,6 +222,7 @@ describe('PositiveInt16 test', () => {
188
222
  const result = PositiveInt16.random(1, 30);
189
223
 
190
224
  expect(result).toBeGreaterThanOrEqual(1);
225
+
191
226
  expect(result).toBeLessThanOrEqual(32_767);
192
227
  }
193
228
  });
@@ -10,7 +10,9 @@ describe('PositiveInt32 test', () => {
10
10
  describe(asPositiveInt32, () => {
11
11
  test('accepts valid positive int32 values', () => {
12
12
  expect(() => asPositiveInt32(1)).not.toThrow();
13
+
13
14
  expect(() => asPositiveInt32(1000)).not.toThrow();
15
+
14
16
  expect(() => asPositiveInt32(2_147_483_647)).not.toThrow(); // 2^31 - 1
15
17
  });
16
18
 
@@ -20,29 +22,37 @@ describe('PositiveInt32 test', () => {
20
22
 
21
23
  test('rejects values outside int32 range', () => {
22
24
  expect(() => asPositiveInt32(2_147_483_648)).toThrow(TypeError); // 2^31
25
+
23
26
  expect(() => asPositiveInt32(4_294_967_296)).toThrow(TypeError);
24
27
  });
25
28
 
26
29
  test('rejects negative integers', () => {
27
30
  expect(() => asPositiveInt32(-1)).toThrow(TypeError);
31
+
28
32
  expect(() => asPositiveInt32(-42)).toThrow(TypeError);
29
33
  });
30
34
 
31
35
  test('rejects non-integers', () => {
32
36
  expect(() => asPositiveInt32(Number.NaN)).toThrow(TypeError);
37
+
33
38
  expect(() => asPositiveInt32(Number.POSITIVE_INFINITY)).toThrow(
34
39
  TypeError,
35
40
  );
41
+
36
42
  expect(() => asPositiveInt32(Number.NEGATIVE_INFINITY)).toThrow(
37
43
  TypeError,
38
44
  );
45
+
39
46
  expect(() => asPositiveInt32(1.2)).toThrow(TypeError);
47
+
40
48
  expect(() => asPositiveInt32(-3.4)).toThrow(TypeError);
41
49
  });
42
50
 
43
51
  test('returns the same value for valid inputs', () => {
44
52
  expect(asPositiveInt32(5)).toBe(5);
53
+
45
54
  expect(asPositiveInt32(1)).toBe(1);
55
+
46
56
  expect(asPositiveInt32(2_147_483_647)).toBe(2_147_483_647);
47
57
  });
48
58
 
@@ -69,38 +79,48 @@ describe('PositiveInt32 test', () => {
69
79
 
70
80
  describe(isPositiveInt32, () => {
71
81
  test('correctly identifies positive int32 values', () => {
72
- expect(isPositiveInt32(1)).toBe(true);
73
- expect(isPositiveInt32(1000)).toBe(true);
74
- expect(isPositiveInt32(2_147_483_647)).toBe(true);
82
+ assert.isTrue(isPositiveInt32(1));
83
+
84
+ assert.isTrue(isPositiveInt32(1000));
85
+
86
+ assert.isTrue(isPositiveInt32(2_147_483_647));
75
87
  });
76
88
 
77
89
  test('correctly identifies zero', () => {
78
- expect(isPositiveInt32(0)).toBe(false);
90
+ assert.isFalse(isPositiveInt32(0));
79
91
  });
80
92
 
81
93
  test('correctly identifies values outside int32 range', () => {
82
- expect(isPositiveInt32(2_147_483_648)).toBe(false);
83
- expect(isPositiveInt32(4_294_967_296)).toBe(false);
94
+ assert.isFalse(isPositiveInt32(2_147_483_648));
95
+
96
+ assert.isFalse(isPositiveInt32(4_294_967_296));
84
97
  });
85
98
 
86
99
  test('correctly identifies negative integers', () => {
87
- expect(isPositiveInt32(-1)).toBe(false);
88
- expect(isPositiveInt32(-42)).toBe(false);
100
+ assert.isFalse(isPositiveInt32(-1));
101
+
102
+ assert.isFalse(isPositiveInt32(-42));
89
103
  });
90
104
 
91
105
  test('correctly identifies non-integers', () => {
92
- expect(isPositiveInt32(Number.NaN)).toBe(false);
93
- expect(isPositiveInt32(Number.POSITIVE_INFINITY)).toBe(false);
94
- expect(isPositiveInt32(Number.NEGATIVE_INFINITY)).toBe(false);
95
- expect(isPositiveInt32(1.2)).toBe(false);
96
- expect(isPositiveInt32(-3.4)).toBe(false);
106
+ assert.isFalse(isPositiveInt32(Number.NaN));
107
+
108
+ assert.isFalse(isPositiveInt32(Number.POSITIVE_INFINITY));
109
+
110
+ assert.isFalse(isPositiveInt32(Number.NEGATIVE_INFINITY));
111
+
112
+ assert.isFalse(isPositiveInt32(1.2));
113
+
114
+ assert.isFalse(isPositiveInt32(-3.4));
97
115
  });
98
116
  });
99
117
 
100
118
  describe('PositiveInt32.is', () => {
101
119
  test('same as isPositiveInt32 function', () => {
102
120
  expect(PositiveInt32.is(5)).toBe(isPositiveInt32(5));
121
+
103
122
  expect(PositiveInt32.is(0)).toBe(isPositiveInt32(0));
123
+
104
124
  expect(PositiveInt32.is(-1)).toBe(isPositiveInt32(-1));
105
125
  });
106
126
  });
@@ -108,16 +128,19 @@ describe('PositiveInt32 test', () => {
108
128
  describe('constants', () => {
109
129
  test('MIN_VALUE and MAX_VALUE', () => {
110
130
  expect(PositiveInt32.MIN_VALUE).toBe(1);
131
+
111
132
  expect(PositiveInt32.MAX_VALUE).toBe(2_147_483_647);
112
133
  });
113
134
  });
114
135
 
115
136
  describe('mathematical operations', () => {
116
137
  const a = asPositiveInt32(1_000_000);
138
+
117
139
  const b = asPositiveInt32(500_000);
118
140
 
119
141
  test('min and max', () => {
120
142
  expect(PositiveInt32.min(a, b)).toBe(500_000);
143
+
121
144
  expect(PositiveInt32.max(a, b)).toBe(1_000_000);
122
145
  });
123
146
 
@@ -128,11 +151,13 @@ describe('PositiveInt32 test', () => {
128
151
  );
129
152
 
130
153
  expect(result).toBe(2_147_483_647); // clamped to max
154
+
131
155
  expect(PositiveInt32.add(a, b)).toBe(1_500_000);
132
156
  });
133
157
 
134
158
  test('sub (never goes below 1)', () => {
135
159
  expect(PositiveInt32.sub(a, b)).toBe(500_000);
160
+
136
161
  expect(PositiveInt32.sub(b, a)).toBe(1); // clamped to 1
137
162
  });
138
163
 
@@ -143,6 +168,7 @@ describe('PositiveInt32 test', () => {
143
168
  );
144
169
 
145
170
  expect(result).toBe(2_147_483_647); // clamped to max
171
+
146
172
  expect(PositiveInt32.mul(asPositiveInt32(1000), asPositiveInt32(5))).toBe(
147
173
  5000,
148
174
  );
@@ -150,7 +176,9 @@ describe('PositiveInt32 test', () => {
150
176
 
151
177
  test('div (floor division, never goes below 1)', () => {
152
178
  expect(PositiveInt32.div(a, asPositiveInt32(500_000))).toBe(2);
179
+
153
180
  expect(PositiveInt32.div(asPositiveInt32(7), asPositiveInt32(3))).toBe(2);
181
+
154
182
  expect(
155
183
  PositiveInt32.div(asPositiveInt32(500_000), asPositiveInt32(1_000_000)),
156
184
  ).toBe(1); // floor(500000/1000000) = 0, clamped to 1
@@ -163,6 +191,7 @@ describe('PositiveInt32 test', () => {
163
191
  );
164
192
 
165
193
  expect(result).toBe(2_147_483_647); // clamped to max
194
+
166
195
  expect(PositiveInt32.pow(asPositiveInt32(2), asPositiveInt32(3))).toBe(8);
167
196
  });
168
197
  });
@@ -170,15 +199,20 @@ describe('PositiveInt32 test', () => {
170
199
  describe('random', () => {
171
200
  test('generates positive int32 values within specified range', () => {
172
201
  const min = 1;
202
+
173
203
  const max = 20;
174
204
 
175
205
  for (const _ of range(10)) {
176
206
  const result = PositiveInt32.random(min, max);
177
207
 
178
208
  expect(result).toBeGreaterThanOrEqual(min);
209
+
179
210
  expect(result).toBeLessThanOrEqual(max);
180
- expect(PositiveInt32.is(result)).toBe(true);
181
- expect(Number.isInteger(result)).toBe(true);
211
+
212
+ assert.isTrue(PositiveInt32.is(result));
213
+
214
+ assert.isTrue(Number.isInteger(result));
215
+
182
216
  expect(result).toBeGreaterThan(0);
183
217
  }
184
218
  });
@@ -188,6 +222,7 @@ describe('PositiveInt32 test', () => {
188
222
  const result = PositiveInt32.random(1, 30);
189
223
 
190
224
  expect(result).toBeGreaterThanOrEqual(1);
225
+
191
226
  expect(result).toBeLessThanOrEqual(2_147_483_647);
192
227
  }
193
228
  });
@@ -26,7 +26,7 @@ const {
26
26
  >({
27
27
  integerOrSafeInteger: 'SafeInteger',
28
28
  MIN_VALUE: 1,
29
- // eslint-disable-next-line total-functions/no-unsafe-type-assertion
29
+ // eslint-disable-next-line total-functions/no-unsafe-type-assertion, math/prefer-number-max-safe-integer
30
30
  MAX_VALUE: Number.MAX_SAFE_INTEGER as SafeUint,
31
31
  typeNameInMessage,
32
32
  } as const);
@@ -38,10 +38,13 @@ const {
38
38
  * @example
39
39
  *
40
40
  * ```ts
41
- * assert.ok(isPositiveSafeInt(1));
42
- * assert.ok(isPositiveSafeInt(Number.MAX_SAFE_INTEGER));
43
- * assert.notOk(isPositiveSafeInt(0));
44
- * assert.ok(PositiveSafeInt.is(42));
41
+ * assert.isTrue(isPositiveSafeInt(1));
42
+ *
43
+ * assert.isTrue(isPositiveSafeInt(Number.MAX_SAFE_INTEGER));
44
+ *
45
+ * assert.isFalse(isPositiveSafeInt(0));
46
+ *
47
+ * assert.isTrue(PositiveSafeInt.is(42));
45
48
  * ```
46
49
  *
47
50
  * @param value The value to check.
@@ -57,8 +60,9 @@ export const isPositiveSafeInt = is;
57
60
  * ```ts
58
61
  * const branded = asPositiveSafeInt(128);
59
62
  *
60
- * assert(branded === 128);
61
- * assert.ok(PositiveSafeInt.is(branded));
63
+ * assert.isTrue(branded === 128);
64
+ *
65
+ * assert.isTrue(PositiveSafeInt.is(branded));
62
66
  * ```
63
67
  *
64
68
  * @param value The value to cast.
@@ -83,10 +87,13 @@ export const PositiveSafeInt = {
83
87
  * @example
84
88
  *
85
89
  * ```ts
86
- * assert.ok(isPositiveSafeInt(1));
87
- * assert.ok(isPositiveSafeInt(Number.MAX_SAFE_INTEGER));
88
- * assert.notOk(isPositiveSafeInt(0));
89
- * assert.ok(PositiveSafeInt.is(42));
90
+ * assert.isTrue(isPositiveSafeInt(1));
91
+ *
92
+ * assert.isTrue(isPositiveSafeInt(Number.MAX_SAFE_INTEGER));
93
+ *
94
+ * assert.isFalse(isPositiveSafeInt(0));
95
+ *
96
+ * assert.isTrue(PositiveSafeInt.is(42));
90
97
  * ```
91
98
  *
92
99
  * @param value The value to check.
@@ -120,7 +127,7 @@ export const PositiveSafeInt = {
120
127
  * asPositiveSafeInt(5),
121
128
  * );
122
129
  *
123
- * assert(smallest === 5);
130
+ * assert.isTrue(smallest === 5);
124
131
  * ```
125
132
  *
126
133
  * @param a The first PositiveSafeInt.
@@ -140,7 +147,7 @@ export const PositiveSafeInt = {
140
147
  * asPositiveSafeInt(5),
141
148
  * );
142
149
  *
143
- * assert(largest === 10);
150
+ * assert.isTrue(largest === 10);
144
151
  * ```
145
152
  *
146
153
  * @param a The first PositiveSafeInt.
@@ -156,12 +163,16 @@ export const PositiveSafeInt = {
156
163
  *
157
164
  * ```ts
158
165
  * const belowRange = PositiveSafeInt.clamp(0);
166
+ *
159
167
  * const withinRange = PositiveSafeInt.clamp(123);
168
+ *
160
169
  * const aboveRange = PositiveSafeInt.clamp(Number.MAX_SAFE_INTEGER + 10);
161
170
  *
162
- * assert(belowRange === 1);
163
- * assert(withinRange === 123);
164
- * assert(aboveRange === Number.MAX_SAFE_INTEGER);
171
+ * assert.isTrue(belowRange === 1);
172
+ *
173
+ * assert.isTrue(withinRange === 123);
174
+ *
175
+ * assert.isTrue(aboveRange === Number.MAX_SAFE_INTEGER);
165
176
  * ```
166
177
  *
167
178
  * @param value The number to clamp.
@@ -176,11 +187,14 @@ export const PositiveSafeInt = {
176
187
  *
177
188
  * ```ts
178
189
  * const min = asPositiveSafeInt(1);
190
+ *
179
191
  * const max = asPositiveSafeInt(6);
192
+ *
180
193
  * const randomValue = PositiveSafeInt.random(min, max);
181
194
  *
182
- * assert.ok(PositiveSafeInt.is(randomValue));
183
- * assert.ok(randomValue >= 1 && randomValue <= 6);
195
+ * assert.isTrue(PositiveSafeInt.is(randomValue));
196
+ *
197
+ * assert.isTrue(randomValue >= 1 && randomValue <= 6);
184
198
  * ```
185
199
  *
186
200
  * @returns A random PositiveSafeInt between 1 and MAX_SAFE_INTEGER.
@@ -194,10 +208,12 @@ export const PositiveSafeInt = {
194
208
  *
195
209
  * ```ts
196
210
  * const base = asPositiveSafeInt(3);
211
+ *
197
212
  * const exponent = asPositiveSafeInt(3);
213
+ *
198
214
  * const power = PositiveSafeInt.pow(base, exponent);
199
215
  *
200
- * assert(power === 27);
216
+ * assert.isTrue(power === 27);
201
217
  * ```
202
218
  *
203
219
  * @param a The base PositiveSafeInt.
@@ -217,8 +233,9 @@ export const PositiveSafeInt = {
217
233
  * asPositiveSafeInt(2048),
218
234
  * );
219
235
  *
220
- * assert(sum === 3048);
221
- * assert.ok(PositiveSafeInt.is(sum));
236
+ * assert.isTrue(sum === 3048);
237
+ *
238
+ * assert.isTrue(PositiveSafeInt.is(sum));
222
239
  * ```
223
240
  *
224
241
  * @param a The first PositiveSafeInt.
@@ -238,8 +255,9 @@ export const PositiveSafeInt = {
238
255
  * asPositiveSafeInt(20),
239
256
  * );
240
257
  *
241
- * assert(difference === 1);
242
- * assert.ok(PositiveSafeInt.is(difference));
258
+ * assert.isTrue(difference === 1);
259
+ *
260
+ * assert.isTrue(PositiveSafeInt.is(difference));
243
261
  * ```
244
262
  *
245
263
  * @param a The minuend PositiveSafeInt.
@@ -260,8 +278,9 @@ export const PositiveSafeInt = {
260
278
  * asPositiveSafeInt(20),
261
279
  * );
262
280
  *
263
- * assert(product === 1000);
264
- * assert.ok(PositiveSafeInt.is(product));
281
+ * assert.isTrue(product === 1000);
282
+ *
283
+ * assert.isTrue(PositiveSafeInt.is(product));
265
284
  * ```
266
285
  *
267
286
  * @param a The first PositiveSafeInt.
@@ -280,13 +299,15 @@ export const PositiveSafeInt = {
280
299
  * asPositiveSafeInt(25),
281
300
  * asPositiveSafeInt(4),
282
301
  * );
302
+ *
283
303
  * const clamped = PositiveSafeInt.div(
284
304
  * asPositiveSafeInt(5),
285
305
  * asPositiveSafeInt(50),
286
306
  * );
287
307
  *
288
- * assert(quotient === 6);
289
- * assert(clamped === 1);
308
+ * assert.isTrue(quotient === 6);
309
+ *
310
+ * assert.isTrue(clamped === 1);
290
311
  * ```
291
312
  *
292
313
  * @param a The dividend PositiveSafeInt.