Skip to content

[ID-Prep] Preserve type nodes from type assertions in declarationsΒ #57587

Closed
@dragomirtitian

Description

@dragomirtitian

The [ID-prep] set of issues aligns Declaration Emit with the forthcoming Isolated Declarations feature.

πŸ” Search Terms

declaration emit preserve types assertions

βœ… Viability Checklist

⭐ Suggestion

Preserve types from type assertions when emitting declarations.

πŸ“ƒ Motivating Example

// index.ts
type P = {} & { foo: boolean };
export let p = null as P

// index-current.d.ts
export declare let p: {
    foo: boolean;
};

// index-proposed.d.ts
type P = {} & { foo: boolean };
export declare let p: P;

πŸ’» Use Cases

  1. What do you want to use this for?
    This would improvement would can bring us closer to external declaration emitters being a reality.
  2. What shortcomings exist with current approaches?
    An external tool can extract the type from the assertion, but then they would have different declarations. It would be great if, where possible, typescript would also preserve types as written.
  3. What workarounds are you using in the meantime?
    We could force users to always specify the type even when it's obvious from the assertion, but this makes for very frustrating DX

Metadata

Metadata

Assignees

No one assigned

    Labels

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions