fix several issues with branching tools
- force review method to 'default' if --bypass-gerrit is selected. - Allow local branch creation even if remote tracvking branch is undetermined. - allow git-utils to call into git-repo-utils to determine the prefered remote rather than guessing without repo's help. - allow git_local_branch to return 'HEAD' if there is no better answer. - git_remote must never return multiple remotes when falling back to git_list_remotes. - git_remote_branch must never return a tag. Signed-off-by: Scott Little <scott.little@windriver.com> Change-Id: Ib1ea9d4ced601e48ac6b5f41c629c9dae82e8108
This commit is contained in:
parent
7c4121a17f
commit
ddd4d8792b
@ -383,18 +383,19 @@ for subgit in $SUBGITS; do
|
|||||||
remote_branch=$(git_repo_remote_branch)
|
remote_branch=$(git_repo_remote_branch)
|
||||||
if [ "${remote_branch}" == "" ]; then
|
if [ "${remote_branch}" == "" ]; then
|
||||||
remote_branch=$(git_remote_branch)
|
remote_branch=$(git_remote_branch)
|
||||||
if [ "${remote_branch}" == "" ]; then
|
fi
|
||||||
echo_stderr "ERROR: failed to determine remote branch in ${subgit}"
|
|
||||||
exit 1
|
extra_args=""
|
||||||
fi
|
if [ "${remote_branch}" != "" ]; then
|
||||||
|
extra_args="-t ${remote}/${remote_branch}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# check if destination branch already exists
|
# check if destination branch already exists
|
||||||
branch_check=$(git branch -a --list $branch)
|
branch_check=$(git branch -a --list $branch)
|
||||||
if [ -z "$branch_check" ]; then
|
if [ -z "$branch_check" ]; then
|
||||||
echo "Creating branch $branch in $subgit"
|
echo "Creating branch $branch in $subgit"
|
||||||
echo " git checkout -t ${remote}/${remote_branch} -b $branch"
|
echo " git checkout ${extra_args} -b $branch"
|
||||||
git checkout -t ${remote}/${remote_branch} -b $branch
|
git checkout ${extra_args} -b $branch
|
||||||
if [ $? != 0 ] ; then
|
if [ $? != 0 ] ; then
|
||||||
echo_stderr "ERROR: failed to create branch '$branch' in ${subgit}"
|
echo_stderr "ERROR: failed to create branch '$branch' in ${subgit}"
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -215,13 +215,17 @@ for subgit in $SUBGITS; do
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
review_method=$(git_repo_review_method)
|
if [ $BYPASS_GERRIT -eq 0 ]; then
|
||||||
if [ "${review_method}" == "" ]; then
|
review_method=$(git_repo_review_method)
|
||||||
echo_stderr "ERROR: Failed to determine review method in ${subgit}"
|
if [ "${review_method}" == "" ]; then
|
||||||
exit 1
|
echo_stderr "ERROR: Failed to determine review method in ${subgit}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
review_method='default'
|
||||||
fi
|
fi
|
||||||
|
|
||||||
remote=$(git_remote)
|
remote=$(git_repo_remote)
|
||||||
if [ "${remote}" == "" ]; then
|
if [ "${remote}" == "" ]; then
|
||||||
echo_stderr "ERROR: Failed to determine remote in ${manifest_dir}"
|
echo_stderr "ERROR: Failed to determine remote in ${manifest_dir}"
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -24,6 +24,9 @@ source ${GIT_REPO_UTILS_DIR}/repo-utils.sh
|
|||||||
source ${GIT_REPO_UTILS_DIR}/git-utils.sh
|
source ${GIT_REPO_UTILS_DIR}/git-utils.sh
|
||||||
source ${GIT_REPO_UTILS_DIR}/url_utils.sh
|
source ${GIT_REPO_UTILS_DIR}/url_utils.sh
|
||||||
|
|
||||||
|
git_remote_fp="git_repo_remote"
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# git_repo_rel_dir [<dir>]:
|
# git_repo_rel_dir [<dir>]:
|
||||||
# Return the relative directory of a git within a repo.
|
# Return the relative directory of a git within a repo.
|
||||||
|
@ -15,6 +15,10 @@ GIT_UTILS_DIR="$(dirname "$(readlink -f "${BASH_SOURCE[0]}" )" )"
|
|||||||
|
|
||||||
source ${GIT_UTILS_DIR}/utils.sh
|
source ${GIT_UTILS_DIR}/utils.sh
|
||||||
|
|
||||||
|
# pseudo function pointer for git_remote (fallback) or git_repo_remote (preferred)
|
||||||
|
if [ -z git_remote_fp ]; then
|
||||||
|
git_remote_fp="git_remote"
|
||||||
|
fi
|
||||||
|
|
||||||
git_ctx_root_dir () {
|
git_ctx_root_dir () {
|
||||||
dirname "${MY_REPO}"
|
dirname "${MY_REPO}"
|
||||||
@ -427,6 +431,7 @@ git_local_branch () {
|
|||||||
# This used to work on older git versions
|
# This used to work on older git versions
|
||||||
result=$(git name-rev --name-only HEAD)
|
result=$(git name-rev --name-only HEAD)
|
||||||
if [ "$result" == "" ] || [ "$result" == "undefined" ]; then
|
if [ "$result" == "" ] || [ "$result" == "undefined" ]; then
|
||||||
|
echo "HEAD"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -436,6 +441,7 @@ git_local_branch () {
|
|||||||
while git_is_tag $result; do
|
while git_is_tag $result; do
|
||||||
result=$(git name-rev --name-only $result^1 )
|
result=$(git name-rev --name-only $result^1 )
|
||||||
if [ "$result" == "" ] || [ "$result" == "undefined" ]; then
|
if [ "$result" == "" ] || [ "$result" == "undefined" ]; then
|
||||||
|
echo "HEAD"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
@ -447,6 +453,7 @@ git_list_remotes () {
|
|||||||
git remote | grep -v gerrit
|
git remote | grep -v gerrit
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
git_remote () {
|
git_remote () {
|
||||||
local DIR="${1:-${PWD}}"
|
local DIR="${1:-${PWD}}"
|
||||||
|
|
||||||
@ -455,7 +462,7 @@ git_remote () {
|
|||||||
local_branch=$(git_local_branch) || return 1
|
local_branch=$(git_local_branch) || return 1
|
||||||
|
|
||||||
# Return remote of current local branch, else default remote.
|
# Return remote of current local branch, else default remote.
|
||||||
git config branch.${local_branch}.remote || git_list_remotes
|
git config branch.${local_branch}.remote || git_list_remotes | head -n 1
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -473,13 +480,13 @@ git_remote_branch () {
|
|||||||
# Our best bet is if the git config shows the local
|
# Our best bet is if the git config shows the local
|
||||||
# branch is tracking a remote branch.
|
# branch is tracking a remote branch.
|
||||||
local_branch=$(git_local_branch) || return 1
|
local_branch=$(git_local_branch) || return 1
|
||||||
git config branch.${local_branch}.merge | sed 's#^refs/heads/##'
|
git config branch.${local_branch}.merge | grep -v '^refs/tags/' | sed 's#^refs/heads/##'
|
||||||
if [ ${PIPESTATUS[0]} -eq 0 ]; then
|
if [ ${PIPESTATUS[0]} -eq 0 ]; then
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Before we can select a remote branch, we need to know which remote.
|
# Before we can select a remote branch, we need to know which remote.
|
||||||
remote=$(git_remote)
|
remote=$($git_remote_fp)
|
||||||
if [ $? -ne 0 ] || [ "$remote" == "" ]; then
|
if [ $? -ne 0 ] || [ "$remote" == "" ]; then
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
Loading…
Reference in New Issue
Block a user