Jak skonfigurować moją powłokę tak, aby nvm use
uruchamiała się automatycznie za każdym razem, gdy w katalogu znajduje się plik .nvmrc i używać najnowszej wersji lub globalnej konfiguracji, gdy nie ma pliku .nvmrc?
Jak skonfigurować moją powłokę tak, aby nvm use
uruchamiała się automatycznie za każdym razem, gdy w katalogu znajduje się plik .nvmrc i używać najnowszej wersji lub globalnej konfiguracji, gdy nie ma pliku .nvmrc?
Odpowiedzi:
Jeśli używasz zsh (z powłoki):
Wywołanie „nvm use” automatycznie w katalogu z plikiem .nvmrc
Umieść to w swoim $ HOME / .zshrc, aby wywołać nvm use automatycznie za każdym razem, gdy wejdziesz do katalogu zawierającego plik .nvmrc z ciągiem informującym nvm, którego węzła użyć:
# place this after nvm initialization!
autoload -U add-zsh-hook
load-nvmrc() {
local node_version="$(nvm version)"
local nvmrc_path="$(nvm_find_nvmrc)"
if [ -n "$nvmrc_path" ]; then
local nvmrc_node_version=$(nvm version "$(cat "${nvmrc_path}")")
if [ "$nvmrc_node_version" = "N/A" ]; then
nvm install
elif [ "$nvmrc_node_version" != "$node_version" ]; then
nvm use
fi
elif [ "$node_version" != "$(nvm version default)" ]; then
echo "Reverting to nvm default version"
nvm use default
fi
}
add-zsh-hook chpwd load-nvmrc
load-nvmrc
Więcej informacji: https://github.com/creationix/nvm#zsh
cd
, ponieważ jest uruchamiane za każdym razem, gdy zmieniasz katalog. Dodałem [[ -a .nvmrc ]] || return
do pierwszej linii load-nvmrc (), co znacznie poprawiło jego wydajność
.nvmrc
katalogów nadrzędnych, a także nie wróci do node
wersji domyślnej, gdy wyjdziesz cd
z katalogu projektu.
Doskonała odpowiedź od @devius .
Po prostu rozszerzyłem go, aby mógł powrócić do wersji domyślnej, gdy opuszczam katalog z .nvmrc
innym bez niego.
~/.bashrc
:
#
# Run 'nvm use' automatically every time there's
# a .nvmrc file in the directory. Also, revert to default
# version when entering a directory without .nvmrc
#
enter_directory() {
if [[ $PWD == $PREV_PWD ]]; then
return
fi
PREV_PWD=$PWD
if [[ -f ".nvmrc" ]]; then
nvm use
NVM_DIRTY=true
elif [[ $NVM_DIRTY = true ]]; then
nvm use default
NVM_DIRTY=false
fi
}
export PROMPT_COMMAND=enter_directory
node v.0.0 (64-bit) is not installed.
systemie Windows zwraca to, mimo że plik .nvmrc ma 9.3
.
VERSION=$(cat .nvmrc); nvm use $VERSION
Właśnie dowiedziałem się o automatycznym przełączaniu wersji dla Node.js https://github.com/wbyoung/avn , możesz tego użyć.
Możesz również śledzić ten wątek https://github.com/creationix/nvm/issues/110
Ta odpowiedź pochodzi z oficjalnej dokumentacji NVM .
Na końcu swojego $HOME/.bashrc
:
find-up () {
path=$(pwd)
while [[ "$path" != "" && ! -e "$path/$1" ]]; do
path=${path%/*}
done
echo "$path"
}
cdnvm(){
cd "$@";
nvm_path=$(find-up .nvmrc | tr -d '[:space:]')
# If there are no .nvmrc file, use the default nvm version
if [[ ! $nvm_path = *[^[:space:]]* ]]; then
declare default_version;
default_version=$(nvm version default);
# If there is no default version, set it to `node`
# This will use the latest version on your machine
if [[ $default_version == "N/A" ]]; then
nvm alias default node;
default_version=$(nvm version default);
fi
# If the current version is not the default version, set it to use the default version
if [[ $(nvm current) != "$default_version" ]]; then
nvm use default;
fi
elif [[ -s $nvm_path/.nvmrc && -r $nvm_path/.nvmrc ]]; then
declare nvm_version
nvm_version=$(<"$nvm_path"/.nvmrc)
# Add the `v` suffix if it does not exists in the .nvmrc file
if [[ $nvm_version != v* ]]; then
nvm_version="v""$nvm_version"
fi
# If it is not already installed, install it
if [[ $(nvm ls "$nvm_version" | tr -d '[:space:]') == "N/A" ]]; then
nvm install "$nvm_version";
fi
if [[ $(nvm current) != "$nvm_version" ]]; then
nvm use "$nvm_version";
fi
fi
}
alias cd='cdnvm'
To poprawa w stosunku do:
avn
)Ten alias przeszukałby „w górę” z bieżącego katalogu w celu wykrycia .nvmrc
pliku. Jeśli ją znajdzie, przełączy się na tę wersję; jeśli nie, użyje wersji domyślnej.
cd
nie jest czymś, co zwykle robisz w dużych partiach, więc nie sądzę, że ma to znaczenie, chyba że opóźnienie jest zauważalne dla człowieka.
Wypróbowałem wiele rozwiązań i nic nie działało tak, jak chciałem, więc napisałem własne:
Funkcja ZSH do automatycznego przełączania na poprawną wersję węzła
O ile wiem, jest to jedyny, który spełnia wszystkie poniższe kryteria:
.nvmrc
(tak jak nvm use
);.nvmrc
format;.nvmrc
,default
jeśli nie ma .nvmrc
nigdzie na drzewie;Jeszcze inne rozwiązanie wykorzystujące direnv . Direnv jest dostarczany z systemem OS X i wieloma dystrybucjami, więc nie jest wymagana instalacja.
Dodaj te dwie linie do swojego .zshenv lub .bash_profile w zależności od używanej powłoki:
export NVM_DIR="$HOME/.nvm" # You probably have this line already
export NODE_VERSIONS="${NVM_DIR}/versions/node"
export NODE_VERSION_PREFIX="v"
Dodaj plik .envrc do katalogu głównego projektu z zawartością
set -e
use node
Wreszcie cd do swojego katalogu. (Nie zapomnij o źródle .zshenv)
direnv poprosi Cię o zezwolenie na załadowanie config. Wpisz direnv allow
i voila!
Zauważ, że direnv nie obsługuje wymyślnych konstrukcji, takich jak lts/*
.nvrmc. Z drugiej strony, direnv obsługuje wiele środowisk wykonawczych, takich jak node, php, go, pyhton, ruby itp., Co pozwala nam używać jednego narzędzia do rozwiązywania problemów ze ścieżkami.
Rozszerzając odpowiedź @Adriano P , zaproponowałbym tę wersję, która jest mniej ogólna (działa tylko wtedy, gdy .nvmrc
jest ustawiona w katalogu głównym repozytorium git ), ale działa w przypadkach, gdy przechodzimy do innego miejsca w projekcie niż jego katalog główny:
_enter_dir() {
local git_root
git_root=$(git rev-parse --show-toplevel 2>/dev/null)
if [[ "$git_root" == "$PREV_PWD" ]]; then
return
elif [[ -n "$git_root" && -f "$git_root/.nvmrc" ]]; then
nvm use
NVM_DIRTY=1
elif [[ "$NVM_DIRTY" == 1 ]]; then
nvm use default
NVM_DIRTY=0
fi
PREV_PWD="$git_root"
}
export PROMPT_COMMAND=_enter_dir
#export PROMPT_COMMAND="$PROMPT_COMMAND;_enter_dir" # use this if PROMPT_COMMAND already defined
Używam tej struktury konfiguracyjnej zsh o nazwie Oh My Zsh. To bardzo aktywne repozytorium z regularnymi aktualizacjami. Wypróbuj, a na pewno Ci się spodoba. Aha, i ma wbudowaną funkcję automatycznego .nvmrc, więc jest tak proste, jak instalacja pakietu przez npm!
Dla kogoś, kto wciąż boryka się z powyższym problemem, plik README nvm
zawiera tę sekcję, która byłaby pomocna
https://github.com/creationix/nvm#deeper-shell-integration
Osobiście wolę edytować .bashrc
( https://github.com/creationix/nvm#automatically-call-nvm-use ) niż inne rozwiązania.
bash
muszlę.