27#include "../common/GrammarFromXMLParser.h"
28#include "../common/GrammarToXMLComposer.h"
34template <
class TerminalSymbolType,
class NonterminalSymbolType >
35struct xmlApi <
grammar::EpsilonFreeCFG < TerminalSymbolType, NonterminalSymbolType > > {
44 return "EpsilonFreeCFG";
92template <
class TerminalSymbolType,
class NonterminalSymbolType >
98 NonterminalSymbolType initialSymbol = grammar::GrammarFromXMLParser::parseInitialSymbol < NonterminalSymbolType > ( input );
102 grammar.setNonterminalAlphabet ( std::move ( nonterminalAlphabet ) );
103 grammar.setTerminalAlphabet ( std::move ( terminalAlphabet ) );
108 grammar.setGeneratesEpsilon ( generatesEpsilon );
114template <
class TerminalSymbolType,
class NonterminalSymbolType >
116 NonterminalSymbolType lhs = grammar::GrammarFromXMLParser::parseRuleSingleSymbolLHS < NonterminalSymbolType > ( input );
119 grammar.addRule ( std::move ( lhs ), std::move ( rhs ) );
122template <
class TerminalSymbolType,
class NonterminalSymbolType >
135template <
class TerminalSymbolType,
class NonterminalSymbolType >
139 for (
const auto & rule :
grammar.getRules ( ) )
141 for (
const auto & rhs : rule.second ) {
Class extending the deque class from the standard library. Original reason is to allow printing of th...
Definition: deque.hpp:44
Class extending the vector class from the standard library. Original reason is to allow printing of t...
Definition: vector.hpp:45
Context free grammar without epsilon rules in Chomsky hierarchy or type 2 in Chomsky hierarchy....
Definition: EpsilonFreeCFG.h:65
static void parseRules(ext::deque< sax::Token >::iterator &input, T &grammar)
Definition: GrammarFromXMLParser.h:157
static bool parseGeneratesEpsilon(ext::deque< sax::Token >::iterator &input)
Definition: GrammarFromXMLParser.h:31
static void composeNonterminalAlphabet(ext::deque< sax::Token > &out, const ext::set< SymbolType > &symbols)
Definition: GrammarToXMLComposer.h:66
static void composeTerminalAlphabet(ext::deque< sax::Token > &out, const ext::set< SymbolType > &symbols)
Definition: GrammarToXMLComposer.h:75
static void composeRuleSingleSymbolLHS(ext::deque< sax::Token > &out, const SymbolType &symbol)
Definition: GrammarToXMLComposer.h:127
static void composeInitialSymbol(ext::deque< sax::Token > &out, const SymbolType &symbol)
Definition: GrammarToXMLComposer.h:84
static void composeGeneratesEpsilon(ext::deque< sax::Token > &out, bool generatesEpsilon)
Definition: GrammarToXMLComposer.h:31
static void composeRuleRHS(ext::deque< sax::Token > &out, const ext::vector< SymbolType > &symbols)
Definition: GrammarToXMLComposer.h:134
static void popToken(ext::deque< Token >::iterator &input, Token::TokenType type, const std::string &data)
Definition: FromXMLParserHelper.cpp:39
static bool isToken(ext::deque< Token >::const_iterator input, Token::TokenType type, const std::string &data)
Definition: FromXMLParserHelper.cpp:29
return grammar
Definition: ToGrammarLeftRG.h:99
Definition: normalize.hpp:10
Definition: ToAutomaton.h:24
static std::string xmlTagName()
The XML tag name of class.
Definition: EpsilonFreeCFG.h:43
static bool first(const ext::deque< sax::Token >::const_iterator &input)
Tests whether the token stream starts with this type.
Definition: EpsilonFreeCFG.h:54
Definition: xmlApi.hpp:27