/* File: fsm_phrase.cpp Date and Time: Fri Jan 30 18:55:12 2015 */ #include "fsm_phrase.h" using namespace NS_yacco2_T_enum;// enumerate using namespace NS_yacco2_err_symbols;// error symbols using namespace NS_yacco2_k_symbols;// lrk using namespace NS_yacco2_terminals;// terminals using namespace NS_yacco2_characters;// rc using namespace yacco2;// yacco2 library using namespace NS_fsm_phrase;// grammar's ns // first set terminals fsm_rules_reuse_table_type::fsm_rules_reuse_table_type(){ no_rules_entries_ = 2; per_rule_s_table_[0] = new Per_rule_s_reuse_table(); per_rule_s_table_[1] = new Per_rule_s_reuse_table(); } Cfsm_phrase:: Cfsm_phrase() :yacco2::CAbs_fsm ("fsm_phrase.lex" ,"1.0" ,"4 mar 2004" ,false ,"Dispatcher to parse ``fsm'' construct." ,"Fri Jan 30 18:55:12 2015 " ,S1_Cfsm_phrase){ } Cfsm_phrase::~Cfsm_phrase(){ for(int x = 0;x < 2;++x){ ///delete fsm_rules_reuse_table.per_rule_s_table_[x]; } } bool Cfsm_phrase::failed(){ return false; } void Cfsm_phrase::op(){ cweb_marker__ = 0; } int Cfsm_phrase::rhs_to_rules_mapping_[5] = { -1 ,0 // subrule 1 for rule 1 ,1 // subrule 2 for rule 2 ,1 // subrule 3 for rule 2 ,1 // subrule 4 for rule 2 }; Rfsm_phrase::Rfsm_phrase(yacco2::Parser* P) :CAbs_lr1_sym ("Rfsm_phrase",0,Cfsm_phrase::R_Rfsm_phrase_,P,false,false){ } Rphrase::Rphrase(yacco2::Parser* P) :CAbs_lr1_sym ("Rphrase",0,Cfsm_phrase::R_Rphrase_,P,false,false){ } void Rphrase::sr1(){ struct SF{ LR1_parallel_operator* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; T_fsm_phrase* p2__; State* s2__; bool abort2__; Rule_s_reuse_entry* rule_s_reuse_entry2__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(2); ADD_TOKEN_TO_PRODUCER_QUEUE(*sf->p2__); } void Rphrase::sr2(){ struct SF{ LR1_parallel_operator* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; CAbs_lr1_sym* p2__; State* s2__; bool abort2__; Rule_s_reuse_entry* rule_s_reuse_entry2__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(2); ADD_TOKEN_TO_ERROR_QUEUE(*sf->p2__); } void Rphrase::sr3(){ CAbs_lr1_sym* sym = new Err_no_open_parenthesis; sym->set_rc(*rule_info__.parser__->current_token(),__FILE__,__LINE__); ADD_TOKEN_TO_ERROR_QUEUE(*sym); }