From 612937fb46beee81b8bbd1f7e188e27c5240e935 Mon Sep 17 00:00:00 2001 From: Joshua T Kalis Date: Tue, 3 Dec 2024 08:36:44 -0500 Subject: [PATCH] refactor: make anys explicit --- packages/core/src/composition/compose/index.ts | 14 ++++++++++---- packages/core/src/composition/curry/index.ts | 11 +++++++---- packages/core/src/composition/pipe/index.ts | 14 ++++++++------ packages/core/src/types.ts | 11 +++++++---- packages/core/src/utility/lookup/index.ts | 3 ++- packages/core/src/utility/once/index.ts | 4 +++- 6 files changed, 37 insertions(+), 20 deletions(-) diff --git a/packages/core/src/composition/compose/index.ts b/packages/core/src/composition/compose/index.ts index aaaf48f9..c354741d 100644 --- a/packages/core/src/composition/compose/index.ts +++ b/packages/core/src/composition/compose/index.ts @@ -1,11 +1,11 @@ /* eslint-disable @typescript-eslint/no-explicit-any */ -import type { UnaryFunction } from '@/types'; +import type { ExplicitAny, UnaryFunction } from '@/types'; // https://stackoverflow.com/questions/49310886/typing-compose-function-in-typescript-flow-compose#answer-73082627 // If its a list of functions, last being Unary type ComposeParams = Fns extends readonly [ - ...any[], + ...ExplicitAny[], infer Last extends UnaryFunction, ] ? // Get Params of the last, which returns [...argTypes], so get the first one [0] @@ -21,11 +21,17 @@ type Composable = Fn extends readonly [UnaryFunction] ? Fn : // if its a list of Unary funcs (ignoring the first) - Fn extends readonly [any, ...infer Rest extends readonly UnaryFunction[]] + Fn extends readonly [ + ExplicitAny, + ...infer Rest extends readonly UnaryFunction[], + ] ? // Start building the list of func type by using the return type of the first in Rest // as the arg of the next in line and recursively spread the rest (doing the same thing) // The first is ignored but handled by the top level ComposeReturn - readonly [(arg: ComposeReturn) => any, ...Composable] + readonly [ + (arg: ComposeReturn) => ExplicitAny, + ...Composable, + ] : never; /** diff --git a/packages/core/src/composition/curry/index.ts b/packages/core/src/composition/curry/index.ts index b8787e94..47b06d01 100644 --- a/packages/core/src/composition/curry/index.ts +++ b/packages/core/src/composition/curry/index.ts @@ -1,9 +1,12 @@ -/* eslint-disable @typescript-eslint/no-explicit-any */ // https://github.com/type-challenges/type-challenges/issues/15988 +import type { ExplicitAny } from '@/types'; + export type Curried =

>( ...args: P -) => ((...args: T) => any) extends (...args: [...P, ...infer Args]) => any +) => ((...args: T) => ExplicitAny) extends ( + ...args: [...P, ...infer Args] +) => ExplicitAny ? Args extends [] ? R : Curried @@ -19,9 +22,9 @@ export type Curried =

>( * curried(2)(3, 4); * curried(2, 3, 4); */ -export function autoCurry any>( +export function autoCurry ExplicitAny>( fn: T, - _args = [] as any[], + _args = [] as ExplicitAny[], ): Curried, ReturnType> { return (...__args) => ((rest) => (rest.length >= fn.length ? fn(...rest) : autoCurry(fn, rest)))([ diff --git a/packages/core/src/composition/pipe/index.ts b/packages/core/src/composition/pipe/index.ts index 4cd3e4eb..3baacdef 100644 --- a/packages/core/src/composition/pipe/index.ts +++ b/packages/core/src/composition/pipe/index.ts @@ -1,10 +1,9 @@ -/* eslint-disable @typescript-eslint/no-explicit-any */ -import type { UnaryFunction } from '@/types'; +import type { ExplicitAny, UnaryFunction } from '@/types'; // If its a list of functions, last being Unary type PipeParams = Fns extends readonly [ infer First extends UnaryFunction, - ...any[], + ...ExplicitAny[], ] ? // Get Params of the first, which returns [...argTypes], so get the first one [0] // so that we have the true type of the arg @@ -15,7 +14,7 @@ type PipeParams = Fns extends readonly [ // have to spread and infer last so that it gets the right type for the last one // [-1] no bueno type PipeReturn = ReturnType< - Fns extends readonly [...any[], infer Last extends UnaryFunction] + Fns extends readonly [...ExplicitAny[], infer Last extends UnaryFunction] ? Last : never >; @@ -25,11 +24,14 @@ type Pipeable = Fn extends readonly [UnaryFunction] ? Fn : // if its a list of Unary funcs (ignoring the last) - Fn extends readonly [...infer Head extends readonly UnaryFunction[], any] + Fn extends readonly [ + ...infer Head extends readonly UnaryFunction[], + ExplicitAny, + ] ? // Start building the list of func type by using the return type of the last in Head // as the arg of the previous in line and recursively spread the rest (doing the same thing) // The last is ignored but handled by the top level FlowReturn - readonly [...Pipeable, (arg: PipeReturn) => any] + readonly [...Pipeable, (arg: PipeReturn) => ExplicitAny] : never; /** diff --git a/packages/core/src/types.ts b/packages/core/src/types.ts index dc008bcf..57c3f927 100644 --- a/packages/core/src/types.ts +++ b/packages/core/src/types.ts @@ -1,11 +1,14 @@ -export type UnaryFunction = (x: any) => any; +export type Accumulator = (acc: R, x: T) => R; export type ArrayElementType = T extends (infer E)[] ? E : T; export type Comparator = (x: T) => boolean; -export type Predicate = (x: T, idx?: number) => boolean; - -export type Accumulator = (acc: R, x: T) => R; +// biome-ignore lint/suspicious/noExplicitAny: +export type ExplicitAny = any; export type MapFn = (x: T, idx?: number) => R; + +export type Predicate = (x: T, idx?: number) => boolean; + +export type UnaryFunction = (x: ExplicitAny) => ExplicitAny; diff --git a/packages/core/src/utility/lookup/index.ts b/packages/core/src/utility/lookup/index.ts index bdf4782d..590d0244 100644 --- a/packages/core/src/utility/lookup/index.ts +++ b/packages/core/src/utility/lookup/index.ts @@ -1,3 +1,4 @@ +import type { ExplicitAny } from '@/types'; import { identity } from '../../combinators/i'; /** @@ -18,7 +19,7 @@ import { identity } from '../../combinators/i'; export const lookup = < A extends Record, - B extends (...args: any[]) => any, + B extends (...args: ExplicitAny[]) => ExplicitAny, >( obj: A, def?: B, diff --git a/packages/core/src/utility/once/index.ts b/packages/core/src/utility/once/index.ts index eba3f58b..75511d58 100644 --- a/packages/core/src/utility/once/index.ts +++ b/packages/core/src/utility/once/index.ts @@ -1,5 +1,7 @@ +import type { ExplicitAny } from '@/types'; + // TS' `Function` type only models the object side of it, not whether it is callable. -type SomeFunction = (...args: any[]) => any; +type SomeFunction = (...args: ExplicitAny[]) => ExplicitAny; /** * Ensures that the given function is only called once.