Chromium Code Reviews| 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 |