aboutsummaryrefslogtreecommitdiffstats
path: root/src/event (follow)
Commit message (Collapse)AuthorAgeFilesLines
* event/TimeoutMonitor: really reset "active" flag before invoking OnTimeout()Max Kellermann2014-08-241-1/+1
| | | | The previous commit was broken. D'oh!
* event/TimeoutMonitor: reset "active" flag before invoking OnTimeout()Max Kellermann2014-08-241-1/+3
| | | | | | The IsActive() method returned true even if the timer was not active, after it completed once. This broke the state file timer, and the state file was not saved periodically.
* event/BufferedSocket: fix inversed buffer checkMax Kellermann2014-08-071-1/+1
| | | | | This was broken by commit 84d20d9e, which deleted the "!" from the check.
* DeferredMonitor: fix race condition when using GLib event loopMax Kellermann2014-04-262-11/+22
| | | | | | | | | Turns out the lock-free code using atomics was not thread-safe. The given callback could be invoked by GLib before the source_id attribute was assigned. This commit changes the DeferredMonitor class to use a Mutex to block the event loop until source_id is assigned. This bug does not exist in the 0.19 branch because it does not use the GLib main loop anymore.
* event/SignalMonitor: fix build failure due to missing signal.h includeMax Kellermann2014-03-021-0/+2
|
* event/SignalMonitor: unblock signals after forkMax Kellermann2014-02-181-1/+22
| | | | Fixes hanging child process in the "pipe" output plugin.
* event/FullyBufferedSocket: remove obsolete TODO commentMax Kellermann2013-11-061-16/+0
| | | | We have a better solution now.
* event/FullyBufferedSocket: try to write without extra roundtripMax Kellermann2013-11-062-17/+33
| | | | | | Postpone the write using IdleMonitor instead of scheduling a write event. This reduces the number of system calls, because we don't need to register and unregister the write event in epoll.
* event/FullyBufferedSocket: make WriteFromBuffer() protectedMax Kellermann2013-11-062-4/+4
| | | | .. and rename it to Flush().
* event/SocketMonitor: add method Abandon()Max Kellermann2013-11-064-2/+32
|
* event/ServerSocket: don't abort if IPv6 is not availableMax Kellermann2013-11-041-1/+19
| | | | First check if an IPv6 socket can be created.
* event/ServerSocket: fix assertion failureMax Kellermann2013-11-041-1/+1
| | | | Regression from previous commit. D'oh!
* event/ServerSocket: open sockets in the order they were configuredMax Kellermann2013-11-042-5/+5
| | | | Use a std::list which can be appended at the end.
* *: use nullptr instead of NULLMax Kellermann2013-10-282-4/+4
|
* event/ServerSocket: pass AllocatedPath to AddPath()Max Kellermann2013-10-192-14/+18
|
* SignalMonitor: add SignalMonitorGetEventLoop()Max Kellermann2013-10-182-0/+15
| | | | Eliminate the global variable "shutdown_loop".
* event/BufferedSocket: pass writable pointer to OnSocketInput()Max Kellermann2013-10-151-1/+9
| | | | | Remove the const_cast from HttpdClient.cxx, and avoid one allocation in ClientRead.cxx.
* util/FifoBuffer: C++ version of the fifo_buffer libraryMax Kellermann2013-10-152-44/+21
|
* system/clock: convert to C++Max Kellermann2013-10-151-4/+4
|
* require GLib 2.28Max Kellermann2013-10-151-2/+0
| | | | The header glib_compat.h is now obsolete and can be removed.
* gcc.h: rename to Compiler.hMax Kellermann2013-10-158-8/+8
|
* Log: new logging library APIMax Kellermann2013-10-021-11/+12
| | | | | Prepare to migrate away from GLib. Currently, we're still using GLib as a backend.
* system/SocketError: un-inline constructorMax Kellermann2013-09-041-0/+2
| | | | Reduces header dependencies.
* util/Error: new error passing libraryMax Kellermann2013-09-045-54/+56
| | | | Replaces GLib's GError.
* system/resolver: convert to C++Max Kellermann2013-09-041-1/+1
|
* EventLoop: initialise the thread id explicitlyMax Kellermann2013-08-101-1/+2
|
* EventLoop: new implementation using epollMax Kellermann2013-08-1013-16/+705
| | | | Implement an event loop without GLib.
* event/Call: signal the calling threadMax Kellermann2013-08-101-0/+5
| | | | Fixes regression from commit 018f4155.
* event/IdleMonitor: new monitor classMax Kellermann2013-08-102-0/+130
|
* event/MultiSocketMonitor: add struct SingleFDMax Kellermann2013-08-102-8/+32
| | | | Prepare for migrating away from GLib.
* event/MultiSocketMonitor: use uint64_t instead of gint64Max Kellermann2013-08-102-5/+6
| | | | Unsigned and portable.
* event/MultiSocketMonitor: eliminate virtual method CheckSockets()Max Kellermann2013-08-102-8/+16
| | | | Handle timeout internally.
* event/MultiSocketMonitor: PrepareSockets() returns timeoutMax Kellermann2013-08-101-2/+5
| | | | Simplify the API, don't use GLib specific integer type.
* thread/Id: new class replacing GThread pointersMax Kellermann2013-08-102-8/+9
| | | | Remove a GLib dependencies from class EventLoop and DatabaseLock.
* event: add function BlockingCall()Max Kellermann2013-08-082-0/+108
| | | | | Replaces io_thread_call(). This approach is more generic and easier to use due to std::function.
* EventLoop: add methodd IsInside()Max Kellermann2013-08-082-2/+26
| | | | | Track which thread runs the EventLoop and provide a check whether we're currently inside.
* EventLoop: un-inline Run() and othersMax Kellermann2013-08-082-22/+61
| | | | Prepare for adding more code.
* event/*Monitor: add method GetEventLoop()Max Kellermann2013-08-084-1/+16
|
* event/SocketMonitor: un-inline Schedule()Max Kellermann2013-08-082-24/+23
| | | | Merge with CommitEventFlags().
* event/SocketMonitor: add assertionsMax Kellermann2013-08-082-0/+12
|
* event/BufferedSocket: add missing includeMax Kellermann2013-08-081-0/+1
|
* event/DeferredMonitor: rename Run() to RunDeferred()Max Kellermann2013-08-072-4/+4
|
* event/DeferredMonitor: use EventLoop::AddIdle()Max Kellermann2013-08-072-3/+7
|
* event/DeferredMonitor: new class wrapping g_idle_add()Max Kellermann2013-08-072-0/+109
|
* event/EventFD: move to libsystemMax Kellermann2013-08-075-361/+2
|
* event/SignalMonitor: use signalfd() if availableMax Kellermann2013-08-071-1/+72
|
* SignalHandlers: move code to new class SignalMonitorMax Kellermann2013-08-072-0/+197
|
* event/Event{Pipe,FD}: auto-create in constructorMax Kellermann2013-08-074-59/+23
| | | | Errors are fatal now. This makes the class a lot easier to use.
* Makefile.am: move sources to libsystem.aMax Kellermann2013-08-077-10/+10
|
* configure.ac: add option --enable-eventfdMax Kellermann2013-08-065-102/+227
| | | | | | Remove the runtime check for eventfd(), hard-code the feature once it's been selected at compile time. The class WakeFD is splitted into EventFD and EventPipe, using WakeFD as a macro diversion.