// $Id$
//
-// Copyright (C) 2007
-// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
-// Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
+// Copyright (C) 2007
+// Fraunhofer Institute for Open Communication Systems (FOKUS)
+// Competence Center NETwork research (NET), St. Augustin, GERMANY
// Stefan Bund <g0dil@berlios.de>
//
// This program is free software; you can redistribute it and/or modify
#include "Events.ih"
// Custom includes
+#include "../Utils/senfassert.hh"
#include "detail/EventBinding.hh"
#define prefix_ inline
///////////////////////////////cti.p///////////////////////////////////////
///////////////////////////////////////////////////////////////////////////
-// senf::ppi::EventImplementation<EventType>
+// senf::ppi::EventImplementationHelper<EventType,Self>
////////////////////////////////////////
// protected members
-template <class EventType>
-prefix_ senf::ppi::EventImplementation<EventType>::EventImplementation()
- : binding_(0)
-{}
+template <class EventType, class Self>
+prefix_ void
+senf::ppi::EventImplementationHelper<EventType,Self>::callback(EventArg event,
+ ClockService::clock_type time)
+{
+ binding().callback(event,time);
+}
+
+template <class EventType, class Self>
+prefix_ void senf::ppi::EventImplementationHelper<EventType,Self>::callback(EventArg event)
+{
+ binding().callback(event);
+}
+
+////////////////////////////////////////
+// private members
+
+template <class EventType, class Self>
+prefix_ senf::ppi::detail::EventBinding<EventType> &
+senf::ppi::EventImplementationHelper<EventType,Self>::binding()
+{
+ SENF_ASSERT( static_cast<Self*>(this)->binding_ );
+ return * static_cast<Self*>(this)->binding_;
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::ppi::EventImplementationHelper<void,Self>
+
+////////////////////////////////////////
+// protected members
+
+template <class Self>
+prefix_ void
+senf::ppi::EventImplementationHelper<void,Self>::callback(ClockService::clock_type time)
+{
+ binding().callback(time);
+}
+
+template <class Self>
+prefix_ void senf::ppi::EventImplementationHelper<void,Self>::callback()
+{
+ binding().callback();
+}
+
+////////////////////////////////////////
+// private members
+
+template <class Self>
+prefix_ senf::ppi::detail::EventBinding<void> &
+senf::ppi::EventImplementationHelper<void,Self>::binding()
+{
+ SENF_ASSERT( static_cast<Self*>(this)->binding_ );
+ return * static_cast<Self*>(this)->binding_;
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::ppi::EventImplementation<EventType>
template <class EventType>
-prefix_ void senf::ppi::EventImplementation<EventType>::callback(EventArg event,
- boost::posix_time::ptime time)
+prefix_ senf::ppi::module::Module & senf::ppi::EventImplementation<EventType>::module()
+ const
{
- BOOST_ASSERT(binding_);
- binding_->callback(event,time);
+ return binding_->module();
}
template <class EventType>
-prefix_ void senf::ppi::EventImplementation<EventType>::callback(EventArg event)
+prefix_ senf::ppi::EventManager & senf::ppi::EventImplementation<EventType>::manager()
+ const
{
- BOOST_ASSERT(binding_);
- binding_->callback(event);
+ return binding_->manager();
}
////////////////////////////////////////
+// protected members
+
+template <class EventType>
+prefix_ senf::ppi::EventImplementation<EventType>::EventImplementation()
+ : binding_(0)
+{}
+
+////////////////////////////////////////
// private members
template <class EventType>