112 lines
3.6 KiB
C++
112 lines
3.6 KiB
C++
// This file is distributed under the BSD License.
|
|
// See LICENSE.TXT for details.
|
|
|
|
#ifndef LANGKIT_PARSER_HPP_
|
|
#define LANGKIT_PARSER_HPP_
|
|
|
|
#include <boost/function.hpp>
|
|
|
|
#include "langkit_lexer.hpp"
|
|
|
|
struct RuleImpl;
|
|
|
|
typedef std::vector<TokenPtr>::iterator Token_Iterator;
|
|
typedef boost::function<std::pair<Token_Iterator, bool>(Token_Iterator, Token_Iterator, TokenPtr, bool, int)> RuleFun;
|
|
typedef std::tr1::shared_ptr<RuleImpl> RuleImplPtr;
|
|
|
|
struct RuleImpl {
|
|
RuleFun rule;
|
|
bool keep;
|
|
int new_id;
|
|
|
|
RuleImpl() : keep(true), new_id(-1) {}
|
|
RuleImpl(int id) : keep(true), new_id(id) {}
|
|
RuleImpl(RuleFun fun) : rule(fun), keep(true), new_id(-1) {}
|
|
RuleImpl(RuleFun fun, bool keep_match) : rule(fun), keep(keep_match), new_id(-1) {}
|
|
|
|
std::pair<Token_Iterator, bool> operator()(Token_Iterator iter, Token_Iterator end, TokenPtr parent) {
|
|
return rule(iter, end, parent, keep, new_id);
|
|
}
|
|
};
|
|
|
|
std::pair<Token_Iterator, bool> String_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, const std::string &val);
|
|
|
|
std::pair<Token_Iterator, bool> Type_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, const int val);
|
|
|
|
std::pair<Token_Iterator, bool> Or_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, struct Rule lhs, struct Rule rhs);
|
|
|
|
std::pair<Token_Iterator, bool> And_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, struct Rule lhs, struct Rule rhs);
|
|
|
|
std::pair<Token_Iterator, bool> Kleene_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, struct Rule rule);
|
|
|
|
std::pair<Token_Iterator, bool> Plus_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, struct Rule rule);
|
|
|
|
std::pair<Token_Iterator, bool> Optional_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, struct Rule rule);
|
|
|
|
std::pair<Token_Iterator, bool> Epsilon_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, struct Rule rule);
|
|
|
|
std::pair<Token_Iterator, bool> Wrap_Rule
|
|
(Token_Iterator iter, Token_Iterator end, TokenPtr parent, bool keep, int new_id, struct Rule rule);
|
|
|
|
struct Rule {
|
|
RuleImplPtr impl;
|
|
|
|
Rule() : impl(new RuleImpl()) {}
|
|
Rule(int id) : impl(new RuleImpl(id)) {}
|
|
Rule(RuleFun fun) : impl(new RuleImpl(fun)) {}
|
|
Rule(RuleFun fun, bool keep) : impl(new RuleImpl(fun, keep)) {}
|
|
|
|
std::pair<Token_Iterator, bool> operator()(Token_Iterator iter, Token_Iterator end, TokenPtr parent) {
|
|
return (*impl)(iter, end, parent);
|
|
}
|
|
|
|
Rule &operator=(const Rule &rule) {
|
|
int prev_id = impl->new_id;
|
|
*impl = *(rule.impl);
|
|
impl->new_id = prev_id;
|
|
|
|
return *this;
|
|
}
|
|
|
|
Rule operator|(const Rule &rhs) {
|
|
return Rule(boost::bind(Or_Rule, _1, _2, _3, _4, _5, *this, rhs));
|
|
}
|
|
|
|
Rule operator>>(const Rule &rhs) {
|
|
return Rule(boost::bind(And_Rule, _1, _2, _3, _4, _5, *this, rhs));
|
|
}
|
|
|
|
Rule operator*() {
|
|
return Rule(boost::bind(Kleene_Rule, _1, _2, _3, _4, _5, *this));
|
|
}
|
|
|
|
Rule operator+() {
|
|
return Rule(boost::bind(Plus_Rule, _1, _2, _3, _4, _5, *this));
|
|
}
|
|
|
|
Rule operator~() {
|
|
return Rule(boost::bind(Optional_Rule, _1, _2, _3, _4, _5, *this));
|
|
}
|
|
};
|
|
|
|
|
|
Rule Str(const std::string &text, bool keep);
|
|
Rule Id(int id, bool keep);
|
|
|
|
Rule Str(const std::string &text);
|
|
Rule Id(int id);
|
|
|
|
Rule Ign(Rule rule);
|
|
Rule Epsilon(Rule rule);
|
|
Rule Wrap(Rule rule);
|
|
|
|
#endif /* LANGKIT_PARSER_HPP_ */
|