moved statistics classes from NetEmu to SENF
[senf.git] / PPI / Route.cti
index 3d0f465..c72ad31 100644 (file)
@@ -1,8 +1,8 @@
 // $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
 ///////////////////////////////////////////////////////////////////////////
 // senf::ppi::Route<Source,Target>
 
-////////////////////////////////////////
-// protected members
-
 template <class Source, class Target>
 prefix_ senf::ppi::Route<Source,Target>::Route(module::Module & module, Source & source,
                                                Target & target)
-    : Implementation(module, source, target)
+    : Base(module,source,target)
+{}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::ppi::ForwardingRoute
+
+////////////////////////////////////////
+// protected members
+
+template <class T>
+prefix_ void senf::ppi::ForwardingRoute::registerRoute(T & ob)
+{
+    ob.registerRoute(*this);
+}
+
+template <class T>
+prefix_ void senf::ppi::ForwardingRoute::notifyThrottle(T & ob)
+{
+    ob.notifyThrottle();
+}
+
+template <class T>
+prefix_ void senf::ppi::ForwardingRoute::notifyUnthrottle(T & ob)
+{
+    ob.notifyUnthrottle();
+}
+
+///////////////////////////////////////////////////////////////////////////
+// senf::ppi::detail::BaseRouteImplementation<Source,Target,Base>
+
+template <class Source, class Target, class Base>
+prefix_ Source & senf::ppi::detail::BaseRouteImplementation<Source,Target,Base>::source()
+    const
+{
+    return *source_;
+}
+
+template <class Source, class Target, class Base>
+prefix_ Target & senf::ppi::detail::BaseRouteImplementation<Source,Target,Base>::target()
+    const
+{
+    return *target_;
+}
+
+////////////////////////////////////////
+// protected members
+
+template <class Source, class Target, class Base>
+prefix_ senf::ppi::detail::BaseRouteImplementation<Source,Target,Base>::
+BaseRouteImplementation(module::Module & module, Source & source, Target & target)
+    : Base(module), source_(&source), target_(&target)
 {}
 
 ///////////////////////////////////////////////////////////////////////////
-// senf::ppi::detail::RouteImplementation<Source,Target,srcEvent,trgEvent>
+// senf::ppi::detail::ForwardingRouteImplementation<Source,Target>
 
 ////////////////////////////////////////
 // protected members
 
-template <bool srcEvent, bool trgEvent>
-prefix_ senf::ppi::detail::RouteImplementation<srcEvent,trgEvent>::
-RouteImplementation(module::Module & module, connector::InputConnector & source,
-                    connector::OutputConnector & target)
-    : RouteBase(module), source_(&source), target_(&target)
+template <class Source, class Target>
+prefix_
+senf::ppi::detail::ForwardingRouteImplementation<Source,Target>::
+ForwardingRouteImplementation(module::Module & module, Source & source, Target & target)
+    : Base(module,source,target)
+{
+    registerRoute(source);
+    registerRoute(target);
+}
+
+////////////////////////////////////////
+// private members
+
+template <class Source, class Target>
+template <class T>
+prefix_ void senf::ppi::detail::ForwardingRouteImplementation<Source,Target>::
+notifyThrottle(T & ob, boost::mpl::bool_<true> const &)
+{
+    ForwardingRoute::notifyThrottle(ob);
+}
+
+template <class Source, class Target>
+template <class T>
+prefix_ void senf::ppi::detail::ForwardingRouteImplementation<Source,Target>::
+notifyThrottle(T & ob, boost::mpl::bool_<false> const &)
+{}
+
+template <class Source, class Target>
+template <class T>
+prefix_ void senf::ppi::detail::ForwardingRouteImplementation<Source,Target>::
+notifyUnthrottle(T & ob, boost::mpl::bool_<true> const &)
+{
+    ForwardingRoute::notifyUnthrottle(ob);
+}
+
+template <class Source, class Target>
+template <class T>
+prefix_ void senf::ppi::detail::ForwardingRouteImplementation<Source,Target>::
+notifyUnthrottle(T & ob, boost::mpl::bool_<false> const &)
 {}
 
+template <class Source, class Target>
+template <class T>
+prefix_ bool senf::ppi::detail::ForwardingRouteImplementation<Source,Target>::
+throttled(T & ob, boost::mpl::bool_<true> const &)
+    const
+{
+    return ob.throttled();
+}
+
+template <class Source, class Target>
+template <class T>
+prefix_ bool senf::ppi::detail::ForwardingRouteImplementation<Source,Target>::
+throttled(T & ob, boost::mpl::bool_<false> const &)
+    const
+{
+    return false;
+}
+
 ///////////////////////////////////////////////////////////////////////////
-// senf::ppi::detail::RouteImplementation<true,false>
+// senf::ppi::detail::RouteImplementation2<Source,Target>
 
 ////////////////////////////////////////
 // protected members
 
-prefix_ senf::ppi::detail::RouteImplementation<true,false>::
-RouteImplementation(module::Module & module, EventDescriptor & source,
-                    connector::OutputConnector & target)
-    : RouteBase(module), source_(&source), target_(&target)
+template <class Source, class Target>
+prefix_ senf::ppi::detail::RouteImplementation2<Source,Target>::
+RouteImplementation2(module::Module & module, Source & source, Target & target)
+    : Base(module,source,target)
 {}
 
 ///////////////////////////////////////////////////////////////////////////
-// senf::ppi::detail::RouteImplementation<false,true>
+// senf::ppi::detail::RouteImplementation<Source,Target>
 
 ////////////////////////////////////////
 // protected members
 
-prefix_ senf::ppi::detail::RouteImplementation<false,true>::
-RouteImplementation(module::Module & module, connector::InputConnector & source,
-                    EventDescriptor & target)
-: RouteBase(module), source_(&source), target_(&target)
+template <class Source, class Target>
+prefix_ senf::ppi::detail::RouteImplementation<Source,Target>::
+RouteImplementation(module::Module & module, Source & source, Target & target)
+    : Base(module,source,target)
 {}
 
 ///////////////////////////////cti.e///////////////////////////////////////