Open
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 maybe: 'a' | 'b';
declare const fallback: ['c'];
declare function createValues(): string[] | undefined;
function computeStrings(): string[] {
const intermediate = maybe === 'a' && createValues();
const value = intermediate || fallback;
return value;
}
ESLint Config
module.exports = {
"rules": {
"@typescript-eslint/prefer-nullish-coalescing": "error"
}
}
tsconfig
Expected Result
intermediate
is false | string[] | undefined
and its parent function returns string[]
. The ||
is the right operator to use to make value
a string[]
, not a string[] | false
.
Actual Result
Prefer using nullish coalescing operator (`??`) instead of a logical or (`||`), as it is a safer operator. 8:30 - 8:32
Additional Info
Related: #7055, #10356, and probably others, searching gives a lot of false positive results...
#10356 notes that this gets suggested a good amount. I personally was surprised to re-discover that the default behavior of the rule is to report in a way that is sometimes incorrect/unnecessary.
Proposal: I think we should switch the rule to ignore false | undefined | (always-truthy)
s by default.
💖