blob: 611b2b52643f2156959819d8b9e181630e7b7625 [file] [log] [blame]
Jordan Baylesb0c191e2019-03-26 15:49:57 -07001// Copyright 2019 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
btolschc92ba2f2019-04-10 11:46:01 -07005#ifndef PLATFORM_API_TASK_RUNNER_H_
6#define PLATFORM_API_TASK_RUNNER_H_
Jordan Baylesb0c191e2019-03-26 15:49:57 -07007
Yuri Wiitalab929b832019-06-05 17:13:15 -07008#include <future>
Jordan Baylesb0c191e2019-03-26 15:49:57 -07009
10#include "platform/api/time.h"
11
12namespace openscreen {
13namespace platform {
14
15// A thread-safe API surface that allows for posting tasks. The underlying
16// implementation may be single or multi-threaded, and all complication should
17// be handled by either the implementation class or the TaskRunnerFactory
18// method. It is the expectation of this API that the underlying impl gives
19// the following guarantees:
20// (1) Tasks shall not overlap in time/CPU.
21// (2) Tasks shall run sequentially, e.g. posting task A then B implies
22// that A shall run before B.
23// NOTE: we do not make any assumptions about what thread tasks shall run on.
24class TaskRunner {
25 public:
Yuri Wiitalab929b832019-06-05 17:13:15 -070026 using Task = std::packaged_task<void() noexcept>;
Jordan Baylesb0c191e2019-03-26 15:49:57 -070027
28 virtual ~TaskRunner() = default;
29
Yuri Wiitalab929b832019-06-05 17:13:15 -070030 // Takes any callable target (function, lambda-expression, std::bind result,
31 // etc.) that should be run at the first convenient time.
32 template <typename Functor>
33 inline void PostTask(Functor f) {
34 PostPackagedTask(Task(std::move(f)));
35 }
Jordan Baylesb0c191e2019-03-26 15:49:57 -070036
Yuri Wiitalab929b832019-06-05 17:13:15 -070037 // Takes any callable target (function, lambda-expression, std::bind result,
38 // etc.) that should be run no sooner than |delay| time from now. Note that
39 // the Task might run after an additional delay, especially under heavier
40 // system load. There is no deadline concept.
41 template <typename Functor>
42 inline void PostTaskWithDelay(Functor f, Clock::duration delay) {
43 PostPackagedTaskWithDelay(Task(std::move(f)), delay);
44 }
45
46 // Implementations should provide the behavior explained in the comments above
47 // for PostTask[WithDelay](). Client code may also call these directly when
48 // passing an existing Task object.
49 virtual void PostPackagedTask(Task task) = 0;
50 virtual void PostPackagedTaskWithDelay(Task task, Clock::duration delay) = 0;
Jordan Baylesb0c191e2019-03-26 15:49:57 -070051};
Yuri Wiitalab929b832019-06-05 17:13:15 -070052
Jordan Baylesb0c191e2019-03-26 15:49:57 -070053} // namespace platform
54} // namespace openscreen
55
btolschc92ba2f2019-04-10 11:46:01 -070056#endif // PLATFORM_API_TASK_RUNNER_H_