blob: 365302dd6d1af6ea91b05a7a6285921d365f50e5 [file] [log] [blame]
// Copyright 2019 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_AUTOCOMPLETE_PROVIDER_DEBOUNCER_H_
#define COMPONENTS_OMNIBOX_BROWSER_AUTOCOMPLETE_PROVIDER_DEBOUNCER_H_
#include "base/functional/callback.h"
#include "base/time/time.h"
#include "base/timer/timer.h"
// Debounces a method call, i.e. throttles its call rate by delaying its
// invocations and cancelling pending ones when new ones are requested. Each
// instance should be used in a single thread to avoid bad `callback_`.
class AutocompleteProviderDebouncer {
public:
AutocompleteProviderDebouncer(bool from_last_run, int delay_ms);
~AutocompleteProviderDebouncer();
// Request |callback| to be invoked after the debouncing delay. If called
// while a previous request is still pending, the previous request will be
// cancelled.
void RequestRun(base::OnceCallback<void()> callback);
// Cancels any pending request.
void CancelRequest();
// Resets `time_last_run_` to now. Should be called when the debounced method
// was called externally. E.g., if there are 2 flows to call `X()`:
// 1) `X()`
// 2) `debouncer.RequestRun(base::BindOnce(&X))`
// When (1) occurs prior to (2), it might want to also invoke
// `debouncer.ResetTimeLastRan()` to make sure the 2nd call to `X()` doesn't
// occur in rapid succession.
// Will delay both future `RequestRun()` as well as any pending requests.
void ResetTimeLastRun();
private:
void Run();
// Whether debounce delays are calculated since |time_last_run_| or the last
// invocation of |RequestRun|.
bool from_last_run_ = false;
// The debounce delay.
int delay_ms_ = 0;
// Tracks when to next invoke |callback_|.
base::OneShotTimer timer_;
// The last time |Run| was invoked.
base::TimeTicks time_last_run_;
// The callback to invoke once |timer_| expires.
base::OnceCallback<void()> callback_;
};
#endif // COMPONENTS_OMNIBOX_BROWSER_AUTOCOMPLETE_PROVIDER_DEBOUNCER_H_