Skip to content
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

Use .nvmrc with n #547

Closed
spences10 opened this issue Jan 9, 2019 · 10 comments
Closed

Use .nvmrc with n #547

spences10 opened this issue Jan 9, 2019 · 10 comments

Comments

@spences10
Copy link

Hi,

Is there a way to use an .nvmrc file with n?

@gussyboy touched on it in another issue #423 but @JohnRGee seemed to be confused by the comment.

So, so there is no confusion around what I am requesting, I would like to know if it is possible to configure a project that uses node, to use a specific version of node. This sort of behaviour is possible *(as I understand it) with a .nvmrc file.

Is there a way to do this if I'm an n user and the rest of my team are nvm users.

Thanks

@spences10 spences10 changed the title Use .nvmrc with n Use .nvmrc with n Jan 9, 2019
@shadowspawn
Copy link
Collaborator

shadowspawn commented Jan 10, 2019

I can see a limited but simple way to use .nvmrc with n, assuming version number specified in compatible way::

alias ni='n $(cat .nvmrc)'
alias nu='n use $(cat .nvmrc)'

@shadowspawn
Copy link
Collaborator

shadowspawn commented Jan 10, 2019

Configuring a project that uses node, to use a specific version of node, is complex. One option more in that spirit is: https://www.npmjs.com/package/node

@spences10
Copy link
Author

Thanks, I'll try, closing this for now.

@shadowspawn
Copy link
Collaborator

shadowspawn commented Apr 11, 2020

On a related note, I have added support for reading a .node-version file in n 6.5.0.
#616

Edit: changed to .n-node-version file in n 6.5.1

@adrianmcli
Copy link

adrianmcli commented Apr 25, 2020

@shadowspawn I appreciate the new feature, but there are many existing projects with .nvmrc files. I know that a non-tool specific dotfile would be more ideal. But to make it easy for people to transition from NVM to n, do you think maybe we can add the ability for n to be configured to read from .nvmrc as well?

Another convention I would like n to support is engines.node. It's just so commonly used that I feel like n is missing out by not supporting it (even if it has to be behind a feature-flag).

@shadowspawn
Copy link
Collaborator

shadowspawn commented Apr 25, 2020

  1. .nvmrc is a propriatory configuration file for a specific node version manager. I don't think many people are going to transition from nvm to n, but a situation I am interested in is teams which may be using both and possibly other tools too. What I would rather support for cross-tool compatibility is .node-version, but I got some pushback on adopting that before it was a standard (not from a user).

nodejs/version-management#13

  1. engines.node is a challenge because n is implemented as a shell script, and parsing json is non-trivial (I assume you are referring to the engines field in package.json). However, I am open to the idea. I suggest you open new issues for the ideas you care about to see if there is support for them from other users.

@adrianmcli
Copy link

@shadowspawn Thanks for the reply.

  1. I understand the push for .node-version, but the fact is that .nvmrc is vastly more popular and as an avid n user, I (and many others) have run into problems when getting onboarded to projects with .nvmrc. Of course it's not something I couldn't deal with manually, but it's a huge hassle especially if you are switching in and out of projects on a daily basis.

    I understand the proprietary nature of .nvmrc might make it sound odd to support, but I don't see a downside to supporting something proprietary. For example, Google Docs support exporting of Microsoft Word files even as a direct competitor. And numerous non-Adobe graphic design software support reading and writing Adobe Photoshop and Illustrator files.

  2. Understood, I will create a new issue for this specifically.

@shadowspawn
Copy link
Collaborator

shadowspawn commented Apr 25, 2020

  1. To be clear, I am not completely against limited support for .nvmrc if there is demand for it. Since auto is an explicit opt-in target, I am ok with looking in multiple locations for the desired version and even "having a go".

@MarkLyck
Copy link

Please add support for .nvmrc 🙏

@shadowspawn
Copy link
Collaborator

New issues have been opened for:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants