1
1
mirror of https://github.com/mawww/kakoune.git synced 2025-01-04 09:44:27 +03:00

EventManager: fix forced event processing

previous implementation could drop some forced events.
This commit is contained in:
Maxime Coste 2012-12-03 18:49:09 +01:00
parent 658e008785
commit 9e3c1c74c5
2 changed files with 9 additions and 3 deletions

View File

@ -5,6 +5,11 @@
namespace Kakoune
{
EventManager::EventManager()
{
m_forced.reserve(4);
}
void EventManager::watch(int fd, EventHandler handler)
{
auto event = std::find_if(m_events.begin(), m_events.end(),
@ -35,16 +40,16 @@ void EventManager::handle_next_events()
{
const int timeout_ms = 100;
poll(m_events.data(), m_events.size(), timeout_ms);
std::vector<int> forced = m_forced;
m_forced.clear();
for (size_t i = 0; i < m_events.size(); ++i)
{
auto& event = m_events[i];
const int fd = event.fd;
if (event.revents or contains(m_forced, fd))
if (event.revents or contains(forced, fd))
(*m_handlers[i])(fd);
}
m_handlers_trash.clear();
m_forced.clear();
}
void EventManager::force_signal(int fd)

View File

@ -19,6 +19,7 @@ using EventHandler = std::function<void (int fd)>;
class EventManager : public Singleton<EventManager>
{
public:
EventManager();
// Watch the given file descriptor, when data becomes
// ready, handler will be called with fd as parameter.
// It is an error to register multiple handlers on the