From 59a704679c825d01f417a303a49be7ef34134c4e Mon Sep 17 00:00:00 2001 From: Constantin Musca Date: Wed, 5 Dec 2012 10:58:58 +0200 Subject: prs: use the PRServer to replace the BB_URI_LOCALCOUNT functionality - adapt the PRServer to generate an incremental number for every revision set associated with a (PN, PV) - use one incrementing value rather than several - PV becomes 0.1+gitAUTOINC+deadbeefdecafbad_decafbaddeadbeef - if PV contains 'AUTOINC' set PKGV to the same thing with AUTOINC replaced with the "auto PR" value - if the PRServer isn't running replace AUTOINC with 0 (no package feeds, but usual image creation would work) - use the PR table with "AUTOINC-${PV-without-SRCREVs}" as key - modify prexport/primport to address the generated srcrev entries - this patch addresses the following proposal: http://lists.linuxtogo.org/pipermail/bitbake-devel/2012-November/003878.html (From OE-Core rev: b27b438221e16ac3df6ac66d761b77e3bd43db67) Signed-off-by: Constantin Musca Signed-off-by: Saul Wold Signed-off-by: Richard Purdie --- meta/classes/package.bbclass | 4 ++++ meta/classes/prexport.bbclass | 10 ++++++++++ meta/classes/prserv.bbclass | 22 +++++++++++++++++----- 3 files changed, 31 insertions(+), 5 deletions(-) diff --git a/meta/classes/package.bbclass b/meta/classes/package.bbclass index 3278d37b53..993ce98782 100644 --- a/meta/classes/package.bbclass +++ b/meta/classes/package.bbclass @@ -411,6 +411,10 @@ python package_get_auto_pr() { bb.fatal("Can NOT get PRAUTO from remote PR service") return d.setVar('PRAUTO',str(auto_pr)) + else: + pv = d.getVar("PV", True) + if 'AUTOINC' in pv: + d.setVar("PKGV", pv.replace("AUTOINC", "0")) } LOCALEBASEPN ??= "${PN}" diff --git a/meta/classes/prexport.bbclass b/meta/classes/prexport.bbclass index b990c2be5e..6b9d540989 100644 --- a/meta/classes/prexport.bbclass +++ b/meta/classes/prexport.bbclass @@ -24,6 +24,16 @@ python prexport_handler () { bb.warn("prexport_handler: No AUTOPR values found for %s" % ver) return oe.prservice.prserv_export_tofile(e.data, None, datainfo, False) + if 'AUTOINC' in ver: + import re + srcpv = bb.fetch2.get_srcrev(e.data) + base_ver = "AUTOINC-%s" % ver[:ver.find(srcpv)] + e.data.setVar('PRSERV_DUMPOPT_VERSION', base_ver) + retval = oe.prservice.prserv_dump_db(e.data) + if not retval: + bb.fatal("prexport_handler: export failed!") + (metainfo, datainfo) = retval + oe.prservice.prserv_export_tofile(e.data, None, datainfo, False) elif isinstance(e, bb.event.ParseStarted): import bb.utils import oe.prservice diff --git a/meta/classes/prserv.bbclass b/meta/classes/prserv.bbclass index 0825306f91..33547f989c 100644 --- a/meta/classes/prserv.bbclass +++ b/meta/classes/prserv.bbclass @@ -1,6 +1,11 @@ def prserv_get_pr_auto(d): import oe.prservice + import re + + pv = d.getVar("PV", True) if d.getVar('USE_PR_SERV', True) != "1": + if 'AUTOINC' in pv: + d.setVar("PKGV", pv.replace("AUTOINC", "0")) bb.warn("Not using network based PR service") return None @@ -8,14 +13,21 @@ def prserv_get_pr_auto(d): pkgarch = d.getVar("PACKAGE_ARCH", True) checksum = d.getVar("BB_TASKHASH", True) + conn = d.getVar("__PRSERV_CONN", True) + if conn is None: + conn = oe.prservice.prserv_make_conn(d) + if conn is None: + return None + + if "AUTOINC" in pv: + srcpv = bb.fetch2.get_srcrev(d) + base_ver = "AUTOINC-%s" % version[:version.find(srcpv)] + value = conn.getPR(base_ver, pkgarch, srcpv) + d.setVar("PKGV", pv.replace("AUTOINC", str(value))) + if d.getVar('PRSERV_LOCKDOWN', True): auto_rev = d.getVar('PRAUTO_' + version + '_' + pkgarch, True) or d.getVar('PRAUTO_' + version, True) or None else: - conn = d.getVar("__PRSERV_CONN", True) - if conn is None: - conn = oe.prservice.prserv_make_conn(d) - if conn is None: - return None auto_rev = conn.getPR(version, pkgarch, checksum) return auto_rev -- cgit v1.2.3-54-g00ecf