mirror of
https://github.com/ohmyzsh/ohmyzsh.git
synced 2026-02-11 05:39:45 +08:00
Compare commits
5 Commits
47eae26bf6
...
c1b798aff3
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c1b798aff3 | ||
|
|
eeb49bf5b0 | ||
|
|
de261bd29c | ||
|
|
e8609b857c | ||
|
|
d49397a01d |
@ -10,195 +10,196 @@ plugins=(... git)
|
|||||||
|
|
||||||
## Aliases
|
## Aliases
|
||||||
|
|
||||||
| Alias | Command |
|
| Alias | Command |
|
||||||
|:---------------------|:------------------------------------------------------------------------------------------------------------------------------|
|
|:---------------------|:---------------------------------------------------------------------------------------------------------------------------------|
|
||||||
| g | git |
|
| g | git |
|
||||||
| ga | git add |
|
| ga | git add |
|
||||||
| gaa | git add --all |
|
| gaa | git add --all |
|
||||||
| gapa | git add --patch |
|
| gapa | git add --patch |
|
||||||
| gau | git add --update |
|
| gau | git add --update |
|
||||||
| gav | git add --verbose |
|
| gav | git add --verbose |
|
||||||
| gap | git apply |
|
| gap | git apply |
|
||||||
| gb | git branch |
|
| gb | git branch |
|
||||||
| gba | git branch -a |
|
| gba | git branch -a |
|
||||||
| gbd | git branch -d |
|
| gbd | git branch -d |
|
||||||
| gbda | git branch --no-color --merged \| command grep -vE "^(\+|\*\|\s*(master\|develop\|dev)\s*$)" \| command xargs -n 1 git branch -d |
|
| gbda | git branch --no-color --merged \| command grep -vE "^(\+|\*\|\s*(master\|develop\|dev)\s*$)" \| command xargs -n 1 git branch -d |
|
||||||
| gbD | git branch -D |
|
| gbD | git branch -D |
|
||||||
| gbl | git blame -b -w |
|
| gbl | git blame -b -w |
|
||||||
| gbnm | git branch --no-merged |
|
| gbnm | git branch --no-merged |
|
||||||
| gbr | git branch --remote |
|
| gbr | git branch --remote |
|
||||||
| gbs | git bisect |
|
| gbs | git bisect |
|
||||||
| gbsb | git bisect bad |
|
| gbsb | git bisect bad |
|
||||||
| gbsg | git bisect good |
|
| gbsg | git bisect good |
|
||||||
| gbsr | git bisect reset |
|
| gbsr | git bisect reset |
|
||||||
| gbss | git bisect start |
|
| gbss | git bisect start |
|
||||||
| gc | git commit -v |
|
| gc | git commit -v |
|
||||||
| gc! | git commit -v --amend |
|
| gc! | git commit -v --amend |
|
||||||
| gcn! | git commit -v --no-edit --amend |
|
| gcn! | git commit -v --no-edit --amend |
|
||||||
| gca | git commit -v -a |
|
| gca | git commit -v -a |
|
||||||
| gca! | git commit -v -a --amend |
|
| gca! | git commit -v -a --amend |
|
||||||
| gcan! | git commit -v -a --no-edit --amend |
|
| gcan! | git commit -v -a --no-edit --amend |
|
||||||
| gcans! | git commit -v -a -s --no-edit --amend |
|
| gcans! | git commit -v -a -s --no-edit --amend |
|
||||||
| gcam | git commit -a -m |
|
| gcam | git commit -a -m |
|
||||||
| gcsm | git commit -s -m |
|
| gcsm | git commit -s -m |
|
||||||
| gcb | git checkout -b |
|
| gcb | git checkout -b |
|
||||||
| gcf | git config --list |
|
| gcf | git config --list |
|
||||||
| gcl | git clone --recurse-submodules |
|
| gcl | git clone --recurse-submodules |
|
||||||
| gclean | git clean -id |
|
| gclean | git clean -id |
|
||||||
| gpristine | git reset --hard && git clean -dfx |
|
| gpristine | git reset --hard && git clean -dfx |
|
||||||
| gcm | git checkout master |
|
| gcm | git checkout master |
|
||||||
| gcd | git checkout develop |
|
| gcd | git checkout develop |
|
||||||
| gcmsg | git commit -m |
|
| gcmsg | git commit -m |
|
||||||
| gco | git checkout |
|
| gco | git checkout |
|
||||||
| gcount | git shortlog -sn |
|
| gcount | git shortlog -sn |
|
||||||
| gcp | git cherry-pick |
|
| gcp | git cherry-pick |
|
||||||
| gcpa | git cherry-pick --abort |
|
| gcpa | git cherry-pick --abort |
|
||||||
| gcpc | git cherry-pick --continue |
|
| gcpc | git cherry-pick --continue |
|
||||||
| gcs | git commit -S |
|
| gcs | git commit -S |
|
||||||
| gd | git diff |
|
| gd | git diff |
|
||||||
| gdca | git diff --cached |
|
| gdca | git diff --cached |
|
||||||
| gdcw | git diff --cached --word-diff |
|
| gdcw | git diff --cached --word-diff |
|
||||||
| gdct | git describe --tags $(git rev-list --tags --max-count=1) |
|
| gdct | git describe --tags $(git rev-list --tags --max-count=1) |
|
||||||
| gds | git diff --staged |
|
| gds | git diff --staged |
|
||||||
| gdt | git diff-tree --no-commit-id --name-only -r |
|
| gdt | git diff-tree --no-commit-id --name-only -r |
|
||||||
| gdv | git diff -w $@ \| view - |
|
| gdv | git diff -w $@ \| view - |
|
||||||
| gdw | git diff --word-diff |
|
| gdw | git diff --word-diff |
|
||||||
| gf | git fetch |
|
| gf | git fetch |
|
||||||
| gfa | git fetch --all --prune |
|
| gfa | git fetch --all --prune |
|
||||||
| gfg | git ls-files \| grep |
|
| gfg | git ls-files \| grep |
|
||||||
| gfo | git fetch origin |
|
| gfo | git fetch origin |
|
||||||
| gg | git gui citool |
|
| gg | git gui citool |
|
||||||
| gga | git gui citool --amend |
|
| gga | git gui citool --amend |
|
||||||
| ggf | git push --force origin $(current_branch) |
|
| ggf | git push --force origin $(current_branch) |
|
||||||
| ggfl | git push --force-with-lease origin $(current_branch) |
|
| ggfl | git push --force-with-lease origin $(current_branch) |
|
||||||
| ggl | git pull origin $(current_branch) |
|
| ggl | git pull origin $(current_branch) |
|
||||||
| ggp | git push origin $(current_branch) |
|
| ggp | git push origin $(current_branch) |
|
||||||
| ggpnp | ggl && ggp |
|
| ggpnp | ggl && ggp |
|
||||||
| ggpull | git pull origin "$(git_current_branch)" |
|
| ggpull | git pull origin "$(git_current_branch)" |
|
||||||
| ggpur | ggu |
|
| ggpur | ggu |
|
||||||
| ggpush | git push origin "$(git_current_branch)" |
|
| ggpush | git push origin "$(git_current_branch)" |
|
||||||
| ggsup | git branch --set-upstream-to=origin/$(git_current_branch) |
|
| ggsup | git branch --set-upstream-to=origin/$(git_current_branch) |
|
||||||
| ggu | git pull --rebase origin $(current_branch) |
|
| ggu | git pull --rebase origin $(current_branch) |
|
||||||
| gpsup | git push --set-upstream origin $(git_current_branch) |
|
| gpsup | git push --set-upstream origin $(git_current_branch) |
|
||||||
| ghh | git help |
|
| ghh | git help |
|
||||||
| gignore | git update-index --assume-unchanged |
|
| gignore | git update-index --assume-unchanged |
|
||||||
| gignored | git ls-files -v \| grep "^[[:lower:]]" |
|
| gignored | git ls-files -v \| grep "^[[:lower:]]" |
|
||||||
| git-svn-dcommit-push | git svn dcommit && git push github master:svntrunk |
|
| git-svn-dcommit-push | git svn dcommit && git push github master:svntrunk |
|
||||||
| gk | gitk --all --branches |
|
| gk | gitk --all --branches |
|
||||||
| gke | gitk --all $(git log -g --pretty=%h) |
|
| gke | gitk --all $(git log -g --pretty=%h) |
|
||||||
| gl | git pull |
|
| gl | git pull |
|
||||||
| glg | git log --stat |
|
| glg | git log --stat |
|
||||||
| glgp | git log --stat -p |
|
| glgp | git log --stat -p |
|
||||||
| glgg | git log --graph |
|
| glgg | git log --graph |
|
||||||
| glgga | git log --graph --decorate --all |
|
| glgga | git log --graph --decorate --all |
|
||||||
| glgm | git log --graph --max-count=10 |
|
| glgm | git log --graph --max-count=10 |
|
||||||
| glo | git log --oneline --decorate |
|
| glo | git log --oneline --decorate |
|
||||||
| glol | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' |
|
| glol | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' |
|
||||||
| glols | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --stat |
|
| glols | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --stat |
|
||||||
| glod | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' |
|
| glod | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' |
|
||||||
| glods | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short |
|
| glods | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short |
|
||||||
| glola | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --all |
|
| glola | git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --all |
|
||||||
| glog | git log --oneline --decorate --graph |
|
| glog | git log --oneline --decorate --graph |
|
||||||
| gloga | git log --oneline --decorate --graph --all |
|
| gloga | git log --oneline --decorate --graph --all |
|
||||||
| glp | `_git_log_prettily` |
|
| glp | `_git_log_prettily` |
|
||||||
| gm | git merge |
|
| gm | git merge |
|
||||||
| gmom | git merge origin/master |
|
| gmom | git merge origin/master |
|
||||||
| gmt | git mergetool --no-prompt |
|
| gmt | git mergetool --no-prompt |
|
||||||
| gmtvim | git mergetool --no-prompt --tool=vimdiff |
|
| gmtvim | git mergetool --no-prompt --tool=vimdiff |
|
||||||
| gmum | git merge upstream/master |
|
| gmum | git merge upstream/master |
|
||||||
| gma | git merge --abort |
|
| gma | git merge --abort |
|
||||||
| gp | git push |
|
| gp | git push |
|
||||||
| gpd | git push --dry-run |
|
| gpd | git push --dry-run |
|
||||||
| gpf | git push --force-with-lease |
|
| gpf | git push --force-with-lease |
|
||||||
| gpf! | git push --force |
|
| gpf! | git push --force |
|
||||||
| gpoat | git push origin --all && git push origin --tags |
|
| gpoat | git push origin --all && git push origin --tags |
|
||||||
| gpu | git push upstream |
|
| gpu | git push upstream |
|
||||||
| gpv | git push -v |
|
| gpv | git push -v |
|
||||||
| gr | git remote |
|
| gr | git remote |
|
||||||
| gra | git remote add |
|
| gra | git remote add |
|
||||||
| grb | git rebase |
|
| grb | git rebase |
|
||||||
| grba | git rebase --abort |
|
| grba | git rebase --abort |
|
||||||
| grbc | git rebase --continue |
|
| grbc | git rebase --continue |
|
||||||
| grbd | git rebase develop |
|
| grbd | git rebase develop |
|
||||||
| grbi | git rebase -i |
|
| grbi | git rebase -i |
|
||||||
| grbm | git rebase master |
|
| grbm | git rebase master |
|
||||||
| grbs | git rebase --skip |
|
| grbs | git rebase --skip |
|
||||||
| grev | git revert |
|
| grev | git revert |
|
||||||
| grh | git reset |
|
| grh | git reset |
|
||||||
| grhh | git reset --hard |
|
| grhh | git reset --hard |
|
||||||
| groh | git reset origin/$(git_current_branch) --hard |
|
| groh | git reset origin/$(git_current_branch) --hard |
|
||||||
| grm | git rm |
|
| grm | git rm |
|
||||||
| grmc | git rm --cached |
|
| grmc | git rm --cached |
|
||||||
| grmv | git remote rename |
|
| grmv | git remote rename |
|
||||||
| grrm | git remote remove |
|
| grrm | git remote remove |
|
||||||
| grs | git restore |
|
| grs | git restore |
|
||||||
| grset | git remote set-url |
|
| grset | git remote set-url |
|
||||||
| grss | git restore --source |
|
| grss | git restore --source |
|
||||||
| grt | cd "$(git rev-parse --show-toplevel \|\| echo .)" |
|
| grt | cd "$(git rev-parse --show-toplevel \|\| echo .)" |
|
||||||
| gru | git reset -- |
|
| gru | git reset -- |
|
||||||
| grup | git remote update |
|
| grup | git remote update |
|
||||||
| grv | git remote -v |
|
| grv | git remote -v |
|
||||||
| gsb | git status -sb |
|
| gsb | git status -sb |
|
||||||
| gsd | git svn dcommit |
|
| gsd | git svn dcommit |
|
||||||
| gsh | git show |
|
| gsh | git show |
|
||||||
| gsi | git submodule init |
|
| gsi | git submodule init |
|
||||||
| gsps | git show --pretty=short --show-signature |
|
| gsps | git show --pretty=short --show-signature |
|
||||||
| gsr | git svn rebase |
|
| gsr | git svn rebase |
|
||||||
| gss | git status -s |
|
| gss | git status -s |
|
||||||
| gst | git status |
|
| gst | git status |
|
||||||
| gsta | git stash push |
|
| gsta | git stash push |
|
||||||
| gsta | git stash save |
|
| gsta | git stash save |
|
||||||
| gstaa | git stash apply |
|
| gstaa | git stash apply |
|
||||||
| gstc | git stash clear |
|
| gstc | git stash clear |
|
||||||
| gstd | git stash drop |
|
| gstd | git stash drop |
|
||||||
| gstl | git stash list |
|
| gstl | git stash list |
|
||||||
| gstp | git stash pop |
|
| gstp | git stash pop |
|
||||||
| gsts | git stash show --text |
|
| gsts | git stash show --text |
|
||||||
| gstu | git stash --include-untracked |
|
| gstu | git stash --include-untracked |
|
||||||
| gstall | git stash --all |
|
| gstall | git stash --all |
|
||||||
| gsu | git submodule update |
|
| gsu | git submodule update |
|
||||||
| gsw | git switch |
|
| gsw | git switch |
|
||||||
| gswc | git switch -c |
|
| gswc | git switch -c |
|
||||||
| gts | git tag -s |
|
| gts | git tag -s |
|
||||||
| gtv | git tag \| sort -V |
|
| gtv | git tag \| sort -V |
|
||||||
| gtl | gtl(){ git tag --sort=-v:refname -n -l ${1}* }; noglob gtl |
|
| gtl | gtl(){ git tag --sort=-v:refname -n -l ${1}* }; noglob gtl |
|
||||||
| gunignore | git update-index --no-assume-unchanged |
|
| gunignore | git update-index --no-assume-unchanged |
|
||||||
| gunwip | git log -n 1 \| grep -q -c "\-\-wip\-\-" && git reset HEAD~1 |
|
| gunwip | git log -n 1 \| grep -q -c "\-\-wip\-\-" && git reset HEAD~1 |
|
||||||
| gup | git pull --rebase |
|
| gup | git pull --rebase |
|
||||||
| gupv | git pull --rebase -v |
|
| gupv | git pull --rebase -v |
|
||||||
| gupa | git pull --rebase --autostash |
|
| gupa | git pull --rebase --autostash |
|
||||||
| gupav | git pull --rebase --autostash -v |
|
| gupav | git pull --rebase --autostash -v |
|
||||||
| glum | git pull upstream master |
|
| glum | git pull upstream master |
|
||||||
| gwch | git whatchanged -p --abbrev-commit --pretty=medium |
|
| gwch | git whatchanged -p --abbrev-commit --pretty=medium |
|
||||||
| gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]" |
|
| gwip | git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]" |
|
||||||
|
|
||||||
### Deprecated
|
### Deprecated
|
||||||
|
|
||||||
These are aliases that have been removed, renamed, or otherwise modified in a way that may, or may not, receive further support.
|
These are aliases that have been removed, renamed, or otherwise modified in a way that may, or may not, receive further support.
|
||||||
|
|
||||||
| Alias | Command | Modification |
|
| Alias | Command | Modification |
|
||||||
| :----- | :----------------------------------------------------------------------------------| --------------------------------------------------------------------------------------------------- |
|
| :----- | :----------------------------------------------------- | :----------------------------------------------------- |
|
||||||
| gap | git add --patch | new alias `gapa` |
|
| gap | `git add --patch` | new alias `gapa` |
|
||||||
| gcl | git config --list | new alias `gcf` |
|
| gcl | `git config --list` | new alias `gcf` |
|
||||||
| gdc | git diff --cached | new alias `gdca` |
|
| gdc | `git diff --cached` | new alias `gdca` |
|
||||||
| gdt | git difftool | no replacement |
|
| gdt | `git difftool` | no replacement |
|
||||||
| ggpull | git pull origin $(current_branch) | new alias `ggl` (`ggpull` still exists for now though) |
|
| ggpull | `git pull origin $(current_branch)` | new alias `ggl` (`ggpull` still exists for now though) |
|
||||||
| ggpur | git pull --rebase origin $(current_branch) | new alias `ggu` (`ggpur` still exists for now though) |
|
| ggpur | `git pull --rebase origin $(current_branch)` | new alias `ggu` (`ggpur` still exists for now though) |
|
||||||
| ggpush | git push origin $(current_branch) | new alias `ggp` (`ggpush` still exists for now though) |
|
| ggpush | `git push origin $(current_branch)` | new alias `ggp` (`ggpush` still exists for now though) |
|
||||||
| gk | gitk --all --branches | now aliased to `gitk --all --branches` |
|
| gk | `gitk --all --branches` | now aliased to `gitk --all --branches` |
|
||||||
| glg | git log --stat --max-count = 10 | now aliased to `git log --stat --color` |
|
| glg | `git log --stat --max-count = 10` | now aliased to `git log --stat --color` |
|
||||||
| glgg | git log --graph --max-count = 10 | now aliased to `git log --graph --color` |
|
| glgg | `git log --graph --max-count = 10` | now aliased to `git log --graph --color` |
|
||||||
| gwc | git whatchanged -p --abbrev-commit --pretty = medium | new alias `gwch` |
|
| gwc | `git whatchanged -p --abbrev-commit --pretty = medium` | new alias `gwch` |
|
||||||
|
|
||||||
## Functions
|
## Functions
|
||||||
|
|
||||||
### Current
|
### Current
|
||||||
|
|
||||||
| Command | Description |
|
| Command | Description |
|
||||||
|:-----------------------|:----------------------------------------|
|
|:-----------------------|:---------------------------------------------------------|
|
||||||
| current_branch | Return the name of the current branch |
|
| `grename <old> <new>` | Rename `old` branch to `new`, including in origin remote |
|
||||||
| git_current_user_name | Returns the `user.name` config value |
|
| current_branch | Return the name of the current branch |
|
||||||
| git_current_user_email | Returns the `user.email` config value |
|
| git_current_user_name | Returns the `user.name` config value |
|
||||||
|
| git_current_user_email | Returns the `user.email` config value |
|
||||||
|
|
||||||
### Work in Progress (WIP)
|
### Work in Progress (WIP)
|
||||||
|
|
||||||
|
|||||||
@ -256,3 +256,17 @@ alias glum='git pull upstream master'
|
|||||||
|
|
||||||
alias gwch='git whatchanged -p --abbrev-commit --pretty=medium'
|
alias gwch='git whatchanged -p --abbrev-commit --pretty=medium'
|
||||||
alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]"'
|
alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign -m "--wip-- [skip ci]"'
|
||||||
|
|
||||||
|
function grename() {
|
||||||
|
if [[ -z "$1" || -z "$2" ]]; then
|
||||||
|
echo "Usage: $0 old_branch new_branch"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Rename branch locally
|
||||||
|
git branch -m "$1" "$2"
|
||||||
|
# Rename branch in origin remote
|
||||||
|
if git push origin :"$1"; then
|
||||||
|
git push --set-upstream origin "$2"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|||||||
@ -51,3 +51,44 @@ plugins=(... systemd)
|
|||||||
|
|
||||||
You can use the above aliases as `--user` by using the prefix `scu` instead of `sc`.
|
You can use the above aliases as `--user` by using the prefix `scu` instead of `sc`.
|
||||||
For example: `scu-list-units` will be aliased to `systemctl --user list-units`.
|
For example: `scu-list-units` will be aliased to `systemctl --user list-units`.
|
||||||
|
|
||||||
|
### Unit Status Prompt
|
||||||
|
|
||||||
|
You can add a token to your prompt in a similar way to the gitfast plugin. To add the token
|
||||||
|
to your prompt, drop `$(systemd_prompt_info [unit]...)` into your prompt (more than one unit
|
||||||
|
may be specified).
|
||||||
|
|
||||||
|
The plugin will add the following to your prompt for each `$unit`.
|
||||||
|
```
|
||||||
|
<prefix><unit>:<active|notactive><suffix>
|
||||||
|
```
|
||||||
|
You can control these parts with the following variables:
|
||||||
|
|
||||||
|
- `<prefix>`: Set `$ZSH_THEME_SYSTEMD_PROMPT_PREFIX`.
|
||||||
|
|
||||||
|
- `<suffix>`: Set `$ZSH_THEME_SYSTEMD_PROMPT_SUFFIX`.
|
||||||
|
|
||||||
|
- `<unit>`: name passed as parameter to the function. If you want it to be in ALL CAPS,
|
||||||
|
you can set the variable `$ZSH_THEME_SYSTEMD_PROMPT_CAPS` to a non-empty string.
|
||||||
|
|
||||||
|
- `<active>`: shown if the systemd unit is active.
|
||||||
|
Set `$ZSH_THEME_SYSTEMD_PROMPT_ACTIVE`.
|
||||||
|
|
||||||
|
- `<notactive>`: shown if the systemd unit is *not* active.
|
||||||
|
Set `$ZSH_THEME_SYSTEMD_PROMPT_NOTACTIVE`.
|
||||||
|
|
||||||
|
For example, if your prompt contains `PROMPT='$(systemd_prompt_info dhcpd httpd)'` and you set the following variables:
|
||||||
|
|
||||||
|
```
|
||||||
|
ZSH_THEME_SYSTEMD_PROMPT_PREFIX="["
|
||||||
|
ZSH_THEME_SYSTEMD_PROMPT_SUFFIX="]"
|
||||||
|
ZSH_THEME_SYSTEMD_PROMPT_ACTIVE="+"
|
||||||
|
ZSH_THEME_SYSTEMD_PROMPT_NOTACTIVE="X"
|
||||||
|
ZSH_THEME_SYSTEMD_PROMPT_CAPS=1
|
||||||
|
```
|
||||||
|
|
||||||
|
If `dhcpd` is running, and `httpd` is not, then your prompt will look like this:
|
||||||
|
|
||||||
|
```
|
||||||
|
[DHCPD: +][HTTPD: X]
|
||||||
|
```
|
||||||
|
|||||||
@ -73,3 +73,18 @@ alias sc-mask-now="sc-mask --now"
|
|||||||
alias scu-enable-now="scu-enable --now"
|
alias scu-enable-now="scu-enable --now"
|
||||||
alias scu-disable-now="scu-disable --now"
|
alias scu-disable-now="scu-disable --now"
|
||||||
alias scu-mask-now="scu-mask --now"
|
alias scu-mask-now="scu-mask --now"
|
||||||
|
|
||||||
|
function systemd_prompt_info {
|
||||||
|
local unit
|
||||||
|
for unit in $@; do
|
||||||
|
echo -n "$ZSH_THEME_SYSTEMD_PROMPT_PREFIX"
|
||||||
|
[[ -n "$ZSH_THEME_SYSTEMD_PROMPT_CAPS" ]] && echo "${(U)unit}:" || echo "$unit:"
|
||||||
|
if systemctl is-active $unit &>/dev/null; then
|
||||||
|
echo -n "$ZSH_THEME_SYSTEMD_PROMPT_ACTIVE"
|
||||||
|
else
|
||||||
|
echo -n "$ZSH_THEME_SYSTEMD_PROMPT_NOTACTIVE"
|
||||||
|
fi
|
||||||
|
echo -n "$ZSH_THEME_SYSTEMD_PROMPT_SUFFIX"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
@ -2,29 +2,28 @@
|
|||||||
# Repo: https://github.com/andyfleming/oh-my-zsh
|
# Repo: https://github.com/andyfleming/oh-my-zsh
|
||||||
# Direct Link: https://github.com/andyfleming/oh-my-zsh/blob/master/themes/af-magic.zsh-theme
|
# Direct Link: https://github.com/andyfleming/oh-my-zsh/blob/master/themes/af-magic.zsh-theme
|
||||||
|
|
||||||
if [ $UID -eq 0 ]; then NCOLOR="red"; else NCOLOR="green"; fi
|
|
||||||
local return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})"
|
# settings
|
||||||
|
typeset +H return_code="%(?..%{$fg[red]%}%? ↵%{$reset_color%})"
|
||||||
|
typeset +H my_gray="$FG[237]"
|
||||||
|
typeset +H my_orange="$FG[214]"
|
||||||
|
|
||||||
|
# separator dashes size
|
||||||
|
function afmagic_dashes {
|
||||||
|
[[ -n "${VIRTUAL_ENV-}" && -z "${VIRTUAL_ENV_DISABLE_PROMPT-}" && "$PS1" = \(* ]] \
|
||||||
|
&& echo $(( COLUMNS - ${#VIRTUAL_ENV} - 3 )) \
|
||||||
|
|| echo $COLUMNS
|
||||||
|
}
|
||||||
|
|
||||||
# primary prompt
|
# primary prompt
|
||||||
PROMPT='$FG[237]${(l.COLUMNS..-.)}%{$reset_color%}
|
PS1='$FG[237]${(l.$(afmagic_dashes)..-.)}%{$reset_color%}
|
||||||
$FG[032]%~\
|
$FG[032]%~$(git_prompt_info)$(hg_prompt_info) $FG[105]%(!.#.»)%{$reset_color%} '
|
||||||
$(git_prompt_info)$(hg_prompt_info) \
|
PS2='%{$fg[red]%}\ %{$reset_color%}'
|
||||||
$FG[105]%(!.#.»)%{$reset_color%} '
|
|
||||||
PROMPT2='%{$fg[red]%}\ %{$reset_color%}'
|
|
||||||
RPS1='${return_code}'
|
RPS1='${return_code}'
|
||||||
|
|
||||||
|
|
||||||
# color vars
|
|
||||||
eval my_gray='$FG[237]'
|
|
||||||
eval my_orange='$FG[214]'
|
|
||||||
|
|
||||||
# right prompt
|
# right prompt
|
||||||
if type "virtualenv_prompt_info" > /dev/null
|
(( $+functions[virtualenv_prompt_info] )) && RPS1+='$(virtualenv_prompt_info)'
|
||||||
then
|
RPS1+=' $my_gray%n@%m%{$reset_color%}%'
|
||||||
RPROMPT="${RPROMPT}"'$FG[078]$(virtualenv_prompt_info)%{$reset_color%} $my_gray%n@%m%{$reset_color%}%'
|
|
||||||
else
|
|
||||||
RPROMPT="${RPROMPT}"'$my_gray%n@%m%{$reset_color%}%'
|
|
||||||
fi
|
|
||||||
|
|
||||||
# git settings
|
# git settings
|
||||||
ZSH_THEME_GIT_PROMPT_PREFIX="$FG[075]($FG[078]"
|
ZSH_THEME_GIT_PROMPT_PREFIX="$FG[075]($FG[078]"
|
||||||
@ -37,3 +36,7 @@ ZSH_THEME_HG_PROMPT_PREFIX="$FG[075]($FG[078]"
|
|||||||
ZSH_THEME_HG_PROMPT_CLEAN=""
|
ZSH_THEME_HG_PROMPT_CLEAN=""
|
||||||
ZSH_THEME_HG_PROMPT_DIRTY="$my_orange*%{$reset_color%}"
|
ZSH_THEME_HG_PROMPT_DIRTY="$my_orange*%{$reset_color%}"
|
||||||
ZSH_THEME_HG_PROMPT_SUFFIX="$FG[075])%{$reset_color%}"
|
ZSH_THEME_HG_PROMPT_SUFFIX="$FG[075])%{$reset_color%}"
|
||||||
|
|
||||||
|
# virtualenv settings
|
||||||
|
ZSH_THEME_VIRTUALENV_PREFIX=" $FG[075]["
|
||||||
|
ZSH_THEME_VIRTUALENV_SUFFIX="]%{$reset_color%}"
|
||||||
|
|||||||
@ -140,24 +140,30 @@ prompt_git() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
prompt_bzr() {
|
prompt_bzr() {
|
||||||
(( $+commands[bzr] )) || return
|
(( $+commands[bzr] )) || return
|
||||||
if (bzr status >/dev/null 2>&1); then
|
|
||||||
status_mod=`bzr status | head -n1 | grep "modified" | wc -m`
|
# Test if bzr repository in directory hierarchy
|
||||||
status_all=`bzr status | head -n1 | wc -m`
|
local dir="$PWD"
|
||||||
revision=`bzr log | head -n2 | tail -n1 | sed 's/^revno: //'`
|
while [[ ! -d "$dir/.bzr" ]]; do
|
||||||
if [[ $status_mod -gt 0 ]] ; then
|
[[ "$dir" = "/" ]] && return
|
||||||
prompt_segment yellow black
|
dir="${dir:h}"
|
||||||
echo -n "bzr@"$revision "✚ "
|
done
|
||||||
else
|
|
||||||
if [[ $status_all -gt 0 ]] ; then
|
local bzr_status status_mod status_all revision
|
||||||
prompt_segment yellow black
|
if bzr_status=$(bzr status 2>&1); then
|
||||||
echo -n "bzr@"$revision
|
status_mod=$(echo -n "$bzr_status" | head -n1 | grep "modified" | wc -m)
|
||||||
else
|
status_all=$(echo -n "$bzr_status" | head -n1 | wc -m)
|
||||||
prompt_segment green black
|
revision=$(bzr log -r-1 --log-format line | cut -d: -f1)
|
||||||
echo -n "bzr@"$revision
|
if [[ $status_mod -gt 0 ]] ; then
|
||||||
fi
|
prompt_segment yellow black "bzr@$revision ✚"
|
||||||
fi
|
else
|
||||||
|
if [[ $status_all -gt 0 ]] ; then
|
||||||
|
prompt_segment yellow black "bzr@$revision"
|
||||||
|
else
|
||||||
|
prompt_segment green black "bzr@$revision"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
prompt_hg() {
|
prompt_hg() {
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user