summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lib/bb/command.py11
-rw-r--r--lib/bb/cooker.py24
-rw-r--r--lib/bb/event.py10
3 files changed, 45 insertions, 0 deletions
diff --git a/lib/bb/command.py b/lib/bb/command.py
index d84898a84..9841e6874 100644
--- a/lib/bb/command.py
+++ b/lib/bb/command.py
@@ -232,6 +232,17 @@ class CommandsAsync:
command.finishAsyncCommand()
generateTargetsTree.needcache = True
+ def findConfigFiles(self, command, params):
+ """
+ Find config files which provide appropriate values
+ for the passed configuration variable. i.e. MACHINE
+ """
+ varname = params[0]
+
+ command.cooker.findConfigFiles(varname)
+ command.finishAsyncCommand()
+ findConfigFiles.needcache = True
+
def showVersions(self, command, params):
"""
Show the currently selected versions
diff --git a/lib/bb/cooker.py b/lib/bb/cooker.py
index 89a2d604a..46d059db3 100644
--- a/lib/bb/cooker.py
+++ b/lib/bb/cooker.py
@@ -430,8 +430,32 @@ class BBCooker:
if not regex in matched:
collectlog.warn("No bb files matched BBFILE_PATTERN_%s '%s'" % (collection, pattern))
+ def findConfigFiles(self, varname):
+ """
+ Find config files which are appropriate values for varname.
+ i.e. MACHINE, DISTRO
+ """
+ possible = []
+ var = varname.lower()
+
+ data = self.configuration.data
+ # iterate configs
+ bbpaths = bb.data.getVar('BBPATH', data, True).split(':')
+ for path in bbpaths:
+ confpath = os.path.join(path, "conf", var)
+ if os.path.exists(confpath):
+ for root, dirs, files in os.walk(confpath):
+ # get all child files, these are appropriate values
+ for f in files:
+ val, sep, end = f.rpartition('.')
+ if end == 'conf':
+ possible.append(val)
+
+ bb.event.fire(bb.event.ConfigFilesFound(var, possible), self.configuration.data)
+
def checkInheritsClass(self, klass):
pkg_list = []
+
for pfn in self.status.pkg_fn:
inherits = self.status.inherits.get(pfn, None)
if inherits and inherits.count(klass) > 0:
diff --git a/lib/bb/event.py b/lib/bb/event.py
index 2acf9b119..0612bd67c 100644
--- a/lib/bb/event.py
+++ b/lib/bb/event.py
@@ -360,6 +360,16 @@ class TargetsTreeGenerated(Event):
Event.__init__(self)
self._model = model
+class ConfigFilesFound(Event):
+ """
+ Event when a list of appropriate config files has been generated
+ """
+
+ def __init__(self, variable, values):
+ Event.__init__(self)
+ self._variable = variable
+ self._values = values
+
class MsgBase(Event):
"""Base class for messages"""