Ghostty Configuration
Guidance for configuring the Ghostty terminal emulator. Ghostty uses text-based config files with sensible defaults and zero required configuration.
Config File Locations
XDG Path (All Platforms):
$XDG_CONFIG_HOME/ghostty/config
- Defaults to if XDG_CONFIG_HOME undefined
macOS Additional Path:
~/Library/Application Support/com.mitchellh.ghostty/config
- If both XDG and macOS paths exist, both are loaded with macOS path taking precedence
Config Syntax
# Comments start with #
background = 282c34
foreground = ffffff
font-family = "JetBrains Mono"
keybind = ctrl+z=close_surface
font-family = # Empty value resets to default
Rules:
- Keys are case-sensitive (use lowercase)
- Whitespace around is flexible
- Values can be quoted or unquoted
- Empty values reset to defaults
- Every config key works as CLI flag:
ghostty --background=282c34
Config Loading & Includes
Files processed sequentially - later entries override earlier ones.
# Include additional configs
config-file = themes/dark.conf
config-file = ?local.conf # ? prefix = optional (no error if missing)
Critical: directives are processed at the file's end. Keys appearing after
won't override the included file's values.
Runtime Reloading
Some options cannot be reloaded at runtime. Some apply only to newly created terminals.
CLI Commands
Ghostty provides CLI actions via
. Use
for action-specific help.
Configuration Commands
| Command | Description |
|---|
| Show current effective configuration |
ghostty +show-config --default
| Show default configuration |
ghostty +show-config --default --docs
| Show defaults with documentation |
| Validate configuration file for errors |
| Open config file in default editor |
Listing Commands
| Command | Description |
|---|
| List available fonts (fixed-width) |
| List available colour themes |
| Show current keybindings |
ghostty +list-keybinds --default
| Show default keybindings |
| List available colour names |
| List all available keybinding actions |
Other Commands
| Command | Description |
|---|
| Show version information |
| Show help |
| Show font face information |
| Manage SSH terminfo cache |
| Generate crash report |
| Open new window (Linux only) |
| Easter egg |
Launching with Options
Every config key works as a CLI flag:
bash
ghostty --background=282c34 --font-size=14
ghostty -e top # Run command in terminal
macOS Note: The
CLI is a helper tool. To launch the terminal use
or
open -na Ghostty.app --args --font-size=14
.
Keybinding Syntax
Triggers
keybind = ctrl+a=select_all
keybind = ctrl+shift+t=new_tab
keybind = super+backquote=toggle_quick_terminal
Physical keys (W3C codes): ,
,
,
- Physical keys have higher priority than unicode codepoints
- Use for non-US keyboard layouts
Key sequences (leader keys):
keybind = ctrl+a>n=new_window # Press ctrl+a, release, press n
keybind = ctrl+a>ctrl+n=new_window # Both with ctrl
Sequences wait indefinitely for next key.
Prefixes
| Prefix | Effect |
|---|
| System-wide (macOS: needs Accessibility permissions; Linux: needs XDG Desktop Portal) |
| Apply to all terminal surfaces |
| Don't consume input (passes through) |
| Only consume if action succeeds |
Combine prefixes:
global:unconsumed:ctrl+a=reload_config
Note: Sequences cannot be used with
or
prefixes.
Special Values
- - Remove ALL keybindings
- - Remove specific binding
- - Prevent processing by Ghostty and terminal
Shell Integration
Auto-injection for: bash, zsh, fish, elvish
shell-integration = detect # Default - auto-detect shell
shell-integration = none # Disable auto-injection
shell-integration = fish # Force specific shell
Shell Integration Features
shell-integration-features = cursor,sudo,title
shell-integration-features = no-cursor # Disable specific feature
| Feature | Description |
|---|
| Blinking bar at prompt |
| Preserve terminfo with sudo |
| Set window title from shell |
| SSH environment compatibility |
| Auto terminfo on remote hosts |
What Shell Integration Enables
- Smart close (no confirm when at prompt)
- New terminals start in previous terminal's directory
- Prompt resizing via redraw
- Ctrl/Cmd+triple-click selects command output
- keybinding works
- Alt/Option+click repositions cursor at prompt
Manual Setup (if auto-injection fails)
bash
if [ -n "${GHOSTTY_RESOURCES_DIR}" ]; then
builtin source "${GHOSTTY_RESOURCES_DIR}/shell-integration/bash/ghostty.bash"
fi
Zsh:
zsh
source ${GHOSTTY_RESOURCES_DIR}/shell-integration/zsh/ghostty-integration
Fish:
fish
source "$GHOSTTY_RESOURCES_DIR"/shell-integration/fish/vendor_conf.d/ghostty-shell-integration.fish
macOS Note: does NOT support automatic shell integration. Install Bash via Homebrew or manually source the script.
Common Configuration Patterns
Theme with Light/Dark Mode
theme = light:catppuccin-latte,dark:catppuccin-mocha
Quick Terminal (Drop-down)
quick-terminal-position = top
quick-terminal-size = 50%
quick-terminal-autohide = true
keybind = global:super+backquote=toggle_quick_terminal
Custom Colour Palette
palette = 0=#1d2021
palette = 1=#cc241d
# ... (0-255 supported)
Font Configuration
font-family = "JetBrains Mono"
font-family-bold = "JetBrains Mono Bold"
font-size = 14
font-feature = -calt # Disable ligatures
font-feature = -liga
Background Transparency
background-opacity = 0.9
background-blur = true # macOS, KDE Plasma only
Platform-Specific Notes
macOS Only:
- , ,
- ,
- ,
toggle_window_float_on_top
- ,
- , , ,
- Global keybindings require Accessibility permissions
Linux/GTK Only:
- ,
window-titlebar-background/foreground
(requires )
- ,
- ,
toggle_window_decorations
- ,
Linux Wayland Only:
quick-terminal-keyboard-interactivity
- ,
gtk-quick-terminal-namespace
FreeType (Linux) Only:
Reference Files
For complete option and keybinding references, load:
- - All config options by category (font, colour, window, etc.)
references/keybindings.md
- All keybinding actions with parameters
Load these when you need specific option details, valid values, or keybinding action syntax.