-
Notifications
You must be signed in to change notification settings - Fork 12.6k
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
Add import assertions to type only imports and import types to force the resolution mode of the specifier #47807
Conversation
tests/baselines/reference/nodeModulesImportTypeModeDeclarationEmitErrors1(module=node12).js
Outdated
Show resolved
Hide resolved
FYI the PR description claims "Fixes #47807", but this PR has number 47807 |
45e3c3d
to
355ae11
Compare
355ae11
to
476dc6d
Compare
This feels really wrong 😕 The proposal explicitly says that import assertions must not affect how a module is evaluated or resolved:
In other words, if both these two imports succeed they must resolve/evaluate the same file: import { A } from "pkg" assert { "resolution-mode": "require" };
import { A } from "pkg" assert { "resolution-mode": "import" }; The imports assertions proposal even mentions a possible follow-up proposal that would allow what you need, but it would be a separate proposal (with likely different syntax). I know that this PR is only about |
https://github.com/tc39/proposal-import-reflection is probably what you need, even if it's not clear yet if it's also meant to affect resolution. |
These don't affect runtime and are type-only (your example above doesn't work - you have to say |
@weswigham This is wrong, we're using the There are plenty of other options that make sense without completely new and ts-only syntax e.g. // comment directive, nothing new
// @ts-resolution=require
import type { RequireInterface } from "pkg"; // https://github.com/tc39/proposal-import-reflection
import type { RequireInterface } from "pkg" as "resolution=require"; // dangles off the already ts-only part
import type(resolution=require) { RequireInterface } from "pkg"; Please consider reverting this change. |
I've already seen a lot of people confused by import assertions and what they could be used for in runtimes, specifically conflating them with what's proposed in https://github.com/tc39/proposal-import-reflection. It would be a shame to see TS fostering that misconception, or perhaps falling victim to it. |
Why is it: assert {"resolution-mode": "import"}; (requiring quotes), and not: assert {resolutionMode: "import"}; ? |
Consistency with the triple-slash reference form and a bit of extra syntax encumbrance to make you pause and think if you really need to use it. :) |
Would this also hypothetically help solve the issue found at #46213 ? If so, how soon do you think this feature will graduate from nightly? |
This PR adds support for a TS-specific assertion on type-only imports and on import type nodes which forces the resolver into either
require
orimport
resolution mode, allowing access to types which the containing file's default mode would normally make difficult or impossible to access. They look like this:This is essentially a continuation of #47732 that allows resolver configurability for more kinds of type-based imports. Since it's included in this PR, it's probably best to go and review & merge that first.
Fixes #47338 by allowing the types of an esm package to be fetched in a cjs file via these modal imports.
Fixes #47248