/b-gtk/fix-viz

To get this branch, use:
bzr branch http://gegoxaren.bato24.eu/bzr/b-gtk/fix-viz

« back to all changes in this revision

Viewing changes to search.py

  • Committer: Curtis Hovey
  • Date: 2011-08-12 20:25:28 UTC
  • mto: This revision was merged to the branch mainline in revision 741.
  • Revision ID: sinzui.is@verizon.net-20110812202528-4xf4a2t23urx50d2
Updated gst to gtk3.

Show diffs side-by-side

added added

removed removed

Lines of Context:
21
21
 
22
22
from bzrlib.plugins.gtk.i18n import _i18n
23
23
 
24
 
 
25
24
class SearchDialog(Gtk.Dialog):
26
25
    """Search dialog."""
27
 
 
28
26
    def __init__(self, index, parent=None):
29
 
        super(SearchDialog, self).__init__(
30
 
            title="Search Revisions", parent=parent,
31
 
            flags=Gtk.DialogFlags.MODAL,
32
 
            buttons=(Gtk.STOCK_OK, Gtk.ResponseType.OK,
33
 
                Gtk.STOCK_CANCEL, Gtk.ResponseType.CANCEL))
34
 
        pixbuf = self.render_icon_pixbuf(Gtk.STOCK_FIND, Gtk.IconSize.MENU)
 
27
        GObject.GObject.__init__(self, title="Search Revisions",
 
28
                                  parent=parent,
 
29
                                  flags=Gtk.DialogFlags.MODAL,
 
30
                                  buttons=(Gtk.STOCK_OK, Gtk.ResponseType.OK,
 
31
                                           Gtk.STOCK_CANCEL, Gtk.ResponseType.CANCEL))
 
32
        pixbuf = self.render_icon(Gtk.STOCK_FIND, Gtk.IconSize.MENU)
35
33
        self.set_icon(pixbuf)
36
34
        
37
35
        # Get arguments
44
42
        self.searchentry.connect('activate', self._searchentry_activate)
45
43
        # TODO: Completion using the bzr-search suggests functionality
46
44
        self.searchbar.add(self.searchentry)
47
 
        self.get_content_area().pack_start(self.searchbar, False, False, 0)
 
45
        self.vbox.pack_start(self.searchbar, expand=False, fill=False)
48
46
 
49
 
        self.results_model = Gtk.ListStore(
50
 
            GObject.TYPE_STRING, GObject.TYPE_STRING, GObject.TYPE_PYOBJECT)
 
47
        self.results_model = Gtk.ListStore(GObject.TYPE_STRING, GObject.TYPE_STRING, GObject.TYPE_PYOBJECT)
51
48
        self.results_treeview = Gtk.TreeView(self.results_model)
52
 
        self.results_treeview.connect(
53
 
            "row-activated", self._searchresult_row_activated)
 
49
        self.results_treeview.connect("row-activated", self._searchresult_row_activated)
54
50
 
55
 
        documentname_column = Gtk.TreeViewColumn(
56
 
            _i18n("Document"), Gtk.CellRendererText(), text=0)
 
51
        documentname_column = Gtk.TreeViewColumn(_i18n("Document"), Gtk.CellRendererText(), text=0)
57
52
        self.results_treeview.append_column(documentname_column)
58
53
 
59
 
        summary_column = Gtk.TreeViewColumn(
60
 
            _i18n("Summary"), Gtk.CellRendererText(), text=1)
 
54
        summary_column = Gtk.TreeViewColumn(_i18n("Summary"), Gtk.CellRendererText(), text=1)
61
55
        self.results_treeview.append_column(summary_column)
62
56
 
63
57
        results_scrolledwindow = Gtk.ScrolledWindow()
64
 
        results_scrolledwindow.set_policy(
65
 
            Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
 
58
        results_scrolledwindow.set_policy(Gtk.PolicyType.NEVER, Gtk.PolicyType.AUTOMATIC)
66
59
        results_scrolledwindow.add(self.results_treeview)
67
60
 
68
 
        self.get_content_area().pack_start(
69
 
            results_scrolledwindow, True, True, 0)
 
61
        self.vbox.pack_start(results_scrolledwindow, expand=True, fill=True)
70
62
 
71
63
        self.set_default_size(600, 400)
72
64
        # Show the dialog
83
75
        self.results_model.clear()
84
76
        self.index._branch.lock_read()
85
77
        try:
86
 
            query = [
87
 
                (query_item,)
88
 
                for query_item in self.searchentry.get_text().split(" ")]
 
78
            query = [(query_item,) for query_item in self.searchentry.get_text().split(" ")]
89
79
            for result in self.index.search(query):
90
80
                if isinstance(result, _mod_index.FileTextHit):
91
81
                    revid = result.text_key[-1]
93
83
                    revid = result.revision_key[0]
94
84
                else:
95
85
                    raise AssertionError()
96
 
                self.results_model.append(
97
 
                    [result.document_name(), result.summary(), revid])
 
86
                self.results_model.append([result.document_name(), result.summary(), revid])
98
87
        finally:
99
88
            self.index._branch.unlock()
100
89