Skip to main content

A minimal CLI tool to organize, load, and switch between your project's environment contexts.

Project description

envlit

CI codecov Python Versions PyPI

A simple CLI tool to organize, load, and switch between your project's environment variable contexts.

Installation

pip install envlit

Quick Start

Initialize envlit in your shell (add to .bashrc or .zshrc):

eval "$(envlit init)"

Create a config file at .envlit/default.yaml:

env:
  PROJECT_MODE: "Development"
  DEBUG: "true"

Load and unload environment variables:

el                       # Load default profile
echo $PROJECT_MODE       # Output: Development (variable set by envlit)
echo $DEBUG              # Output: true (variable set by envlit)

eul                      # Unload environment variables
echo $PROJECT_MODE       # Output: (empty - variable restored to original state)
echo $DEBUG              # Output: (empty - variable restored to original state)

Features

  • Smart state tracking - Detects manual changes and preserves them
  • Dynamic flags - YAML-defined flags become CLI options
  • Path operations - Prepend, append, remove path entries
  • Lifecycle hooks - Run scripts before/after load/unload
  • Config inheritance - Extend base configurations

Comparison with Similar Tools

Feature envlit direnv dotenv
Auto-activation on cd
Manual load/unload
State restoration ✅ Full restore ⚠️ Basic ❌ No
Config format YAML Shell/direnvrc .env
Dynamic CLI flags
PATH operations
Lifecycle hooks ✅ 4 stages ⚠️ Limited
Config inheritance
Manual change detection

Key Differences:

  • envlit: Manual control with explicit load/unload. Full state tracking with restoration. Better for variable contexts that you want to toggle on demand.
  • direnv: Automatically activates on directory change. Great for per-directory isolation but less control over when environments load. Basic restoration.
  • dotenv: Simple .env file loading, no restoration or advanced features. Good for 12-factor apps but lacks state management.

When to use envlit:

  • You want CLI flags that map to environment variables (especially useful for long names and values)
  • You want explicit control over when environments load/unload
  • You need to preserve user modifications and restore clean state
  • You need complex PATH operations or lifecycle hooks

AI Agent Skill

[!TIP] Install the envlit skill to let your AI assistant manage envlit profiles directly.

Claude Code — install via marketplace:

/plugin marketplace add luocfprime/envlit
/plugin install envlit-skill@envlit

Or copy skills/envlit/SKILL.md to ~/.claude/skills/envlit/SKILL.md

OpenCode — copy skills/envlit/SKILL.md to .opencode/skills/envlit/SKILL.md

Documentation

Visit luocfprime.github.io/envlit for full documentation.

Development

# Install dependencies
make install

# Run tests
pytest

License

MIT License - see LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

envlit-0.0.6.tar.gz (29.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

envlit-0.0.6-py3-none-any.whl (18.3 kB view details)

Uploaded Python 3

File details

Details for the file envlit-0.0.6.tar.gz.

File metadata

  • Download URL: envlit-0.0.6.tar.gz
  • Upload date:
  • Size: 29.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for envlit-0.0.6.tar.gz
Algorithm Hash digest
SHA256 41d998558c68b1d031be257293ddccfa92ddcd90884b7ca88ddcbc1273be0299
MD5 b1d72d157568f271ca0b42020d4cb6b3
BLAKE2b-256 76b9386db7668e93ee3711db8233ddbeb5ab30bfba8b42e4b71894a21c0f14c0

See more details on using hashes here.

Provenance

The following attestation bundles were made for envlit-0.0.6.tar.gz:

Publisher: release.yml on luocfprime/envlit

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file envlit-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: envlit-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 18.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for envlit-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 26a4b25a242a28108d0a673290dd13d5395eb372dc34bd848ad727b1db86902a
MD5 3ec3f13ee7945a177336a01894dcf874
BLAKE2b-256 265faa4bbcc689e31c61a221a5a66c05bd8359efed35bf54e84504d5e1c5fff8

See more details on using hashes here.

Provenance

The following attestation bundles were made for envlit-0.0.6-py3-none-any.whl:

Publisher: release.yml on luocfprime/envlit

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page