EVOLUTION-MANAGER
Edit File: annotate_on_success.hpp
/*============================================================================= Copyright (c) 2001-2015 Joel de Guzman Distributed under the Boost Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt) =============================================================================*/ #if !defined(BOOST_SPIRIT_X3__ANNOTATE_ON_SUCCESS_HPP) #define BOOST_SPIRIT_X3__ANNOTATE_ON_SUCCESS_HPP #include <boost/spirit/home/x3/support/ast/variant.hpp> #include <boost/spirit/home/x3/support/context.hpp> #include <boost/spirit/home/x3/support/utility/error_reporting.hpp> #include <boost/spirit/home/x3/support/utility/lambda_visitor.hpp> namespace boost { namespace spirit { namespace x3 { /////////////////////////////////////////////////////////////////////////// // The on_success handler tags the AST with the iterator position // for error handling. // // The on_success handler also ties the AST to a vector of iterator // positions for the purpose of subsequent semantic error handling // when the program is being compiled. See x3::position_cache in // x3/support/ast. // // We'll ask the X3's error_handler utility to do these. /////////////////////////////////////////////////////////////////////////// struct annotate_on_success { template <typename Iterator, typename Context, typename... Types> inline void on_success(Iterator const& first, Iterator const& last , variant<Types...>& ast, Context const& context) { ast.apply_visitor(x3::make_lambda_visitor<void>([&](auto& node) { this->on_success(first, last, node, context); })); } template <typename T, typename Iterator, typename Context> inline void on_success(Iterator const& first, Iterator const& last , T& ast, Context const& context) { auto& error_handler = get<error_handler_tag>(context).get(); error_handler.tag(ast, first, last); } }; }}} #endif