summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDongxiao Xu <dongxiao.xu@intel.com>2012-04-12 23:46:26 +0800
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-04-13 12:04:19 +0100
commit9c1dcdceb235c53b92a64e741f5a5491b1e489bd (patch)
treec1f2111a2c7c947c3fd00f7542e104c03d49cf1a
parent302f2cc8ce756ab61042f1d904df4d18071a976a (diff)
downloadpoky-9c1dcdceb235c53b92a64e741f5a5491b1e489bd.tar.gz
Hob: Implement Hob config parse hook
To make Hob's specific variable settings take effect, we add a Hob config hook at the end of parsing for each configuration file, and in the hook function, Hob will set its own variables to the data store. This fixes: [YOCTO #2210] [YOCTO #2254] (Bitbake rev: 0ec7d1bbfd2e09ae60f99e6134b20ffd1d9145b1) Signed-off-by: Dongxiao Xu <dongxiao.xu@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rwxr-xr-xbitbake/lib/bb/ui/crumbs/builder.py26
-rw-r--r--bitbake/lib/bb/ui/crumbs/hobeventhandler.py26
2 files changed, 40 insertions, 12 deletions
diff --git a/bitbake/lib/bb/ui/crumbs/builder.py b/bitbake/lib/bb/ui/crumbs/builder.py
index 10b9a77032..410ff5fa85 100755
--- a/bitbake/lib/bb/ui/crumbs/builder.py
+++ b/bitbake/lib/bb/ui/crumbs/builder.py
@@ -210,6 +210,30 @@ class Parameters:
210 self.tmpdir = params["tmpdir"] 210 self.tmpdir = params["tmpdir"]
211 self.enable_proxy = False 211 self.enable_proxy = False
212 212
213def hob_conf_filter(fn, data):
214 if fn.endswith("/local.conf"):
215 distro = data.getVar("DISTRO_HOB")
216 if distro:
217 if distro != "defaultsetup":
218 data.setVar("DISTRO", distro)
219 else:
220 data.delVar("DISTRO")
221
222 keys = ["MACHINE_HOB", "SDKMACHINE_HOB", "PACKAGE_CLASSES_HOB", \
223 "BB_NUMBER_THREADS_HOB", "PARALLEL_MAKE_HOB", "DL_DIR_HOB", \
224 "SSTATE_DIR_HOB", "SSTATE_MIRROR_HOB", "INCOMPATIBLE_LICENSE_HOB"]
225 for key in keys:
226 var_hob = data.getVar(key)
227 if var_hob:
228 data.setVar(key.split("_HOB")[0], var_hob)
229 return
230
231 if fn.endswith("/bblayers.conf"):
232 layers = data.getVar("BBLAYERS_HOB")
233 if layers:
234 data.setVar("BBLAYERS", layers)
235 return
236
213class Builder(gtk.Window): 237class Builder(gtk.Window):
214 238
215 (MACHINE_SELECTION, 239 (MACHINE_SELECTION,
@@ -296,6 +320,8 @@ class Builder(gtk.Window):
296 self.handler.connect("command-succeeded", self.handler_command_succeeded_cb) 320 self.handler.connect("command-succeeded", self.handler_command_succeeded_cb)
297 self.handler.connect("command-failed", self.handler_command_failed_cb) 321 self.handler.connect("command-failed", self.handler_command_failed_cb)
298 322
323 self.handler.set_config_filter(hob_conf_filter)
324
299 self.initiate_new_build_async() 325 self.initiate_new_build_async()
300 326
301 def create_visual_elements(self): 327 def create_visual_elements(self):
diff --git a/bitbake/lib/bb/ui/crumbs/hobeventhandler.py b/bitbake/lib/bb/ui/crumbs/hobeventhandler.py
index 1a7427a812..292d9056b2 100644
--- a/bitbake/lib/bb/ui/crumbs/hobeventhandler.py
+++ b/bitbake/lib/bb/ui/crumbs/hobeventhandler.py
@@ -253,43 +253,42 @@ class HobHandler(gobject.GObject):
253 self.server.runCommand(["setVariable", "INHERIT", inherits]) 253 self.server.runCommand(["setVariable", "INHERIT", inherits])
254 254
255 def set_bblayers(self, bblayers): 255 def set_bblayers(self, bblayers):
256 self.server.runCommand(["setVariable", "BBLAYERS", " ".join(bblayers)]) 256 self.server.runCommand(["setVariable", "BBLAYERS_HOB", " ".join(bblayers)])
257 257
258 def set_machine(self, machine): 258 def set_machine(self, machine):
259 if machine: 259 if machine:
260 self.server.runCommand(["setVariable", "MACHINE", machine]) 260 self.server.runCommand(["setVariable", "MACHINE_HOB", machine])
261 261
262 def set_sdk_machine(self, sdk_machine): 262 def set_sdk_machine(self, sdk_machine):
263 self.server.runCommand(["setVariable", "SDKMACHINE", sdk_machine]) 263 self.server.runCommand(["setVariable", "SDKMACHINE_HOB", sdk_machine])
264 264
265 def set_image_fstypes(self, image_fstypes): 265 def set_image_fstypes(self, image_fstypes):
266 self.server.runCommand(["setVariable", "IMAGE_FSTYPES", image_fstypes]) 266 self.server.runCommand(["setVariable", "IMAGE_FSTYPES", image_fstypes])
267 267
268 def set_distro(self, distro): 268 def set_distro(self, distro):
269 if distro != "defaultsetup": 269 self.server.runCommand(["setVariable", "DISTRO_HOB", distro])
270 self.server.runCommand(["setVariable", "DISTRO", distro])
271 270
272 def set_package_format(self, format): 271 def set_package_format(self, format):
273 package_classes = "" 272 package_classes = ""
274 for pkgfmt in format.split(): 273 for pkgfmt in format.split():
275 package_classes += ("package_%s" % pkgfmt + " ") 274 package_classes += ("package_%s" % pkgfmt + " ")
276 self.server.runCommand(["setVariable", "PACKAGE_CLASSES", package_classes]) 275 self.server.runCommand(["setVariable", "PACKAGE_CLASSES_HOB", package_classes])
277 276
278 def set_bbthreads(self, threads): 277 def set_bbthreads(self, threads):
279 self.server.runCommand(["setVariable", "BB_NUMBER_THREADS", threads]) 278 self.server.runCommand(["setVariable", "BB_NUMBER_THREADS_HOB", threads])
280 279
281 def set_pmake(self, threads): 280 def set_pmake(self, threads):
282 pmake = "-j %s" % threads 281 pmake = "-j %s" % threads
283 self.server.runCommand(["setVariable", "PARALLEL_MAKE", pmake]) 282 self.server.runCommand(["setVariable", "PARALLEL_MAKE_HOB", pmake])
284 283
285 def set_dl_dir(self, directory): 284 def set_dl_dir(self, directory):
286 self.server.runCommand(["setVariable", "DL_DIR", directory]) 285 self.server.runCommand(["setVariable", "DL_DIR_HOB", directory])
287 286
288 def set_sstate_dir(self, directory): 287 def set_sstate_dir(self, directory):
289 self.server.runCommand(["setVariable", "SSTATE_DIR", directory]) 288 self.server.runCommand(["setVariable", "SSTATE_DIR_HOB", directory])
290 289
291 def set_sstate_mirror(self, url): 290 def set_sstate_mirror(self, url):
292 self.server.runCommand(["setVariable", "SSTATE_MIRROR", url]) 291 self.server.runCommand(["setVariable", "SSTATE_MIRROR_HOB", url])
293 292
294 def set_extra_size(self, image_extra_size): 293 def set_extra_size(self, image_extra_size):
295 self.server.runCommand(["setVariable", "IMAGE_ROOTFS_EXTRA_SPACE", str(image_extra_size)]) 294 self.server.runCommand(["setVariable", "IMAGE_ROOTFS_EXTRA_SPACE", str(image_extra_size)])
@@ -298,13 +297,16 @@ class HobHandler(gobject.GObject):
298 self.server.runCommand(["setVariable", "IMAGE_ROOTFS_SIZE", str(image_rootfs_size)]) 297 self.server.runCommand(["setVariable", "IMAGE_ROOTFS_SIZE", str(image_rootfs_size)])
299 298
300 def set_incompatible_license(self, incompat_license): 299 def set_incompatible_license(self, incompat_license):
301 self.server.runCommand(["setVariable", "INCOMPATIBLE_LICENSE", incompat_license]) 300 self.server.runCommand(["setVariable", "INCOMPATIBLE_LICENSE_HOB", incompat_license])
302 301
303 def set_extra_config(self, extra_setting): 302 def set_extra_config(self, extra_setting):
304 for key in extra_setting.keys(): 303 for key in extra_setting.keys():
305 value = extra_setting[key] 304 value = extra_setting[key]
306 self.server.runCommand(["setVariable", key, value]) 305 self.server.runCommand(["setVariable", key, value])
307 306
307 def set_config_filter(self, config_filter):
308 self.server.runCommand(["setConfFilter", config_filter])
309
308 def set_http_proxy(self, http_proxy): 310 def set_http_proxy(self, http_proxy):
309 self.server.runCommand(["setVariable", "http_proxy", http_proxy]) 311 self.server.runCommand(["setVariable", "http_proxy", http_proxy])
310 312