Releases: ahrjarrett/any-ts
v0.48.1
Patch Changes
-
#171
47039da
Thanks @ahrjarrett! - feat: addsinline
type utilitynew features
- new inline utility
inline
is basically a type-level identity function.like its runtime counterpart, it can be pretty useful.
the name
inline
refers to the particular use case that I personally usually use it for,
which is for wrapping a type literal so that an interface can extend it.import type { inline } from "any-ts"; ////////////// /// example /** * did you know you can make an interface out of an array? * this can be useful when you want to preserve the * identifier: vvvv */ interface Numbers extends inline<number[]> {} declare const numbers: Numbers; // ^? const numbers: Numbers // normal array behavior is preserved: const copy = [...ex_01.numbers]; // ^? const copy: number[]
v0.48.0
Minor Changes
- #169
648a8de
Thanks @ahrjarrett! - ### breaking changes- All of the members of Universal namespace have changed their implementations
- Since
any-ts
is still pre v1.0, this is a minor version bump. - The API is relatively stable; I expect one (1) more breaking change before releasing v1.0.0 this fall
- Since
- All of the members of Universal namespace have changed their implementations
v0.47.4
Patch Changes
- #167
4234c81
Thanks @ahrjarrett! - deprecate:Identity
-- usenewtype
instead
v0.47.3
Patch Changes
- #165
60f77df
Thanks @ahrjarrett! - fix:some.entriesOf
when used in matching position
v0.47.2
Patch Changes
- #163
29e5043
Thanks @ahrjarrett! - feat: addssome.entriesOf
v0.47.1
Patch Changes
- #161
b06a828
Thanks @ahrjarrett! - fix: correctly exportsmatch.finite
namespace
v0.47.0
Minor Changes
-
#157
9fb7871
Thanks @ahrjarrett! - break: renamesmatch.finite*
tomatch.finite.*
for example:
match.finiteArray -> match.finite.array match.nonfiniteArray -> match.nonfinite.array
Patch Changes
- #160
350fd9f
Thanks @ahrjarrett! - fix: re-exportssome.instanceOf
; feat: addsany.maybeIndexedBy
v0.46.0
Minor Changes
-
bf5df0f: ### new features
- added
match
, a namespace for advanced pattern matching - added
any.functions
to describe any array of functions
breaking changes
a few members of the
some
namespace behave differently than before:-
some.keyOf
: this change was made to support a homomorphicobject.map
function
that operates on both arrays and objects, preserves structure in either case.An example implementation:
/** * {@link map `map [overload 1/2]`} ("data-last") * * [TypeScript playground](https://tsplay.dev/weA2Yw) * * {@link map `map`} takes two arguments: * 1. a function * 2. a composite data structure that contains one or more targets to apply the function to * * A unique feature of this implementation is its polymorphism: it doesn't care whether the * composite data structure is an array, or whether it's an object. It will apply the argument * to each of the children, and will preserve the structure of the original shape. * * **Trade-off:** the data-last overload of {@link map `map`} is optimized for function composition. * It works best when used inside a call to {@link fn.pipe `fn.pipe`} or {@link fn.flow `fn.flow`}. * It comes with greater potential for code re-use, at the cost of slightly slower performance. * * **Ergonomics:** if you'd prefer to provide both arguments at the same time, see overload #2. */ export function map<const xs, target>( fn: (x: xs[some.keyof<xs>], ix: some.keyof<xs>, xs: xs) => target ): (xs: xs) => { [ix in keyof xs]: target }; /** * {@link map `map [overload 2/2]`} ("data-first") * * [TypeScript playground](https://tsplay.dev/weA2Yw) * * {@link map `map`} is a polymorphic function that accepts a function and a data structure (such * as an array or object) to apply the function to. * * A unique feature of this implementation is its ability to abstract away the type of the data * structure it maps the function over; whether you pass it an object or an array, it will handle * applying the function to the data strucuture's values and returning a data structure whose type * corresponds 1-1 with the type of input. * * **Trade-off:** the data-first overload of {@link map `map`} evaluates eagerly. It comes with * slightly better performance than the data-last overload, at the cost of reusability. * * **Ergonomics:** if you'd prefer to use {@link map `map`} in a pipeline, see overload #1. */ export function map<const xs, target>( xs: xs, fn: (x: xs[some.keyof<xs>], xs: xs) => target ): { [ix in keyof xs]: target }; // impl. export function map<const xs, target>( ...args: | [fn: (x: xs[some.keyof<xs>], ix: some.keyof<xs>, xs: xs) => target] | [ xs: xs, fn: (x: xs[some.keyof<xs>], ix: some.keyof<xs>, xs: xs) => target ] ) { if (args.length === 1) return (xs: xs) => map(xs, args[0]); else { const [xs, fn] = args; if (globalThis.Array.isArray(xs)) return xs.map(fn as never); else { let out: any.struct = {}; for (const k in xs) out[k] = fn(xs[k] as never, k as never, xs); return out; } } }
-
some.entryOf
slightly different semantics to support a polymorphicobject.entries
function -
some.valueOf
slightly different semantics to support a polymorphicobject.values
function
- added