aboutsummaryrefslogtreecommitdiffstats
path: root/classes/patch.bbclass
diff options
context:
space:
mode:
authorBernhard Reutner-Fischer <rep.dot.nop@gmail.com>2010-12-21 13:40:52 +0100
committerBernhard Reutner-Fischer <rep.dot.nop@gmail.com>2011-01-11 21:29:10 +0100
commit0f2330dd7a03d4a2ffa46f44a94aa2218127dd3b (patch)
tree6a68abfb80c7a8f2a307bcb45e48f395b39bc67f /classes/patch.bbclass
parentee85c41bb8f694ea7c58cebefa358adfb29f9adc (diff)
downloadopenembedded-0f2330dd7a03d4a2ffa46f44a94aa2218127dd3b.tar.gz
patch.bbclass: conditional patch-tool dependency
only depend do_patch on patch-tool if recipe references any patch The whole of do_patch should be gated through a facility to determine if there is any patch at all. TODO. Acked-by: Leon Woestenberg <leon@sidebranch.com> Signed-off-by: Bernhard Reutner-Fischer <rep.dot.nop@gmail.com>
Diffstat (limited to 'classes/patch.bbclass')
-rw-r--r--classes/patch.bbclass22
1 files changed, 19 insertions, 3 deletions
diff --git a/classes/patch.bbclass b/classes/patch.bbclass
index bc52ae7e16..edfb5e9ec8 100644
--- a/classes/patch.bbclass
+++ b/classes/patch.bbclass
@@ -43,7 +43,7 @@ python patch_do_patch() {
src_uri = d.getVar("SRC_URI", True).split()
srcurldata = bb.fetch.init(src_uri, d, True)
workdir = bb.data.getVar('WORKDIR', d, 1)
- for url in d.getVar("SRC_URI", True).split():
+ for url in src_uri:
urldata = srcurldata[url]
local = urldata.localpath
@@ -97,7 +97,7 @@ python patch_do_patch() {
continue
if "maxrev" in parm:
- srcrev = bb.data.getVar('SRCREV', d, 1)
+ srcrev = bb.data.getVar('SRCREV', d, 1)
if srcrev and srcrev > parm["maxrev"]:
bb.note("Patch '%s' applies to earlier revisions" % pname)
continue
@@ -125,8 +125,24 @@ python patch_do_patch() {
bb.fatal(str(exc))
}
+def patch_deps(d):
+ import oe.unpack
+
+ src_uri = d.getVar("SRC_URI", True).split()
+ srcurldata = bb.fetch.init(src_uri, d, True)
+ for url in src_uri:
+ urldata = srcurldata[url]
+ local = urldata.localpath
+ if local:
+ base, ext = os.path.splitext(os.path.basename(local))
+ if ext in ('.gz', '.bz2', '.Z', '.xz'):
+ local = base
+ if oe.unpack.is_patch(local, urldata.parm):
+ return "${PATCHDEPENDENCY}"
+ return ""
+
addtask patch after do_unpack
do_patch[dirs] = "${WORKDIR}"
-do_patch[depends] = "${PATCHDEPENDENCY}"
+do_patch[depends] = "${@patch_deps(d)}"
EXPORT_FUNCTIONS do_patch