|
| 1 | +=== tests/cases/compiler/switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts === |
| 2 | +export const narrowToLiterals = (str: string) => { |
| 3 | +>narrowToLiterals : Symbol(narrowToLiterals, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 0, 12)) |
| 4 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 0, 33)) |
| 5 | + |
| 6 | + switch (str) { |
| 7 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 0, 33)) |
| 8 | + |
| 9 | + case 'abc': { |
| 10 | + // inferred type as `abc` |
| 11 | + return str; |
| 12 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 0, 33)) |
| 13 | + } |
| 14 | + default: |
| 15 | + return 'defaultValue'; |
| 16 | + } |
| 17 | + }; |
| 18 | + |
| 19 | + export const narrowToString = (str: string, someOtherStr: string) => { |
| 20 | +>narrowToString : Symbol(narrowToString, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 11, 14)) |
| 21 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 11, 33)) |
| 22 | +>someOtherStr : Symbol(someOtherStr, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 11, 45)) |
| 23 | + |
| 24 | + switch (str) { |
| 25 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 11, 33)) |
| 26 | + |
| 27 | + case 'abc': { |
| 28 | + // inferred type should be `abc` |
| 29 | + return str; |
| 30 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 11, 33)) |
| 31 | + } |
| 32 | + case someOtherStr: { |
| 33 | +>someOtherStr : Symbol(someOtherStr, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 11, 45)) |
| 34 | + |
| 35 | + // `string` |
| 36 | + return str; |
| 37 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 11, 33)) |
| 38 | + } |
| 39 | + default: |
| 40 | + return 'defaultValue'; |
| 41 | + } |
| 42 | + }; |
| 43 | + |
| 44 | + export const narrowToStringOrNumber = (str: string | number, someNumber: number) => { |
| 45 | +>narrowToStringOrNumber : Symbol(narrowToStringOrNumber, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 26, 14)) |
| 46 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 26, 41)) |
| 47 | +>someNumber : Symbol(someNumber, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 26, 62)) |
| 48 | + |
| 49 | + switch (str) { |
| 50 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 26, 41)) |
| 51 | + |
| 52 | + case 'abc': { |
| 53 | + // inferred type should be `abc` |
| 54 | + return str; |
| 55 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 26, 41)) |
| 56 | + } |
| 57 | + case someNumber: { |
| 58 | +>someNumber : Symbol(someNumber, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 26, 62)) |
| 59 | + |
| 60 | + // inferred type should be `number` |
| 61 | + return str; |
| 62 | +>str : Symbol(str, Decl(switchCaseNarrowsMatchingClausesEvenWhenNonMatchingClausesExist.ts, 26, 41)) |
| 63 | + } |
| 64 | + default: |
| 65 | + return 'defaultValue'; |
| 66 | + } |
| 67 | + }; |
0 commit comments