blob: 8d16b53d4056fba3cbae8d4b905ee52b40e4e139 [file] [log] [blame]
/*=============================================================================
Copyright (c) 2010-2011 Daniel James
Use, modification and distribution is subject to 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_QUICKBOOK_VALUES_PARSE_HPP)
#define BOOST_SPIRIT_QUICKBOOK_VALUES_PARSE_HPP
#include "values.hpp"
#include "parsers.hpp"
#include "scoped.hpp"
#include <boost/spirit/include/phoenix1_functions.hpp>
#include <iostream>
namespace quickbook {
namespace ph = phoenix;
struct value_builder_save : scoped_action_base
{
value_builder_save(value_builder& builder) : builder(builder) {}
bool start()
{
builder.save();
return true;
}
void cleanup() { builder.restore(); }
value_builder& builder;
};
struct value_builder_list : scoped_action_base
{
value_builder_list(value_builder& builder) : builder(builder) {}
bool start(value::tag_type tag = value::default_tag)
{
builder.start_list(tag);
return true;
}
void success(parse_iterator, parse_iterator) { builder.finish_list(); }
void failure() { builder.clear_list(); }
value_builder& builder;
};
struct value_entry
{
template <typename Arg1, typename Arg2 = void, typename Arg3 = void, typename Arg4 = void>
struct result {
typedef void type;
};
value_entry(value_builder& b, file_ptr* current_file)
: b(b), current_file(current_file) {}
void operator()(parse_iterator begin, parse_iterator end,
value::tag_type tag = value::default_tag) const
{
b.insert(qbk_value(*current_file, begin.base(), end.base(), tag));
}
void operator()(int v,
value::tag_type tag = value::default_tag) const
{
b.insert(int_value(v, tag));
}
value_builder& b;
file_ptr* current_file;
};
struct value_sort
{
typedef void result_type;
value_sort(value_builder& b)
: b(b) {}
void operator()() const {
b.sort_list();
}
value_builder& b;
};
struct value_parser
{
value_parser(file_ptr* current_file)
: builder()
, save(builder)
, list(builder)
, entry(value_entry(builder, current_file))
, sort(builder)
{}
value release() { return builder.release(); }
value_builder builder;
scoped_parser<value_builder_save> save;
scoped_parser<value_builder_list> list;
ph::function<value_entry> entry;
ph::function<value_sort> sort;
};
}
#endif