From f678ba557b0307de117be73cec6e69b69bcb0a0a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?J=C3=B6rg=20Thalheim?= Date: Fri, 27 Sep 2019 09:03:55 +0100 Subject: [PATCH] add direnvrc --- README.md | 22 ++++++++++++++++++- direnvrc | 66 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 87 insertions(+), 1 deletion(-) create mode 100644 direnvrc diff --git a/README.md b/README.md index 1cf2312..4aa2c02 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,22 @@ # nix-direnv -A fast, persistent use_nix implementation for direnv + +A fast, persistent use_nix implementation for direnv. +Prominent features: + +- significantly faster after the first run by caching nix-shell environment +- prevents garbage collection of build dependencies by symlinking the resulting + shell derivation in the user's `gcroots` (Life is too short to loose your + build cache of your project if you are in a plane without internet connection) + +## USAGE + +```console +$ git clone https://github.com/nix-community/nix-direnv $HOME/.nix-direnv +``` + +Then source the direnvrc from this repository in your own `.direnvrc` + +```bash +# put this in ~/.direnvrc +source $HOME/.nix-direnv/direnvrc +``` diff --git a/direnvrc b/direnvrc new file mode 100644 index 0000000..dd2db9a --- /dev/null +++ b/direnvrc @@ -0,0 +1,66 @@ +use_nix() { + local path="$(nix-instantiate --find-file nixpkgs)" + + if [ -f "${path}/.version-suffix" ]; then + local version="$(< $path/.version-suffix)" + elif [ -f "${path}/.git" ]; then + local version="$(< $(< ${path}/.git/HEAD))" + fi + + local cache=".direnv/cache-${version:-unknown}" + + local update_drv=0 + if [[ ! -e "$cache" ]] || \ + [[ "$HOME/.direnvrc" -nt "$cache" ]] || \ + [[ .envrc -nt "$cache" ]] || \ + [[ default.nix -nt "$cache" ]] || \ + [[ shell.nix -nt "$cache" ]]; + then + [ -d .direnv ] || mkdir .direnv + local dump_cmd="echo \; \"$direnv\" dump bash; echo \" + local tmp=$(nix-shell --show-trace --pure "$@" \ + --run "$dump_cmd" | grep -oP '(?<=).*?(?=)') + echo "$tmp" > "$cache" + update_drv=1 + else + log_status using cached derivation + fi + local term_backup=$TERM path_backup=$PATH + if [ -z ${TMPDIR+x} ]; then + local tmp_backup=$TMPDIR + fi + + log_status eval $cache + eval "$(< $cache)" + export PATH=$PATH:$path_backup TERM=$term_backup TMPDIR=$tmp_backup + if [ -z ${tmp_backup+x} ]; then + export TMPDIR=${tmp_backup} + else + unset TMPDIR + fi + + # `nix-shell --pure` sets invalid ssl certificate paths + if [ "${SSL_CERT_FILE:-}" = /no-cert-file.crt ]; then + unset SSL_CERT_FILE + fi + if [ "${NIX_SSL_CERT_FILE:-}" = /no-cert-file.crt ]; then + unset NIX_SSL_CERT_FILE + fi + + # This part is based on https://discourse.nixos.org/t/what-is-the-best-dev-workflow-around-nix-shell/418/4 + if [ "$out" ] && (( $update_drv )); then + local drv_link=".direnv/drv" + local drv="$(nix show-derivation $out | grep -E -o -m1 '/nix/store/.*.drv')" + local stripped_pwd=${PWD/\//} + local escaped_pwd=${stripped_pwd//-/--} + local escaped_pwd=${escaped_pwd//\//-} + ln -fs "$drv" "$drv_link" + ln -fs "$PWD/$drv_link" "/nix/var/nix/gcroots/per-user/$LOGNAME/$escaped_pwd" + log_status renewed cache and derivation link + fi + + if [[ $# = 0 ]]; then + watch_file default.nix + watch_file shell.nix + fi +} \ No newline at end of file