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:
Scott Little 2023-09-23 18:51:20 -04:00
parent 7c4121a17f
commit ddd4d8792b
4 changed files with 29 additions and 14 deletions

View File

@ -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

View File

@ -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

View File

@ -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.

View File

@ -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