mirror of
https://github.com/mawww/kakoune.git
synced 2024-11-15 18:15:53 +03:00
Get forced file descriptors after calling poll
That way, we do not wait for the next poll to finish before servicing forced fd triggered by a signal that interupted the poll call.
This commit is contained in:
parent
541ec58d76
commit
e6b9a1d982
@ -52,8 +52,6 @@ void EventManager::handle_next_events()
|
||||
events.reserve(m_fd_watchers.size());
|
||||
for (auto& watcher : m_fd_watchers)
|
||||
events.emplace_back(pollfd{ watcher->fd(), POLLIN | POLLPRI, 0 });
|
||||
std::vector<int> forced;
|
||||
std::swap(forced, m_forced_fd);
|
||||
|
||||
TimePoint next_timer = TimePoint::max();
|
||||
for (auto& timer : m_timers)
|
||||
@ -64,6 +62,12 @@ void EventManager::handle_next_events()
|
||||
using namespace std::chrono;
|
||||
auto timeout = duration_cast<milliseconds>(next_timer - Clock::now()).count();
|
||||
poll(events.data(), events.size(), timeout < INT_MAX ? (int)timeout : INT_MAX);
|
||||
|
||||
// gather forced fds *after* poll, so that signal handlers can write to
|
||||
// m_forced_fd, interupt poll, and directly be serviced.
|
||||
std::vector<int> forced;
|
||||
std::swap(forced, m_forced_fd);
|
||||
|
||||
for (size_t i = 0; i < events.size(); ++i)
|
||||
{
|
||||
auto& event = events[i];
|
||||
|
Loading…
Reference in New Issue
Block a user