dfx 0.1.0
Linux-based dynamic dataflow executor
Loading...
Searching...
No Matches
Delay.hpp
1// SPDX-FileCopyrightText: 2025 Vincent Leroy
2// SPDX-License-Identifier: MIT
3//
4// This file is part of dfx.
5//
6// Licensed under the MIT License. See the LICENSE file in the project root
7// for full license information.
8
9#pragma once
10
11// Standard includes
12#include <chrono>
13#include <queue>
14
15// Project includes
16#include <dfx-core/Node.hpp>
17#include <dfx-fdwatch/Timer.hpp>
18
19namespace dfx::Node
20{
21class Delay : public Core::Node
22{
23 DFX_NODE("Delay")
24
25 struct MessageData
26 {
27 Core::MessagePtr message;
28 std::chrono::steady_clock::time_point deliveryTime;
29 };
30
31public:
32 Delay(Id id, std::string name);
33
34protected:
35 void initializeImpl(nlohmann::json config) override;
36 void handleMessage(Core::InputPort const & port, Core::MessagePtr message) override;
37
38private:
39 void _onTimerTimeout();
40
41private:
42 std::chrono::milliseconds _delay{0};
43 std::queue<MessageData> _pendingMessages;
44 FdWatch::Timer _timer;
45};
46} // !namespace dfx::Node
Base class for all runtime-executed nodes in a dfx dataflow graph.
#define DFX_NODE(typeName)
Convenience macro to declare the node type string and metadata/schema hooks.
Definition Node.hpp:501
Incoming message endpoint attached to a node.
Definition InputPort.hpp:55
Abstract base class for all nodes in the dfx runtime.
Definition Node.hpp:91
uint32_t Id
Node identifier type (unique and stable within a graph instance).
Definition Node.hpp:113
nlohmann::json const & config() const noexcept
Get the node configuration.
Definition Node.hpp:138
std::string const & name() const noexcept
Get the node name.
Definition Node.hpp:134
FD-integrated timer utility (timerfd-backed).
Definition Timer.hpp:52
void initializeImpl(nlohmann::json config) override
Called by initialize; derived nodes must parse config here.
void handleMessage(Core::InputPort const &port, Core::MessagePtr message) override
Handle an incoming message on an input port.
std::unique_ptr< Message > MessagePtr
Unique ownership handle for messages.
Definition Message.hpp:27
Definition MimeTypeRouter.hpp:18