blob: 3bdeeac1f69ecb748bfd03810bc24ead0588b24b [file] [log] [blame]
// Copyright 2019 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_OMNIBOX_BROWSER_ON_DEVICE_HEAD_PROVIDER_H_
#define COMPONENTS_OMNIBOX_BROWSER_ON_DEVICE_HEAD_PROVIDER_H_
#include <memory>
#include "base/callback_list.h"
#include "base/sequence_checker.h"
#include "base/task/post_task.h"
#include "components/omnibox/browser/autocomplete_provider.h"
#include "components/omnibox/browser/autocomplete_provider_client.h"
#include "components/omnibox/browser/on_device_head_model.h"
class AutocompleteProviderListener;
// An asynchronous autocomplete provider which receives input string and tries
// to find the matches in an on device head model. This provider is designed to
// help users get suggestions when they are in poor network.
// By default, all matches provided by this provider will have a relevance no
// greater than 99, such that its matches will not show before any other
// providers; However the relevance can be changed to any arbitrary value by
// Finch when the input is not classified as a URL.
// TODO(crbug.com/925072): make some cleanups after removing |model_| and |this|
// in task postings from this class.
class OnDeviceHeadProvider : public AutocompleteProvider {
public:
static OnDeviceHeadProvider* Create(AutocompleteProviderClient* client,
AutocompleteProviderListener* listener);
void Start(const AutocompleteInput& input, bool minimal_changes) override;
void Stop(bool clear_cached_results, bool due_to_user_inactivity) override;
void AddProviderInfo(ProvidersInfo* provider_info) const override;
AutocompleteProviderClient* client() { return client_; }
private:
friend class OnDeviceHeadProviderTest;
// A useful data structure to store Autocomplete input and suggestions fetched
// from the on device head model for a search request to the model.
struct OnDeviceHeadProviderParams;
OnDeviceHeadProvider(AutocompleteProviderClient* client,
AutocompleteProviderListener* listener);
~OnDeviceHeadProvider() override;
OnDeviceHeadProvider(const OnDeviceHeadProvider&) = delete;
OnDeviceHeadProvider& operator=(const OnDeviceHeadProvider&) = delete;
bool IsOnDeviceHeadProviderAllowed(const AutocompleteInput& input);
// Helper functions used for asynchronous search to the on device head model.
// The Autocomplete input and output from the model will be passed from
// DoSearch to SearchDone via the OnDeviceHeadProviderParams object.
// DoSearch: searches the on device model and returns the tops suggestions
// matches the given AutocompleteInput.
void DoSearch(std::unique_ptr<OnDeviceHeadProviderParams> params);
// SearchDone: called after DoSearch, fills |matches_| with the suggestions
// fetches by DoSearch and then calls OnProviderUpdate.
void SearchDone(std::unique_ptr<OnDeviceHeadProviderParams> params);
// Helper functions to read model filename from the static
// OnDeviceModelUpdateListener instance.
std::string GetOnDeviceHeadModelFilename() const;
// Fetches suggestions matching the params from the given on device head
// model.
static std::unique_ptr<OnDeviceHeadProviderParams> GetSuggestionsFromModel(
const std::string& model_filename,
const size_t provider_max_matches,
std::unique_ptr<OnDeviceHeadProviderParams> params);
AutocompleteProviderClient* client_;
AutocompleteProviderListener* listener_;
// The task runner dedicated for on device head model operations which is
// added to offload expensive operations out of the UI sequence.
scoped_refptr<base::SequencedTaskRunner> worker_task_runner_;
// Sequence checker that ensure autocomplete request handling will only happen
// on main thread.
SEQUENCE_CHECKER(main_sequence_checker_);
// The request id used to trace current request to the on device head model.
// The id will be increased whenever a new request is received from the
// AutocompleteController.
size_t on_device_search_request_id_;
base::WeakPtrFactory<OnDeviceHeadProvider> weak_ptr_factory_{this};
};
#endif // COMPONENTS_OMNIBOX_BROWSER_ON_DEVICE_HEAD_PROVIDER_H_