2

与えられた:

typedef boost::mpl::vector<Type1, Type2, Type3> types;
const size_t numTypes = boost::mpl::size<types>::value;
std::array<std::function<bool(const obj&, const obj&)>, numTypes*numTypes> arr;

私はコンパイル時にこの種の機能を取得しようとしています:

for( size_t i = 0; i < numTypes; ++i )
{
    for( size_t j = 0; j < numTypes; ++j )
    {
        arr[i*numTypes+j] = ObjPair<boost::mpl::at_c<vecType, i>::type, boost::mpl::at_c<vecType, j>::type>::Foo;
    }
}

私はそれが次のようになると思います:

std::array<std::function<bool(const obj&, const obj&)>, numTypes*numTypes> arr = { BOOST_PP_FOR((0, numTypes), PRED, OP, MACRO) };

しかし、私はそれを機能させることができません (BOOST_PP_FOR を使用して完全に失敗した試みを投稿しませんでした)。

ObjPair<T1, T2>::Foo署名の静的メソッドですbool(const obj&, const obj&)。さまざまな obj タイプに特化しています。

この配列を使用して、オブジェクトのペアが与えられた特定の関数を見つけます。オブジェクトは基本クラスとして保持され、基本クラスで使用可能な ID に基づいてインデックスを決定するために、いくつかの数学で配列にインデックスを付けることができます。

4

1 に答える 1

2

PP がboost::mpl::vectorサイズを超えて反復することはできません。ただし、それを定義してみることができます。

typedef boost::mpl::vector<bool, short, long> vecType;
#define numTypes 3

私は TR1 を持っていないので、ブースト アレイを試します。

typedef  boost::function<bool(const obj&, const obj&)> Function;
typedef boost::array<Function, numTypes*numTypes> FooArray;

#define OBJPAIR_FOO_ARRAY(z, n, text)  BOOST_PP_COMMA_IF(n) &ObjPair<      \
boost::mpl::at_c<vecType, n/numTypes>::type,  \
boost::mpl::at_c<vecType, n%numTypes>::type   \
    >::Foo

FooArray fooArray= {
    BOOST_PP_REPEAT( BOOST_PP_MUL(numTypes, numTypes) , OBJPAIR_FOO_ARRAY, )
};
于 2012-04-19T00:11:02.370 に答える