All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@git.madduck.net.
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
We have to jump through hoops to check out fake-bare repositories since
the target directory probably already exists. Thus, we cheat by telling
git-clone *not* to checkout and then read-tree and checkout-index
ourselves. We also convert the non-bare repository to a fake bare one by
moving stuff around.
Probably a bit hackish but this is the best I can do for now.
if [ -z "$url" ]; then
error "cannot determine git url"
fi
if [ -z "$url" ]; then
error "cannot determine git url"
fi
+ local clone_opts add_cmd work_tree suffix
- bare|fake-bare)
- # this seems like a bare repo as it has no
- # worktree.
- local work_tree
+ fake-bare)
+ # this seems like a fake bare repo and needs a worktree
work_tree="$(git-config --get core.worktree)" || :
work_tree="$(git-config --get core.worktree)" || :
+ work_tree="${work_tree%%/}/"
if [ ! -d "$work_tree" ]; then
if [ ! -d "$work_tree" ]; then
- error "git worktree $work_tree does not exist"
+ error "git worktree '$work_tree' does not exist"
+ clone_opts=" --no-checkout"
+ add_cmd="$add_cmd && cd $basedir"
+ add_cmd="$add_cmd && git read-tree HEAD"
+ add_cmd="$add_cmd && git checkout-index -a --prefix='$work_tree' || :"
+ add_cmd="$add_cmd; git config core.worktree '$work_tree'"
+ add_cmd="$add_cmd && mv .git/* . && rmdir .git"
suffix=" (with worktree $work_tree)"
suffix=" (with worktree $work_tree)"
- mr -c "$MR_CONFIG" config "$PWD" \
- lib="GIT_WORK_TREE=$work_tree; export GIT_WORK_TREE"
+ ;;
+ bare)
+ clone_opts=" --bare"
+ suffix=" (bare repository)"
;;
esac
echo "Registering git url: $url in $MR_CONFIG${suffix:-}"
;;
esac
echo "Registering git url: $url in $MR_CONFIG${suffix:-}"
- mr -c "$MR_CONFIG" config "$PWD" checkout="git clone $url $basedir"
+ mr -c "$MR_CONFIG" config "$PWD" checkout="git clone${clone_opts:-} $url $basedir${add_cmd:-}"
;;
bzr)
url=$(cat .bzr/branch/parent)
;;
bzr)
url=$(cat .bzr/branch/parent)