ts-data-forge 3.3.0 → 4.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +37 -13
- package/dist/array/impl/array-utils-creation.d.mts +116 -0
- package/dist/array/impl/array-utils-creation.d.mts.map +1 -0
- package/dist/array/impl/array-utils-creation.mjs +110 -0
- package/dist/array/impl/array-utils-creation.mjs.map +1 -0
- package/dist/array/impl/array-utils-element-access.d.mts +60 -0
- package/dist/array/impl/array-utils-element-access.d.mts.map +1 -0
- package/dist/array/impl/array-utils-element-access.mjs +66 -0
- package/dist/array/impl/array-utils-element-access.mjs.map +1 -0
- package/dist/array/impl/array-utils-iterators.d.mts +59 -0
- package/dist/array/impl/array-utils-iterators.d.mts.map +1 -0
- package/dist/array/impl/array-utils-iterators.mjs +104 -0
- package/dist/array/impl/array-utils-iterators.mjs.map +1 -0
- package/dist/array/impl/array-utils-modification.d.mts +154 -0
- package/dist/array/impl/array-utils-modification.d.mts.map +1 -0
- package/dist/array/impl/array-utils-modification.mjs +139 -0
- package/dist/array/impl/array-utils-modification.mjs.map +1 -0
- package/dist/array/impl/array-utils-reducing-value.d.mts +213 -0
- package/dist/array/impl/array-utils-reducing-value.d.mts.map +1 -0
- package/dist/array/impl/array-utils-reducing-value.mjs +162 -0
- package/dist/array/impl/array-utils-reducing-value.mjs.map +1 -0
- package/dist/array/impl/array-utils-search.d.mts +178 -0
- package/dist/array/impl/array-utils-search.d.mts.map +1 -0
- package/dist/array/impl/array-utils-search.mjs +153 -0
- package/dist/array/impl/array-utils-search.mjs.map +1 -0
- package/dist/array/impl/array-utils-set-op.d.mts +100 -0
- package/dist/array/impl/array-utils-set-op.d.mts.map +1 -0
- package/dist/array/impl/array-utils-set-op.mjs +137 -0
- package/dist/array/impl/array-utils-set-op.mjs.map +1 -0
- package/dist/array/impl/array-utils-size.d.mts +24 -0
- package/dist/array/impl/array-utils-size.d.mts.map +1 -0
- package/dist/array/impl/array-utils-size.mjs +28 -0
- package/dist/array/impl/array-utils-size.mjs.map +1 -0
- package/dist/array/impl/array-utils-slice-clamped.d.mts +18 -0
- package/dist/array/impl/array-utils-slice-clamped.d.mts.map +1 -0
- package/dist/array/impl/array-utils-slice-clamped.mjs +49 -0
- package/dist/array/impl/array-utils-slice-clamped.mjs.map +1 -0
- package/dist/array/impl/array-utils-slicing.d.mts +120 -0
- package/dist/array/impl/array-utils-slicing.d.mts.map +1 -0
- package/dist/array/impl/array-utils-slicing.mjs +140 -0
- package/dist/array/impl/array-utils-slicing.mjs.map +1 -0
- package/dist/array/impl/array-utils-transformation.d.mts +348 -0
- package/dist/array/impl/array-utils-transformation.d.mts.map +1 -0
- package/dist/array/impl/array-utils-transformation.mjs +329 -0
- package/dist/array/impl/array-utils-transformation.mjs.map +1 -0
- package/dist/array/impl/array-utils-validation.d.mts +149 -0
- package/dist/array/impl/array-utils-validation.d.mts.map +1 -0
- package/dist/array/impl/array-utils-validation.mjs +166 -0
- package/dist/array/impl/array-utils-validation.mjs.map +1 -0
- package/dist/array/impl/index.d.mts +13 -0
- package/dist/array/impl/index.d.mts.map +1 -0
- package/dist/array/impl/index.mjs +13 -0
- package/dist/array/impl/index.mjs.map +1 -0
- package/dist/array/index.d.mts +1 -1
- package/dist/array/index.d.mts.map +1 -1
- package/dist/array/index.mjs +2 -1
- package/dist/array/index.mjs.map +1 -1
- package/dist/collections/imap-mapped.d.mts +83 -254
- package/dist/collections/imap-mapped.d.mts.map +1 -1
- package/dist/collections/imap-mapped.mjs +40 -170
- package/dist/collections/imap-mapped.mjs.map +1 -1
- package/dist/collections/imap.d.mts +436 -164
- package/dist/collections/imap.d.mts.map +1 -1
- package/dist/collections/imap.mjs +83 -101
- package/dist/collections/imap.mjs.map +1 -1
- package/dist/collections/iset-mapped.d.mts +828 -345
- package/dist/collections/iset-mapped.d.mts.map +1 -1
- package/dist/collections/iset-mapped.mjs +200 -242
- package/dist/collections/iset-mapped.mjs.map +1 -1
- package/dist/collections/iset.d.mts +397 -205
- package/dist/collections/iset.d.mts.map +1 -1
- package/dist/collections/iset.mjs +102 -184
- package/dist/collections/iset.mjs.map +1 -1
- package/dist/collections/queue.d.mts +155 -136
- package/dist/collections/queue.d.mts.map +1 -1
- package/dist/collections/queue.mjs +59 -160
- package/dist/collections/queue.mjs.map +1 -1
- package/dist/collections/stack.d.mts +154 -155
- package/dist/collections/stack.d.mts.map +1 -1
- package/dist/collections/stack.mjs +58 -207
- package/dist/collections/stack.mjs.map +1 -1
- package/dist/entry-point.d.mts +2 -0
- package/dist/entry-point.d.mts.map +1 -1
- package/dist/entry-point.mjs +8 -5
- package/dist/entry-point.mjs.map +1 -1
- package/dist/expect-type.d.mts +43 -172
- package/dist/expect-type.d.mts.map +1 -1
- package/dist/expect-type.mjs +43 -172
- package/dist/expect-type.mjs.map +1 -1
- package/dist/functional/index.d.mts +2 -2
- package/dist/functional/index.d.mts.map +1 -1
- package/dist/functional/index.mjs +4 -2
- package/dist/functional/index.mjs.map +1 -1
- package/dist/functional/match.d.mts +35 -140
- package/dist/functional/match.d.mts.map +1 -1
- package/dist/functional/match.mjs.map +1 -1
- package/dist/functional/optional/impl/index.d.mts +18 -0
- package/dist/functional/optional/impl/index.d.mts.map +1 -0
- package/dist/functional/optional/impl/index.mjs +17 -0
- package/dist/functional/optional/impl/index.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-expect-to-be.d.mts +29 -0
- package/dist/functional/optional/impl/optional-expect-to-be.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-expect-to-be.mjs +25 -0
- package/dist/functional/optional/impl/optional-expect-to-be.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-filter.d.mts +29 -0
- package/dist/functional/optional/impl/optional-filter.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-filter.mjs +28 -0
- package/dist/functional/optional/impl/optional-filter.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-flat-map.d.mts +33 -0
- package/dist/functional/optional/impl/optional-flat-map.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-flat-map.mjs +21 -0
- package/dist/functional/optional/impl/optional-flat-map.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-from-nullable.d.mts +24 -0
- package/dist/functional/optional/impl/optional-from-nullable.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-from-nullable.mjs +29 -0
- package/dist/functional/optional/impl/optional-from-nullable.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-is-none.d.mts +22 -0
- package/dist/functional/optional/impl/optional-is-none.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-is-none.mjs +25 -0
- package/dist/functional/optional/impl/optional-is-none.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-is-optional.d.mts +18 -0
- package/dist/functional/optional/impl/optional-is-optional.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-is-optional.mjs +27 -0
- package/dist/functional/optional/impl/optional-is-optional.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-is-some.d.mts +22 -0
- package/dist/functional/optional/impl/optional-is-some.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-is-some.mjs +25 -0
- package/dist/functional/optional/impl/optional-is-some.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-map.d.mts +31 -0
- package/dist/functional/optional/impl/optional-map.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-map.mjs +25 -0
- package/dist/functional/optional/impl/optional-map.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-none.d.mts +16 -0
- package/dist/functional/optional/impl/optional-none.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-none.mjs +20 -0
- package/dist/functional/optional/impl/optional-none.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-or-else.d.mts +35 -0
- package/dist/functional/optional/impl/optional-or-else.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-or-else.mjs +19 -0
- package/dist/functional/optional/impl/optional-or-else.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-some.d.mts +19 -0
- package/dist/functional/optional/impl/optional-some.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-some.mjs +26 -0
- package/dist/functional/optional/impl/optional-some.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-to-nullable.d.mts +27 -0
- package/dist/functional/optional/impl/optional-to-nullable.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-to-nullable.mjs +31 -0
- package/dist/functional/optional/impl/optional-to-nullable.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-unwrap-or.d.mts +33 -0
- package/dist/functional/optional/impl/optional-unwrap-or.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-unwrap-or.mjs +19 -0
- package/dist/functional/optional/impl/optional-unwrap-or.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-unwrap-throw.d.mts +29 -0
- package/dist/functional/optional/impl/optional-unwrap-throw.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-unwrap-throw.mjs +38 -0
- package/dist/functional/optional/impl/optional-unwrap-throw.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-unwrap.d.mts +28 -0
- package/dist/functional/optional/impl/optional-unwrap.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-unwrap.mjs +11 -0
- package/dist/functional/optional/impl/optional-unwrap.mjs.map +1 -0
- package/dist/functional/optional/impl/optional-zip.d.mts +31 -0
- package/dist/functional/optional/impl/optional-zip.d.mts.map +1 -0
- package/dist/functional/optional/impl/optional-zip.mjs +39 -0
- package/dist/functional/optional/impl/optional-zip.mjs.map +1 -0
- package/dist/functional/optional/impl/tag.d.mts +5 -0
- package/dist/functional/optional/impl/tag.d.mts.map +1 -0
- package/dist/functional/optional/impl/tag.mjs +7 -0
- package/dist/functional/optional/impl/tag.mjs.map +1 -0
- package/dist/functional/optional/impl/types.d.mts +22 -0
- package/dist/functional/optional/impl/types.d.mts.map +1 -0
- package/dist/functional/optional/impl/types.mjs +2 -0
- package/dist/functional/optional/impl/types.mjs.map +1 -0
- package/dist/functional/optional/index.d.mts +2 -0
- package/dist/functional/optional/index.d.mts.map +1 -0
- package/dist/functional/optional/index.mjs +3 -0
- package/dist/functional/optional/index.mjs.map +1 -0
- package/dist/functional/pipe.d.mts +63 -117
- package/dist/functional/pipe.d.mts.map +1 -1
- package/dist/functional/pipe.mjs +4 -3
- package/dist/functional/pipe.mjs.map +1 -1
- package/dist/functional/result/impl/index.d.mts +24 -0
- package/dist/functional/result/impl/index.d.mts.map +1 -0
- package/dist/functional/result/impl/index.mjs +23 -0
- package/dist/functional/result/impl/index.mjs.map +1 -0
- package/dist/functional/result/impl/result-err.d.mts +25 -0
- package/dist/functional/result/impl/result-err.d.mts.map +1 -0
- package/dist/functional/result/impl/result-err.mjs +32 -0
- package/dist/functional/result/impl/result-err.mjs.map +1 -0
- package/dist/functional/result/impl/result-expect-to-be.d.mts +27 -0
- package/dist/functional/result/impl/result-expect-to-be.d.mts.map +1 -0
- package/dist/functional/result/impl/result-expect-to-be.mjs +26 -0
- package/dist/functional/result/impl/result-expect-to-be.mjs.map +1 -0
- package/dist/functional/result/impl/result-flat-map.d.mts +39 -0
- package/dist/functional/result/impl/result-flat-map.d.mts.map +1 -0
- package/dist/functional/result/impl/result-flat-map.mjs +24 -0
- package/dist/functional/result/impl/result-flat-map.mjs.map +1 -0
- package/dist/functional/result/impl/result-fold.d.mts +45 -0
- package/dist/functional/result/impl/result-fold.d.mts.map +1 -0
- package/dist/functional/result/impl/result-fold.mjs +26 -0
- package/dist/functional/result/impl/result-fold.mjs.map +1 -0
- package/dist/functional/result/impl/result-from-promise.d.mts +32 -0
- package/dist/functional/result/impl/result-from-promise.d.mts.map +1 -0
- package/dist/functional/result/impl/result-from-promise.mjs +32 -0
- package/dist/functional/result/impl/result-from-promise.mjs.map +1 -0
- package/dist/functional/result/impl/result-from-throwable.d.mts +29 -0
- package/dist/functional/result/impl/result-from-throwable.d.mts.map +1 -0
- package/dist/functional/result/impl/result-from-throwable.mjs +46 -0
- package/dist/functional/result/impl/result-from-throwable.mjs.map +1 -0
- package/dist/functional/result/impl/result-is-err.d.mts +20 -0
- package/dist/functional/result/impl/result-is-err.d.mts.map +1 -0
- package/dist/functional/result/impl/result-is-err.mjs +23 -0
- package/dist/functional/result/impl/result-is-err.mjs.map +1 -0
- package/dist/functional/result/impl/result-is-ok.d.mts +20 -0
- package/dist/functional/result/impl/result-is-ok.d.mts.map +1 -0
- package/dist/functional/result/impl/result-is-ok.mjs +23 -0
- package/dist/functional/result/impl/result-is-ok.mjs.map +1 -0
- package/dist/functional/result/impl/result-is-result.d.mts +17 -0
- package/dist/functional/result/impl/result-is-result.d.mts.map +1 -0
- package/dist/functional/result/impl/result-is-result.mjs +26 -0
- package/dist/functional/result/impl/result-is-result.mjs.map +1 -0
- package/dist/functional/result/impl/result-map-err.d.mts +33 -0
- package/dist/functional/result/impl/result-map-err.d.mts.map +1 -0
- package/dist/functional/result/impl/result-map-err.mjs +25 -0
- package/dist/functional/result/impl/result-map-err.mjs.map +1 -0
- package/dist/functional/result/impl/result-map.d.mts +34 -0
- package/dist/functional/result/impl/result-map.d.mts.map +1 -0
- package/dist/functional/result/impl/result-map.mjs +25 -0
- package/dist/functional/result/impl/result-map.mjs.map +1 -0
- package/dist/functional/result/impl/result-ok.d.mts +25 -0
- package/dist/functional/result/impl/result-ok.d.mts.map +1 -0
- package/dist/functional/result/impl/result-ok.mjs +32 -0
- package/dist/functional/result/impl/result-ok.mjs.map +1 -0
- package/dist/functional/result/impl/result-or-else.d.mts +32 -0
- package/dist/functional/result/impl/result-or-else.d.mts.map +1 -0
- package/dist/functional/result/impl/result-or-else.mjs +20 -0
- package/dist/functional/result/impl/result-or-else.mjs.map +1 -0
- package/dist/functional/result/impl/result-swap.d.mts +20 -0
- package/dist/functional/result/impl/result-swap.d.mts.map +1 -0
- package/dist/functional/result/impl/result-swap.mjs +28 -0
- package/dist/functional/result/impl/result-swap.mjs.map +1 -0
- package/dist/functional/result/impl/result-to-optional.d.mts +28 -0
- package/dist/functional/result/impl/result-to-optional.d.mts.map +1 -0
- package/dist/functional/result/impl/result-to-optional.mjs +34 -0
- package/dist/functional/result/impl/result-to-optional.mjs.map +1 -0
- package/dist/functional/result/impl/result-unwrap-err-or.d.mts +29 -0
- package/dist/functional/result/impl/result-unwrap-err-or.d.mts.map +1 -0
- package/dist/functional/result/impl/result-unwrap-err-or.mjs +20 -0
- package/dist/functional/result/impl/result-unwrap-err-or.mjs.map +1 -0
- package/dist/functional/result/impl/result-unwrap-err-throw.d.mts +30 -0
- package/dist/functional/result/impl/result-unwrap-err-throw.d.mts.map +1 -0
- package/dist/functional/result/impl/result-unwrap-err-throw.mjs +47 -0
- package/dist/functional/result/impl/result-unwrap-err-throw.mjs.map +1 -0
- package/dist/functional/result/impl/result-unwrap-err.d.mts +31 -0
- package/dist/functional/result/impl/result-unwrap-err.d.mts.map +1 -0
- package/dist/functional/result/impl/result-unwrap-err.mjs +36 -0
- package/dist/functional/result/impl/result-unwrap-err.mjs.map +1 -0
- package/dist/functional/result/impl/result-unwrap-ok-or.d.mts +29 -0
- package/dist/functional/result/impl/result-unwrap-ok-or.d.mts.map +1 -0
- package/dist/functional/result/impl/result-unwrap-ok-or.mjs +20 -0
- package/dist/functional/result/impl/result-unwrap-ok-or.mjs.map +1 -0
- package/dist/functional/result/impl/result-unwrap-ok.d.mts +23 -0
- package/dist/functional/result/impl/result-unwrap-ok.d.mts.map +1 -0
- package/dist/functional/result/impl/result-unwrap-ok.mjs +11 -0
- package/dist/functional/result/impl/result-unwrap-ok.mjs.map +1 -0
- package/dist/functional/result/impl/result-unwrap-throw.d.mts +30 -0
- package/dist/functional/result/impl/result-unwrap-throw.d.mts.map +1 -0
- package/dist/functional/result/impl/result-unwrap-throw.mjs +41 -0
- package/dist/functional/result/impl/result-unwrap-throw.mjs.map +1 -0
- package/dist/functional/result/impl/result-zip.d.mts +29 -0
- package/dist/functional/result/impl/result-zip.d.mts.map +1 -0
- package/dist/functional/result/impl/result-zip.mjs +38 -0
- package/dist/functional/result/impl/result-zip.mjs.map +1 -0
- package/dist/functional/result/impl/tag.d.mts +5 -0
- package/dist/functional/result/impl/tag.d.mts.map +1 -0
- package/dist/functional/result/impl/tag.mjs +7 -0
- package/dist/functional/result/impl/tag.mjs.map +1 -0
- package/dist/functional/result/impl/types.d.mts +29 -0
- package/dist/functional/result/impl/types.d.mts.map +1 -0
- package/dist/functional/result/impl/types.mjs +2 -0
- package/dist/functional/result/impl/types.mjs.map +1 -0
- package/dist/functional/result/index.d.mts +2 -0
- package/dist/functional/result/index.d.mts.map +1 -0
- package/dist/functional/result/index.mjs +3 -0
- package/dist/functional/result/index.mjs.map +1 -0
- package/dist/globals.d.mts +95 -5
- package/dist/guard/has-key.d.mts +23 -74
- package/dist/guard/has-key.d.mts.map +1 -1
- package/dist/guard/has-key.mjs +23 -74
- package/dist/guard/has-key.mjs.map +1 -1
- package/dist/guard/is-non-empty-string.d.mts +20 -87
- package/dist/guard/is-non-empty-string.d.mts.map +1 -1
- package/dist/guard/is-non-empty-string.mjs +20 -87
- package/dist/guard/is-non-empty-string.mjs.map +1 -1
- package/dist/guard/is-non-null-object.d.mts +14 -84
- package/dist/guard/is-non-null-object.d.mts.map +1 -1
- package/dist/guard/is-non-null-object.mjs +14 -84
- package/dist/guard/is-non-null-object.mjs.map +1 -1
- package/dist/guard/is-primitive.d.mts +13 -126
- package/dist/guard/is-primitive.d.mts.map +1 -1
- package/dist/guard/is-primitive.mjs +13 -126
- package/dist/guard/is-primitive.mjs.map +1 -1
- package/dist/guard/is-record.d.mts +21 -132
- package/dist/guard/is-record.d.mts.map +1 -1
- package/dist/guard/is-record.mjs +21 -132
- package/dist/guard/is-record.mjs.map +1 -1
- package/dist/guard/is-type.d.mts +201 -238
- package/dist/guard/is-type.d.mts.map +1 -1
- package/dist/guard/is-type.mjs +201 -238
- package/dist/guard/is-type.mjs.map +1 -1
- package/dist/guard/key-is-in.d.mts +22 -139
- package/dist/guard/key-is-in.d.mts.map +1 -1
- package/dist/guard/key-is-in.mjs +22 -139
- package/dist/guard/key-is-in.mjs.map +1 -1
- package/dist/index.d.mts +0 -2
- package/dist/index.d.mts.map +1 -1
- package/dist/index.mjs +0 -5
- package/dist/index.mjs.map +1 -1
- package/dist/iterator/range.d.mts +29 -62
- package/dist/iterator/range.d.mts.map +1 -1
- package/dist/iterator/range.mjs.map +1 -1
- package/dist/json/json.d.mts +191 -122
- package/dist/json/json.d.mts.map +1 -1
- package/dist/json/json.mjs +246 -144
- package/dist/json/json.mjs.map +1 -1
- package/dist/number/branded-types/finite-number.d.mts +24 -156
- package/dist/number/branded-types/finite-number.d.mts.map +1 -1
- package/dist/number/branded-types/finite-number.mjs +28 -160
- package/dist/number/branded-types/finite-number.mjs.map +1 -1
- package/dist/number/branded-types/int.d.mts +122 -120
- package/dist/number/branded-types/int.d.mts.map +1 -1
- package/dist/number/branded-types/int.mjs +123 -121
- package/dist/number/branded-types/int.mjs.map +1 -1
- package/dist/number/branded-types/int16.d.mts +22 -30
- package/dist/number/branded-types/int16.d.mts.map +1 -1
- package/dist/number/branded-types/int16.mjs +23 -31
- package/dist/number/branded-types/int16.mjs.map +1 -1
- package/dist/number/branded-types/int32.d.mts +22 -31
- package/dist/number/branded-types/int32.d.mts.map +1 -1
- package/dist/number/branded-types/int32.mjs +23 -32
- package/dist/number/branded-types/int32.mjs.map +1 -1
- package/dist/number/branded-types/non-negative-finite-number.d.mts +28 -36
- package/dist/number/branded-types/non-negative-finite-number.d.mts.map +1 -1
- package/dist/number/branded-types/non-negative-finite-number.mjs +32 -40
- package/dist/number/branded-types/non-negative-finite-number.mjs.map +1 -1
- package/dist/number/branded-types/non-negative-int16.d.mts +24 -34
- package/dist/number/branded-types/non-negative-int16.d.mts.map +1 -1
- package/dist/number/branded-types/non-negative-int16.mjs +25 -35
- package/dist/number/branded-types/non-negative-int16.mjs.map +1 -1
- package/dist/number/branded-types/non-negative-int32.d.mts +26 -35
- package/dist/number/branded-types/non-negative-int32.d.mts.map +1 -1
- package/dist/number/branded-types/non-negative-int32.mjs +27 -36
- package/dist/number/branded-types/non-negative-int32.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-finite-number.d.mts +22 -37
- package/dist/number/branded-types/non-zero-finite-number.d.mts.map +1 -1
- package/dist/number/branded-types/non-zero-finite-number.mjs +26 -41
- package/dist/number/branded-types/non-zero-finite-number.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-int.d.mts +15 -30
- package/dist/number/branded-types/non-zero-int.d.mts.map +1 -1
- package/dist/number/branded-types/non-zero-int.mjs +16 -31
- package/dist/number/branded-types/non-zero-int.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-int16.d.mts +27 -35
- package/dist/number/branded-types/non-zero-int16.d.mts.map +1 -1
- package/dist/number/branded-types/non-zero-int16.mjs +28 -36
- package/dist/number/branded-types/non-zero-int16.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-int32.d.mts +29 -36
- package/dist/number/branded-types/non-zero-int32.d.mts.map +1 -1
- package/dist/number/branded-types/non-zero-int32.mjs +30 -37
- package/dist/number/branded-types/non-zero-int32.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-safe-int.d.mts +37 -38
- package/dist/number/branded-types/non-zero-safe-int.d.mts.map +1 -1
- package/dist/number/branded-types/non-zero-safe-int.mjs +40 -41
- package/dist/number/branded-types/non-zero-safe-int.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-uint16.d.mts +24 -35
- package/dist/number/branded-types/non-zero-uint16.d.mts.map +1 -1
- package/dist/number/branded-types/non-zero-uint16.mjs +25 -36
- package/dist/number/branded-types/non-zero-uint16.mjs.map +1 -1
- package/dist/number/branded-types/non-zero-uint32.d.mts +24 -35
- package/dist/number/branded-types/non-zero-uint32.d.mts.map +1 -1
- package/dist/number/branded-types/non-zero-uint32.mjs +25 -36
- package/dist/number/branded-types/non-zero-uint32.mjs.map +1 -1
- package/dist/number/branded-types/positive-finite-number.d.mts +26 -40
- package/dist/number/branded-types/positive-finite-number.d.mts.map +1 -1
- package/dist/number/branded-types/positive-finite-number.mjs +30 -44
- package/dist/number/branded-types/positive-finite-number.mjs.map +1 -1
- package/dist/number/branded-types/positive-int.d.mts +133 -123
- package/dist/number/branded-types/positive-int.d.mts.map +1 -1
- package/dist/number/branded-types/positive-int.mjs +134 -124
- package/dist/number/branded-types/positive-int.mjs.map +1 -1
- package/dist/number/branded-types/positive-int16.d.mts +24 -35
- package/dist/number/branded-types/positive-int16.d.mts.map +1 -1
- package/dist/number/branded-types/positive-int16.mjs +25 -36
- package/dist/number/branded-types/positive-int16.mjs.map +1 -1
- package/dist/number/branded-types/positive-int32.d.mts +24 -35
- package/dist/number/branded-types/positive-int32.d.mts.map +1 -1
- package/dist/number/branded-types/positive-int32.mjs +25 -36
- package/dist/number/branded-types/positive-int32.mjs.map +1 -1
- package/dist/number/branded-types/positive-safe-int.d.mts +159 -33
- package/dist/number/branded-types/positive-safe-int.d.mts.map +1 -1
- package/dist/number/branded-types/positive-safe-int.mjs +161 -35
- package/dist/number/branded-types/positive-safe-int.mjs.map +1 -1
- package/dist/number/branded-types/positive-uint16.d.mts +24 -35
- package/dist/number/branded-types/positive-uint16.d.mts.map +1 -1
- package/dist/number/branded-types/positive-uint16.mjs +25 -36
- package/dist/number/branded-types/positive-uint16.mjs.map +1 -1
- package/dist/number/branded-types/positive-uint32.d.mts +26 -36
- package/dist/number/branded-types/positive-uint32.d.mts.map +1 -1
- package/dist/number/branded-types/positive-uint32.mjs +27 -37
- package/dist/number/branded-types/positive-uint32.mjs.map +1 -1
- package/dist/number/branded-types/safe-int.d.mts +140 -99
- package/dist/number/branded-types/safe-int.d.mts.map +1 -1
- package/dist/number/branded-types/safe-int.mjs +143 -102
- package/dist/number/branded-types/safe-int.mjs.map +1 -1
- package/dist/number/branded-types/safe-uint.d.mts +24 -33
- package/dist/number/branded-types/safe-uint.d.mts.map +1 -1
- package/dist/number/branded-types/safe-uint.mjs +26 -35
- package/dist/number/branded-types/safe-uint.mjs.map +1 -1
- package/dist/number/branded-types/uint.d.mts +121 -30
- package/dist/number/branded-types/uint.d.mts.map +1 -1
- package/dist/number/branded-types/uint.mjs +122 -31
- package/dist/number/branded-types/uint.mjs.map +1 -1
- package/dist/number/branded-types/uint16.d.mts +26 -34
- package/dist/number/branded-types/uint16.d.mts.map +1 -1
- package/dist/number/branded-types/uint16.mjs +27 -35
- package/dist/number/branded-types/uint16.mjs.map +1 -1
- package/dist/number/branded-types/uint32.d.mts +26 -68
- package/dist/number/branded-types/uint32.d.mts.map +1 -1
- package/dist/number/branded-types/uint32.mjs +27 -69
- package/dist/number/branded-types/uint32.mjs.map +1 -1
- package/dist/number/enum/int8.d.mts +37 -101
- package/dist/number/enum/int8.d.mts.map +1 -1
- package/dist/number/enum/int8.mjs +40 -171
- package/dist/number/enum/int8.mjs.map +1 -1
- package/dist/number/enum/uint8.d.mts +45 -55
- package/dist/number/enum/uint8.d.mts.map +1 -1
- package/dist/number/enum/uint8.mjs +47 -156
- package/dist/number/enum/uint8.mjs.map +1 -1
- package/dist/number/num.d.mts +145 -206
- package/dist/number/num.d.mts.map +1 -1
- package/dist/number/num.mjs +143 -199
- package/dist/number/num.mjs.map +1 -1
- package/dist/number/refined-number-utils.d.mts +97 -21
- package/dist/number/refined-number-utils.d.mts.map +1 -1
- package/dist/number/refined-number-utils.mjs +91 -22
- package/dist/number/refined-number-utils.mjs.map +1 -1
- package/dist/object/object.d.mts +126 -208
- package/dist/object/object.d.mts.map +1 -1
- package/dist/object/object.mjs +68 -102
- package/dist/object/object.mjs.map +1 -1
- package/dist/others/cast-mutable.d.mts +12 -88
- package/dist/others/cast-mutable.d.mts.map +1 -1
- package/dist/others/cast-mutable.mjs +13 -89
- package/dist/others/cast-mutable.mjs.map +1 -1
- package/dist/others/cast-readonly.d.mts +12 -168
- package/dist/others/cast-readonly.d.mts.map +1 -1
- package/dist/others/cast-readonly.mjs +13 -169
- package/dist/others/cast-readonly.mjs.map +1 -1
- package/dist/others/if-then.d.mts +6 -83
- package/dist/others/if-then.d.mts.map +1 -1
- package/dist/others/if-then.mjs +6 -83
- package/dist/others/if-then.mjs.map +1 -1
- package/dist/others/map-nullable.d.mts +12 -136
- package/dist/others/map-nullable.d.mts.map +1 -1
- package/dist/others/map-nullable.mjs.map +1 -1
- package/dist/others/memoize-function.d.mts +14 -157
- package/dist/others/memoize-function.d.mts.map +1 -1
- package/dist/others/memoize-function.mjs +14 -157
- package/dist/others/memoize-function.mjs.map +1 -1
- package/dist/others/tuple.d.mts +33 -151
- package/dist/others/tuple.d.mts.map +1 -1
- package/dist/others/tuple.mjs +33 -151
- package/dist/others/tuple.mjs.map +1 -1
- package/dist/others/unknown-to-string.d.mts +11 -125
- package/dist/others/unknown-to-string.d.mts.map +1 -1
- package/dist/others/unknown-to-string.mjs +12 -126
- package/dist/others/unknown-to-string.mjs.map +1 -1
- package/dist/promise/promise.d.mts +33 -21
- package/dist/promise/promise.d.mts.map +1 -1
- package/dist/promise/promise.mjs +36 -24
- package/dist/promise/promise.mjs.map +1 -1
- package/package.json +58 -44
- package/src/array/impl/array-utils-creation.mts +192 -0
- package/src/array/{array-utils-creation.test.mts → impl/array-utils-creation.test.mts} +121 -72
- package/src/array/impl/array-utils-element-access.mts +115 -0
- package/src/array/impl/array-utils-element-access.test.mts +151 -0
- package/src/array/impl/array-utils-iterators.mts +79 -0
- package/src/array/impl/array-utils-iterators.test.mts +98 -0
- package/src/array/impl/array-utils-modification.mts +434 -0
- package/src/array/{array-utils-modification.test.mts → impl/array-utils-modification.test.mts} +41 -28
- package/src/array/{array-utils-overload-type-error.test.mts → impl/array-utils-overload-type-error.test.mts} +33 -33
- package/src/array/impl/array-utils-reducing-value.mts +535 -0
- package/src/array/{array-utils-reducing-value.test.mts → impl/array-utils-reducing-value.test.mts} +53 -58
- package/src/array/impl/array-utils-search.mts +509 -0
- package/src/array/impl/array-utils-search.test.mts +346 -0
- package/src/array/impl/array-utils-set-op.mts +166 -0
- package/src/array/{array-utils-set-op.test.mts → impl/array-utils-set-op.test.mts} +42 -35
- package/src/array/impl/array-utils-size.mts +30 -0
- package/src/array/impl/array-utils-size.test.mts +9 -0
- package/src/array/impl/array-utils-slice-clamped.mts +51 -0
- package/src/array/{array-utils-slice-clamped.test.mts → impl/array-utils-slice-clamped.test.mts} +13 -13
- package/src/array/impl/array-utils-slicing.mts +275 -0
- package/src/array/impl/array-utils-slicing.test.mts +158 -0
- package/src/array/impl/array-utils-transformation.mts +746 -0
- package/src/array/{array-utils-transformation.test.mts → impl/array-utils-transformation.test.mts} +662 -889
- package/src/array/impl/array-utils-validation.mts +241 -0
- package/src/array/{array-utils-validation.test.mts → impl/array-utils-validation.test.mts} +194 -107
- package/src/array/{array.test.mts → impl/array.test.mts} +2 -2
- package/src/array/impl/index.mts +12 -0
- package/src/array/index.mts +1 -1
- package/src/collections/imap-mapped.mts +99 -265
- package/src/collections/imap.mts +477 -174
- package/src/collections/imap.test.mts +12 -19
- package/src/collections/iset-mapped.mts +892 -358
- package/src/collections/iset.mts +429 -213
- package/src/collections/queue.mts +174 -200
- package/src/collections/stack.mts +172 -245
- package/src/collections/stack.test.mts +9 -1
- package/src/entry-point.mts +2 -0
- package/src/expect-type.mts +43 -172
- package/src/functional/index.mts +2 -2
- package/src/functional/match.mts +35 -145
- package/src/functional/optional/impl/index.mts +17 -0
- package/src/functional/optional/impl/optional-expect-to-be.mts +65 -0
- package/src/functional/optional/impl/optional-filter.mts +71 -0
- package/src/functional/optional/impl/optional-flat-map.mts +67 -0
- package/src/functional/optional/impl/optional-from-nullable.mts +28 -0
- package/src/functional/optional/impl/optional-is-none.mts +25 -0
- package/src/functional/optional/impl/optional-is-optional.mts +27 -0
- package/src/functional/optional/impl/optional-is-some.mts +25 -0
- package/src/functional/optional/impl/optional-map.mts +69 -0
- package/src/functional/optional/impl/optional-none.mts +17 -0
- package/src/functional/optional/impl/optional-or-else.mts +73 -0
- package/src/functional/optional/impl/optional-some.mts +23 -0
- package/src/functional/optional/impl/optional-to-nullable.mts +31 -0
- package/src/functional/optional/impl/optional-unwrap-or.mts +64 -0
- package/src/functional/optional/impl/optional-unwrap-throw.mts +39 -0
- package/src/functional/optional/impl/optional-unwrap.mts +41 -0
- package/src/functional/optional/impl/optional-zip.mts +40 -0
- package/src/functional/optional/impl/tag.mts +6 -0
- package/src/functional/optional/impl/types.mts +28 -0
- package/src/functional/optional/index.mts +1 -0
- package/src/functional/optional.test.mts +11 -9
- package/src/functional/pipe.mts +65 -118
- package/src/functional/pipe.test.mts +1 -1
- package/src/functional/result/impl/index.mts +23 -0
- package/src/functional/result/impl/result-err.mts +29 -0
- package/src/functional/result/impl/result-expect-to-be.mts +63 -0
- package/src/functional/result/impl/result-flat-map.mts +79 -0
- package/src/functional/result/impl/result-fold.mts +95 -0
- package/src/functional/result/impl/result-from-promise.mts +39 -0
- package/src/functional/result/impl/result-from-throwable.mts +42 -0
- package/src/functional/result/impl/result-is-err.mts +23 -0
- package/src/functional/result/impl/result-is-ok.mts +23 -0
- package/src/functional/result/impl/result-is-result.mts +23 -0
- package/src/functional/result/impl/result-map-err.mts +72 -0
- package/src/functional/result/impl/result-map.mts +73 -0
- package/src/functional/result/impl/result-ok.mts +29 -0
- package/src/functional/result/impl/result-or-else.mts +63 -0
- package/src/functional/result/impl/result-swap.mts +28 -0
- package/src/functional/result/impl/result-to-optional.mts +34 -0
- package/src/functional/result/impl/result-unwrap-err-or.mts +60 -0
- package/src/functional/result/impl/result-unwrap-err-throw.mts +53 -0
- package/src/functional/result/impl/result-unwrap-err.mts +36 -0
- package/src/functional/result/impl/result-unwrap-ok-or.mts +60 -0
- package/src/functional/result/impl/result-unwrap-ok.mts +35 -0
- package/src/functional/result/impl/result-unwrap-throw.mts +43 -0
- package/src/functional/result/impl/result-zip.mts +39 -0
- package/src/functional/result/impl/tag.mts +6 -0
- package/src/functional/result/impl/types.mts +35 -0
- package/src/functional/result/index.mts +1 -0
- package/src/functional/result.test.mts +14 -6
- package/src/globals.d.mts +95 -5
- package/src/guard/has-key.mts +23 -74
- package/src/guard/is-non-empty-string.mts +20 -87
- package/src/guard/is-non-empty-string.test.mts +1 -1
- package/src/guard/is-non-null-object.mts +14 -84
- package/src/guard/is-non-null-object.test.mts +4 -4
- package/src/guard/is-primitive.mts +13 -126
- package/src/guard/is-primitive.test.mts +4 -4
- package/src/guard/is-record.mts +21 -132
- package/src/guard/is-type.mts +201 -238
- package/src/guard/is-type.test.mts +10 -10
- package/src/guard/key-is-in.mts +22 -139
- package/src/index.mts +0 -2
- package/src/iterator/range.mts +29 -62
- package/src/json/json.mts +202 -134
- package/src/json/json.test.mts +1 -3
- package/src/number/branded-types/finite-number.mts +34 -166
- package/src/number/branded-types/int.mts +129 -127
- package/src/number/branded-types/int16.mts +31 -39
- package/src/number/branded-types/int16.test.mts +24 -24
- package/src/number/branded-types/int32.mts +31 -40
- package/src/number/branded-types/int32.test.mts +39 -39
- package/src/number/branded-types/non-negative-finite-number.mts +39 -47
- package/src/number/branded-types/non-negative-int16.mts +33 -43
- package/src/number/branded-types/non-negative-int16.test.mts +16 -16
- package/src/number/branded-types/non-negative-int32.mts +35 -44
- package/src/number/branded-types/non-negative-int32.test.mts +30 -30
- package/src/number/branded-types/non-zero-finite-number.mts +32 -47
- package/src/number/branded-types/non-zero-int.mts +22 -37
- package/src/number/branded-types/non-zero-int16.mts +36 -44
- package/src/number/branded-types/non-zero-int16.test.mts +26 -26
- package/src/number/branded-types/non-zero-int32.mts +38 -45
- package/src/number/branded-types/non-zero-int32.test.mts +45 -42
- package/src/number/branded-types/non-zero-safe-int.mts +48 -49
- package/src/number/branded-types/non-zero-uint16.mts +33 -44
- package/src/number/branded-types/non-zero-uint16.test.mts +16 -16
- package/src/number/branded-types/non-zero-uint32.mts +33 -44
- package/src/number/branded-types/non-zero-uint32.test.mts +28 -28
- package/src/number/branded-types/positive-finite-number.mts +37 -51
- package/src/number/branded-types/positive-int.mts +142 -132
- package/src/number/branded-types/positive-int16.mts +33 -44
- package/src/number/branded-types/positive-int16.test.mts +14 -14
- package/src/number/branded-types/positive-int32.mts +33 -44
- package/src/number/branded-types/positive-int32.test.mts +26 -26
- package/src/number/branded-types/positive-safe-int.mts +169 -43
- package/src/number/branded-types/positive-uint16.mts +33 -44
- package/src/number/branded-types/positive-uint16.test.mts +16 -16
- package/src/number/branded-types/positive-uint32.mts +35 -45
- package/src/number/branded-types/positive-uint32.test.mts +31 -28
- package/src/number/branded-types/safe-int.mts +151 -110
- package/src/number/branded-types/safe-uint.mts +34 -43
- package/src/number/branded-types/uint.mts +129 -38
- package/src/number/branded-types/uint16.mts +35 -43
- package/src/number/branded-types/uint16.test.mts +16 -16
- package/src/number/branded-types/uint32.mts +35 -77
- package/src/number/branded-types/uint32.test.mts +28 -28
- package/src/number/enum/int8.mts +42 -173
- package/src/number/enum/int8.test.mts +9 -9
- package/src/number/enum/uint8.mts +49 -158
- package/src/number/enum/uint8.test.mts +8 -8
- package/src/number/num.mts +157 -212
- package/src/number/num.test.mts +4 -4
- package/src/number/refined-number-utils.mts +109 -26
- package/src/object/object.mts +130 -212
- package/src/object/object.test.mts +29 -0
- package/src/others/cast-mutable.mts +13 -89
- package/src/others/cast-mutable.test.mts +80 -0
- package/src/others/cast-readonly.mts +13 -169
- package/src/others/if-then.mts +6 -83
- package/src/others/map-nullable.mts +12 -136
- package/src/others/map-nullable.test.mts +6 -6
- package/src/others/memoize-function.mts +14 -157
- package/src/others/tuple.mts +33 -151
- package/src/others/unknown-to-string.mts +12 -126
- package/src/others/unknown-to-string.test.mts +13 -1
- package/src/promise/promise.mts +34 -21
- package/src/promise/promise.test.mts +43 -0
- package/dist/array/array-utils.d.mts +0 -2956
- package/dist/array/array-utils.d.mts.map +0 -1
- package/dist/array/array-utils.mjs +0 -1838
- package/dist/array/array-utils.mjs.map +0 -1
- package/dist/functional/optional.d.mts +0 -360
- package/dist/functional/optional.d.mts.map +0 -1
- package/dist/functional/optional.mjs +0 -268
- package/dist/functional/optional.mjs.map +0 -1
- package/dist/functional/result.d.mts +0 -611
- package/dist/functional/result.d.mts.map +0 -1
- package/dist/functional/result.mjs +0 -545
- package/dist/functional/result.mjs.map +0 -1
- package/src/array/array-utils-search.test.mts +0 -169
- package/src/array/array-utils-slicing.test.mts +0 -274
- package/src/array/array-utils.mts +0 -4834
- package/src/functional/optional.mts +0 -591
- package/src/functional/result.mts +0 -986
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { TsDataForgeInternals } from '../refined-number-utils.mjs';
|
|
2
2
|
|
|
3
3
|
const typeNameInMessage = 'a non-zero integer in [-2^31, 2^31)';
|
|
4
|
-
const {
|
|
4
|
+
const { MAX_VALUE, MIN_VALUE, abs, add, castType, clamp, div, is, max: max_, min: min_, mul, pow, randomNonZero: random, sub, } = TsDataForgeInternals.RefinedNumberUtils.operatorsForInteger({
|
|
5
5
|
integerOrSafeInteger: 'SafeInteger',
|
|
6
6
|
nonZero: true,
|
|
7
7
|
MIN_VALUE: -2147483648,
|
|
@@ -9,78 +9,61 @@ const { MIN_VALUE, MAX_VALUE, abs, min: min_, max: max_, pow, add, sub, mul, div
|
|
|
9
9
|
typeNameInMessage,
|
|
10
10
|
});
|
|
11
11
|
/**
|
|
12
|
-
* Checks if a number is a NonZeroInt32 (32-bit non-zero signed integer in the
|
|
12
|
+
* Checks if a number is a NonZeroInt32 (32-bit non-zero signed integer in the
|
|
13
|
+
* range [-2^31, 2^31) excluding 0).
|
|
14
|
+
*
|
|
13
15
|
* @param value The value to check.
|
|
14
16
|
* @returns `true` if the value is a NonZeroInt32, `false` otherwise.
|
|
15
17
|
*/
|
|
16
18
|
const isNonZeroInt32 = is;
|
|
17
19
|
/**
|
|
18
20
|
* Casts a number to a NonZeroInt32 type.
|
|
21
|
+
*
|
|
19
22
|
* @param value The value to cast.
|
|
20
23
|
* @returns The value as a NonZeroInt32 type.
|
|
21
24
|
* @throws {TypeError} If the value is not a non-zero integer in [-2^31, 2^31).
|
|
22
|
-
* @example
|
|
23
|
-
* ```typescript
|
|
24
|
-
* const x = asNonZeroInt32(1000); // NonZeroInt32
|
|
25
|
-
* const y = asNonZeroInt32(-1000); // NonZeroInt32
|
|
26
|
-
* // asNonZeroInt32(0); // throws TypeError
|
|
27
|
-
* // asNonZeroInt32(2147483648); // throws TypeError
|
|
28
|
-
* ```
|
|
29
25
|
*/
|
|
30
26
|
const asNonZeroInt32 = castType;
|
|
31
27
|
/**
|
|
32
|
-
* Namespace providing type-safe arithmetic operations for 32-bit non-zero
|
|
33
|
-
*
|
|
34
|
-
* All operations automatically clamp results to the valid NonZeroInt32 range [-2147483648, 2147483647]
|
|
35
|
-
* excluding 0. This ensures that all arithmetic maintains the 32-bit non-zero signed integer
|
|
36
|
-
* constraint, preventing zero results and overflow.
|
|
37
|
-
*
|
|
38
|
-
* @example
|
|
39
|
-
* ```typescript
|
|
40
|
-
* const a = asNonZeroInt32(2000000000);
|
|
41
|
-
* const b = asNonZeroInt32(-500000000);
|
|
42
|
-
*
|
|
43
|
-
* // Arithmetic operations with automatic clamping and non-zero constraint
|
|
44
|
-
* const sum = NonZeroInt32.add(a, b); // NonZeroInt32 (1500000000)
|
|
45
|
-
* const diff = NonZeroInt32.sub(a, b); // NonZeroInt32 (2147483647 - clamped to MAX_VALUE)
|
|
46
|
-
* const product = NonZeroInt32.mul(a, b); // NonZeroInt32 (-2147483648 - clamped to MIN_VALUE)
|
|
47
|
-
*
|
|
48
|
-
* // Utility operations
|
|
49
|
-
* const absolute = NonZeroInt32.abs(b); // NonZeroInt32 (500000000)
|
|
50
|
-
* const minimum = NonZeroInt32.min(a, b); // NonZeroInt32 (-500000000)
|
|
51
|
-
* const maximum = NonZeroInt32.max(a, b); // NonZeroInt32 (2000000000)
|
|
28
|
+
* Namespace providing type-safe arithmetic operations for 32-bit non-zero
|
|
29
|
+
* signed integers.
|
|
52
30
|
*
|
|
53
|
-
*
|
|
54
|
-
*
|
|
55
|
-
*
|
|
56
|
-
*
|
|
57
|
-
* ```
|
|
31
|
+
* All operations automatically clamp results to the valid NonZeroInt32 range
|
|
32
|
+
* [-2147483648, 2147483647] excluding 0. This ensures that all arithmetic
|
|
33
|
+
* maintains the 32-bit non-zero signed integer constraint, preventing zero
|
|
34
|
+
* results and overflow.
|
|
58
35
|
*/
|
|
59
36
|
const NonZeroInt32 = {
|
|
60
37
|
/**
|
|
61
38
|
* Type guard to check if a value is a NonZeroInt32.
|
|
39
|
+
*
|
|
62
40
|
* @param value The value to check.
|
|
63
|
-
* @returns `true` if the value is a 32-bit non-zero signed integer, `false`
|
|
41
|
+
* @returns `true` if the value is a 32-bit non-zero signed integer, `false`
|
|
42
|
+
* otherwise.
|
|
64
43
|
*/
|
|
65
44
|
is,
|
|
66
45
|
/**
|
|
67
46
|
* The minimum value for a 32-bit non-zero signed integer.
|
|
47
|
+
*
|
|
68
48
|
* @readonly
|
|
69
49
|
*/
|
|
70
50
|
MIN_VALUE,
|
|
71
51
|
/**
|
|
72
52
|
* The maximum value for a 32-bit non-zero signed integer.
|
|
53
|
+
*
|
|
73
54
|
* @readonly
|
|
74
55
|
*/
|
|
75
56
|
MAX_VALUE,
|
|
76
57
|
/**
|
|
77
58
|
* Returns the absolute value of a 32-bit non-zero signed integer.
|
|
59
|
+
*
|
|
78
60
|
* @param a The NonZeroInt32 value.
|
|
79
61
|
* @returns The absolute value as a NonZeroInt32, clamped to valid range.
|
|
80
62
|
*/
|
|
81
63
|
abs,
|
|
82
64
|
/**
|
|
83
65
|
* Returns the smaller of two NonZeroInt32 values.
|
|
66
|
+
*
|
|
84
67
|
* @param a The first NonZeroInt32.
|
|
85
68
|
* @param b The second NonZeroInt32.
|
|
86
69
|
* @returns The minimum value as a NonZeroInt32.
|
|
@@ -88,6 +71,7 @@ const NonZeroInt32 = {
|
|
|
88
71
|
min: min_,
|
|
89
72
|
/**
|
|
90
73
|
* Returns the larger of two NonZeroInt32 values.
|
|
74
|
+
*
|
|
91
75
|
* @param a The first NonZeroInt32.
|
|
92
76
|
* @param b The second NonZeroInt32.
|
|
93
77
|
* @returns The maximum value as a NonZeroInt32.
|
|
@@ -95,17 +79,22 @@ const NonZeroInt32 = {
|
|
|
95
79
|
max: max_,
|
|
96
80
|
/**
|
|
97
81
|
* Clamps a number to the NonZeroInt32 range (avoiding zero).
|
|
82
|
+
*
|
|
98
83
|
* @param value The number to clamp.
|
|
99
|
-
* @returns The value clamped to [-2147483648, 2147483647] \ {0} as a
|
|
84
|
+
* @returns The value clamped to [-2147483648, 2147483647] \ {0} as a
|
|
85
|
+
* NonZeroInt32.
|
|
100
86
|
*/
|
|
101
87
|
clamp,
|
|
102
88
|
/**
|
|
103
89
|
* Generates a random NonZeroInt32 value within the valid range.
|
|
104
|
-
*
|
|
90
|
+
*
|
|
91
|
+
* @returns A random NonZeroInt32 between MIN_VALUE and MAX_VALUE (excluding
|
|
92
|
+
* 0).
|
|
105
93
|
*/
|
|
106
94
|
random,
|
|
107
95
|
/**
|
|
108
96
|
* Raises a NonZeroInt32 to the power of another NonZeroInt32.
|
|
97
|
+
*
|
|
109
98
|
* @param a The base NonZeroInt32.
|
|
110
99
|
* @param b The exponent NonZeroInt32.
|
|
111
100
|
* @returns `a ** b` clamped to [-2147483648, 2147483647] as a NonZeroInt32.
|
|
@@ -113,6 +102,7 @@ const NonZeroInt32 = {
|
|
|
113
102
|
pow,
|
|
114
103
|
/**
|
|
115
104
|
* Adds two NonZeroInt32 values.
|
|
105
|
+
*
|
|
116
106
|
* @param a The first NonZeroInt32.
|
|
117
107
|
* @param b The second NonZeroInt32.
|
|
118
108
|
* @returns `a + b` clamped to [-2147483648, 2147483647] as a NonZeroInt32.
|
|
@@ -120,6 +110,7 @@ const NonZeroInt32 = {
|
|
|
120
110
|
add,
|
|
121
111
|
/**
|
|
122
112
|
* Subtracts one NonZeroInt32 from another.
|
|
113
|
+
*
|
|
123
114
|
* @param a The minuend NonZeroInt32.
|
|
124
115
|
* @param b The subtrahend NonZeroInt32.
|
|
125
116
|
* @returns `a - b` clamped to [-2147483648, 2147483647] as a NonZeroInt32.
|
|
@@ -127,6 +118,7 @@ const NonZeroInt32 = {
|
|
|
127
118
|
sub,
|
|
128
119
|
/**
|
|
129
120
|
* Multiplies two NonZeroInt32 values.
|
|
121
|
+
*
|
|
130
122
|
* @param a The first NonZeroInt32.
|
|
131
123
|
* @param b The second NonZeroInt32.
|
|
132
124
|
* @returns `a * b` clamped to [-2147483648, 2147483647] as a NonZeroInt32.
|
|
@@ -134,6 +126,7 @@ const NonZeroInt32 = {
|
|
|
134
126
|
mul,
|
|
135
127
|
/**
|
|
136
128
|
* Divides one NonZeroInt32 by another using floor division.
|
|
129
|
+
*
|
|
137
130
|
* @param a The dividend NonZeroInt32.
|
|
138
131
|
* @param b The divisor NonZeroInt32.
|
|
139
132
|
* @returns `⌊a / b⌋` clamped to [-2147483648, 2147483647] as a NonZeroInt32.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"non-zero-int32.mjs","sources":["../../../src/number/branded-types/non-zero-int32.mts"],"sourcesContent":[null],"names":[],"mappings":";;AAKA,MAAM,iBAAiB,GAAG,qCAAqC;AAE/D,MAAM,EACJ,SAAS,EACT,SAAS,EACT,GAAG,EACH,GAAG,
|
|
1
|
+
{"version":3,"file":"non-zero-int32.mjs","sources":["../../../src/number/branded-types/non-zero-int32.mts"],"sourcesContent":[null],"names":[],"mappings":";;AAKA,MAAM,iBAAiB,GAAG,qCAAqC;AAE/D,MAAM,EACJ,SAAS,EACT,SAAS,EACT,GAAG,EACH,GAAG,EACH,QAAQ,EACR,KAAK,EACL,GAAG,EACH,EAAE,EACF,GAAG,EAAE,IAAI,EACT,GAAG,EAAE,IAAI,EACT,GAAG,EACH,GAAG,EACH,aAAa,EAAE,MAAM,EACrB,GAAG,GACJ,GAAG,oBAAoB,CAAC,kBAAkB,CAAC,mBAAmB,CAI7D;AACA,IAAA,oBAAoB,EAAE,aAAa;AACnC,IAAA,OAAO,EAAE,IAAI;AACb,IAAA,SAAS,EAAE,WAAU;AACrB,IAAA,SAAS,EAAE,CAAC,IAAI,EAAE,GAAG,CAAC;IACtB,iBAAiB;AACT,CAAA,CAAC;AAEX;;;;;;AAMG;AACI,MAAM,cAAc,GAAG;AAE9B;;;;;;AAMG;AACI,MAAM,cAAc,GAAG;AAE9B;;;;;;;;AAQG;AACI,MAAM,YAAY,GAAG;AAC1B;;;;;;AAMG;IACH,EAAE;AAEF;;;;AAIG;IACH,SAAS;AAET;;;;AAIG;IACH,SAAS;AAET;;;;;AAKG;IACH,GAAG;AAEH;;;;;;AAMG;AACH,IAAA,GAAG,EAAE,IAAI;AAET;;;;;;AAMG;AACH,IAAA,GAAG,EAAE,IAAI;AAET;;;;;;AAMG;IACH,KAAK;AAEL;;;;;AAKG;IACH,MAAM;AAEN;;;;;;AAMG;IACH,GAAG;AAEH;;;;;;AAMG;IACH,GAAG;AAEH;;;;;;AAMG;IACH,GAAG;AAEH;;;;;;AAMG;IACH,GAAG;AAEH;;;;;;AAMG;IACH,GAAG;;;;;"}
|
|
@@ -1,22 +1,18 @@
|
|
|
1
1
|
import { TsDataForgeInternals } from '../refined-number-utils.mjs';
|
|
2
2
|
/**
|
|
3
|
-
* Checks if a number is a NonZeroSafeInt (a non-zero safe integer in the range
|
|
3
|
+
* Checks if a number is a NonZeroSafeInt (a non-zero safe integer in the range
|
|
4
|
+
* [MIN_SAFE_INTEGER, MAX_SAFE_INTEGER] excluding 0).
|
|
5
|
+
*
|
|
4
6
|
* @param value The value to check.
|
|
5
7
|
* @returns `true` if the value is a NonZeroSafeInt, `false` otherwise.
|
|
6
8
|
*/
|
|
7
9
|
export declare const isNonZeroSafeInt: (a: number) => a is NonZeroSafeInt;
|
|
8
10
|
/**
|
|
9
11
|
* Casts a number to a NonZeroSafeInt type.
|
|
12
|
+
*
|
|
10
13
|
* @param value The value to cast.
|
|
11
14
|
* @returns The value as a NonZeroSafeInt type.
|
|
12
15
|
* @throws {TypeError} If the value is not a non-zero safe integer.
|
|
13
|
-
* @example
|
|
14
|
-
* ```typescript
|
|
15
|
-
* const x = asNonZeroSafeInt(5); // NonZeroSafeInt
|
|
16
|
-
* const y = asNonZeroSafeInt(-1000); // NonZeroSafeInt
|
|
17
|
-
* // asNonZeroSafeInt(0); // throws TypeError
|
|
18
|
-
* // asNonZeroSafeInt(1.5); // throws TypeError
|
|
19
|
-
* ```
|
|
20
16
|
*/
|
|
21
17
|
export declare const asNonZeroSafeInt: <N extends number>(x: N) => number & {
|
|
22
18
|
readonly NaNValue: false;
|
|
@@ -28,56 +24,44 @@ export declare const asNonZeroSafeInt: <N extends number>(x: N) => number & {
|
|
|
28
24
|
'TSTypeForgeInternals--edd2f9ce-7ca5-45b0-9d1a-bd61b9b5d9c3': unknown;
|
|
29
25
|
}> & N;
|
|
30
26
|
/**
|
|
31
|
-
* Namespace providing type-safe arithmetic operations for non-zero safe
|
|
32
|
-
*
|
|
33
|
-
* All operations automatically clamp results to the non-zero safe integer range, excluding zero.
|
|
34
|
-
* This ensures that all arithmetic maintains both the non-zero constraint and IEEE 754 precision guarantees,
|
|
35
|
-
* preventing precision loss while ensuring results are never zero.
|
|
36
|
-
*
|
|
37
|
-
* @example
|
|
38
|
-
* ```typescript
|
|
39
|
-
* const a = asNonZeroSafeInt(9007199254740000); // Near MAX_SAFE_INTEGER
|
|
40
|
-
* const b = asNonZeroSafeInt(-1000);
|
|
41
|
-
*
|
|
42
|
-
* // Arithmetic operations with non-zero safe range clamping
|
|
43
|
-
* const sum = NonZeroSafeInt.add(a, b); // NonZeroSafeInt (9007199254739000)
|
|
44
|
-
* const diff = NonZeroSafeInt.sub(a, b); // NonZeroSafeInt (clamped to MAX_SAFE_INTEGER)
|
|
45
|
-
* const product = NonZeroSafeInt.mul(a, b); // NonZeroSafeInt (clamped to MIN_SAFE_INTEGER)
|
|
46
|
-
*
|
|
47
|
-
* // Utility operations
|
|
48
|
-
* const absolute = NonZeroSafeInt.abs(b); // NonZeroSafeInt (1000)
|
|
49
|
-
* const minimum = NonZeroSafeInt.min(a, b); // NonZeroSafeInt (-1000)
|
|
50
|
-
* const maximum = NonZeroSafeInt.max(a, b); // NonZeroSafeInt (a)
|
|
27
|
+
* Namespace providing type-safe arithmetic operations for non-zero safe
|
|
28
|
+
* integers.
|
|
51
29
|
*
|
|
52
|
-
*
|
|
53
|
-
*
|
|
54
|
-
*
|
|
30
|
+
* All operations automatically clamp results to the non-zero safe integer
|
|
31
|
+
* range, excluding zero. This ensures that all arithmetic maintains both the
|
|
32
|
+
* non-zero constraint and IEEE 754 precision guarantees, preventing precision
|
|
33
|
+
* loss while ensuring results are never zero.
|
|
55
34
|
*/
|
|
56
35
|
export declare const NonZeroSafeInt: {
|
|
57
36
|
/**
|
|
58
37
|
* Type guard to check if a value is a NonZeroSafeInt.
|
|
38
|
+
*
|
|
59
39
|
* @param value The value to check.
|
|
60
40
|
* @returns `true` if the value is a non-zero safe integer, `false` otherwise.
|
|
61
41
|
*/
|
|
62
42
|
readonly is: (a: number) => a is NonZeroSafeInt;
|
|
63
43
|
/**
|
|
64
44
|
* The minimum safe integer value (-(2^53 - 1)).
|
|
45
|
+
*
|
|
65
46
|
* @readonly
|
|
66
47
|
*/
|
|
67
48
|
readonly MIN_VALUE: SafeInt;
|
|
68
49
|
/**
|
|
69
50
|
* The maximum safe integer value (2^53 - 1).
|
|
51
|
+
*
|
|
70
52
|
* @readonly
|
|
71
53
|
*/
|
|
72
54
|
readonly MAX_VALUE: SafeUint;
|
|
73
55
|
/**
|
|
74
56
|
* Returns the absolute value of a non-zero safe integer.
|
|
57
|
+
*
|
|
75
58
|
* @param a The NonZeroSafeInt value.
|
|
76
59
|
* @returns The absolute value as a NonZeroSafeInt, clamped to safe range.
|
|
77
60
|
*/
|
|
78
61
|
readonly abs: (x: WithSmallInt<NonZeroSafeInt, 40>) => TsDataForgeInternals.RefinedNumberUtils.ToNonNegative<NonZeroSafeInt>;
|
|
79
62
|
/**
|
|
80
63
|
* Returns the smaller of two NonZeroSafeInt values.
|
|
64
|
+
*
|
|
81
65
|
* @param a The first NonZeroSafeInt.
|
|
82
66
|
* @param b The second NonZeroSafeInt.
|
|
83
67
|
* @returns The minimum value as a NonZeroSafeInt.
|
|
@@ -85,6 +69,7 @@ export declare const NonZeroSafeInt: {
|
|
|
85
69
|
readonly min: (...values: readonly WithSmallInt<NonZeroSafeInt, 40>[]) => NonZeroSafeInt;
|
|
86
70
|
/**
|
|
87
71
|
* Returns the larger of two NonZeroSafeInt values.
|
|
72
|
+
*
|
|
88
73
|
* @param a The first NonZeroSafeInt.
|
|
89
74
|
* @param b The second NonZeroSafeInt.
|
|
90
75
|
* @returns The maximum value as a NonZeroSafeInt.
|
|
@@ -92,48 +77,62 @@ export declare const NonZeroSafeInt: {
|
|
|
92
77
|
readonly max: (...values: readonly WithSmallInt<NonZeroSafeInt, 40>[]) => NonZeroSafeInt;
|
|
93
78
|
/**
|
|
94
79
|
* Clamps a number to the non-zero safe integer range.
|
|
80
|
+
*
|
|
95
81
|
* @param value The number to clamp.
|
|
96
|
-
* @returns The value clamped to [MIN_SAFE_INTEGER, MAX_SAFE_INTEGER] \ {0} as
|
|
82
|
+
* @returns The value clamped to [MIN_SAFE_INTEGER, MAX_SAFE_INTEGER] \ {0} as
|
|
83
|
+
* a NonZeroSafeInt.
|
|
97
84
|
*/
|
|
98
85
|
readonly clamp: (x: number) => NonZeroSafeInt;
|
|
99
86
|
/**
|
|
100
87
|
* Generates a random NonZeroSafeInt value within the valid range.
|
|
101
|
-
*
|
|
88
|
+
*
|
|
89
|
+
* @returns A random non-zero safe integer between MIN_SAFE_INTEGER and
|
|
90
|
+
* MAX_SAFE_INTEGER.
|
|
102
91
|
*/
|
|
103
92
|
readonly random: (min?: WithSmallInt<NonZeroSafeInt, 40> | undefined, max?: WithSmallInt<NonZeroSafeInt, 40> | undefined) => NonZeroSafeInt;
|
|
104
93
|
/**
|
|
105
94
|
* Raises a NonZeroSafeInt to the power of another NonZeroSafeInt.
|
|
95
|
+
*
|
|
106
96
|
* @param a The base NonZeroSafeInt.
|
|
107
97
|
* @param b The exponent NonZeroSafeInt.
|
|
108
|
-
* @returns `a ** b` clamped to non-zero safe integer range as a
|
|
98
|
+
* @returns `a ** b` clamped to non-zero safe integer range as a
|
|
99
|
+
* NonZeroSafeInt.
|
|
109
100
|
*/
|
|
110
101
|
readonly pow: (x: WithSmallInt<NonZeroSafeInt, 40>, y: WithSmallInt<NonZeroSafeInt, 40>) => NonZeroSafeInt;
|
|
111
102
|
/**
|
|
112
103
|
* Adds two NonZeroSafeInt values.
|
|
104
|
+
*
|
|
113
105
|
* @param a The first NonZeroSafeInt.
|
|
114
106
|
* @param b The second NonZeroSafeInt.
|
|
115
|
-
* @returns `a + b` clamped to non-zero safe integer range as a
|
|
107
|
+
* @returns `a + b` clamped to non-zero safe integer range as a
|
|
108
|
+
* NonZeroSafeInt.
|
|
116
109
|
*/
|
|
117
110
|
readonly add: (x: WithSmallInt<NonZeroSafeInt, 40>, y: WithSmallInt<NonZeroSafeInt, 40>) => NonZeroSafeInt;
|
|
118
111
|
/**
|
|
119
112
|
* Subtracts one NonZeroSafeInt from another.
|
|
113
|
+
*
|
|
120
114
|
* @param a The minuend NonZeroSafeInt.
|
|
121
115
|
* @param b The subtrahend NonZeroSafeInt.
|
|
122
|
-
* @returns `a - b` clamped to non-zero safe integer range as a
|
|
116
|
+
* @returns `a - b` clamped to non-zero safe integer range as a
|
|
117
|
+
* NonZeroSafeInt.
|
|
123
118
|
*/
|
|
124
119
|
readonly sub: (x: WithSmallInt<NonZeroSafeInt, 40>, y: WithSmallInt<NonZeroSafeInt, 40>) => NonZeroSafeInt;
|
|
125
120
|
/**
|
|
126
121
|
* Multiplies two NonZeroSafeInt values.
|
|
122
|
+
*
|
|
127
123
|
* @param a The first NonZeroSafeInt.
|
|
128
124
|
* @param b The second NonZeroSafeInt.
|
|
129
|
-
* @returns `a * b` clamped to non-zero safe integer range as a
|
|
125
|
+
* @returns `a * b` clamped to non-zero safe integer range as a
|
|
126
|
+
* NonZeroSafeInt.
|
|
130
127
|
*/
|
|
131
128
|
readonly mul: (x: WithSmallInt<NonZeroSafeInt, 40>, y: WithSmallInt<NonZeroSafeInt, 40>) => NonZeroSafeInt;
|
|
132
129
|
/**
|
|
133
130
|
* Divides one NonZeroSafeInt by another using floor division.
|
|
131
|
+
*
|
|
134
132
|
* @param a The dividend NonZeroSafeInt.
|
|
135
133
|
* @param b The divisor NonZeroSafeInt.
|
|
136
|
-
* @returns `⌊a / b⌋` clamped to non-zero safe integer range as a
|
|
134
|
+
* @returns `⌊a / b⌋` clamped to non-zero safe integer range as a
|
|
135
|
+
* NonZeroSafeInt.
|
|
137
136
|
*/
|
|
138
137
|
readonly div: (x: WithSmallInt<NonZeroSafeInt, 40>, y: 1 | 2 | 3 | 32 | 4 | 5 | 6 | 7 | 8 | 9 | 11 | 10 | 24 | 14 | 34 | 12 | 13 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 33 | 35 | 36 | 37 | 38 | 39 | -1 | -2 | -3 | -32 | -4 | -5 | -6 | -7 | -8 | -9 | -11 | -10 | -24 | -14 | -34 | -12 | -13 | -15 | -16 | -17 | -18 | -19 | -20 | -21 | -22 | -23 | -25 | -26 | -27 | -28 | -29 | -30 | -31 | -33 | -35 | -36 | -37 | -38 | -39 | -40 | NormalizeBrandUnion<number & {
|
|
139
138
|
readonly NaNValue: false;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"non-zero-safe-int.d.mts","sourceRoot":"","sources":["../../../src/number/branded-types/non-zero-safe-int.mts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAmCnE
|
|
1
|
+
{"version":3,"file":"non-zero-safe-int.d.mts","sourceRoot":"","sources":["../../../src/number/branded-types/non-zero-safe-int.mts"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAmCnE;;;;;;GAMG;AACH,eAAO,MAAM,gBAAgB,oCAAK,CAAC;AAEnC;;;;;;GAMG;AACH,eAAO,MAAM,gBAAgB;;;;;;;;MAAW,CAAC;AAEzC;;;;;;;;GAQG;AACH,eAAO,MAAM,cAAc;IACzB;;;;;OAKG;;IAGH;;;;OAIG;;IAGH;;;;OAIG;;IAGH;;;;;OAKG;;IAGH;;;;;;OAMG;;IAGH;;;;;;OAMG;;IAGH;;;;;;OAMG;;IAGH;;;;;OAKG;;IAGH;;;;;;;OAOG;;IAGH;;;;;;;OAOG;;IAGH;;;;;;;OAOG;;IAGH;;;;;;;OAOG;;IAGH;;;;;;;OAOG;;;;;;;;;;CAEK,CAAC"}
|
|
@@ -1,86 +1,70 @@
|
|
|
1
1
|
import { TsDataForgeInternals } from '../refined-number-utils.mjs';
|
|
2
2
|
|
|
3
3
|
const typeNameInMessage = 'a non-zero safe integer';
|
|
4
|
-
const {
|
|
4
|
+
const { MAX_VALUE, MIN_VALUE, abs, add, castType, clamp, div, is, max: max_, min: min_, mul, pow, randomNonZero: random, sub, } = TsDataForgeInternals.RefinedNumberUtils.operatorsForInteger({
|
|
5
5
|
integerOrSafeInteger: 'SafeInteger',
|
|
6
6
|
nonZero: true,
|
|
7
|
-
// eslint-disable-next-line
|
|
7
|
+
// eslint-disable-next-line total-functions/no-unsafe-type-assertion
|
|
8
8
|
MIN_VALUE: Number.MIN_SAFE_INTEGER,
|
|
9
|
-
// eslint-disable-next-line
|
|
9
|
+
// eslint-disable-next-line total-functions/no-unsafe-type-assertion
|
|
10
10
|
MAX_VALUE: Number.MAX_SAFE_INTEGER,
|
|
11
11
|
typeNameInMessage,
|
|
12
12
|
});
|
|
13
13
|
/**
|
|
14
|
-
* Checks if a number is a NonZeroSafeInt (a non-zero safe integer in the range
|
|
14
|
+
* Checks if a number is a NonZeroSafeInt (a non-zero safe integer in the range
|
|
15
|
+
* [MIN_SAFE_INTEGER, MAX_SAFE_INTEGER] excluding 0).
|
|
16
|
+
*
|
|
15
17
|
* @param value The value to check.
|
|
16
18
|
* @returns `true` if the value is a NonZeroSafeInt, `false` otherwise.
|
|
17
19
|
*/
|
|
18
20
|
const isNonZeroSafeInt = is;
|
|
19
21
|
/**
|
|
20
22
|
* Casts a number to a NonZeroSafeInt type.
|
|
23
|
+
*
|
|
21
24
|
* @param value The value to cast.
|
|
22
25
|
* @returns The value as a NonZeroSafeInt type.
|
|
23
26
|
* @throws {TypeError} If the value is not a non-zero safe integer.
|
|
24
|
-
* @example
|
|
25
|
-
* ```typescript
|
|
26
|
-
* const x = asNonZeroSafeInt(5); // NonZeroSafeInt
|
|
27
|
-
* const y = asNonZeroSafeInt(-1000); // NonZeroSafeInt
|
|
28
|
-
* // asNonZeroSafeInt(0); // throws TypeError
|
|
29
|
-
* // asNonZeroSafeInt(1.5); // throws TypeError
|
|
30
|
-
* ```
|
|
31
27
|
*/
|
|
32
28
|
const asNonZeroSafeInt = castType;
|
|
33
29
|
/**
|
|
34
|
-
* Namespace providing type-safe arithmetic operations for non-zero safe
|
|
35
|
-
*
|
|
36
|
-
* All operations automatically clamp results to the non-zero safe integer range, excluding zero.
|
|
37
|
-
* This ensures that all arithmetic maintains both the non-zero constraint and IEEE 754 precision guarantees,
|
|
38
|
-
* preventing precision loss while ensuring results are never zero.
|
|
39
|
-
*
|
|
40
|
-
* @example
|
|
41
|
-
* ```typescript
|
|
42
|
-
* const a = asNonZeroSafeInt(9007199254740000); // Near MAX_SAFE_INTEGER
|
|
43
|
-
* const b = asNonZeroSafeInt(-1000);
|
|
44
|
-
*
|
|
45
|
-
* // Arithmetic operations with non-zero safe range clamping
|
|
46
|
-
* const sum = NonZeroSafeInt.add(a, b); // NonZeroSafeInt (9007199254739000)
|
|
47
|
-
* const diff = NonZeroSafeInt.sub(a, b); // NonZeroSafeInt (clamped to MAX_SAFE_INTEGER)
|
|
48
|
-
* const product = NonZeroSafeInt.mul(a, b); // NonZeroSafeInt (clamped to MIN_SAFE_INTEGER)
|
|
49
|
-
*
|
|
50
|
-
* // Utility operations
|
|
51
|
-
* const absolute = NonZeroSafeInt.abs(b); // NonZeroSafeInt (1000)
|
|
52
|
-
* const minimum = NonZeroSafeInt.min(a, b); // NonZeroSafeInt (-1000)
|
|
53
|
-
* const maximum = NonZeroSafeInt.max(a, b); // NonZeroSafeInt (a)
|
|
30
|
+
* Namespace providing type-safe arithmetic operations for non-zero safe
|
|
31
|
+
* integers.
|
|
54
32
|
*
|
|
55
|
-
*
|
|
56
|
-
*
|
|
57
|
-
*
|
|
33
|
+
* All operations automatically clamp results to the non-zero safe integer
|
|
34
|
+
* range, excluding zero. This ensures that all arithmetic maintains both the
|
|
35
|
+
* non-zero constraint and IEEE 754 precision guarantees, preventing precision
|
|
36
|
+
* loss while ensuring results are never zero.
|
|
58
37
|
*/
|
|
59
38
|
const NonZeroSafeInt = {
|
|
60
39
|
/**
|
|
61
40
|
* Type guard to check if a value is a NonZeroSafeInt.
|
|
41
|
+
*
|
|
62
42
|
* @param value The value to check.
|
|
63
43
|
* @returns `true` if the value is a non-zero safe integer, `false` otherwise.
|
|
64
44
|
*/
|
|
65
45
|
is,
|
|
66
46
|
/**
|
|
67
47
|
* The minimum safe integer value (-(2^53 - 1)).
|
|
48
|
+
*
|
|
68
49
|
* @readonly
|
|
69
50
|
*/
|
|
70
51
|
MIN_VALUE,
|
|
71
52
|
/**
|
|
72
53
|
* The maximum safe integer value (2^53 - 1).
|
|
54
|
+
*
|
|
73
55
|
* @readonly
|
|
74
56
|
*/
|
|
75
57
|
MAX_VALUE,
|
|
76
58
|
/**
|
|
77
59
|
* Returns the absolute value of a non-zero safe integer.
|
|
60
|
+
*
|
|
78
61
|
* @param a The NonZeroSafeInt value.
|
|
79
62
|
* @returns The absolute value as a NonZeroSafeInt, clamped to safe range.
|
|
80
63
|
*/
|
|
81
64
|
abs,
|
|
82
65
|
/**
|
|
83
66
|
* Returns the smaller of two NonZeroSafeInt values.
|
|
67
|
+
*
|
|
84
68
|
* @param a The first NonZeroSafeInt.
|
|
85
69
|
* @param b The second NonZeroSafeInt.
|
|
86
70
|
* @returns The minimum value as a NonZeroSafeInt.
|
|
@@ -88,6 +72,7 @@ const NonZeroSafeInt = {
|
|
|
88
72
|
min: min_,
|
|
89
73
|
/**
|
|
90
74
|
* Returns the larger of two NonZeroSafeInt values.
|
|
75
|
+
*
|
|
91
76
|
* @param a The first NonZeroSafeInt.
|
|
92
77
|
* @param b The second NonZeroSafeInt.
|
|
93
78
|
* @returns The maximum value as a NonZeroSafeInt.
|
|
@@ -95,48 +80,62 @@ const NonZeroSafeInt = {
|
|
|
95
80
|
max: max_,
|
|
96
81
|
/**
|
|
97
82
|
* Clamps a number to the non-zero safe integer range.
|
|
83
|
+
*
|
|
98
84
|
* @param value The number to clamp.
|
|
99
|
-
* @returns The value clamped to [MIN_SAFE_INTEGER, MAX_SAFE_INTEGER] \ {0} as
|
|
85
|
+
* @returns The value clamped to [MIN_SAFE_INTEGER, MAX_SAFE_INTEGER] \ {0} as
|
|
86
|
+
* a NonZeroSafeInt.
|
|
100
87
|
*/
|
|
101
88
|
clamp,
|
|
102
89
|
/**
|
|
103
90
|
* Generates a random NonZeroSafeInt value within the valid range.
|
|
104
|
-
*
|
|
91
|
+
*
|
|
92
|
+
* @returns A random non-zero safe integer between MIN_SAFE_INTEGER and
|
|
93
|
+
* MAX_SAFE_INTEGER.
|
|
105
94
|
*/
|
|
106
95
|
random,
|
|
107
96
|
/**
|
|
108
97
|
* Raises a NonZeroSafeInt to the power of another NonZeroSafeInt.
|
|
98
|
+
*
|
|
109
99
|
* @param a The base NonZeroSafeInt.
|
|
110
100
|
* @param b The exponent NonZeroSafeInt.
|
|
111
|
-
* @returns `a ** b` clamped to non-zero safe integer range as a
|
|
101
|
+
* @returns `a ** b` clamped to non-zero safe integer range as a
|
|
102
|
+
* NonZeroSafeInt.
|
|
112
103
|
*/
|
|
113
104
|
pow,
|
|
114
105
|
/**
|
|
115
106
|
* Adds two NonZeroSafeInt values.
|
|
107
|
+
*
|
|
116
108
|
* @param a The first NonZeroSafeInt.
|
|
117
109
|
* @param b The second NonZeroSafeInt.
|
|
118
|
-
* @returns `a + b` clamped to non-zero safe integer range as a
|
|
110
|
+
* @returns `a + b` clamped to non-zero safe integer range as a
|
|
111
|
+
* NonZeroSafeInt.
|
|
119
112
|
*/
|
|
120
113
|
add,
|
|
121
114
|
/**
|
|
122
115
|
* Subtracts one NonZeroSafeInt from another.
|
|
116
|
+
*
|
|
123
117
|
* @param a The minuend NonZeroSafeInt.
|
|
124
118
|
* @param b The subtrahend NonZeroSafeInt.
|
|
125
|
-
* @returns `a - b` clamped to non-zero safe integer range as a
|
|
119
|
+
* @returns `a - b` clamped to non-zero safe integer range as a
|
|
120
|
+
* NonZeroSafeInt.
|
|
126
121
|
*/
|
|
127
122
|
sub,
|
|
128
123
|
/**
|
|
129
124
|
* Multiplies two NonZeroSafeInt values.
|
|
125
|
+
*
|
|
130
126
|
* @param a The first NonZeroSafeInt.
|
|
131
127
|
* @param b The second NonZeroSafeInt.
|
|
132
|
-
* @returns `a * b` clamped to non-zero safe integer range as a
|
|
128
|
+
* @returns `a * b` clamped to non-zero safe integer range as a
|
|
129
|
+
* NonZeroSafeInt.
|
|
133
130
|
*/
|
|
134
131
|
mul,
|
|
135
132
|
/**
|
|
136
133
|
* Divides one NonZeroSafeInt by another using floor division.
|
|
134
|
+
*
|
|
137
135
|
* @param a The dividend NonZeroSafeInt.
|
|
138
136
|
* @param b The divisor NonZeroSafeInt.
|
|
139
|
-
* @returns `⌊a / b⌋` clamped to non-zero safe integer range as a
|
|
137
|
+
* @returns `⌊a / b⌋` clamped to non-zero safe integer range as a
|
|
138
|
+
* NonZeroSafeInt.
|
|
140
139
|
*/
|
|
141
140
|
div,
|
|
142
141
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"non-zero-safe-int.mjs","sources":["../../../src/number/branded-types/non-zero-safe-int.mts"],"sourcesContent":[null],"names":[],"mappings":";;AAKA,MAAM,iBAAiB,GAAG,yBAAyB;AAEnD,MAAM,EACJ,SAAS,EACT,SAAS,EACT,GAAG,EACH,GAAG,
|
|
1
|
+
{"version":3,"file":"non-zero-safe-int.mjs","sources":["../../../src/number/branded-types/non-zero-safe-int.mts"],"sourcesContent":[null],"names":[],"mappings":";;AAKA,MAAM,iBAAiB,GAAG,yBAAyB;AAEnD,MAAM,EACJ,SAAS,EACT,SAAS,EACT,GAAG,EACH,GAAG,EACH,QAAQ,EACR,KAAK,EACL,GAAG,EACH,EAAE,EACF,GAAG,EAAE,IAAI,EACT,GAAG,EAAE,IAAI,EACT,GAAG,EACH,GAAG,EACH,aAAa,EAAE,MAAM,EACrB,GAAG,GACJ,GAAG,oBAAoB,CAAC,kBAAkB,CAAC,mBAAmB,CAI7D;AACA,IAAA,oBAAoB,EAAE,aAAa;AACnC,IAAA,OAAO,EAAE,IAAI;;IAEb,SAAS,EAAE,MAAM,CAAC,gBAA2B;;IAE7C,SAAS,EAAE,MAAM,CAAC,gBAA4B;IAC9C,iBAAiB;AACT,CAAA,CAAC;AAEX;;;;;;AAMG;AACI,MAAM,gBAAgB,GAAG;AAEhC;;;;;;AAMG;AACI,MAAM,gBAAgB,GAAG;AAEhC;;;;;;;;AAQG;AACI,MAAM,cAAc,GAAG;AAC5B;;;;;AAKG;IACH,EAAE;AAEF;;;;AAIG;IACH,SAAS;AAET;;;;AAIG;IACH,SAAS;AAET;;;;;AAKG;IACH,GAAG;AAEH;;;;;;AAMG;AACH,IAAA,GAAG,EAAE,IAAI;AAET;;;;;;AAMG;AACH,IAAA,GAAG,EAAE,IAAI;AAET;;;;;;AAMG;IACH,KAAK;AAEL;;;;;AAKG;IACH,MAAM;AAEN;;;;;;;AAOG;IACH,GAAG;AAEH;;;;;;;AAOG;IACH,GAAG;AAEH;;;;;;;AAOG;IACH,GAAG;AAEH;;;;;;;AAOG;IACH,GAAG;AAEH;;;;;;;AAOG;IACH,GAAG;;;;;"}
|