From c1b31f899675bafd4b69e567299f968a0a52cc2e Mon Sep 17 00:00:00 2001 From: Joshua Lock Date: Wed, 17 Aug 2011 20:17:42 -0700 Subject: bb/ui/crumbs/tasklistmodel: more robust checking for substrings Relying on the count() method of Str to determine whether the string contains a substring is error prone purely because the return value doesn't strictly convert to a Boolean value. To that end take the more pythonic approach of using the in operator (foo in bar) to check for the substring. Further, add a helper method for the common case of testing whether a pn is -native, -cross or virtual/ (Bitbake rev: d7768cefcddd59a5102d7e9b67e4416bf8603f55) Signed-off-by: Joshua Lock Signed-off-by: Richard Purdie --- bitbake/lib/bb/ui/crumbs/tasklistmodel.py | 26 +++++++++++++++++--------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/bitbake/lib/bb/ui/crumbs/tasklistmodel.py b/bitbake/lib/bb/ui/crumbs/tasklistmodel.py index 203b6284ac..fa16609678 100644 --- a/bitbake/lib/bb/ui/crumbs/tasklistmodel.py +++ b/bitbake/lib/bb/ui/crumbs/tasklistmodel.py @@ -124,6 +124,14 @@ class TaskListModel(gtk.ListStore): gobject.TYPE_BOOLEAN, gobject.TYPE_STRING) + """ + Helper method to determine whether name is a target pn + """ + def non_target_name(self, name): + if ('-native' in name) or ('-cross' in name) or name.startswith('virtual/'): + return True + return False + def contents_changed_cb(self, tree_model, path, it=None): pkg_cnt = self.contents.iter_n_children(None) self.emit("contents-changed", pkg_cnt) @@ -132,7 +140,7 @@ class TaskListModel(gtk.ListStore): if not model.get_value(it, self.COL_INC) or model.get_value(it, self.COL_TYPE) == 'image': return False name = model.get_value(it, self.COL_NAME) - if name.count('-native') or name.count('-cross'): + if self.non_target_name(name): return False else: return True @@ -196,7 +204,7 @@ class TaskListModel(gtk.ListStore): return False else: name = model.get_value(it, self.COL_NAME) - if name.count('-native') or name.count('-cross'): + if self.non_target_name(name): return False return True @@ -226,9 +234,9 @@ class TaskListModel(gtk.ListStore): lic = event_model["pn"][item]["license"] group = event_model["pn"][item]["section"] filename = event_model["pn"][item]["filename"] - if name.count('task-') > 0: + if ('task-' in name): atype = 'task' - elif name.count('-image-') > 0: + elif ('-image-' in name): atype = 'image' depends = event_model["depends"].get(item, []) @@ -352,14 +360,14 @@ class TaskListModel(gtk.ListStore): # If the iterated item is included and depends on the removed # item it should also be removed. # FIXME: need to ensure partial name matching doesn't happen - if inc and deps.count(marked_name) and itname not in removed: + if inc and marked_name in deps and itname not in removed: # found a dependency, remove it removed.append(itname) self.mark(path) # If the iterated item was brought in by the removed (passed) item # try and find an alternative dependee and update the binb column - if inc and binb.count(marked_name): + if inc and marked_name in binb: bib = self.find_alt_dependency(itname) self[path][self.COL_BINB] = bib @@ -411,7 +419,7 @@ class TaskListModel(gtk.ListStore): deps = self.contents[path][self.COL_DEPS] itname = self.contents[path][self.COL_NAME] inc = self.contents[path][self.COL_INC] - if itname != name and inc and deps.count(name) > 0: + if itname != name and inc and name in deps: # if this item depends on the item, return this items name return itname it = self.contents.iter_next(it) @@ -471,7 +479,7 @@ class TaskListModel(gtk.ListStore): def find_path_for_item(self, item_name): # We don't include virtual/* or *-native items in the model so save a # heavy iteration loop by exiting early for these items - if item_name.startswith("virtual/") or item_name.count('-native') or item_name.count('-cross'): + if self.non_target_name(item_name): return None it = self.get_iter_first() @@ -561,7 +569,7 @@ class TaskListModel(gtk.ListStore): if not itype == 'package': continue - if deps.count(pn) != 0: + if pn not in deps: revdeps.append(name) if pn in revdeps: -- cgit v1.2.3-54-g00ecf