summaryrefslogtreecommitdiffstats
path: root/meta/classes/prserv.bbclass
diff options
context:
space:
mode:
authorConstantin Musca <constantinx.musca@intel.com>2012-12-05 10:58:58 +0200
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-12-06 12:31:16 +0000
commit59a704679c825d01f417a303a49be7ef34134c4e (patch)
tree34825c2a39d7edf0e35d01f78310717111712945 /meta/classes/prserv.bbclass
parent65049e9fe67ee004f57e7e28ff868d1479fa4544 (diff)
downloadpoky-59a704679c825d01f417a303a49be7ef34134c4e.tar.gz
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 <constantinx.musca@intel.com> Signed-off-by: Saul Wold <sgw@linux.intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/classes/prserv.bbclass')
-rw-r--r--meta/classes/prserv.bbclass22
1 files changed, 17 insertions, 5 deletions
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 @@
1def prserv_get_pr_auto(d): 1def prserv_get_pr_auto(d):
2 import oe.prservice 2 import oe.prservice
3 import re
4
5 pv = d.getVar("PV", True)
3 if d.getVar('USE_PR_SERV', True) != "1": 6 if d.getVar('USE_PR_SERV', True) != "1":
7 if 'AUTOINC' in pv:
8 d.setVar("PKGV", pv.replace("AUTOINC", "0"))
4 bb.warn("Not using network based PR service") 9 bb.warn("Not using network based PR service")
5 return None 10 return None
6 11
@@ -8,14 +13,21 @@ def prserv_get_pr_auto(d):
8 pkgarch = d.getVar("PACKAGE_ARCH", True) 13 pkgarch = d.getVar("PACKAGE_ARCH", True)
9 checksum = d.getVar("BB_TASKHASH", True) 14 checksum = d.getVar("BB_TASKHASH", True)
10 15
16 conn = d.getVar("__PRSERV_CONN", True)
17 if conn is None:
18 conn = oe.prservice.prserv_make_conn(d)
19 if conn is None:
20 return None
21
22 if "AUTOINC" in pv:
23 srcpv = bb.fetch2.get_srcrev(d)
24 base_ver = "AUTOINC-%s" % version[:version.find(srcpv)]
25 value = conn.getPR(base_ver, pkgarch, srcpv)
26 d.setVar("PKGV", pv.replace("AUTOINC", str(value)))
27
11 if d.getVar('PRSERV_LOCKDOWN', True): 28 if d.getVar('PRSERV_LOCKDOWN', True):
12 auto_rev = d.getVar('PRAUTO_' + version + '_' + pkgarch, True) or d.getVar('PRAUTO_' + version, True) or None 29 auto_rev = d.getVar('PRAUTO_' + version + '_' + pkgarch, True) or d.getVar('PRAUTO_' + version, True) or None
13 else: 30 else:
14 conn = d.getVar("__PRSERV_CONN", True)
15 if conn is None:
16 conn = oe.prservice.prserv_make_conn(d)
17 if conn is None:
18 return None
19 auto_rev = conn.getPR(version, pkgarch, checksum) 31 auto_rev = conn.getPR(version, pkgarch, checksum)
20 32
21 return auto_rev 33 return auto_rev