Comments (5)
The generated function has SignatureFlags.IsUntypedSignatureInJSFile
assigned to it. So its min argument count gets computed as 0. Based on that calls without any arguments are allowed as the provided number of arguments (0 here) satisfies the min argument count.
Currently, this flag is not assigned to signatures coming from JS files when the function has either @param
tag or when the function itself is typed using @type
. For that reason, you end with the same problem when the function is contextually-typed using @satisfies
:
/** @satisfies {(arg: string) => void} */
const func = function func(param) { };
func() // oops
Related(ish) case to the @satisfies
can be found here
from typescript.
@kungfooman That's because the parameter itself is, in fact, optional:
function func(/** @type {string} */ param) {}
/**
* @typedef {typeof func} Func
* @typedef {Func extends (...args: infer P) => any ? P : never} FuncParam
*/
func(); // not an error
I don't know why it's treated as optional, but the inference result is correct.
from typescript.
Funny behaviour, and why does it work somewhat better in only one file: Playground
function func(/** @type {string} */ param) {}
/**
* @typedef {typeof func} Func
* @typedef {Func extends (...args: infer P) => any ? P : never} FuncParam
*/
Result: type FuncParam = [param?: string]
(it shouldn't be optional)
from typescript.
I don't know why it's treated as optional, but the inference result is correct.
If we turn on strictNullChecks
it's suddenly never
again 😅
IMO it should only ever be considered optional if we use the Google Closure syntax:
function func(/** @type {string=} */ param) {}
(=
after string
)
from typescript.
Thank you for the playground links! Reproduces the problem nicely.
In the non-optional cases above, the tooltip hover still thinks that func
is a function with a non-optional (param: string)
parameter. Which seems correct. Later still having param
be optional seems weird to me too, but maybe that's how optionality works 🤷
In addition, both the infer
and func()
remain inconsistent with how @param
works (which is how I expect, in fact):
/** @param {string} param */
function func(param) {}
func() // error
and FuncParam
as above is [param: string]
. Playground link
from typescript.
Related Issues (20)
- Method `concat` has wrong typization HOT 4
- Invalid type inference for optional chaining operator when nullish check is extracted to `const` varaiable HOT 2
- Inline type annotations for destructured properties using angle bracket syntax HOT 3
- Enum generic does not restrict union of possible objects where enum is defined HOT 9
- `const wrong = () => (1 < 3) as true // type: () => true` this should be an error. HOT 9
- "Organize Imports" should adjust specifiers based on preferences HOT 1
- TS 5.4.5: Return type for performance.getEntriesByType is inaccurate
- Lose generic when spreading `T | undefined` where T is a generic object type HOT 3
- [isolatedDeclarations][5.5] Optional parameter annotated with imported type has isolatedDeclarations error HOT 2
- Missing content in documentation FAQ section HOT 3
- Make property decorator fabrics share generics with corresponding methods HOT 2
- Generic type parameter not inferring properly HOT 3
- JSDoc `@private` on constructor without parameters is omitted in declaration files
- [API] Ability to check if a parameter is being passed to const type parameter
- Improve support for internal packages by resolving path aliases
- CommonJS globals permitted for ES module builds with no compiler error. HOT 4
- -
- Type predicate doesn't narrow down function overload (but assertion works) HOT 8
- Recursive type strangely resolved to never HOT 3
- [5.5 beta] package.json `"type"` lookup in non-Node.js `module` is unexpected HOT 10
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from typescript.