X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=PPI%2FRoute.hh;h=54c41396d2499c58001259565d05103ec68a847e;hb=81ffa1c459b96dd44472bcef37e1e373934ee138;hp=3d4f513f9c9a688f05a50dafe975e8d211f1f4eb;hpb=217dd10cd636d614ee110f0be293d5d5b5fa646d;p=senf.git diff --git a/PPI/Route.hh b/PPI/Route.hh index 3d4f513..54c4139 100644 --- a/PPI/Route.hh +++ b/PPI/Route.hh @@ -25,6 +25,8 @@ #define HH_Route_ 1 // Custom includes +#include +#include "predecl.hh" //#include "Route.mpp" ///////////////////////////////hh.p//////////////////////////////////////// @@ -32,13 +34,7 @@ namespace senf { namespace ppi { - /** \brief Route descriptor - - Route instances are created by Module::route statements. The Route class provides an - interface to manipulate the flow processing. - */ - template - class Route + class RouteBase { public: void autoThrottling(bool state); ///< Change automatic throttle notification forwarding @@ -47,11 +43,6 @@ namespace ppi { be disabled by setting the authoThrottling state to \c false. - This member only exists if - \li \a Source or \a Target is an event - \li one of \a Source and \a Target is an active - connector and the other is a passive connector. - Routing from/to an event to/from a passive connector will automatically create throttling notifications on the connector whenever the event is disabled. Routing @@ -66,14 +57,47 @@ namespace ppi { specializations. However, this is an implementation detail which does not affect the exposed interface. */ + + protected: + RouteBase(module::Module & module); + + private: + module::Module * module_; + }; + +}} + +#include "Route.ih" + +namespace senf { +namespace ppi { + + /** \brief Route descriptor + + Route instances are created by Module::route statements. The Route class provides an + interface to manipulate the flow processing. + */ + template + class Route + : public detail::RouteImplementation< boost::is_base_of::value, + boost::is_base_of::value > + { + private: + typedef detail::RouteImplementation< + boost::is_base_of::value, + boost::is_base_of::value > Implementation; + + Route(module::Module & module, Source & source, Target & target); + + friend class module::Module; }; }} ///////////////////////////////hh.e//////////////////////////////////////// -//#include "Route.cci" +#include "Route.cci" //#include "Route.ct" -//#include "Route.cti" +#include "Route.cti" #endif @@ -83,4 +107,6 @@ namespace ppi { // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: