From 623ac6a5bcc05f1309f0670bf6516e631fd907cc Mon Sep 17 00:00:00 2001 From: Randy Coulman Date: Sat, 29 Dec 2012 11:27:23 -0800 Subject: [PATCH] Allow configuration of the sed command to be used. On OS/X, the builtin sed command does not handle the sed expressions used throughout git-prompt.sh. This commit allows customization of the sed command to use in git-prompt.conf. On OS/X, one could install GNU sed instead (e.g., brew install gnu-sed) and modify sed_cmd to use that. --- git-prompt.conf | 7 +++++++ git-prompt.sh | 17 +++++++++-------- 2 files changed, 16 insertions(+), 8 deletions(-) diff --git a/git-prompt.conf b/git-prompt.conf index dee3c0c..4b66a5b 100644 --- a/git-prompt.conf +++ b/git-prompt.conf @@ -34,6 +34,13 @@ ## cwd_cmd='\W' # display only last dir of path ## cwd_cmd='cwd_truncate 40' # display only last N chars of path +########################################################### SED COMMAND + +# The default sed command on OS/X doesn't handle the sed commands used. +# Install gnu-sed instead (brew install gnu-sed) and replace the sed command. +# sed_cmd='sed' +## sed_cmd='gsed' + ########################################################### ETC # Some don't like hostname in uppercase diff --git a/git-prompt.sh b/git-prompt.sh index d1e88b3..5bc7653 100755 --- a/git-prompt.sh +++ b/git-prompt.sh @@ -36,6 +36,7 @@ virtualenv_module=${virtualenv_module:-on} error_bell=${error_bell:-off} cwd_cmd=${cwd_cmd:-\\w} + sed_cmd=${sed_cmd:-sed} #### dir, rc, root color @@ -195,7 +196,7 @@ cwd_truncate() { # split path into: head='~/', truncateble middle, last_dir local cwd_max_length=$1 - + if [[ "$cwd" =~ '(~?/)(.*/)([^/]*)$' ]] ; then # only valid if path have more than 1 dir local path_head=${BASH_REMATCH[1]} local path_middle=${BASH_REMATCH[2]} @@ -268,8 +269,8 @@ set_shell_label() { ########################################################### TTY tty=`tty` - tty=`echo $tty | sed "s:/dev/pts/:p:; s:/dev/tty::" ` # RH tty devs - tty=`echo $tty | sed "s:/dev/vc/:vc:" ` # gentoo tty devs + tty=`echo $tty | $sed_cmd "s:/dev/pts/:p:; s:/dev/tty::" ` # RH tty devs + tty=`echo $tty | $sed_cmd "s:/dev/vc/:vc:" ` # gentoo tty devs if [[ "$TERM" = "screen" ]] ; then @@ -361,7 +362,7 @@ parse_svn_status() { ### get rev eval ` svn info | - sed -n " + $sed_cmd -n " s@^URL[^/]*//@repo_dir=@p s/^Revision: /rev=/p " @@ -370,7 +371,7 @@ parse_svn_status() { unset status modified added clean init added mixed untracked op detached eval `svn status 2>/dev/null | - sed -n ' + $sed_cmd -n ' s/^A... \([^.].*\)/modified=modified; modified_files[${#modified_files[@]}]=\"\1\";/p s/^M... \([^.].*\)/modified=modified; modified_files[${#modified_files[@]}]=\"\1\";/p s/^\?... \([^.].*\)/untracked=untracked; untracked_files[${#untracked_files[@]}]=\"\1\";/p @@ -393,7 +394,7 @@ parse_hg_status() { unset status modified added clean init added mixed untracked op detached eval `hg status 2>/dev/null | - sed -n ' + $sed_cmd -n ' s/^M \([^.].*\)/modified=modified; modified_files[${#modified_files[@]}]=\"\1\";/p s/^A \([^.].*\)/added=added; added_files[${#added_files[@]}]=\"\1\";/p s/^R \([^.].*\)/added=added;/p @@ -440,7 +441,7 @@ parse_git_status() { # info not in porcelain status eval " $( LANG=C git status 2>/dev/null | - sed -n ' + $sed_cmd -n ' s/^\(# \)*On branch /branch=/p s/^nothing to commi.*/clean=clean/p s/^\(# \)*Initial commi.*/init=init/p @@ -463,7 +464,7 @@ parse_git_status() { eval " $( LANG=C git status --porcelain 2>/dev/null | - sed -n ' + $sed_cmd -n ' s,^[MARC]. \([^\"][^/]*/\?\).*, added=added; [[ \" ${added_files[@]} \" =~ \" \1 \" ]] || added_files[${#added_files[@]}]=\"\1\",p s,^[MARC]. \"\([^/]\+/\?\).*\"$, added=added; [[ \" ${added_files[@]} \" =~ \" \1 \" ]] || added_files[${#added_files[@]}]=\"\1\",p s,^.[MAU] \([^\"][^/]*/\?\).*, modified=modified; [[ \" ${modified_files[@]} \" =~ \" \1 \" ]] || modified_files[${#modified_files[@]}]=\"\1\",p