Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(599)

Side by Side Diff: chrome/browser/autocomplete/bookmark_provider.h

Issue 10913262: Implement Bookmark Autocomplete Provider (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Now handles duplicate term matching. Comments, etc. Created 8 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
Property Changes:
Added: svn:eol-style
+ LF
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CHROME_BROWSER_AUTOCOMPLETE_BOOKMARK_PROVIDER_H_
6 #define CHROME_BROWSER_AUTOCOMPLETE_BOOKMARK_PROVIDER_H_
7
8 #include <string>
9
10 #include "chrome/browser/autocomplete/autocomplete_input.h"
11 #include "chrome/browser/autocomplete/autocomplete_match.h"
12 #include "chrome/browser/autocomplete/autocomplete_provider.h"
13 #include "chrome/browser/bookmarks/bookmark_utils.h"
14 #include "chrome/browser/history/snippet.h"
15
16 class BookmarkModel;
17 class Profile;
18
19 // This class is an autocomplete provider which quickly (and synchronously)
20 // provides autocomplete suggestions based on the titles of bookmarks. Page
21 // titles, URLs, and typed and visit counts of the bookmarks are not taken into
Peter Kasting 2012/10/10 18:29:06 The old comment said "Page titles and URLs are not
mrossetti 2012/10/15 19:22:46 Exactly right. But I wanted to get this basic impl
22 // consideration as those factors will have been used by the
23 // HistoryQuickProvider in identifying suggestions.
24 class BookmarkProvider : public AutocompleteProvider {
25 public:
26 BookmarkProvider(AutocompleteProviderListener* listener, Profile* profile);
27
28 // AutocompleteProvider. When |minimal_changes| is true short circuit any
29 // additional searching and leave the previous matches for this provider
30 // unchanged.
31 virtual void Start(const AutocompleteInput& input,
32 bool minimal_changes) OVERRIDE;
33
34 // Sets the BookmarkModel for unit tests.
35 void set_bookmark_model_for_testing(BookmarkModel* bookmark_model) {
36 bookmark_model_ = bookmark_model;
37 }
38
39 private:
40 virtual ~BookmarkProvider();
41
42 // Performs the actual matching of |input| over the bookmarks and fills in
43 // |matches_|. If |best_match| then only suggest the single best match,
44 // otherwise suggest the top |kMaxMatches| matches.
45 void DoAutocomplete(const AutocompleteInput& input, bool best_match);
46
47 // Calculates a relevance for |title_match|, converts it to an
48 // AutocompleteMatch and returns the converted match.
49 AutocompleteMatch TitleMatchToACMatch(
50 const bookmark_utils::TitleMatch& title_match);
51
52 // Converts |positions| into ACMatchClassifications and returns the
53 // classifications. |text_length| is used to determine the need to add an
54 // 'unhighlighted' classification span so the tail of the source string
55 // properly highlighted.
56 static ACMatchClassifications ClassificationsFromMatch(
57 const Snippet::MatchPositions& positions,
58 size_t text_length);
59
60 BookmarkModel* bookmark_model_;
61
62 // Languages used during the URL formatting.
63 std::string languages_;
64
65 DISALLOW_COPY_AND_ASSIGN(BookmarkProvider);
66 };
67
68 #endif // CHROME_BROWSER_AUTOCOMPLETE_BOOKMARK_PROVIDER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698