@fncts/base 0.0.19 → 0.0.21
Sign up to get free protection for your applications and to get access to all the features.
- package/_cjs/collection/Iterable/api/traverseConc.cjs +8 -8
- package/_cjs/collection/Iterable/api/traverseConc.cjs.map +1 -1
- package/_cjs/collection/Iterable/api.cjs +497 -444
- package/_cjs/collection/Iterable/api.cjs.map +1 -1
- package/_cjs/collection/Iterable/constructors.cjs +7 -7
- package/_cjs/collection/Iterable/constructors.cjs.map +1 -1
- package/_cjs/collection/compat/Array/api.cjs +16 -12
- package/_cjs/collection/compat/Array/api.cjs.map +1 -1
- package/_cjs/collection/compat/Array/derivations.cjs +41 -19
- package/_cjs/collection/compat/Array/derivations.cjs.map +1 -1
- package/_cjs/collection/compat/ArrayLike/api.cjs +1 -1
- package/_cjs/collection/compat/ArrayLike/api.cjs.map +1 -1
- package/_cjs/collection/compat/Record/instances.cjs +39 -3
- package/_cjs/collection/compat/Record/instances.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/api/makeBy.cjs +1 -1
- package/_cjs/collection/immutable/Conc/api/makeBy.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/api.cjs +866 -765
- package/_cjs/collection/immutable/Conc/api.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/definition.cjs +55 -53
- package/_cjs/collection/immutable/Conc/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc/derivations.cjs +13 -2
- package/_cjs/collection/immutable/Conc/derivations.cjs.map +1 -1
- package/_cjs/collection/immutable/Conc.cjs.map +1 -1
- package/_cjs/collection/immutable/Dictionary/api.cjs +57 -44
- package/_cjs/collection/immutable/Dictionary/api.cjs.map +1 -1
- package/_cjs/collection/immutable/HashMap/api.cjs +351 -258
- package/_cjs/collection/immutable/HashMap/api.cjs.map +1 -1
- package/_cjs/collection/immutable/HashMap/definition.cjs +1 -1
- package/_cjs/collection/immutable/HashMap/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/HashMap/internal.cjs.map +1 -1
- package/_cjs/collection/immutable/HashSet/api.cjs +230 -192
- package/_cjs/collection/immutable/HashSet/api.cjs.map +1 -1
- package/_cjs/collection/immutable/HashSet/definition.cjs +1 -1
- package/_cjs/collection/immutable/HashSet/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray/api/chunksOf.cjs +6 -4
- package/_cjs/collection/immutable/ImmutableArray/api/chunksOf.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray/api/slice.cjs +6 -4
- package/_cjs/collection/immutable/ImmutableArray/api/slice.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray/api/splitAt.cjs +6 -4
- package/_cjs/collection/immutable/ImmutableArray/api/splitAt.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray/api/splitWhere.cjs +15 -13
- package/_cjs/collection/immutable/ImmutableArray/api/splitWhere.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray/api.cjs +943 -749
- package/_cjs/collection/immutable/ImmutableArray/api.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray/derivations.cjs +12 -1
- package/_cjs/collection/immutable/ImmutableArray/derivations.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray/instances.cjs +33 -33
- package/_cjs/collection/immutable/ImmutableArray/instances.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableArray.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/api.cjs +338 -273
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/api.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/constructors.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/derivations.cjs +15 -4
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/derivations.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/destructors.cjs +2 -2
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/destructors.cjs.map +1 -1
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/instances.cjs +12 -12
- package/_cjs/collection/immutable/ImmutableNonEmptyArray/instances.cjs.map +1 -1
- package/_cjs/collection/immutable/List/api/foldLeft.cjs +12 -10
- package/_cjs/collection/immutable/List/api/foldLeft.cjs.map +1 -1
- package/_cjs/collection/immutable/List/api.cjs +164 -141
- package/_cjs/collection/immutable/List/api.cjs.map +1 -1
- package/_cjs/collection/immutable/List.cjs.map +1 -1
- package/_cjs/collection/immutable/Queue/api.cjs +64 -48
- package/_cjs/collection/immutable/Queue/api.cjs.map +1 -1
- package/_cjs/collection/immutable/Queue/definition.cjs +1 -1
- package/_cjs/collection/immutable/Queue/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/RoseTree/api.cjs +50 -36
- package/_cjs/collection/immutable/RoseTree/api.cjs.map +1 -1
- package/_cjs/collection/immutable/RoseTree/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/SortedMap/api.cjs +408 -368
- package/_cjs/collection/immutable/SortedMap/api.cjs.map +1 -1
- package/_cjs/collection/immutable/Vector/api.cjs +723 -608
- package/_cjs/collection/immutable/Vector/api.cjs.map +1 -1
- package/_cjs/collection/immutable/Vector/definition.cjs +18 -16
- package/_cjs/collection/immutable/Vector/definition.cjs.map +1 -1
- package/_cjs/collection/immutable/Vector/internal.cjs +40 -39
- package/_cjs/collection/immutable/Vector/internal.cjs.map +1 -1
- package/_cjs/collection/mutable/HashMap.cjs +3 -5
- package/_cjs/collection/mutable/HashMap.cjs.map +1 -1
- package/_cjs/collection/mutable/HashSet.cjs.map +1 -1
- package/_cjs/collection/mutable/ListBuffer.cjs +2 -2
- package/_cjs/collection/mutable/ListBuffer.cjs.map +1 -1
- package/_cjs/collection/mutable/internal.cjs +0 -2
- package/_cjs/collection/mutable/internal.cjs.map +1 -1
- package/_cjs/collection/weak/IterableWeakMap.cjs +7 -7
- package/_cjs/collection/weak/IterableWeakMap.cjs.map +1 -1
- package/_cjs/collection/weak/IterableWeakSet.cjs +7 -7
- package/_cjs/collection/weak/IterableWeakSet.cjs.map +1 -1
- package/_cjs/control/Eval/api.cjs +55 -43
- package/_cjs/control/Eval/api.cjs.map +1 -1
- package/_cjs/control/Eval/instance.cjs +4 -4
- package/_cjs/control/Eval/instance.cjs.map +1 -1
- package/_cjs/control/Eval/run.cjs +1 -1
- package/_cjs/control/Eval/run.cjs.map +1 -1
- package/_cjs/control/Z/api.cjs +241 -172
- package/_cjs/control/Z/api.cjs.map +1 -1
- package/_cjs/control/Z/instances.cjs +3 -3
- package/_cjs/control/Z/instances.cjs.map +1 -1
- package/_cjs/control/Z/runtime.cjs +250 -241
- package/_cjs/control/Z/runtime.cjs.map +1 -1
- package/_cjs/data/Branded/definition.cjs.map +1 -1
- package/_cjs/data/Branded/derivations.cjs +3 -3
- package/_cjs/data/Branded/derivations.cjs.map +1 -1
- package/_cjs/data/CaseClass.cjs.map +1 -1
- package/_cjs/data/Cause/api/fold.cjs +20 -18
- package/_cjs/data/Cause/api/fold.cjs.map +1 -1
- package/_cjs/data/Cause/api/isEmpty.cjs +1 -1
- package/_cjs/data/Cause/api/isEmpty.cjs.map +1 -1
- package/_cjs/data/Cause/api/linearize.cjs +8 -8
- package/_cjs/data/Cause/api/linearize.cjs.map +1 -1
- package/_cjs/data/Cause/api/prettyPrint.cjs +1 -1
- package/_cjs/data/Cause/api/prettyPrint.cjs.map +1 -1
- package/_cjs/data/Cause/api.cjs +160 -140
- package/_cjs/data/Cause/api.cjs.map +1 -1
- package/_cjs/data/Cause/definition.cjs +18 -18
- package/_cjs/data/Cause/definition.cjs.map +1 -1
- package/_cjs/data/Cause.cjs.map +1 -1
- package/_cjs/data/Const/api.cjs +8 -6
- package/_cjs/data/Const/api.cjs.map +1 -1
- package/_cjs/data/Const/instances.cjs +4 -4
- package/_cjs/data/Const/instances.cjs.map +1 -1
- package/_cjs/data/Datum/api.cjs +219 -176
- package/_cjs/data/Datum/api.cjs.map +1 -1
- package/_cjs/data/Datum/definition.cjs.map +1 -1
- package/_cjs/data/DatumEither/api.cjs +165 -133
- package/_cjs/data/DatumEither/api.cjs.map +1 -1
- package/_cjs/data/DecodeError/definition.cjs +14 -14
- package/_cjs/data/DecodeError/definition.cjs.map +1 -1
- package/_cjs/data/Decoder/api.cjs +9 -7
- package/_cjs/data/Decoder/api.cjs.map +1 -1
- package/_cjs/data/Duration/api.cjs +18 -12
- package/_cjs/data/Duration/api.cjs.map +1 -1
- package/_cjs/data/Either/api/align.cjs +8 -3
- package/_cjs/data/Either/api/align.cjs.map +1 -1
- package/_cjs/data/Either/api/alignWith.cjs +14 -12
- package/_cjs/data/Either/api/alignWith.cjs.map +1 -1
- package/_cjs/data/Either/api.cjs +206 -169
- package/_cjs/data/Either/api.cjs.map +1 -1
- package/_cjs/data/Either/constructors.cjs +11 -9
- package/_cjs/data/Either/constructors.cjs.map +1 -1
- package/_cjs/data/Either/destructors.cjs +16 -14
- package/_cjs/data/Either/destructors.cjs.map +1 -1
- package/_cjs/data/Either/instances.cjs +8 -8
- package/_cjs/data/Either/instances.cjs.map +1 -1
- package/_cjs/data/EitherT/api.cjs +8 -8
- package/_cjs/data/EitherT/api.cjs.map +1 -1
- package/_cjs/data/Encoder/api.cjs +134 -0
- package/_cjs/data/Encoder/api.cjs.map +1 -0
- package/_cjs/data/Encoder/definition.cjs +25 -0
- package/_cjs/data/Encoder/definition.cjs.map +1 -0
- package/_cjs/data/{Patch.cjs → Encoder.cjs} +3 -3
- package/_cjs/data/Encoder.cjs.map +1 -0
- package/_cjs/data/Environment/api.cjs +45 -33
- package/_cjs/data/Environment/api.cjs.map +1 -1
- package/_cjs/data/Environment/definition.cjs.map +1 -1
- package/_cjs/data/{Patch/api.cjs → EnvironmentPatch.cjs} +134 -38
- package/_cjs/data/EnvironmentPatch.cjs.map +1 -0
- package/_cjs/data/ExecutionStrategy.cjs +21 -29
- package/_cjs/data/ExecutionStrategy.cjs.map +1 -1
- package/_cjs/data/Exit/api.cjs +159 -127
- package/_cjs/data/Exit/api.cjs.map +1 -1
- package/_cjs/data/Exit/constructors.cjs +4 -4
- package/_cjs/data/Exit/constructors.cjs.map +1 -1
- package/_cjs/data/FiberId/api.cjs +23 -21
- package/_cjs/data/FiberId/api.cjs.map +1 -1
- package/_cjs/data/FiberId/constructors.cjs.map +1 -1
- package/_cjs/data/Identity/api.cjs +26 -18
- package/_cjs/data/Identity/api.cjs.map +1 -1
- package/_cjs/data/Identity/instances.cjs +3 -3
- package/_cjs/data/Identity/instances.cjs.map +1 -1
- package/_cjs/data/Interval.cjs +43 -33
- package/_cjs/data/Interval.cjs.map +1 -1
- package/_cjs/data/Intervals.cjs +35 -27
- package/_cjs/data/Intervals.cjs.map +1 -1
- package/_cjs/data/Maybe/api.cjs +160 -125
- package/_cjs/data/Maybe/api.cjs.map +1 -1
- package/_cjs/data/Maybe/constructors.cjs +2 -2
- package/_cjs/data/Maybe/constructors.cjs.map +1 -1
- package/_cjs/data/Maybe/definition.cjs.map +1 -1
- package/_cjs/data/Maybe/destructors.cjs +9 -7
- package/_cjs/data/Maybe/destructors.cjs.map +1 -1
- package/_cjs/data/Maybe/instances.cjs +11 -11
- package/_cjs/data/Maybe/instances.cjs.map +1 -1
- package/_cjs/data/Predicate/api.cjs +10 -8
- package/_cjs/data/Predicate/api.cjs.map +1 -1
- package/_cjs/data/Refinement/api.cjs +15 -9
- package/_cjs/data/Refinement/api.cjs.map +1 -1
- package/_cjs/data/Struct/api.cjs +62 -50
- package/_cjs/data/Struct/api.cjs.map +1 -1
- package/_cjs/data/Tag/constructors.cjs +3 -2
- package/_cjs/data/Tag/constructors.cjs.map +1 -1
- package/_cjs/data/Tag/definition.cjs +0 -3
- package/_cjs/data/Tag/definition.cjs.map +1 -1
- package/_cjs/data/These/api.cjs +188 -170
- package/_cjs/data/These/api.cjs.map +1 -1
- package/_cjs/data/These/constructors.cjs +1 -1
- package/_cjs/data/These/constructors.cjs.map +1 -1
- package/_cjs/data/These/destructors.cjs +39 -35
- package/_cjs/data/These/destructors.cjs.map +1 -1
- package/_cjs/data/These/instances.cjs +1 -1
- package/_cjs/data/These/instances.cjs.map +1 -1
- package/_cjs/data/Trace/api.cjs +7 -5
- package/_cjs/data/Trace/api.cjs.map +1 -1
- package/_cjs/data/Zipped.cjs.map +1 -1
- package/_cjs/data/function/api.cjs +6 -4
- package/_cjs/data/function/api.cjs.map +1 -1
- package/_cjs/data/function/pipe.cjs +9 -0
- package/_cjs/data/function/pipe.cjs.map +1 -1
- package/_cjs/data/string/api.cjs +53 -96
- package/_cjs/data/string/api.cjs.map +1 -1
- package/_cjs/global/api.cjs +4 -2
- package/_cjs/global/api.cjs.map +1 -1
- package/_cjs/internal/AtomicBoolean.cjs.map +1 -1
- package/_cjs/internal/AtomicNumber.cjs.map +1 -1
- package/_cjs/internal/AtomicReference.cjs.map +1 -1
- package/_cjs/internal/Stack.cjs +2 -2
- package/_cjs/internal/Stack.cjs.map +1 -1
- package/_cjs/optics/At/api.cjs +1 -1
- package/_cjs/optics/At/api.cjs.map +1 -1
- package/_cjs/optics/At/definition.cjs +2 -2
- package/_cjs/optics/At/definition.cjs.map +1 -1
- package/_cjs/optics/Fold/definition.cjs +3 -4
- package/_cjs/optics/Fold/definition.cjs.map +1 -1
- package/_cjs/optics/Getter/definition.cjs +2 -3
- package/_cjs/optics/Getter/definition.cjs.map +1 -1
- package/_cjs/optics/Index/api.cjs +4 -4
- package/_cjs/optics/Index/api.cjs.map +1 -1
- package/_cjs/optics/Index/definition.cjs +2 -2
- package/_cjs/optics/Index/definition.cjs.map +1 -1
- package/_cjs/optics/Iso/api.cjs +9 -7
- package/_cjs/optics/Iso/api.cjs.map +1 -1
- package/_cjs/optics/Iso/definition.cjs +12 -12
- package/_cjs/optics/Iso/definition.cjs.map +1 -1
- package/_cjs/optics/Lens/api.cjs +54 -44
- package/_cjs/optics/Lens/api.cjs.map +1 -1
- package/_cjs/optics/Lens/definition.cjs +10 -10
- package/_cjs/optics/Lens/definition.cjs.map +1 -1
- package/_cjs/optics/Optional/api/compose.cjs +9 -7
- package/_cjs/optics/Optional/api/compose.cjs.map +1 -1
- package/_cjs/optics/Optional/definition.cjs +12 -13
- package/_cjs/optics/Optional/definition.cjs.map +1 -1
- package/_cjs/optics/Optional.cjs.map +1 -1
- package/_cjs/optics/Prism/api/compose.cjs +9 -7
- package/_cjs/optics/Prism/api/compose.cjs.map +1 -1
- package/_cjs/optics/Prism/api/fromNullable.cjs +2 -2
- package/_cjs/optics/Prism/api/fromNullable.cjs.map +1 -1
- package/_cjs/optics/Prism/api/just.cjs +2 -2
- package/_cjs/optics/Prism/api/just.cjs.map +1 -1
- package/_cjs/optics/Prism/definition.cjs +9 -9
- package/_cjs/optics/Prism/definition.cjs.map +1 -1
- package/_cjs/optics/Prism.cjs.map +1 -1
- package/_cjs/optics/Setter/definition.cjs +8 -13
- package/_cjs/optics/Setter/definition.cjs.map +1 -1
- package/_cjs/optics/Traversal/api/compose.cjs +8 -6
- package/_cjs/optics/Traversal/api/compose.cjs.map +1 -1
- package/_cjs/optics/Traversal/api/fromTraversable.cjs +2 -2
- package/_cjs/optics/Traversal/api/fromTraversable.cjs.map +1 -1
- package/_cjs/optics/Traversal/definition.cjs +12 -12
- package/_cjs/optics/Traversal/definition.cjs.map +1 -1
- package/_cjs/optics/Traversal.cjs.map +1 -1
- package/_cjs/typeclass/Align.cjs.map +1 -1
- package/_cjs/typeclass/Alt.cjs.map +1 -1
- package/_cjs/typeclass/Applicative.cjs.map +1 -1
- package/_cjs/typeclass/ApplicativeExcept.cjs +5 -10
- package/_cjs/typeclass/ApplicativeExcept.cjs.map +1 -1
- package/_cjs/typeclass/Apply.cjs +8 -8
- package/_cjs/typeclass/Apply.cjs.map +1 -1
- package/_cjs/typeclass/Chain.cjs +4 -4
- package/_cjs/typeclass/Chain.cjs.map +1 -1
- package/_cjs/typeclass/Eq/definition.cjs.map +1 -1
- package/_cjs/typeclass/Eq/derivations.cjs.map +1 -1
- package/_cjs/typeclass/Equatable/api.cjs.map +1 -1
- package/_cjs/typeclass/Equatable/definition.cjs.map +1 -1
- package/_cjs/typeclass/Equatable/fast-equals.cjs.map +1 -1
- package/_cjs/typeclass/Filterable.cjs.map +1 -1
- package/_cjs/typeclass/FilterableWithIndex.cjs.map +1 -1
- package/_cjs/typeclass/Foldable.cjs +1 -1
- package/_cjs/typeclass/Foldable.cjs.map +1 -1
- package/_cjs/typeclass/FoldableWithIndex.cjs +1 -1
- package/_cjs/typeclass/FoldableWithIndex.cjs.map +1 -1
- package/_cjs/typeclass/Functor.cjs.map +1 -1
- package/_cjs/typeclass/FunctorWithIndex.cjs.map +1 -1
- package/_cjs/typeclass/Guard/api.cjs +18 -10
- package/_cjs/typeclass/Guard/api.cjs.map +1 -1
- package/_cjs/typeclass/Guard/definition.cjs.map +1 -1
- package/_cjs/typeclass/Guard/derivations.cjs.map +1 -1
- package/_cjs/typeclass/Has.cjs +7 -5
- package/_cjs/typeclass/Has.cjs.map +1 -1
- package/_cjs/typeclass/HashEq.cjs.map +1 -1
- package/_cjs/typeclass/Hashable/definition.cjs.map +1 -1
- package/_cjs/typeclass/Hashable/hash.cjs.map +1 -1
- package/_cjs/typeclass/MonadExcept.cjs +1 -1
- package/_cjs/typeclass/MonadExcept.cjs.map +1 -1
- package/_cjs/typeclass/Ord/api/contramap.cjs +7 -5
- package/_cjs/typeclass/Ord/api/contramap.cjs.map +1 -1
- package/_cjs/typeclass/Ord/api/max.cjs.map +1 -1
- package/_cjs/typeclass/Ord/api/min.cjs.map +1 -1
- package/_cjs/typeclass/Ord/definition.cjs.map +1 -1
- package/_cjs/typeclass/Ord/instances.cjs.map +1 -1
- package/_cjs/typeclass/Ordering.cjs.map +1 -1
- package/_cjs/typeclass/Semialign.cjs +7 -7
- package/_cjs/typeclass/Semialign.cjs.map +1 -1
- package/_cjs/typeclass/Semigroup/api.cjs.map +1 -1
- package/_cjs/typeclass/Semigroup/definition.cjs.map +1 -1
- package/_cjs/typeclass/Semigroup/derivations.cjs.map +1 -1
- package/_cjs/typeclass/Semimonoidal.cjs.map +1 -1
- package/_cjs/typeclass/Showable/definition.cjs.map +1 -1
- package/_cjs/typeclass/Showable/show.cjs +107 -107
- package/_cjs/typeclass/Showable/show.cjs.map +1 -1
- package/_cjs/typeclass/Showable/styles.cjs.map +1 -1
- package/_cjs/typeclass/Showable/util.cjs +1 -1
- package/_cjs/typeclass/Showable/util.cjs.map +1 -1
- package/_cjs/typeclass/Traversable.cjs +1 -2
- package/_cjs/typeclass/Traversable.cjs.map +1 -1
- package/_cjs/typeclass/TraversableWithIndex.cjs.map +1 -1
- package/_cjs/typeclass/Witherable.cjs +3 -1
- package/_cjs/typeclass/Witherable.cjs.map +1 -1
- package/_cjs/typeclass/WitherableWithIndex.cjs +3 -1
- package/_cjs/typeclass/WitherableWithIndex.cjs.map +1 -1
- package/_cjs/util/AnsiFormat.cjs +11 -11
- package/_cjs/util/AnsiFormat.cjs.map +1 -1
- package/_cjs/util/PCGRandom.cjs.map +1 -1
- package/_cjs/util/assert.cjs.map +1 -1
- package/_cjs/util/pattern.cjs.map +1 -1
- package/_cjs/util/predicates.cjs.map +1 -1
- package/_cjs/util/rand/Random.cjs.map +1 -1
- package/_cjs/util/rand/distribution/UniformArrayIntDistribution.cjs.map +1 -1
- package/_cjs/util/rand/distribution/UniformBigIntDistribution.cjs.map +1 -1
- package/_cjs/util/rand/distribution/UniformIntDistribution.cjs.map +1 -1
- package/_cjs/util/rand/distribution/internals/ArrayInt.cjs.map +1 -1
- package/_cjs/util/rand/distribution/internals/UniformArrayIntDistributionInternal.cjs.map +1 -1
- package/_cjs/util/rand/distribution/internals/UniformIntDistributionInternal.cjs.map +1 -1
- package/_cjs/util/rand/generator/MersenneTwister.cjs.map +1 -1
- package/_cjs/util/rand/generator/RandomGenerator.cjs.map +1 -1
- package/_cjs/util/rand.cjs.map +1 -1
- package/_mjs/collection/Iterable/api/traverseConc.mjs +5 -5
- package/_mjs/collection/Iterable/api/traverseConc.mjs.map +1 -1
- package/_mjs/collection/Iterable/api.mjs +465 -411
- package/_mjs/collection/Iterable/api.mjs.map +1 -1
- package/_mjs/collection/Iterable/constructors.mjs +5 -5
- package/_mjs/collection/Iterable/constructors.mjs.map +1 -1
- package/_mjs/collection/compat/Array/api.mjs +16 -12
- package/_mjs/collection/compat/Array/api.mjs.map +1 -1
- package/_mjs/collection/compat/Array/derivations.mjs +35 -19
- package/_mjs/collection/compat/Array/derivations.mjs.map +1 -1
- package/_mjs/collection/compat/ArrayLike/api.mjs +1 -1
- package/_mjs/collection/compat/ArrayLike/api.mjs.map +1 -1
- package/_mjs/collection/compat/Record/instances.mjs +34 -3
- package/_mjs/collection/compat/Record/instances.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/api/makeBy.mjs +1 -1
- package/_mjs/collection/immutable/Conc/api/makeBy.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/api.mjs +795 -697
- package/_mjs/collection/immutable/Conc/api.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/definition.mjs +53 -51
- package/_mjs/collection/immutable/Conc/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc/derivations.mjs +10 -2
- package/_mjs/collection/immutable/Conc/derivations.mjs.map +1 -1
- package/_mjs/collection/immutable/Conc.mjs.map +1 -1
- package/_mjs/collection/immutable/Dictionary/api.mjs +47 -35
- package/_mjs/collection/immutable/Dictionary/api.mjs.map +1 -1
- package/_mjs/collection/immutable/HashMap/api.mjs +295 -217
- package/_mjs/collection/immutable/HashMap/api.mjs.map +1 -1
- package/_mjs/collection/immutable/HashMap/definition.mjs +1 -1
- package/_mjs/collection/immutable/HashMap/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/HashMap/internal.mjs.map +1 -1
- package/_mjs/collection/immutable/HashSet/api.mjs +206 -168
- package/_mjs/collection/immutable/HashSet/api.mjs.map +1 -1
- package/_mjs/collection/immutable/HashSet/definition.mjs +1 -1
- package/_mjs/collection/immutable/HashSet/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray/api/chunksOf.mjs +5 -3
- package/_mjs/collection/immutable/ImmutableArray/api/chunksOf.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray/api/slice.mjs +5 -3
- package/_mjs/collection/immutable/ImmutableArray/api/slice.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray/api/splitAt.mjs +5 -3
- package/_mjs/collection/immutable/ImmutableArray/api/splitAt.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray/api/splitWhere.mjs +13 -11
- package/_mjs/collection/immutable/ImmutableArray/api/splitWhere.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray/api.mjs +816 -629
- package/_mjs/collection/immutable/ImmutableArray/api.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray/derivations.mjs +9 -1
- package/_mjs/collection/immutable/ImmutableArray/derivations.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray/instances.mjs +34 -34
- package/_mjs/collection/immutable/ImmutableArray/instances.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableArray.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/api.mjs +301 -239
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/api.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/constructors.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/derivations.mjs +12 -4
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/derivations.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/destructors.mjs +2 -2
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/destructors.mjs.map +1 -1
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/instances.mjs +13 -13
- package/_mjs/collection/immutable/ImmutableNonEmptyArray/instances.mjs.map +1 -1
- package/_mjs/collection/immutable/List/api/foldLeft.mjs +11 -9
- package/_mjs/collection/immutable/List/api/foldLeft.mjs.map +1 -1
- package/_mjs/collection/immutable/List/api.mjs +157 -133
- package/_mjs/collection/immutable/List/api.mjs.map +1 -1
- package/_mjs/collection/immutable/List.mjs.map +1 -1
- package/_mjs/collection/immutable/Queue/api.mjs +55 -39
- package/_mjs/collection/immutable/Queue/api.mjs.map +1 -1
- package/_mjs/collection/immutable/Queue/definition.mjs +1 -1
- package/_mjs/collection/immutable/Queue/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/RoseTree/api.mjs +50 -36
- package/_mjs/collection/immutable/RoseTree/api.mjs.map +1 -1
- package/_mjs/collection/immutable/RoseTree/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/SortedMap/api.mjs +398 -358
- package/_mjs/collection/immutable/SortedMap/api.mjs.map +1 -1
- package/_mjs/collection/immutable/Vector/api.mjs +650 -538
- package/_mjs/collection/immutable/Vector/api.mjs.map +1 -1
- package/_mjs/collection/immutable/Vector/definition.mjs +16 -14
- package/_mjs/collection/immutable/Vector/definition.mjs.map +1 -1
- package/_mjs/collection/immutable/Vector/internal.mjs +40 -39
- package/_mjs/collection/immutable/Vector/internal.mjs.map +1 -1
- package/_mjs/collection/mutable/HashMap.mjs +3 -5
- package/_mjs/collection/mutable/HashMap.mjs.map +1 -1
- package/_mjs/collection/mutable/HashSet.mjs.map +1 -1
- package/_mjs/collection/mutable/ListBuffer.mjs +2 -2
- package/_mjs/collection/mutable/ListBuffer.mjs.map +1 -1
- package/_mjs/collection/mutable/internal.mjs +0 -2
- package/_mjs/collection/mutable/internal.mjs.map +1 -1
- package/_mjs/collection/weak/IterableWeakMap.mjs +7 -7
- package/_mjs/collection/weak/IterableWeakMap.mjs.map +1 -1
- package/_mjs/collection/weak/IterableWeakSet.mjs +7 -7
- package/_mjs/collection/weak/IterableWeakSet.mjs.map +1 -1
- package/_mjs/control/Eval/api.mjs +40 -28
- package/_mjs/control/Eval/api.mjs.map +1 -1
- package/_mjs/control/Eval/instance.mjs +5 -5
- package/_mjs/control/Eval/instance.mjs.map +1 -1
- package/_mjs/control/Eval/run.mjs +1 -1
- package/_mjs/control/Eval/run.mjs.map +1 -1
- package/_mjs/control/Z/api.mjs +196 -128
- package/_mjs/control/Z/api.mjs.map +1 -1
- package/_mjs/control/Z/instances.mjs +4 -4
- package/_mjs/control/Z/instances.mjs.map +1 -1
- package/_mjs/control/Z/runtime.mjs +244 -234
- package/_mjs/control/Z/runtime.mjs.map +1 -1
- package/_mjs/data/Branded/definition.mjs.map +1 -1
- package/_mjs/data/Branded/derivations.mjs +3 -3
- package/_mjs/data/Branded/derivations.mjs.map +1 -1
- package/_mjs/data/CaseClass.mjs.map +1 -1
- package/_mjs/data/Cause/api/fold.mjs +19 -17
- package/_mjs/data/Cause/api/fold.mjs.map +1 -1
- package/_mjs/data/Cause/api/isEmpty.mjs +1 -1
- package/_mjs/data/Cause/api/isEmpty.mjs.map +1 -1
- package/_mjs/data/Cause/api/linearize.mjs +8 -8
- package/_mjs/data/Cause/api/linearize.mjs.map +1 -1
- package/_mjs/data/Cause/api/prettyPrint.mjs +1 -1
- package/_mjs/data/Cause/api/prettyPrint.mjs.map +1 -1
- package/_mjs/data/Cause/api.mjs +149 -129
- package/_mjs/data/Cause/api.mjs.map +1 -1
- package/_mjs/data/Cause/definition.mjs +18 -18
- package/_mjs/data/Cause/definition.mjs.map +1 -1
- package/_mjs/data/Cause.mjs.map +1 -1
- package/_mjs/data/Const/api.mjs +6 -4
- package/_mjs/data/Const/api.mjs.map +1 -1
- package/_mjs/data/Const/instances.mjs +4 -4
- package/_mjs/data/Const/instances.mjs.map +1 -1
- package/_mjs/data/Datum/api.mjs +220 -179
- package/_mjs/data/Datum/api.mjs.map +1 -1
- package/_mjs/data/Datum/definition.mjs.map +1 -1
- package/_mjs/data/DatumEither/api.mjs +163 -132
- package/_mjs/data/DatumEither/api.mjs.map +1 -1
- package/_mjs/data/DecodeError/definition.mjs +14 -14
- package/_mjs/data/DecodeError/definition.mjs.map +1 -1
- package/_mjs/data/Decoder/api.mjs +9 -7
- package/_mjs/data/Decoder/api.mjs.map +1 -1
- package/_mjs/data/Duration/api.mjs +16 -10
- package/_mjs/data/Duration/api.mjs.map +1 -1
- package/_mjs/data/Either/api/align.mjs +8 -2
- package/_mjs/data/Either/api/align.mjs.map +1 -1
- package/_mjs/data/Either/api/alignWith.mjs +13 -11
- package/_mjs/data/Either/api/alignWith.mjs.map +1 -1
- package/_mjs/data/Either/api.mjs +175 -136
- package/_mjs/data/Either/api.mjs.map +1 -1
- package/_mjs/data/Either/constructors.mjs +7 -5
- package/_mjs/data/Either/constructors.mjs.map +1 -1
- package/_mjs/data/Either/destructors.mjs +15 -13
- package/_mjs/data/Either/destructors.mjs.map +1 -1
- package/_mjs/data/Either/instances.mjs +9 -9
- package/_mjs/data/Either/instances.mjs.map +1 -1
- package/_mjs/data/EitherT/api.mjs +8 -8
- package/_mjs/data/EitherT/api.mjs.map +1 -1
- package/_mjs/data/Encoder/api.mjs +102 -0
- package/_mjs/data/Encoder/api.mjs.map +1 -0
- package/_mjs/data/Encoder/definition.mjs +15 -0
- package/_mjs/data/Encoder/definition.mjs.map +1 -0
- package/_mjs/data/Encoder.mjs +4 -0
- package/_mjs/data/Encoder.mjs.map +1 -0
- package/_mjs/data/Environment/api.mjs +45 -33
- package/_mjs/data/Environment/api.mjs.map +1 -1
- package/_mjs/data/Environment/definition.mjs.map +1 -1
- package/_mjs/data/EnvironmentPatch.mjs +188 -0
- package/_mjs/data/EnvironmentPatch.mjs.map +1 -0
- package/_mjs/data/ExecutionStrategy.mjs +19 -27
- package/_mjs/data/ExecutionStrategy.mjs.map +1 -1
- package/_mjs/data/Exit/api.mjs +140 -108
- package/_mjs/data/Exit/api.mjs.map +1 -1
- package/_mjs/data/Exit/constructors.mjs +3 -3
- package/_mjs/data/Exit/constructors.mjs.map +1 -1
- package/_mjs/data/FiberId/api.mjs +22 -20
- package/_mjs/data/FiberId/api.mjs.map +1 -1
- package/_mjs/data/FiberId/constructors.mjs.map +1 -1
- package/_mjs/data/Identity/api.mjs +21 -13
- package/_mjs/data/Identity/api.mjs.map +1 -1
- package/_mjs/data/Identity/instances.mjs +4 -4
- package/_mjs/data/Identity/instances.mjs.map +1 -1
- package/_mjs/data/Interval.mjs +38 -28
- package/_mjs/data/Interval.mjs.map +1 -1
- package/_mjs/data/Intervals.mjs +35 -27
- package/_mjs/data/Intervals.mjs.map +1 -1
- package/_mjs/data/Maybe/api.mjs +141 -106
- package/_mjs/data/Maybe/api.mjs.map +1 -1
- package/_mjs/data/Maybe/constructors.mjs +1 -1
- package/_mjs/data/Maybe/constructors.mjs.map +1 -1
- package/_mjs/data/Maybe/definition.mjs.map +1 -1
- package/_mjs/data/Maybe/destructors.mjs +8 -6
- package/_mjs/data/Maybe/destructors.mjs.map +1 -1
- package/_mjs/data/Maybe/instances.mjs +12 -12
- package/_mjs/data/Maybe/instances.mjs.map +1 -1
- package/_mjs/data/Predicate/api.mjs +10 -8
- package/_mjs/data/Predicate/api.mjs.map +1 -1
- package/_mjs/data/Refinement/api.mjs +15 -9
- package/_mjs/data/Refinement/api.mjs.map +1 -1
- package/_mjs/data/Struct/api.mjs +56 -44
- package/_mjs/data/Struct/api.mjs.map +1 -1
- package/_mjs/data/Tag/constructors.mjs +3 -2
- package/_mjs/data/Tag/constructors.mjs.map +1 -1
- package/_mjs/data/Tag/definition.mjs +0 -2
- package/_mjs/data/Tag/definition.mjs.map +1 -1
- package/_mjs/data/These/api.mjs +187 -169
- package/_mjs/data/These/api.mjs.map +1 -1
- package/_mjs/data/These/constructors.mjs +1 -1
- package/_mjs/data/These/constructors.mjs.map +1 -1
- package/_mjs/data/These/destructors.mjs +35 -31
- package/_mjs/data/These/destructors.mjs.map +1 -1
- package/_mjs/data/These/instances.mjs +1 -1
- package/_mjs/data/These/instances.mjs.map +1 -1
- package/_mjs/data/Trace/api.mjs +6 -4
- package/_mjs/data/Trace/api.mjs.map +1 -1
- package/_mjs/data/Zipped.mjs.map +1 -1
- package/_mjs/data/function/api.mjs +5 -3
- package/_mjs/data/function/api.mjs.map +1 -1
- package/_mjs/data/function/pipe.mjs +7 -0
- package/_mjs/data/function/pipe.mjs.map +1 -1
- package/_mjs/data/string/api.mjs +46 -66
- package/_mjs/data/string/api.mjs.map +1 -1
- package/_mjs/global/api.mjs +4 -2
- package/_mjs/global/api.mjs.map +1 -1
- package/_mjs/internal/AtomicBoolean.mjs.map +1 -1
- package/_mjs/internal/AtomicNumber.mjs.map +1 -1
- package/_mjs/internal/AtomicReference.mjs.map +1 -1
- package/_mjs/internal/Stack.mjs +1 -1
- package/_mjs/internal/Stack.mjs.map +1 -1
- package/_mjs/optics/At/api.mjs +1 -1
- package/_mjs/optics/At/api.mjs.map +1 -1
- package/_mjs/optics/At/definition.mjs +2 -2
- package/_mjs/optics/At/definition.mjs.map +1 -1
- package/_mjs/optics/Fold/definition.mjs +2 -3
- package/_mjs/optics/Fold/definition.mjs.map +1 -1
- package/_mjs/optics/Getter/definition.mjs +1 -2
- package/_mjs/optics/Getter/definition.mjs.map +1 -1
- package/_mjs/optics/Index/api.mjs +4 -4
- package/_mjs/optics/Index/api.mjs.map +1 -1
- package/_mjs/optics/Index/definition.mjs +1 -1
- package/_mjs/optics/Index/definition.mjs.map +1 -1
- package/_mjs/optics/Iso/api.mjs +8 -6
- package/_mjs/optics/Iso/api.mjs.map +1 -1
- package/_mjs/optics/Iso/definition.mjs +9 -9
- package/_mjs/optics/Iso/definition.mjs.map +1 -1
- package/_mjs/optics/Lens/api.mjs +49 -39
- package/_mjs/optics/Lens/api.mjs.map +1 -1
- package/_mjs/optics/Lens/definition.mjs +7 -7
- package/_mjs/optics/Lens/definition.mjs.map +1 -1
- package/_mjs/optics/Optional/api/compose.mjs +8 -6
- package/_mjs/optics/Optional/api/compose.mjs.map +1 -1
- package/_mjs/optics/Optional/definition.mjs +8 -10
- package/_mjs/optics/Optional/definition.mjs.map +1 -1
- package/_mjs/optics/Optional.mjs.map +1 -1
- package/_mjs/optics/Prism/api/compose.mjs +8 -6
- package/_mjs/optics/Prism/api/compose.mjs.map +1 -1
- package/_mjs/optics/Prism/api/fromNullable.mjs +2 -2
- package/_mjs/optics/Prism/api/fromNullable.mjs.map +1 -1
- package/_mjs/optics/Prism/api/just.mjs +2 -2
- package/_mjs/optics/Prism/api/just.mjs.map +1 -1
- package/_mjs/optics/Prism/definition.mjs +6 -6
- package/_mjs/optics/Prism/definition.mjs.map +1 -1
- package/_mjs/optics/Prism.mjs.map +1 -1
- package/_mjs/optics/Setter/definition.mjs +5 -10
- package/_mjs/optics/Setter/definition.mjs.map +1 -1
- package/_mjs/optics/Traversal/api/compose.mjs +7 -5
- package/_mjs/optics/Traversal/api/compose.mjs.map +1 -1
- package/_mjs/optics/Traversal/api/fromTraversable.mjs +2 -2
- package/_mjs/optics/Traversal/api/fromTraversable.mjs.map +1 -1
- package/_mjs/optics/Traversal/definition.mjs +9 -9
- package/_mjs/optics/Traversal/definition.mjs.map +1 -1
- package/_mjs/optics/Traversal.mjs.map +1 -1
- package/_mjs/typeclass/Align.mjs.map +1 -1
- package/_mjs/typeclass/Alt.mjs.map +1 -1
- package/_mjs/typeclass/Applicative.mjs.map +1 -1
- package/_mjs/typeclass/ApplicativeExcept.mjs +6 -10
- package/_mjs/typeclass/ApplicativeExcept.mjs.map +1 -1
- package/_mjs/typeclass/Apply.mjs +9 -9
- package/_mjs/typeclass/Apply.mjs.map +1 -1
- package/_mjs/typeclass/Chain.mjs +5 -5
- package/_mjs/typeclass/Chain.mjs.map +1 -1
- package/_mjs/typeclass/Eq/definition.mjs.map +1 -1
- package/_mjs/typeclass/Eq/derivations.mjs.map +1 -1
- package/_mjs/typeclass/Equatable/api.mjs.map +1 -1
- package/_mjs/typeclass/Equatable/definition.mjs.map +1 -1
- package/_mjs/typeclass/Equatable/fast-equals.mjs.map +1 -1
- package/_mjs/typeclass/Filterable.mjs.map +1 -1
- package/_mjs/typeclass/FilterableWithIndex.mjs.map +1 -1
- package/_mjs/typeclass/Foldable.mjs +1 -1
- package/_mjs/typeclass/Foldable.mjs.map +1 -1
- package/_mjs/typeclass/FoldableWithIndex.mjs +1 -1
- package/_mjs/typeclass/FoldableWithIndex.mjs.map +1 -1
- package/_mjs/typeclass/Functor.mjs.map +1 -1
- package/_mjs/typeclass/FunctorWithIndex.mjs.map +1 -1
- package/_mjs/typeclass/Guard/api.mjs +18 -10
- package/_mjs/typeclass/Guard/api.mjs.map +1 -1
- package/_mjs/typeclass/Guard/definition.mjs.map +1 -1
- package/_mjs/typeclass/Guard/derivations.mjs.map +1 -1
- package/_mjs/typeclass/Has.mjs +7 -5
- package/_mjs/typeclass/Has.mjs.map +1 -1
- package/_mjs/typeclass/HashEq.mjs.map +1 -1
- package/_mjs/typeclass/Hashable/definition.mjs.map +1 -1
- package/_mjs/typeclass/Hashable/hash.mjs.map +1 -1
- package/_mjs/typeclass/MonadExcept.mjs +1 -1
- package/_mjs/typeclass/MonadExcept.mjs.map +1 -1
- package/_mjs/typeclass/Ord/api/contramap.mjs +7 -5
- package/_mjs/typeclass/Ord/api/contramap.mjs.map +1 -1
- package/_mjs/typeclass/Ord/api/max.mjs.map +1 -1
- package/_mjs/typeclass/Ord/api/min.mjs.map +1 -1
- package/_mjs/typeclass/Ord/definition.mjs.map +1 -1
- package/_mjs/typeclass/Ord/instances.mjs.map +1 -1
- package/_mjs/typeclass/Ordering.mjs.map +1 -1
- package/_mjs/typeclass/Semialign.mjs +7 -7
- package/_mjs/typeclass/Semialign.mjs.map +1 -1
- package/_mjs/typeclass/Semigroup/api.mjs.map +1 -1
- package/_mjs/typeclass/Semigroup/definition.mjs.map +1 -1
- package/_mjs/typeclass/Semigroup/derivations.mjs.map +1 -1
- package/_mjs/typeclass/Semimonoidal.mjs.map +1 -1
- package/_mjs/typeclass/Showable/definition.mjs.map +1 -1
- package/_mjs/typeclass/Showable/show.mjs +107 -107
- package/_mjs/typeclass/Showable/show.mjs.map +1 -1
- package/_mjs/typeclass/Showable/styles.mjs.map +1 -1
- package/_mjs/typeclass/Showable/util.mjs +1 -1
- package/_mjs/typeclass/Showable/util.mjs.map +1 -1
- package/_mjs/typeclass/Traversable.mjs +1 -2
- package/_mjs/typeclass/Traversable.mjs.map +1 -1
- package/_mjs/typeclass/TraversableWithIndex.mjs.map +1 -1
- package/_mjs/typeclass/Witherable.mjs +2 -1
- package/_mjs/typeclass/Witherable.mjs.map +1 -1
- package/_mjs/typeclass/WitherableWithIndex.mjs +2 -1
- package/_mjs/typeclass/WitherableWithIndex.mjs.map +1 -1
- package/_mjs/util/AnsiFormat.mjs +11 -11
- package/_mjs/util/AnsiFormat.mjs.map +1 -1
- package/_mjs/util/PCGRandom.mjs.map +1 -1
- package/_mjs/util/assert.mjs.map +1 -1
- package/_mjs/util/pattern.mjs.map +1 -1
- package/_mjs/util/predicates.mjs.map +1 -1
- package/_mjs/util/rand/Random.mjs.map +1 -1
- package/_mjs/util/rand/distribution/UniformArrayIntDistribution.mjs.map +1 -1
- package/_mjs/util/rand/distribution/UniformBigIntDistribution.mjs.map +1 -1
- package/_mjs/util/rand/distribution/UniformIntDistribution.mjs.map +1 -1
- package/_mjs/util/rand/distribution/internals/ArrayInt.mjs.map +1 -1
- package/_mjs/util/rand/distribution/internals/UniformArrayIntDistributionInternal.mjs.map +1 -1
- package/_mjs/util/rand/distribution/internals/UniformIntDistributionInternal.mjs.map +1 -1
- package/_mjs/util/rand/generator/MersenneTwister.mjs.map +1 -1
- package/_mjs/util/rand/generator/RandomGenerator.mjs.map +1 -1
- package/_mjs/util/rand.mjs.map +1 -1
- package/_src/collection/Iterable/api/traverseConc.ts +3 -3
- package/_src/collection/Iterable/api.ts +445 -408
- package/_src/collection/Iterable/constructors.ts +1 -1
- package/_src/collection/compat/Array/api.ts +16 -13
- package/_src/collection/compat/Array/derivations.ts +27 -1
- package/_src/collection/compat/Record/instances.ts +51 -2
- package/_src/collection/immutable/Conc/api.ts +716 -607
- package/_src/collection/immutable/Conc/definition.ts +60 -68
- package/_src/collection/immutable/Conc/derivations.ts +13 -0
- package/_src/collection/immutable/Conc.ts +0 -1
- package/_src/collection/immutable/Dictionary/api.ts +44 -32
- package/_src/collection/immutable/HashMap/api.ts +338 -224
- package/_src/collection/immutable/HashMap/internal.ts +3 -7
- package/_src/collection/immutable/HashSet/api.ts +193 -158
- package/_src/collection/immutable/ImmutableArray/api/chunksOf.ts +5 -3
- package/_src/collection/immutable/ImmutableArray/api/slice.ts +5 -3
- package/_src/collection/immutable/ImmutableArray/api/splitAt.ts +5 -3
- package/_src/collection/immutable/ImmutableArray/api/splitWhere.ts +13 -14
- package/_src/collection/immutable/ImmutableArray/api.ts +870 -722
- package/_src/collection/immutable/ImmutableArray/derivations.ts +13 -0
- package/_src/collection/immutable/ImmutableArray/instances.ts +54 -73
- package/_src/collection/immutable/ImmutableArray.ts +0 -1
- package/_src/collection/immutable/ImmutableNonEmptyArray/api.ts +311 -273
- package/_src/collection/immutable/ImmutableNonEmptyArray/constructors.ts +19 -4
- package/_src/collection/immutable/ImmutableNonEmptyArray/definition.ts +0 -1
- package/_src/collection/immutable/ImmutableNonEmptyArray/derivations.ts +13 -0
- package/_src/collection/immutable/ImmutableNonEmptyArray/instances.ts +22 -23
- package/_src/collection/immutable/List/api/foldLeft.ts +11 -9
- package/_src/collection/immutable/List/api.ts +147 -133
- package/_src/collection/immutable/List.ts +0 -1
- package/_src/collection/immutable/Queue/api.ts +53 -37
- package/_src/collection/immutable/Queue/definition.ts +0 -1
- package/_src/collection/immutable/RoseTree/api.ts +38 -32
- package/_src/collection/immutable/RoseTree/definition.ts +2 -0
- package/_src/collection/immutable/SortedMap/api.ts +364 -332
- package/_src/collection/immutable/Vector/api.ts +608 -482
- package/_src/collection/immutable/Vector/definition.ts +11 -12
- package/_src/collection/immutable/Vector/internal.ts +37 -38
- package/_src/collection/mutable/HashMap.ts +1 -4
- package/_src/collection/mutable/HashSet.ts +1 -2
- package/_src/collection/mutable/ListBuffer.ts +1 -1
- package/_src/collection/mutable/internal.ts +0 -2
- package/_src/collection/weak/IterableWeakMap.ts +11 -7
- package/_src/collection/weak/IterableWeakSet.ts +10 -5
- package/_src/control/Eval/api.ts +35 -19
- package/_src/control/Eval/instance.ts +5 -5
- package/_src/control/Z/api.ts +191 -208
- package/_src/control/Z/instances.ts +4 -5
- package/_src/control/Z/runtime.ts +190 -189
- package/_src/data/Branded/definition.ts +11 -12
- package/_src/data/Branded/derivations.ts +2 -2
- package/_src/data/CaseClass.ts +4 -1
- package/_src/data/Cause/api/fold.ts +13 -14
- package/_src/data/Cause/api.ts +125 -105
- package/_src/data/Cause.ts +0 -1
- package/_src/data/Const/api.ts +6 -4
- package/_src/data/Const/instances.ts +3 -3
- package/_src/data/Datum/api.ts +229 -197
- package/_src/data/Datum/definition.ts +2 -5
- package/_src/data/DatumEither/api.ts +208 -193
- package/_src/data/Decoder/api.ts +5 -3
- package/_src/data/Duration/api.ts +19 -15
- package/_src/data/Either/api/align.ts +7 -2
- package/_src/data/Either/api/alignWith.ts +13 -15
- package/_src/data/Either/api.ts +141 -119
- package/_src/data/Either/constructors.ts +12 -10
- package/_src/data/Either/destructors.ts +11 -9
- package/_src/data/Either/instances.ts +24 -20
- package/_src/data/EitherT/api.ts +43 -49
- package/_src/data/Encoder/api.ts +123 -0
- package/_src/data/Encoder/definition.ts +12 -0
- package/_src/data/Encoder.ts +4 -0
- package/_src/data/Environment/api.ts +52 -44
- package/_src/data/Environment/definition.ts +6 -0
- package/_src/data/EnvironmentPatch.ts +137 -0
- package/_src/data/ExecutionStrategy.ts +14 -24
- package/_src/data/Exit/api.ts +104 -73
- package/_src/data/Exit/constructors.ts +2 -2
- package/_src/data/FiberId/api.ts +19 -17
- package/_src/data/FiberId/constructors.ts +1 -2
- package/_src/data/Identity/api.ts +20 -12
- package/_src/data/Identity/instances.ts +4 -7
- package/_src/data/Interval.ts +39 -29
- package/_src/data/Intervals.ts +31 -23
- package/_src/data/Maybe/api.ts +112 -79
- package/_src/data/Maybe/constructors.ts +3 -3
- package/_src/data/Maybe/definition.ts +11 -1
- package/_src/data/Maybe/destructors.ts +6 -4
- package/_src/data/Maybe/instances.ts +10 -21
- package/_src/data/Predicate/api.ts +14 -8
- package/_src/data/Refinement/api.ts +19 -13
- package/_src/data/Struct/api.ts +75 -55
- package/_src/data/Tag/constructors.ts +1 -2
- package/_src/data/Tag/definition.ts +0 -1
- package/_src/data/These/api.ts +114 -114
- package/_src/data/These/destructors.ts +23 -24
- package/_src/data/Trace/api.ts +5 -3
- package/_src/data/Zipped.ts +3 -4
- package/_src/data/function/api.ts +6 -7
- package/_src/data/function/pipe.ts +9 -1
- package/_src/data/string/api.ts +40 -60
- package/_src/data.ts +2 -1
- package/_src/global/api.ts +7 -12
- package/_src/global.ts +8 -0
- package/_src/internal/AtomicBoolean.ts +0 -1
- package/_src/internal/AtomicNumber.ts +0 -7
- package/_src/internal/AtomicReference.ts +0 -4
- package/_src/internal/Stack.ts +1 -7
- package/_src/optics/At/definition.ts +5 -3
- package/_src/optics/Fold/definition.ts +3 -10
- package/_src/optics/Getter/definition.ts +1 -2
- package/_src/optics/Index/definition.ts +1 -1
- package/_src/optics/Iso/api.ts +8 -6
- package/_src/optics/Iso/definition.ts +3 -3
- package/_src/optics/Lens/api.ts +44 -42
- package/_src/optics/Lens/definition.ts +5 -5
- package/_src/optics/Optional/api/compose.ts +9 -9
- package/_src/optics/Optional/definition.ts +9 -16
- package/_src/optics/Optional.ts +0 -1
- package/_src/optics/Prism/api/compose.ts +9 -6
- package/_src/optics/Prism/definition.ts +3 -3
- package/_src/optics/Prism.ts +0 -1
- package/_src/optics/Setter/definition.ts +3 -23
- package/_src/optics/Traversal/api/compose.ts +7 -8
- package/_src/optics/Traversal/api/fromTraversable.ts +1 -1
- package/_src/optics/Traversal/definition.ts +10 -15
- package/_src/optics/Traversal.ts +0 -1
- package/_src/typeclass/Align.ts +0 -3
- package/_src/typeclass/Alt.ts +2 -1
- package/_src/typeclass/Applicative.ts +0 -1
- package/_src/typeclass/ApplicativeExcept.ts +15 -10
- package/_src/typeclass/Apply.ts +30 -33
- package/_src/typeclass/Chain.ts +9 -12
- package/_src/typeclass/Eq/definition.ts +0 -3
- package/_src/typeclass/Eq/derivations.ts +0 -2
- package/_src/typeclass/Equatable/api.ts +0 -2
- package/_src/typeclass/Equatable/definition.ts +0 -4
- package/_src/typeclass/Equatable/fast-equals.ts +11 -93
- package/_src/typeclass/Filterable.ts +19 -13
- package/_src/typeclass/FilterableWithIndex.ts +19 -13
- package/_src/typeclass/Foldable.ts +7 -10
- package/_src/typeclass/FoldableWithIndex.ts +7 -10
- package/_src/typeclass/Functor.ts +6 -4
- package/_src/typeclass/FunctorWithIndex.ts +3 -2
- package/_src/typeclass/Guard/api.ts +21 -16
- package/_src/typeclass/Guard/definition.ts +0 -3
- package/_src/typeclass/Guard/derivations.ts +5 -6
- package/_src/typeclass/Has.ts +6 -4
- package/_src/typeclass/HashEq.ts +0 -7
- package/_src/typeclass/Hashable/definition.ts +0 -4
- package/_src/typeclass/Hashable/hash.ts +0 -26
- package/_src/typeclass/MonadExcept.ts +1 -1
- package/_src/typeclass/Ord/api/contramap.ts +7 -6
- package/_src/typeclass/Ord/api/max.ts +0 -1
- package/_src/typeclass/Ord/api/min.ts +0 -1
- package/_src/typeclass/Ord/definition.ts +0 -4
- package/_src/typeclass/Ord/instances.ts +0 -2
- package/_src/typeclass/Ordering.ts +2 -0
- package/_src/typeclass/Semialign.ts +43 -32
- package/_src/typeclass/Semigroup/api.ts +0 -2
- package/_src/typeclass/Semigroup/definition.ts +0 -4
- package/_src/typeclass/Semigroup/derivations.ts +0 -2
- package/_src/typeclass/Semimonoidal.ts +3 -2
- package/_src/typeclass/Showable/definition.ts +0 -6
- package/_src/typeclass/Showable/show.ts +1 -57
- package/_src/typeclass/Showable/styles.ts +0 -8
- package/_src/typeclass/Showable/util.ts +22 -57
- package/_src/typeclass/Traversable.ts +13 -18
- package/_src/typeclass/TraversableWithIndex.ts +5 -7
- package/_src/typeclass/Witherable.ts +21 -13
- package/_src/typeclass/WitherableWithIndex.ts +26 -17
- package/_src/typeclass/builtin/Symbol.ts +0 -1
- package/_src/types/extractions.ts +12 -3
- package/_src/types/utility.ts +3 -5
- package/_src/util/AnsiFormat.ts +0 -25
- package/_src/util/PCGRandom.ts +4 -9
- package/_src/util/assert.ts +1 -2
- package/_src/util/pattern.ts +91 -12
- package/_src/util/predicates.ts +3 -1
- package/_src/util/rand/Random.ts +12 -16
- package/_src/util/rand/distribution/Distribution.ts +0 -1
- package/_src/util/rand/distribution/UniformArrayIntDistribution.ts +0 -3
- package/_src/util/rand/distribution/UniformBigIntDistribution.ts +0 -5
- package/_src/util/rand/distribution/UniformIntDistribution.ts +0 -7
- package/_src/util/rand/distribution/internals/ArrayInt.ts +3 -13
- package/_src/util/rand/distribution/internals/UniformArrayIntDistributionInternal.ts +0 -3
- package/_src/util/rand/distribution/internals/UniformIntDistributionInternal.ts +0 -4
- package/_src/util/rand/generator/MersenneTwister.ts +6 -29
- package/_src/util/rand/generator/RandomGenerator.ts +0 -3
- package/_src/util/rand.ts +0 -2
- package/collection/Iterable/api/traverseConc.d.ts +2 -2
- package/collection/Iterable/api.d.ts +64 -64
- package/collection/Iterable/constructors.d.ts +1 -1
- package/collection/compat/Array/api.d.ts +6 -6
- package/collection/compat/Array/derivations.d.ts +11 -0
- package/collection/compat/Record/instances.d.ts +30 -6
- package/collection/immutable/Conc/api.d.ts +108 -105
- package/collection/immutable/Conc/definition.d.ts +2 -2
- package/collection/immutable/Conc/derivations.d.ts +6 -0
- package/collection/immutable/Dictionary/api.d.ts +12 -12
- package/collection/immutable/HashMap/api.d.ts +76 -70
- package/collection/immutable/HashSet/api.d.ts +45 -41
- package/collection/immutable/ImmutableArray/api/chunksOf.d.ts +2 -2
- package/collection/immutable/ImmutableArray/api/slice.d.ts +2 -2
- package/collection/immutable/ImmutableArray/api/splitAt.d.ts +2 -2
- package/collection/immutable/ImmutableArray/api/splitWhere.d.ts +3 -3
- package/collection/immutable/ImmutableArray/api.d.ts +206 -206
- package/collection/immutable/ImmutableArray/derivations.d.ts +6 -0
- package/collection/immutable/ImmutableNonEmptyArray/api.d.ts +64 -63
- package/collection/immutable/ImmutableNonEmptyArray/derivations.d.ts +6 -0
- package/collection/immutable/List/api/foldLeft.d.ts +2 -2
- package/collection/immutable/List/api.d.ts +24 -24
- package/collection/immutable/Queue/api.d.ts +16 -16
- package/collection/immutable/RoseTree/api.d.ts +14 -14
- package/collection/immutable/SortedMap/api.d.ts +41 -41
- package/collection/immutable/Vector/api.d.ts +121 -117
- package/collection/immutable/Vector/definition.d.ts +2 -2
- package/collection/immutable/Vector/internal.d.ts +2 -2
- package/collection/mutable/ListBuffer.d.ts +1 -1
- package/control/Eval/api.d.ts +12 -12
- package/control/Z/api.d.ts +68 -68
- package/control/Z/runtime.d.ts +10 -10
- package/data/Branded/derivations.d.ts +2 -2
- package/data/Cause/api/fold.d.ts +3 -3
- package/data/Cause/api.d.ts +20 -20
- package/data/Const/api.d.ts +3 -3
- package/data/Datum/api.d.ts +43 -41
- package/data/DatumEither/api.d.ts +48 -46
- package/data/Decoder/api.d.ts +2 -2
- package/data/Duration/api.d.ts +7 -7
- package/data/Either/api/align.d.ts +5 -1
- package/data/Either/api/alignWith.d.ts +2 -2
- package/data/Either/api.d.ts +40 -46
- package/data/Either/constructors.d.ts +6 -6
- package/data/Either/destructors.d.ts +2 -2
- package/data/EitherT/api.d.ts +6 -6
- package/data/Encoder/api.d.ts +73 -0
- package/data/Encoder/definition.d.ts +12 -0
- package/data/Encoder.d.ts +2 -0
- package/data/Environment/api.d.ts +14 -14
- package/data/Environment/definition.d.ts +4 -0
- package/data/EnvironmentPatch.d.ts +73 -0
- package/data/ExecutionStrategy.d.ts +1 -6
- package/data/Exit/api.d.ts +32 -32
- package/data/Exit/constructors.d.ts +2 -2
- package/data/FiberId/api.d.ts +2 -2
- package/data/Identity/api.d.ts +8 -8
- package/data/Interval.d.ts +11 -11
- package/data/Intervals.d.ts +11 -11
- package/data/Maybe/api.d.ts +36 -37
- package/data/Maybe/constructors.d.ts +2 -2
- package/data/Maybe/definition.d.ts +7 -3
- package/data/Maybe/destructors.d.ts +2 -2
- package/data/Predicate/api.d.ts +5 -5
- package/data/Refinement/api.d.ts +9 -9
- package/data/Struct/api.d.ts +13 -23
- package/data/Tag/constructors.d.ts +1 -2
- package/data/Tag/definition.d.ts +0 -1
- package/data/These/api.d.ts +18 -22
- package/data/These/destructors.d.ts +4 -4
- package/data/Trace/api.d.ts +2 -2
- package/data/function/api.d.ts +3 -3
- package/data/function/pipe.d.ts +7 -1
- package/data/string/api.d.ts +9 -49
- package/data.d.ts +2 -1
- package/global/api.d.ts +3 -3
- package/global.d.ts +8 -0
- package/internal/Stack.d.ts +1 -1
- package/optics/At/definition.d.ts +1 -1
- package/optics/Fold/definition.d.ts +2 -6
- package/optics/Getter/definition.d.ts +1 -1
- package/optics/Index/definition.d.ts +1 -1
- package/optics/Iso/api.d.ts +2 -2
- package/optics/Iso/definition.d.ts +2 -2
- package/optics/Lens/api.d.ts +10 -10
- package/optics/Lens/definition.d.ts +4 -4
- package/optics/Optional/api/compose.d.ts +2 -2
- package/optics/Optional/definition.d.ts +4 -8
- package/optics/Prism/api/compose.d.ts +2 -2
- package/optics/Prism/definition.d.ts +2 -2
- package/optics/Setter/definition.d.ts +2 -14
- package/optics/Traversal/api/compose.d.ts +2 -2
- package/optics/Traversal/definition.d.ts +4 -4
- package/package.json +1 -1
- package/typeclass/Alt.d.ts +1 -1
- package/typeclass/ApplicativeExcept.d.ts +2 -6
- package/typeclass/Apply.d.ts +5 -5
- package/typeclass/Chain.d.ts +4 -4
- package/typeclass/Filterable.d.ts +6 -6
- package/typeclass/FilterableWithIndex.d.ts +6 -6
- package/typeclass/Foldable.d.ts +4 -4
- package/typeclass/FoldableWithIndex.d.ts +4 -4
- package/typeclass/Functor.d.ts +2 -2
- package/typeclass/FunctorWithIndex.d.ts +1 -1
- package/typeclass/Guard/api.d.ts +7 -7
- package/typeclass/Has.d.ts +3 -3
- package/typeclass/Ord/api/contramap.d.ts +2 -2
- package/typeclass/Semialign.d.ts +14 -14
- package/typeclass/Semimonoidal.d.ts +1 -1
- package/typeclass/Traversable.d.ts +4 -6
- package/typeclass/TraversableWithIndex.d.ts +2 -2
- package/typeclass/Witherable.d.ts +3 -3
- package/typeclass/WitherableWithIndex.d.ts +5 -5
- package/types/extractions.d.ts +10 -6
- package/util/assert.d.ts +1 -1
- package/_cjs/data/Patch/api.cjs.map +0 -1
- package/_cjs/data/Patch/definition.cjs +0 -88
- package/_cjs/data/Patch/definition.cjs.map +0 -1
- package/_cjs/data/Patch.cjs.map +0 -1
- package/_mjs/data/Patch/api.mjs +0 -112
- package/_mjs/data/Patch/api.mjs.map +0 -1
- package/_mjs/data/Patch/definition.mjs +0 -61
- package/_mjs/data/Patch/definition.mjs.map +0 -1
- package/_mjs/data/Patch.mjs +0 -4
- package/_mjs/data/Patch.mjs.map +0 -1
- package/_src/data/Patch/api.ts +0 -75
- package/_src/data/Patch/definition.ts +0 -58
- package/_src/data/Patch.ts +0 -4
- package/data/Patch/api.d.ts +0 -24
- package/data/Patch/definition.d.ts +0 -44
- package/data/Patch.d.ts +0 -2
@@ -10,6 +10,7 @@ import {
|
|
10
10
|
SIZE,
|
11
11
|
toBitmap,
|
12
12
|
} from "@fncts/base/collection/immutable/HashMap/internal";
|
13
|
+
import { pipe } from "@fncts/base/data/function";
|
13
14
|
import * as P from "@fncts/base/typeclass";
|
14
15
|
|
15
16
|
/**
|
@@ -53,55 +54,66 @@ export function makeDefault<K, V>(): HashMap<K, V> {
|
|
53
54
|
/**
|
54
55
|
* Makes a new map from a Foldable of key-value pairs
|
55
56
|
*
|
56
|
-
* @tsplus
|
57
|
+
* @tsplus pipeable fncts.HashMapOps fromFoldable
|
57
58
|
*/
|
58
59
|
export function fromFoldable<F extends HKT, C, K, A>(config: P.HashEq<K>, S: P.Semigroup<A>, F: P.Foldable<F, C>) {
|
59
60
|
return <K_, Q, W, X, I, S, R, E>(fka: HKT.Kind<F, C, K_, Q, W, X, I, S, R, E, readonly [K, A]>): HashMap<K, A> => {
|
60
|
-
return
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
61
|
+
return pipe(
|
62
|
+
fka,
|
63
|
+
F.foldLeft(makeWith(config), (b, [k, a]) => {
|
64
|
+
const oa = b.get(k);
|
65
|
+
if (oa.isJust()) {
|
66
|
+
return b.set(k, S.combine(oa.value, a));
|
67
|
+
} else {
|
68
|
+
return b.set(k, a);
|
69
|
+
}
|
70
|
+
}),
|
71
|
+
);
|
68
72
|
};
|
69
73
|
}
|
70
74
|
|
71
75
|
/**
|
72
76
|
* Lookup the value for `key` in `map` using custom hash.
|
73
77
|
*
|
74
|
-
* @tsplus
|
78
|
+
* @tsplus pipeable fncts.HashMap getHash
|
75
79
|
*/
|
76
|
-
export function
|
77
|
-
return
|
80
|
+
export function getHash<K>(key: K, hash: number) {
|
81
|
+
return <V>(map: HashMap<K, V>): Maybe<V> => {
|
82
|
+
return tryGetHash(map, key, hash);
|
83
|
+
};
|
78
84
|
}
|
79
85
|
|
80
86
|
/**
|
81
87
|
* Lookup the value for `key` in `map` using internal hash function.
|
82
88
|
*
|
83
|
-
* @tsplus
|
89
|
+
* @tsplus pipeable fncts.HashMap get
|
84
90
|
*/
|
85
|
-
export function
|
86
|
-
return
|
91
|
+
export function get<K>(key: K) {
|
92
|
+
return <V>(map: HashMap<K, V>): Maybe<V> => {
|
93
|
+
return tryGetHash(map, key, map.config.hash(key));
|
94
|
+
};
|
87
95
|
}
|
88
96
|
|
89
97
|
/**
|
90
98
|
* Does an entry exist for `key` in `map`? Uses custom `hash`.
|
91
99
|
*
|
92
|
-
* @tsplus
|
100
|
+
* @tsplus pipeable fncts.HashMap hashHash
|
93
101
|
*/
|
94
|
-
export function
|
95
|
-
return
|
102
|
+
export function hasHash<K>(key: K, hash: number) {
|
103
|
+
return <V>(map: HashMap<K, V>): boolean => {
|
104
|
+
return tryGetHash(map, key, hash).isJust();
|
105
|
+
};
|
96
106
|
}
|
97
107
|
|
98
108
|
/**
|
99
109
|
* Does an entry exist for `key` in `map`? Uses internal hash function.
|
100
110
|
*
|
101
|
-
* @tsplus
|
111
|
+
* @tsplus pipeable fncts.HashMap has
|
102
112
|
*/
|
103
|
-
export function
|
104
|
-
return
|
113
|
+
export function has<K>(key: K) {
|
114
|
+
return <V>(map: HashMap<K, V>): boolean => {
|
115
|
+
return tryGetHash(map, key, map.config.hash(key)).isJust();
|
116
|
+
};
|
105
117
|
}
|
106
118
|
|
107
119
|
/**
|
@@ -113,12 +125,14 @@ export function has_<K, V>(map: HashMap<K, V>, key: K): boolean {
|
|
113
125
|
* `modify` will always either update or insert a value into the map.
|
114
126
|
* Returns a map with the modified value. Does not alter `map`.
|
115
127
|
*
|
116
|
-
* @tsplus
|
128
|
+
* @tsplus pipeable fncts.HashMap modifyHash
|
117
129
|
*/
|
118
|
-
export function
|
119
|
-
|
120
|
-
|
121
|
-
|
130
|
+
export function modifyHash<K, V>(key: K, hash: number, f: UpdateFn<V>) {
|
131
|
+
return (map: HashMap<K, V>): HashMap<K, V> => {
|
132
|
+
const size = { value: map.size };
|
133
|
+
const newRoot = map.root.modify(map.editable ? map.edit : NaN, map.config.equals, 0, f, hash, key, size);
|
134
|
+
return setTree(map, newRoot, size.value);
|
135
|
+
};
|
122
136
|
}
|
123
137
|
|
124
138
|
/**
|
@@ -130,41 +144,49 @@ export function modifyHash_<K, V>(map: HashMap<K, V>, key: K, hash: number, f: U
|
|
130
144
|
* `modify` will always either update or insert a value into the map.
|
131
145
|
* Returns a map with the modified value. Does not alter `map`.
|
132
146
|
*
|
133
|
-
* @tsplus
|
147
|
+
* @tsplus pipeable fncts.HashMap modify
|
134
148
|
*/
|
135
|
-
export function
|
136
|
-
return map
|
149
|
+
export function modify<K, V>(key: K, f: UpdateFn<V>) {
|
150
|
+
return (map: HashMap<K, V>): HashMap<K, V> => {
|
151
|
+
return map.modifyHash(key, map.config.hash(key), f);
|
152
|
+
};
|
137
153
|
}
|
138
154
|
|
139
155
|
/**
|
140
156
|
* Store `value` for `key` in `map` using internal hash function.
|
141
157
|
*
|
142
|
-
* @tsplus
|
158
|
+
* @tsplus pipeable fncts.HashMap set
|
143
159
|
*/
|
144
|
-
export function
|
145
|
-
return map
|
160
|
+
export function set<K, V>(key: K, value: V) {
|
161
|
+
return (map: HashMap<K, V>): HashMap<K, V> => {
|
162
|
+
return map.modify(key, () => Just(value));
|
163
|
+
};
|
146
164
|
}
|
147
165
|
|
148
166
|
/**
|
149
167
|
* Remove the entry for `key` in `map` using internal hash.
|
150
168
|
*
|
151
|
-
* @tsplus
|
169
|
+
* @tsplus pipeable fncts.HashMap remove
|
152
170
|
*/
|
153
|
-
export function
|
154
|
-
return map
|
171
|
+
export function remove<K>(key: K) {
|
172
|
+
return <V>(map: HashMap<K, V>): HashMap<K, V> => {
|
173
|
+
return map.modify(key, () => Nothing());
|
174
|
+
};
|
155
175
|
}
|
156
176
|
|
157
177
|
/**
|
158
178
|
* Remove many keys
|
159
179
|
*
|
160
|
-
* @tsplus
|
180
|
+
* @tsplus pipeable fncts.HashMap removeMany
|
161
181
|
*/
|
162
|
-
export function
|
163
|
-
return
|
164
|
-
|
165
|
-
|
166
|
-
|
167
|
-
|
182
|
+
export function removeMany<K>(keys: Iterable<K>) {
|
183
|
+
return <V>(map: HashMap<K, V>): HashMap<K, V> => {
|
184
|
+
return map.mutate((m) => {
|
185
|
+
for (const k of keys) {
|
186
|
+
m.remove(k);
|
187
|
+
}
|
188
|
+
});
|
189
|
+
};
|
168
190
|
}
|
169
191
|
|
170
192
|
/**
|
@@ -189,12 +211,14 @@ export function endMutation<K, V>(map: HashMap<K, V>): HashMap<K, V> {
|
|
189
211
|
/**
|
190
212
|
* Mutate `map` within the context of `f`.
|
191
213
|
*
|
192
|
-
* @tsplus
|
214
|
+
* @tsplus pipeable fncts.HashMap mutate
|
193
215
|
*/
|
194
|
-
export function
|
195
|
-
|
196
|
-
|
197
|
-
|
216
|
+
export function mutate<K, V>(f: (map: HashMap<K, V>) => void) {
|
217
|
+
return (map: HashMap<K, V>): HashMap<K, V> => {
|
218
|
+
const transient = map.beginMutation;
|
219
|
+
f(transient);
|
220
|
+
return transient.endMutation;
|
221
|
+
};
|
198
222
|
}
|
199
223
|
|
200
224
|
/**
|
@@ -272,70 +296,84 @@ export function values<K, V>(map: HashMap<K, V>): IterableIterator<V> {
|
|
272
296
|
/**
|
273
297
|
* Update a value if exists
|
274
298
|
*
|
275
|
-
* @tsplus
|
299
|
+
* @tsplus pipeable fncts.HashMap update
|
276
300
|
*/
|
277
|
-
export function
|
278
|
-
return map
|
301
|
+
export function update<K, V>(key: K, f: (v: V) => V) {
|
302
|
+
return (map: HashMap<K, V>): HashMap<K, V> => {
|
303
|
+
return map.modify(key, (v) => v.map(f));
|
304
|
+
};
|
279
305
|
}
|
280
306
|
|
281
307
|
/**
|
282
308
|
* Apply f to each element
|
283
309
|
*
|
284
|
-
* @tsplus
|
310
|
+
* @tsplus pipeable fncts.HashMap forEachWithIndex
|
285
311
|
*/
|
286
|
-
export function
|
287
|
-
|
312
|
+
export function forEachWithIndex<K, V>(f: (k: K, v: V, m: HashMap<K, V>) => void) {
|
313
|
+
return (map: HashMap<K, V>): void => {
|
314
|
+
map.foldLeftWithIndex(undefined as void, (key, _, value) => f(key, value, map));
|
315
|
+
};
|
288
316
|
}
|
289
317
|
|
290
318
|
/**
|
291
319
|
* Apply f to each element
|
292
320
|
*
|
293
|
-
* @tsplus
|
321
|
+
* @tsplus pipeable fncts.HashMap forEach
|
294
322
|
*/
|
295
|
-
export function
|
296
|
-
return map
|
323
|
+
export function forEach<K, V>(f: (v: V, m: HashMap<K, V>) => void) {
|
324
|
+
return (map: HashMap<K, V>): void => {
|
325
|
+
return map.forEachWithIndex((_, v, m) => f(v, m));
|
326
|
+
};
|
297
327
|
}
|
298
328
|
|
299
329
|
/**
|
300
330
|
* Maps over the map entries
|
301
331
|
*
|
302
|
-
* @tsplus
|
332
|
+
* @tsplus pipeable fncts.HashMap mapWithIndex
|
303
333
|
*/
|
304
|
-
export function
|
305
|
-
return fa
|
334
|
+
export function mapWithIndex<K, V, A>(f: (k: K, v: V) => A) {
|
335
|
+
return (fa: HashMap<K, V>): HashMap<K, A> => {
|
336
|
+
return fa.foldLeftWithIndex(makeWith<K, A>(fa.config), (k, z, v) => z.set(k, f(k, v)));
|
337
|
+
};
|
306
338
|
}
|
307
339
|
|
308
340
|
/**
|
309
341
|
* Maps over the map entries
|
310
342
|
*
|
311
|
-
* @tsplus
|
343
|
+
* @tsplus pipeable fncts.HashMap map
|
312
344
|
*/
|
313
|
-
export function
|
314
|
-
return fa
|
345
|
+
export function map<V, A>(f: (v: V) => A) {
|
346
|
+
return <K>(fa: HashMap<K, V>): HashMap<K, A> => {
|
347
|
+
return fa.mapWithIndex((_, a) => f(a));
|
348
|
+
};
|
315
349
|
}
|
316
350
|
|
317
351
|
/**
|
318
352
|
* Chain over the map entries, the hash and equal of the 2 maps has to be the same
|
319
353
|
*
|
320
|
-
* @tsplus
|
354
|
+
* @tsplus pipeable fncts.HashMap flatMapWithIndex
|
321
355
|
*/
|
322
|
-
export function
|
323
|
-
return ma
|
324
|
-
|
325
|
-
|
326
|
-
|
327
|
-
|
328
|
-
|
329
|
-
|
356
|
+
export function flatMapWithIndex<K, V, A>(f: (k: K, v: V) => HashMap<K, A>) {
|
357
|
+
return (ma: HashMap<K, V>): HashMap<K, A> => {
|
358
|
+
return ma.foldLeftWithIndex(makeWith<K, A>(ma.config), (k, z, v) =>
|
359
|
+
z.mutate((m) => {
|
360
|
+
f(k, v).forEachWithIndex((k1, a1) => {
|
361
|
+
m.set(k1, a1);
|
362
|
+
});
|
363
|
+
}),
|
364
|
+
);
|
365
|
+
};
|
330
366
|
}
|
331
367
|
|
332
368
|
/**
|
333
369
|
* Chain over the map entries, the hash and equal of the 2 maps has to be the same
|
334
370
|
*
|
335
|
-
* @tsplus
|
371
|
+
* @tsplus pipeable fncts.HashMap flatMap
|
336
372
|
*/
|
337
|
-
export function
|
338
|
-
return ma
|
373
|
+
export function flatMap<K, V, A>(f: (v: V) => HashMap<K, A>) {
|
374
|
+
return (ma: HashMap<K, V>): HashMap<K, A> => {
|
375
|
+
return ma.flatMapWithIndex((_, a) => f(a));
|
376
|
+
};
|
339
377
|
}
|
340
378
|
|
341
379
|
/**
|
@@ -359,254 +397,330 @@ export function separate<K, A, B>(map: HashMap<K, Either<A, B>>): readonly [Hash
|
|
359
397
|
/**
|
360
398
|
* Filter out None and map
|
361
399
|
*
|
362
|
-
* @tsplus
|
400
|
+
* @tsplus pipeable fncts.HashMap filterMapWithIndex
|
363
401
|
*/
|
364
|
-
export function
|
365
|
-
return
|
366
|
-
|
367
|
-
const
|
368
|
-
|
369
|
-
|
402
|
+
export function filterMapWithIndex<K, A, B>(f: (k: K, a: A) => Maybe<B>) {
|
403
|
+
return (map: HashMap<K, A>): HashMap<K, B> => {
|
404
|
+
return makeWith<K, B>(map.config).mutate((m) => {
|
405
|
+
for (const [k, a] of map) {
|
406
|
+
const o = f(k, a);
|
407
|
+
if (o.isJust()) {
|
408
|
+
m.set(k, o.value);
|
409
|
+
}
|
370
410
|
}
|
371
|
-
}
|
372
|
-
}
|
411
|
+
});
|
412
|
+
};
|
373
413
|
}
|
374
414
|
|
375
415
|
/**
|
376
416
|
* Filter out None and map
|
377
417
|
*
|
378
|
-
* @tsplus
|
418
|
+
* @tsplus pipeable fncts.HashMap filterMap
|
379
419
|
*/
|
380
|
-
export function
|
381
|
-
return map
|
420
|
+
export function filterMap<A, B>(f: (a: A) => Maybe<B>) {
|
421
|
+
return <K>(map: HashMap<K, A>): HashMap<K, B> => {
|
422
|
+
return map.filterMapWithIndex((_, a) => f(a));
|
423
|
+
};
|
382
424
|
}
|
383
425
|
|
384
426
|
/**
|
385
427
|
* Filter out by predicate
|
386
428
|
*
|
387
|
-
* @tsplus
|
429
|
+
* @tsplus pipeable fncts.HashMap filterWithIndex
|
388
430
|
*/
|
389
|
-
export function
|
390
|
-
map: HashMap<K, A>,
|
431
|
+
export function filterWithIndex<K, A, B extends A>(
|
391
432
|
refinement: RefinementWithIndex<K, A, B>,
|
392
|
-
): HashMap<K, B>;
|
393
|
-
export function
|
394
|
-
export function
|
395
|
-
return
|
396
|
-
|
397
|
-
|
398
|
-
|
433
|
+
): (map: HashMap<K, A>) => HashMap<K, B>;
|
434
|
+
export function filterWithIndex<K, A>(predicate: PredicateWithIndex<K, A>): (map: HashMap<K, A>) => HashMap<K, A>;
|
435
|
+
export function filterWithIndex<K, A>(predicate: PredicateWithIndex<K, A>) {
|
436
|
+
return (map: HashMap<K, A>): HashMap<K, A> => {
|
437
|
+
return makeWith<K, A>(map.config).mutate((m) => {
|
438
|
+
for (const [k, a] of map) {
|
439
|
+
if (predicate(k, a)) {
|
440
|
+
m.set(k, a);
|
441
|
+
}
|
399
442
|
}
|
400
|
-
}
|
401
|
-
}
|
443
|
+
});
|
444
|
+
};
|
402
445
|
}
|
403
446
|
|
404
447
|
/**
|
405
448
|
* Filter out by predicate
|
406
449
|
*
|
407
|
-
* @tsplus
|
450
|
+
* @tsplus pipeable fncts.HashMap filter
|
408
451
|
*/
|
409
|
-
export function
|
410
|
-
export function
|
411
|
-
export function
|
412
|
-
return map
|
452
|
+
export function filter<A, B extends A>(refinement: Refinement<A, B>): <K>(map: HashMap<K, A>) => HashMap<K, B>;
|
453
|
+
export function filter<A>(predicate: Predicate<A>): <K>(map: HashMap<K, A>) => HashMap<K, A>;
|
454
|
+
export function filter<A>(predicate: Predicate<A>) {
|
455
|
+
return <K>(map: HashMap<K, A>): HashMap<K, A> => {
|
456
|
+
return map.filterWithIndex((_, a) => predicate(a));
|
457
|
+
};
|
413
458
|
}
|
414
459
|
|
415
460
|
/**
|
416
|
-
* @tsplus
|
461
|
+
* @tsplus pipeable fncts.HashMap partitionMapWithIndex
|
417
462
|
*/
|
418
|
-
export function
|
419
|
-
map: HashMap<K, V>,
|
420
|
-
|
421
|
-
|
422
|
-
|
423
|
-
|
424
|
-
|
425
|
-
|
426
|
-
|
427
|
-
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
});
|
435
|
-
|
436
|
-
return [left.endMutation, right.endMutation];
|
463
|
+
export function partitionMapWithIndex<K, V, A, B>(f: (i: K, a: V) => Either<A, B>) {
|
464
|
+
return (map: HashMap<K, V>): readonly [HashMap<K, A>, HashMap<K, B>] => {
|
465
|
+
const left = makeWith<K, A>(map.config).beginMutation;
|
466
|
+
const right = makeWith<K, B>(map.config).beginMutation;
|
467
|
+
map.forEachWithIndex((k, v) => {
|
468
|
+
f(k, v).match(
|
469
|
+
(a) => {
|
470
|
+
left.set(k, a);
|
471
|
+
},
|
472
|
+
(b) => {
|
473
|
+
right.set(k, b);
|
474
|
+
},
|
475
|
+
);
|
476
|
+
});
|
477
|
+
return [left.endMutation, right.endMutation];
|
478
|
+
};
|
437
479
|
}
|
438
480
|
|
439
481
|
/**
|
440
|
-
* @tsplus
|
482
|
+
* @tsplus pipeable fncts.HashMap partitionMap
|
441
483
|
*/
|
442
|
-
export function
|
443
|
-
map: HashMap<K, V>,
|
444
|
-
|
445
|
-
|
446
|
-
return map.partitionMapWithIndex((_, a) => f(a));
|
484
|
+
export function partitionMap<V, A, B>(f: (a: V) => Either<A, B>) {
|
485
|
+
return <K>(map: HashMap<K, V>): readonly [HashMap<K, A>, HashMap<K, B>] => {
|
486
|
+
return map.partitionMapWithIndex((_, a) => f(a));
|
487
|
+
};
|
447
488
|
}
|
448
489
|
|
449
490
|
/**
|
450
|
-
* @tsplus
|
491
|
+
* @tsplus pipeable fncts.HashMap partitionWithIndex
|
451
492
|
*/
|
452
|
-
export function
|
453
|
-
map: HashMap<K, V>,
|
493
|
+
export function partitionWithIndex<K, V, B extends V>(
|
454
494
|
refinement: RefinementWithIndex<K, V, B>,
|
455
|
-
): readonly [HashMap<K, V>, HashMap<K, B>];
|
456
|
-
export function
|
457
|
-
map: HashMap<K, V>,
|
458
|
-
predicate: PredicateWithIndex<K, V>,
|
459
|
-
): readonly [HashMap<K, V>, HashMap<K, V>];
|
460
|
-
export function partitionWithIndex_<K, V>(
|
461
|
-
map: HashMap<K, V>,
|
495
|
+
): (map: HashMap<K, V>) => readonly [HashMap<K, V>, HashMap<K, B>];
|
496
|
+
export function partitionWithIndex<K, V>(
|
462
497
|
predicate: PredicateWithIndex<K, V>,
|
463
|
-
): readonly [HashMap<K, V>, HashMap<K, V>]
|
464
|
-
|
465
|
-
|
466
|
-
|
467
|
-
|
468
|
-
|
469
|
-
|
470
|
-
|
471
|
-
|
472
|
-
|
473
|
-
|
474
|
-
|
475
|
-
|
498
|
+
): (map: HashMap<K, V>) => readonly [HashMap<K, V>, HashMap<K, V>];
|
499
|
+
export function partitionWithIndex<K, V>(predicate: PredicateWithIndex<K, V>) {
|
500
|
+
return (map: HashMap<K, V>): readonly [HashMap<K, V>, HashMap<K, V>] => {
|
501
|
+
const left = makeWith<K, V>(map.config).beginMutation;
|
502
|
+
const right = makeWith<K, V>(map.config).beginMutation;
|
503
|
+
map.forEachWithIndex((k, v) => {
|
504
|
+
if (predicate(k, v)) {
|
505
|
+
right.set(k, v);
|
506
|
+
} else {
|
507
|
+
left.set(k, v);
|
508
|
+
}
|
509
|
+
});
|
510
|
+
return [left.endMutation, right.endMutation];
|
511
|
+
};
|
476
512
|
}
|
477
513
|
|
478
514
|
/**
|
479
|
-
* @tsplus
|
515
|
+
* @tsplus pipeable fncts.HashMap partition
|
480
516
|
*/
|
481
|
-
export function
|
482
|
-
map: HashMap<K, V>,
|
517
|
+
export function partition<V, B extends V>(
|
483
518
|
refinement: Refinement<V, B>,
|
484
|
-
): readonly [HashMap<K, V>, HashMap<K, B>];
|
485
|
-
export function
|
486
|
-
|
487
|
-
|
519
|
+
): <K>(map: HashMap<K, V>) => readonly [HashMap<K, V>, HashMap<K, B>];
|
520
|
+
export function partition<V>(
|
521
|
+
predicate: Predicate<V>,
|
522
|
+
): <K>(map: HashMap<K, V>) => readonly [HashMap<K, V>, HashMap<K, V>];
|
523
|
+
export function partition<V>(predicate: Predicate<V>) {
|
524
|
+
return <K>(map: HashMap<K, V>): readonly [HashMap<K, V>, HashMap<K, V>] => {
|
525
|
+
return map.partitionWithIndex((_, a) => predicate(a));
|
526
|
+
};
|
488
527
|
}
|
489
528
|
|
490
529
|
/**
|
491
530
|
* Reduce a state over the map entries
|
492
531
|
*
|
493
|
-
* @tsplus
|
532
|
+
* @tsplus pipeable fncts.HashMap foldLeftWithIndex
|
494
533
|
*/
|
495
|
-
export function
|
496
|
-
|
497
|
-
|
498
|
-
|
499
|
-
|
500
|
-
|
501
|
-
|
502
|
-
|
503
|
-
|
504
|
-
|
505
|
-
|
506
|
-
|
507
|
-
|
508
|
-
if (child
|
509
|
-
if (child.
|
510
|
-
|
511
|
-
|
534
|
+
export function foldLeftWithIndex<K, V, Z>(z: Z, f: (k: K, z: Z, v: V) => Z) {
|
535
|
+
return (map: HashMap<K, V>): Z => {
|
536
|
+
const root = map.root;
|
537
|
+
if (root._tag === "LeafNode") return root.value.isJust() ? f(root.key, z, root.value.value) : z;
|
538
|
+
if (root._tag === "EmptyNode") {
|
539
|
+
return z;
|
540
|
+
}
|
541
|
+
const toVisit = [root.children];
|
542
|
+
let children;
|
543
|
+
let acc = z;
|
544
|
+
while ((children = toVisit.pop())) {
|
545
|
+
for (let i = 0, len = children.length; i < len; ) {
|
546
|
+
const child = children[i++];
|
547
|
+
if (child && !isEmptyNode(child)) {
|
548
|
+
if (child._tag === "LeafNode") {
|
549
|
+
if (child.value.isJust()) {
|
550
|
+
// eslint-disable-next-line no-param-reassign
|
551
|
+
acc = f(child.key, acc, child.value.value);
|
552
|
+
}
|
553
|
+
} else {
|
554
|
+
toVisit.push(child.children);
|
512
555
|
}
|
513
|
-
} else {
|
514
|
-
toVisit.push(child.children);
|
515
556
|
}
|
516
557
|
}
|
517
558
|
}
|
518
|
-
|
519
|
-
|
559
|
+
return acc;
|
560
|
+
};
|
520
561
|
}
|
521
562
|
|
522
563
|
/**
|
523
564
|
* Reduce a state over the map entries
|
524
565
|
*
|
525
|
-
* @tsplus
|
566
|
+
* @tsplus pipeable fncts.HashMap foldLeft
|
526
567
|
*/
|
527
|
-
export function
|
528
|
-
return map
|
568
|
+
export function foldLeft<V, Z>(z: Z, f: (z: Z, v: V) => Z) {
|
569
|
+
return <K>(map: HashMap<K, V>): Z => {
|
570
|
+
return map.foldLeftWithIndex(z, (_, b, a) => f(b, a));
|
571
|
+
};
|
529
572
|
}
|
530
573
|
|
531
574
|
/**
|
532
575
|
* @tsplus getter fncts.HashMap traverseWithIndex
|
533
576
|
*/
|
534
|
-
export
|
535
|
-
|
536
|
-
|
537
|
-
|
577
|
+
export function _traverseWithIndex<K, A>(
|
578
|
+
self: HashMap<K, A>,
|
579
|
+
): <G extends HKT, GC = HKT.None>(
|
580
|
+
G: P.Applicative<G, GC>,
|
581
|
+
) => <K1, Q, W, X, I, S, R, E, B>(
|
582
|
+
f: (i: K, a: A) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, B>,
|
583
|
+
) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, HashMap<K, B>>;
|
584
|
+
export function _traverseWithIndex<K, A>(
|
585
|
+
self: HashMap<K, A>,
|
586
|
+
): <G>(G: P.Applicative<HKT.F<G>>) => <B>(f: (i: K, a: A) => HKT.FK1<G, B>) => HKT.FK1<G, HashMap<K, B>> {
|
587
|
+
return (G) => (f) =>
|
588
|
+
self.foldLeftWithIndex(G.pure(HashMap.makeWith(self.config)), (k, b, a) =>
|
589
|
+
pipe(
|
590
|
+
b,
|
591
|
+
G.zipWith(f(k, a), (map, b) => map.set(k, b)),
|
592
|
+
),
|
593
|
+
);
|
594
|
+
}
|
538
595
|
|
539
596
|
/**
|
540
597
|
* @tsplus getter fncts.HashMap traverse
|
541
598
|
*/
|
542
|
-
export
|
599
|
+
export function _traverse<K, A>(
|
600
|
+
self: HashMap<K, A>,
|
601
|
+
): <G extends HKT, GC = HKT.None>(
|
602
|
+
G: P.Applicative<G, GC>,
|
603
|
+
) => <K1, Q, W, X, I, S, R, E, B>(
|
604
|
+
f: (a: A) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, B>,
|
605
|
+
) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, HashMap<K, B>> {
|
606
|
+
return (G) => (f) => self.traverseWithIndex(G)((_, a) => f(a));
|
607
|
+
}
|
608
|
+
|
609
|
+
export const traverseWithIndex: P.TraversableWithIndex<HashMapF>["traverseWithIndex"] = (G) => (f) => (ta) =>
|
610
|
+
ta.traverseWithIndex(G)(f);
|
611
|
+
|
612
|
+
export const traverse: P.Traversable<HashMapF>["traverse"] = (G) => (f) => (ta) =>
|
543
613
|
ta.traverseWithIndex(G)((_, a) => f(a));
|
544
614
|
|
545
615
|
/**
|
546
|
-
* @tsplus
|
616
|
+
* @tsplus pipeable fncts.HashMap unsafeGet
|
547
617
|
*/
|
548
|
-
export function
|
549
|
-
return self
|
618
|
+
export function unsafeGet<K>(key: K) {
|
619
|
+
return <V>(self: HashMap<K, V>): V | undefined => {
|
620
|
+
return self.getHash(key, self.config.hash(key)).value;
|
621
|
+
};
|
550
622
|
}
|
551
623
|
|
552
624
|
/**
|
553
625
|
* @tsplus getter fncts.HashMap witherWithIndex
|
554
626
|
*/
|
555
|
-
export
|
556
|
-
|
627
|
+
export function _witherWithIndex<K, A>(
|
628
|
+
self: HashMap<K, A>,
|
629
|
+
): <G extends HKT, GC = HKT.None>(
|
630
|
+
G: P.Applicative<G, GC>,
|
631
|
+
) => <K1, Q, W, X, I, S, R, E, B>(
|
632
|
+
f: (i: K, a: A) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, Maybe<B>>,
|
633
|
+
) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, HashMap<K, B>> {
|
634
|
+
return (G) => (f) => self.traverseWithIndex(G)(f).pipe(G.map(compact));
|
635
|
+
}
|
557
636
|
|
558
637
|
/**
|
559
638
|
* @tsplus getter fncts.HashMap wither
|
560
639
|
*/
|
561
|
-
export
|
640
|
+
export function _wither<K, A>(
|
641
|
+
self: HashMap<K, A>,
|
642
|
+
): <G extends HKT, GC = HKT.None>(
|
643
|
+
G: P.Applicative<G, GC>,
|
644
|
+
) => <K1, Q, W, X, I, S, R, E, B>(
|
645
|
+
f: (a: A) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, Maybe<B>>,
|
646
|
+
) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, HashMap<K, B>> {
|
647
|
+
return (G) => (f) => self.witherWithIndex(G)((_, a) => f(a));
|
648
|
+
}
|
649
|
+
|
650
|
+
export const witherWithIndex: P.WitherableWithIndex<HashMapF>["witherWithIndex"] = (G) => (f) => (wa) =>
|
651
|
+
wa.witherWithIndex(G)(f);
|
652
|
+
|
653
|
+
export const wither: P.Witherable<HashMapF>["wither"] = (G) => (f) => (wa) => wa.witherWithIndex(G)((_, a) => f(a));
|
562
654
|
|
563
655
|
/**
|
564
656
|
* @tsplus getter fncts.HashMap wiltWithIndex
|
565
657
|
*/
|
566
|
-
export
|
567
|
-
|
658
|
+
export function _wiltWithIndex<K, A>(
|
659
|
+
self: HashMap<K, A>,
|
660
|
+
): <G extends HKT, GC = HKT.None>(
|
661
|
+
G: P.Applicative<G, GC>,
|
662
|
+
) => <K1, Q, W, X, I, S, R, E, B, B2>(
|
663
|
+
f: (i: K, a: A) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, Either<B, B2>>,
|
664
|
+
) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, readonly [HashMap<K, B>, HashMap<K, B2>]> {
|
665
|
+
return (G) => (f) => self.traverseWithIndex(G)(f).pipe(G.map(separate));
|
666
|
+
}
|
568
667
|
|
569
668
|
/**
|
570
669
|
* @tsplus getter fncts.HashMap wilt
|
571
670
|
*/
|
572
|
-
export
|
671
|
+
export function _wilt<K, A>(
|
672
|
+
self: HashMap<K, A>,
|
673
|
+
): <G extends HKT, GC = HKT.None>(
|
674
|
+
G: P.Applicative<G, GC>,
|
675
|
+
) => <K1, Q, W, X, I, S, R, E, B, B2>(
|
676
|
+
f: (a: A) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, Either<B, B2>>,
|
677
|
+
) => HKT.Kind<G, GC, K1, Q, W, X, I, S, R, E, readonly [HashMap<K, B>, HashMap<K, B2>]> {
|
678
|
+
return (G) => (f) => self.wiltWithIndex(G)((_, a) => f(a));
|
679
|
+
}
|
680
|
+
|
681
|
+
export const wiltWithIndex: P.WitherableWithIndex<HashMapF>["wiltWithIndex"] = (G) => (f) => (wa) =>
|
682
|
+
wa.wiltWithIndex(G)(f);
|
683
|
+
|
684
|
+
export const wilt: P.Witherable<HashMapF>["wilt"] = (G) => (f) => (wa) => wa.wiltWithIndex(G)((_, a) => f(a));
|
573
685
|
|
574
686
|
/**
|
575
|
-
* @tsplus
|
687
|
+
* @tsplus pipeable fncts.HashMap unionWith
|
576
688
|
*/
|
577
|
-
export function
|
578
|
-
self: HashMap<K, A
|
579
|
-
|
580
|
-
|
581
|
-
|
582
|
-
|
583
|
-
|
584
|
-
|
585
|
-
|
586
|
-
|
587
|
-
|
588
|
-
|
589
|
-
|
590
|
-
}
|
591
|
-
});
|
689
|
+
export function unionWith<K, A>(that: Iterable<readonly [K, A]>, f: (x: A, y: A) => A) {
|
690
|
+
return (self: HashMap<K, A>): HashMap<K, A> => {
|
691
|
+
return self.mutate((m) => {
|
692
|
+
for (const [k, a] of that) {
|
693
|
+
m.modify(k, (v) =>
|
694
|
+
v.match(
|
695
|
+
() => Just(a),
|
696
|
+
(a0) => Just(f(a0, a)),
|
697
|
+
),
|
698
|
+
);
|
699
|
+
}
|
700
|
+
});
|
701
|
+
};
|
592
702
|
}
|
593
703
|
|
594
704
|
/**
|
595
|
-
* @tsplus
|
705
|
+
* @tsplus pipeable fncts.HashMap union
|
596
706
|
*/
|
597
|
-
export function
|
598
|
-
return self
|
599
|
-
|
600
|
-
|
601
|
-
|
602
|
-
|
707
|
+
export function union<K, A>(that: Iterable<readonly [K, A]>) {
|
708
|
+
return (self: HashMap<K, A>): HashMap<K, A> => {
|
709
|
+
return self.mutate((m) => {
|
710
|
+
for (const [k, a] of that) {
|
711
|
+
m.set(k, a);
|
712
|
+
}
|
713
|
+
});
|
714
|
+
};
|
603
715
|
}
|
604
716
|
|
605
717
|
/**
|
606
|
-
* @tsplus
|
718
|
+
* @tsplus pipeable fncts.HashMap pop
|
607
719
|
*/
|
608
|
-
export function
|
609
|
-
return
|
720
|
+
export function pop<K>(k: K) {
|
721
|
+
return <A>(map: HashMap<K, A>): Maybe<readonly [A, HashMap<K, A>]> => {
|
722
|
+
return map.get(k).map((a) => [a, map.remove(k)]);
|
723
|
+
};
|
610
724
|
}
|
611
725
|
|
612
726
|
/*
|