-
-
Notifications
You must be signed in to change notification settings - Fork 23
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
Yarn PnP #53
Comments
|
Personally, I don't think this resolver should support Yarn PnP |
Please link your project with yarn pnp setup here for the possibility of reopening this issue.
We can provide yarn pnp support with a feature flag. Supporting yarn pnp is a big maintenance burden for us, but I'm happy to add another maintainer who is willing to implement, maintain and triage issues related with yarn pnp, since triaging a resolution error usually takes an hour at least. If I get a bug report that looks similar to the 120+ open issues in yarn relating to pnp, how much time should I spend on triaging them? https://github.com/search?q=repo%3Ayarnpkg%2Fberry+pnp++&type=issues&state=open |
Probably the biggest and most useful reference for Yarn monorepo would be Yarn itself: https://github.com/yarnpkg/berry AFAIK Yarn (berry) is still used well on corporate projects due to its highly configurable nature but hasn't seen wide usage outside of it. I'd love to help this issue but I think I should look more deep into oxc before promising anything ;) |
Note that I implemented a PnP resolver in Rust as a package: https://github.com/arcanis/pnp-rust; I had a prototype integrating it with Parcel and the work was quite minimal. So if you're interested, I'm more than happy to help integrate the
The repo issues aren't the right metric - rather, the interesting one is Esbuild, which has natively supported PnP for a while. There's been ~60 issues in ~3 years, most of them closed. In your case it'd be lower if you leveraged the |
Thank you @arcanis. The Let's collaborate and integrate. Just ping me if you need anything from me. |
The Rust side is complete. For future reference:
Rust option is Line 122 in 5310589
Feature is Lines 105 to 106 in 5310589
|
Now I need a collaborator to help me test this in their tool. |
I'm willing to test, but I'm not a contributor. I am looking to set the resolution for |
* chore: update lockfiles * Release v1.9.4 * feat(napi): expose module type info in ResolveResult (#223) * chore: update devDependencies * Release v1.10.0 * fix(napi): update buggy NAPI-RS versions (#225) fix(napi): update buggy @napi-rs/cli * ci: all `--all-features` to various commands * chore(deps): update crate-ci/typos action to v1.23.2 * chore(deps): update rust crate napi to 3.0.0-alpha * chore(deps): update rust crates * ci: add x86_64-unknown-freebsd target (#226) * fix: resolve module `ipaddr.js` correctly when `extensionAlias` is provided (#228) closes #227 * Release v1.10.1 * ci: fix FreeBSD build (#230) * ci: add `needs` check in build-freebsd * ci: publish needs build-freebsd (#232) * Release v1.10.2 * feat: Yarn PnP (#217) Part of oxc-project/oxc-resolver#53 * chore(deps): update rust crate napi-derive to 3.0.0-alpha * chore(deps): update rust crates * chore(deps): fix the lock --------- Co-authored-by: Boshen <[email protected]> Co-authored-by: LongYinan <[email protected]> Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> Co-authored-by: Maël Nison <[email protected]>
This is now behind a feature flag Lines 105 to 106 in 509dc00
Feel free to create an issue for integration. |
Hi @Boshen, thanks for the amazing work together with @arcanis! What is currently missing to enable the yarn_pnp feature? I am working on porting a project which uses swc to pnpm plug-n-play (pnp). The app is at
|
Yan PnP can be enabled via features Line 94 in 2378375
|
@ematipico Thanks for pointing that out. I managed to enable the feature now, but I am unable to build the napi module as it throws the following error when running
Is integration into the napi module missing? I think this is required to make this work in swc. |
Note that I made some updates in the rspack fork of oxc-resolver, which I still need to backport here (those are mostly API changes, see here for details). I hope to send a PR sometime in the next couple of weeks! |
https://yarnpkg.com/features/pnp
Please +1 and link your public repository if you're using yarn pnp.
The text was updated successfully, but these errors were encountered: