SNode.C
Loading...
Searching...
No Matches
EventMultiplexer.h
Go to the documentation of this file.
1/*
2 * SNode.C - A Slim Toolkit for Network Communication
3 * Copyright (C) Volker Christian <me@vchrist.at>
4 * 2020, 2021, 2022, 2023, 2024, 2025
5 *
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Lesser General Public License as published
8 * by the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Lesser General Public License for more details.
15 *
16 * You should have received a copy of the GNU Lesser General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20/*
21 * MIT License
22 *
23 * Permission is hereby granted, free of charge, to any person obtaining a copy
24 * of this software and associated documentation files (the "Software"), to deal
25 * in the Software without restriction, including without limitation the rights
26 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
27 * copies of the Software, and to permit persons to whom the Software is
28 * furnished to do so, subject to the following conditions:
29 *
30 * The above copyright notice and this permission notice shall be included in
31 * all copies or substantial portions of the Software.
32 *
33 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
34 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
35 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
36 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
37 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
38 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
39 * THE SOFTWARE.
40 */
41
42#ifndef CORE_POLL_EVENTDISPATCHER_H
43#define CORE_POLL_EVENTDISPATCHER_H
44
45#include "core/EventMultiplexer.h" // IWYU pragma: export
46
47namespace core {
49}
50
51#ifndef DOXYGEN_SHOULD_SKIP_THIS
52
53#include "core/system/poll.h" // IWYU pragma: export
54
55#include <cstddef>
56#include <functional>
57#include <limits>
58#include <new>
59#include <tuple>
60#include <unordered_map>
61#include <utility>
62#include <vector>
63
64#endif /* DOXYGEN_SHOULD_SKIP_THIS */
65
66namespace core::multiplexer::poll {
67
69 private:
70 template <typename T, typename S>
72 public:
73 // Standard allocator typedefs
74 using value_type = T;
75 using pointer = T*;
76 using const_pointer = const T*;
77 using void_pointer = void*;
78 using const_void_pointer = const void*;
79 using size_type = S;
80 using difference_type = std::ptrdiff_t;
81
82 // Rebind allocator to type U.
83 template <typename U>
84 struct rebind {
85 using other = VarSizeTypeAllocator<U, S>;
86 };
87
88 // Constructors
90 }
91
92 VarSizeTypeAllocator(const VarSizeTypeAllocator&) noexcept = default;
93
94 template <typename U>
95 VarSizeTypeAllocator(const VarSizeTypeAllocator<U, S>& /*unused*/) noexcept {
96 }
97
99 }
100
101 // Allocate memory for n objects of type T.
102 pointer allocate(size_type n) {
103 if (n > max_size()) {
104 throw std::bad_alloc();
105 }
106 // Allocate using the global operator new.
107 return static_cast<pointer>(::operator new(n * sizeof(T)));
108 }
109
110 // Deallocate memory for n objects of type T.
111 void deallocate(pointer p, size_type /*n*/) noexcept {
112 ::operator delete(p);
113 }
114
115 // Returns the maximum number of T objects that can be allocated.
116 size_type max_size() const noexcept {
117 return std::numeric_limits<size_type>::max() / sizeof(T);
118 }
119
120 // Construct an object of type U at the given memory location.
121 template <typename U, typename... Args>
122 void construct(U* p, Args&&... args) {
123 ::new (static_cast<void*>(p)) U(std::forward<Args>(args)...);
124 }
125
126 // Destroy an object of type U.
127 template <typename U>
128 void destroy(U* p) noexcept {
129 p->~U();
130 }
131
132 // Equality comparisons.
133 template <typename U>
134 bool operator==(const VarSizeTypeAllocator<U, S>& /*unused*/) const noexcept {
135 return true;
136 }
137
138 template <typename U>
139 bool operator!=(const VarSizeTypeAllocator<U, S>& /*unused*/) const noexcept {
140 return false;
141 }
142 };
143
144 public:
146
147 struct PollFdIndex {
149 short events;
150 };
151
154 std::hash<int>,
155 std::equal_to<>,
157
158 explicit PollFdsManager();
159
160 void muxAdd(core::DescriptorEventReceiver* eventReceiver, short event);
161 void muxDel(int fd, short event);
162 void muxOn(const core::DescriptorEventReceiver* eventReceiver, short event);
163 void muxOff(const DescriptorEventReceiver* eventReceiver, short event);
164
165 pollfd* getEvents();
166
167 const pollfdindex_map& getPollFdIndices() const;
168
169 nfds_t getCurrentSize() const;
170
171 private:
173 void compress();
174
177 };
178
179 class EventMultiplexer : public core::EventMultiplexer {
180 public:
182 ~EventMultiplexer() override = default;
183
184 private:
185 int monitorDescriptors(utils::Timeval& tickTimeOut, const sigset_t& sigMask) override;
186 void spanActiveEvents(int activeDescriptorCount) override;
187
189 };
190
191} // namespace core::multiplexer::poll
192
193#endif // CORE_POLL_EVENTDISPATCHER_H
virtual void spanActiveEvents()=0
std::array< DescriptorEventPublisher *, 3 > descriptorEventPublishers
int monitorDescriptors(utils::Timeval &tickTimeOut, const sigset_t &sigMask) override
void spanActiveEvents(int activeDescriptorCount) override
VarSizeTypeAllocator(const VarSizeTypeAllocator< U, S > &) noexcept
VarSizeTypeAllocator(const VarSizeTypeAllocator &) noexcept=default
bool operator==(const VarSizeTypeAllocator< U, S > &) const noexcept
bool operator!=(const VarSizeTypeAllocator< U, S > &) const noexcept
void muxOff(const DescriptorEventReceiver *eventReceiver, short event)
void muxAdd(core::DescriptorEventReceiver *eventReceiver, short event)
const pollfdindex_map & getPollFdIndices() const
void muxOn(const core::DescriptorEventReceiver *eventReceiver, short event)
timespec getTimespec() const
Definition Timeval.cpp:173