Fixes for g++-4
g0dil [Mon, 16 Oct 2006 10:56:04 +0000 (10:56 +0000)]
git-svn-id: https://svn.berlios.de/svnroot/repos/senf/trunk@141 270642c3-0616-0410-b53a-bc976706d245

Packets/PacketRegistry.ih
Packets/ParserBase.ih
Packets/ParserBase.test.cc
Packets/typeidvalue.hh

index 2a752b2..f014506 100644 (file)
@@ -35,6 +35,7 @@ namespace pkf {
 namespace impl {
 
     struct PkReg_Entry {
+        virtual ~PkReg_Entry() {}
         virtual void registerInterpreter(Packet const * p, 
                                          Packet::iterator b, Packet::iterator e) = 0;
         virtual Packet::ptr reinterpret(Packet * p) = 0;
index 3cb5eb1..924189a 100644 (file)
@@ -45,11 +45,11 @@ namespace impl {
             Parser_traits_fixed_size_check(&Parser::bytes))-sizeof(Parser_traits_sentinel<1>);
     };
 
-    template <class T>
-    Parser_traits_sentinel<2> Parser_traits_fixed_size_check(T);
+    template <class R>
+    Parser_traits_sentinel<2> Parser_traits_fixed_size_check(R (*)());
 
     template <class R,class T>
-    Parser_traits_sentinel<1> Parser_traits_fixed_size_check(R (T::*)());
+    Parser_traits_sentinel<1> Parser_traits_fixed_size_check(R (T::*)() const);
 
     template <class Parser, class Iterator>
     bool check(Iterator const & b, Iterator const & e, ParserBase *);
index dca6b77..b1a8983 100644 (file)
@@ -28,6 +28,7 @@
 // Custom includes
 #include "ParserBase.hh"
 #include "Packet.hh"
+#include <boost/static_assert.hpp>
 
 #include <boost/test/auto_unit_test.hpp>
 #include <boost/test/test_tools.hpp>
@@ -85,6 +86,9 @@ namespace {
 
 BOOST_AUTO_UNIT_TEST(parserBase_construction)
 {
+    BOOST_STATIC_ASSERT( pkf::Parser_traits< Parse_Test<> >::fixed_size );
+    BOOST_STATIC_ASSERT( ! pkf::Parser_traits< Parse_Test2<> >::fixed_size );
+
     BOOST_CHECK_EQUAL( pkf::min_bytes< Parse_Test<int> >(), 14u );
     BOOST_CHECK( pkf::check< Parse_Test<int> >(0,14) );
     BOOST_CHECK( ! pkf::check< Parse_Test<int> >(2,15) );
index 425c14f..bb03dbe 100644 (file)
@@ -68,6 +68,7 @@ namespace lib {
         template <class Type> TypeIdValue(Type *);
 
         struct Value {
+            virtual ~Value() {}
             virtual std::type_info const & id() = 0;
             virtual Value * clone() = 0;
         };