direnv

Category: General Risk: High risk ★ 4.2 · Rating 4.2/5 (86) TerminalSkills/skills Apache-2.0

Rating is derived from the repo's GitHub stars and shown for reference.

shell_executionfilesystem_access

name: direnv
description: >-
Auto-load environment variables per directory with direnv. Use when a user asks to manage env vars per project, auto-switch configs between projects, or avoid manual .env loading.
license: Apache-2.0
compatibility: 'Linux, macOS, WSL'
metadata:
author: terminal-skills
version: 1.0.0
category: development
tags:
- direnv
- environment
- dotenv
- shell
- config

direnv

Overview

direnv automatically loads/unloads environment variables when you cd into a directory. No more source .env — enter the project folder and variables are set.

Instructions

Step 1: Install

brew install direnv
# Add to .bashrc or .zshrc:
eval "$(direnv hook bash)"

Step 2: Configure

# .envrc — Auto-loaded when entering directory
export DATABASE_URL="postgresql://localhost:5432/myapp"
export API_KEY="sk-dev-key-123"
export NODE_ENV="development"
dotenv .env
PATH_add bin
PATH_add node_modules/.bin
direnv allow    # required first time and after changes

Step 3: Per-Project Layouts

# .envrc — Use specific versions
use nvm 20
layout python3

Guidelines

  • Always add .envrc to .gitignore — it contains secrets.
  • Use .envrc.example (committed) as template.
  • direnv unloads vars when you leave the directory — no env pollution.