Index: chrome/browser/autocomplete/bookmark_provider.h |
=================================================================== |
--- chrome/browser/autocomplete/bookmark_provider.h (revision 0) |
+++ chrome/browser/autocomplete/bookmark_provider.h (revision 0) |
@@ -0,0 +1,59 @@ |
+#ifndef CHROME_BROWSER_AUTOCOMPLETE_BOOKMARK_PROVIDER_H_ |
+#define CHROME_BROWSER_AUTOCOMPLETE_BOOKMARK_PROVIDER_H_ |
+ |
+#include "chrome/browser/autocomplete/autocomplete_input.h" |
+#include "chrome/browser/autocomplete/autocomplete_match.h" |
+#include "chrome/browser/autocomplete/autocomplete_provider.h" |
+#include "chrome/browser/bookmarks/bookmark_utils.h" |
+#include "chrome/browser/history/snippet.h" |
+ |
+class BookmarkModel; |
+class Profile; |
+ |
+// This class is an autocomplete provider which quickly (and synchronously) |
+// provides autocomplete suggestions based on matches between the search terms |
+// entered by the user into the omnibox and the titles of bookmarks. Page |
+// titles and URLs of the bookmarks are not matched. |
+class BookmarkProvider : public AutocompleteProvider { |
+ public: |
+ BookmarkProvider(AutocompleteProviderListener* listener, Profile* profile); |
+ |
+ // AutocompleteProvider. |minimal_changes| is ignored since there is no |
+ // asynch completion performed. |
+ virtual void Start(const AutocompleteInput& input, |
+ bool minimal_changes) OVERRIDE; |
+ |
+ // Sets the BookmarkModel for unit tests. |
+ void set_bookmark_model_for_testing(BookmarkModel* bookmark_model) { |
Mark P
2012/09/28 00:55:13
Should this be private and a friend to your test c
mrossetti
2012/10/02 00:44:16
Not necessarily. There is no style guidance for th
Mark P
2012/10/03 20:40:14
You can make a function a friend without having to
|
+ bookmark_model_ = bookmark_model; |
+ } |
+ |
+ private: |
+ virtual ~BookmarkProvider(); |
+ |
+ // Performs the actual matching of |input| over the bookmarks and fills in |
+ // matches. If |best_match| then only return the single best match, otherwise |
Mark P
2012/09/28 00:55:13
matches -> |matches_|
mrossetti
2012/10/02 00:44:16
Done.
|
+ // return the top |kMaxMatches| matches. |
Mark P
2012/09/28 00:55:13
Using return (both times) in the above sentence is
mrossetti
2012/10/02 00:44:16
Done.
|
+ void DoAutocomplete(const AutocompleteInput& input, bool best_match); |
+ |
+ // Converts |title_match| to an AutocompleteMatch and returns the converted |
+ // match. |
+ AutocompleteMatch TitleMatchToACMatch( |
Mark P
2012/09/28 00:55:13
Can this be static or at least const?
mrossetti
2012/10/02 00:44:16
Unfortunately, neither. Can't be static because it
|
+ const bookmark_utils::TitleMatch& title_match); |
+ |
+ // Converts |positions| into ACMatchClassifications and returns the |
+ // classifications. |text_length| is used to determine the need for a |
+ // terminating classification. |
Mark P
2012/09/28 00:55:13
I don't understand the last sentence. (What is a
mrossetti
2012/10/02 00:44:16
I've updated the comment a bit, but for your edifi
|
+ static ACMatchClassifications SpansFromMatch( |
+ const Snippet::MatchPositions& positions, |
+ size_t text_length); |
+ |
+ BookmarkModel* bookmark_model_; |
+ |
+ // Languages used during the URL formatting. |
+ std::string languages_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(BookmarkProvider); |
+}; |
+ |
+#endif // CHROME_BROWSER_AUTOCOMPLETE_BOOKMARK_PROVIDER_H_ |
Property changes on: chrome/browser/autocomplete/bookmark_provider.h |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |