100.00% Lines (1/1) 100.00% Functions (1/1)
TLA Baseline Branch
Line Hits Code Line Hits Code
1   // 1   //
2   // Copyright (c) 2025 Vinnie Falco (vinnie.falco@gmail.com) 2   // Copyright (c) 2025 Vinnie Falco (vinnie.falco@gmail.com)
3   // Copyright (c) 2026 Steve Gerbino 3   // Copyright (c) 2026 Steve Gerbino
4   // 4   //
5   // Distributed under the Boost Software License, Version 1.0. (See accompanying 5   // Distributed under the Boost Software License, Version 1.0. (See accompanying
6   // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) 6   // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
7   // 7   //
8   // Official repository: https://github.com/cppalliance/corosio 8   // Official repository: https://github.com/cppalliance/corosio
9   // 9   //
10   10  
11   #ifndef BOOST_COROSIO_DETAIL_SCHEDULER_HPP 11   #ifndef BOOST_COROSIO_DETAIL_SCHEDULER_HPP
12   #define BOOST_COROSIO_DETAIL_SCHEDULER_HPP 12   #define BOOST_COROSIO_DETAIL_SCHEDULER_HPP
13   13  
14   #include <boost/corosio/detail/config.hpp> 14   #include <boost/corosio/detail/config.hpp>
15   #include <coroutine> 15   #include <coroutine>
16   16  
17   #include <cstddef> 17   #include <cstddef>
18   18  
19   namespace boost::corosio::detail { 19   namespace boost::corosio::detail {
20   20  
21   class scheduler_op; 21   class scheduler_op;
22   22  
23   /** Define the abstract interface for the event loop scheduler. 23   /** Define the abstract interface for the event loop scheduler.
24   24  
25   Concrete backends (epoll, IOCP, kqueue, select) derive from 25   Concrete backends (epoll, IOCP, kqueue, select) derive from
26   this to implement the reactor/proactor event loop. The 26   this to implement the reactor/proactor event loop. The
27   @ref io_context delegates all scheduling operations here. 27   @ref io_context delegates all scheduling operations here.
28   28  
29   @see io_context 29   @see io_context
30   */ 30   */
31   struct BOOST_COROSIO_DECL scheduler 31   struct BOOST_COROSIO_DECL scheduler
32   { 32   {
HITCBC 33   605 virtual ~scheduler() = default; 33   605 virtual ~scheduler() = default;
34   34  
35   /// Post a coroutine handle for deferred execution. 35   /// Post a coroutine handle for deferred execution.
36   virtual void post(std::coroutine_handle<>) const = 0; 36   virtual void post(std::coroutine_handle<>) const = 0;
37   37  
38   /// Post a scheduler operation for deferred execution. 38   /// Post a scheduler operation for deferred execution.
39   virtual void post(scheduler_op*) const = 0; 39   virtual void post(scheduler_op*) const = 0;
40   40  
41   /// Increment the outstanding work count. 41   /// Increment the outstanding work count.
42   virtual void work_started() noexcept = 0; 42   virtual void work_started() noexcept = 0;
43   43  
44   /// Decrement the outstanding work count. 44   /// Decrement the outstanding work count.
45   virtual void work_finished() noexcept = 0; 45   virtual void work_finished() noexcept = 0;
46   46  
47   /// Check if the calling thread is running the event loop. 47   /// Check if the calling thread is running the event loop.
48   virtual bool running_in_this_thread() const noexcept = 0; 48   virtual bool running_in_this_thread() const noexcept = 0;
49   49  
50   /// Signal the event loop to stop. 50   /// Signal the event loop to stop.
51   virtual void stop() = 0; 51   virtual void stop() = 0;
52   52  
53   /// Check if the event loop has been stopped. 53   /// Check if the event loop has been stopped.
54   virtual bool stopped() const noexcept = 0; 54   virtual bool stopped() const noexcept = 0;
55   55  
56   /// Reset the stopped state so `run()` can be called again. 56   /// Reset the stopped state so `run()` can be called again.
57   virtual void restart() = 0; 57   virtual void restart() = 0;
58   58  
59   /// Run the event loop, blocking until all work completes. 59   /// Run the event loop, blocking until all work completes.
60   virtual std::size_t run() = 0; 60   virtual std::size_t run() = 0;
61   61  
62   /// Run one handler, blocking until one completes. 62   /// Run one handler, blocking until one completes.
63   virtual std::size_t run_one() = 0; 63   virtual std::size_t run_one() = 0;
64   64  
65   /** Run one handler, blocking up to @p usec microseconds. 65   /** Run one handler, blocking up to @p usec microseconds.
66   66  
67   @param usec Maximum wait time in microseconds. 67   @param usec Maximum wait time in microseconds.
68   68  
69   @return The number of handlers executed (0 or 1). 69   @return The number of handlers executed (0 or 1).
70   */ 70   */
71   virtual std::size_t wait_one(long usec) = 0; 71   virtual std::size_t wait_one(long usec) = 0;
72   72  
73   /// Run all ready handlers without blocking. 73   /// Run all ready handlers without blocking.
74   virtual std::size_t poll() = 0; 74   virtual std::size_t poll() = 0;
75   75  
76   /// Run at most one ready handler without blocking. 76   /// Run at most one ready handler without blocking.
77   virtual std::size_t poll_one() = 0; 77   virtual std::size_t poll_one() = 0;
78   }; 78   };
79   79  
80   } // namespace boost::corosio::detail 80   } // namespace boost::corosio::detail
81   81  
82   #endif 82   #endif