~loggerhead-team/loggerhead/trunk-rich

« back to all changes in this revision

Viewing changes to loggerhead/controllers/search_ui.py

  • Committer: Michael Hudson
  • Date: 2008-06-22 23:53:25 UTC
  • Revision ID: michael.hudson@canonical.com-20080622235325-fs0yapvfxn3xhkro
make serve-branches.py executable

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
# Copyright (C) 2008  Canonical Ltd.
2
 
#                     (Authored by Martin Albisetti <argentina@gmail.com>)
3
 
#
4
 
# This program is free software; you can redistribute it and/or modify
5
 
# it under the terms of the GNU General Public License as published by
6
 
# the Free Software Foundation; either version 2 of the License, or
7
 
# (at your option) any later version.
8
 
#
9
 
# This program is distributed in the hope that it will be useful,
10
 
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 
# GNU General Public License for more details.
13
 
#
14
 
# You should have received a copy of the GNU General Public License
15
 
# along with this program; if not, write to the Free Software
16
 
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
17
 
#
18
 
 
19
 
from loggerhead.controllers import TemplatedBranchView
20
 
from loggerhead import search
21
 
 
22
 
 
23
 
class SearchUI(TemplatedBranchView):
24
 
    """
25
 
 
26
 
    Class to output progressive search result terms.
27
 
    """
28
 
 
29
 
    template_path = 'loggerhead.templates.search'
30
 
 
31
 
    def get_values(self, h, args, kwargs, response):
32
 
        """
33
 
        Default method called from the search box as /search URL
34
 
 
35
 
        Returns a list of suggested search terms parsed through the
36
 
        templating engine.
37
 
        """
38
 
        terms = []
39
 
        query = kwargs['query']
40
 
        if len(query) > 0:
41
 
            terms = search.search_revisions(h._branch, query, True)
42
 
            if terms is not None:
43
 
                terms = [term[0] for term in terms]
44
 
            else:
45
 
                # Should show a 'search is not available' etc box.
46
 
                terms = []
47
 
 
48
 
        return {'terms':terms}