Merge "Improved branching tools"
This commit is contained in:
commit
99be4a94c7
@ -24,7 +24,7 @@ CREATE_BRANCHES_AND_TAGS_SH_DIR="$(dirname "$(readlink -f "${BASH_SOURCE[0]}" )"
|
|||||||
source "${CREATE_BRANCHES_AND_TAGS_SH_DIR}/../git-repo-utils.sh"
|
source "${CREATE_BRANCHES_AND_TAGS_SH_DIR}/../git-repo-utils.sh"
|
||||||
|
|
||||||
usage () {
|
usage () {
|
||||||
echo "create_branches_and_tags.sh --branch=<branch> [--tag=<tag>] [ --remotes=<remotes> ] [ --projects=<projects> ] [ --manifest [ --lock-down ]]"
|
echo "create_branches_and_tags.sh --branch=<branch> [--tag=<tag>] [ --remotes=<remotes> ] [ --projects=<projects> ] [ --gitreview-default ] [ --manifest [ --lock-down | --soft-lock-down ] [ --default-revision ]]"
|
||||||
echo ""
|
echo ""
|
||||||
echo "Create a branch and a tag in all listed projects, and all"
|
echo "Create a branch and a tag in all listed projects, and all"
|
||||||
echo "projects hosted by all listed remotes. Lists are comma separated."
|
echo "projects hosted by all listed remotes. Lists are comma separated."
|
||||||
@ -33,13 +33,19 @@ usage () {
|
|||||||
echo "If the tag is omitted, one is automativally generate by adding the"
|
echo "If the tag is omitted, one is automativally generate by adding the"
|
||||||
echo "prefix 'v' to the branch name."
|
echo "prefix 'v' to the branch name."
|
||||||
echo ""
|
echo ""
|
||||||
echo "If a manifest is requested, it will recieve the name '<branch>.xml' and"
|
echo "If a manifest is requested, the current manifest is modified."
|
||||||
echo "it will specify the branch as the revision for all tagged projects."
|
echo "to specify the new branch for all select remotes and projects."
|
||||||
echo "If lockdown is requested, all other projects get the current"
|
echo "If lockdown is requested, all other projects get the current"
|
||||||
echo "HEAD's sha set as the revision."
|
echo "HEAD's sha set as the revision."
|
||||||
|
echo "If default-revision is selected, then the manifest default revision"
|
||||||
|
wcho "will be set."
|
||||||
|
echo ""
|
||||||
|
echo "If a gitreview-default is selected, then all branched projects"
|
||||||
|
echo "with a .gitreview file will have a defaultbranch entry added"
|
||||||
|
echo "or updated."
|
||||||
}
|
}
|
||||||
|
|
||||||
TEMP=$(getopt -o h --long remotes:,projects:,branch:,tag:,manifest,lock-down,help -n 'create_branches_and_tags.sh' -- "$@")
|
TEMP=$(getopt -o h --long remotes:,projects:,branch:,tag:,manifest,lock-down,hard-lock-down,soft-lock-down,default-revision,gitreview-default,help -n 'create_branches_and_tags.sh' -- "$@")
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
usage
|
usage
|
||||||
exit 1
|
exit 1
|
||||||
@ -49,6 +55,8 @@ eval set -- "$TEMP"
|
|||||||
HELP=0
|
HELP=0
|
||||||
MANIFEST=0
|
MANIFEST=0
|
||||||
LOCK_DOWN=0
|
LOCK_DOWN=0
|
||||||
|
GITREVIEW_DEFAULT=0
|
||||||
|
SET_DEFAULT_REVISION=0
|
||||||
remotes=""
|
remotes=""
|
||||||
projects=""
|
projects=""
|
||||||
branch=""
|
branch=""
|
||||||
@ -59,15 +67,19 @@ repo_root_dir=""
|
|||||||
|
|
||||||
while true ; do
|
while true ; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
-h|--help) HELP=1 ; shift ;;
|
-h|--help) HELP=1 ; shift ;;
|
||||||
--remotes) remotes+=$(echo "$2 " | tr ',' ' '); shift 2;;
|
--remotes) remotes+=$(echo "$2 " | tr ',' ' '); shift 2;;
|
||||||
--projects) projects+=$(echo "$2 " | tr ',' ' '); shift 2;;
|
--projects) projects+=$(echo "$2 " | tr ',' ' '); shift 2;;
|
||||||
--branch) branch=$2; shift 2;;
|
--branch) branch=$2; shift 2;;
|
||||||
--tag) tag=$2; shift 2;;
|
--tag) tag=$2; shift 2;;
|
||||||
--manifest) MANIFEST=1 ; shift ;;
|
--manifest) MANIFEST=1 ; shift ;;
|
||||||
--lock-down) LOCK_DOWN=1 ; shift ;;
|
--lock-down) LOCK_DOWN=2 ; shift ;;
|
||||||
--) shift ; break ;;
|
--hard-lock-down) LOCK_DOWN=2 ; shift ;;
|
||||||
*) usage; exit 1 ;;
|
--soft-lock-down) LOCK_DOWN=1 ; shift ;;
|
||||||
|
--default-revision) SET_DEFAULT_REVISION=1 ; shift ;;
|
||||||
|
--gitreview-default) GITREVIEW_DEFAULT=1 ; shift ;;
|
||||||
|
--) shift ; break ;;
|
||||||
|
*) usage; exit 1 ;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
@ -88,6 +100,37 @@ if [ $? -ne 0 ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
update_gitreview () {
|
||||||
|
local DIR=$1
|
||||||
|
(
|
||||||
|
cd $DIR || exit 1
|
||||||
|
if [ $GITREVIEW_DEFAULT -eq 1 ] && [ -f .gitreview ]; then
|
||||||
|
if ! grep -q "^defaultbranch=$branch$" .gitreview; then
|
||||||
|
echo "Updating defaultbranch in ${DIR}/.gitreview"
|
||||||
|
if grep -q defaultbranch= .gitreview; then
|
||||||
|
sed "s#\(defaultbranch=\).*#\1$branch#" -i .gitreview
|
||||||
|
else
|
||||||
|
echo "defaultbranch=$branch" >> .gitreview
|
||||||
|
fi
|
||||||
|
|
||||||
|
git add .gitreview
|
||||||
|
if [ $? != 0 ] ; then
|
||||||
|
echo_stderr "ERROR: failed to add .gitreview in ${DIR}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
git commit -s -m "Update .gitreview for $branch"
|
||||||
|
if [ $? != 0 ] ; then
|
||||||
|
echo_stderr "ERROR: failed to commit .gitreview in ${DIR}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "defaultbranch in ${DIR}/.gitreview already set"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
if [ $MANIFEST -eq 1 ]; then
|
if [ $MANIFEST -eq 1 ]; then
|
||||||
manifest=$(repo_manifest $repo_root_dir)
|
manifest=$(repo_manifest $repo_root_dir)
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
@ -205,6 +248,7 @@ for subgit in $SUBGITS; do
|
|||||||
git checkout $branch
|
git checkout $branch
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# check if destination tag already exists
|
||||||
tag_check=$(git tag -l $tag)
|
tag_check=$(git tag -l $tag)
|
||||||
if [ -z "$tag_check" ]; then
|
if [ -z "$tag_check" ]; then
|
||||||
echo "Creating tag $tag in ${subgit}"
|
echo "Creating tag $tag in ${subgit}"
|
||||||
@ -216,6 +260,8 @@ for subgit in $SUBGITS; do
|
|||||||
else
|
else
|
||||||
echo "Tag '$tag' already exists in ${subgit}"
|
echo "Tag '$tag' already exists in ${subgit}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
update_gitreview ${subgit} || exit 1
|
||||||
) || exit 1
|
) || exit 1
|
||||||
done
|
done
|
||||||
) || exit 1
|
) || exit 1
|
||||||
@ -276,8 +322,10 @@ if [ $MANIFEST -eq 1 ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
update_gitreview ${manifest_dir} || exit 1
|
||||||
|
|
||||||
echo "Creating manifest ${new_manifest_name}"
|
echo "Creating manifest ${new_manifest_name}"
|
||||||
manifest_set_revision "${manifest}" "${new_manifest}" "$branch" ${LOCK_DOWN} $projects || exit 1
|
manifest_set_revision "${manifest}" "${new_manifest}" "$branch" ${LOCK_DOWN} ${SET_DEFAULT_REVISION} $projects || exit 1
|
||||||
|
|
||||||
echo "Move manifest ${new_manifest_name}, overwriting ${manifest_name}"
|
echo "Move manifest ${new_manifest_name}, overwriting ${manifest_name}"
|
||||||
\cp -f "${manifest}" "${manifest}.save"
|
\cp -f "${manifest}" "${manifest}.save"
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
PUSH_BRANCHES_TAGS_SH_DIR="$(dirname "$(readlink -f "${BASH_SOURCE[0]}" )" )"
|
PUSH_BRANCHES_TAGS_SH_DIR="$(dirname "$(readlink -f "${BASH_SOURCE[0]}" )" )"
|
||||||
|
|
||||||
source "${PUSH_BRANCHES_TAGS_SH_DIR}/../git-repo-utils.sh"
|
source "${PUSH_BRANCHES_TAGS_SH_DIR}/../git-repo-utils.sh"
|
||||||
|
source "${PUSH_BRANCHES_TAGS_SH_DIR}/../url_utils.sh"
|
||||||
|
|
||||||
usage () {
|
usage () {
|
||||||
echo "push_branches_tags.sh --branch=<branch> [--tag=<tag>] [ --remotes=<remotes> ] [ --projects=<projects> ] [ --manifest ]"
|
echo "push_branches_tags.sh --branch=<branch> [--tag=<tag>] [ --remotes=<remotes> ] [ --projects=<projects> ] [ --manifest ]"
|
||||||
@ -151,6 +152,8 @@ for subgit in $SUBGITS; do
|
|||||||
(
|
(
|
||||||
cd $subgit
|
cd $subgit
|
||||||
|
|
||||||
|
git fetch --all
|
||||||
|
|
||||||
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_stderr "ERROR: Expected branch '$branch' to exist in ${subgit}"
|
echo_stderr "ERROR: Expected branch '$branch' to exist in ${subgit}"
|
||||||
@ -169,21 +172,49 @@ for subgit in $SUBGITS; do
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${review_method}" == "gerrit" ]; then
|
remote=$(git_remote)
|
||||||
remote=$(git_repo_review_remote)
|
if [ "${remote}" == "" ]; then
|
||||||
else
|
echo_stderr "ERROR: Failed to determine remote in ${manifest_dir}"
|
||||||
remote=$(git_repo_remote)
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "${remote}" == "" ]; then
|
if [ "${review_method}" == "gerrit" ]; then
|
||||||
echo_stderr "ERROR: Failed to determine remote in ${subgit}"
|
review_remote=$(git_repo_review_remote)
|
||||||
|
else
|
||||||
|
review_remote=${remote}
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${review_remote}" == "" ]; then
|
||||||
|
echo_stderr "ERROR: Failed to determine review_remote in ${subgit}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
branch_check=$(git branch -a --list $remote/$branch)
|
||||||
|
if [ "${branch_check}" != "" ]; then
|
||||||
|
echo "Branch $branch already exists in ${subgit}"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
echo "Pushing branch $branch in ${subgit}"
|
echo "Pushing branch $branch in ${subgit}"
|
||||||
if [ "${review_method}" == "gerrit" ]; then
|
if [ "${review_method}" == "gerrit" ]; then
|
||||||
echo "git push --tags ${remote} ${branch}"
|
url=$(git_repo_review_url)
|
||||||
git push --tags ${remote} ${branch}
|
if [ "${review_remote}" == "" ]; then
|
||||||
|
echo_stderr "ERROR: Failed to determine review_url in ${subgit}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
host=$(url_server "${url}")
|
||||||
|
port=$(url_port "${url}")
|
||||||
|
path=$(url_path "${url}")
|
||||||
|
if [ "${host}" == "review.opendev.org" ]; then
|
||||||
|
git push ${review_remote} ${tag} && \
|
||||||
|
ssh -p ${port} ${host} gerrit create-branch ${path} ${branch} ${tag} && \
|
||||||
|
git config --local --replace-all "branch.${branch}.merge" refs/heads/${branch} && \
|
||||||
|
git review --topic="${branch}"
|
||||||
|
else
|
||||||
|
echo "git push --tags ${remote} ${branch}"
|
||||||
|
git push --tags ${remote} ${branch}
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
echo "git push --tags --set-upstream ${remote} ${branch}"
|
echo "git push --tags --set-upstream ${remote} ${branch}"
|
||||||
git push --tags --set-upstream ${remote} ${branch}
|
git push --tags --set-upstream ${remote} ${branch}
|
||||||
@ -232,23 +263,44 @@ if [ $MANIFEST -eq 1 ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
remote=$(git_remote)
|
||||||
remote=$(git_review_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
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
review_remote=$(git_review_remote)
|
||||||
|
if [ "${review_remote}" == "" ]; then
|
||||||
|
echo_stderr "ERROR: Failed to determine review_remote in ${manifest_dir}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
echo "Pushing branch $branch in ${manifest_dir}"
|
echo "Pushing branch $branch in ${manifest_dir}"
|
||||||
if [ "${review_method}" == "gerrit" ]; then
|
if [ "${review_method}" == "gerrit" ]; then
|
||||||
# Is a reviewless push possible as part of creating a new branch in gerrit?
|
# Is a reviewless push possible as part of creating a new branch in gerrit?
|
||||||
git push --tags ${remote} ${branch}
|
url=$(git_review_url)
|
||||||
|
if [ "${review_remote}" == "" ]; then
|
||||||
|
echo_stderr "ERROR: Failed to determine review_url in ${subgit}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
host=$(url_server "${url}")
|
||||||
|
port=$(url_port "${url}")
|
||||||
|
path=$(url_path "${url}")
|
||||||
|
if [ "${host}" == "review.opendev.org" ]; then
|
||||||
|
git push ${review_remote} ${tag} && \
|
||||||
|
ssh -p ${port} ${host} gerrit create-branch ${path} ${branch} ${tag} && \
|
||||||
|
git config --local --replace-all "branch.${branch}.merge" refs/heads/${branch} && \
|
||||||
|
git review --yes --topic="${branch}"
|
||||||
|
else
|
||||||
|
git push --tags ${review_remote} ${branch}
|
||||||
|
fi
|
||||||
else
|
else
|
||||||
git push --tags --set-upstream ${remote} ${branch}
|
git push --tags --set-upstream ${review_remote} ${branch}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ $? != 0 ] ; then
|
if [ $? != 0 ] ; then
|
||||||
echo_stderr "ERROR: Failed to push tag '${tag}' to remote '${remote}' in ${manifest_dir}"
|
echo_stderr "ERROR: Failed to push tag '${tag}' to remote '${review_remote}' in ${manifest_dir}"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
) || exit 1
|
) || exit 1
|
||||||
|
@ -140,6 +140,50 @@ repo_is_project () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# manifest_get_revision_of_project <manifest> <project-name>
|
||||||
|
#
|
||||||
|
# Extract the revision of a project within the manifest.
|
||||||
|
# The default revision is supplied in the absence
|
||||||
|
# of an explicit project revision.
|
||||||
|
#
|
||||||
|
# manifest = Path to manifest.
|
||||||
|
# project-name = name of project.
|
||||||
|
#
|
||||||
|
manifest_get_revision_of_project () {
|
||||||
|
local manifest="${1}"
|
||||||
|
local project="${2}"
|
||||||
|
|
||||||
|
local default_revision=""
|
||||||
|
local revision=""
|
||||||
|
|
||||||
|
default_revision=$(manifest_get_default_revision "${manifest}")
|
||||||
|
revision=$(grep '<project' "${manifest}" | \
|
||||||
|
grep -e "name=${project}" -e "name=\"${project}\"" | \
|
||||||
|
grep 'revision=' | \
|
||||||
|
sed -e 's#.*revision=\([^ ]*\).*#\1#' -e 's#"##g' -e "s#'##g")
|
||||||
|
if [ "${revision}" != "" ]; then
|
||||||
|
echo "${revision}"
|
||||||
|
elif [ "${default_revision}" != "" ]; then
|
||||||
|
echo "${default_revision}"
|
||||||
|
else
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# manifest_get_default_revision <manifest>
|
||||||
|
#
|
||||||
|
# Extract the default revision of the manifest, if any.
|
||||||
|
#
|
||||||
|
# manifest = Path to manifest.
|
||||||
|
#
|
||||||
|
manifest_get_default_revision () {
|
||||||
|
local manifest="${1}"
|
||||||
|
|
||||||
|
grep '<default' $manifest |sed -e 's#.*revision=\([^ ]*\).*#\1#' -e 's#"##g' -e "s#'##g"
|
||||||
|
}
|
||||||
|
|
||||||
#
|
#
|
||||||
# manifest_set_revision <old_manifest> <new_manifest> <revision> <lock_down> <project-list>
|
# manifest_set_revision <old_manifest> <new_manifest> <revision> <lock_down> <project-list>
|
||||||
#
|
#
|
||||||
@ -149,8 +193,10 @@ repo_is_project () {
|
|||||||
# revision = A branch, tag ,or sha. Branch and SHA can be used
|
# revision = A branch, tag ,or sha. Branch and SHA can be used
|
||||||
# directly, but repo requires that a tag be in the form
|
# directly, but repo requires that a tag be in the form
|
||||||
# "refs/tags/<tag-name>".
|
# "refs/tags/<tag-name>".
|
||||||
# lock_down = 0 or 1. If 1, set a revision on all other non-listed
|
# lock_down = 0,1 or 2. If 2, set a revision on all other non-listed
|
||||||
# projects to equal the SHA of the current git head.
|
# projects to equal the SHA of the current git head.
|
||||||
|
# If 1, similar to 2, but only if the project doesn't have
|
||||||
|
# some other form of revision specified.
|
||||||
# project-list = A space seperated list of projects. Listed projects
|
# project-list = A space seperated list of projects. Listed projects
|
||||||
# will have their revision set to the provided revision
|
# will have their revision set to the provided revision
|
||||||
# value.
|
# value.
|
||||||
@ -160,9 +206,11 @@ manifest_set_revision () {
|
|||||||
local new_manifest="${2}"
|
local new_manifest="${2}"
|
||||||
local revision="${3}"
|
local revision="${3}"
|
||||||
local lock_down="${4}"
|
local lock_down="${4}"
|
||||||
shift 4
|
local set_default="${5}"
|
||||||
|
shift 5
|
||||||
local projects="${@}"
|
local projects="${@}"
|
||||||
|
|
||||||
|
local old_default_revision=""
|
||||||
local repo_root_dir=""
|
local repo_root_dir=""
|
||||||
local line=""
|
local line=""
|
||||||
local FOUND=0
|
local FOUND=0
|
||||||
@ -192,11 +240,32 @@ manifest_set_revision () {
|
|||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
old_default_revision=$(manifest_get_default_revision "${old_manifest}")
|
||||||
|
if [ ${set_default} -eq 1 ] && [ "${old_default_revision}" == "" ]; then
|
||||||
|
# We only know how to alter an existing default revision, not set a
|
||||||
|
# new one, so continue without setting a default.
|
||||||
|
set_default=0
|
||||||
|
fi
|
||||||
|
|
||||||
while IFS= read -r line; do
|
while IFS= read -r line; do
|
||||||
echo "${line}" | grep -q '<project'
|
echo "${line}" | grep -q '<project'
|
||||||
if [ $? -ne 0 ]; then
|
if [ $? -ne 0 ]; then
|
||||||
# Line does not define a project, do not modify
|
# Line does not define a project
|
||||||
echo "${line}"
|
if [ ${set_default} -eq 0 ] || [ "${old_default_revision}" == "" ]; then
|
||||||
|
# No further processing, do not modify
|
||||||
|
echo "${line}"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
# ok setting the default
|
||||||
|
echo "${line}" | grep -q '<default'
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
# Line does not set defaults, do not modify
|
||||||
|
echo "${line}"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "${line}" | sed "s#${old_default_revision}#${revision}#"
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -211,15 +280,58 @@ manifest_set_revision () {
|
|||||||
done
|
done
|
||||||
|
|
||||||
rev=${revision}
|
rev=${revision}
|
||||||
|
old_rev=$(echo "${line}" | grep 'revision=' | sed -e 's#.*revision=\([^ ]*\).*#\1#' -e 's#"##g' -e "s#'##g")
|
||||||
if [ $FOUND -eq 0 ]; then
|
if [ $FOUND -eq 0 ]; then
|
||||||
# A non-selected project
|
# A non-selected project
|
||||||
if [ ${lock_down} -eq 0 ]; then
|
if [ ${lock_down} -eq 2 ]; then
|
||||||
echo "${line}"
|
# Hard lock-down
|
||||||
|
# Set the revision to current HEAD SHA.
|
||||||
|
path="${repo_root_dir}/$(echo "${line}" | sed 's#.*path="\([^"]*\)".*#\1#')"
|
||||||
|
rev=$(cd "${path}"; git rev-parse HEAD)
|
||||||
|
elif [ ${lock_down} -eq 1 ] && [ "${old_rev}" == "" ]; then
|
||||||
|
# Soft lock-down but no revision is currently set on the project.
|
||||||
|
# Set the revision to current HEAD SHA.
|
||||||
|
path="${repo_root_dir}/$(echo "${line}" | sed 's#.*path="\([^"]*\)".*#\1#')"
|
||||||
|
rev=$(cd "${path}"; git rev-parse HEAD)
|
||||||
|
elif [ ${lock_down} -eq 1 ] && [ "${old_rev}" == "master" ]; then
|
||||||
|
# Soft lock-down and project has revision set to 'master' which is definitly unstable.
|
||||||
|
# Set the revision to current HEAD SHA.
|
||||||
|
path="${repo_root_dir}/$(echo "${line}" | sed 's#.*path="\([^"]*\)".*#\1#')"
|
||||||
|
rev=$(cd "${path}"; git rev-parse HEAD)
|
||||||
|
else
|
||||||
|
if [ ${set_default} -eq 0 ] || [ "${old_default_revision}" == "${revision}" ]; then
|
||||||
|
# default revision unchanged, leave it be
|
||||||
|
echo "${line}"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "${old_rev}" != "" ]; then
|
||||||
|
# Non-selected project has an explicit revision, leave it be
|
||||||
|
echo "${line}"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
# The default revision will change, but this project, which
|
||||||
|
# relied on the old default, is not supposed to change,
|
||||||
|
# so it's revision must now be explicitly set to point to
|
||||||
|
# the old default revision.
|
||||||
|
rev="${old_default_revision}"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
# A selected project
|
||||||
|
if [ ${set_default} -eq 1 ]; then
|
||||||
|
# Selected project does not need to set a revision.
|
||||||
|
# The revision will come from the default
|
||||||
|
if [ "${old_rev}" == "" ]; then
|
||||||
|
# project has no revision to delete
|
||||||
|
echo "${line}"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
|
||||||
|
# delete any revision present
|
||||||
|
echo "${line}" | sed 's#\(.*\)revision=[^ ]*\(.*\)#\1\2#'
|
||||||
continue
|
continue
|
||||||
fi
|
fi
|
||||||
|
|
||||||
path="${repo_root_dir}/$(echo "${line}" | sed 's#.*path="\([^"]*\)".*#\1#')"
|
|
||||||
rev=$(cd "${path}"; git rev-parse HEAD)
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Need to set revision on selected project
|
# Need to set revision on selected project
|
||||||
|
267
build-tools/url_utils.sh
Executable file
267
build-tools/url_utils.sh
Executable file
@ -0,0 +1,267 @@
|
|||||||
|
#
|
||||||
|
# SPDX-License-Identifier: Apache-2.0
|
||||||
|
#
|
||||||
|
# A set of bash utility functions to parse a URL.
|
||||||
|
# This script was originated by Scott Little
|
||||||
|
#
|
||||||
|
|
||||||
|
url_protocol () {
|
||||||
|
local URL="$1"
|
||||||
|
|
||||||
|
if [ "$URL" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if echo "$URL" | grep -q '[:][/][/]' ;then
|
||||||
|
echo "$URL" | sed 's#^\(.*\)://.*$#\1#'
|
||||||
|
else
|
||||||
|
echo "http"
|
||||||
|
fi
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
url_login () {
|
||||||
|
local URL="$1"
|
||||||
|
|
||||||
|
if [ "$URL" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$URL" | sed 's#^.*://\([^/]*\)/.*$#\1#'
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
url_user () {
|
||||||
|
local URL="$1"
|
||||||
|
local LOGIN
|
||||||
|
|
||||||
|
if [ "$URL" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
url_login "$URL" | sed -e '/@/! s#.*## ; s#\([^@]*\)@.*#\1#'
|
||||||
|
if [ ${PIPESTATUS[0]} -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): url_login failed"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
url_port () {
|
||||||
|
local URL="$1"
|
||||||
|
local LOGIN
|
||||||
|
|
||||||
|
if [ "$URL" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
url_login "$URL" | sed -e '/:/! s#.*## ; s#[^:]*:\([^:]*\)#\1#'
|
||||||
|
if [ ${PIPESTATUS[0]} -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): url_login failed"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
url_server () {
|
||||||
|
local URL="$1"
|
||||||
|
local LOGIN
|
||||||
|
|
||||||
|
if [ "$URL" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
url_login "$URL" | sed 's#^.*@## ; s#:.*$##'
|
||||||
|
if [ ${PIPESTATUS[0]} -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): url_login failed"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
url_path () {
|
||||||
|
local URL="$1"
|
||||||
|
|
||||||
|
if [ "$URL" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$URL" | sed 's#^.*://[^/]*/\(.*\)$#\1#'
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# url_path_to_fs_path:
|
||||||
|
#
|
||||||
|
# Convert url format path to file system format.
|
||||||
|
# e.g. replace %20 with ' '.
|
||||||
|
#
|
||||||
|
# Note: Does NOT test the output path to ensure there are
|
||||||
|
# no illegal file system characters.
|
||||||
|
#
|
||||||
|
url_path_to_fs_path () {
|
||||||
|
local INPUT_PATH="$1"
|
||||||
|
local TEMP
|
||||||
|
|
||||||
|
if [ "$INPUT_PATH" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Deviate from URI spec by not substituding '+' with ' '.
|
||||||
|
# It would alias '%20' and we need unique mappings.
|
||||||
|
# TEMP="${INPUT_PATH//+/ }"
|
||||||
|
|
||||||
|
TEMP="$INPUT_PATH"
|
||||||
|
printf '%b' "${TEMP//%/\\x}"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# fs_path_to_url_path:
|
||||||
|
#
|
||||||
|
# Convert file system format path to url format.
|
||||||
|
# e.g. replace ' ' with %20.
|
||||||
|
#
|
||||||
|
fs_path_to_url_path () {
|
||||||
|
local INPUT_PATH="$1"
|
||||||
|
local LENGTH
|
||||||
|
local POS
|
||||||
|
local CHAR
|
||||||
|
|
||||||
|
if [ "$INPUT_PATH" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
LENGTH="${#INPUT_PATH}"
|
||||||
|
for (( POS = 0; POS < LENGTH; POS++ )); do
|
||||||
|
CHAR="${1:POS:1}"
|
||||||
|
case $CHAR in
|
||||||
|
[/a-zA-Z0-9.~_-])
|
||||||
|
# Reference https://metacpan.org/pod/URI::Escape
|
||||||
|
printf "$CHAR"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
printf '%%%02X' "'$CHAR"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
#
|
||||||
|
# normalize_path:
|
||||||
|
#
|
||||||
|
# 1) replace // with /
|
||||||
|
# 2) replace /./ with /
|
||||||
|
# 3) Remove trailing /
|
||||||
|
# 4) Remove leading ./
|
||||||
|
#
|
||||||
|
|
||||||
|
normalize_path () {
|
||||||
|
local INPUT_PATH="$1"
|
||||||
|
|
||||||
|
if [ "$INPUT_PATH" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$INPUT_PATH" | sed 's#[/]\+#/#g ; s#[/][.][/]#/#g ; s#/$## ; s#^[.]/##'
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#
|
||||||
|
# repo_url_to_sub_path:
|
||||||
|
#
|
||||||
|
repo_url_to_sub_path () {
|
||||||
|
local URL="$1"
|
||||||
|
local FAMILY=""
|
||||||
|
local SERVER=""
|
||||||
|
local URL_PATH=""
|
||||||
|
local FS_PATH=""
|
||||||
|
|
||||||
|
if [ "$URL" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# set FAMILY from URL
|
||||||
|
echo $URL | grep -q 'centos[.]org' && FAMILY=centos
|
||||||
|
echo $URL | grep -q 'fedoraproject[.]org[/]pub[/]epel' && FAMILY=epel
|
||||||
|
|
||||||
|
SERVER=$(url_server "$URL")
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): url_server '$URL'"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
URL_PATH="$(url_path "$URL")"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): url_path '$URL'"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
FS_PATH="$(url_path_to_fs_path "$URL_PATH")"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): url_path_to_fs_path '$URL_PATH'"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
FS_PATH="$(normalize_path "$FS_PATH")"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): normalize_path '$FS_PATH'"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
normalize_path "./$FAMILY/$SERVER/$FS_PATH"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): normalize_path './$FAMILY/$SERVER/$FS_PATH'"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
CENGN_PROTOCOL="http"
|
||||||
|
CENGN_HOST="mirror.starlingx.cengn.ca"
|
||||||
|
CENGN_PORT="80"
|
||||||
|
CENGN_URL_ROOT="mirror"
|
||||||
|
|
||||||
|
url_to_stx_mirror_url () {
|
||||||
|
local URL="$1"
|
||||||
|
local DISTRO="$2"
|
||||||
|
local URL_PATH=""
|
||||||
|
local FS_PATH=""
|
||||||
|
|
||||||
|
if [ "$URL" == "" ] || [ "$DISTRO" == "" ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): empty argument"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
FS_PATH="$(repo_url_to_sub_path "$URL")"
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): repo_url_to_sub_path '$URL'"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
URL_PATH=$(fs_path_to_url_path "$FS_PATH")
|
||||||
|
if [ $? -ne 0 ]; then
|
||||||
|
>&2 echo "Error: $FUNCNAME (${LINENO}): fs_path_to_url_path '$FS_PATH'"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$CENGN_PROTOCOL://$CENGN_HOST:$CENGN_PORT/$CENGN_URL_ROOT/$DISTRO/$URL_PATH"
|
||||||
|
return 0
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user