X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Packets%2FParseHelpers.ih;h=02520f599bca189fad841b489cb29302a9d699f4;hb=96bb4084fc4493a7a2686d02a895bce1160d61d6;hp=18f58e586be5962c34e283fbd1e19baddb905ac6;hpb=8f1a688cea76f2e76bfa0193dff9c1538929147e;p=senf.git diff --git a/Packets/ParseHelpers.ih b/Packets/ParseHelpers.ih index 18f58e5..02520f5 100644 --- a/Packets/ParseHelpers.ih +++ b/Packets/ParseHelpers.ih @@ -29,6 +29,7 @@ # include # include # include +# include # include "../Utils/mpl.hh" # # ////////////////////////////////ih.p/////////////////////////////////////// @@ -326,7 +327,9 @@ # define SENF_PARSER_SKIP_BITS_fix(bits) SENF_PARSER_I_SKIP_BITS(bits, fix) # # define SENF_PARSER_I_SKIP_BITS(bits, ofstype) \ - SENF_MPL_SLOT_SET(bit, SENF_MPL_SLOT_GET(bit) + bits) + private: \ + SENF_MPL_SLOT_SET(bit, SENF_MPL_SLOT_GET(bit) + bits); \ + public: # # /////////////////////////////////////////////////////////////////////////// # // SENF_PARSER_GOTO_* @@ -439,25 +442,63 @@ # /////////////////////////////////////////////////////////////////////////// # // SENF_PARSER_COLLECTION_I # +# ifndef DOXYGEN +# namespace senf { namespace detail { namespace auxtag { struct none {}; } } } namespace senf { namespace detail { namespace auxtag { struct bytes {}; } } } namespace senf { namespace detail { namespace auxtag { - template + template struct transform {}; } } } +# +# endif # # define SENF_PARSER_COLLECTION_TAG_GOBBLE__bytes(x) -# define SENF_PARSER_COLLECTION_TAG__bytes(x) senf::detail::auxtag::bytes +# define SENF_PARSER_COLLECTION_TAG__bytes(x) bytes() +# define SENF_PARSER_COLLECTION_TAG_EXPAND__bytes() senf::detail::auxtag::bytes # define SENF_PARSER_COLLECTION_TAG_GETAUX__bytes(x) x # +# // No recursive call so we need some more of theese ... ARGH !!! +# define SENF_CAT_RECURS1(a, b) SENF_CAT_RECURS1_I(a,b) +# define SENF_CAT_RECURS1_I(a, b) a ## b +# define SENF_CAT_RECURS2(a, b) SENF_CAT_RECURS2_I(a,b) +# define SENF_CAT_RECURS2_I(a, b) a ## b +# define SENF_CAT_RECURS3(a, b) SENF_CAT_RECURS3_I(a,b) +# define SENF_CAT_RECURS3_I(a, b) a ## b +# # define SENF_PARSER_COLLECTION_TAG_GOBBLE__transform(x,y) -# define SENF_PARSER_COLLECTION_TAG__transform(x,y) senf::detail::auxtag::transform -# define SENF_PARSER_COLLECTION_TAG_GETAUX__transform(x,y) y +# define SENF_PARSER_COLLECTION_TAG__transform(x,y) \ + transform(x, SENF_PARSER_COLLECTION_TAG_RECURS1(y)) +# define SENF_PARSER_COLLECTION_TAG_EXPAND__transform(x,y) \ + senf::detail::auxtag::transform< \ + x, \ + SENF_CAT_RECURS1(SENF_PARSER_COLLECTION_TAG_EXPAND__, y)> +# define SENF_PARSER_COLLECTION_TAG_GETAUX__transform(x,y) \ + SENF_PARSER_COLLECTION_TAG_GETAUX_RECURS1(y) +# +# define SENF_PARSER_COLLECTION_TAG_EXPAND__none() senf::detail::auxtag::none +# +# define SENF_PARSER_COLLECTION_TAG_RECURS1(aux) \ + BOOST_PP_IF( \ + SENF_PARSER_COLLECTION_HAS_KEYWORD(aux), \ + BOOST_PP_CAT(SENF_PARSER_COLLECTION_TAG__, aux), \ + none() ) +# +# define SENF_PARSER_COLLECTION_TAG_GETAUX_RECURS1(aux) \ + BOOST_PP_IF( \ + SENF_PARSER_COLLECTION_HAS_KEYWORD(aux), \ + BOOST_PP_CAT(SENF_PARSER_COLLECTION_TAG_GETAUX__, aux), \ + aux) # # define SENF_PARSER_COLLECTION_HAS_KEYWORD(x) \ - BOOST_PP_IS_EMPTY( BOOST_PP_CAT(SENF_PARSER_COLLECTION_TAG_GOBBLE__, x) ) + BOOST_PP_IS_EMPTY( SENF_CAT_RECURS1(SENF_PARSER_COLLECTION_TAG_GOBBLE__, x) ) # +# define SENF_PARSER_COLLECTION_GETAUX(aux) \ + BOOST_PP_IF( SENF_PARSER_COLLECTION_HAS_KEYWORD(aux), \ + SENF_CAT_RECURS2(SENF_PARSER_COLLECTION_TAG_GETAUX__, aux), \ + aux ) + # define SENF_PARSER_COLLECTION_I(access, name, aux, traits) \ BOOST_PP_EXPAND( \ SENF_PARSER_COLLECTION_II \ @@ -465,13 +506,13 @@ SENF_PARSER_COLLECTION_HAS_KEYWORD(aux), \ ( access, \ name, \ - BOOST_PP_CAT(SENF_PARSER_COLLECTION_TAG_GETAUX__, aux), \ - BOOST_PP_CAT(SENF_PARSER_COLLECTION_TAG__, aux), \ + SENF_CAT_RECURS2(SENF_PARSER_COLLECTION_TAG_GETAUX__, aux), \ + SENF_CAT_RECURS2(SENF_PARSER_COLLECTION_TAG__, aux), \ traits ), \ ( access, \ name, \ aux, \ - senf::detail::auxtag::none, \ + none(), \ traits ) )) # # define SENF_PARSER_COLLECTION_II(access, name, aux, tag, traits) \ @@ -481,7 +522,7 @@ BOOST_PP_CAT(name,_aux_policy); \ typedef traits::parser< \ BOOST_PP_CAT(name,_aux_policy), \ - tag \ + BOOST_PP_CAT(SENF_PARSER_COLLECTION_TAG_EXPAND__, tag) \ >::type BOOST_PP_CAT(name, _collection_t); \ access: \ SENF_PARSER_FIELD_SETUP_I( name, \ @@ -498,6 +539,8 @@ # # define SENF_PARSER_COLLECTION_AUXTYPE_fix(name, aux) # +# ifndef DOXYGEN +# namespace senf { namespace detail { template struct DynamicAuxParserPolicy; template struct FixedAuxParserPolicy; @@ -509,6 +552,8 @@ { typedef senf::detail::FixedAuxParserPolicy type; }; }}; # +# endif +# # define SENF_PARSER_COLLECTION_AUX_I_var(name, aux) \ senf::detail::ParserAuxPolicySelect< BOOST_PP_CAT(aux, _t), \ SENF_PARSER_CURRENT_FIXED_OFFSET() \