Description
π Search Terms
"implicitly has an" inference
π Version & Regression Information
- This is the behavior in every version I tried, and I reviewed the FAQ for entries about "inference"
β― Playground Link
π» Code
export interface AsyncResultCallback<T, E = Error> {
(err?: E | null, result?: T): void;
}
export interface AsyncResultIterator<T, R, E = Error> {
(item: T, callback: AsyncResultCallback<R, E>): void;
}
export interface AsyncResultIteratorPromise<T, R> {
(item: T): Promise<R>;
}
declare function mapLimit<T, R, E = Error>(
arr: T[],
limit: number,
iterator: AsyncResultIteratorPromise<T, R> | AsyncResultIterator<T, R, E>,
): Promise<R[]>;
mapLimit([1,2,3], 3, async (n) => {
return n ** 2;
});
π Actual behavior
The type of n
in the mapLimit
callback is inferred as any
:
Parameter 'n' implicitly has an 'any' type. (7006)
π Expected behavior
I would expect the type of n
to be inferred as number
.
Additional information about the issue
This example is based on the types for the async
package:
Note that if the type for iterator
in mapLimit
is changed to either just AsyncResultIteratorPromise<T, R>
or just AsyncResultIterator<T, R, E>
(that is, no longer a union type), things work as expected and n
has type number
.
I found a very old discussion of what looks to be the same issue in the DefinitelyTyped
repo: DefinitelyTyped/DefinitelyTyped#24297. The issue described there is exactly the one I'm facing. One commenter claimed that things worked correctly, and another commenter claimed that changing the way that async
was imported had some effect? Neither of those sounds plausible to me.
I found some issues that may describe the same or a similar problem:
- Contextual parameter types failed to be provided based on filtering mapped typesΒ #56881
- No type inferrence of callback arguments inside a tuple union typeΒ #55632
- Callback parameter inference not working when part of an inferred tuple typeΒ #52047
- Improve inference in the presence of context-sensitive expressionsΒ #47599
However, my knowledge of TypeScript internals/terminology isn't strong enough to say for sure that this isn't a novel issue I'm facing. If this is in fact a duplicate, please close it as such and I'll add this example to the relevant issue. Thank you!