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.
- package/README.md +101 -50
- package/dist/array/impl/array-utils-creation.d.mts +14 -0
- package/dist/array/impl/array-utils-creation.d.mts.map +1 -1
- package/dist/array/impl/array-utils-creation.mjs +12 -0
- package/dist/array/impl/array-utils-creation.mjs.map +1 -1
- package/dist/array/impl/array-utils-element-access.d.mts +10 -0
- package/dist/array/impl/array-utils-element-access.d.mts.map +1 -1
- package/dist/array/impl/array-utils-element-access.mjs +6 -0
- package/dist/array/impl/array-utils-element-access.mjs.map +1 -1
- package/dist/array/impl/array-utils-modification.d.mts +14 -0
- package/dist/array/impl/array-utils-modification.d.mts.map +1 -1
- package/dist/array/impl/array-utils-modification.mjs.map +1 -1
- package/dist/array/impl/array-utils-reducing-value.d.mts +34 -10
- package/dist/array/impl/array-utils-reducing-value.d.mts.map +1 -1
- package/dist/array/impl/array-utils-reducing-value.mjs.map +1 -1
- package/dist/array/impl/array-utils-search.d.mts +34 -4
- package/dist/array/impl/array-utils-search.d.mts.map +1 -1
- package/dist/array/impl/array-utils-search.mjs.map +1 -1
- package/dist/array/impl/array-utils-set-op.d.mts +20 -7
- package/dist/array/impl/array-utils-set-op.d.mts.map +1 -1
- package/dist/array/impl/array-utils-set-op.mjs +20 -7
- package/dist/array/impl/array-utils-set-op.mjs.map +1 -1
- package/dist/array/impl/array-utils-size.d.mts +5 -2
- package/dist/array/impl/array-utils-size.d.mts.map +1 -1
- package/dist/array/impl/array-utils-size.mjs +5 -2
- package/dist/array/impl/array-utils-size.mjs.map +1 -1
- package/dist/array/impl/array-utils-slice-clamped.d.mts +2 -0
- package/dist/array/impl/array-utils-slice-clamped.d.mts.map +1 -1
- package/dist/array/impl/array-utils-slice-clamped.mjs.map +1 -1
- package/dist/array/impl/array-utils-slicing.d.mts +17 -2
- package/dist/array/impl/array-utils-slicing.d.mts.map +1 -1
- package/dist/array/impl/array-utils-slicing.mjs +9 -2
- package/dist/array/impl/array-utils-slicing.mjs.map +1 -1
- package/dist/array/impl/array-utils-transformation.d.mts +27 -0
- package/dist/array/impl/array-utils-transformation.d.mts.map +1 -1
- package/dist/array/impl/array-utils-transformation.mjs +6 -0
- package/dist/array/impl/array-utils-transformation.mjs.map +1 -1
- package/dist/array/impl/array-utils-validation.d.mts +35 -18
- package/dist/array/impl/array-utils-validation.d.mts.map +1 -1
- package/dist/array/impl/array-utils-validation.mjs +25 -14
- package/dist/array/impl/array-utils-validation.mjs.map +1 -1
- package/dist/collections/imap-mapped.mjs.map +1 -1
- package/dist/collections/imap.d.mts +35 -15
- package/dist/collections/imap.d.mts.map +1 -1
- package/dist/collections/imap.mjs +5 -3
- package/dist/collections/imap.mjs.map +1 -1
- package/dist/collections/iset-mapped.d.mts +46 -19
- package/dist/collections/iset-mapped.d.mts.map +1 -1
- package/dist/collections/iset-mapped.mjs +9 -2
- package/dist/collections/iset-mapped.mjs.map +1 -1
- package/dist/collections/iset.d.mts +48 -19
- package/dist/collections/iset.d.mts.map +1 -1
- package/dist/collections/iset.mjs +9 -2
- package/dist/collections/iset.mjs.map +1 -1
- package/dist/collections/queue.d.mts +65 -25
- package/dist/collections/queue.d.mts.map +1 -1
- package/dist/collections/queue.mjs +13 -5
- package/dist/collections/queue.mjs.map +1 -1
- package/dist/collections/stack.d.mts +60 -25
- package/dist/collections/stack.d.mts.map +1 -1
- package/dist/collections/stack.mjs +12 -5
- package/dist/collections/stack.mjs.map +1 -1
- package/dist/entry-point.mjs +1 -1
- package/dist/functional/match.d.mts +1 -1
- package/dist/functional/match.d.mts.map +1 -1
- package/dist/functional/match.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-expect-to-be.d.mts +3 -2
- package/dist/functional/optional/impl/optional-expect-to-be.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-expect-to-be.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-filter.d.mts +3 -0
- package/dist/functional/optional/impl/optional-filter.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-filter.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-flat-map.d.mts +2 -0
- package/dist/functional/optional/impl/optional-flat-map.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-flat-map.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-from-nullable.d.mts +2 -0
- package/dist/functional/optional/impl/optional-from-nullable.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-from-nullable.mjs +2 -0
- package/dist/functional/optional/impl/optional-from-nullable.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-is-none.d.mts +1 -1
- package/dist/functional/optional/impl/optional-is-none.mjs +1 -1
- package/dist/functional/optional/impl/optional-is-optional.d.mts +4 -2
- package/dist/functional/optional/impl/optional-is-optional.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-is-optional.mjs +4 -2
- package/dist/functional/optional/impl/optional-is-optional.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-is-some.d.mts +2 -1
- package/dist/functional/optional/impl/optional-is-some.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-is-some.mjs +2 -1
- package/dist/functional/optional/impl/optional-is-some.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-map.d.mts +2 -0
- package/dist/functional/optional/impl/optional-map.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-map.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-none.d.mts +4 -2
- package/dist/functional/optional/impl/optional-none.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-none.mjs +4 -2
- package/dist/functional/optional/impl/optional-none.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-or-else.d.mts +4 -0
- package/dist/functional/optional/impl/optional-or-else.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-or-else.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-some.d.mts +5 -3
- package/dist/functional/optional/impl/optional-some.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-some.mjs +4 -2
- package/dist/functional/optional/impl/optional-some.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-to-nullable.d.mts +4 -2
- package/dist/functional/optional/impl/optional-to-nullable.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-to-nullable.mjs +4 -2
- package/dist/functional/optional/impl/optional-to-nullable.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-unwrap-or.d.mts +7 -4
- package/dist/functional/optional/impl/optional-unwrap-or.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-unwrap-or.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-unwrap-throw.d.mts +2 -1
- package/dist/functional/optional/impl/optional-unwrap-throw.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-unwrap-throw.mjs +2 -1
- package/dist/functional/optional/impl/optional-unwrap-throw.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-unwrap.d.mts +4 -2
- package/dist/functional/optional/impl/optional-unwrap.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-unwrap.mjs.map +1 -1
- package/dist/functional/optional/impl/optional-zip.d.mts +3 -1
- package/dist/functional/optional/impl/optional-zip.d.mts.map +1 -1
- package/dist/functional/optional/impl/optional-zip.mjs +3 -1
- package/dist/functional/optional/impl/optional-zip.mjs.map +1 -1
- package/dist/functional/pipe.d.mts +2 -2
- package/dist/functional/result/impl/result-err.d.mts +4 -2
- package/dist/functional/result/impl/result-err.d.mts.map +1 -1
- package/dist/functional/result/impl/result-err.mjs +3 -1
- package/dist/functional/result/impl/result-err.mjs.map +1 -1
- package/dist/functional/result/impl/result-expect-to-be.d.mts +3 -2
- package/dist/functional/result/impl/result-expect-to-be.d.mts.map +1 -1
- package/dist/functional/result/impl/result-expect-to-be.mjs.map +1 -1
- package/dist/functional/result/impl/result-flat-map.d.mts +5 -0
- package/dist/functional/result/impl/result-flat-map.d.mts.map +1 -1
- package/dist/functional/result/impl/result-flat-map.mjs.map +1 -1
- package/dist/functional/result/impl/result-fold.d.mts +4 -0
- package/dist/functional/result/impl/result-fold.d.mts.map +1 -1
- package/dist/functional/result/impl/result-fold.mjs.map +1 -1
- package/dist/functional/result/impl/result-from-promise.d.mts +4 -1
- package/dist/functional/result/impl/result-from-promise.d.mts.map +1 -1
- package/dist/functional/result/impl/result-from-promise.mjs +4 -1
- package/dist/functional/result/impl/result-from-promise.mjs.map +1 -1
- package/dist/functional/result/impl/result-from-throwable.d.mts +3 -1
- package/dist/functional/result/impl/result-from-throwable.d.mts.map +1 -1
- package/dist/functional/result/impl/result-from-throwable.mjs +3 -1
- package/dist/functional/result/impl/result-from-throwable.mjs.map +1 -1
- package/dist/functional/result/impl/result-is-err.d.mts +4 -2
- package/dist/functional/result/impl/result-is-err.d.mts.map +1 -1
- package/dist/functional/result/impl/result-is-err.mjs +4 -2
- package/dist/functional/result/impl/result-is-err.mjs.map +1 -1
- package/dist/functional/result/impl/result-is-ok.d.mts +4 -2
- package/dist/functional/result/impl/result-is-ok.d.mts.map +1 -1
- package/dist/functional/result/impl/result-is-ok.mjs +4 -2
- package/dist/functional/result/impl/result-is-ok.mjs.map +1 -1
- package/dist/functional/result/impl/result-is-result.d.mts +7 -3
- package/dist/functional/result/impl/result-is-result.d.mts.map +1 -1
- package/dist/functional/result/impl/result-is-result.mjs +7 -3
- package/dist/functional/result/impl/result-is-result.mjs.map +1 -1
- package/dist/functional/result/impl/result-map-err.d.mts +3 -0
- package/dist/functional/result/impl/result-map-err.d.mts.map +1 -1
- package/dist/functional/result/impl/result-map-err.mjs.map +1 -1
- package/dist/functional/result/impl/result-map.d.mts +4 -0
- package/dist/functional/result/impl/result-map.d.mts.map +1 -1
- package/dist/functional/result/impl/result-map.mjs.map +1 -1
- package/dist/functional/result/impl/result-ok.d.mts +4 -2
- package/dist/functional/result/impl/result-ok.d.mts.map +1 -1
- package/dist/functional/result/impl/result-ok.mjs +3 -1
- package/dist/functional/result/impl/result-ok.mjs.map +1 -1
- package/dist/functional/result/impl/result-or-else.d.mts +4 -0
- package/dist/functional/result/impl/result-or-else.d.mts.map +1 -1
- package/dist/functional/result/impl/result-or-else.mjs.map +1 -1
- package/dist/functional/result/impl/result-swap.d.mts +2 -0
- package/dist/functional/result/impl/result-swap.d.mts.map +1 -1
- package/dist/functional/result/impl/result-swap.mjs +2 -0
- package/dist/functional/result/impl/result-swap.mjs.map +1 -1
- package/dist/functional/result/impl/result-to-optional.d.mts +2 -0
- package/dist/functional/result/impl/result-to-optional.d.mts.map +1 -1
- package/dist/functional/result/impl/result-to-optional.mjs +2 -0
- package/dist/functional/result/impl/result-to-optional.mjs.map +1 -1
- package/dist/functional/result/impl/result-unwrap-err-or.d.mts +7 -4
- package/dist/functional/result/impl/result-unwrap-err-or.d.mts.map +1 -1
- package/dist/functional/result/impl/result-unwrap-err-or.mjs.map +1 -1
- package/dist/functional/result/impl/result-unwrap-err-throw.d.mts +3 -1
- package/dist/functional/result/impl/result-unwrap-err-throw.d.mts.map +1 -1
- package/dist/functional/result/impl/result-unwrap-err-throw.mjs +3 -1
- package/dist/functional/result/impl/result-unwrap-err-throw.mjs.map +1 -1
- package/dist/functional/result/impl/result-unwrap-err.d.mts +3 -2
- package/dist/functional/result/impl/result-unwrap-err.d.mts.map +1 -1
- package/dist/functional/result/impl/result-unwrap-err.mjs +3 -2
- package/dist/functional/result/impl/result-unwrap-err.mjs.map +1 -1
- package/dist/functional/result/impl/result-unwrap-ok-or.d.mts +7 -4
- package/dist/functional/result/impl/result-unwrap-ok-or.d.mts.map +1 -1
- package/dist/functional/result/impl/result-unwrap-ok-or.mjs.map +1 -1
- package/dist/functional/result/impl/result-unwrap-ok.d.mts +3 -2
- package/dist/functional/result/impl/result-unwrap-ok.d.mts.map +1 -1
- package/dist/functional/result/impl/result-unwrap-ok.mjs.map +1 -1
- package/dist/functional/result/impl/result-unwrap-throw.d.mts +3 -1
- package/dist/functional/result/impl/result-unwrap-throw.d.mts.map +1 -1
- package/dist/functional/result/impl/result-unwrap-throw.mjs +3 -1
- package/dist/functional/result/impl/result-unwrap-throw.mjs.map +1 -1
- package/dist/functional/result/impl/result-zip.d.mts +3 -1
- package/dist/functional/result/impl/result-zip.d.mts.map +1 -1
- package/dist/functional/result/impl/result-zip.mjs +3 -1
- package/dist/functional/result/impl/result-zip.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-err.d.mts +3 -2
- package/dist/functional/ternary-result/impl/ternary-result-err.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-err.mjs +2 -1
- package/dist/functional/ternary-result/impl/ternary-result-err.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-expect-to-be.d.mts +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-expect-to-be.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-expect-to-be.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-flat-map.d.mts +4 -0
- package/dist/functional/ternary-result/impl/ternary-result-flat-map.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-flat-map.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-fold.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-fold.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-fold.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-promise.d.mts +3 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-promise.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-promise.mjs +3 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-promise.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-throwable.d.mts +3 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-throwable.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-throwable.mjs +3 -1
- package/dist/functional/ternary-result/impl/ternary-result-from-throwable.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-is-ok.d.mts +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-is-ok.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-is-ok.mjs +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-is-ok.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.d.mts +7 -3
- package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.mjs +7 -3
- package/dist/functional/ternary-result/impl/ternary-result-is-ternary-result.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-is-warn.d.mts +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-is-warn.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-is-warn.mjs +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-is-warn.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-map-err.d.mts +3 -0
- package/dist/functional/ternary-result/impl/ternary-result-map-err.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-map-err.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-map-warn.d.mts +3 -0
- package/dist/functional/ternary-result/impl/ternary-result-map-warn.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-map-warn.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-map.d.mts +6 -0
- package/dist/functional/ternary-result/impl/ternary-result-map.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-map.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-ok.d.mts +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-ok.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-ok.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-or-else.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-or-else.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-or-else.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-to-optional.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-to-optional.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-to-optional.mjs +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-to-optional.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-or.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-or.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-or.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.d.mts +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.mjs +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err-throw.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.mjs +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-err.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok-or.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok-or.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok-or.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-ok.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.d.mts +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.mjs +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-throw.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-or.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-or.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-or.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.d.mts +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.mjs +1 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.d.mts +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.mjs +2 -0
- package/dist/functional/ternary-result/impl/ternary-result-unwrap-warn.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-warn.d.mts +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-warn.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-warn.mjs.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-zip.d.mts +4 -0
- package/dist/functional/ternary-result/impl/ternary-result-zip.d.mts.map +1 -1
- package/dist/functional/ternary-result/impl/ternary-result-zip.mjs +4 -0
- package/dist/functional/ternary-result/impl/ternary-result-zip.mjs.map +1 -1
- package/dist/globals.d.mts +12 -1
- package/dist/guard/has-key.d.mts +6 -3
- package/dist/guard/has-key.d.mts.map +1 -1
- package/dist/guard/has-key.mjs +2 -2
- package/dist/guard/index.mjs +1 -1
- package/dist/guard/is-record.d.mts +31 -0
- package/dist/guard/is-record.d.mts.map +1 -1
- package/dist/guard/is-record.mjs +32 -1
- package/dist/guard/is-record.mjs.map +1 -1
- package/dist/guard/is-type.d.mts +3 -0
- package/dist/guard/is-type.d.mts.map +1 -1
- package/dist/guard/is-type.mjs +3 -0
- package/dist/guard/is-type.mjs.map +1 -1
- package/dist/guard/key-is-in.d.mts +3 -2
- package/dist/guard/key-is-in.d.mts.map +1 -1
- package/dist/guard/key-is-in.mjs +3 -2
- package/dist/guard/key-is-in.mjs.map +1 -1
- package/dist/index.mjs +1 -1
- package/dist/iterator/range.d.mts +4 -0
- package/dist/iterator/range.d.mts.map +1 -1
- package/dist/iterator/range.mjs +1 -0
- package/dist/iterator/range.mjs.map +1 -1
- package/dist/json/json.d.mts +42 -21
- package/dist/json/json.d.mts.map +1 -1
- package/dist/json/json.mjs +42 -21
- package/dist/json/json.mjs.map +1 -1
- package/dist/number/branded-types/int.d.mts +33 -19
- package/dist/number/branded-types/int.d.mts.map +1 -1
- package/dist/number/branded-types/int.mjs +33 -19
- package/dist/number/branded-types/int.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-safe-int.mjs +2 -2
- package/dist/number/branded-types/positive-int.d.mts +34 -20
- package/dist/number/branded-types/positive-int.d.mts.map +1 -1
- package/dist/number/branded-types/positive-int.mjs +34 -20
- package/dist/number/branded-types/positive-int.mjs.map +1 -1
- package/dist/number/branded-types/positive-safe-int.d.mts +47 -26
- package/dist/number/branded-types/positive-safe-int.d.mts.map +1 -1
- package/dist/number/branded-types/positive-safe-int.mjs +48 -27
- package/dist/number/branded-types/positive-safe-int.mjs.map +1 -1
- package/dist/number/branded-types/safe-int.d.mts +48 -27
- package/dist/number/branded-types/safe-int.d.mts.map +1 -1
- package/dist/number/branded-types/safe-int.mjs +50 -29
- package/dist/number/branded-types/safe-int.mjs.map +1 -1
- package/dist/number/branded-types/safe-uint.mjs +1 -1
- package/dist/number/branded-types/uint.d.mts +31 -19
- package/dist/number/branded-types/uint.d.mts.map +1 -1
- package/dist/number/branded-types/uint.mjs +31 -19
- package/dist/number/branded-types/uint.mjs.map +1 -1
- package/dist/number/num.d.mts +29 -20
- package/dist/number/num.d.mts.map +1 -1
- package/dist/number/num.mjs +24 -17
- package/dist/number/num.mjs.map +1 -1
- package/dist/number/refined-number-utils.d.mts +33 -11
- package/dist/number/refined-number-utils.d.mts.map +1 -1
- package/dist/number/refined-number-utils.mjs +33 -11
- package/dist/number/refined-number-utils.mjs.map +1 -1
- package/dist/object/object.d.mts +12 -3
- package/dist/object/object.d.mts.map +1 -1
- package/dist/object/object.mjs +10 -3
- package/dist/object/object.mjs.map +1 -1
- package/dist/others/map-nullable.mjs.map +1 -1
- package/dist/others/tuple.d.mts +14 -3
- package/dist/others/tuple.d.mts.map +1 -1
- package/dist/others/tuple.mjs +14 -3
- package/dist/others/tuple.mjs.map +1 -1
- package/dist/others/unknown-to-string.d.mts.map +1 -1
- package/dist/others/unknown-to-string.mjs.map +1 -1
- package/dist/promise/promise.d.mts +8 -4
- package/dist/promise/promise.d.mts.map +1 -1
- package/dist/promise/promise.mjs +8 -4
- package/dist/promise/promise.mjs.map +1 -1
- package/package.json +26 -28
- package/src/array/impl/array-utils-creation.mts +20 -0
- package/src/array/impl/array-utils-creation.test.mts +72 -1
- package/src/array/impl/array-utils-element-access.mts +13 -0
- package/src/array/impl/array-utils-element-access.test.mts +36 -15
- package/src/array/impl/array-utils-iterators.test.mts +17 -0
- package/src/array/impl/array-utils-modification.mts +78 -19
- package/src/array/impl/array-utils-modification.test.mts +75 -0
- package/src/array/impl/array-utils-overload-type-error.test.mts +19 -0
- package/src/array/impl/array-utils-reducing-value.mts +61 -16
- package/src/array/impl/array-utils-reducing-value.test.mts +107 -25
- package/src/array/impl/array-utils-search.mts +57 -4
- package/src/array/impl/array-utils-search.test.mts +61 -10
- package/src/array/impl/array-utils-set-op.mts +26 -7
- package/src/array/impl/array-utils-set-op.test.mts +129 -13
- package/src/array/impl/array-utils-size.mts +5 -2
- package/src/array/impl/array-utils-size.test.mts +1 -0
- package/src/array/impl/array-utils-slice-clamped.mts +7 -0
- package/src/array/impl/array-utils-slice-clamped.test.mts +20 -0
- package/src/array/impl/array-utils-slicing.mts +29 -2
- package/src/array/impl/array-utils-slicing.test.mts +57 -0
- package/src/array/impl/array-utils-transformation.mts +58 -0
- package/src/array/impl/array-utils-transformation.test.mts +115 -3
- package/src/array/impl/array-utils-validation.mts +41 -18
- package/src/array/impl/array-utils-validation.test.mts +176 -78
- package/src/array/impl/array.test.mts +18 -6
- package/src/collections/imap-mapped.mts +11 -0
- package/src/collections/imap-mapped.test.mts +86 -18
- package/src/collections/imap.mts +47 -15
- package/src/collections/imap.test.mts +137 -31
- package/src/collections/iset-mapped.mts +54 -19
- package/src/collections/iset-mapped.test.mts +163 -52
- package/src/collections/iset.mts +53 -19
- package/src/collections/iset.test.mts +323 -130
- package/src/collections/queue.mts +78 -25
- package/src/collections/queue.test.mts +65 -35
- package/src/collections/stack.mts +67 -25
- package/src/collections/stack.test.mts +59 -15
- package/src/functional/match.mts +17 -1
- package/src/functional/match.test.mts +2 -0
- package/src/functional/optional/impl/optional-expect-to-be.mts +5 -2
- package/src/functional/optional/impl/optional-filter.mts +6 -0
- package/src/functional/optional/impl/optional-flat-map.mts +4 -0
- package/src/functional/optional/impl/optional-from-nullable.mts +2 -0
- package/src/functional/optional/impl/optional-is-none.mts +1 -1
- package/src/functional/optional/impl/optional-is-optional.mts +4 -2
- package/src/functional/optional/impl/optional-is-some.mts +2 -1
- package/src/functional/optional/impl/optional-map.mts +5 -0
- package/src/functional/optional/impl/optional-none.mts +4 -2
- package/src/functional/optional/impl/optional-or-else.mts +6 -0
- package/src/functional/optional/impl/optional-some.mts +5 -3
- package/src/functional/optional/impl/optional-to-nullable.mts +4 -2
- package/src/functional/optional/impl/optional-unwrap-or.mts +9 -4
- package/src/functional/optional/impl/optional-unwrap-throw.mts +2 -1
- package/src/functional/optional/impl/optional-unwrap.mts +4 -2
- package/src/functional/optional/impl/optional-zip.mts +3 -1
- package/src/functional/optional.test.mts +126 -54
- package/src/functional/pipe.mts +2 -2
- package/src/functional/pipe.test.mts +7 -4
- package/src/functional/result/impl/result-err.mts +4 -2
- package/src/functional/result/impl/result-expect-to-be.mts +5 -2
- package/src/functional/result/impl/result-flat-map.mts +7 -0
- package/src/functional/result/impl/result-fold.mts +6 -0
- package/src/functional/result/impl/result-from-promise.mts +4 -1
- package/src/functional/result/impl/result-from-throwable.mts +5 -1
- package/src/functional/result/impl/result-is-err.mts +4 -2
- package/src/functional/result/impl/result-is-ok.mts +4 -2
- package/src/functional/result/impl/result-is-result.mts +7 -3
- package/src/functional/result/impl/result-map-err.mts +5 -0
- package/src/functional/result/impl/result-map.mts +6 -0
- package/src/functional/result/impl/result-ok.mts +4 -2
- package/src/functional/result/impl/result-or-else.mts +6 -0
- package/src/functional/result/impl/result-swap.mts +2 -0
- package/src/functional/result/impl/result-to-optional.mts +2 -0
- package/src/functional/result/impl/result-unwrap-err-or.mts +9 -4
- package/src/functional/result/impl/result-unwrap-err-throw.mts +3 -1
- package/src/functional/result/impl/result-unwrap-err.mts +3 -2
- package/src/functional/result/impl/result-unwrap-ok-or.mts +9 -4
- package/src/functional/result/impl/result-unwrap-ok.mts +4 -2
- package/src/functional/result/impl/result-unwrap-throw.mts +3 -1
- package/src/functional/result/impl/result-zip.mts +3 -1
- package/src/functional/result.test.mts +182 -152
- package/src/functional/ternary-result/impl/ternary-result-err.mts +3 -2
- package/src/functional/ternary-result/impl/ternary-result-expect-to-be.mts +4 -0
- package/src/functional/ternary-result/impl/ternary-result-flat-map.mts +7 -0
- package/src/functional/ternary-result/impl/ternary-result-fold.mts +5 -0
- package/src/functional/ternary-result/impl/ternary-result-from-promise.mts +3 -1
- package/src/functional/ternary-result/impl/ternary-result-from-throwable.mts +4 -1
- package/src/functional/ternary-result/impl/ternary-result-is-ok.mts +1 -0
- package/src/functional/ternary-result/impl/ternary-result-is-ternary-result.mts +7 -3
- package/src/functional/ternary-result/impl/ternary-result-is-warn.mts +1 -0
- package/src/functional/ternary-result/impl/ternary-result-map-err.mts +6 -0
- package/src/functional/ternary-result/impl/ternary-result-map-warn.mts +6 -0
- package/src/functional/ternary-result/impl/ternary-result-map.mts +9 -0
- package/src/functional/ternary-result/impl/ternary-result-ok.mts +1 -1
- package/src/functional/ternary-result/impl/ternary-result-or-else.mts +5 -0
- package/src/functional/ternary-result/impl/ternary-result-to-optional.mts +2 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-err-or.mts +5 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-err-throw.mts +1 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-err.mts +2 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-ok-or.mts +5 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-ok.mts +3 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-throw.mts +1 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-warn-or.mts +5 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-warn-throw.mts +1 -0
- package/src/functional/ternary-result/impl/ternary-result-unwrap-warn.mts +2 -0
- package/src/functional/ternary-result/impl/ternary-result-warn.mts +4 -1
- package/src/functional/ternary-result/impl/ternary-result-zip.mts +4 -0
- package/src/functional/ternary-result.test.mts +99 -8
- package/src/globals.d.mts +12 -1
- package/src/guard/has-key.mts +8 -5
- package/src/guard/has-key.test.mts +9 -5
- package/src/guard/is-error.test.mts +143 -0
- package/src/guard/is-non-empty-string.test.mts +44 -24
- package/src/guard/is-non-null-object.test.mts +45 -26
- package/src/guard/is-primitive.test.mts +51 -28
- package/src/guard/is-record.mts +34 -0
- package/src/guard/is-record.test.mts +28 -7
- package/src/guard/is-type.mts +3 -0
- package/src/guard/is-type.test.mts +285 -155
- package/src/guard/key-is-in.mts +3 -2
- package/src/guard/key-is-in.test.mts +2 -2
- package/src/iterator/range.mts +9 -0
- package/src/json/json.mts +50 -21
- package/src/json/json.test.mts +224 -176
- package/src/number/branded-types/finite-number.test.mts +51 -11
- package/src/number/branded-types/int.mts +33 -19
- package/src/number/branded-types/int.test.mts +56 -14
- package/src/number/branded-types/int16.test.mts +63 -16
- package/src/number/branded-types/int32.test.mts +63 -16
- package/src/number/branded-types/non-negative-finite-number.test.mts +52 -12
- package/src/number/branded-types/non-negative-int16.test.mts +59 -16
- package/src/number/branded-types/non-negative-int32.test.mts +59 -16
- package/src/number/branded-types/non-zero-finite-number.test.mts +65 -14
- package/src/number/branded-types/non-zero-int.test.mts +72 -19
- package/src/number/branded-types/non-zero-int16.test.mts +60 -16
- package/src/number/branded-types/non-zero-int32.test.mts +60 -16
- package/src/number/branded-types/non-zero-safe-int.mts +2 -2
- package/src/number/branded-types/non-zero-safe-int.test.mts +85 -23
- package/src/number/branded-types/non-zero-uint16.test.mts +53 -16
- package/src/number/branded-types/non-zero-uint32.test.mts +53 -16
- package/src/number/branded-types/positive-finite-number.test.mts +59 -14
- package/src/number/branded-types/positive-int.mts +34 -20
- package/src/number/branded-types/positive-int.test.mts +64 -17
- package/src/number/branded-types/positive-int16.test.mts +50 -15
- package/src/number/branded-types/positive-int32.test.mts +50 -15
- package/src/number/branded-types/positive-safe-int.mts +48 -27
- package/src/number/branded-types/positive-safe-int.test.mts +68 -19
- package/src/number/branded-types/positive-uint16.test.mts +53 -16
- package/src/number/branded-types/positive-uint32.test.mts +53 -16
- package/src/number/branded-types/safe-int.mts +50 -29
- package/src/number/branded-types/safe-int.test.mts +70 -18
- package/src/number/branded-types/safe-uint.mts +1 -1
- package/src/number/branded-types/safe-uint.test.mts +65 -17
- package/src/number/branded-types/uint.mts +31 -19
- package/src/number/branded-types/uint.test.mts +58 -15
- package/src/number/branded-types/uint16.test.mts +56 -15
- package/src/number/branded-types/uint32.test.mts +56 -15
- package/src/number/enum/int8.test.mts +7 -1
- package/src/number/enum/uint8.test.mts +7 -1
- package/src/number/num.mts +32 -21
- package/src/number/num.test.mts +88 -26
- package/src/number/refined-number-utils.mts +38 -13
- package/src/object/object.mts +19 -3
- package/src/object/object.test.mts +16 -6
- package/src/others/cast-mutable.test.mts +8 -1
- package/src/others/cast-readonly.test.mts +21 -4
- package/src/others/if-then.test.mts +40 -24
- package/src/others/map-nullable.mts +3 -0
- package/src/others/map-nullable.test.mts +27 -0
- package/src/others/memoize-function.test.mts +41 -0
- package/src/others/tuple.mts +14 -3
- package/src/others/unknown-to-string.mts +2 -0
- package/src/others/unknown-to-string.test.mts +10 -0
- package/src/promise/promise.mts +8 -4
- package/src/promise/promise.test.mts +8 -13
|
@@ -7,32 +7,43 @@ describe('Uint32 test', () => {
|
|
|
7
7
|
describe(asUint32, () => {
|
|
8
8
|
test('accepts valid uint32 values', () => {
|
|
9
9
|
expect(() => asUint32(0)).not.toThrow();
|
|
10
|
+
|
|
10
11
|
expect(() => asUint32(1)).not.toThrow();
|
|
12
|
+
|
|
11
13
|
expect(() => asUint32(4_294_967_295)).not.toThrow(); // 2^32 - 1
|
|
14
|
+
|
|
12
15
|
expect(() => asUint32(2_147_483_648)).not.toThrow(); // 2^31
|
|
13
16
|
});
|
|
14
17
|
|
|
15
18
|
test('rejects values outside uint32 range', () => {
|
|
16
19
|
expect(() => asUint32(4_294_967_296)).toThrow(TypeError); // 2^32
|
|
20
|
+
|
|
17
21
|
expect(() => asUint32(10_000_000_000)).toThrow(TypeError);
|
|
18
22
|
});
|
|
19
23
|
|
|
20
24
|
test('rejects negative integers', () => {
|
|
21
25
|
expect(() => asUint32(-1)).toThrow(TypeError);
|
|
26
|
+
|
|
22
27
|
expect(() => asUint32(-42)).toThrow(TypeError);
|
|
23
28
|
});
|
|
24
29
|
|
|
25
30
|
test('rejects non-integers', () => {
|
|
26
31
|
expect(() => asUint32(Number.NaN)).toThrow(TypeError);
|
|
32
|
+
|
|
27
33
|
expect(() => asUint32(Number.POSITIVE_INFINITY)).toThrow(TypeError);
|
|
34
|
+
|
|
28
35
|
expect(() => asUint32(Number.NEGATIVE_INFINITY)).toThrow(TypeError);
|
|
36
|
+
|
|
29
37
|
expect(() => asUint32(1.2)).toThrow(TypeError);
|
|
38
|
+
|
|
30
39
|
expect(() => asUint32(-3.4)).toThrow(TypeError);
|
|
31
40
|
});
|
|
32
41
|
|
|
33
42
|
test('returns the same value for valid inputs', () => {
|
|
34
43
|
expect(asUint32(5)).toBe(5);
|
|
44
|
+
|
|
35
45
|
expect(asUint32(0)).toBe(0);
|
|
46
|
+
|
|
36
47
|
expect(asUint32(4_294_967_295)).toBe(4_294_967_295);
|
|
37
48
|
});
|
|
38
49
|
|
|
@@ -54,35 +65,46 @@ describe('Uint32 test', () => {
|
|
|
54
65
|
|
|
55
66
|
describe(isUint32, () => {
|
|
56
67
|
test('correctly identifies uint32 values', () => {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
68
|
+
assert.isTrue(isUint32(0));
|
|
69
|
+
|
|
70
|
+
assert.isTrue(isUint32(1));
|
|
71
|
+
|
|
72
|
+
assert.isTrue(isUint32(4_294_967_295));
|
|
73
|
+
|
|
74
|
+
assert.isTrue(isUint32(2_147_483_648));
|
|
61
75
|
});
|
|
62
76
|
|
|
63
77
|
test('correctly identifies values outside uint32 range', () => {
|
|
64
|
-
|
|
65
|
-
|
|
78
|
+
assert.isFalse(isUint32(4_294_967_296));
|
|
79
|
+
|
|
80
|
+
assert.isFalse(isUint32(10_000_000_000));
|
|
66
81
|
});
|
|
67
82
|
|
|
68
83
|
test('correctly identifies negative integers', () => {
|
|
69
|
-
|
|
70
|
-
|
|
84
|
+
assert.isFalse(isUint32(-1));
|
|
85
|
+
|
|
86
|
+
assert.isFalse(isUint32(-42));
|
|
71
87
|
});
|
|
72
88
|
|
|
73
89
|
test('correctly identifies non-integers', () => {
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
90
|
+
assert.isFalse(isUint32(Number.NaN));
|
|
91
|
+
|
|
92
|
+
assert.isFalse(isUint32(Number.POSITIVE_INFINITY));
|
|
93
|
+
|
|
94
|
+
assert.isFalse(isUint32(Number.NEGATIVE_INFINITY));
|
|
95
|
+
|
|
96
|
+
assert.isFalse(isUint32(1.2));
|
|
97
|
+
|
|
98
|
+
assert.isFalse(isUint32(-3.4));
|
|
79
99
|
});
|
|
80
100
|
});
|
|
81
101
|
|
|
82
102
|
describe('Uint32.is', () => {
|
|
83
103
|
test('same as isUint32 function', () => {
|
|
84
104
|
expect(Uint32.is(5)).toBe(isUint32(5));
|
|
105
|
+
|
|
85
106
|
expect(Uint32.is(4_294_967_296)).toBe(isUint32(4_294_967_296));
|
|
107
|
+
|
|
86
108
|
expect(Uint32.is(-1)).toBe(isUint32(-1));
|
|
87
109
|
});
|
|
88
110
|
});
|
|
@@ -90,19 +112,25 @@ describe('Uint32 test', () => {
|
|
|
90
112
|
describe('constants', () => {
|
|
91
113
|
test('MIN_VALUE and MAX_VALUE', () => {
|
|
92
114
|
expect(Uint32.MIN_VALUE).toBe(0);
|
|
115
|
+
|
|
93
116
|
expect(Uint32.MAX_VALUE).toBe(4_294_967_295);
|
|
94
117
|
});
|
|
95
118
|
});
|
|
96
119
|
|
|
97
120
|
describe('mathematical operations', () => {
|
|
98
121
|
const a = asUint32(1_000_000);
|
|
122
|
+
|
|
99
123
|
const b = asUint32(500_000);
|
|
124
|
+
|
|
100
125
|
const c = asUint32(0);
|
|
101
126
|
|
|
102
127
|
test('min and max', () => {
|
|
103
128
|
expect(Uint32.min(a, b)).toBe(500_000);
|
|
129
|
+
|
|
104
130
|
expect(Uint32.max(a, b)).toBe(1_000_000);
|
|
131
|
+
|
|
105
132
|
expect(Uint32.min(a, c)).toBe(0);
|
|
133
|
+
|
|
106
134
|
expect(Uint32.max(a, c)).toBe(1_000_000);
|
|
107
135
|
});
|
|
108
136
|
|
|
@@ -110,12 +138,15 @@ describe('Uint32 test', () => {
|
|
|
110
138
|
const result = Uint32.add(asUint32(4_294_967_000), asUint32(1000));
|
|
111
139
|
|
|
112
140
|
expect(result).toBe(4_294_967_295); // clamped to max
|
|
141
|
+
|
|
113
142
|
expect(Uint32.add(a, b)).toBe(1_500_000);
|
|
114
143
|
});
|
|
115
144
|
|
|
116
145
|
test('sub (never goes below 0)', () => {
|
|
117
146
|
expect(Uint32.sub(a, b)).toBe(500_000);
|
|
147
|
+
|
|
118
148
|
expect(Uint32.sub(b, a)).toBe(0); // clamped to 0
|
|
149
|
+
|
|
119
150
|
expect(Uint32.sub(c, a)).toBe(0); // clamped to 0
|
|
120
151
|
});
|
|
121
152
|
|
|
@@ -123,12 +154,15 @@ describe('Uint32 test', () => {
|
|
|
123
154
|
const result = Uint32.mul(asUint32(100_000), asUint32(100_000));
|
|
124
155
|
|
|
125
156
|
expect(result).toBe(4_294_967_295); // clamped to max
|
|
157
|
+
|
|
126
158
|
expect(Uint32.mul(asUint32(1000), asUint32(5))).toBe(5000);
|
|
127
159
|
});
|
|
128
160
|
|
|
129
161
|
test('div (floor division, never goes below 0)', () => {
|
|
130
162
|
expect(Uint32.div(a, asNonZeroUint32(500_000))).toBe(2);
|
|
163
|
+
|
|
131
164
|
expect(Uint32.div(asUint32(7), asNonZeroUint32(3))).toBe(2);
|
|
165
|
+
|
|
132
166
|
expect(Uint32.div(asUint32(500_000), asNonZeroUint32(1_000_000))).toBe(0); // floor(500000/1000000) = 0
|
|
133
167
|
});
|
|
134
168
|
|
|
@@ -136,6 +170,7 @@ describe('Uint32 test', () => {
|
|
|
136
170
|
const result = Uint32.pow(asUint32(10_000), asUint32(3));
|
|
137
171
|
|
|
138
172
|
expect(result).toBe(4_294_967_295); // clamped to max
|
|
173
|
+
|
|
139
174
|
expect(Uint32.pow(asUint32(2), asUint32(3))).toBe(8);
|
|
140
175
|
});
|
|
141
176
|
});
|
|
@@ -143,15 +178,20 @@ describe('Uint32 test', () => {
|
|
|
143
178
|
describe('random', () => {
|
|
144
179
|
test('generates uint32 values within specified range', () => {
|
|
145
180
|
const min = 0;
|
|
181
|
+
|
|
146
182
|
const max = 20;
|
|
147
183
|
|
|
148
184
|
for (const _ of range(10)) {
|
|
149
185
|
const result = Uint32.random(min, max);
|
|
150
186
|
|
|
151
187
|
expect(result).toBeGreaterThanOrEqual(min);
|
|
188
|
+
|
|
152
189
|
expect(result).toBeLessThanOrEqual(max);
|
|
153
|
-
|
|
154
|
-
|
|
190
|
+
|
|
191
|
+
assert.isTrue(Uint32.is(result));
|
|
192
|
+
|
|
193
|
+
assert.isTrue(Number.isInteger(result));
|
|
194
|
+
|
|
155
195
|
expect(result).toBeGreaterThanOrEqual(0);
|
|
156
196
|
}
|
|
157
197
|
});
|
|
@@ -161,6 +201,7 @@ describe('Uint32 test', () => {
|
|
|
161
201
|
const result = Uint32.random(0, 30);
|
|
162
202
|
|
|
163
203
|
expect(result).toBeGreaterThanOrEqual(0);
|
|
204
|
+
|
|
164
205
|
expect(result).toBeLessThanOrEqual(4_294_967_295);
|
|
165
206
|
}
|
|
166
207
|
});
|
|
@@ -77,6 +77,7 @@ describe('Int8 test', () => {
|
|
|
77
77
|
describe('Int8.min', () => {
|
|
78
78
|
test('should return minimum value', () => {
|
|
79
79
|
expect(Int8.min(-100, -50, 10)).toBe(-100);
|
|
80
|
+
|
|
80
81
|
expect(Int8.min(1, 2, 3)).toBe(1);
|
|
81
82
|
});
|
|
82
83
|
});
|
|
@@ -84,6 +85,7 @@ describe('Int8 test', () => {
|
|
|
84
85
|
describe('Int8.max', () => {
|
|
85
86
|
test('should return maximum value', () => {
|
|
86
87
|
expect(Int8.max(-100, -50, 10)).toBe(10);
|
|
88
|
+
|
|
87
89
|
expect(Int8.max(1, 2, 3)).toBe(3);
|
|
88
90
|
});
|
|
89
91
|
});
|
|
@@ -174,12 +176,16 @@ describe('Int8 test', () => {
|
|
|
174
176
|
describe('Int8.random', () => {
|
|
175
177
|
test('should generate value within range', () => {
|
|
176
178
|
const min = -10;
|
|
179
|
+
|
|
177
180
|
const max = 10;
|
|
181
|
+
|
|
178
182
|
const result = Int8.random(min, max);
|
|
179
183
|
|
|
180
184
|
expect(result).toBeGreaterThanOrEqual(min);
|
|
185
|
+
|
|
181
186
|
expect(result).toBeLessThanOrEqual(max);
|
|
182
|
-
|
|
187
|
+
|
|
188
|
+
assert.isTrue(Number.isInteger(result));
|
|
183
189
|
});
|
|
184
190
|
});
|
|
185
191
|
});
|
|
@@ -77,6 +77,7 @@ describe('Uint8 test', () => {
|
|
|
77
77
|
describe('Uint8.min', () => {
|
|
78
78
|
test('should return minimum value', () => {
|
|
79
79
|
expect(Uint8.min(100, 50, 10)).toBe(10);
|
|
80
|
+
|
|
80
81
|
expect(Uint8.min(1, 2, 3)).toBe(1);
|
|
81
82
|
});
|
|
82
83
|
});
|
|
@@ -84,6 +85,7 @@ describe('Uint8 test', () => {
|
|
|
84
85
|
describe('Uint8.max', () => {
|
|
85
86
|
test('should return maximum value', () => {
|
|
86
87
|
expect(Uint8.max(100, 50, 10)).toBe(100);
|
|
88
|
+
|
|
87
89
|
expect(Uint8.max(1, 2, 3)).toBe(3);
|
|
88
90
|
});
|
|
89
91
|
});
|
|
@@ -156,12 +158,16 @@ describe('Uint8 test', () => {
|
|
|
156
158
|
describe('Uint8.random', () => {
|
|
157
159
|
test('should generate value within range', () => {
|
|
158
160
|
const min = 10;
|
|
161
|
+
|
|
159
162
|
const max = 50;
|
|
163
|
+
|
|
160
164
|
const result = Uint8.random(min, max);
|
|
161
165
|
|
|
162
166
|
expect(result).toBeGreaterThanOrEqual(min);
|
|
167
|
+
|
|
163
168
|
expect(result).toBeLessThanOrEqual(max);
|
|
164
|
-
|
|
169
|
+
|
|
170
|
+
assert.isTrue(Number.isInteger(result));
|
|
165
171
|
});
|
|
166
172
|
});
|
|
167
173
|
});
|
package/src/number/num.mts
CHANGED
|
@@ -26,7 +26,7 @@ export namespace Num {
|
|
|
26
26
|
*
|
|
27
27
|
* const result = Num.from(input);
|
|
28
28
|
*
|
|
29
|
-
* assert(result === 123.45);
|
|
29
|
+
* assert.isTrue(result === 123.45);
|
|
30
30
|
* ```
|
|
31
31
|
*
|
|
32
32
|
* @param n The value to convert.
|
|
@@ -50,10 +50,11 @@ export namespace Num {
|
|
|
50
50
|
* // Safe to divide now that we know value is non-zero
|
|
51
51
|
* // eslint-disable-next-line total-functions/no-partial-division
|
|
52
52
|
* const inverted = 1 / value;
|
|
53
|
-
*
|
|
53
|
+
*
|
|
54
|
+
* assert.isTrue(inverted === 0.2);
|
|
54
55
|
* }
|
|
55
56
|
*
|
|
56
|
-
* assert.
|
|
57
|
+
* assert.isFalse(Num.isNonZero(0));
|
|
57
58
|
* ```
|
|
58
59
|
*
|
|
59
60
|
* @template N - The numeric literal type or number type to check
|
|
@@ -81,10 +82,11 @@ export namespace Num {
|
|
|
81
82
|
*
|
|
82
83
|
* if (Num.isNonNegative(candidate)) {
|
|
83
84
|
* const index: number = candidate;
|
|
84
|
-
*
|
|
85
|
+
*
|
|
86
|
+
* assert.isTrue(index === 10);
|
|
85
87
|
* }
|
|
86
88
|
*
|
|
87
|
-
* assert.
|
|
89
|
+
* assert.isFalse(Num.isNonNegative(-1));
|
|
88
90
|
* ```
|
|
89
91
|
*
|
|
90
92
|
* @template N - The numeric literal type or number type to check
|
|
@@ -109,10 +111,10 @@ export namespace Num {
|
|
|
109
111
|
* const amount = 42;
|
|
110
112
|
*
|
|
111
113
|
* if (Num.isPositive(amount)) {
|
|
112
|
-
* assert.
|
|
114
|
+
* assert.isTrue(amount > 0);
|
|
113
115
|
* }
|
|
114
116
|
*
|
|
115
|
-
* assert.
|
|
117
|
+
* assert.isFalse(Num.isPositive(0));
|
|
116
118
|
* ```
|
|
117
119
|
*
|
|
118
120
|
* @template N - The numeric literal type or number type to check
|
|
@@ -133,8 +135,9 @@ export namespace Num {
|
|
|
133
135
|
* ```ts
|
|
134
136
|
* const isGrade = Num.isInRange(0, 100);
|
|
135
137
|
*
|
|
136
|
-
* assert.
|
|
137
|
-
*
|
|
138
|
+
* assert.isTrue(isGrade(50));
|
|
139
|
+
*
|
|
140
|
+
* assert.isFalse(isGrade(100));
|
|
138
141
|
* ```
|
|
139
142
|
*
|
|
140
143
|
* @param lowerBound The lower bound (inclusive).
|
|
@@ -156,8 +159,9 @@ export namespace Num {
|
|
|
156
159
|
* ```ts
|
|
157
160
|
* const isPercentage = Num.isInRangeInclusive(0, 100);
|
|
158
161
|
*
|
|
159
|
-
* assert.
|
|
160
|
-
*
|
|
162
|
+
* assert.isTrue(isPercentage(100));
|
|
163
|
+
*
|
|
164
|
+
* assert.isFalse(isPercentage(-1));
|
|
161
165
|
* ```
|
|
162
166
|
*
|
|
163
167
|
* @param lowerBound The lower bound (inclusive).
|
|
@@ -215,9 +219,11 @@ export namespace Num {
|
|
|
215
219
|
* ```ts
|
|
216
220
|
* const indexGuard = Num.isUintInRange(0, 5);
|
|
217
221
|
*
|
|
218
|
-
* assert.
|
|
219
|
-
*
|
|
220
|
-
* assert.
|
|
222
|
+
* assert.isTrue(indexGuard(3));
|
|
223
|
+
*
|
|
224
|
+
* assert.isFalse(indexGuard(5));
|
|
225
|
+
*
|
|
226
|
+
* assert.isFalse(indexGuard(-1));
|
|
221
227
|
* ```
|
|
222
228
|
*
|
|
223
229
|
* @template L - The lower bound as a SmallUint literal type
|
|
@@ -249,8 +255,9 @@ export namespace Num {
|
|
|
249
255
|
* ```ts
|
|
250
256
|
* const inclusiveGuard = Num.isUintInRangeInclusive(0, 5);
|
|
251
257
|
*
|
|
252
|
-
* assert.
|
|
253
|
-
*
|
|
258
|
+
* assert.isTrue(inclusiveGuard(5));
|
|
259
|
+
*
|
|
260
|
+
* assert.isFalse(inclusiveGuard(6));
|
|
254
261
|
* ```
|
|
255
262
|
*
|
|
256
263
|
* @template L - The lower bound as a SmallUint literal type
|
|
@@ -277,13 +284,15 @@ export namespace Num {
|
|
|
277
284
|
* @example
|
|
278
285
|
*
|
|
279
286
|
* ```ts
|
|
280
|
-
* assert(Num.clamp(150, 0, 100) === 100);
|
|
281
|
-
*
|
|
287
|
+
* assert.isTrue(Num.clamp(150, 0, 100) === 100);
|
|
288
|
+
*
|
|
289
|
+
* assert.isTrue(Num.clamp(-50, 0, 100) === 0);
|
|
282
290
|
*
|
|
283
291
|
* const clampToPercentage = Num.clamp(0, 100);
|
|
284
292
|
*
|
|
285
|
-
* assert(clampToPercentage(75) === 75);
|
|
286
|
-
*
|
|
293
|
+
* assert.isTrue(clampToPercentage(75) === 75);
|
|
294
|
+
*
|
|
295
|
+
* assert.isTrue(clampToPercentage(150) === 100);
|
|
287
296
|
* ```
|
|
288
297
|
*/
|
|
289
298
|
export function clamp(
|
|
@@ -306,6 +315,7 @@ export namespace Num {
|
|
|
306
315
|
switch (args.length) {
|
|
307
316
|
case 3: {
|
|
308
317
|
const [target, lowerBound, upperBound] = args;
|
|
318
|
+
|
|
309
319
|
return !Number.isFinite(target)
|
|
310
320
|
? lowerBound
|
|
311
321
|
: Math.max(lowerBound, Math.min(upperBound, target));
|
|
@@ -313,6 +323,7 @@ export namespace Num {
|
|
|
313
323
|
|
|
314
324
|
case 2: {
|
|
315
325
|
const [lowerBound, upperBound] = args;
|
|
326
|
+
|
|
316
327
|
return (target: number): number =>
|
|
317
328
|
clamp(target, lowerBound, upperBound);
|
|
318
329
|
}
|
|
@@ -385,7 +396,7 @@ export namespace Num {
|
|
|
385
396
|
* @returns The rounded integer as an Int branded type
|
|
386
397
|
*/
|
|
387
398
|
// eslint-disable-next-line total-functions/no-unsafe-type-assertion
|
|
388
|
-
export const roundToInt = (num: number): Int => (
|
|
399
|
+
export const roundToInt = (num: number): Int => Math.trunc(num + 0.5) as Int;
|
|
389
400
|
|
|
390
401
|
/**
|
|
391
402
|
* Creates a reusable rounding function with a fixed precision.
|