Replies: 1 comment
-
Clarification just in case, this RFC does not discuss if |
Beta Was this translation helpful? Give feedback.
0 replies
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
Summary
This RFC proposes a migration for JS-based plugins when
@swc/core
no longer offers support, by creating a userland wasm plugin that runs a JS visitor with limited runtime support.Motivation
After introducing a new plugin system based on wasm / rust native codes, core team has been seeking for a path for the legacy, JS plugin support. The current architecture may not be able to address the known limitations, so the core team is considering consolidating efforts to support a new plugin system with wasm instead of having 2 different plugin systems, which could cause fragmentation.
So far as we aware, there aren't a lot of SWC plugins written in JS and hope this workaround provides time to migrate those plugins into new one once after core does not support to running JS visitors.
Detailed design
Introducing user-land wasm plugin can run JS visitor
The core of this proposal is moving JS visitor execution to the userland. Instead of relying on host (node.js for
@swc/core
, non-exist for any other platforms likeswcx
or@swc/wasm
) runtime that executes JS, a wasm plugin can embed a modest JS interpreter. Plugin internally interops between seralized AST to the JSON payload that JS visitor accepts.Initial implementation to the plugin can be found at swc-plugin-js-transformer, currently able to execute the simplest plugins with below examples:
Calling plugin is pretty much similar to any other swc plugins. Difference is the plugin is a thin layer to the JS visitor, that only executes & interop AST back and forth.
As example illustrates there are some differences between usual JS implementation to the visitor supplied to the plugin. There's no import to base class, as well as no exports. The plugin is sandboxed and does not support module resolution, so
plugin-js-transformer
adds the base class and executes automatically.@swc/core@1.x
warns plugin deprecationOnce after plugin releases,
@swc/core
will emit a warning message if configuration specifics plugin.@swc/core
will emit a warning message if the configuration specifies a plugin, but this is not a hard failure.JS-transformer plugin owns
@swc/core/visitor
Instead of depending on
@swc/core/visitor
, js transformer plugin owns JS visitor directly. This may not remove the existing visitor from@swc/core
yet to avoid breaking changes.@swc/core@2
release with breaking changes@swc/core@2
removes configuration option for the existing plugin, as well as@swc/core/visitor
implementation.Deprecate / archive js-transformer plugin
After some time period, gracefully archive js transformer plugin.
Drawbacks
This is soft landing plan, but still it doesn't provide 100% compatibility. Notably, since plugin will run its own JS engine, it is not identical to the node.js runtime. There won't be equivalent JS module support, and most of JS runtime features will not be available as well. It may possible to stopgap some important blockers for the JS visitor though.
Alternatives
@swc/core@2
release.Unresolved questions
References (if exists)
Beta Was this translation helpful? Give feedback.
All reactions