SENF_ASSERT( ! target.peer_,
"senf::ppi::connector::Connector::connect(): (target) "
"duplicate connection" );
+
if (! (packetTypeID() == typeid(void) ||
target.packetTypeID() == typeid(void) ||
packetTypeID() == target.packetTypeID()) )
--- /dev/null
+// $Id$
+//
+// Copyright (C) 2009
+// 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
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation; either version 2 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; if not, write to the
+// Free Software Foundation, Inc.,
+// 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+
+/** \file
+ \brief Jack non-inline non-template implementation */
+
+//#include "Jack.ih"
+
+// Custom includes
+#include "Setup.hh"
+
+#define prefix_
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
+
+prefix_ void senf::ppi::connector::GenericActiveInputJack::reset(GenericActiveInput & input)
+{
+ if (input_->connected()) {
+ GenericPassiveOutput & peer (input_->peer());
+ input_->disconnect();
+ connect(peer, input);
+ }
+ input_ = & input;
+}
+
+prefix_ void senf::ppi::connector::GenericActiveOutputJack::reset(GenericActiveOutput & output)
+{
+ if (output_->connected()) {
+ GenericPassiveInput & peer (output_->peer());
+ output_->disconnect();
+ connect(output, peer);
+ }
+ output_ = & output;
+}
+
+prefix_ void senf::ppi::connector::GenericPassiveInputJack::reset(GenericPassiveInput & input)
+{
+ if (input_->connected()) {
+ GenericActiveOutput & peer (input_->peer());
+ input_->disconnect();
+ connect(peer, input);
+ }
+ input_ = & input;
+}
+
+prefix_ void senf::ppi::connector::GenericPassiveOutputJack::reset(GenericPassiveOutput & output)
+{
+ if (output_->connected()) {
+ GenericActiveInput & peer (output_->peer());
+ output_->disconnect();
+ connect(output, peer);
+ }
+ output_ = & output;
+}
+
+//-/////////////////////////////////////////////////////////////////////////////////////////////////
+#undef prefix_
+
+\f
+// Local Variables:
+// mode: c++
+// fill-column: 100
+// comment-column: 40
+// c-file-style: "senf"
+// indent-tabs-mode: nil
+// ispell-local-dictionary: "american"
+// compile-command: "scons -u test"
+// End:
return *input_;
}
-prefix_ void senf::ppi::connector::GenericActiveInputJack::reset(GenericActiveInput & input)
-{
- if (input_->connected()) {
- GenericPassiveOutput & peer (input_->peer());
- input_->disconnect();
- connect(peer, input);
- }
- input_ = & input;
-}
-
prefix_ senf::ppi::connector::GenericActiveOutputJack::
GenericActiveOutputJack(GenericActiveOutput & output)
: output_ (&output)
return *output_;
}
-prefix_ void senf::ppi::connector::GenericActiveOutputJack::reset(GenericActiveOutput & output)
-{
- if (output_->connected()) {
- GenericPassiveInput & peer (output_->peer());
- output_->disconnect();
- connect(output, peer);
- }
- output_ = & output;
-}
-
prefix_ senf::ppi::connector::GenericPassiveInputJack::
GenericPassiveInputJack(GenericPassiveInput & input)
: input_ (&input)
return *input_;
}
-prefix_ void senf::ppi::connector::GenericPassiveInputJack::reset(GenericPassiveInput & input)
-{
- if (input_->connected()) {
- GenericActiveOutput & peer (input_->peer());
- input_->disconnect();
- connect(peer, input);
- }
- input_ = & input;
-}
-
prefix_ senf::ppi::connector::GenericPassiveOutputJack::
GenericPassiveOutputJack(GenericPassiveOutput & output)
: output_ (&output)
return *output_;
}
-prefix_ void
-senf::ppi::connector::GenericPassiveOutputJack::reset(GenericPassiveOutput & output)
-{
- if (output_->connected()) {
- GenericActiveInput & peer (output_->peer());
- output_->disconnect();
- connect(output, peer);
- }
- output_ = & output;
-}
-
prefix_ senf::ppi::connector::ActiveInputJack<senf::Packet>::
ActiveInputJack(GenericActiveInput & input)
: GenericActiveInputJack (input)
BOOST_CHECK( ! sink );
}
+namespace {
+ struct ActiveJackSource
+ {
+ senf::ppi::connector::ActiveOutputJack<> output;
+
+ debug::ActiveSource source1;
+ debug::ActiveSource source2;
+
+ ActiveJackSource()
+ : output (source1.output) {}
+
+ void flip() {
+ output.reset( source2.output);
+ }
+ };
+}
+
+//SENF_AUTO_UNIT_TEST(jack_passiveJoin)
+//{
+// ActiveJackSource jackSource;
+// PassiveJoin join;
+// debug::PassiveSink sink;
+//
+// ppi::connect(jackSource, join);
+// ppi::connect(join, sink);
+// ppi::init();
+//
+// senf::Packet p1 (senf::DataPacket::create());
+// senf::Packet p2 (senf::DataPacket::create());
+//
+// jackSource.source1.submit( p1);
+// BOOST_CHECK_EQUAL( sink.pop_front(), p1);
+//
+// jackSource.flip();
+//
+// jackSource.source2.submit( p2);
+// BOOST_CHECK_EQUAL( sink.pop_front(), p2);
+//}
+
//-/////////////////////////////////////////////////////////////////////////////////////////////////
#undef prefix_