X-Git-Url: https://git.madduck.net/etc/zsh.git/blobdiff_plain/05175deb43e4643176c377b9c7d2fe828c9dae30..9567c0145755a8997c8435ceea1189021d2abe30:/.zsh/func/vcsh

diff --git a/.zsh/func/vcsh b/.zsh/func/vcsh
index 655c9ea..083bc7d 100755
--- a/.zsh/func/vcsh
+++ b/.zsh/func/vcsh
@@ -1,4 +1,4 @@
-#!/bin/sh
+#!/bin/zsh
 #
 # func/vcsh
 #
@@ -7,23 +7,50 @@
 # Copyright © 1994–2008 martin f. krafft <madduck@madduck.net>
 # Released under the terms of the Artistic Licence 2.0
 #
-# Source repository: http://git.madduck.net/v/etc/zsh.git
+# Source repository: git://git.madduck.net/etc/zsh.git
 #
 
 local FGIT_BASE="$HOME/.fgits"
 
-if [ "${1:---help}" = '--help' ] || [ $# -gt 1 ]; then
-  echo "usage: ${0##*/} reponame" >&2
-  echo "usage: ${0##*/} -l" >&2
-  [ "$1" = '--help' ]
-  return $?
-
-elif [ "$1" = '-l' ]; then
-  for i in $FGIT_BASE/*.git; do
-    i="${i#$FGIT_BASE/}"
-    echo "${i%.git}"
-  done
-  return 0
+if [[ "$1" == '-l' ]]
+then
+   for i in $FGIT_BASE/*.git
+   do
+      i="${i#$FGIT_BASE/}"
+      echo "${i%.git}"
+   done
+   return 0
+elif [[ "$1" == '-c' ]]
+then
+   shift
+
+   if [[ -z "$1" ]]
+   then
+      echo "E: no repository name given" >&2
+      return 2
+   fi
+   if [[ -e "$FGIT_BASE/${1}.git" ]]
+   then
+      echo "E: repository '$1' still exists" >&2
+      return 2
+   fi
+
+   git init --bare "$FGIT_BASE/${1}.git"
+   cd "$FGIT_BASE/${1}.git"
+   git config core.bare false
+   git config core.worktree ../../
+   git config core.excludesfile "$FGIT_BASE/${1}.ignore"
+   cd -
+
+   [[ -e "$FGIT_BASE/${1}.ignore" ]] || echo "/*" > "$FGIT_BASE/${1}.ignore"
+fi
+if [[ "${1:---help}" == '--help' ]] || [[ $# -gt 1 ]]
+then
+   echo "usage: ${0##*/} reponame" >&2
+   echo "usage: ${0##*/} -l" >&2
+   echo "usage: ${0##*/} -c reponame" >&2
+   [ "$1" = '--help' ]
+   return $?
 fi
 
 if [ ! -d "$FGIT_BASE/${1}.git" ]; then
@@ -31,11 +58,15 @@ if [ ! -d "$FGIT_BASE/${1}.git" ]; then
   return 2
 fi
 
+old_GIT_DIR="${GIT_DIR:-}"
+old_GIT_WORK_TREE="${GIT_WORK_TREE:-}"
+
 export GIT_DIR="$FGIT_BASE/${1}.git"
-local _WORKTREE="$(git config --get core.worktree)"
-export GIT_WORK_TREE="$(readlink -f $GIT_DIR/$_WORKTREE)"
-unset _WORKTREE
+export GIT_WORK_TREE="$GIT_DIR/$(git config --get core.worktree)"
 
-git status
+PS1="%S{${0##*/}:$1}%s$PS1" $SHELL -i || :
 
-PS1="%S{${0##*/}:$1}%s$PS1" $SHELL -i
+GIT_DIR="$old_GIT_DIR"
+[ -z "$GIT_DIR" ] && unset GIT_DIR
+GIT_WORK_TREE="$old_GIT_WORK_TREE"
+[ -z "$GIT_WORK_TREE" ] && unset GIT_WORK_TREE