mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-31 02:37:10 +00:00 
			
		
		
		
	build: Refactor the earlier "basebranch" commit
Recap from earlier commit:  If you have a development branch for a
major project that will receive gerrit reviews it'll probably be
named something like "development/16/newproject" or a work branch
based on that "development" branch.  That will necessitate
setting "defaultbranch=development/16/newproject" in .gitreview.
The make_version script uses that variable to construct the
asterisk version however, which results in versions
like "GIT-development/16/newproject-ee582a8c7b" which is probably
not what you want.  It also constructs the URLs for downloading
external modules with that version, which will fail.
Fast-forward:
The earlier attempt at adding a "basebranch" variable to
.gitreview didn't work out too well in practice because changes
were made to .gitreview, which is a checked-in file.  So, if
you wanted to rebase your work branch on the base branch, rebase
would attempt to overwrite your .gitreview with the one from
the base branch and complain about a conflict.
This is a slighltly different approach that adds three methods to
determine the mainline branch:
1.  --- MAINLINE_BRANCH from the environment
If MAINLINE_BRANCH is already set in the environment, that will
be used.  This is primarily for the Jenkins jobs.
2.  --- .develvars
Instead of storing the basebranch in .gitreview, it can now be
stored in a non-checked-in ".develvars" file and keyed by the
current branch.  So, if you were working on a branch named
"new-feature-work" based on "development/16/new-feature" and wanted
 to push to that branch in Gerrit but wanted to pull the external
 modules for 16, you'd create the following .develvars file:
[branch "new-feature-work"]
    mainline-branch = 16
The .gitreview file would still look like:
[gerrit]
defaultbranch=development/16/new-feature
...which would cause any reviews pushed from "new-feature-work" to
go to the "development/16/new-feature" branch in Gerrit.
The key is that the .develvars file is NEVER checked in (it's been
added to .gitignore).
3.  --- Well Known Development Branch
If you're actually working in a branch named like
"development/<mainline_branch>/some-feature", the mainline branch
will be parsed from it.
4.  --- .gitreview
If none of the earlier conditions exist, the .gitreview
"defaultbranch" variable will be used just as before.
Change-Id: I1cdeeaa0944bba3f2e01d7a2039559d0c266f8c9
			
			
This commit is contained in:
		
				
					committed by
					
						 Friendly Automation
						Friendly Automation
					
				
			
			
				
	
			
			
			
						parent
						
							3771074a45
						
					
				
				
					commit
					47106a09b0
				
			| @@ -3,11 +3,13 @@ | ||||
| AWK=${AWK:-awk} | ||||
| GIT=${GIT:-git} | ||||
| GREP=${GREP:-grep} | ||||
| SED=${SED:-sed} | ||||
|  | ||||
|  | ||||
| if [ -f ${1}/.version ]; then | ||||
|     cat ${1}/.version | ||||
| elif [ -d ${1}/.svn ]; then | ||||
|     PARTS=`LANG=C svn info ${1} | ${GREP} URL | ${AWK} '{print $2;}' | sed -e 's:^.*/svn/asterisk/::' | sed -e 's:/: :g'` | ||||
|     PARTS=`LANG=C svn info ${1} | ${GREP} URL | ${AWK} '{print $2;}' | ${SED} -e 's:^.*/svn/asterisk/::' | ${SED} -e 's:/: :g'` | ||||
|     BRANCH=0 | ||||
|     TEAM=0 | ||||
|     TAG=0 | ||||
| @@ -93,16 +95,33 @@ elif [ -d ${1}/.git ]; then | ||||
|         echo "UNKNOWN__and_probably_unsupported" | ||||
|         exit 1 | ||||
|     fi | ||||
| 	cd ${1} | ||||
|     cd ${1} | ||||
|  | ||||
|     # If the first log commit messages indicates that this is checked into | ||||
|     # subversion, we'll just use the SVN- form of the revision. | ||||
|     MODIFIED="" | ||||
|     SVN_REV=`${GIT} log --pretty=full -1 | sed -n '/git-svn-id:/ s/.*\@\([^ ]*\) .*/\1/p'` | ||||
|     SVN_REV=`${GIT} log --pretty=full -1 | ${SED} -n '/git-svn-id:/ s/.*\@\([^ ]*\) .*/\1/p'` | ||||
|     if [ -z "$SVN_REV" ]; then | ||||
|         MAINLINE_BRANCH=$(${GIT} config -f .gitreview --get gerrit.basebranch) | ||||
|         if [ "x${MAINLINE_BRANCH}" = "x" ] ; then | ||||
|             MAINLINE_BRANCH=$(${GIT} config -f .gitreview --get gerrit.defaultbranch) | ||||
|         # If MAINLINE_BRANCH is already set in the environment, use it. | ||||
|         if [ -z "${MAINLINE_BRANCH}" ] ; then | ||||
|             # Try to retrieve MAINLINE_BRANCH from a local .develvars file first. | ||||
|             # .develvars is keyed by the branch name so we need to get that first. | ||||
|             BRANCH=$(${GIT} symbolic-ref --short HEAD) | ||||
|             if [ -f .develvars ] ; then | ||||
|                 MAINLINE_BRANCH=$(${GIT} config -f .develvars --get branch.${BRANCH}.mainline-branch) | ||||
|             fi | ||||
|  | ||||
|             # If we didn't find it, see if this is a well-known development branch. | ||||
|             # development/<mainline_branch>/<branchname> or | ||||
|             # devel/<mainline_branch>/<branchname> | ||||
|             if [ "x${MAINLINE_BRANCH}" = "x" ] ; then | ||||
|                 MAINLINE_BRANCH=$(echo "${BRANCH}" | ${SED} -n -r -e "s@devel(opment)?/([0-9]+)/.+@\2@p") | ||||
|             fi | ||||
|  | ||||
|             # If we didn't find it, get it from .gitreview defaultbranch. | ||||
|             if [ "x${MAINLINE_BRANCH}" = "x" ] ; then | ||||
|                 MAINLINE_BRANCH=$(${GIT} config -f .gitreview --get gerrit.defaultbranch) | ||||
|             fi | ||||
|         fi | ||||
|  | ||||
|         VERSION=`${GIT} describe --long --always --tags --dirty=M 2> /dev/null` | ||||
| @@ -116,7 +135,7 @@ elif [ -d ${1}/.git ]; then | ||||
|         fi | ||||
|         echo GIT-${MAINLINE_BRANCH}-${VERSION} | ||||
|     else | ||||
|         PARTS=`LANG=C ${GIT} log --pretty=full | ${GREP} -F "git-svn-id:" | head -1 | ${AWK} '{print $2;}' | sed -e s:^.*/svn/$2/:: | sed -e 's:/: :g' | sed -e 's/@.*$//g'` | ||||
|         PARTS=`LANG=C ${GIT} log --pretty=full | ${GREP} -F "git-svn-id:" | head -1 | ${AWK} '{print $2;}' | ${SED} -e s:^.*/svn/$2/:: | ${SED} -e 's:/: :g' | ${SED} -e 's/@.*$//g'` | ||||
|         BRANCH=0 | ||||
|         TEAM=0 | ||||
|         TAG=0 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user