カルマ文法のポインターのベクトルにアクセスしようとしていますが、ほとんど成功していません。ポインタタイプはコピーできないため、それを使用するルールは参照を取得する必要があります。
#include <boost/spirit/include/karma.hpp>
#include <boost/fusion/adapted/struct/adapt_struct.hpp>
#include <boost/fusion/include/adapt_struct.hpp>
namespace karma = boost::spirit::karma;
namespace fusion = boost::fusion;
namespace phx = boost::phoenix;
struct test1 : boost::noncopyable {
test1(int i = 0) : value(i) {}
int value;
};
struct test2 : boost::noncopyable {
int value;
std::vector<test1*> vector;
};
BOOST_FUSION_ADAPT_STRUCT( test1, (int, value) );
BOOST_FUSION_ADAPT_STRUCT( test2, (int, value) (std::vector<test1*>, vector) );
typedef std::ostream_iterator<char> Iterator;
int main() {
karma::rule<Iterator, test1*()> t1r;
karma::rule<Iterator, test2&()> t2r;
t2r %= "test 2 rule:" << karma::int_ << karma::eol << (t1r % karma::eol);
t1r %= "test 1 rule: " << karma::int_;
std::stringstream stream;
std::ostream_iterator<char> out(stream);
test2 t;
t.vector.push_back(new test1(2));
t.vector.push_back(new test1(3));
t.vector.push_back(new test1(4));
t.vector.push_back(new test1(5));
t.value = 1;
karma::generate(out, t2r, t);
std::cout<<stream.str()<<std::endl;
}
これはコンパイルされますが、次を返します:テスト2ルール:1、テスト1ルール:25104656、テスト1ルール:25104720など。この単純なケースで私ができることを私は知っています
t1r = "test 1 rule: " << karma::int_[karma::_1 = phx::bind(&test1::value, *karma::_val)];
それを解決するために、しかし実際には値は文法に渡されるはずの別のコピー不可能なタイプであり、したがって私は例で行われたように構造体適応を使用する必要があります。
ここで説明したように、custimisation point deref_iteratorも知っていますが、私はテンプレートライブラリで作業しており、テンプレートに依存するタイプでderef_iteratorを特殊化することはできないと思います。
例を機能させる方法について何かアイデアはありますか?