]> git.phdru.name Git - dotfiles.git/blobdiff - .shellrc
.shellrc: define completion for cdremote
[dotfiles.git] / .shellrc
index 2527547c4d3e1a046134debc854c8d7e015d3adc..d0c9c37d5921a94ca8ae9d783113dfd781689863 100644 (file)
--- a/.shellrc
+++ b/.shellrc
@@ -12,6 +12,9 @@ case $- in
       *) return;;
 esac
 
+# Stop if non-interactive shell
+# [ -z "$PS1" ] && return
+
 # append to the history file, don't overwrite it
 shopt -s histappend
 
@@ -119,7 +122,10 @@ case "$SHELL" in
    fi
    complete -W "`echo $BROWSER | sed 's/:/ /g'`" start-browser
 
-   which pip >/dev/null 2>&1 && eval "`pip completion --bash`"
+   if which pip >/dev/null 2>&1; then
+      eval "`pip completion --bash`"
+      rm -rf /tmp/pip_build_"$USER"
+   fi
    ;;
 
 */ksh)
@@ -158,8 +164,39 @@ KillAll() {
 }
 
 
-x() { exit; }
-X() { startx >> .Xserver.log 2>&1; cyr; }
+# git-related
+
+# chdir to a remote's directory (if the remote is on the local FS)
+cdremote() {
+   cd "`git config --get remote.$1.url`"
+}
+
+case "$SHELL" in
+   */bash)
+      # list remotes with URLs matching a regexp
+      list_remotes() {
+         GIT_REMOTES=""
+         for remote in `git remote`; do
+            if git config --get remote.$remote.url | grep -q "$1"; then
+               GIT_REMOTES="$GIT_REMOTES $remote"
+            fi
+         done
+         remote=""
+         unset remote
+      }
+
+      # define completion for cdremote - list remotes with directories as URLs
+      _cdremote_complete() {
+         local cur="${COMP_WORDS[COMP_CWORD]}";
+         list_remotes '^/'
+         COMPREPLY=(`compgen -W "$GIT_REMOTES" -- "$cur"`)
+         GIT_REMOTES=""
+         unset GIT_REMOTES
+      }
+
+      complete -F _cdremote_complete cdremote
+   ;;
+esac
 
 
 include()
@@ -278,3 +315,17 @@ tmux() {
       ;;
    esac
 }
+
+
+if [ -f /usr/local/bin/virtualenvwrapper_lazy.sh ]; then
+   source /usr/local/bin/virtualenvwrapper_lazy.sh
+fi
+
+#if which pyenv >/dev/null 2>&1; then
+#   eval "`pyenv init -`"
+#   eval "`pyenv virtualenv-init -`"
+#fi
+
+
+X() { startx >> .Xserver.log 2>&1; cyr; }
+x() { exit; }