X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FSocketPolicy.ct;h=fa9ca77116aa7ecb3d882312e96729519031213b;hb=a1fdb7bb122f0b05be809a922d4b7ef5e125fa67;hp=bec4f71bcfea7add243e96912df3affc48cb3e19;hpb=85ab07d100a382467a42e19d741d403a7a96c951;p=senf.git diff --git a/Socket/SocketPolicy.ct b/Socket/SocketPolicy.ct index bec4f71..fa9ca77 100644 --- a/Socket/SocketPolicy.ct +++ b/Socket/SocketPolicy.ct @@ -1,9 +1,9 @@ // $Id$ // // Copyright (C) 2006 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) -// Stefan Bund +// 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 // it under the terms of the GNU General Public License as published by @@ -27,6 +27,7 @@ #include "SocketPolicy.ih" // Custom includes +#include "../Utils/Exception.hh" #define prefix_ ///////////////////////////////ct.p//////////////////////////////////////// @@ -41,8 +42,16 @@ checkBaseOf(SocketPolicyBase const & other) // check, wether each policy of other is (dynamically!) convertible // to the corresponding (static) policy of this class. Throws // std::bad_cast on failure -# define SP_CheckPolicy(x1,x2,SomePolicy) (void) dynamic_cast(other.BOOST_PP_CAT(the,SomePolicy)()); - BOOST_PP_SEQ_FOR_EACH( SP_CheckPolicy, , SENF_SOCKET_POLICIES ) + +# define SP_CheckPolicy(x1,x2,SomePolicy) \ + (void) dynamic_cast( \ + other.BOOST_PP_CAT(the,SomePolicy)()); + + try { + BOOST_PP_SEQ_FOR_EACH( SP_CheckPolicy, , SENF_SOCKET_POLICIES ) + } + SENF_WRAP_EXC(std::bad_cast) + # undef SP_CheckPolicy } @@ -59,4 +68,6 @@ checkBaseOf(SocketPolicyBase const & other) // c-file-style: "senf" // indent-tabs-mode: nil // ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: