aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorCristiana Voicu <cristiana.voicu@intel.com>2012-11-26 09:42:36 +0200
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-11-26 14:21:17 +0000
commit05da1621eed4c6201cd65372d229f63ea8a44b6e (patch)
treea2719e7cd1a7173f508ec5bf37d3ae356d657406 /lib
parentcc7fdbdc607df530f5539b162831bf9998eb48d8 (diff)
downloadbitbake-05da1621eed4c6201cd65372d229f63ea8a44b6e.tar.gz
hob: make some layers non removable
- there are some layers which cannot be removed; so ,I have used a new variable called BBLAYERS_NON_REMOVABLE located in bblayers.conf, which contains those layers which cannot be deleted - "meta-hob" layer is added to this variable in hob code, like it's added to BBLAYERS var [YOCTO #3176] Signed-off-by: Cristiana Voicu <cristiana.voicu@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'lib')
-rwxr-xr-xlib/bb/ui/crumbs/builder.py2
-rw-r--r--lib/bb/ui/crumbs/hig.py15
-rw-r--r--lib/bb/ui/crumbs/hobeventhandler.py3
3 files changed, 10 insertions, 10 deletions
diff --git a/lib/bb/ui/crumbs/builder.py b/lib/bb/ui/crumbs/builder.py
index d10c681df..2f3d6d0c6 100755
--- a/lib/bb/ui/crumbs/builder.py
+++ b/lib/bb/ui/crumbs/builder.py
@@ -172,6 +172,7 @@ class Configuration:
# self.extra_setting/self.toolchain_build
# bblayers.conf
self.layers = params["layer"].split()
+ self.layers_non_removable = params["layers_non_removable"].split()
self.default_task = params["default_task"]
# proxy settings
@@ -1200,6 +1201,7 @@ class Builder(gtk.Window):
def show_layer_selection_dialog(self):
dialog = LayerSelectionDialog(title = "Layers",
layers = copy.deepcopy(self.configuration.layers),
+ layers_non_removable = copy.deepcopy(self.configuration.layers_non_removable),
all_layers = self.parameters.all_layers,
parent = self,
flags = gtk.DIALOG_MODAL
diff --git a/lib/bb/ui/crumbs/hig.py b/lib/bb/ui/crumbs/hig.py
index d97308610..e56cf2a75 100644
--- a/lib/bb/ui/crumbs/hig.py
+++ b/lib/bb/ui/crumbs/hig.py
@@ -1665,11 +1665,12 @@ class LayerSelectionDialog (CrumbsDialog):
def add_leave_cb(self, button, event):
self.im.set_from_file(hic.ICON_INDI_ADD_FILE)
- def __init__(self, title, layers, all_layers, parent, flags, buttons=None):
+ def __init__(self, title, layers, layers_non_removable, all_layers, parent, flags, buttons=None):
super(LayerSelectionDialog, self).__init__(title, parent, flags, buttons)
# class members from other objects
self.layers = layers
+ self.layers_non_removable = layers_non_removable
self.all_layers = all_layers
self.layers_changed = False
@@ -1709,10 +1710,7 @@ class LayerSelectionDialog (CrumbsDialog):
"""
def draw_delete_button_cb(self, col, cell, model, it, tv):
path = model.get_value(it, 0)
- # Trailing slashes are uncommon in bblayers.conf but confuse os.path.basename
- path.rstrip('/')
- name = os.path.basename(path)
- if name == "meta" or name == "meta-hob":
+ if path in self.layers_non_removable:
cell.set_sensitive(False)
cell.set_property('pixbuf', None)
cell.set_property('mode', gtk.CELL_RENDERER_MODE_INERT)
@@ -1730,11 +1728,8 @@ class LayerSelectionDialog (CrumbsDialog):
"""
def draw_layer_path_cb(self, col, cell, model, it):
path = model.get_value(it, 0)
- name = os.path.basename(path)
- if name == "meta":
- cell.set_property('markup', "<b>Core layer for images: it cannot be removed</b>\n%s" % path)
- elif name == "meta-hob":
- cell.set_property('markup', "<b>Core layer for Hob: it cannot be removed</b>\n%s" % path)
+ if path in self.layers_non_removable:
+ cell.set_property('markup', "<b>It cannot be removed</b>\n%s" % path)
else:
cell.set_property('text', path)
diff --git a/lib/bb/ui/crumbs/hobeventhandler.py b/lib/bb/ui/crumbs/hobeventhandler.py
index 4b908f904..ae1cefc53 100644
--- a/lib/bb/ui/crumbs/hobeventhandler.py
+++ b/lib/bb/ui/crumbs/hobeventhandler.py
@@ -435,8 +435,11 @@ class HobHandler(gobject.GObject):
params["core_base"] = self.runCommand(["getVariable", "COREBASE"]) or ""
hob_layer = params["core_base"] + "/meta-hob"
params["layer"] = self.runCommand(["getVariable", "BBLAYERS"]) or ""
+ params["layers_non_removable"] = self.runCommand(["getVariable", "BBLAYERS_NON_REMOVABLE"])
if hob_layer not in params["layer"].split():
params["layer"] += (" " + hob_layer)
+ if hob_layer not in params["layers_non_removable"].split():
+ params["layers_non_removable"] += (" " + hob_layer)
params["dldir"] = self.runCommand(["getVariable", "DL_DIR"]) or ""
params["machine"] = self.runCommand(["getVariable", "MACHINE"]) or ""
params["distro"] = self.runCommand(["getVariable", "DISTRO"]) or "defaultsetup"