28#include "../common/AutomatonFromXMLParser.h"
29#include "../common/AutomatonToXMLComposer.h"
33template <
class InputSymbolType,
class PushdownStoreSymbolType,
class StateType >
34struct xmlApi <
automaton::VisiblyPushdownDPDA < InputSymbolType, PushdownStoreSymbolType, StateType > > {
43 return "VisiblyPushdownDPDA";
91template <
class InputSymbolType,
class PushdownStoreSymbolType,
class StateType >
95 ext::set<StateType> states = automaton::AutomatonFromXMLParser::parseStates<StateType>(input);
96 ext::set<InputSymbolType> callAlphabet = automaton::AutomatonFromXMLParser::parseCallInputAlphabet<InputSymbolType>(input);
97 ext::set<InputSymbolType> returnAlphabet = automaton::AutomatonFromXMLParser::parseReturnInputAlphabet<InputSymbolType>(input);
98 ext::set<InputSymbolType> localAlphabet = automaton::AutomatonFromXMLParser::parseLocalInputAlphabet<InputSymbolType>(input);
100 StateType initialState = automaton::AutomatonFromXMLParser::parseInitialState<StateType>(input);
101 PushdownStoreSymbolType bottomOfTheStackSymbol = automaton::AutomatonFromXMLParser::parseBottomOfTheStackSymbol<PushdownStoreSymbolType>(input);
102 ext::set<StateType> finalStates = automaton::AutomatonFromXMLParser::parseFinalStates<StateType>(input);
106 automaton.setCallInputAlphabet(std::move(callAlphabet));
107 automaton.setReturnInputAlphabet(std::move(returnAlphabet));
108 automaton.setLocalInputAlphabet(std::move(localAlphabet));
109 automaton.setPushdownStoreAlphabet(std::move(stackSymbols));
110 automaton.setFinalStates(std::move(finalStates));
118template <
class InputSymbolType,
class PushdownStoreSymbolType,
class StateType >
122 StateType from = automaton::AutomatonFromXMLParser::parseTransitionFrom<StateType>(input);
123 InputSymbolType inputSymbol = automaton::AutomatonFromXMLParser::parseTransitionInputSymbol<InputSymbolType>(input);
124 StateType to = automaton::AutomatonFromXMLParser::parseTransitionTo<StateType>(input);
125 PushdownStoreSymbolType push = automaton::AutomatonFromXMLParser::parseTransitionSinglePush<PushdownStoreSymbolType>(input);
127 automaton.addCallTransition(std::move(from), std::move(inputSymbol), std::move(to), std::move(push));
131 StateType from = automaton::AutomatonFromXMLParser::parseTransitionFrom<StateType>(input);
132 InputSymbolType inputSymbol = automaton::AutomatonFromXMLParser::parseTransitionInputSymbol<InputSymbolType>(input);
133 PushdownStoreSymbolType pop = automaton::AutomatonFromXMLParser::parseTransitionSinglePop<PushdownStoreSymbolType>(input);
134 StateType to = automaton::AutomatonFromXMLParser::parseTransitionTo<StateType>(input);
136 automaton.addReturnTransition(std::move(from), std::move(inputSymbol), std::move(pop), std::move(to));
140 StateType from = automaton::AutomatonFromXMLParser::parseTransitionFrom<StateType>(input);
141 InputSymbolType inputSymbol = automaton::AutomatonFromXMLParser::parseTransitionInputSymbol<InputSymbolType>(input);
142 StateType to = automaton::AutomatonFromXMLParser::parseTransitionTo<StateType>(input);
144 automaton.addLocalTransition(std::move(from), std::move(inputSymbol), std::move(to));
149template <
class InputSymbolType,
class PushdownStoreSymbolType,
class StateType >
166template <
class InputSymbolType,
class PushdownStoreSymbolType,
class StateType >
169 for(
const auto& transition :
automaton.getCallTransitions()) {
179 for(
const auto& transition :
automaton.getReturnTransitions()) {
189 for(
const auto& transition :
automaton.getLocalTransitions()) {
static void parseTransitions(ext::deque< sax::Token >::iterator &input, T &automaton)
Definition: AutomatonFromXMLParser.h:114
static void composeLocalInputAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:136
static void composeTransitionTo(ext::deque< sax::Token > &, const StateType &state)
Definition: AutomatonToXMLComposer.h:252
static void composeStates(ext::deque< sax::Token > &, const ext::set< StateType > &states)
Definition: AutomatonToXMLComposer.h:100
static void composeTransitionFrom(ext::deque< sax::Token > &, const StateType &state)
Definition: AutomatonToXMLComposer.h:259
static void composeTransitionSinglePush(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:309
static void composeReturnInputAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:127
static void composeTransitionSinglePop(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:293
static void composeFinalStates(ext::deque< sax::Token > &, const ext::set< StateType > &states)
Definition: AutomatonToXMLComposer.h:170
static void composeBottomOfTheStackSymbol(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:229
static void composeTransitionInputSymbol(ext::deque< sax::Token > &, const SymbolType &symbol)
Definition: AutomatonToXMLComposer.h:316
static void composeInitialState(ext::deque< sax::Token > &, const StateType &state)
Definition: AutomatonToXMLComposer.h:163
static void composePushdownStoreAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:179
static void composeCallInputAlphabet(ext::deque< sax::Token > &, const ext::set< SymbolType > &symbols)
Definition: AutomatonToXMLComposer.h:118
Deterministic visibly pushdown automaton. Accepts subset of context free languages.
Definition: VisiblyPushdownDPDA.h:86
Class extending the deque class from the standard library. Original reason is to allow printing of th...
Definition: deque.hpp:44
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
typename T::StateType StateType
Definition: ToGrammarLeftRG.h:64
Definition: ToGrammar.h:31
Definition: normalize.hpp:10
Definition: xmlApi.hpp:27