From 701f310a4b7e3035b260b838a63bec80c74a0bed Mon Sep 17 00:00:00 2001 From: Balazs Racz Date: Sun, 29 Jan 2023 13:26:35 +0100 Subject: [PATCH 1/2] Refactors fast time state into a separate base class from BroadcastTime. --- src/openlcb/BroadcastTime.hxx | 236 +-------------------------- src/utils/TimeBase.hxx | 296 ++++++++++++++++++++++++++++++++++ 2 files changed, 298 insertions(+), 234 deletions(-) create mode 100644 src/utils/TimeBase.hxx diff --git a/src/openlcb/BroadcastTime.hxx b/src/openlcb/BroadcastTime.hxx index d99de21c0..5b6f54a82 100644 --- a/src/openlcb/BroadcastTime.hxx +++ b/src/openlcb/BroadcastTime.hxx @@ -39,6 +39,7 @@ #include "openlcb/BroadcastTimeDefs.hxx" #include "openlcb/EventHandlerTemplates.hxx" +#include "utils/TimeBase.hxx" namespace openlcb { @@ -46,7 +47,7 @@ namespace openlcb /// Implementation of Broadcast Time Protocol. class BroadcastTime : public SimpleEventHandler , public StateFlowBase - , protected Atomic + , public TimeBase { public: typedef std::vector>::size_type UpdateSubscribeHandle; @@ -121,230 +122,6 @@ public: send_event(node_, eventBase_ | BroadcastTimeDefs::QUERY_EVENT_SUFFIX); } - /// Get the time as a value of seconds relative to the system epoch. At the - /// same time get an atomic matching pair of the rate - /// @return pair