#ifndef SPROUT_WEED_PARSER_DIRECTIVE_AS_TUPLE_HPP #define SPROUT_WEED_PARSER_DIRECTIVE_AS_TUPLE_HPP #include #include #include #include #include #include #include #include #include #include namespace sprout { namespace weed { // // as_tuple_p // template struct as_tuple_p : public sprout::weed::parser_base { public: template struct attribute { private: typedef typename sprout::weed::traits::attribute_of::type attr_type; private: static_assert(!sprout::weed::traits::is_unused::value, "invalid attribute : unused"); public: typedef sprout::tuples::tuple type; }; template struct result { public: typedef sprout::weed::parser_result::type> type; }; private: typedef typename sprout::weed::traits::terminal_or_expr_of::type expr_type; private: expr_type expr_; private: template SPROUT_CONSTEXPR typename result::type call( Iterator first, Result const& res ) const { typedef typename result::type result_type; typedef typename attribute::type attribute_type; return res.success() ? result_type(true, res.current(), attribute_type(res.attr())) : result_type(false, first, attribute_type()) ; } public: as_tuple_p() = default; SPROUT_CONSTEXPR explicit as_tuple_p( Parser const& p ) : expr_(sprout::weed::make_terminal_or_expr(p)) {} template SPROUT_CONSTEXPR typename result::type operator()( Iterator first, Iterator last, Context const& ctx ) const { return call(first, sprout::weed::eval(expr_, ctx)); } }; // // as_tuple_d // struct as_tuple_d { public: template SPROUT_CONSTEXPR sprout::weed::as_tuple_p operator[](Parser const& p) const { return sprout::weed::as_tuple_p(p); } }; // // as_tuple // SPROUT_CONSTEXPR sprout::weed::as_tuple_d as_tuple = sprout::weed::as_tuple_d(); } // namespace weed } // namespace sprout #endif // #ifndef SPROUT_WEED_PARSER_DIRECTIVE_AS_TUPLE_HPP