/* File: la_expr_lexical.cpp Date and Time: Fri Jan 30 18:55:13 2015 */ #include "la_expr_lexical.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_la_expr_lexical;// grammar's ns // first set terminals fsm_rules_reuse_table_type::fsm_rules_reuse_table_type(){ no_rules_entries_ = 3; per_rule_s_table_[0] = new Per_rule_s_reuse_table(); per_rule_s_table_[1] = new Per_rule_s_reuse_table(); per_rule_s_table_[2] = new Per_rule_s_reuse_table(); } Cla_expr_lexical:: Cla_expr_lexical() :yacco2::CAbs_fsm ("la_expr_lexical.lex" ,"1.0" ,"24 mar 2004" ,false ,"Lexer: 2nd stage lexing for lookahead: stripper..." ,"Fri Jan 30 18:55:13 2015 " ,S1_Cla_expr_lexical){ } Cla_expr_lexical::~Cla_expr_lexical(){ for(int x = 0;x < 3;++x){ ///delete fsm_rules_reuse_table.per_rule_s_table_[x]; } } bool Cla_expr_lexical::failed(){ return false; } void Cla_expr_lexical::op(){ } int Cla_expr_lexical::rhs_to_rules_mapping_[10] = { -1 ,0 // subrule 1 for rule 1 ,1 // subrule 2 for rule 2 ,1 // subrule 3 for rule 2 ,2 // subrule 4 for rule 3 ,2 // subrule 5 for rule 3 ,2 // subrule 6 for rule 3 ,2 // subrule 7 for rule 3 ,2 // subrule 8 for rule 3 ,2 // subrule 9 for rule 3 }; Rstripper::Rstripper(yacco2::Parser* P) :CAbs_lr1_sym ("Rstripper",0,Cla_expr_lexical::R_Rstripper_,P,false,false){ } void Rstripper::op(){ sstrace_rulesss using namespace NS_yacco2_k_symbols; ADD_TOKEN_TO_PRODUCER_QUEUE(*yacco2::PTR_LR1_eog__); ADD_TOKEN_TO_PRODUCER_QUEUE(*yacco2::PTR_LR1_eog__); } Rtoks::Rtoks(yacco2::Parser* P) :CAbs_lr1_sym ("Rtoks",0,Cla_expr_lexical::R_Rtoks_,P,false,false){ } Rtok::Rtok(yacco2::Parser* P) :CAbs_lr1_sym ("Rtok",0,Cla_expr_lexical::R_Rtok_,P,false,false){ } void Rtok::sr1(){ struct SF{ T_identifier* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(1); using namespace yacco2_stbl; T_sym_tbl_report_card report_card; find_sym_in_stbl(report_card,*sf->p1__->identifier()->c_str()); if(report_card.action_ == T_sym_tbl_report_card::not_fnd){ CAbs_lr1_sym* sym = new Err_bad_term_in_la_expr; sym->set_rc(*sf->p1__,__FILE__,__LINE__); ADD_TOKEN_TO_ERROR_QUEUE(*sym); rule_info__.parser__->set_stop_parse(true); return; } ADD_TOKEN_TO_PRODUCER_QUEUE(*report_card.tbl_entry_->symbol_); } void Rtok::sr2(){ struct SF{ T_c_string* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(1); using namespace yacco2_stbl; T_sym_tbl_report_card report_card; find_sym_in_stbl(report_card,*sf->p1__->c_string()->c_str()); if(report_card.action_ == T_sym_tbl_report_card::not_fnd){ CAbs_lr1_sym* sym = new Err_bad_term_in_la_expr; sym->set_rc(*sf->p1__,__FILE__,__LINE__); ADD_TOKEN_TO_ERROR_QUEUE(*sym); rule_info__.parser__->set_stop_parse(true); return; } ADD_TOKEN_TO_PRODUCER_QUEUE(*report_card.tbl_entry_->symbol_); } void Rtok::sr3(){ struct SF{ T_c_literal* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(1); using namespace yacco2_stbl; T_sym_tbl_report_card report_card; find_sym_in_stbl(report_card,*sf->p1__->c_literal()->c_str()); if(report_card.action_ == T_sym_tbl_report_card::not_fnd){ CAbs_lr1_sym* sym = new Err_bad_term_in_la_expr; sym->set_rc(*sf->p1__,__FILE__,__LINE__); ADD_TOKEN_TO_ERROR_QUEUE(*sym); rule_info__.parser__->set_stop_parse(true); return; } ADD_TOKEN_TO_PRODUCER_QUEUE(*report_card.tbl_entry_->symbol_); } void Rtok::sr4(){ struct SF{ raw_plus* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(1); ADD_TOKEN_TO_PRODUCER_QUEUE(*sf->p1__); } void Rtok::sr5(){ struct SF{ raw_minus* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(1); ADD_TOKEN_TO_PRODUCER_QUEUE(*sf->p1__); } void Rtok::sr6(){ struct SF{ CAbs_lr1_sym* p1__; State* s1__; bool abort1__; Rule_s_reuse_entry* rule_s_reuse_entry1__; }; SF* sf = (SF*)rule_info__.parser__->parse_stack__.sf_by_top(1); ADD_TOKEN_TO_PRODUCER_QUEUE(*sf->p1__); }