- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.1k
Closed
Labels
Design NotesNotes from our design meetingsNotes from our design meetings
Description
Verbatim Import Syntax
- importsNotUsedAsValues- Default is remove
- Sometimes you don't want to elide the import- The module you're importing has a type, but also has side-effects.
- preservefixes this.- The named import is dropped, but the import statement is retained for side-effects.
 
 
 
- Default is 
- preserveValueImports- Default is false
 
- Default is 
- Wouldn't it be simpler to have a mode where whatever you write is what you get, and the only things that get dropped are typeimports?- So import { blah, type foo } from "module"->import { blah } from "module"
- So import { type foo } from "module"->import "module"
- Technically this mode already exists - when you combine importsNotUsedAsValues: preserveandpreserveValueImports: truewithisolatedModules: true.
 
- So 
- What's the const enum behavior?
- Seems like simplifying is good, and this is what we wanted to ship originally - but are we forgetting the original use-cases? Also, we would be sending our users a lot of confusion/mixed messages.
- Angular.js 1.x was a pretty big motivation.
- Error mode was possibly a mistake - trying to signal "this is an unnecessary value import."
- Maybe this should have been a lint rule.
 
 
- Angular.js 1.x was a pretty big motivation.
- There is positive feedback about deprecating the old options, providing a new one.
- Second part of this proposal prohibits ESM syntax when targeting other module systems.
- CJSish systems would need
- 
Importing import fs = require("fs"); 
- 
exports need to beexport = { /* some object*/ }
- 
Tradeoff - named imports in import {} = require(...)aren't supported.
- 
Anecdotally, issues in CJS/ESM interop in nodenext are horrible - the resolution works, but the types inferred from the interop are extremely confusing. 
 
- 
 
- CJSish systems would need
- We have consensus on the first part, not the second part being part of the same flag.
Require Literal Types to Have Value Overlap in Assignability with Enums
Today this is the situation in our main branch:
enum E {
    Foo = 1,
    Bar = 2,
    Baz = 4,
}
function f(e: E) {
    if (e === 7) { // disallowed
        // ...
    }
    e = 7; // allowed for some reason?
}- Tightened this up.
- Breaks a lot in our compiler because of enums not declaring an explicit 0-likeNonevalue.
- Having a computed enum member like enum E { Foo = Math.random() }allows it to be comparable to everything else.
- But strange that you can't compare but you can assign. Seems bad.
- New change require some overlap in the value domains when assigning.
Narrowing unknown-Originating {} Values with instanceof
function foo(x: unknown) {
    if (!!x && typeof x === "object" && "yadda" in x) {
        x.yadda
    //  ^?
    }
    if (!!x && x instanceof Object && "yadda" in x) {
        x.yadda
    //  ^?
    }
}- We think there are no issues in principle - but implementation consults the declared type which is inappropriate. You can end up with one of these unknowns in different ways
- Discussion should follow outside of the meeting.
Metadata
Metadata
Assignees
Labels
Design NotesNotes from our design meetingsNotes from our design meetings