blob: b8bcc431b2f34a7c76212ce9da7511a89d201fcd [file] [log] [blame]
// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_OMNIBOX_BROWSER_BOOKMARK_PROVIDER_H_
#define COMPONENTS_OMNIBOX_BROWSER_BOOKMARK_PROVIDER_H_
#include <stddef.h>
#include <vector>
#include "base/gtest_prod_util.h"
#include "base/memory/raw_ptr.h"
#include "components/bookmarks/browser/titled_url_match.h"
#include "components/omnibox/browser/autocomplete_input.h"
#include "components/omnibox/browser/autocomplete_provider.h"
class AutocompleteProviderClient;
namespace bookmarks {
class BookmarkModel;
struct TitledUrlMatch;
} // namespace bookmarks
// This class is an autocomplete provider which quickly (and synchronously)
// provides autocomplete suggestions based on the titles of bookmarks. Page
// titles, URLs, and typed and visit counts of the bookmarks are not currently
// taken into consideration as those factors will have been used by the
// HistoryQuickProvider (HQP) while identifying suggestions.
//
// TODO(mrossetti): Propose a way to coordinate with the HQP the taking of typed
// and visit counts and last visit dates, etc. into consideration while scoring.
class BookmarkProvider : public AutocompleteProvider {
public:
explicit BookmarkProvider(AutocompleteProviderClient* client);
BookmarkProvider(const BookmarkProvider&) = delete;
BookmarkProvider& operator=(const BookmarkProvider&) = delete;
// When |minimal_changes| is true short circuit any additional searching and
// leave the previous matches for this provider unchanged, otherwise perform
// a complete search for |input| across all bookmark titles.
void Start(const AutocompleteInput& input, bool minimal_changes) override;
private:
FRIEND_TEST_ALL_PREFIXES(BookmarkProviderTest, InlineAutocompletion);
FRIEND_TEST_ALL_PREFIXES(BookmarkProviderTest, MatchingAlgorithmForHubSearch);
~BookmarkProvider() override;
// Performs the actual matching of |input| over the bookmarks and fills in
// |matches_|.
void DoAutocomplete(const AutocompleteInput& input);
// Allow short input word prefix matching only if the input is longer than 3
// chars.
query_parser::MatchingAlgorithm GetMatchingAlgorithm(AutocompleteInput input);
// Calculates the relevance score for |match|.
// Also returns the number of bookmarks containing the destination URL.
std::pair<int, int> CalculateBookmarkMatchRelevance(
const bookmarks::TitledUrlMatch& match) const;
const raw_ptr<AutocompleteProviderClient> client_;
const raw_ptr<bookmarks::BookmarkModel> bookmark_model_;
};
#endif // COMPONENTS_OMNIBOX_BROWSER_BOOKMARK_PROVIDER_H_