Shell Integration and Interoperability
Atuin uses shell hooks to capture your command history. This page explains how the integration works, why Atuin might not record commands in certain environments, and how to control what gets recorded.
How Atuin's Shell Integration Works
When you add eval "$(atuin init <shell>)" to your shell configuration, Atuin installs hooks that run at specific points in your shell's command lifecycle:
- Preexec hook: Runs before each command executes. Atuin records the command text, timestamp, and working directory.
- Precmd hook: Runs after each command completes. Atuin records the exit code and duration.
These hooks only activate under specific conditions:
- The shell must be interactive (started with
-ior inherently interactive) - Your shell configuration file must be sourced (
.bashrc,.zshrc, etc.) - The
atuin initcommand must run during shell startup
If any of these conditions aren't met, Atuin's hooks won't be installed, and commands won't be recorded.
Environment Variables
When Atuin initializes, it sets several environment variables:
| Variable | Purpose |
|---|---|
ATUIN_SESSION |
Unique identifier for this shell session |
ATUIN_SHLVL |
Tracks shell nesting level |
ATUIN_HISTORY_ID |
Temporary ID for the currently executing command |
These variables are used internally to track command execution and associate commands with sessions.
Embedded Terminals and IDE Integrations
Many development tools include embedded terminals:
- IDEs: PyCharm, IntelliJ, VS Code, Cursor, Zed
- AI coding assistants: Claude Code, GitHub Copilot CLI, Aider
- Container environments: Docker, Podman, devcontainers
These tools often spawn shells differently than your regular terminal, which can prevent Atuin from working.
Why Atuin Might Not Work
Embedded terminals commonly:
- Start non-interactive shells: Many tools run commands via
bash -c "command"or similar, which doesn't trigger shell configuration - Skip shell configuration: Some tools explicitly avoid sourcing
.bashrc/.zshrcfor performance or isolation - Use different shell paths: The embedded terminal might use a different shell than your default
You can verify whether Atuin is active by running:
Look for the shell.preexec field in the output. If it shows none, Atuin's hooks aren't installed in that shell session.
Enabling Atuin in Embedded Terminals
If you want Atuin to record commands from an embedded terminal, you'll need to ensure it starts an interactive shell that sources your configuration.
IDE Terminal Settings
Most IDEs let you customize the shell command used for their integrated terminal:
PyCharm / IntelliJ:
- Go to Settings → Tools → Terminal
- Change "Shell path" to include the
-iflag: - Linux/macOS:
/bin/bash -ior/bin/zsh -i - Or create a wrapper script (see below)
VS Code:
Add to your settings.json (substitute the shells for whatever you use):
{
"terminal.integrated.profiles.linux": {
"bash": {
"path": "/bin/bash",
"args": ["-i"]
}
},
"terminal.integrated.profiles.osx": {
"zsh": {
"path": "/bin/zsh",
"args": ["-i"]
}
}
}
Wrapper Script Approach
For tools that don't easily support shell arguments, create a wrapper script:
Then configure your IDE to use ~/bin/interactive-bash.sh as the shell path.
Verifying the Fix
After configuring, open a new terminal in your IDE and run:
You should see built-in, bash-preexec, blesh, or similar—not none.
Excluding Commands from History
Sometimes you don't want certain commands in your history. This is common when:
- AI coding tools run many automated commands (git status, file listings, etc.)
- You're running sensitive commands you don't want synced
- Build tools or scripts generate repetitive command noise
Using history_filter
The history_filter option in ~/.config/atuin/config.toml lets you exclude commands matching specific patterns:
history_filter = [
"^ls$", # Exclude bare 'ls' commands
"^cd ", # Exclude cd commands
"^cat ", # Exclude cat commands
]
Patterns are regular expressions. They're unanchored by default, so secret matches anywhere in a command. Use ^ and $ for exact matching.
Using cwd_filter
To exclude all commands run from specific directories:
cwd_filter = [
"^/tmp", # Exclude commands run from /tmp
"/node_modules/", # Exclude commands from any node_modules
"^/home/user/scratch", # Exclude a scratch directory
]
Prefix with Space (ignorespace)
Most shells support "ignorespace"—commands prefixed with a space aren't saved to history. Atuin honors this convention:
Bash with bash-preexec
When using bash-preexec (not ble.sh), there's a known issue where ignorespace isn't fully honored. The command won't appear in Atuin, but may still appear in your bash history. See installation for details.
Disabling Atuin for Specific Tools
If a tool spawns interactive shells but you don't want its commands recorded, you have several options:
Option 1: Environment Variable Check
Modify your shell configuration to skip Atuin initialization based on an environment variable:
Then configure your tool to set MY_TOOL_SESSION=1 when spawning shells.
Option 2: Use history_filter for Tool-Specific Patterns
If the tool runs predictable commands, filter them:
Option 3: Filter by Directory
If the tool operates in specific directories:
Cleaning Up Existing History
After adding filters, you can remove matching entries from your existing history:
This removes entries that match your current history_filter or cwd_filter patterns.
Shell-Specific Notes
Bash
Atuin supports two preexec backends for Bash:
- ble.sh (recommended): Full-featured line editor with accurate timing and proper ignorespace support
- bash-preexec: Simpler but has some limitations with subshells and ignorespace
The shell integration explicitly checks for interactive mode:
Zsh
Zsh has native hook support via add-zsh-hook. The integration is straightforward and works reliably in interactive sessions.
Fish
Fish uses its event system (fish_preexec and fish_postexec events). It also respects Fish's private mode—commands run with fish --private aren't recorded.
Troubleshooting
Commands aren't being recorded
- Run
atuin doctorand check the output - Verify
shell.preexecis notnone - Ensure your shell is interactive (
echo $-should containi) - Check that
atuin initis in your shell config and being sourced
Commands from a specific tool aren't recorded
- Check if the tool starts an interactive shell
- Try configuring the tool to use
bash -iorzsh -i - Use a wrapper script if the tool doesn't support shell arguments
Too many commands are being recorded
- Add patterns to
history_filterin your config - Use
cwd_filterfor directory-based exclusion - Prefix sensitive commands with a space
- Run
atuin history pruneto clean existing entries
Atuin works in terminal but not in IDE
This is the most common issue. The IDE's embedded terminal likely isn't starting an interactive shell. See Enabling Atuin in Embedded Terminals above.