diff options
author | Richard Purdie <rpurdie@linux.intel.com> | 2009-01-02 11:09:04 +0000 |
---|---|---|
committer | Richard Purdie <rpurdie@linux.intel.com> | 2009-01-02 11:09:04 +0000 |
commit | 3ab2ff7668229f8f103043aaaad9310d607510bb (patch) | |
tree | 55c61b7cd19c1657ac278baa4c1784a00d2091f3 /meta/classes | |
parent | 1d89595e2b99c645f7529cf9868e3aae7f4d70f1 (diff) | |
download | openembedded-core-3ab2ff7668229f8f103043aaaad9310d607510bb.tar.gz openembedded-core-3ab2ff7668229f8f103043aaaad9310d607510bb.tar.bz2 openembedded-core-3ab2ff7668229f8f103043aaaad9310d607510bb.zip |
base.bbclass: Add metadata revision handling for git (from OE)
Diffstat (limited to 'meta/classes')
-rw-r--r-- | meta/classes/base.bbclass | 56 |
1 files changed, 53 insertions, 3 deletions
diff --git a/meta/classes/base.bbclass b/meta/classes/base.bbclass index 8e6284c532..0edd4127c8 100644 --- a/meta/classes/base.bbclass +++ b/meta/classes/base.bbclass @@ -714,6 +714,17 @@ def base_get_scmbasepath(d): path_to_bbfiles = bb.data.getVar( 'BBFILES', d, 1 ).split() return path_to_bbfiles[0][:path_to_bbfiles[0].rindex( "packages" )] +def base_get_metadata_monotone_branch(d): + monotone_branch = "<unknown>" + try: + monotone_branch = file( "%s/_MTN/options" % base_get_scmbasepath(d) ).read().strip() + if monotone_branch.startswith( "database" ): + monotone_branch_words = monotone_branch.split() + monotone_branch = monotone_branch_words[ monotone_branch_words.index( "branch" )+1][1:-1] + except: + pass + return monotone_branch + def base_get_metadata_monotone_revision(d): monotone_revision = "<unknown>" try: @@ -733,6 +744,47 @@ def base_get_metadata_svn_revision(d): pass return revision +def base_get_metadata_git_branch(d): + import os + branch = os.popen('cd %s; git branch | grep "^* " | tr -d "* "' % base_get_scmbasepath(d)).read() + + if len(branch) != 0: + return branch + return "<unknown>" + +def base_get_metadata_git_revision(d): + import os + rev = os.popen("cd %s; git log -n 1 --pretty=oneline --" % base_get_scmbasepath(d)).read().split(" ")[0] + if len(rev) != 0: + return rev + return "<unknown>" + +def base_detect_revision(d): + scms = [base_get_metadata_git_revision, \ + base_get_metadata_svn_revision] + + for scm in scms: + rev = scm(d) + if rev <> "<unknown>": + return rev + + return "<unknown>" + +def base_detect_branch(d): + scms = [base_get_metadata_git_branch] + + for scm in scms: + rev = scm(d) + if rev <> "<unknown>": + return rev.strip() + + return "<unknown>" + + + +METADATA_BRANCH ?= "${@base_detect_branch(d)}" +METADATA_REVISION ?= "${@base_detect_revision(d)}" + GIT_CONFIG = "${STAGING_DIR_NATIVE}/usr/etc/gitconfig" def generate_git_config(e): @@ -756,8 +808,6 @@ def generate_git_config(e): f.write(proxy_command) f.close -METADATA_REVISION ?= "${@base_get_metadata_monotone_revision(d)}" - addhandler base_eventhandler python base_eventhandler() { from bb import note, error, data @@ -792,7 +842,7 @@ python base_eventhandler() { if name.startswith("BuildStarted"): bb.data.setVar( 'BB_VERSION', bb.__version__, e.data ) - statusvars = ['BB_VERSION', 'METADATA_REVISION', 'TARGET_ARCH', 'TARGET_OS', 'MACHINE', 'DISTRO', 'DISTRO_VERSION','TARGET_FPU'] + statusvars = ['BB_VERSION', 'METADATA_BRANCH', 'METADATA_REVISION', 'TARGET_ARCH', 'TARGET_OS', 'MACHINE', 'DISTRO', 'DISTRO_VERSION','TARGET_FPU'] statuslines = ["%-17s = \"%s\"" % (i, bb.data.getVar(i, e.data, 1) or '') for i in statusvars] statusmsg = "\nOE Build Configuration:\n%s\n" % '\n'.join(statuslines) print statusmsg |