私は次の問題に直面しています:私はboost::variantのために何人かの訪問者を持っています。
void operator()(const foo& ast)
{
//allways the same
}
すべての訪問者で常に同じです。この冗長なメソッドをすべての訪問者に記述したくないので、このメソッドを実装する共通の基本クラスをすべての訪問者に追加することを避けようとしました。次のように、メソッドがビジター自体を再帰的に呼び出す問題:
void operator(const foo& ast)
{
for(auto&& item : ast.members)
{
boost::apply_visitor(*this, item);
}
}
メンバーに一致する他のすべてのメソッドが基本クラスに実装されていないため、これでコンパイラ エラーが発生します。私の質問は、冗長なコードを削除するにはどうすればよいですか?
問題がどのように見えるかの例を次に示します。
struct variant_one;
struct variant_two;
struct nil{};
typedef boost::variant<
boost::spirit::x3::forward_ast<variant_one>,
boost::spirit::x3::forward_ast<variant_two>,
nil
> example_variant;
struct variant_one {};
struct variant_two
{
std::vector<example_variant> members;
};
struct visitor_one : boost::static_visitor<void>
{
void operator()(const variant_one& ast)
{
std::cout << "visitor_one detected var_one" << std::endl;
}
//this is the redundant method
void operator()(const variant_two& ast)
{
std::cout << "visitor detected var_two, output members:" <<std::endl;
for(auto&& member : ast.members)
{
boost::apply_visitor(*this, member);
}
}
}
struct visitor_two : boost::static_visitor<void>
{
void operator()(const variant_one& ast)
{
std::cout << "visitor_one detected var_two" << std::endl;
}
//this is the redundant method
void operator()(const variant_two& ast)
{
std::cout << "visitor detected var_two, output members:" <<std::endl;
for(auto&& member : ast.members)
{
boost::apply_visitor(*this, member);
}
}
}