...sets environment variables when you enter a directory that matches a regular expression.
At work, I have to set some environment variables every time I'm working on certain projects.
For example, these can be Google Cloud settings, the Consul host or Docker configs.
It's tedious to do that myself every time.
[direnv] automatically loads .env
files, but I don't want to clutter my system
with .env
files. Also I need the same environment variables in a few unrelated
projects and I don't want to keep the .env
files in sync.
Thus, envy was born.
It uses a config file that defines what environment variables to set for each folder. The first regular expression that matches a path will be used.
Run envy edit
to open the config file.
(On macOS, this file is located at /Users/<user>/Library/Application Support/Envy/Config.toml
)
```toml [[paths]] pattern = ".project1." env = [ "CONSULHTTPADDR=http://consul:8500" ]
[[paths]] pattern = ".project2." env = [ "DOCKER_HOST=tcp://127.0.0.1:2376", "foo=bar" ] ```
cargo install envy-cli
Add the following line at the end of the ~/.zshrc
file:
eval "$(envy hook zsh)"
Once you open a new shell, envy will watch directories and set the specified environment variables from the config file.