diff options
| author | Marc Cornellà <marc.cornella@live.com> | 2016-09-29 14:04:22 +0200 | 
|---|---|---|
| committer | Marc Cornellà <marc.cornella@live.com> | 2016-09-29 14:04:22 +0200 | 
| commit | 1ad2556ce37d3900f38f5905ded60168dbd36ab7 (patch) | |
| tree | 9bff6c93b83a1d06baf5cb7994ea2105e7b20950 | |
| parent | ac8915d43f0e8de9294c8552dc338ecc9993acd2 (diff) | |
| parent | e6df0e036e39bcc2c20d7feaef1749d3c4f2768f (diff) | |
| download | zsh-1ad2556ce37d3900f38f5905ded60168dbd36ab7.tar.gz zsh-1ad2556ce37d3900f38f5905ded60168dbd36ab7.tar.bz2 zsh-1ad2556ce37d3900f38f5905ded60168dbd36ab7.zip  | |
Merge branch 'refactor-svn-plugin'
Closes #5462
| -rw-r--r-- | plugins/svn/README.md | 67 | ||||
| -rw-r--r-- | plugins/svn/svn.plugin.zsh | 56 | 
2 files changed, 91 insertions, 32 deletions
diff --git a/plugins/svn/README.md b/plugins/svn/README.md new file mode 100644 index 000000000..1f7b70c86 --- /dev/null +++ b/plugins/svn/README.md @@ -0,0 +1,67 @@ +# `svn` plugin + +This plugin adds some utility functions to display additional information regarding your current +svn repository. See http://subversion.apache.org/ for the full svn documentation. + +To use it, add `svn` to your plugins array: + +```zsh +plugins=(... svn) +``` + +## Functions + +| Command               | Description                                 | +|:----------------------|:--------------------------------------------| +| `svn_prompt_info`     | Shows svn prompt in themes                  | +| `in_svn`              | Checks if we're in an svn repository        | +| `svn_get_repo_name`   | Get repository name                         | +| `svn_get_branch_name` | Get branch name (see [caveats](#caveats))   | +| `svn_get_rev_nr`      | Get revision number                         | +| `svn_dirty`           | Checks if there are changes in the svn repo | + +## Caveats + +The plugin expects the first directory to be the current branch / tag / trunk. So it returns +the first path element if you don't use branches. + +## Usage on themes + +To use this in the `agnoster` theme follow these instructions: + +1. Enable the svn plugin + +2. Add the following lines to your `zshrc` file: + +    ```shell +    prompt_svn() { +        local rev branch +        if in_svn; then +            rev=$(svn_get_rev_nr) +            branch=$(svn_get_branch_name) +            if [[ $(svn_dirty_choose_pwd 1 0) -eq 1 ]]; then +                prompt_segment yellow black +                echo -n "$rev@$branch" +                echo -n "±" +            else +                prompt_segment green black +                echo -n "$rev@$branch" +            fi +        fi +    } +    ``` + +3. Override the agnoster `build_prompt()` function: + +    ```zsh +    build_prompt() { +        RETVAL=$? +        prompt_status +        prompt_context +        prompt_dir +        prompt_git +        prompt_svn +        prompt_end +    } +    ``` + diff --git a/plugins/svn/svn.plugin.zsh b/plugins/svn/svn.plugin.zsh index 816055afe..fbc9ee538 100644 --- a/plugins/svn/svn.plugin.zsh +++ b/plugins/svn/svn.plugin.zsh @@ -1,9 +1,7 @@ -# vim:ft=zsh ts=2 sw=2 sts=2 -# -function svn_prompt_info() { +svn_prompt_info() {    local _DISPLAY    if in_svn; then -    if [ "x$SVN_SHOW_BRANCH" = "xtrue" ]; then +    if [[ "$SVN_SHOW_BRANCH" = true ]]; then        unset SVN_SHOW_BRANCH        _DISPLAY=$(svn_get_branch_name)      else @@ -16,23 +14,20 @@ $ZSH_THEME_REPO_NAME_COLOR$_DISPLAY$ZSH_PROMPT_BASE_COLOR$ZSH_THEME_SVN_PROMPT_S  } -function in_svn() { -  if $(svn info >/dev/null 2>&1); then -    return 0 -  fi -  return 1 +in_svn() { +  svn info >/dev/null 2>&1  } -function svn_get_repo_name() { +svn_get_repo_name() {    if in_svn; then -    svn info | sed -n 's/Repository\ Root:\ .*\///p' | read SVN_ROOT -    svn info | sed -n "s/URL:\ .*$SVN_ROOT\///p" +    LANG=C svn info | sed -n 's/^Repository\ Root:\ .*\///p' | read SVN_ROOT +    LANG=C svn info | sed -n "s/^URL:\ .*$SVN_ROOT\///p"    fi  } -function svn_get_branch_name() { +svn_get_branch_name() {    local _DISPLAY=$( -    svn info 2> /dev/null | \ +    LANG=C svn info 2> /dev/null | \        awk -F/ \        '/^URL:/ { \          for (i=0; i<=NF; i++) { \ @@ -44,24 +39,28 @@ function svn_get_branch_name() {          } \        }'    ) -   -  if [ "x$_DISPLAY" = "x" ]; then + +  if [[ -z "$_DISPLAY" ]]; then      svn_get_repo_name    else      echo $_DISPLAY    fi  } -function svn_get_rev_nr() { +svn_get_rev_nr() {    if in_svn; then -    svn info 2> /dev/null | sed -n 's/Revision:\ //p' +    LANG=C svn info 2> /dev/null | sed -n 's/Revision:\ //p'    fi  } -function svn_dirty_choose() { +svn_dirty() { +  svn_dirty_choose $ZSH_THEME_SVN_PROMPT_DIRTY $ZSH_THEME_SVN_PROMPT_CLEAN +} + +svn_dirty_choose() {    if in_svn; then -    local root=`svn info 2> /dev/null | sed -n 's/^Working Copy Root Path: //p'` -    if $(svn status $root 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'); then +    local root=$(LANG=C svn info 2> /dev/null | sed -n 's/^Working Copy Root Path: //p') +    if svn status $root 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'; then        # Grep exits with 0 when "One or more lines were selected", return "dirty".        echo $1      else @@ -71,14 +70,13 @@ function svn_dirty_choose() {    fi  } -function svn_dirty() { -  svn_dirty_choose $ZSH_THEME_SVN_PROMPT_DIRTY $ZSH_THEME_SVN_PROMPT_CLEAN +svn_dirty_pwd () { +  svn_dirty_choose_pwd $ZSH_THEME_SVN_PROMPT_DIRTY_PWD $ZSH_THEME_SVN_PROMPT_CLEAN_PWD  } -function svn_dirty_choose_pwd () { +svn_dirty_choose_pwd () {    if in_svn; then -    local root=$PWD -    if $(svn status $root 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'); then +    if svn status "$PWD" 2> /dev/null | command grep -Eq '^\s*[ACDIM!?L]'; then        # Grep exits with 0 when "One or more lines were selected", return "dirty".        echo $1      else @@ -87,9 +85,3 @@ function svn_dirty_choose_pwd () {      fi    fi  } - -function svn_dirty_pwd () { -  svn_dirty_choose_pwd $ZSH_THEME_SVN_PROMPT_DIRTY_PWD $ZSH_THEME_SVN_PROMPT_CLEAN_PWD -} - -  | 
