-
Notifications
You must be signed in to change notification settings - Fork 29
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
node_modules isn't cool anymore, what to do #29
Comments
I guess it's like doing the same thing over and over again, why yarn doesn't simply embed/use @verdaccio and support in their development instead. |
Hm, yeah. It seems like we'll need new heuristics. Sadly, it looks like PnP will fundamentally break the way this library works… Luckily, our fallback strategy of using |
Yeah, that's true. I have played around a bit with |
Yeah, test-runners and anything else that inject themselves before your app will break that method. We may need to just check for those cases and rely on require.main more heavily, though… |
FYI with PnP it should just be a matter of doing this: const pnp = process.versions.pnp
? require('pnpapi')
: null;
const appRoot = pnp
? pnp.getPackageInformation(pnp.topLevel).packageLocation
: null; |
This package seems to be checking for Would that work? Is it too simple/naive and doesn't work in some cases? |
Good suggestion @benface. I've played around with looking for package.json. It seems a bit less robust than node_modules in my testing. For example, if you are in a path inside node_modules, you might assume your current directory is the root because it has a package.json file when really you want the parent directory (the one that has node_modules in it). For example:
|
Oh, ok so it wouldn't work for task runners / test frameworks because those run from their own directory? |
Note that the Yarn cache is (in most cases for now) outside of the project folder. So if you simply traverse upwards until you find the top-most For a perfect integration, I recommend my snippet above 🙂 |
Another thing to consider is that
I'm disappointed. I thought |
Look here: |
Thanks @arcanis — 2.2.0 adds pnp support. |
I just read about yarn's new plug n play install and it looks like npm might be pursuing something similar.
Since one of the main heuristics used here is the presence of node_modules, I could see this breaking if these new module resolution systems gain traction.
The text was updated successfully, but these errors were encountered: