eve.core.linux.loop
Linux Layer 1 event loop built on the selected Layer 0 backend.
This module provides the Linux-specific implementation of EventLoop using timerfd for timers, signalfd for signals, and eventfd for cross-thread wakeups.
struct EventLoop
Types 1
structEventLoop
Single-threaded readiness event loop.
Fields
TimerWheel _timerWheellong _startTimeMsSelectedBackend _pollerWatcherSlot[] _slotsNativeEvent[] _eventsDnsData[] _dnsSlotssize_t _watcherCountsize_t _totalSendQueueBytessize_t _activeConnectionssize_t _openFdsEventLoopConfig _configbool _runningbool _stopRequesteduint _freeHeaduint _dnsFreeHeadsize_t _phaseDispatchCountToken[] _phaseBufferbool _signalMaskActivebool _hasSavedSignalMasksigset_t _savedSignalMaskMethods
EventLoop create(EventLoopConfig config = EventLoopConfig.init) @trustedCreate a new event loop with fixed-capacity watcher and event buffers.Handle backendHandle() @property const @safe nothrow @nogcReturn the native handle for the active Layer 0 poller.size_t watcherCount() @property const pure @safe nothrow @nogcReport how many watchers are currently registered.bool isRunning() @property const pure @safe nothrow @nogcReport whether `run` or `runToCompletion` is currently executing.const(EventLoopLimits) limits() @property const @safe nothrow @nogcGet the resource limits configured for the event loop.void updateSendQueueUsage(long delta) @safe nothrow @nogcUpdate the total send queue bytes tracked by the loop.void updateConnectionCount(long delta) @safe nothrow @nogcUpdate the active connection count tracked by the loop.Token registerIo(Handle handle, IoInterest interest, IoWatcherCallback callback) @trusted nothrowRegister an I/O watcher with the selected backend.Token registerTimer(long delayMs, long intervalMs, WatcherCallback callback) @trusted nothrowRegister a one-shot timer watcher.Token registerSignal(Signal signal, SignalWatcherCallback callback) @trusted nothrowRegister a signal watcher.void updateDnsResults(Token token, scope const(IpAddress)[] results, DnsError error) @safe nothrowInternal: Update results for a DNS watcher.const(char) * getDnsHostname(Token token) @safe nothrowInternal: Get the hostname associated with a DNS watcher.Token registerDns(scope const(char)[] host, DnsWatcherCallback callback, CancelToken cancel = CancelToken
.invalid) @trusted nothrowRegister an async DNS resolution watcher.CancelToken getCancelToken(Token token) @safe nothrow @nogcGet the cancellation token associated with a watcher.int updateIo(Token token, IoInterest interest) @trusted nothrowUpdate the interest mask for an existing I/O watcher.bool checkLimit(LimitKind kind, size_t current, size_t limit) @safe nothrowInternal: Check if a resource limit is hit.Nested Templates
WatcherSlotDnsData