Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Compatibility with --experimental-strip-types #2812

Open
achingbrain opened this issue Nov 7, 2024 · 0 comments
Open

Compatibility with --experimental-strip-types #2812

achingbrain opened this issue Nov 7, 2024 · 0 comments

Comments

@achingbrain
Copy link
Member

achingbrain commented Nov 7, 2024

Node.js supports stripping TypeScript types with the --experimental-strip-types flag. This flag was introduced in 22.6.0 and will be turned on by default soon(tm) and backported to older versions.

It takes a TypeScript file like:

export function myFunction (name: string): string {
  return `hello ${name}`
}

And simply replaces any TypeScript specific syntax with whitespace:

export function myFunction (name        )         {
  return `hello ${name}`
}

This means Node.js can run TypeScript files without a transpilation/validation step, without depending on tsc or having to know about a project's special unique tsconfig.json setup, and also without needing to add source maps, since all the line numbers/locations are unchanged between the .ts source and the executed JavaScript.

There are a few caveats:

  1. Preprocessing .ts files like this only happens in the current project, not in the node_modules folder so projects will still need to ship transpiled .js files (this will likely apply to monorepo sibling packages too, they'll still have to be built before a dependant sibling can run their code)
  2. It'll only run on .ts files, so all import statements must import .ts
  3. Features that require code transforms by tsc require an additional --experimental-transform-types flag

For us only the last two things will cause headaches.

The replacement of .js with .ts will need a PR to aegir to enable the allowImportingTsExtensions tsconfig option and likely an upgrade to the typescript dependency to 5.7.x when it is available, after that it is a relatively simple find & replace operation.

For code that requires transpilation, we only have a few enums in the codebase - I don't think we use any other features that need it. Enabling the --experimental-transform-types flag will cause source maps to be generated which we may wish to avoid - we may be better of refactoring our enums to just be regular JS objects.

@achingbrain achingbrain added need/triage Needs initial labeling and prioritization exploration and removed need/triage Needs initial labeling and prioritization labels Nov 7, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant