From 1641a87bd521352fff64b4c520bd6c8c257d6751 Mon Sep 17 00:00:00 2001 From: exos Date: Fri, 26 Sep 2014 10:56:48 -0300 Subject: [PATCH 1/2] Agrego aviso de virtualenv en el prompt --- themes/exos.zsh-theme | 47 ++++++++++++++++++++++++++++--------------- 1 file changed, 31 insertions(+), 16 deletions(-) diff --git a/themes/exos.zsh-theme b/themes/exos.zsh-theme index 0faef97ed..56791d8c2 100644 --- a/themes/exos.zsh-theme +++ b/themes/exos.zsh-theme @@ -3,36 +3,51 @@ autoload -Uz vcs_info zstyle ':vcs_info:*' actionformats \ '%F{5}(%f%s%F{5})%F{3}-%F{5}[%F{2}%b%F{3}|%F{1}%a%F{5}]%f ' + zstyle ':vcs_info:*' formats '%F{2}%s%F{7}:%F{2}(%F{1}%b%F{2})%f ' zstyle ':vcs_info:(sv[nk]|bzr):*' branchformat '%b%F{1}:%F{3}%r' zstyle ':vcs_info:*' enable git add-zsh-hook precmd prompt_vcs +add-zsh-hook precmd prompt_virtualenv prompt_vcs () { -vcs_info + vcs_info -if [ "${vcs_info_msg_0_}" = "" ]; then - dir_status="%F{2}→%f" -elif [[ $(git diff --cached --name-status 2>/dev/null ) != "" ]]; then - dir_status="%F{1}šŸ’¾%f" -elif [[ $(git diff --name-status 2>/dev/null ) != "" ]]; then - dir_status="%F{3}šŸ’¾%f" -else - dir_status="%F{2}āœ“ā–¶%f" -fi + if [ "${vcs_info_msg_0_}" = "" ]; then + dir_status="%F{2}→%f" + elif [[ $(git diff --cached --name-status 2>/dev/null ) != "" ]]; then + dir_status="%F{1}šŸ’¾%f" + elif [[ $(git diff --name-status 2>/dev/null ) != "" ]]; then + dir_status="%F{3}šŸ’¾%f" + else + dir_status="%F{2}āœ“ā–¶%f" + fi +} + +prompt_virtualenv () { + if [[ -n $VIRTUAL_ENV ]]; then + ve_status="%F{2}⌬%f " + else + if [[ -d ./virtualenv || -d ./.virtualenv ]]; then + ve_status="%F{1}⌬%f " + else + ve_status="" + fi + fi } function { -if [[ -n "$SSH_CLIENT" ]]; then - PROMPT_HOST=" ($HOST)" -else - PROMPT_HOST='' -fi + if [[ -n "$SSH_CLIENT" ]]; then + PROMPT_HOST=" ($HOST)" + else + PROMPT_HOST='' + fi } local ret_status="%(?:%{$fg_bold[green]%}⌨ :%{$fg_bold[red]%}%S↑%s%?)" -PROMPT='${ret_status}%{$fg[blue]%}${PROMPT_HOST}%{$fg_bold[green]%}%p %{$fg_bold[yellow]%}%2~ ${vcs_info_msg_0_}${dir_status}%{$reset_color%} ' + +PROMPT='${ret_status}%{$fg[blue]%}${PROMPT_HOST}%{$fg_bold[green]%}%p %{$fg_bold[yellow]%}%2~ ${vcs_info_msg_0_}${ve_status}${dir_status}%{$reset_color%} ' RPROMPT='%F{blue}$(pwd) %F{yellow}[%*]%f' # vim: set ft=zsh ts=4 sw=4 et: From 27aae50d89d350ff47a738a6fe8a67bc1a167936 Mon Sep 17 00:00:00 2001 From: exos Date: Tue, 30 Sep 2014 11:40:17 -0300 Subject: [PATCH 2/2] Add Project name support and change icons --- themes/exos.zsh-theme | 60 +++++++++++++++++++++++++++++++++---------- 1 file changed, 47 insertions(+), 13 deletions(-) diff --git a/themes/exos.zsh-theme b/themes/exos.zsh-theme index 56791d8c2..a480ba020 100644 --- a/themes/exos.zsh-theme +++ b/themes/exos.zsh-theme @@ -4,50 +4,84 @@ autoload -Uz vcs_info zstyle ':vcs_info:*' actionformats \ '%F{5}(%f%s%F{5})%F{3}-%F{5}[%F{2}%b%F{3}|%F{1}%a%F{5}]%f ' -zstyle ':vcs_info:*' formats '%F{2}%s%F{7}:%F{2}(%F{1}%b%F{2})%f ' +zstyle ':vcs_info:*' formats '%F{2}%F{1}%b%F{2}%f ' zstyle ':vcs_info:(sv[nk]|bzr):*' branchformat '%b%F{1}:%F{3}%r' zstyle ':vcs_info:*' enable git +add-zsh-hook precmd detect_pdir add-zsh-hook precmd prompt_vcs add-zsh-hook precmd prompt_virtualenv +add-zsh-hook precmd prompt_projectname + +detect_pdir () { + pdir=$(git rev-parse --show-toplevel 2> /dev/null ) +} prompt_vcs () { vcs_info if [ "${vcs_info_msg_0_}" = "" ]; then - dir_status="%F{2}→%f" + dir_status="" elif [[ $(git diff --cached --name-status 2>/dev/null ) != "" ]]; then - dir_status="%F{1}šŸ’¾%f" + dir_status="%F{1}⬆%f" elif [[ $(git diff --name-status 2>/dev/null ) != "" ]]; then - dir_status="%F{3}šŸ’¾%f" + dir_status="%F{3}⬆%f" else - dir_status="%F{2}āœ“ā–¶%f" + dir_status="%F{2}āœ“%f" fi + + if [ "${vcs_info_msg_0_}" = "" ]; then + cbranch="" + else + cbranch="ā­ ${vcs_info_msg_0_}" + fi + } prompt_virtualenv () { if [[ -n $VIRTUAL_ENV ]]; then - ve_status="%F{2}⌬%f " - else - if [[ -d ./virtualenv || -d ./.virtualenv ]]; then - ve_status="%F{1}⌬%f " + ve_status="%F{2} ⌬%f " + elif [[ -n $pdir ]]; then + if [[ -d $pdir/virtualenv || -d $pdir/.virtualenv || -f $pdir/requirements.txt ]]; then + ve_status="%F{1} ⌬%f " else ve_status="" fi fi } +prompt_projectname () { + + pname=" ${cbranch}${dir_status}${ve_status}" + + if [[ -n $pdir ]]; then + + if [[ -f $pdir/package.json ]]; then + ppname=$(python2 -c "import json;print json.loads(open('$pdir/package.json', 'r').read())['name']" 2> /dev/null) + elif [[ -f $pdir/bower.json ]]; then + ppname=$(python2 -c "import json;print json.loads(open('$pdir/bower.json', 'r').read())['name']" 2> /dev/null) + else + ppname=$(basename $pdir) + fi + + if [[ -n $ppname ]]; then + pname=" ⁅${ve_status}${ppname} ${cbranch}${dir_status} ⁆" + fi + fi + +} + function { if [[ -n "$SSH_CLIENT" ]]; then - PROMPT_HOST=" ($HOST)" + PROMPT_HOST=" $HOST āž² " else PROMPT_HOST='' fi } -local ret_status="%(?:%{$fg_bold[green]%}⌨ :%{$fg_bold[red]%}%S↑%s%?)" +local ret_status="%(?:%{$fg_bold[green]%}āŗ:%{$fg_bold[red]%}āŗ)" -PROMPT='${ret_status}%{$fg[blue]%}${PROMPT_HOST}%{$fg_bold[green]%}%p %{$fg_bold[yellow]%}%2~ ${vcs_info_msg_0_}${ve_status}${dir_status}%{$reset_color%} ' -RPROMPT='%F{blue}$(pwd) %F{yellow}[%*]%f' +PROMPT='${ret_status}%{$fg[blue]%}${PROMPT_HOST}${pname}%{$fg_bold[green]%}%p %{$fg_bold[yellow]%}%2~ ā–¶%{$reset_color%} ' +RPROMPT='%F{blue}$(pwd)%(?: :%{$fg_bold[red]%} %? )%F{yellow}[%*]%f' # vim: set ft=zsh ts=4 sw=4 et: