doomemacs/modules/tools/direnv
2019-08-27 12:50:10 -04:00
..
config.el tools/direnv: add README 2019-08-27 12:50:10 -04:00
doctor.el
packages.el
README.org tools/direnv: add README 2019-08-27 12:50:10 -04:00

tools/direnv

Description

This module integrates direnv into Emacs.

direnv is an environment switcher for the shell. It knows how to hook into bash, zsh, tcsh, fish shell and elvish to load or unload environment variables depending on the current directory. This allows project-specific environment variables without cluttering the ~/.profile file.

Before each prompt, direnv checks for the existence of a ".envrc" file in the current and parent directories. If the file exists (and is authorized), it is loaded into a bash sub-shell and all exported variables are then captured by direnv and then made available to the current shell.

Module Flags

This module provides no flags.

Plugins

Hacks

  • Normally, the direnv environment is updated on post-command-hook. We've changed it to update on doom-switch-buffer-hook, doom-switch-window-hook and doom-switch-frame-hook instead.
  • Special direnv keywords/commands are highlighted in direnv-envrc-mode.
  • A fix has been applied to ensure flycheck searches for executables from within the direnv environment, if any.

Prerequisites

This module requires the direnv utility.

MacOS

brew install direnv

Arch Linux

sudo pacman -S direnv

NixOS

environment.systemPackages = [ pkgs.direnv ];

Or nix-env -i direnv

Troubleshooting

direnv + nix is slow

Consider augmenting direnv with lorri, which will cache nix builds and speed up direnv tremendously.

At the time of writing, the lorri package in nixpkgs simply emits an error message, telling you to install it manually. You can get around this with:

nixpkgs.overlays = [
  (self: super: {
    lorri =
      let src = (super.fetchFromGitHub {
            owner = "target";
            repo = "lorri";
            rev = "e943fa403234f1a5e403b6fdc112e79abc1e29ba";
            sha256 = "1ar7clza117qdzldld9qzg4q0wr3g20zxrnd1s51cg6gxwlpg7fa";
          });
      in super.callPackage src { inherit src; };
  })
];

environment.systemPackages = [ pkgs.lorri ];

Otherwise, follow the instructions in lorri's README on how to install it manually.