From 69956a6aef5e1dc764a8435978e36efb8f29ff78 Mon Sep 17 00:00:00 2001 From: g0dil <g0dil@wiback.org> Date: Mon, 29 Jun 2009 15:26:19 +0000 Subject: [PATCH] PPI: MultiConnectorMixin documentation fixes --- PPI/MultiConnectorMixin.cti | 13 +++++++++++- PPI/MultiConnectorMixin.hh | 41 ++++++++++++++++++++++++++----------- PPI/MultiConnectorMixin.ih | 4 ++++ 3 files changed, 45 insertions(+), 13 deletions(-) diff --git a/PPI/MultiConnectorMixin.cti b/PPI/MultiConnectorMixin.cti index 5f94de72d..3df16d896 100644 --- a/PPI/MultiConnectorMixin.cti +++ b/PPI/MultiConnectorMixin.cti @@ -37,6 +37,15 @@ senf::ppi::module::MultiConnectorMixin<Self_,ConnectorType_,KeyType_,ContainerTy return connectors_; } +template <class Self_, class ConnectorType_, class KeyType_, class ContainerType_> +prefix_ ContainerType_ const & +senf::ppi::module::MultiConnectorMixin<Self_,ConnectorType_,KeyType_,ContainerType_>:: +connectors() + const +{ + return connectors_; +} + template <class Self_, class ConnectorType_, class ContainerType_> prefix_ ContainerType_ & senf::ppi::module::MultiConnectorMixin<Self_,ConnectorType_,void,ContainerType_>::connectors() @@ -91,7 +100,7 @@ senf::ppi::connect(Source & source, Target & target , A1 const & a1) connect(source, target.newConnector(a1)); } -#endif +#else // Include 'Implementation' from MultiConnectorMixin.mpp #define BOOST_PP_ITERATION_PARAMS_1 (4, ( \ @@ -101,6 +110,8 @@ senf::ppi::connect(Source & source, Target & target , A1 const & a1) 3 )) #include BOOST_PP_ITERATE() +#endif + ///////////////////////////////cti.e/////////////////////////////////////// #undef prefix_ diff --git a/PPI/MultiConnectorMixin.hh b/PPI/MultiConnectorMixin.hh index e607c48fc..7052d657e 100644 --- a/PPI/MultiConnectorMixin.hh +++ b/PPI/MultiConnectorMixin.hh @@ -54,20 +54,26 @@ namespace ppi { // output, otherwise the second overload. /** \brief Connect MultiConnector source to arbitrary target + Additional implementations with 0..SENF_MULTI_CONNECTOR_MAX_ARGS arguments. + \related module::MultiConnectorMixin */ - template <class Source, class Target, class A1> - Source::ConnectorType & connect(Source & source, Target & target, A1 const & a1); + template <class MultiConnectorSource, class Target, class A1> + MultiConnectorSource::ConnectorType & connect( + MultiConnectorSource & source, Target & target, A1 const & a1); /** \brief Connect arbitrary source to MultiConnector target + Additional implementations with 0..SENF_MULTI_CONNECTOR_MAX_ARGS arguments. + \related module::MultiConnectorMixin */ - template <class Source, class Target> - Target::ConnectorType & connect(Source & source, Target & target, A1 const & a1); + template <class Source, class MultiConnectorTarget, class A1> + MultiConnectorTarget::ConnectorType & connect( + Source & source, MultiConnectorTarget & target, A1 const & a1); -#endif +#else // Include 'senf::ppi::namespace member declarations' from MultiConnectorMixin.mpp # define BOOST_PP_ITERATION_PARAMS_1 (4, ( \ @@ -77,6 +83,8 @@ namespace ppi { 2 )) # include BOOST_PP_ITERATE() +#endif + namespace module { /** \brief Multi connector management @@ -153,12 +161,12 @@ namespace module { \par "Example:" senf::ppi::module::AnnotationRouter - \section senf_ppi_multiconnector_connect Connect and additional \c connectorSetup() arguments + \section senf_ppi_multiconnector_connect Connect and additional connectorSetup() arguments When connecting to a module using the MultiConnectorMixin, every new connect call will allocate a new connector \code - MuModule muModule; + MyModule muModule; senf::ppi::connect(someModule, myModule); \endcode @@ -176,6 +184,7 @@ namespace module { { container().insert(container().begin()+index, container().pop_back().release()); } + \endcode \par "Advanced note:" These additional arguments are always passed by const-reference. If you need to pass a non-const reference, declare the \c connectorSetup() argument as @@ -191,14 +200,15 @@ namespace module { : private detail::MultiConnectorSelectBase<ConnectorType_>::type { public: - typedef ConnectorType_ ConnectorType; + typedef ConnectorType_ ConnectorType; ///< Type of MultiConnector connector protected: - typedef ContainerType_ ContainerType; - ContainerType_ & connectors(); + typedef ContainerType_ ContainerType; ///< Type of connector container + ContainerType_ & connectors(); ///< Get connector container + ContainerType_ const & connectors() const; ///< Get connectors container (const) private: -#ifdef DOXYGEN +#ifdef 0 // For exposition only // Other implementations with 0..SENF_MULTI_CONNECTOR_MAX_ARGS arguments accordingly @@ -218,6 +228,7 @@ namespace module { Target & target, A1 const & a1); #endif +#ifndef DOXYGEN // Include 'MultiConnectorMixin member declaration' from MultiConnectorMixin.mpp # define BOOST_PP_ITERATION_PARAMS_1 (4, ( \ @@ -226,10 +237,14 @@ namespace module { SENF_ABSOLUTE_INCLUDE_PATH(PPI/MultiConnectorMixin.mpp), \ 1 )) # include BOOST_PP_ITERATE() + +#endif ContainerType_ connectors_; }; +#ifndef DOXYGEN + template <class Self_, class ConnectorType_, class ContainerType_> @@ -245,7 +260,7 @@ namespace module { private: -#ifdef DOXYGEN +#if 0 // For exposition only // Other implementations with 0..SENF_MULTI_CONNECTOR_MAX_ARGS arguments accordingly @@ -276,6 +291,8 @@ namespace module { ContainerType_ connectors_; }; + +#endif }}} diff --git a/PPI/MultiConnectorMixin.ih b/PPI/MultiConnectorMixin.ih index 6f1f2a00a..0d9622652 100644 --- a/PPI/MultiConnectorMixin.ih +++ b/PPI/MultiConnectorMixin.ih @@ -41,12 +41,16 @@ namespace detail { typedef boost::ptr_map<KeyType, ConnectorType> type; }; +#ifndef DOXYGEN + template <class ConnectorType> struct MultiConnectorDefaultContainer<void,ConnectorType> { typedef boost::ptr_vector<ConnectorType> type; }; +#endif + template <class ConnectorType> struct MultiConnectorSelectBase : public boost::mpl::if_< -- GitLab