summaryrefslogtreecommitdiffstats
path: root/bitbake/lib/bb/cookerdata.py
diff options
context:
space:
mode:
authorChristopher Larson <chris_larson@mentor.com>2016-04-30 12:52:49 -0700
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-05-19 09:05:21 +0100
commit32ee30a46d5e27ffcb0f18d85a0768bd22adca94 (patch)
tree711b1253359d62d29586ae8b362eac4e7ef7f859 /bitbake/lib/bb/cookerdata.py
parent90bc9b4f3342c41e4f9c20a6f0f8e69b8ed4bce3 (diff)
downloadpoky-32ee30a46d5e27ffcb0f18d85a0768bd22adca94.tar.gz
bitbake: Provide LAYERDIR_RE for layer.conf
This variable is a regex-escaped version of LAYERDIR, for safer use in BBFILE_PATTERN, so as to avoid issues with regex special characters in the layer path. [YOCTO #8402] (Bitbake rev: 72900522778b6ff08b135bf8bb97dff3f1a20bd9) Signed-off-by: Christopher Larson <chris_larson@mentor.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/lib/bb/cookerdata.py')
-rw-r--r--bitbake/lib/bb/cookerdata.py9
1 files changed, 7 insertions, 2 deletions
diff --git a/bitbake/lib/bb/cookerdata.py b/bitbake/lib/bb/cookerdata.py
index fba95afa54..1615db5b17 100644
--- a/bitbake/lib/bb/cookerdata.py
+++ b/bitbake/lib/bb/cookerdata.py
@@ -22,9 +22,11 @@
22# with this program; if not, write to the Free Software Foundation, Inc., 22# with this program; if not, write to the Free Software Foundation, Inc.,
23# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. 23# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
24 24
25import os, sys
26from functools import wraps
27import logging 25import logging
26import os
27import re
28import sys
29from functools import wraps
28import bb 30import bb
29from bb import data 31from bb import data
30import bb.parse 32import bb.parse
@@ -296,9 +298,12 @@ class CookerDataBuilder(object):
296 if layer.endswith('/'): 298 if layer.endswith('/'):
297 layer = layer.rstrip('/') 299 layer = layer.rstrip('/')
298 data.setVar('LAYERDIR', layer) 300 data.setVar('LAYERDIR', layer)
301 data.setVar('LAYERDIR_RE', re.escape(layer))
299 data = parse_config_file(os.path.join(layer, "conf", "layer.conf"), data) 302 data = parse_config_file(os.path.join(layer, "conf", "layer.conf"), data)
300 data.expandVarref('LAYERDIR') 303 data.expandVarref('LAYERDIR')
304 data.expandVarref('LAYERDIR_RE')
301 305
306 data.delVar('LAYERDIR_RE')
302 data.delVar('LAYERDIR') 307 data.delVar('LAYERDIR')
303 308
304 if not data.getVar("BBPATH", True): 309 if not data.getVar("BBPATH", True):