Skip to content

Commit

Permalink
No did-you-mean-to-call error on casts Part 2 (#42779)
Browse files Browse the repository at this point in the history
* No did-you-mean-to-call error on casts

I chose to do the ad-hoc check rather than yet another tree walk.

1. It's faster to run and easier to read.
2. This error came from looking at real code. It happened twice, so I
think the best estimate for other uses that happened zero times is in
fact zero.
3. I couldn't think of other places to put the cast, given the
restrictions on `testedNode` just before the new code.

* Skip parentheses
  • Loading branch information
sandersn authored Feb 12, 2021
1 parent f2bcb21 commit 5deb676
Show file tree
Hide file tree
Showing 5 changed files with 46 additions and 3 deletions.
4 changes: 1 addition & 3 deletions src/compiler/checker.ts
Original file line number Diff line number Diff line change
Expand Up @@ -34547,9 +34547,7 @@ namespace ts {
: isBinaryExpression(location) && isIdentifier(location.right) ? location.right
: undefined;
const isPropertyExpressionCast = isPropertyAccessExpression(location)
&& isParenthesizedExpression(location.expression)
&& isAssertionExpression(location.expression.expression);

&& isAssertionExpression(skipParentheses(location.expression));
if (!testedNode || isPropertyExpressionCast) {
return;
}
Expand Down
10 changes: 10 additions & 0 deletions tests/baselines/reference/truthinessCallExpressionCoercion3.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,11 @@ function f(result: unknown) {
return result
}
}
function g(result: unknown) {
if (((result as I)).always) {
return result
}
}


//// [truthinessCallExpressionCoercion3.js]
Expand All @@ -17,3 +22,8 @@ function f(result) {
return result;
}
}
function g(result) {
if (result.always) {
return result;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,18 @@ function f(result: unknown) {
>result : Symbol(result, Decl(truthinessCallExpressionCoercion3.ts, 5, 11))
}
}
function g(result: unknown) {
>g : Symbol(g, Decl(truthinessCallExpressionCoercion3.ts, 9, 1))
>result : Symbol(result, Decl(truthinessCallExpressionCoercion3.ts, 10, 11))

if (((result as I)).always) {
>((result as I)).always : Symbol(I.always, Decl(truthinessCallExpressionCoercion3.ts, 1, 13))
>result : Symbol(result, Decl(truthinessCallExpressionCoercion3.ts, 10, 11))
>I : Symbol(I, Decl(truthinessCallExpressionCoercion3.ts, 0, 0))
>always : Symbol(I.always, Decl(truthinessCallExpressionCoercion3.ts, 1, 13))

return result
>result : Symbol(result, Decl(truthinessCallExpressionCoercion3.ts, 10, 11))
}
}

16 changes: 16 additions & 0 deletions tests/baselines/reference/truthinessCallExpressionCoercion3.types
Original file line number Diff line number Diff line change
Expand Up @@ -20,4 +20,20 @@ function f(result: unknown) {
>result : unknown
}
}
function g(result: unknown) {
>g : (result: unknown) => unknown
>result : unknown

if (((result as I)).always) {
>((result as I)).always : () => void
>((result as I)) : I
>(result as I) : I
>result as I : I
>result : unknown
>always : () => void

return result
>result : unknown
}
}

5 changes: 5 additions & 0 deletions tests/cases/compiler/truthinessCallExpressionCoercion3.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,8 @@ function f(result: unknown) {
return result
}
}
function g(result: unknown) {
if (((result as I)).always) {
return result
}
}

0 comments on commit 5deb676

Please sign in to comment.