次を解析したい (最初の列は識別子、2 番目の列 (日付) は識別子ごとに一意であり、その後にフロートのタプルが続く):
Max,2016-02-01,1.0,2.0,3.0
Max,2016-02-02,1.0,2.0,3.0
Rob,2016-02-01,1.0,2.0,3.0
Max,2016-02-03,1.0,2.0,3.0
私の好きな構造は
using ValueType = std::tuple<float, float, float>;
using ValueMap = std::map<std::time_t, ValueType>;
using DataType = std::unordered_map<std::string, ValueMap>;
属性の伝播を伴う有効な文法を作成することは可能ですか (セマンティック アクションおよび/または後でこの構造にコピーする必要はありません) ?
構文解析は次のようになります。
namespace grammar
{
using namespace x3;
auto str2date = [](auto& ctx)
{
int y,m,d;
auto tub = std::tie(y,m,d);
fusion::copy(_attr(ctx), tub);
std::tm t{};
t.tm_year = y - 1900;
t.tm_mon = m - 1;
t.tm_mday = d;
auto time = std::mktime(&t);
_val(ctx) = time;
_pass(ctx) = time > 0;
};
auto date_ = rule<struct date_, std::time_t>{"date"}
= (int_ >> '-' >> int_ >> int_)[str2date];
auto values_= rule<struct values_, ValueType>{"values"}
= float_ >> ',' >> float_ >> ',' >> float_;
auto line_ = rule<struct line_, std::pair<std::time_t, ValueType>>{"line"}
= date_ >> ',' >> values_;
auto start_ = rule<struct start_, DataType>{"start"}
= (+~char_(',') >> ',' >> line_) % eol >> (eol | eoi);
};