diff options
author | Bruce Ashfield <bruce.ashfield@windriver.com> | 2012-02-01 13:55:41 -0500 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2012-02-03 16:51:30 +0000 |
commit | 41e92923a0b2fe047ecaa9f9ffb564d6069f784f (patch) | |
tree | 2b06b03a4c2d41593872cc66a343b8cbfe1b5985 /meta | |
parent | 7b355ad09a622cfe57c66674ed1affd61c4d872e (diff) | |
download | openembedded-core-41e92923a0b2fe047ecaa9f9ffb564d6069f784f.tar.gz openembedded-core-41e92923a0b2fe047ecaa9f9ffb564d6069f784f.tar.bz2 openembedded-core-41e92923a0b2fe047ecaa9f9ffb564d6069f784f.tar.xz openembedded-core-41e92923a0b2fe047ecaa9f9ffb564d6069f784f.zip |
classes/patch: optionally return non-patch sources
commit:
patch.bbclass: abstract out logic that determines patches to apply
gives the ability for other clases to emit series files for use outside
of a build system, or even within the build system. There are sometimes
elements on the SRC_URI that while not directly applicable to patching,
can be related to patching the package. For example, the yocto kernel
class would like to know about these other source items on the SRC_URI
to locate out of tree kernel features.
This change keeps the default behaviour of returning patches, but adds the
ability to request that non-patch results be returned. Additional filtering
within the non-patch category, is left up to the caller of the routine.
Signed-off-by: Bruce Ashfield <bruce.ashfield@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta')
-rw-r--r-- | meta/classes/patch.bbclass | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/meta/classes/patch.bbclass b/meta/classes/patch.bbclass index 1ea4bc5e0..31db9e372 100644 --- a/meta/classes/patch.bbclass +++ b/meta/classes/patch.bbclass @@ -7,13 +7,17 @@ PATCHDEPENDENCY = "${PATCHTOOL}-native:do_populate_sysroot" inherit terminal -def src_patches(d): +def src_patches(d, all = False ): workdir = d.getVar('WORKDIR', True) fetch = bb.fetch2.Fetch([], d) patches = [] + sources = [] for url in fetch.urls: local = patch_path(url, fetch, workdir) if not local: + if all: + local = fetch.localpath(url) + sources.append(local) continue urldata = fetch.ud[url] @@ -43,6 +47,9 @@ def src_patches(d): localurl = bb.encodeurl(('file', '', local, '', '', patchparm)) patches.append(localurl) + if all: + return sources + return patches def patch_path(url, fetch, workdir): |