From eea7bd77c35c1f86f94a49f948d73e6f67aa6c2f Mon Sep 17 00:00:00 2001
From: g0dil <g0dil@wiback.org>
Date: Tue, 22 May 2007 10:57:23 +0000
Subject: [PATCH] Implement libPacket protocol bundles

---
 Examples/MCSniffer/MCSniffer.cc               |  2 +-
 Examples/MCSniffer/SConscript                 |  3 +-
 Examples/Sniffer/SConscript                   |  3 +-
 Examples/Sniffer/Sniffer.cc                   | 11 +----
 Examples/TCPClientServer/client.cc            |  1 -
 Examples/TCPClientServer/server.cc            |  2 +-
 Packets/{ => DefaultBundle}/EthernetPacket.cc |  0
 .../{ => DefaultBundle}/EthernetPacket.cti    |  0
 Packets/{ => DefaultBundle}/EthernetPacket.hh |  8 ++--
 .../EthernetPacket.test.cc                    |  0
 Packets/{ => DefaultBundle}/IpV4Packet.cc     |  0
 Packets/{ => DefaultBundle}/IpV4Packet.cti    |  0
 Packets/{ => DefaultBundle}/IpV4Packet.hh     |  8 ++--
 .../{ => DefaultBundle}/IpV4Packet.test.cc    |  0
 Packets/{ => DefaultBundle}/IpV6Extensions.cc |  0
 Packets/{ => DefaultBundle}/IpV6Extensions.ct |  0
 Packets/{ => DefaultBundle}/IpV6Extensions.hh |  0
 .../IpV6Extensions.test.cc                    |  2 +-
 Packets/{ => DefaultBundle}/IpV6Packet.cc     |  0
 Packets/{ => DefaultBundle}/IpV6Packet.cti    |  0
 Packets/{ => DefaultBundle}/IpV6Packet.hh     |  8 ++--
 .../{ => DefaultBundle}/IpV6Packet.test.cc    |  0
 Packets/DefaultBundle/SConscript              | 14 ++++++
 Packets/{ => DefaultBundle}/UDPPacket.cc      |  2 +-
 Packets/{ => DefaultBundle}/UDPPacket.cti     |  0
 Packets/{ => DefaultBundle}/UDPPacket.hh      |  8 ++--
 Packets/{ => DefaultBundle}/UDPPacket.test.cc |  0
 Packets/DefaultBundle/main.test.cc            | 47 +++++++++++++++++++
 Packets/Doxyfile                              |  3 +-
 Packets/PacketRegistry.hh                     |  3 --
 Packets/{ => RTPBundle}/RTCPPacket.cc         |  0
 Packets/{ => RTPBundle}/RTCPPacket.cti        |  0
 Packets/{ => RTPBundle}/RTCPPacket.hh         | 12 ++---
 Packets/{ => RTPBundle}/RTCPPacket.test.cc    |  0
 Packets/{ => RTPBundle}/RTPPacket.cc          |  0
 Packets/{ => RTPBundle}/RTPPacket.cti         |  0
 Packets/{ => RTPBundle}/RTPPacket.hh          | 10 ++--
 Packets/{ => RTPBundle}/RTPPacket.test.cc     |  6 +--
 Packets/RTPBundle/SConscript                  | 15 ++++++
 Packets/RTPBundle/main.test.cc                | 47 +++++++++++++++++++
 Packets/SConscript                            |  4 +-
 senfscons/BoostUnitTests.py                   |  4 +-
 senfscons/SENFSCons.py                        | 22 ++++++---
 43 files changed, 185 insertions(+), 60 deletions(-)
 rename Packets/{ => DefaultBundle}/EthernetPacket.cc (100%)
 rename Packets/{ => DefaultBundle}/EthernetPacket.cti (100%)
 rename Packets/{ => DefaultBundle}/EthernetPacket.hh (97%)
 rename Packets/{ => DefaultBundle}/EthernetPacket.test.cc (100%)
 rename Packets/{ => DefaultBundle}/IpV4Packet.cc (100%)
 rename Packets/{ => DefaultBundle}/IpV4Packet.cti (100%)
 rename Packets/{ => DefaultBundle}/IpV4Packet.hh (97%)
 rename Packets/{ => DefaultBundle}/IpV4Packet.test.cc (100%)
 rename Packets/{ => DefaultBundle}/IpV6Extensions.cc (100%)
 rename Packets/{ => DefaultBundle}/IpV6Extensions.ct (100%)
 rename Packets/{ => DefaultBundle}/IpV6Extensions.hh (100%)
 rename Packets/{ => DefaultBundle}/IpV6Extensions.test.cc (99%)
 rename Packets/{ => DefaultBundle}/IpV6Packet.cc (100%)
 rename Packets/{ => DefaultBundle}/IpV6Packet.cti (100%)
 rename Packets/{ => DefaultBundle}/IpV6Packet.hh (96%)
 rename Packets/{ => DefaultBundle}/IpV6Packet.test.cc (100%)
 create mode 100644 Packets/DefaultBundle/SConscript
 rename Packets/{ => DefaultBundle}/UDPPacket.cc (98%)
 rename Packets/{ => DefaultBundle}/UDPPacket.cti (100%)
 rename Packets/{ => DefaultBundle}/UDPPacket.hh (95%)
 rename Packets/{ => DefaultBundle}/UDPPacket.test.cc (100%)
 create mode 100644 Packets/DefaultBundle/main.test.cc
 rename Packets/{ => RTPBundle}/RTCPPacket.cc (100%)
 rename Packets/{ => RTPBundle}/RTCPPacket.cti (100%)
 rename Packets/{ => RTPBundle}/RTCPPacket.hh (98%)
 rename Packets/{ => RTPBundle}/RTCPPacket.test.cc (100%)
 rename Packets/{ => RTPBundle}/RTPPacket.cc (100%)
 rename Packets/{ => RTPBundle}/RTPPacket.cti (100%)
 rename Packets/{ => RTPBundle}/RTPPacket.hh (98%)
 rename Packets/{ => RTPBundle}/RTPPacket.test.cc (98%)
 create mode 100644 Packets/RTPBundle/SConscript
 create mode 100644 Packets/RTPBundle/main.test.cc

diff --git a/Examples/MCSniffer/MCSniffer.cc b/Examples/MCSniffer/MCSniffer.cc
index f353b2c36..1da14b6f6 100644
--- a/Examples/MCSniffer/MCSniffer.cc
+++ b/Examples/MCSniffer/MCSniffer.cc
@@ -30,7 +30,7 @@
 #include <iomanip>
 #include "Socket/UDPSocketHandle.hh"
 #include "Scheduler/Scheduler.hh"
-#include "Packets/EthernetPacket.hh"
+#include "Packets/DefaultBundle/EthernetPacket.hh"
 #include "Utils/membind.hh"
 
 
diff --git a/Examples/MCSniffer/SConscript b/Examples/MCSniffer/SConscript
index c7cab0929..8d4e3b7d0 100644
--- a/Examples/MCSniffer/SConscript
+++ b/Examples/MCSniffer/SConscript
@@ -4,4 +4,5 @@ import SENFSCons
 ###########################################################################
 
 SENFSCons.Binary(env, 'mcsniffer', SENFSCons.GlobSources(),
-                LIBS = [ 'Scheduler', 'Packets', 'Socket', 'Utils' ]);
+                 LIBS = [ 'Scheduler', 'Packets', 'Socket', 'Utils' ],
+                 OBJECTS = [ '#/Packets/DefaultBundle/DefaultBundle.o' ]);
diff --git a/Examples/Sniffer/SConscript b/Examples/Sniffer/SConscript
index 8d68b85a8..6c1c57ad7 100644
--- a/Examples/Sniffer/SConscript
+++ b/Examples/Sniffer/SConscript
@@ -4,4 +4,5 @@ import SENFSCons
 ###########################################################################
 
 SENFSCons.Binary(env, 'sniffer', SENFSCons.GlobSources(),
-                LIBS = [ 'Scheduler', 'Packets', 'Socket', 'Utils' ]);
+                 LIBS = [ 'Scheduler', 'Packets', 'Socket', 'Utils' ],
+                 OBJECTS = [ '#/Packets/DefaultBundle/DefaultBundle.o' ]);
diff --git a/Examples/Sniffer/Sniffer.cc b/Examples/Sniffer/Sniffer.cc
index 9cf18838d..2c43eb619 100644
--- a/Examples/Sniffer/Sniffer.cc
+++ b/Examples/Sniffer/Sniffer.cc
@@ -32,10 +32,7 @@
 #include "Socket/PacketSocketHandle.hh"
 #include "Scheduler/Scheduler.hh"
 #include "Utils/membind.hh"
-
-#include "Packets/EthernetPacket.hh"
-#include "Packets/IpV4Packet.hh"
-#include "Packets/UDPPacket.hh"
+#include "Packets/DefaultBundle/EthernetPacket.hh"
 
 //#include "Sniffer.mpp"
 #define prefix_
@@ -81,12 +78,6 @@ namespace {
         std::cout << std::dec;
     }
 
-    void use_em()
-    {
-        // Pull in symbols from the wanted packets ...
-        senf::Packet::create<senf::IpV4Packet>(0,0);
-        senf::Packet::create<senf::UDPPacket>(0,0);
-    }
 }
 
 int loop_main (int argc, char const * argv[])
diff --git a/Examples/TCPClientServer/client.cc b/Examples/TCPClientServer/client.cc
index 0297c4185..e30c96ec8 100644
--- a/Examples/TCPClientServer/client.cc
+++ b/Examples/TCPClientServer/client.cc
@@ -25,7 +25,6 @@
 #include <sstream>
 #include "Socket/TCPSocketHandle.hh"
 #include "Socket/INetAddressing.hh"
-#include "Packets/EthernetPacket.hh"
 
 
 int main(int argc, char const * argv[])
diff --git a/Examples/TCPClientServer/server.cc b/Examples/TCPClientServer/server.cc
index 99991f7f4..a3b0374dc 100644
--- a/Examples/TCPClientServer/server.cc
+++ b/Examples/TCPClientServer/server.cc
@@ -26,11 +26,11 @@
 
 // Custom includes
 #include <string>
+#include <iostream>
 #include "Scheduler/Scheduler.hh"
 #include "Utils/membind.hh"
 #include "Socket/TCPSocketHandle.hh"
 #include "Socket/INetAddressing.hh"
-#include "Packets/EthernetPacket.hh"
 
 
 class Server
diff --git a/Packets/EthernetPacket.cc b/Packets/DefaultBundle/EthernetPacket.cc
similarity index 100%
rename from Packets/EthernetPacket.cc
rename to Packets/DefaultBundle/EthernetPacket.cc
diff --git a/Packets/EthernetPacket.cti b/Packets/DefaultBundle/EthernetPacket.cti
similarity index 100%
rename from Packets/EthernetPacket.cti
rename to Packets/DefaultBundle/EthernetPacket.cti
diff --git a/Packets/EthernetPacket.hh b/Packets/DefaultBundle/EthernetPacket.hh
similarity index 97%
rename from Packets/EthernetPacket.hh
rename to Packets/DefaultBundle/EthernetPacket.hh
index 8603c856a..5dbec31f4 100644
--- a/Packets/EthernetPacket.hh
+++ b/Packets/DefaultBundle/EthernetPacket.hh
@@ -24,10 +24,10 @@
 #define HH_EthernetPacket_ 1
 
 // Custom includes
-#include "Packet.hh"
-#include "ParseInt.hh"
-#include "ParseArray.hh"
-#include "PacketRegistry.hh"
+#include "Packets/Packet.hh"
+#include "Packets/ParseInt.hh"
+#include "Packets/ParseArray.hh"
+#include "Packets/PacketRegistry.hh"
 
 //#include "EthernetPacket.mpp"
 ///////////////////////////////hh.p////////////////////////////////////////
diff --git a/Packets/EthernetPacket.test.cc b/Packets/DefaultBundle/EthernetPacket.test.cc
similarity index 100%
rename from Packets/EthernetPacket.test.cc
rename to Packets/DefaultBundle/EthernetPacket.test.cc
diff --git a/Packets/IpV4Packet.cc b/Packets/DefaultBundle/IpV4Packet.cc
similarity index 100%
rename from Packets/IpV4Packet.cc
rename to Packets/DefaultBundle/IpV4Packet.cc
diff --git a/Packets/IpV4Packet.cti b/Packets/DefaultBundle/IpV4Packet.cti
similarity index 100%
rename from Packets/IpV4Packet.cti
rename to Packets/DefaultBundle/IpV4Packet.cti
diff --git a/Packets/IpV4Packet.hh b/Packets/DefaultBundle/IpV4Packet.hh
similarity index 97%
rename from Packets/IpV4Packet.hh
rename to Packets/DefaultBundle/IpV4Packet.hh
index c848d3a17..94a3a9115 100644
--- a/Packets/IpV4Packet.hh
+++ b/Packets/DefaultBundle/IpV4Packet.hh
@@ -24,10 +24,10 @@
 #define HH_IpV4Packet_ 1
 
 // Custom includes
-#include "Packet.hh"
-#include "ParseInt.hh"
-#include "ParseArray.hh"
-#include "PacketRegistry.hh"
+#include "Packets/Packet.hh"
+#include "Packets/ParseInt.hh"
+#include "Packets/ParseArray.hh"
+#include "Packets/PacketRegistry.hh"
 
 //#include "IpV4Packet.mpp"
 ///////////////////////////////hh.p////////////////////////////////////////
diff --git a/Packets/IpV4Packet.test.cc b/Packets/DefaultBundle/IpV4Packet.test.cc
similarity index 100%
rename from Packets/IpV4Packet.test.cc
rename to Packets/DefaultBundle/IpV4Packet.test.cc
diff --git a/Packets/IpV6Extensions.cc b/Packets/DefaultBundle/IpV6Extensions.cc
similarity index 100%
rename from Packets/IpV6Extensions.cc
rename to Packets/DefaultBundle/IpV6Extensions.cc
diff --git a/Packets/IpV6Extensions.ct b/Packets/DefaultBundle/IpV6Extensions.ct
similarity index 100%
rename from Packets/IpV6Extensions.ct
rename to Packets/DefaultBundle/IpV6Extensions.ct
diff --git a/Packets/IpV6Extensions.hh b/Packets/DefaultBundle/IpV6Extensions.hh
similarity index 100%
rename from Packets/IpV6Extensions.hh
rename to Packets/DefaultBundle/IpV6Extensions.hh
diff --git a/Packets/IpV6Extensions.test.cc b/Packets/DefaultBundle/IpV6Extensions.test.cc
similarity index 99%
rename from Packets/IpV6Extensions.test.cc
rename to Packets/DefaultBundle/IpV6Extensions.test.cc
index f0fed3970..35c33f0fc 100644
--- a/Packets/IpV6Extensions.test.cc
+++ b/Packets/DefaultBundle/IpV6Extensions.test.cc
@@ -28,7 +28,7 @@
 #include "IpV6Extensions.hh"
 #include "IpV6Packet.hh"
 #include "UDPPacket.hh"
-#include "DataPacket.hh"
+#include "Packets/DataPacket.hh"
 #include "Socket/INetAddressing.hh"
 
 #include <boost/test/auto_unit_test.hpp>
diff --git a/Packets/IpV6Packet.cc b/Packets/DefaultBundle/IpV6Packet.cc
similarity index 100%
rename from Packets/IpV6Packet.cc
rename to Packets/DefaultBundle/IpV6Packet.cc
diff --git a/Packets/IpV6Packet.cti b/Packets/DefaultBundle/IpV6Packet.cti
similarity index 100%
rename from Packets/IpV6Packet.cti
rename to Packets/DefaultBundle/IpV6Packet.cti
diff --git a/Packets/IpV6Packet.hh b/Packets/DefaultBundle/IpV6Packet.hh
similarity index 96%
rename from Packets/IpV6Packet.hh
rename to Packets/DefaultBundle/IpV6Packet.hh
index fa8fdb1ed..32fd80783 100644
--- a/Packets/IpV6Packet.hh
+++ b/Packets/DefaultBundle/IpV6Packet.hh
@@ -25,10 +25,10 @@
 #define HH_IpV6Packet_ 1
 
 // Custom includes
-#include "Packet.hh"
-#include "ParseInt.hh"
-#include "ParseArray.hh"
-#include "PacketRegistry.hh"
+#include "Packets/Packet.hh"
+#include "Packets/ParseInt.hh"
+#include "Packets/ParseArray.hh"
+#include "Packets/PacketRegistry.hh"
 #include "IpV4Packet.hh"
 
 //#include "IpV6Packet.mpp"
diff --git a/Packets/IpV6Packet.test.cc b/Packets/DefaultBundle/IpV6Packet.test.cc
similarity index 100%
rename from Packets/IpV6Packet.test.cc
rename to Packets/DefaultBundle/IpV6Packet.test.cc
diff --git a/Packets/DefaultBundle/SConscript b/Packets/DefaultBundle/SConscript
new file mode 100644
index 000000000..f096a6804
--- /dev/null
+++ b/Packets/DefaultBundle/SConscript
@@ -0,0 +1,14 @@
+# -*- python -*-
+
+Import('env')
+import SENFSCons, glob
+
+###########################################################################
+
+sources = SENFSCons.GlobSources()
+
+SENFSCons.StandardTargets(env)
+
+SENFSCons.Object(env, target = 'DefaultBundle', sources=sources,
+                 LIBS = ['Packets', 'Socket', 'Utils'])
+                 
diff --git a/Packets/UDPPacket.cc b/Packets/DefaultBundle/UDPPacket.cc
similarity index 98%
rename from Packets/UDPPacket.cc
rename to Packets/DefaultBundle/UDPPacket.cc
index a93f80f9a..d74e0808c 100644
--- a/Packets/UDPPacket.cc
+++ b/Packets/DefaultBundle/UDPPacket.cc
@@ -27,7 +27,7 @@
 #include "IpV4Packet.hh"
 
 // Custom includes
-#include "DataPacket.hh"
+#include "Packets/DataPacket.hh"
 
 #define prefix_
 ///////////////////////////////cc.p////////////////////////////////////////
diff --git a/Packets/UDPPacket.cti b/Packets/DefaultBundle/UDPPacket.cti
similarity index 100%
rename from Packets/UDPPacket.cti
rename to Packets/DefaultBundle/UDPPacket.cti
diff --git a/Packets/UDPPacket.hh b/Packets/DefaultBundle/UDPPacket.hh
similarity index 95%
rename from Packets/UDPPacket.hh
rename to Packets/DefaultBundle/UDPPacket.hh
index 2f54e93f4..bd0fc5757 100644
--- a/Packets/UDPPacket.hh
+++ b/Packets/DefaultBundle/UDPPacket.hh
@@ -24,10 +24,10 @@
 #define HH_UDPPacket_ 1
 
 // Custom includes
-#include "Packet.hh"
-#include "ParseInt.hh"
-#include "ParseArray.hh"
-#include "PacketRegistry.hh"
+#include "Packets/Packet.hh"
+#include "Packets/ParseInt.hh"
+#include "Packets/ParseArray.hh"
+#include "Packets/PacketRegistry.hh"
 
 //#include "UDPPacket.mpp"
 ///////////////////////////////hh.p////////////////////////////////////////
diff --git a/Packets/UDPPacket.test.cc b/Packets/DefaultBundle/UDPPacket.test.cc
similarity index 100%
rename from Packets/UDPPacket.test.cc
rename to Packets/DefaultBundle/UDPPacket.test.cc
diff --git a/Packets/DefaultBundle/main.test.cc b/Packets/DefaultBundle/main.test.cc
new file mode 100644
index 000000000..fd5cfe15a
--- /dev/null
+++ b/Packets/DefaultBundle/main.test.cc
@@ -0,0 +1,47 @@
+// $Id: main.test.cc 206 2007-02-20 14:20:52Z g0dil $
+//
+// Copyright (C) 2006
+// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
+// Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
+//     Stefan Bund <stefan.bund@fokus.fraunhofer.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.
+
+// Definition of non-inline non-template functions
+
+//#include "test.hh"
+//#include "test.ih"
+
+// Custom includes
+#define BOOST_AUTO_TEST_MAIN
+#include <boost/test/auto_unit_test.hpp>
+#include <boost/test/test_tools.hpp>
+
+#define prefix_
+///////////////////////////////cc.p////////////////////////////////////////
+
+
+///////////////////////////////cc.e////////////////////////////////////////
+#undef prefix_
+
+
+// Local Variables:
+// mode: c++
+// fill-column: 100
+// c-file-style: "senf"
+// indent-tabs-mode: nil
+// ispell-local-dictionary: "american"
+// End:
diff --git a/Packets/Doxyfile b/Packets/Doxyfile
index 2e7c41a30..a7fcd33fb 100644
--- a/Packets/Doxyfile
+++ b/Packets/Doxyfile
@@ -2,4 +2,5 @@
 
 PROJECT_NAME = libPackets
 TAGFILES = "$(TOPDIR)/Utils/doc/Utils.tag"
-GENERATE_TAGFILE = doc/Packets.tag
\ No newline at end of file
+GENERATE_TAGFILE = doc/Packets.tag
+INPUT = . DefaultBundle RTPBundle
\ No newline at end of file
diff --git a/Packets/PacketRegistry.hh b/Packets/PacketRegistry.hh
index 93f951aa3..da9964a20 100644
--- a/Packets/PacketRegistry.hh
+++ b/Packets/PacketRegistry.hh
@@ -89,9 +89,6 @@ namespace senf {
     {
     public:
         /** \brief Statically register a packet type in a PacketRegistry
-
-            \fixme This fails to work within a library since the linker will
-            remove all unused object files ...
          */
         template <class OtherPacket>
         struct RegistrationProxy
diff --git a/Packets/RTCPPacket.cc b/Packets/RTPBundle/RTCPPacket.cc
similarity index 100%
rename from Packets/RTCPPacket.cc
rename to Packets/RTPBundle/RTCPPacket.cc
diff --git a/Packets/RTCPPacket.cti b/Packets/RTPBundle/RTCPPacket.cti
similarity index 100%
rename from Packets/RTCPPacket.cti
rename to Packets/RTPBundle/RTCPPacket.cti
diff --git a/Packets/RTCPPacket.hh b/Packets/RTPBundle/RTCPPacket.hh
similarity index 98%
rename from Packets/RTCPPacket.hh
rename to Packets/RTPBundle/RTCPPacket.hh
index 1d566cb36..da4d25abe 100644
--- a/Packets/RTCPPacket.hh
+++ b/Packets/RTPBundle/RTCPPacket.hh
@@ -24,12 +24,12 @@
 #define HH_RTCPPacket_ 1
 
 // Custom includes
-#include "Packet.hh"
-#include "ParseInt.hh"
-#include "ParseArray.hh"
-#include "ParseListS.hh"
-#include "ParseVec.hh"
-#include "PacketRegistry.hh"
+#include "Packets/Packet.hh"
+#include "Packets/ParseInt.hh"
+#include "Packets/ParseArray.hh"
+#include "Packets/ParseListS.hh"
+#include "Packets/ParseVec.hh"
+#include "Packets/PacketRegistry.hh"
 
 //#include "RTCPPacket.mpp"
 ///////////////////////////////hh.p////////////////////////////////////////
diff --git a/Packets/RTCPPacket.test.cc b/Packets/RTPBundle/RTCPPacket.test.cc
similarity index 100%
rename from Packets/RTCPPacket.test.cc
rename to Packets/RTPBundle/RTCPPacket.test.cc
diff --git a/Packets/RTPPacket.cc b/Packets/RTPBundle/RTPPacket.cc
similarity index 100%
rename from Packets/RTPPacket.cc
rename to Packets/RTPBundle/RTPPacket.cc
diff --git a/Packets/RTPPacket.cti b/Packets/RTPBundle/RTPPacket.cti
similarity index 100%
rename from Packets/RTPPacket.cti
rename to Packets/RTPBundle/RTPPacket.cti
diff --git a/Packets/RTPPacket.hh b/Packets/RTPBundle/RTPPacket.hh
similarity index 98%
rename from Packets/RTPPacket.hh
rename to Packets/RTPBundle/RTPPacket.hh
index 823487a0b..1f281f544 100644
--- a/Packets/RTPPacket.hh
+++ b/Packets/RTPBundle/RTPPacket.hh
@@ -24,11 +24,11 @@
 #define HH_RTPPacket_ 1
 
 // Custom includes
-#include "Packet.hh"
-#include "ParseInt.hh"
-#include "ParseArray.hh"
-#include "ParseVec.hh"
-#include "PacketRegistry.hh"
+#include "Packets/Packet.hh"
+#include "Packets/ParseInt.hh"
+#include "Packets/ParseArray.hh"
+#include "Packets/ParseVec.hh"
+#include "Packets/PacketRegistry.hh"
 
 //#include "RTPPacket.mpp"
 ///////////////////////////////hh.p////////////////////////////////////////
diff --git a/Packets/RTPPacket.test.cc b/Packets/RTPBundle/RTPPacket.test.cc
similarity index 98%
rename from Packets/RTPPacket.test.cc
rename to Packets/RTPBundle/RTPPacket.test.cc
index 9711b185d..1f0da11c7 100644
--- a/Packets/RTPPacket.test.cc
+++ b/Packets/RTPBundle/RTPPacket.test.cc
@@ -28,9 +28,9 @@
 // Custom includes
 #include "RTPPacket.hh"
 
-#include "EthernetPacket.hh"
-#include "IpV4Packet.hh"
-#include "UDPPacket.hh"
+#include "Packets/DefaultBundle/EthernetPacket.hh"
+#include "Packets/DefaultBundle/IpV4Packet.hh"
+#include "Packets/DefaultBundle/UDPPacket.hh"
 
 #include <boost/test/auto_unit_test.hpp>
 #include <boost/test/test_tools.hpp>
diff --git a/Packets/RTPBundle/SConscript b/Packets/RTPBundle/SConscript
new file mode 100644
index 000000000..fe9bc7657
--- /dev/null
+++ b/Packets/RTPBundle/SConscript
@@ -0,0 +1,15 @@
+# -*- python -*-
+
+Import('env')
+import SENFSCons, glob
+
+###########################################################################
+
+sources = SENFSCons.GlobSources()
+
+SENFSCons.StandardTargets(env)
+
+SENFSCons.Object(env, target = 'RTPBundle', sources=sources,
+                 LIBS = ['Packets', 'Socket', 'Utils'],
+                 OBJECTS = ['#/Packets/DefaultBundle/DefaultBundle.o'])
+                 
diff --git a/Packets/RTPBundle/main.test.cc b/Packets/RTPBundle/main.test.cc
new file mode 100644
index 000000000..fd5cfe15a
--- /dev/null
+++ b/Packets/RTPBundle/main.test.cc
@@ -0,0 +1,47 @@
+// $Id: main.test.cc 206 2007-02-20 14:20:52Z g0dil $
+//
+// Copyright (C) 2006
+// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS)
+// Kompetenzzentrum fuer Satelitenkommunikation (SatCom)
+//     Stefan Bund <stefan.bund@fokus.fraunhofer.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.
+
+// Definition of non-inline non-template functions
+
+//#include "test.hh"
+//#include "test.ih"
+
+// Custom includes
+#define BOOST_AUTO_TEST_MAIN
+#include <boost/test/auto_unit_test.hpp>
+#include <boost/test/test_tools.hpp>
+
+#define prefix_
+///////////////////////////////cc.p////////////////////////////////////////
+
+
+///////////////////////////////cc.e////////////////////////////////////////
+#undef prefix_
+
+
+// Local Variables:
+// mode: c++
+// fill-column: 100
+// c-file-style: "senf"
+// indent-tabs-mode: nil
+// ispell-local-dictionary: "american"
+// End:
diff --git a/Packets/SConscript b/Packets/SConscript
index b39aa6539..27f0650e3 100644
--- a/Packets/SConscript
+++ b/Packets/SConscript
@@ -1,7 +1,7 @@
 # -*- python -*-
 
 Import('env')
-import SENFSCons
+import SENFSCons, glob
 
 ###########################################################################
 
@@ -17,3 +17,5 @@ SENFSCons.Lib(env,
 SENFSCons.Doxygen(env, extra_sources = [
     env.Dia2Png("structure.dia")
 ])
+
+SConscript(glob.glob("*/SConscript"))
diff --git a/senfscons/BoostUnitTests.py b/senfscons/BoostUnitTests.py
index e6aed7af7..2dce3ba1e 100644
--- a/senfscons/BoostUnitTests.py
+++ b/senfscons/BoostUnitTests.py
@@ -26,7 +26,7 @@ import SCons.Defaults
 import os.path
 import os
 
-def BoostUnitTests(env, target, source, test_source=None, LIBS = [], DEPENDS = [], **kw):
+def BoostUnitTests(env, target, source, test_source=None, LIBS = [], OBJECTS = [], DEPENDS = [], **kw):
     path, name = os.path.split(target)
     if test_source:
         if type(test_source) is not type([]):
@@ -38,7 +38,7 @@ def BoostUnitTests(env, target, source, test_source=None, LIBS = [], DEPENDS = [
     testEnv.Prepend(LIBS = LIBS)
     sources = []
     if source:
-        sources = sources + env.Object(source)
+        sources = sources + env.Object(source) + OBJECTS
     sources = sources + test_source
     binName = os.path.join(path,'.' + name +'.bin')
     testRunner = testEnv.Program(binName, sources)
diff --git a/senfscons/SENFSCons.py b/senfscons/SENFSCons.py
index d87f229e9..c676f3476 100644
--- a/senfscons/SENFSCons.py
+++ b/senfscons/SENFSCons.py
@@ -292,7 +292,7 @@ def LibPath(lib): return '$LOCALLIBDIR/lib%s.a' % lib
 # provide both \a sources and \a testSources.
 #
 # \ingroup target
-def Objects(env, sources, testSources = None, LIBS = []):
+def Objects(env, sources, testSources = None, LIBS = [], OBJECTS = []):
     if type(sources) == type(()):
         testSources = sources[1]
         sources = sources[0]
@@ -307,6 +307,7 @@ def Objects(env, sources, testSources = None, LIBS = []):
             source = sources,
             test_source = testSources,
             LIBS = LIBS,
+            OBJECTS = OBJECTS,
             DEPENDS = [ env.File(LibPath(x)) for x in LIBS ])
         env.Alias('all_tests', test)
         # Hmm ... here I'd like to use an Alias instead of a file
@@ -493,8 +494,8 @@ def DoxyXRef(env, docs=None,
 # The library is added to the list of default targets.
 #
 #\ingroup target
-def Lib(env, library, sources, testSources = None, LIBS = []):
-    objects = Objects(env,sources,testSources,LIBS=LIBS)
+def Lib(env, library, sources, testSources = None, LIBS = [], OBJECTS = []):
+    objects = Objects(env,sources,testSources,LIBS=LIBS,OBJECTS=OBJECTS)
     lib = None
     if objects:
         lib = env.Library(env.File(LibPath(library)),objects)
@@ -502,6 +503,15 @@ def Lib(env, library, sources, testSources = None, LIBS = []):
         env.Append(ALLLIBS = library)
     return lib
 
+## \brief Build Object from multiple sources
+def Object(env, target, sources, testSources = None, LIBS = [], OBJECTS = []):
+    objects = Objects(env,sources,testSources,LIBS=LIBS,OBJECTS=OBJECTS)
+    ob = None
+    if objects:
+        ob = env.Command(target+".o", objects, "ld -r -o $TARGET $SOURCES")
+        env.Default(ob)
+    return ob
+
 ## \brief Build executable
 #
 # This target helper will build the given binary.  The \a sources, \a
@@ -512,13 +522,13 @@ def Lib(env, library, sources, testSources = None, LIBS = []):
 # construction environment parameters or the framework helpers.
 #
 # \ingroup target
-def Binary(env, binary, sources, testSources = None, LIBS = []):
-    objects = Objects(env,sources,testSources,LIBS=LIBS)
+def Binary(env, binary, sources, testSources = None, LIBS = [], OBJECTS = []):
+    objects = Objects(env,sources,testSources,LIBS=LIBS,OBJECTS=OBJECTS)
     program = None
     if objects:
         progEnv = env.Copy()
         progEnv.Prepend(LIBS = LIBS)
-        program = progEnv.Program(target=binary,source=objects)
+        program = progEnv.Program(target=binary,source=objects+OBJECTS)
         env.Default(program)
         env.Depends(program, [ env.File(LibPath(x)) for x in LIBS ])
     return program
-- 
GitLab