X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FSocketPolicy.ct;h=3488d53f85f38a4db821a1579412ff508dfab6e3;hb=1ad3873b372da6187b1fbc645bf276287d2efb54;hp=cbcfd30842a4f91502a53e51271dc8ac7166285c;hpb=62464586315edf52fbcc613acb4a8a7e919fd8e2;p=senf.git diff --git a/Socket/SocketPolicy.ct b/Socket/SocketPolicy.ct index cbcfd30..3488d53 100644 --- a/Socket/SocketPolicy.ct +++ b/Socket/SocketPolicy.ct @@ -1,6 +1,6 @@ // $Id$ // -// Copyright (C) 2006 +// Copyright (C) 2006 // Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) // Kompetenzzentrum fuer Satelitenkommunikation (SatCom) // Stefan Bund @@ -20,7 +20,9 @@ // Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -// Definition of non-inline template functions +/** \file + \brief Policy Framework non-inline template implemenation + */ #include "SocketPolicy.ih" @@ -36,8 +38,16 @@ template < BOOST_PP_SEQ_FOR_EACH_I( SP_TemplateArgs, , SENF_SOCKET_POLICIES ) > prefix_ void senf::SocketPolicy< BOOST_PP_SEQ_FOR_EACH_I( SP_TemplateParams, , SENF_SOCKET_POLICIES ) >:: checkBaseOf(SocketPolicyBase const & other) { -# define SP_CheckPolicy(x1,x2,SomePolicy) (void) dynamic_cast(other.BOOST_PP_CAT(the,SomePolicy)()); + // 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 ) + # undef SP_CheckPolicy } @@ -50,5 +60,10 @@ checkBaseOf(SocketPolicyBase const & other) // Local Variables: // mode: c++ +// fill-column: 100 // c-file-style: "senf" +// indent-tabs-mode: nil +// ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: