agnoster.zsh-theme 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  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://gist.github.com/1595572).
  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
  65. if $(git rev-parse --is-inside-work-tree >/dev/null 2>&1); then
  66. ZSH_THEME_GIT_PROMPT_DIRTY='±'
  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. echo -n "${ref/refs\/heads\//⭠ }$dirty"
  75. fi
  76. }
  77. prompt_hg() {
  78. local rev status
  79. if $(hg id >/dev/null 2>&1); then
  80. if $(hg prompt >/dev/null 2>&1); then
  81. if [[ $(hg prompt "{status|unknown}") = "?" ]]; then
  82. # if files are not added
  83. prompt_segment red white
  84. st='±'
  85. elif [[ -n $(hg prompt "{status|modified}") ]]; then
  86. # if any modification
  87. prompt_segment yellow black
  88. st='±'
  89. else
  90. # if working copy is clean
  91. prompt_segment green black
  92. fi
  93. echo -n $(hg prompt "⭠ {rev}@{branch}") $st
  94. else
  95. st=""
  96. rev=$(hg id -n 2>/dev/null | sed 's/[^-0-9]//g')
  97. branch=$(hg id -b 2>/dev/null)
  98. if `hg st | grep -Eq "^\?"`; then
  99. prompt_segment red black
  100. st='±'
  101. elif `hg st | grep -Eq "^(M|A)"`; then
  102. prompt_segment yellow black
  103. st='±'
  104. else
  105. prompt_segment green black
  106. fi
  107. echo -n "⭠ $rev@$branch" $st
  108. fi
  109. fi
  110. }
  111. # Dir: current working directory
  112. prompt_dir() {
  113. prompt_segment blue black '%~'
  114. }
  115. # Status:
  116. # - was there an error
  117. # - am I root
  118. # - are there background jobs?
  119. prompt_status() {
  120. local symbols
  121. symbols=()
  122. [[ $RETVAL -ne 0 ]] && symbols+="%{%F{red}%}✘"
  123. [[ $UID -eq 0 ]] && symbols+="%{%F{yellow}%}⚡"
  124. [[ $(jobs -l | wc -l) -gt 0 ]] && symbols+="%{%F{cyan}%}⚙"
  125. [[ -n "$symbols" ]] && prompt_segment black default "$symbols"
  126. }
  127. ## Main prompt
  128. build_prompt() {
  129. RETVAL=$?
  130. prompt_status
  131. prompt_context
  132. prompt_dir
  133. prompt_git
  134. prompt_hg
  135. prompt_end
  136. }
  137. PROMPT='%{%f%b%k%}$(build_prompt) '