子メソッド内でクラスの可変個引数テンプレート型リストを次のように拡張しようとしています:
template<typename... P>
struct Foo
{
template<P...> // error C3522: 'P' : parameter
// pack cannot be expanded in this context
static void Bar(P... a){}
};
このコードの何が問題なのですか?それとも単に MSVS '12: Nov. '12 CTP のバグですか?
(はい、この例の明示的なテンプレートの特殊化が冗長であることはわかっています。)
上記は、エラーを再現できる最も単純なケースです。完全なコードは次のとおりです。
template<typename FuncSignature>
class Callback;
template<typename R, typename... P>
class Callback<R (P...)>
{
public:
Callback() : func(0), obj(0) {}
Callback& operator=(const Callback& rhs)
{ obj = rhs.obj; func = rhs.func; return *this; }
private:
typedef R (*FuncType)(const void*, P...);
Callback(FuncType f, const void* o) : func(f), obj(o) {}
private:
FuncType func;
const void* obj;
template<typename FR, typename... FP>
friend class FreeCallbackFactory;
};
template<typename R, typename... P>
class FreeCallbackFactory
{
private:
template<R (*Func)(P...)>
static R Wrapper(const void*, P... a)
{
return (*Func)(a...);
}
public:
template<R (*Func)(P...)>
inline static Callback<R (P...)> Bind()
{
return Callback<R (P...)>
(&FreeCallbackFactory::Wrapper<Func>, 0);
}
};
template<typename R, typename... P>
inline FreeCallbackFactory<R, P...>
GetCallbackFactory(R (*)(P...))
{
return FreeCallbackFactory<R, P...>();
}
void Test(){}
int main(int argc, char** argv){
Callback<void ()> cb = GetCallbackFactory(&Test).Bind<&Test>()
}
g ++で正常にコンパイルされるため、コンパイラのバグのみを想定しており、継続的な調査結果はまだこれを指しているだけです.1つずつ明示的に展開する以外に、これに対する回避策はありますか?
編集: これはコンパイラ チームにバグとして報告されており、パッチはコンパイラの次のリリースに含まれる予定です。[リンク]