summaryrefslogtreecommitdiffstats
path: root/bitbake
diff options
context:
space:
mode:
authorCristiana Voicu <cristiana.voicu@intel.com>2013-03-27 17:20:07 +0200
committerRichard Purdie <richard.purdie@linuxfoundation.org>2013-03-29 10:41:25 +0000
commit2f4fe1ee111a3dff68ac1cea6f3f6767cd6fe4eb (patch)
tree7ecc49a7043292e18266b1078774f19992d99122 /bitbake
parente98716fc923f0aa60c85ce3547eb416a6af32971 (diff)
downloadpoky-2f4fe1ee111a3dff68ac1cea6f3f6767cd6fe4eb.tar.gz
bitbake: hob: Search strings and results should be persistent
Now, the search results stay until I clear the search field, so that I can manipulate the search results. [YOCTO #4112 & #4117] (Bitbake rev: d880ce966ca825aa66a23755fcb47497fb3f26c3) Signed-off-by: Cristiana Voicu <cristiana.voicu@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake')
-rw-r--r--bitbake/lib/bb/ui/crumbs/hobwidget.py9
-rwxr-xr-xbitbake/lib/bb/ui/crumbs/packageselectionpage.py35
-rwxr-xr-xbitbake/lib/bb/ui/crumbs/recipeselectionpage.py35
3 files changed, 43 insertions, 36 deletions
diff --git a/bitbake/lib/bb/ui/crumbs/hobwidget.py b/bitbake/lib/bb/ui/crumbs/hobwidget.py
index 17d9cee138..51ae78265f 100644
--- a/bitbake/lib/bb/ui/crumbs/hobwidget.py
+++ b/bitbake/lib/bb/ui/crumbs/hobwidget.py
@@ -537,14 +537,18 @@ class HobNotebook(gtk.Notebook):
537 537
538 def set_search_entry_editable_cb(self, search, event): 538 def set_search_entry_editable_cb(self, search, event):
539 search.set_editable(True) 539 search.set_editable(True)
540 search.set_text("") 540 text = search.get_text()
541 if text in self.search_names:
542 search.set_text("")
541 style = self.search.get_style() 543 style = self.search.get_style()
542 style.text[gtk.STATE_NORMAL] = self.get_colormap().alloc_color(HobColors.BLACK, False, False) 544 style.text[gtk.STATE_NORMAL] = self.get_colormap().alloc_color(HobColors.BLACK, False, False)
543 search.set_style(style) 545 search.set_style(style)
544 546
545 def set_search_entry_reset_cb(self, search, event): 547 def set_search_entry_reset_cb(self, search, event):
546 page_num = self.get_current_page() 548 page_num = self.get_current_page()
547 self.reset_entry(search, page_num) 549 text = search.get_text()
550 if not text:
551 self.reset_entry(search, page_num)
548 552
549 def reset_entry(self, entry, page_num): 553 def reset_entry(self, entry, page_num):
550 style = entry.get_style() 554 style = entry.get_style()
@@ -559,6 +563,7 @@ class HobNotebook(gtk.Notebook):
559 if search.get_editable() == True: 563 if search.get_editable() == True:
560 search.set_text("") 564 search.set_text("")
561 search.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, False) 565 search.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, False)
566 search.grab_focus()
562 567
563 def set_page(self, title): 568 def set_page(self, title):
564 for child in self.pages: 569 for child in self.pages:
diff --git a/bitbake/lib/bb/ui/crumbs/packageselectionpage.py b/bitbake/lib/bb/ui/crumbs/packageselectionpage.py
index 3b00ff2377..781d579d6c 100755
--- a/bitbake/lib/bb/ui/crumbs/packageselectionpage.py
+++ b/bitbake/lib/bb/ui/crumbs/packageselectionpage.py
@@ -180,24 +180,25 @@ class PackageSelectionPage (HobPage):
180 self.button_box.pack_end(self.back_button, expand=False, fill=False) 180 self.button_box.pack_end(self.back_button, expand=False, fill=False)
181 181
182 def search_entry_changed(self, entry): 182 def search_entry_changed(self, entry):
183 current_tab = self.ins.get_current_page()
184 filter = self.pages[current_tab]['filter']
185 text = entry.get_text() 183 text = entry.get_text()
186 filter[PackageListModel.COL_NAME] = text 184 if text not in self.ins.search_names:
187 self.tables[current_tab].set_model(self.package_model.tree_model(filter, search_data=text)) 185 current_tab = self.ins.get_current_page()
188 if self.package_model.filtered_nb == 0: 186 filter = self.pages[current_tab]['filter']
189 if not self.ins.get_nth_page(current_tab).top_bar: 187 filter[PackageListModel.COL_NAME] = text
190 self.ins.get_nth_page(current_tab).add_no_result_bar(entry) 188 self.tables[current_tab].set_model(self.package_model.tree_model(filter, search_data=text))
191 self.ins.get_nth_page(current_tab).top_bar.show() 189 if self.package_model.filtered_nb == 0:
192 self.ins.get_nth_page(current_tab).scroll.hide() 190 if not self.ins.get_nth_page(current_tab).top_bar:
193 else: 191 self.ins.get_nth_page(current_tab).add_no_result_bar(entry)
194 if self.ins.get_nth_page(current_tab).top_bar: 192 self.ins.get_nth_page(current_tab).top_bar.show()
195 self.ins.get_nth_page(current_tab).top_bar.hide() 193 self.ins.get_nth_page(current_tab).scroll.hide()
196 self.ins.get_nth_page(current_tab).scroll.show() 194 else:
197 if entry.get_text() == '': 195 if self.ins.get_nth_page(current_tab).top_bar:
198 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, False) 196 self.ins.get_nth_page(current_tab).top_bar.hide()
199 else: 197 self.ins.get_nth_page(current_tab).scroll.show()
200 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, True) 198 if entry.get_text() == '':
199 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, False)
200 else:
201 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, True)
201 202
202 def button_click_cb(self, widget, event): 203 def button_click_cb(self, widget, event):
203 path, col = widget.table_tree.get_cursor() 204 path, col = widget.table_tree.get_cursor()
diff --git a/bitbake/lib/bb/ui/crumbs/recipeselectionpage.py b/bitbake/lib/bb/ui/crumbs/recipeselectionpage.py
index aa0cd60c3f..47bb253309 100755
--- a/bitbake/lib/bb/ui/crumbs/recipeselectionpage.py
+++ b/bitbake/lib/bb/ui/crumbs/recipeselectionpage.py
@@ -195,24 +195,25 @@ class RecipeSelectionPage (HobPage):
195 button_box.pack_end(self.back_button, expand=False, fill=False) 195 button_box.pack_end(self.back_button, expand=False, fill=False)
196 196
197 def search_entry_changed(self, entry): 197 def search_entry_changed(self, entry):
198 current_tab = self.ins.get_current_page()
199 filter = self.pages[current_tab]['filter']
200 text = entry.get_text() 198 text = entry.get_text()
201 filter[RecipeListModel.COL_NAME] = text 199 if text not in self.ins.search_names:
202 self.tables[current_tab].set_model(self.recipe_model.tree_model(filter, search_data=text)) 200 current_tab = self.ins.get_current_page()
203 if self.recipe_model.filtered_nb == 0: 201 filter = self.pages[current_tab]['filter']
204 if not self.ins.get_nth_page(current_tab).top_bar: 202 filter[RecipeListModel.COL_NAME] = text
205 self.ins.get_nth_page(current_tab).add_no_result_bar(entry) 203 self.tables[current_tab].set_model(self.recipe_model.tree_model(filter, search_data=text))
206 self.ins.get_nth_page(current_tab).top_bar.show() 204 if self.recipe_model.filtered_nb == 0:
207 self.ins.get_nth_page(current_tab).scroll.hide() 205 if not self.ins.get_nth_page(current_tab).top_bar:
208 else: 206 self.ins.get_nth_page(current_tab).add_no_result_bar(entry)
209 if self.ins.get_nth_page(current_tab).top_bar: 207 self.ins.get_nth_page(current_tab).top_bar.show()
210 self.ins.get_nth_page(current_tab).top_bar.hide() 208 self.ins.get_nth_page(current_tab).scroll.hide()
211 self.ins.get_nth_page(current_tab).scroll.show() 209 else:
212 if entry.get_text() == '': 210 if self.ins.get_nth_page(current_tab).top_bar:
213 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, False) 211 self.ins.get_nth_page(current_tab).top_bar.hide()
214 else: 212 self.ins.get_nth_page(current_tab).scroll.show()
215 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, True) 213 if entry.get_text() == '':
214 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, False)
215 else:
216 entry.set_icon_sensitive(gtk.ENTRY_ICON_SECONDARY, True)
216 217
217 def button_click_cb(self, widget, event): 218 def button_click_cb(self, widget, event):
218 path, col = widget.table_tree.get_cursor() 219 path, col = widget.table_tree.get_cursor()