⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gram.y

📁 C语言前端编译器,yacc/lex编写,可自行修改代码.
💻 Y
📖 第 1 页 / 共 2 页
字号:
%{
#include <stdio.h>
#include <cstring>
#include "ArgPack.h"
#define YYDEBUG 1
#include "lex_yacc.h"

int yylex();
void yyerror(char *s);
int in_braces = 0;
int in_struct = 0;
%}

%token IDENTIFIER 
%token CONSTANT STRING_LITERAL SIZEOF
%token PTR_OP INC_OP DEC_OP LEFT_OP RIGHT_OP LE_OP GE_OP EQ_OP NE_OP
%token AND_OP OR_OP MUL_ASSIGN DIV_ASSIGN MOD_ASSIGN ADD_ASSIGN
%token SUB_ASSIGN LEFT_ASSIGN RIGHT_ASSIGN AND_ASSIGN
%token XOR_ASSIGN OR_ASSIGN

%token TYPE_NAME
%token TYPEDEF EXTERN STATIC AUTO REGISTER
%token CHAR SHORT INT LONG SIGNED UNSIGNED FLOAT DOUBLE CONST VOLATILE VOID
%token STRUCT UNION ENUM ELIPSIS

%token CASE DEFAULT IF ELSE SWITCH WHILE DO FOR GOTO CONTINUE BREAK RETURN

%start file
%%

file
	: external_definition { yypopulate_tree("file", 1); }
	| file external_definition { yypopulate_tree("file", 2); }
	;

external_definition
	: function_definition { yypopulate_tree("external_definition", 1); }
	| declaration { yypopulate_tree("external_definition", 1); }
	;

function_definition
	: declarator function_body { yypopulate_tree("function_definition", 2); }
	| declaration_specifiers declarator function_body {
			yypopulate_tree("function_definition", 3);
		}
	;

function_body
	: compound_statement { yypopulate_tree("function_body", 1); }
	| declaration_list compound_statement { yypopulate_tree("function_body", 2); }
	;

argument_expr_list
	: assignment_expr { yypopulate_tree("argument_expr_list", 1); }
	| argument_expr_list comma assignment_expr { yypopulate_tree("argument_expr_list", 3); }
	;

expr
	: assignment_expr { yypopulate_tree("expr", 1); }
	| expr comma assignment_expr { yypopulate_tree("expr", 3); }
	;

declaration
	: declaration_specifiers semi { yypopulate_tree("declaration", 2); }
	| declaration_specifiers init_declarator_list semi { yypopulate_tree("declaration", 3); }
	;

declaration_specifiers
	: storage_class_specifier { yypopulate_tree("declaration_specifiers", 1); }
	| storage_class_specifier declaration_specifiers { yypopulate_tree("declaration_specifiers", 2); }
	| type_specifier_list { yypopulate_tree("declaration_specifiers", 1); }
	;

init_declarator_list
	: init_declarator { yypopulate_tree("init_declarator_list", 1); }
	| init_declarator_list comma init_declarator { yypopulate_tree("init_declarator_list", 3); }
	;

init_declarator
	: declarator { yypopulate_tree("init_declarator", 1); }
	| declarator equal initializer { yypopulate_tree("init_declarator", 3); }
	;

storage_class_specifier
	: TYPEDEF 		{ yytypedef_flag = 1;  yypopulate_tree("typedef", 0); }
	| EXTERN 		{ yypopulate_tree("extern", 0); }
	| STATIC 		{ yypopulate_tree("static", 0); }
	;

type_specifier
	: CHAR   		{ yypopulate_tree("char", 0); }
	| SHORT  		{ yypopulate_tree("short", 0); }
	| INT  		{ yypopulate_tree("int", 0); }
	| LONG 		{ yypopulate_tree("long", 0); }
	| REGISTER 		{ yypopulate_tree("register", 0); }
	| SIGNED 		{ yypopulate_tree("signed", 0); }
	| UNSIGNED		{ yypopulate_tree("unsigned", 0); }
	| FLOAT  		{ yypopulate_tree("float", 0); }
	| DOUBLE 		{ yypopulate_tree("double", 0); }
	| CONST  		{ yypopulate_tree("const", 0); }
	| VOLATILE		{ yypopulate_tree("volatile", 0); }
	| VOID  		{ yypopulate_tree("void", 0); }
	| struct_or_union_specifier  { yypopulate_tree("struct_or_union", 1); }
	| enum_specifier  { yypopulate_tree("long", 1); }
	| TYPE_NAME		{ yypopulate_tree(*($1), 0); }
	;

struct_or_union_specifier
	: struct_or_union identifier lbrace struct_declaration_list rbrace   { yypopulate_tree("struct_or_union_specifier", 5); }
	| struct_or_union lbrace struct_declaration_list rbrace  { yypopulate_tree("struct_or_union_specifier", 4); }
	| struct_or_union identifier  { yypopulate_tree("struct_or_union_specifier", 2); }
	;

struct_or_union
	: STRUCT	{ in_struct++;  yypopulate_tree("struct", 0); }
	| UNION 		{ in_struct++; yypopulate_tree("union", 0); }
	;

struct_declaration_list
	: struct_declaration   { yypopulate_tree("struct_declaration_list", 1); }
	| struct_declaration_list struct_declaration   { yypopulate_tree("struct_declaration_list", 2); }
	;

struct_declaration
	: type_specifier_list struct_declarator_list semi   { yypopulate_tree("struct_declaration", 3); }
	;

struct_declarator_list
	: struct_declarator	 { yypopulate_tree("struct_declarator_list", 1); }
	| struct_declarator_list comma struct_declarator { yypopulate_tree("struct_declarator_list", 3); }
	;

struct_declarator
	: declarator	 { yypopulate_tree("struct_declarator", 1); }
	| colon constant_expr	 { yypopulate_tree("struct_declarator", 2); }
	| declarator colon constant_expr	 { yypopulate_tree("struct_declarator", 3); }
	;

enum_specifier
	: enum lbrace enumerator_list rbrace 	 { yypopulate_tree("enum_specifier", 4); }
	| enum identifier lbrace enumerator_list rbrace  { yypopulate_tree("enum_specifier", 5); }
	| enum identifier   { yypopulate_tree("enum_specifier", 1); }
	;

enumerator_list
	: enumerator   { yypopulate_tree("enumerator_list", 1); }
	| enumerator_list comma enumerator  { yypopulate_tree("enumerator_list", 3); }
	;

enumerator
	: identifier  { yypopulate_tree("enumerator", 1); }
	| identifier equal constant_expr   { yypopulate_tree("enumerator", 3); } 
	;

declarator
	: declarator2 { yypopulate_tree("declarator", 1); }
	| pointer declarator2 { yypopulate_tree("declarator", 2); }
	;

declarator2
	: identifier 	{ yypopulate_tree("identifier", 1); }
	| lparen declarator rparen	{ yypopulate_tree("declarator2", 3); }
	| declarator2 lbracket rbracket	{ yypopulate_tree("ARRAY", 3); }
	| declarator2 lbracket constant_expr rbracket		{ yypopulate_tree("array_decl", 4); }
	| declarator2 lparen rparen		{ yypopulate_tree("function", 3); }
	| declarator2 lparen parameter_list rparen		{ yypopulate_tree("function", 4); }
//	| declarator2 lparen parameter_type_list rparen		{ yypopulate_tree("function", 4); }
//	| declarator2 lparen parameter_identifier_list rparen 	{ yypopulate_tree("function", 4); }
	;

pointer
	: star		{ yypopulate_tree("pointer", 1); }
	| star type_specifier_list		{ yypopulate_tree("pointer", 2); } 
	| star pointer		{ yypopulate_tree("pointer", 2); } 
	| star type_specifier_list pointer		{ yypopulate_tree("pointer", 3); }
	;

type_specifier_list
	: type_specifier 		{ yypopulate_tree("type", 1); }
	| type_specifier_list type_specifier 		{ yypopulate_tree("type_specifier_list", 2); }
	;

//parameter_identifier_list
//	: identifier_list		{ yypopulate_tree("parameter_identifier_list", 1); }
//	| identifier_list comma elipsis		{ yypopulate_tree("parameter_identifier_list", 3); }
//	;

//identifier_list
//	: identifier		{ yypopulate_tree("parameter_declaration", 1); }
//	| identifier_list comma identifier 		{ yypopulate_tree("parameter_declaration", 3); }
//	;

//parameter_type_list
//	: parameter_list	{ yypopulate_tree("parameter_type_list", 1); }
//	| parameter_list comma elipsis	{ yypopulate_tree("parameter_type_list", 3); }
//	;

//parameter_list
//	: parameter_declaration	{ yypopulate_tree("parameter_list", 1); }
//	| parameter_list comma parameter_declaration 	{ yypopulate_tree("parameter_list", 3); }
//	;

parameter_list
	: parameter  { yypopulate_tree("parameter_list", 1); }
	| parameter_list comma parameter  { yypopulate_tree("parameter_list", 3); }
	;

parameter
	: parameter_declaration { yypopulate_tree("parameter", 1); }
	| identifier { yypopulate_tree("identifier", 1); }
	| elipsis { yypopulate_tree("parameter", 1); }
	;

parameter_declaration
	: type_specifier_list declarator 	{ yypopulate_tree("parameter_declaration", 2); }
	| type_name 	{ yypopulate_tree("parameter_declaration", 1); }
	;

type_name
	: type_specifier_list { yypopulate_tree("type_name", 1); }
	| type_specifier_list abstract_declarator { yypopulate_tree("type_name", 2); }
	;

abstract_declarator
	: pointer	{ yypopulate_tree("parameter_declarator", 1); }
	| abstract_declarator2	{ yypopulate_tree("parameter_declarator", 1); }
	| pointer abstract_declarator2	{ yypopulate_tree("parameter_declarator", 2); }
	;

abstract_declarator2
	: lparen abstract_declarator rparen		{ yypopulate_tree("abstract_declarator2", 3); }
	| lbracket rbracket			{ yypopulate_tree("abstract_declarator2", 2); }
	| lbracket constant_expr rbracket			{ yypopulate_tree("abstract_declarator2", 3); }
	| abstract_declarator2 lbracket rbracket			{ yypopulate_tree("abstract_declarator2", 3); }
	| abstract_declarator2 lbracket constant_expr rbracket			{ yypopulate_tree("abstract_declarator2", 4); }
	| lparen rparen			{ yypopulate_tree("abstract_declarator2", 2); }
///	| lparen parameter_list rparen			{ yypopulate_tree("abstract_declarator2", 3); }
//	| lparen parameter_type_list rparen			{ yypopulate_tree("abstract_declarator2", 3); }
	| abstract_declarator2 lparen rparen			{ yypopulate_tree("abstract_declarator2", 3); }
///	| abstract_declarator2 lparen parameter_list rparen			{ yypopulate_tree("abstract_declarator2", 4); }
//	| abstract_declarator2 lparen parameter_type_list rparen			{ yypopulate_tree("abstract_declarator2", 4); }
	;

initializer
	: assignment_expr		{ yypopulate_tree("initializer",1); }
	| lbrace initializer_list rbrace		{ yypopulate_tree("initializer",3); }
	| lbrace initializer_list comma rbrace		{ yypopulate_tree("initializer",4); }
	;

initializer_list
	: initializer		{ yypopulate_tree("initializer_list",1); }
	| initializer_list comma initializer		{ yypopulate_tree("initializer_list",3); }
	;

statement
	: labeled_statement		{ yypopulate_tree("statement",1); }
	| compound_statement		{ yypopulate_tree("statement",1); }
	| expression_statement		{ yypopulate_tree("statement",1); }
	| selection_statement		{ yypopulate_tree("statement",1); }
	| iteration_statement		{ yypopulate_tree("statement",1); }
	| jump_statement		{ yypopulate_tree("statement",1); }
	;

labeled_statement
	: identifier colon statement		{ yypopulate_tree("labeled_statement",3); }
	| case constant_expr colon statement		{ yypopulate_tree("labeled_statement",4); }
	| default colon statement		{ yypopulate_tree("labeled_statement",3); }
	;

compound_statement
	: lbrace rbrace		{ yypopulate_tree("compound_statement",2); }
	| lbrace statement_list rbrace		{ yypopulate_tree("compound_statement",3); }
	| lbrace declaration_list rbrace		{ yypopulate_tree("compound_statement",3); }
	| lbrace declaration_list statement_list rbrace		{ yypopulate_tree("compound_statement",4); }
	;

declaration_list
	: declaration		{ yypopulate_tree("declaration_list",1); }
	| declaration_list declaration		{ yypopulate_tree("declaration_list",2); }
	;

statement_list
	: statement		{ yypopulate_tree("statement_list",1); }
	| statement_list statement		{ yypopulate_tree("statement_list",2); }
	;

expression_statement
	: semi		{ yypopulate_tree("expression_statement",1); }
	| expr semi		{ yypopulate_tree("expression_statement",2); }
	;

selection_statement
	: if lparen expr rparen statement		{ yypopulate_tree("selection_statement",5); }
	| if lparen expr rparen statement else statement		{ yypopulate_tree("selection_statement",7); }
	| switch lparen expr rparen statement		{ yypopulate_tree("selection_statement",5); }
	;

iteration_statement
	: while lparen expr rparen statement		{ yypopulate_tree("iteration_statement",5); }
	| do statement while lparen expr rparen semi		{ yypopulate_tree("iteration_statement",7); }
	| for lparen semi semi rparen statement		{ yypopulate_tree("iteration_statement",6); }
	| for lparen semi semi expr rparen statement		{ yypopulate_tree("iteration_statement",7); }
	| for lparen semi expr semi rparen statement		{ yypopulate_tree("iteration_statement",7); }
	| for lparen semi expr semi expr rparen statement		{ yypopulate_tree("iteration_statement",8); }
	| for lparen expr semi semi rparen statement		{ yypopulate_tree("iteration_statement",7); }
	| for lparen expr semi semi expr rparen statement		{ yypopulate_tree("iteration_statement",8); }
	| for lparen expr semi expr semi rparen statement		{ yypopulate_tree("iteration_statement",8); }
	| for lparen expr semi expr semi expr rparen statement		{ yypopulate_tree("iteration_statement",9); }
	;

jump_statement
	: goto identifier semi		{ yypopulate_tree("jump_statement",3); }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -