Comments (5)
Yeah, there's an issue here. This is a simplified repro:
type Foo = { kind: "a" | "b", value: number } | { kind: "a", value: undefined } | { kind: "b", value: undefined };
function test(obj: { kind: "a" | "b", value: number | undefined }) {
let x1: Foo = obj; // Ok
let x2: Foo = { kind: obj.kind, value: obj.value }; // Error, but shouldn't be
}
Above, our type discrimination logic reduces type Foo
to just { kind: "a" | "b", value: number }
because it is the only constituent of the union to which the type of obj.kind
is assignable. This unidirectional assignability check is a little too selective. We should really be checking whether there is any overlap between the discriminant type in the object literal and the discriminant type in the target--in other words, the "a" | "b"
type from the object literal shouldn't eliminate the "a"
and "b"
choices in the target. It's a pretty simple fix. I'll put up a PR.
from typescript.
Why isn't TypeB
written this way?
type TypeB = {
kind: MyEnum.B;
} & ({ id?: number | undefined; });
from typescript.
Why isn't
TypeB
written this way?type TypeB = { kind: MyEnum.B; } & ({ id?: number | undefined; });
As mentioned above, in the real world example were we encounter this, the "id: number" type branch can have additional fields. While when not providing an id (or undefined), you should not provide these. E.g.
type TypeB = {
kind: MyEnum.B;
}
& (
{
id?: undefined;
}
|
{
id: number;
commentId? number;
}
);
from typescript.
You canβt actually prevent a commentId
from appearing in the id?: undefined
case without exact types - see #12936
from typescript.
Bisects to #53709
from typescript.
Related Issues (20)
- Fail to infer Indexed access to the intersection type when it includes an union derived from a generic input HOT 1
- Generators can return undefined values HOT 1
- Inconsistent behaviour of `-?` HOT 4
- Function parameter type inference error HOT 4
- FETCH / Give The json() Function The Power To Use Generic Type HOT 1
- TS 5.6 requires composite projects with noEmit to have fully accessible types, unlike 5.5 HOT 6
- useVsCodeWatcher interferes with updating typescript @aliased imports paths on file or folder moves HOT 2
- Switch typeguard for single case HOT 2
- `AutoFill` is missing a few valid tokens for the `autocomplete` attribute HOT 2
- Cannot read properties of undefined (reading 'charCount') HOT 1
- `tsBuildInfoFile` compiler option should be allowed without `incremental` or `composite` in Typescript versions `>5.6`
- super() typed as returning void HOT 2
- Move to File does not generate imports in the same way that autoimports does
- Move To File makes extra spaces when moving jsdoc comments
- (JSDoc, JavaScript) Imported class types by require() are unresolved HOT 1
- Type all exported members according to some interface HOT 2
- JSDoc typed function comments inside functions
- Error when accessing CSS property value using kebab case in `CSSStyleDeclaration` object HOT 1
- Type 'never' incorrectly inferred for mixed primitive type properties assignment with strictNullChecks disabled HOT 2
- Array of object unions not working as expected HOT 2
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.