diff options
author | Robert Yang <liezhi.yang@windriver.com> | 2016-11-16 19:30:13 -0800 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2018-07-09 22:48:38 +0100 |
commit | be73d2bf15eb6b9afca324e0dd4b1a24c00a1f8e (patch) | |
tree | 6310bd96617996e9990588d0460c7857a46f088d | |
parent | 53ba34d1438981d3c8f47cbaaa91aeca51df4bcf (diff) | |
download | poky-be73d2bf15eb6b9afca324e0dd4b1a24c00a1f8e.tar.gz |
oe/copy_buildsystem.py: add SDK_LAYERS_EXCLUDE_PATTERN
It is helpful when exclude a lot of layers. It uses python re, and
supports multiple patterns (separated by space).
(From OE-Core rev: b5170882feb0f3bc2dddc213b6d115dfa87b7cc1)
Signed-off-by: Robert Yang <liezhi.yang@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/lib/oe/copy_buildsystem.py | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/meta/lib/oe/copy_buildsystem.py b/meta/lib/oe/copy_buildsystem.py index 4abec4666f..7cb784cf8c 100644 --- a/meta/lib/oe/copy_buildsystem.py +++ b/meta/lib/oe/copy_buildsystem.py | |||
@@ -1,5 +1,12 @@ | |||
1 | # This class should provide easy access to the different aspects of the | 1 | # This class should provide easy access to the different aspects of the |
2 | # buildsystem such as layers, bitbake location, etc. | 2 | # buildsystem such as layers, bitbake location, etc. |
3 | # | ||
4 | # SDK_LAYERS_EXCLUDE: Layers which will be excluded from SDK layers. | ||
5 | # SDK_LAYERS_EXCLUDE_PATTERN: The simiar to SDK_LAYERS_EXCLUDE, this supports | ||
6 | # python regular expression, use space as separator, | ||
7 | # e.g.: ".*-downloads closed-.*" | ||
8 | # | ||
9 | |||
3 | import stat | 10 | import stat |
4 | import shutil | 11 | import shutil |
5 | 12 | ||
@@ -23,8 +30,10 @@ class BuildSystem(object): | |||
23 | self.context = context | 30 | self.context = context |
24 | self.layerdirs = [os.path.abspath(pth) for pth in d.getVar('BBLAYERS').split()] | 31 | self.layerdirs = [os.path.abspath(pth) for pth in d.getVar('BBLAYERS').split()] |
25 | self.layers_exclude = (d.getVar('SDK_LAYERS_EXCLUDE') or "").split() | 32 | self.layers_exclude = (d.getVar('SDK_LAYERS_EXCLUDE') or "").split() |
33 | self.layers_exclude_pattern = d.getVar('SDK_LAYERS_EXCLUDE_PATTERN') | ||
26 | 34 | ||
27 | def copy_bitbake_and_layers(self, destdir, workspace_name=None): | 35 | def copy_bitbake_and_layers(self, destdir, workspace_name=None): |
36 | import re | ||
28 | # Copy in all metadata layers + bitbake (as repositories) | 37 | # Copy in all metadata layers + bitbake (as repositories) |
29 | copied_corebase = None | 38 | copied_corebase = None |
30 | layers_copied = [] | 39 | layers_copied = [] |
@@ -41,8 +50,17 @@ class BuildSystem(object): | |||
41 | # Exclude layers | 50 | # Exclude layers |
42 | for layer_exclude in self.layers_exclude: | 51 | for layer_exclude in self.layers_exclude: |
43 | if layer_exclude in layers: | 52 | if layer_exclude in layers: |
53 | bb.note('Excluded %s from sdk layers since it is in SDK_LAYERS_EXCLUDE' % layer_exclude) | ||
44 | layers.remove(layer_exclude) | 54 | layers.remove(layer_exclude) |
45 | 55 | ||
56 | if self.layers_exclude_pattern: | ||
57 | layers_cp = layers[:] | ||
58 | for pattern in self.layers_exclude_pattern.split(): | ||
59 | for layer in layers_cp: | ||
60 | if re.match(pattern, layer): | ||
61 | bb.note('Excluded %s from sdk layers since matched SDK_LAYERS_EXCLUDE_PATTERN' % layer) | ||
62 | layers.remove(layer) | ||
63 | |||
46 | workspace_newname = workspace_name | 64 | workspace_newname = workspace_name |
47 | if workspace_newname: | 65 | if workspace_newname: |
48 | layernames = [os.path.basename(layer) for layer in layers] | 66 | layernames = [os.path.basename(layer) for layer in layers] |