diff options
| author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2016-09-14 17:09:52 +1200 | 
|---|---|---|
| committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-09-14 22:20:05 +0100 | 
| commit | 7c0788cd2390fd0e1ec84bc9dbebcb67daee429f (patch) | |
| tree | c79cd0f2b8947696353203798716379d5bd08f21 /meta/lib | |
| parent | 038d9db66e69c9de12eb8581acb28a8facd726b6 (diff) | |
| download | openembedded-core-7c0788cd2390fd0e1ec84bc9dbebcb67daee429f.tar.gz openembedded-core-7c0788cd2390fd0e1ec84bc9dbebcb67daee429f.tar.bz2 openembedded-core-7c0788cd2390fd0e1ec84bc9dbebcb67daee429f.zip | |
lib/oe/copy_buildsystem: fix building eSDK with indirect paths in BBLAYERS
Indirect paths (e.g. ${TOPDIR}/../meta-something) do generally work if
used in BBLAYERS in bblayers.conf. However, if you built an extensible
SDK with this configuration then the creation of the workspace within
the SDK using devtool in do_populate_sdk_ext failed. This is because
the copy_buildsystem code was no longer correctly recognising that the
core layer ("meta") was part of a repository (e.g. openembedded-core /
poky) that should be shipped together - because of the indirection - and
thus it was splitting out the meta directory, and a number of places in
the code assume that the meta directory is next to the scripts
directory. Use os.path.abspath() to flatten out any indirections.
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib')
| -rw-r--r-- | meta/lib/oe/copy_buildsystem.py | 4 | 
1 files changed, 2 insertions, 2 deletions
| diff --git a/meta/lib/oe/copy_buildsystem.py b/meta/lib/oe/copy_buildsystem.py index 3d5a746586..afaff68598 100644 --- a/meta/lib/oe/copy_buildsystem.py +++ b/meta/lib/oe/copy_buildsystem.py @@ -17,7 +17,7 @@ class BuildSystem(object):      def __init__(self, context, d):          self.d = d          self.context = context -        self.layerdirs = d.getVar('BBLAYERS', True).split() +        self.layerdirs = [os.path.abspath(pth) for pth in d.getVar('BBLAYERS', True).split()]          self.layers_exclude = (d.getVar('SDK_LAYERS_EXCLUDE', True) or "").split()      def copy_bitbake_and_layers(self, destdir, workspace_name=None): @@ -26,7 +26,7 @@ class BuildSystem(object):          bb.utils.mkdirhier(destdir)          layers = list(self.layerdirs) -        corebase = self.d.getVar('COREBASE', True) +        corebase = os.path.abspath(self.d.getVar('COREBASE', True))          layers.append(corebase)          # Exclude layers | 
