-
-
Notifications
You must be signed in to change notification settings - Fork 1.2k
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
Plugin template scaffold generates package.json for easier publish #3548
Comments
How should we manage package.json? I was thinking generating one on build command, just like |
I'd rather let it be created on scaffolding time, and plugin author to manage further details on their own. Same as cargo / our plugin scaffolding does for It may be neat to try cli becomes all handlers for the feature set like build, metadata mgmt / publishing but that's something we can consider in a long run, moreover I'm not sure if that's something we are willing to support as core cli feature. The assumption for the plugin is people are well aware of npm's ecosystem as natually this is being used for node.js binding of swc ( |
I see, seems reasonable to me. |
I think a command to move/copy wasm files to the package directory would be enough. (Currently moving wasm using bash in monorepo is hard) |
I guess this won't be needed even? I have to double confirm though. Since plugin is a single pkg doesn't care about different platform / binaries, as long as package.json points correct entrypoint to binary path resolver should able to find it. This could be a bit cumbersome if someone wants absolute path to the wasm binary for the installed package, but also it's pretty much predictable so not a huge concern. I need to work on resolver part first to confirm this though. Will update both part. |
I was talking about swc-project/plugins#19, as I expect many companies to use a monorepo for their plugins. |
I may miss some points, so are you referring the case 1. monorepo 2. which they do not create separate npm packages but manually resolve paths to each output for their own? 1 should not be relavant regardless of output path, I can only think someone need manual resolve for the case of 2 and if they do not rely on any metadata from pkg.json or cargo.toml. |
I mean a monorepo with separate npm packages. Problem is that to publish an npm package, we should move the mv target/wasm32-wasi/release/swc_plugin_jest.wasm packages/jest
mv target/wasm32-wasi/release/swc_plugin_styled_components.wasm packages/styled_components and once per package, because the cargo package name may not match the directory name. |
Yes, I think this is the part I'm probably not getting at fully. I was under assumption pkg structure looks like this
(this is actually similar to some of repo I worked on) and it seems it's not the layout you're expecting? I'd like to collect some firm / real world usecases of how does layout works across actual users before we tweak something. There are various possible project structures afaik and I don't think we can predict all. We can start from obvious, simple approach first then add supporting some other usecases. |
I think it can be like {
"main": "my-swc-plugin.wasm",
"scripts": {
"pre-release": "cargo build --release && cp target/wasm32-wasi/release/my-swc-plugin.wasm .",
"publish":"npm publish"
},
"files":[
"my-swc-plugin.wasm",
],
// ...
} just put package.json next to cargo.toml |
Yeah, I'll do it for now. I forgot that |
I'm trying to understand: why we have to copy? I was thinking
This removes needs of redundant post / pre script hooks. |
Because the cargo target directory can be outside of the npm package directory. |
That means this copy
also won't work transparently, isn't it? at the moment of project creation, we don't know if |
Yeah I also think we can patch after collecting feedback. |
I'm not familier with
|
@RiESAEX I think it's fine, as the |
Yes it will, but that's quite common for other packages. Only difference is nested level. Peek rxjs for an example - https://unpkg.com/browse/rxjs@7.5.4/dist/cjs/ it's cjs dist output is dist/cjs/index. |
This closed issue has been automatically locked because it had no new activity for a month. If you are running into a similar issue, please create a new issue with the steps to reproduce. Thank you. |
Describe the feature
#3540 (comment)
When we create a plugin via template, we expect it'll be published as npm package in most cases. Having default package.json would be helpful.
We could do
For now I'm leaning on first approach, as said expect most of cases we expect plugin will be published as npm pkg and installed next to
@swc/core
.Babel plugin or link to the feature description
No response
Additional context
No response
The text was updated successfully, but these errors were encountered: