X-Git-Url: https://git.madduck.net/code/vcsh.git/blobdiff_plain/8659c804cad99f97a6325590be2f8c90874fa470..9e324980073d450b700cfeb1952adee2dabd0ddb:/vcsh diff --git a/vcsh b/vcsh index e07cffb..898bdb5 100755 --- a/vcsh +++ b/vcsh @@ -146,13 +146,14 @@ clone() { hook pre-clone init git remote add origin "$GIT_REMOTE" - git config branch.master.remote origin - git config branch.master.merge refs/heads/master - if [ $(git ls-remote origin master 2> /dev/null | wc -l ) -lt 1 ]; then + git config branch."$VCSH_BRANCH".remote origin + git config branch."$VCSH_BRANCH".merge refs/heads/"$VCSH_BRANCH" + git checkout -b $VCSH_BRANCH + if [ $(git ls-remote origin "$VCSH_BRANCH" 2> /dev/null | wc -l ) -lt 1 ]; then info "remote is empty, not merging anything" exit fi - git fetch + git fetch origin "$VCSH_BRANCH" hook pre-merge git ls-tree -r --name-only origin/master | (while read object; do [ -e "$object" ] && @@ -162,7 +163,7 @@ clone() { [ x"$VCSH_CONFLICT" = x'1' ]) && fatal "will stop after fetching and not try to merge! Once this situation has been resolved, run 'vcsh $VCSH_REPO_NAME pull' to finish cloning." 17 - git merge origin/master + git merge origin/"$VCSH_BRANCH" hook post-merge hook post-clone retire @@ -244,12 +245,14 @@ get_files() { list_tracked() { for VCSH_REPO_NAME in $(list); do get_files - done | sort -u + done | sed "s,^,$(printf '%s\n' "$VCSH_BASE/" | \ + sed 's/[,\&]/\\&/g')," | sort -u } list_tracked_by() { use - git ls-files | sort -u + git ls-files | sed "s,^,$(printf '%s\n' "$VCSH_BASE/" | \ + sed 's/[,\&]/\\&/g')," | sort -u } pull() {