]> ToastFreeware Gitweb - gregoa/movein.git/blobdiff - movein
add 'exec' command (thanks Stuart Prescott)
[gregoa/movein.git] / movein
diff --git a/movein b/movein
index 15b0b5de6317b95cf8093a5d6db6d5ecf2446848..f236b1448aa532fb26190df40026e24280b1a75e 100755 (executable)
--- a/movein
+++ b/movein
@@ -34,9 +34,12 @@ SYNOPSIS
   $bn init
   $bn ls
   $bn list
+  $bn ls-r
+  $bn list-remote
   $bn add repository_name
   $bn new repository_name file1 [file2 file3...]
   $bn login repository_name
+  $bn exec repository_name command [arg1 arg2...]
 
 COMMANDS
   init 
@@ -44,7 +47,11 @@ COMMANDS
 
   ls
   list
-      show a list of repositories
+      show a list of local repositories
+
+  ls-r
+  list-remote
+      show a list of remote repositories
 
   add repository_name
       checkout the repository from the remote host and add it to
@@ -58,11 +65,17 @@ COMMANDS
   login repository_name
       start a subshell in repository_name
 
+  exec repository_name command [arg1 arg2...]
+      execute a command in the context of repository_name, for example:
+        $bn exec myrepo git status
+        $bn exec myrepo git ls-files
+
 EOF
 
     exit 1
 }
 
+[ $# -ge 1 ] || usage
 
 GIT_HOST=git.vireo.org
 REMOTE_REPOS=~/git
@@ -133,6 +146,20 @@ login() {
     GIT_PS1_SHOWUNTRACKEDFILES= PSMOVEIN="movein:${1}" $SHELL -i || :
 }
 
+execin() {
+    local REPO
+    if [ $# -lt 1 ]; then
+       usage
+    fi
+
+    REPO=$1;shift
+
+    export GIT_DIR="$LOCAL_REPOS/${REPO}.git"
+    export GIT_WORK_TREE="$GIT_DIR/$(git config --get core.worktree)"
+
+    "$@"
+}
+
 add() {
     if [ $# -ne 1 ]; then 
        usage
@@ -166,6 +193,12 @@ list() {
     find "${LOCAL_REPOS}" -mindepth 1 -maxdepth 1 -type d | sed 's,^.*/\([^/]*\).git$,\1,'
 }
 
+listremote() {
+    ssh $GIT_HOST "
+        find '${REMOTE_REPOS}' -mindepth 1 -maxdepth 1 -type d | sed 's,^.*/\([^/]*\).git$,\1,'
+    " </dev/null
+}
+
 new() {
     if [ $# -lt 2 ]; then 
        usage
@@ -225,12 +258,21 @@ case "$command" in
     login)
        login $@
        ;;
+    exec)
+       execin "$@"
+       ;;
     ls)
        list
        ;;
     list)
        list
        ;;
+    ls-r)
+       listremote
+       ;;
+    list-remote)
+       listremote
+       ;;
 
     *)
        usage