-
-
Notifications
You must be signed in to change notification settings - Fork 2.9k
Open
Labels
accepting prsGo ahead, send a pull request that resolves this issueGo ahead, send a pull request that resolves this issuebugSomething isn't workingSomething isn't workingpackage: eslint-pluginIssues related to @typescript-eslint/eslint-pluginIssues related to @typescript-eslint/eslint-plugin
Description
Before You File a Bug Report Please Confirm You Have Done The Following...
- I have tried restarting my IDE and the issue persists.
- I have updated to the latest version of the packages.
- I have searched for related issues and found none that matched my issue.
- I have read the FAQ and my problem is not listed.
Playground Link
Repro Code
declare const a: { b: () => number; c: number; } | null;
a === null || a.b() !== a.c;ESLint Config
{
"rules": {
"@typescript-eslint/prefer-optional-chain": "warn"
}
}tsconfig
Expected Result
No warning.
Actual Result
An incorrect warning is emitted: "Prefer using an optional chain expression instead, as it's more concise and easier to read".
It suggests an autofix to a.b() !== a?.c which is not the same expression and creates a type error.
Additional Info
Seems to be a similar issue to #11700.
Metadata
Metadata
Assignees
Labels
accepting prsGo ahead, send a pull request that resolves this issueGo ahead, send a pull request that resolves this issuebugSomething isn't workingSomething isn't workingpackage: eslint-pluginIssues related to @typescript-eslint/eslint-pluginIssues related to @typescript-eslint/eslint-plugin
{ "compilerOptions": { "strictNullChecks": true } }