X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=PPI%2FConnectors.cti;h=b8f5bf3cc541a8f2a5fefcbb9794aafc0c5d418a;hb=f2f5d59e83863f3b513950173baee1b6da2aee3c;hp=992bd8c0f29a9de9ff95d4425ca991df5bd4044a;hpb=f539f4271d470794a773a92bacd8ba086c9bc1cd;p=senf.git diff --git a/PPI/Connectors.cti b/PPI/Connectors.cti index 992bd8c..b8f5bf3 100644 --- a/PPI/Connectors.cti +++ b/PPI/Connectors.cti @@ -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 // // This program is free software; you can redistribute it and/or modify @@ -23,7 +23,7 @@ /** \file \brief Connectors inline template implementation */ -//#include "Connectors.ih" +#include "Connectors.ih" // Custom includes @@ -31,12 +31,45 @@ ///////////////////////////////cti.p/////////////////////////////////////// /////////////////////////////////////////////////////////////////////////// +// senf::ppi::connectors::detail::TypedInputMixin + +template +prefix_ typename senf::ppi::connector::detail::TypedInputMixin::Type +senf::ppi::connector::detail::TypedInputMixin::operator()() +{ + return read(); +} + +template +prefix_ typename senf::ppi::connector::detail::TypedInputMixin::Type +senf::ppi::connector::detail::TypedInputMixin::read() +{ + Packet p (static_cast(this)->InputConnector::read()); + return p ? p.as() : Type(); +} + +/////////////////////////////////////////////////////////////////////////// +// senf::ppi::connector::detail::TypedOutputMixin + +template +prefix_ void senf::ppi::connector::detail::TypedOutputMixin::operator()(Type p) +{ + static_cast(this)->OutputConnector::operator()(p); +} + +template +prefix_ void senf::ppi::connector::detail::TypedOutputMixin::write(Type p) +{ + static_cast(this)->OutputConnector::write(p); +} + +/////////////////////////////////////////////////////////////////////////// // senf::ppi::connector::PassiveConnector template prefix_ void senf::ppi::connector::PassiveConnector::onRequest(Handler handler) { - callback_ = detail::Callback<>::make(handler, module()); + callback_ = ppi::detail::Callback<>::make(handler, module()); } /////////////////////////////////////////////////////////////////////////// @@ -45,20 +78,20 @@ prefix_ void senf::ppi::connector::PassiveConnector::onRequest(Handler handler) template prefix_ void senf::ppi::connector::ActiveConnector::onThrottle(Handler handler) { - throttleCallback_ = detail::Callback<>::make(handler, module()); + throttleCallback_ = ppi::detail::Callback<>::make(handler, module()); } template prefix_ void senf::ppi::connector::ActiveConnector::onUnthrottle(Handler handler) { - unthrottleCallback_ = detail::Callback<>::make(handler, module()); + unthrottleCallback_ = ppi::detail::Callback<>::make(handler, module()); } /////////////////////////////////////////////////////////////////////////// -// senf::ppi::connector::PassiveInput +// senf::ppi::connector::GenericPassiveInput template -prefix_ void senf::ppi::connector::PassiveInput::qdisc(QDisc const & disc) +prefix_ void senf::ppi::connector::GenericPassiveInput::qdisc(QDisc const & disc) { qdisc_.reset(new QDisc(disc)); }