Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/twolfson/sexy-bash-prompt
Bash prompt with colors, git statuses, and git branches.
https://github.com/twolfson/sexy-bash-prompt
Last synced: 6 days ago
JSON representation
Bash prompt with colors, git statuses, and git branches.
- Host: GitHub
- URL: https://github.com/twolfson/sexy-bash-prompt
- Owner: twolfson
- License: mit
- Created: 2013-07-09T08:02:48.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2021-03-22T19:11:56.000Z (almost 4 years ago)
- Last Synced: 2025-01-01T14:47:51.403Z (10 days ago)
- Language: Shell
- Homepage:
- Size: 758 KB
- Stars: 1,139
- Watchers: 49
- Forks: 155
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE-MIT
Awesome Lists containing this project
- awesome-bash - sexy-bash-prompt - Bash prompt with colors, Git statuses, and Git branches (Prompts and Color Themes / Reusable Things)
- terminals-are-sexy - sexy-bash-prompt - Bash prompt with colors, Git statuses, and Git branches. (Shells / Git)
- fucking-terminals-are-sexy - sexy-bash-prompt - Bash prompt with colors, Git statuses, and Git branches. (Shells / Git)
README
# sexy-bash-prompt [![Build status](https://travis-ci.org/twolfson/sexy-bash-prompt.png?branch=master)](https://travis-ci.org/twolfson/sexy-bash-prompt)
[Bash][bash] prompt with colors, git statuses, and git branches.
Providing a unique symbol for every combination of a dirty, unpulled, and unpushed `git` branch.
![sexy-bash-prompt screenshot][screenshot]
[screenshot]: screenshot.png
Forked from [a gist by gf3][sexy-bash-orig].
[sexy-bash-orig]: https://gist.github.com/gf3/306785/a35d28b6bdd0f7c54318cce510738438f04dabaa
### Do you like `sexy-bash-prompt`?
[Support us with a monthly donation and help us continue our activities][donations] or [spread word on Twitter][twitter]
[donations]: https://opencollective.com/sexy-bash-prompt#backer
[twitter]: https://twitter.com/intent/tweet?text=Bash%20prompt%20with%20colors%2C%20git%20statuses%2C%20and%20git%20branches&url=https%3A%2F%2Fgithub.com%2Ftwolfson%2Fsexy-bash-prompt&via=sexybashprompt### Sponsors
Become a sponsor and get your logo on our README on GitHub with a link to your site. [Become a sponsor](https://opencollective.com/sexy-bash-prompt#sponsor)## Installation
One line install (requires `git`, `make`):```bash
(cd /tmp && ([[ -d sexy-bash-prompt ]] || git clone --depth 1 --config core.autocrlf=false https://github.com/twolfson/sexy-bash-prompt) && cd sexy-bash-prompt && make install) && source ~/.bashrc```
### My colors don't look as advertised
If you are seeing a screen like this:![Bad TERM config](docs/bad_term.png)
Then, your `TERM` environment variable may never have been configured. Run the script below to prefix our prompt with a `TERM` setup
```bash
cat > /tmp/.bash_prompt_term </dev/null 2>&1; then export TERM=gnome-256color
elif [[ \$TERM != dumb ]] && infocmp xterm-256color >/dev/null 2>&1; then export TERM=xterm-256color
fiEOF
chmod +x /tmp/.bash_prompt_term
cat ~/.bash_prompt >> /tmp/.bash_prompt_term
cp /tmp/.bash_prompt_term ~/.bash_prompt
rm /tmp/.bash_prompt_term
```### Manual install
Requirements: `git`, `make````bash
# Clone the repository
git clone --depth 1 --config core.autocrlf=false https://github.com/twolfson/sexy-bash-prompt
# Cloning into 'sexy-bash-prompt'...
# ...
# Resolving deltas: 100% (13/13), done.# Go into the directory
cd sexy-bash-prompt
# Install the script
make install
# # Copying .bash_prompt to ~/.bash_prompt
# cp -f ".bash_prompt" "/home/todd/.bash_prompt"
# ./install.bash
# # twolfson/sexy-bash-prompt installation complete!# Rerun your ~/.bashrc
source ~/.bashrc
# todd at Euclid in ~/github/sexy-bash-prompt on master
# Your PS1 should now look like this!
```## Configuration
### Behavior
Behavior can be customized with the following environment variables:- `PROMPT_SHOW_ERROR_ONCE` - If enabled (default), then will only show error color once per command execution
- `bash` persists a non-zero exit code across missing commands (e.g. comment line only, keyboard interrupt, empty command)
- Setting this to `1` (default) means show error status once, `0` means always show same error status until a new command is executed### Colors
Colors can be customized by editing `.bash_prompt` directly, or by setting the following environment variables:- `PROMPT_USER_COLOR` - Color for username (e.g. `todd`)
- `PROMPT_PREPOSITION_COLOR` - Color for 'at', 'in', 'on'
- `PROMPT_DEVICE_COLOR` - Color for machine name (e.g. `Euclid`)
- `PROMPT_DIR_COLOR` - Color for directory (e.g. `~/github/sexy-bash-prompt`)
- `PROMPT_GIT_STATUS_COLOR` - Color for git branch and symbol (e.g. `master`)
- `PROMPT_GIT_PROGRESS_COLOR` - Color for in progress git actions (e.g. `[merge]`)
- `PROMPT_SYMBOL_COLOR` - Color for prompt symbol by default or on success (e.g. `$`)
- `PROMPT_SYMBOL_ERROR_COLOR` - Color for prompt symbol on error (e.g. `$`)You can set colors via [`tput`][] or [ANSI escape codes][]. For example:
[`tput`]: http://en.wikipedia.org/wiki/Tput
[ANSI escape codes]: http://en.wikipedia.org/wiki/ANSI_escape_code```bash
# Inside your `.bashrc` or `.bash_profile`
PROMPT_USER_COLOR="$(tput bold)$(tput setaf 9)" # BOLD RED
source ~/.bash_prompt
```![Color overridden prompt](docs/color_override.png)
### Symbols
Similarly, symbols can be customized with the following environment variables:- `PROMPT_SYNCED_SYMBOL` - Symbol for clean and synced branch (e.g. empty string)
- `PROMPT_DIRTY_SYNCED_SYMBOL` - Symbol for dirty and synced branch (e.g. `*`)
- `PROMPT_UNPUSHED_SYMBOL` - Symbol for unpushed branch (e.g. `△`)
- `PROMPT_DIRTY_UNPUSHED_SYMBOL` - Symbol for dirty and unpushed branch (e.g. `▲`)
- `PROMPT_UNPULLED_SYMBOL` - Symbol for unpulled branch (e.g. `▽`)
- `PROMPT_DIRTY_UNPULLED_SYMBOL` - Symbol for dirty and unpulled branch (e.g. `▼`)
- `PROMPT_UNPUSHED_UNPULLED_SYMBOL` - Symbol for unpushed and unpulled branch (e.g. `⬡`)
- `PROMPT_DIRTY_UNPUSHED_UNPULLED_SYMBOL` - Symbol for dirty, unpushed, and unpulled branch (e.g. `⬢`)
- `PROMPT_SYMBOL` - Symbol given after each prompt (e.g. `$`)
- By default, this is `$` for normal users and `#` for root```bash
# Inside your `.bashrc` or `.bash_profile`
PROMPT_UNPUSHED_SYMBOL="↑"
source ~/.bash_prompt
```![Symbol overridden prompt](docs/symbol_override.png)
#### Compatibility
In some situations, the default symbol set can be drawn incorrectly (e.g. as diamonds). To remedy that, a simpler set of symbols can be used:```bash
PROMPT_SYNCED_SYMBOL=""
PROMPT_DIRTY_SYNCED_SYMBOL="*"
PROMPT_UNPUSHED_SYMBOL="↑"
PROMPT_DIRTY_UNPUSHED_SYMBOL="*↑"
PROMPT_UNPULLED_SYMBOL="↓"
PROMPT_DIRTY_UNPULLED_SYMBOL="*↓"
PROMPT_UNPUSHED_UNPULLED_SYMBOL="*↑↓"
PROMPT_DIRTY_UNPUSHED_UNPULLED_SYMBOL="*↑↓"
```## How does it work?
[bash][bash] provides a special set of [variables for your prompts][ps-vars]. `PS1` is the one used by default. The install script adds a command to `~/.bashrc`, a file that is run every time a new terminal opens. Inside of the new command, we run our script and set your `PROMPT_COMMAND` and `PS1` which runs some `git` commands to determine its current state and outputs them as a string.[bash]: https://en.wikipedia.org/wiki/Bash_%28Unix_shell%29
[ps-vars]: http://www.gnu.org/software/bash/manual/bashref.html#index-PS1## Support
Linux and Mac OSX are supported platforms.Windows is supported to the best of my abilities. However, there have been [font issues][putty-issue] with using [PuTTY][].
[PuTTY]: http://www.chiark.greenend.org.uk/~sgtatham/putty/download.html
[putty-issue]: https://github.com/twolfson/sexy-bash-prompt/issues/7## Uninstallation
To uninstall `sexy-bash-prompt`, perform the following steps:- Remove `. ~/.bash_prompt` from `~/.bashrc`
- Delete `~/.bash_prompt` (e.g. `rm ~/.bash_prompt`)
- During installation, we may have added a `. ~/.bashrc` invocation to `~/.bash_profile`, `~/.bash_login`, or `~/.profile`
- Feel free to remove this if it's no longer necessary## Contributing
In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Test via `make test`.## License
Copyright (c) 2013 Todd WolfsonLicensed under the MIT license.