/* File: lalr1_dp2.h Date and Time: Mon Oct 13 18:18:14 2014 */ #ifndef __lalr1_dp2_h__ #define __lalr1_dp2_h__ 1 #include "yacco2.h" #include "yacco2_T_enumeration.h" #include "yacco2_k_symbols.h" #include "yacco2_err_symbols.h" #include "yacco2_terminals.h" #include "yacco2_characters.h" // monolithic grammar: no thread extern yacco2::State S1_Clalr1_dp2; namespace NS_lalr1_dp2 { using namespace NS_yacco2_T_enum;// enumerate using namespace yacco2; struct fsm_rules_reuse_table_type{ fsm_rules_reuse_table_type(); int no_rules_entries_; Per_rule_s_reuse_table* per_rule_s_table_[6]; }; class Clalr1_dp2: public yacco2::CAbs_fsm { public: enum rules_and_subrules{ start_of_rule_list = NS_yacco2_T_enum::T_Enum::sum_total_T ,R_Rlalr1_dp2_ = 569//start_of_rule_list + 0 ,rhs1_Rlalr1_dp2_ = 1 ,R_RS1_ = 570//start_of_rule_list + 2 ,rhs1_RS1_ = 2 ,rhs2_RS1_ = 3 ,rhs3_RS1_ = 4 ,R_RB_ = 571//start_of_rule_list + 4 ,rhs1_RB_ = 5 ,R_RC_ = 572//start_of_rule_list + 6 ,rhs1_RC_ = 6 ,R_RD_ = 573//start_of_rule_list + 8 ,rhs1_RD_ = 7 ,R_RE_ = 574//start_of_rule_list + 10 ,rhs1_RE_ = 8 }; //no of la sets = 4 //no of states = 13 Clalr1_dp2(); ~Clalr1_dp2(); void op(); bool failed(); void reduce_rhs_of_rule (yacco2::UINT Sub_rule_no,yacco2::Rule_s_reuse_entry** Recycled_rule); fsm_rules_reuse_table_type fsm_rules_reuse_table; static int rhs_to_rules_mapping_[9]; }; struct Rlalr1_dp2; struct RS1; struct RB; struct RC; struct RD; struct RE; struct Rlalr1_dp2:public yacco2::CAbs_lr1_sym { Rlalr1_dp2(yacco2::Parser* P); public: }; struct RS1:public yacco2::CAbs_lr1_sym { RS1(yacco2::Parser* P); public: }; struct RB:public yacco2::CAbs_lr1_sym { RB(yacco2::Parser* P); public: }; struct RC:public yacco2::CAbs_lr1_sym { RC(yacco2::Parser* P); public: }; struct RD:public yacco2::CAbs_lr1_sym { RD(yacco2::Parser* P); public: }; struct RE:public yacco2::CAbs_lr1_sym { RE(yacco2::Parser* P); public: }; } // end of namespace #endif