// Copyright 2014 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_DOMAIN_RELIABILITY_DISPATCHER_H_ #define COMPONENTS_DOMAIN_RELIABILITY_DISPATCHER_H_ #include <set> #include "base/callback_forward.h" #include "base/time/time.h" #include "components/domain_reliability/domain_reliability_export.h" namespace tracked_objects { class Location; } // namespace tracked_objects namespace domain_reliability { class MockableTime; // Runs tasks during a specified interval. Calling |RunEligibleTasks| gives any // task a chance to run early (if the minimum delay has already passed); tasks // that aren't run early will be run once their maximum delay has passed. // // (See scheduler.h for an explanation of how the intervals are chosen.) class DOMAIN_RELIABILITY_EXPORT DomainReliabilityDispatcher { public: explicit DomainReliabilityDispatcher(MockableTime* time); ~DomainReliabilityDispatcher(); // Schedules |task| to be executed between |min_delay| and |max_delay| from // now. The task will be run at most |max_delay| from now; once |min_delay| // has passed, any call to |RunEligibleTasks| will run the task earlier than // that. void ScheduleTask(const base::Closure& task, base::TimeDelta min_delay, base::TimeDelta max_delay); // Runs all tasks whose minimum delay has already passed. void RunEligibleTasks(); private: struct Task; // Adds |task| to the set of all tasks, but not the set of eligible tasks. void MakeTaskWaiting(Task* task); // Adds |task| to the set of eligible tasks, and also the set of all tasks // if not already there. void MakeTaskEligible(Task* task); // Runs |task|'s callback, removes it from both sets, and deletes it. void RunAndDeleteTask(Task* task); MockableTime* time_; std::set<Task*> tasks_; std::set<Task*> eligible_tasks_; }; } // namespace domain_reliability #endif