agnoster.zsh-theme 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. # vim:ft=zsh ts=2 sw=2 sts=2
  2. #
  3. # agnoster's Theme - https://gist.github.com/3712874
  4. # A Powerline-inspired theme for ZSH
  5. #
  6. # # README
  7. #
  8. # In order for this theme to render correctly, you will need a
  9. # [Powerline-patched font](https://github.com/Lokaltog/powerline-fonts).
  10. #
  11. # In addition, I recommend the
  12. # [Solarized theme](https://github.com/altercation/solarized/) and, if you're
  13. # using it on Mac OS X, [iTerm 2](http://www.iterm2.com/) over Terminal.app -
  14. # it has significantly better color fidelity.
  15. #
  16. # # Goals
  17. #
  18. # The aim of this theme is to only show you *relevant* information. Like most
  19. # prompts, it will only show git information when in a git working directory.
  20. # However, it goes a step further: everything from the current user and
  21. # hostname to whether the last call exited with an error to whether background
  22. # jobs are running in this shell will all be displayed automatically when
  23. # appropriate.
  24. ### Segment drawing
  25. # A few utility functions to make it easy and re-usable to draw segmented prompts
  26. CURRENT_BG='NONE'
  27. SEGMENT_SEPARATOR=''
  28. # Begin a segment
  29. # Takes two arguments, background and foreground. Both can be omitted,
  30. # rendering default background/foreground.
  31. prompt_segment() {
  32. local bg fg
  33. [[ -n $1 ]] && bg="%K{$1}" || bg="%k"
  34. [[ -n $2 ]] && fg="%F{$2}" || fg="%f"
  35. if [[ $CURRENT_BG != 'NONE' && $1 != $CURRENT_BG ]]; then
  36. echo -n " %{$bg%F{$CURRENT_BG}%}$SEGMENT_SEPARATOR%{$fg%} "
  37. else
  38. echo -n "%{$bg%}%{$fg%} "
  39. fi
  40. CURRENT_BG=$1
  41. [[ -n $3 ]] && echo -n $3
  42. }
  43. # End the prompt, closing any open segments
  44. prompt_end() {
  45. if [[ -n $CURRENT_BG ]]; then
  46. echo -n " %{%k%F{$CURRENT_BG}%}$SEGMENT_SEPARATOR"
  47. else
  48. echo -n "%{%k%}"
  49. fi
  50. echo -n "%{%f%}"
  51. CURRENT_BG=''
  52. }
  53. ### Prompt components
  54. # Each component will draw itself, and hide itself if no information needs to be shown
  55. # Context: user@hostname (who am I and where am I)
  56. prompt_context() {
  57. local user=`whoami`
  58. if [[ "$user" != "$DEFAULT_USER" || -n "$SSH_CLIENT" ]]; then
  59. prompt_segment black default "%(!.%{%F{yellow}%}.)$user@%m"
  60. fi
  61. }
  62. # Git: branch/detached head, dirty status
  63. prompt_git() {
  64. local ref dirty mode repo_path
  65. repo_path=$(git rev-parse --git-dir 2>/dev/null)
  66. if $(git rev-parse --is-inside-work-tree >/dev/null 2>&1); then
  67. dirty=$(parse_git_dirty)
  68. ref=$(git symbolic-ref HEAD 2> /dev/null) || ref="➦ $(git show-ref --head -s --abbrev |head -n1 2> /dev/null)"
  69. if [[ -n $dirty ]]; then
  70. prompt_segment yellow black
  71. else
  72. prompt_segment green black
  73. fi
  74. if [[ -e "${repo_path}/BISECT_LOG" ]]; then
  75. mode=" <B>"
  76. elif [[ -e "${repo_path}/MERGE_HEAD" ]]; then
  77. mode=" >M<"
  78. elif [[ -e "${repo_path}/rebase" || -e "${repo_path}/rebase-apply" || -e "${repo_path}/rebase-merge" || -e "${repo_path}/../.dotest" ]]; then
  79. mode=" >R>"
  80. fi
  81. setopt promptsubst
  82. autoload -Uz vcs_info
  83. zstyle ':vcs_info:*' enable git
  84. zstyle ':vcs_info:*' get-revision true
  85. zstyle ':vcs_info:*' check-for-changes true
  86. zstyle ':vcs_info:*' stagedstr '✚'
  87. zstyle ':vcs_info:git:*' unstagedstr '●'
  88. zstyle ':vcs_info:*' formats ' %u%c'
  89. zstyle ':vcs_info:*' actionformats ' %u%c'
  90. vcs_info
  91. echo -n "${ref/refs\/heads\// }${vcs_info_msg_0_%% }${mode}"
  92. fi
  93. }
  94. prompt_hg() {
  95. local rev status
  96. if $(hg id >/dev/null 2>&1); then
  97. if $(hg prompt >/dev/null 2>&1); then
  98. if [[ $(hg prompt "{status|unknown}") = "?" ]]; then
  99. # if files are not added
  100. prompt_segment red white
  101. st='±'
  102. elif [[ -n $(hg prompt "{status|modified}") ]]; then
  103. # if any modification
  104. prompt_segment yellow black
  105. st='±'
  106. else
  107. # if working copy is clean
  108. prompt_segment green black
  109. fi
  110. echo -n $(hg prompt "☿ {rev}@{branch}") $st
  111. else
  112. st=""
  113. rev=$(hg id -n 2>/dev/null | sed 's/[^-0-9]//g')
  114. branch=$(hg id -b 2>/dev/null)
  115. if `hg st | grep -Eq "^\?"`; then
  116. prompt_segment red black
  117. st='±'
  118. elif `hg st | grep -Eq "^(M|A)"`; then
  119. prompt_segment yellow black
  120. st='±'
  121. else
  122. prompt_segment green black
  123. fi
  124. echo -n "☿ $rev@$branch" $st
  125. fi
  126. fi
  127. }
  128. # Dir: current working directory
  129. prompt_dir() {
  130. prompt_segment blue black '%~'
  131. }
  132. # Virtualenv: current working virtualenv
  133. prompt_virtualenv() {
  134. local virtualenv_path="$VIRTUAL_ENV"
  135. if [[ -n $virtualenv_path && -n $VIRTUAL_ENV_DISABLE_PROMPT ]]; then
  136. prompt_segment blue black "(`basename $virtualenv_path`)"
  137. fi
  138. }
  139. # Status:
  140. # - was there an error
  141. # - am I root
  142. # - are there background jobs?
  143. prompt_status() {
  144. local symbols
  145. symbols=()
  146. [[ $RETVAL -ne 0 ]] && symbols+="%{%F{red}%}✘"
  147. [[ $UID -eq 0 ]] && symbols+="%{%F{yellow}%}⚡"
  148. [[ $(jobs -l | wc -l) -gt 0 ]] && symbols+="%{%F{cyan}%}⚙"
  149. [[ -n "$symbols" ]] && prompt_segment black default "$symbols"
  150. }
  151. ## Main prompt
  152. build_prompt() {
  153. RETVAL=$?
  154. prompt_status
  155. prompt_virtualenv
  156. prompt_context
  157. prompt_dir
  158. prompt_git
  159. prompt_hg
  160. prompt_end
  161. }
  162. PROMPT='%{%f%b%k%}$(build_prompt) '