Replace some spaces with tabs.
[gregoa/movein.git] / movein
diff --git a/movein b/movein
index 00bfcab..15b0b5d 100755 (executable)
--- a/movein
+++ b/movein
@@ -17,6 +17,7 @@
 # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307,
 # USA.  
 
+
 set -e
 
 usage() {
@@ -31,12 +32,19 @@ SYNOPSIS
   $bn command [options]
 
   $bn init
+  $bn ls
+  $bn list
   $bn add repository_name
   $bn new repository_name file1 [file2 file3...]
+  $bn login repository_name
 
 COMMANDS
   init 
-      create ~/.mrconfig
+      create ~/.moveinrc, create/update  ~/.mrconfig
+
+  ls
+  list
+      show a list of repositories
 
   add repository_name
       checkout the repository from the remote host and add it to
@@ -46,19 +54,23 @@ COMMANDS
       create a new repository on the remote host, and checkin the
       listed files to the new repository.   Add the new repository
       to mr's configuration
+
+  login repository_name
+      start a subshell in repository_name
+
 EOF
 
     exit 1
 }
 
 
-GIT_HOST=flounder.vireo.org
+GIT_HOST=git.vireo.org
 REMOTE_REPOS=~/git
-LOCAL_REPOS=~/.fgits
+LOCAL_REPOS=~/.movein
 MRCONFIG=~/.mrconfig
-MOVEIN=~/.movein
+MOVEINRC=~/.moveinrc
 
-[ -e source $MOVEIN ] && source $MOVEIN
+[ -e "$MOVEINRC" ] && . "$MOVEINRC"
 
 init() {
 
@@ -66,13 +78,8 @@ init() {
        usage
     fi
     
-    if [ -e $MRCONFIG ]; then
-       echo $MRCONFIG already exists
-       exit 1
-    fi
-    
-    if [ -e $MOVEIN ]; then
-       echo $MOVEIN already exists
+    if [ -e $MOVEINRC ]; then
+       echo $MOVEINRC already exists
        exit 1
     fi
 
@@ -88,10 +95,10 @@ init() {
        REMOTE_REPOS=~/git
     fi
 
-    echo -n "Local repository directory? [~/.fgit] " 
+    echo -n "Local repository directory? [~/.movein] " 
     read LOCAL_REPOS
     if [ -z "$LOCAL_REPOS" ]; then 
-       LOCAL_REPOS=~/.fgits
+       LOCAL_REPOS=~/.movein
     fi
 
     echo -n "Location of .mrconfig file? [~/.mrconfig] " 
@@ -100,22 +107,31 @@ init() {
        MRCONFIG=~/.mrconfig
     fi
 
-    cat <<EOF > .movein
+    cat <<EOF > $MOVEINRC
 GIT_HOST=$GIT_HOST
 REMOTE_REPOS=$REMOTE_REPOS
 LOCAL_REPOS=$LOCAL_REPOS
 MRCONFIG=$MRCONFIG
 EOF
 
-    mkdir $LOCAL_REPOS
-    cat <<END > $MRCONFIG
-[DEFAULT]
-include = cat /usr/share/mr/git-fake-bare
-END
+    if [ ! -d "$LOCAL_REPOS" ]; then 
+       mkdir -p "$LOCAL_REPOS"
+    fi
 
+    mr -c "$MRCONFIG" config DEFAULT include="cat /usr/share/mr/git-fake-bare"
     
 }
 
+login() {
+    if [ $# -ne 1 ]; then 
+       usage
+    fi
+
+    export GIT_DIR="$LOCAL_REPOS/${1}.git"
+    export GIT_WORK_TREE="$GIT_DIR/$(git config --get core.worktree)"
+
+    GIT_PS1_SHOWUNTRACKEDFILES= PSMOVEIN="movein:${1}" $SHELL -i || :
+}
 
 add() {
     if [ $# -ne 1 ]; then 
@@ -136,17 +152,18 @@ add() {
        git remote add origin $REPO_URL
        git config branch.master.remote origin
        git config branch.master.merge refs/heads/master
-       git config core.worktree ../../
        git config core.bare false
-       GIT_WORK_TREE="$PWD" git pull
+       git config core.worktree ../../
+       git config status.showUntrackedFiles no
+       GIT_WORK_TREE="$LOCAL_REPO/../../" git pull
        trap - 0
-       cat <<END >> $MRCONFIG
 
-[$LOCAL_REPO]
-checkout = git_fake_bare_checkout '$REPO_URL' '$REPO_NAME' '../../'
-END
+       mr -c "$MRCONFIG" config "$LOCAL_REPO" checkout="git_fake_bare_checkout '$REPO_URL' 'REPO_NAME' '../../'"
     fi
+}
 
+list() {
+    find "${LOCAL_REPOS}" -mindepth 1 -maxdepth 1 -type d | sed 's,^.*/\([^/]*\).git$,\1,'
 }
 
 new() {
@@ -178,34 +195,45 @@ new() {
        git remote add origin $REPO_URL
        git config branch.master.remote origin
        git config branch.master.merge refs/heads/master
-       git config core.worktree ../../
        git config core.bare false
-#      for file in  ; do 
-       export GIT_WORK_TREE="$PWD"
-           git add "$@"
-#      done
+       git config core.worktree ../../
+       git config status.showUntrackedFiles no
+       export GIT_WORK_TREE="$LOCAL_REPO/../../"
+       git add "$@"
        git commit -m "initial checkin"
        git push --all
        
        trap - 0
-       cat <<END >> $MRCONFIG
 
-[$LOCAL_REPO]
-checkout = git_fake_bare_checkout '$REPO_URL' '$REPO_NAME' '../../'
-END
+       mr -c "$MRCONFIG" config "$LOCAL_REPO" checkout="git_fake_bare_checkout '$REPO_URL' 'REPO_NAME' '../../'"
     fi
 
 }
 
+
 command=$1 ; shift
 case "$command" in 
     init)
        init $@
        ;;
     add)
-        add $@
+       add $@
        ;;
     new)
-        new $@
+       new $@
+       ;;
+    login)
+       login $@
+       ;;
+    ls)
+       list
+       ;;
+    list)
+       list
+       ;;
+
+    *)
+       usage
+       exit 1
        ;;
 esac