亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? word_parser.c

?? 一個(gè)C語言編譯器
?? C
?? 第 1 頁 / 共 2 頁
字號:
#include <stdio.h>
#include <ctype.h>
#include <string.h>
//#define BUFFER_SIZE 512  //預(yù)定義緩沖區(qū)大小
#define KEY_MOUNT   32      //預(yù)定義關(guān)鍵字個(gè)數(shù)
#define ID_SIZE  64      //預(yù)定義關(guān)鍵字大小
#define MAX_ID  2000
//用來定義關(guān)鍵字的集合
#define  ANTO 257
#define  BREAK 258
#define  CASE 259
#define  CHAR 260
#define  CONST 261
#define  CONTINUE 262
#define  DEFAULT 263
#define  DO 264
#define DOUBLE 265
#define ELSE 266
#define ENUM 267
#define EXTERN 268
#define FLOAT 269
#define FOR 270
#define GOTO 271
#define IF 272
#define INT 273
#define LONG 274
#define REGISTER 275
#define RETURN 276
#define SHORT 277
#define SIGNED 278
#define SIZEOF 279
#define  STATIC 280
#define  STRUCT 281
#define  SWITCH 282
#define TYPEDEF 283
#define UNION 284
#define UNSIGNED 285
#define VOID 286
#define VOLATILE 287
#define WHILE 288

#define ID 289
#define NUMBER 290
#define STRING 291
#define REAL 292
#define RELOP 293
#define LOGIC_OP 294
#define PAIR_MATCH 295
#define SINGLE_CHAR 296
#define PREDEFINE 297
#define PREINCLUDE 298
#define DEPARTOR 299
#define COMMA 300
#define SELF_ADD 301
#define SELF_SUB 302
#define AND 303
#define OR 304
#define BIG_EQUAL 305
#define SMA_EQUAL 306
#define EQUIV 307
#define REF 308
#define REMAIN 309
#define UNEQUAL 310
#define DONE 311

struct symbol
{
 char *lexpre;
 int field;
} symtable[KEY_MOUNT+1];    //用來存儲符號表

struct stack 
{
	int pair_list[100];
	int top;	
} pair;
struct symbol sym_list[MAX_ID];

int lineno=0;
char *lexeme;
FILE *res;
FILE *err;
int token_type;
int token_val;

void init();           //初始化關(guān)鍵字列表
int word_parse();
void error(char *s);
int insert(char *q,int token);
int lookup(char *q);
int is_full();
/*void push(char c);
void pop()  ;
*/
//sajfdkl
char *gt;
int main(int argc,char *argv[])
{
	//sadfdsagddsa
	char *xm;
   int i;   
   init();
   if(argc > 2 || argc < =0 )
   {
   printf("agc :%d can't find resource file 1",argc);
   exit(1);
   }
   if(strlen(argv[0])<3)
   {
   printf("can't find resource file 2");
   exit(1);
   }
   if(!strcmp((argv[0]+strlen(argv[0])-2),".c"))
   {
   printf("undefined file,can't open it");
   exit(1);
   }
   if(!(res=fopen(argv[0],"r")))
   {
   printf("error,can't open the file,please check the file path");
   exit(1);
   }
   err=fopen("error.txt","w+");
   freopen("word_parser_output.txt","w+ ",stdout);
   i=word_parse();
   while(i!=DONE)
	   i=word_parse();
   putc(EOF,err);
   fclose(res);
   fclose(err);	
}
void init()
{
   lexeme="auto\0break\0case\0char\0const\0continue\0default\0do\0double\0else\0enum\0extern\0float\0for\0goto\0if\0int\0long\0register\0return\0short\0signed\0sizeof\0static\0struct\0switch\0typedef\0union\0unsigned\0void\0volatile\0while\0"  ;

   symtable[1].field= ANTO;
   symtable[1].lexpre=lexeme;

   symtable[2].field= BREAK;
   symtable[2].lexpre=lexeme+5;
   
   symtable[3].field= CASE;
   symtable[3].lexpre=lexeme+11;
   
   symtable[4].field= CHAR;
   symtable[4].lexpre=lexeme+16;
   
   symtable[5].field= CONST;
   symtable[5].lexpre=lexeme+21;
   
   symtable[6].field= CONTINUE;
   symtable[6].lexpre=lexeme+27;
   
   symtable[7].field= DEFAULT;
   symtable[7].lexpre=lexeme+36;
   
   symtable[8].field= DO;
   symtable[8].lexpre=lexeme+44;
   
   symtable[9].field= DOUBLE;
   symtable[9].lexpre=lexeme+47;
   
   symtable[10].field= ELSE;
   symtable[10].lexpre=lexeme+54;
   
   symtable[11].field= ENUM;
   symtable[11].lexpre=lexeme+59;
   
   symtable[12].field= EXTERN;
   symtable[12].lexpre=lexeme+64;
   
   symtable[13].field= FLOAT;
   symtable[13].lexpre=lexeme+71;
   
   symtable[14].field= FOR;
   symtable[14].lexpre=lexeme+77;
   
   symtable[15].field= GOTO;
   symtable[15].lexpre=lexeme+81;
   
   symtable[16].field= IF;
   symtable[16].lexpre=lexeme+86;
   
   symtable[17].field= INT;
   symtable[17].lexpre=lexeme+89;
   
   symtable[18].field= LONG;
   symtable[18].lexpre=lexeme+93;
   
   symtable[19].field= REGISTER;
   symtable[19].lexpre=lexeme+98;
   
   symtable[20].field= RETURN;
   symtable[20].lexpre=lexeme+107;
   
   symtable[21].field= SHORT;
   symtable[21].lexpre=lexeme+114;
   
   symtable[22].field= SIGNED;
   symtable[22].lexpre=lexeme+120;
   
   symtable[23].field= SIZEOF;
   symtable[23].lexpre=lexeme+127;
   
   symtable[24].field= STATIC;
   symtable[24].lexpre=lexeme+134;
   
   symtable[25].field= STRUCT;
   symtable[25].lexpre=lexeme+141;
   
   symtable[26].field= SWITCH;
   symtable[26].lexpre=lexeme+148;
   
   symtable[27].field= TYPEDEF;
   symtable[27].lexpre=lexeme+155;
   
   symtable[28].field= UNION;
   symtable[28].lexpre=lexeme+163;
   
   symtable[29].field= UNSIGNED;
   symtable[29].lexpre=lexeme+169;
   
   symtable[30].field= VOID;
   symtable[30].lexpre=lexeme+178;
   
   symtable[31].field= VOLATILE;
   symtable[31].lexpre=lexeme+183;
   
   symtable[32].field= WHILE;
   symtable[32].lexpre=lexeme+192;
}
int word_parse()
{

            int curr_ch;
			int next_ch;
			int last_ch;
            char *records;
			int i,j,k;
			while(1)
	{
			curr_ch=getc(res);			
			
			if(curr_ch=='/')
			{            
				next_ch=getc(res);
			if(next_ch=='/')
			{
				while( curr_ch=getc(res) != EOF && curr_ch != '\n');
            
				if(curr_ch==EOF)
				return DONE;			
				
				lineno++;
				continue;
			}
           
			else if(next_ch=='*')
           {
			   curr_ch=getc(res);
			   next_ch=getc(res);
			   while( curr_ch != EOF && next_ch !=EOF)
			   {
				   if(curr_ch == '*' && next_ch == '/')
					   break;
				   else
				   {
					   curr_ch=getc(res);
					   next_ch=getc(res);
				   }
			   }
			    
			   if(curr_ch == '*' && next_ch == '/')
				   continue;
			   else
				   return DONE;
            }          
           
           else if(next_ch=='=')
           {
			   printf("line %d:</RELOP>/=<RELOP>",lineno);
			   return RELOP;
           }
			
		    else
            {
                ungetc(next_ch,res); 
				printf("line %d:</RELOP>/<RELOP>",lineno);
                return RELOP;
            }           
        }
        
            else if(curr_ch==' '|| curr_ch== '\t')           
			continue;    
        
			else if(curr_ch=='\n')
				lineno++;
			else if(curr_ch=='#')
			{				
				for(i=0;i<=6;i++)
				records[i]=getc(res);

				records[7]='\0';
				if(!strcmp(records,"include"))
				{
					printf("line %d:</PREINCLUDE>#include<PREINCLUDE>\n",lineno);
					token_type=PREINCLUDE;
					return PREINCLUDE;
				}
				curr_ch=records[6];
				records[6]='\0';
				if(!strcmp(records,"define"))
				{
					printf("line %d:</PREDEFINE>#define<PREDEFINE>\n",lineno);
					token_type=PREDEFINE;
					return PREDEFINE;
				}
				ungetc(curr_ch,res);
				for(i=5;i>=0;i--)
				ungetc(records[i],res);
				error("illegar character in prefine");
				continue;
			}
			
			else if(isalpha(curr_ch)||curr_ch=='_')
			{
				i=j=0;
				while( isalnum(curr_ch) || curr_ch == '_')
				{
					records[i++]=curr_ch;
					if(i > ID_SIZE)
						error("identifier too long ,over the max size");
					curr_ch=getc(res);
				}
				records[i]='\0';
				ungetc(curr_ch,res);
				
				k=lookup(records);
				if(k)
				{
					printf("line %d:</KEYWORD>%s<KEYWORD>",lineno,records);
					return  k;
  				}				
				
				insert(records,ID);				
				printf("line %d:</ID>%s<ID>",lineno,records);
				token_type=ID;
				return ID;

			}
         
			else if(curr_ch==EOF)
				return DONE;

			else if(isdigit(curr_ch))
			{
				while(isdigit(curr_ch))
				{
					j=k=0;
					records[j++]=curr_ch;
					curr_ch=getc(res);
				}
				token_type=NUMBER;
				if(curr_ch=='.')
				{
					curr_ch=getc(res);
					if(!isdigit(curr_ch))
					{
						error("unexpected character in number");						
						records[j++]='0';
					}
					else
					{
						while(isdigit(curr_ch))
						{
							records[j++]=curr_ch;
							curr_ch=getc(res);
						}
						token_type=REAL;
					}

				}
				if(curr_ch=='e')
				{
					curr_ch=getc(res);
					if(curr_ch=='+' || curr_ch== '-' )
						curr_ch=getc(res);
					if(!isdigit(curr_ch))
						records[j]='0';
					while(isdigit(curr_ch))
					{
						records[j++]=curr_ch;
						curr_ch=getc(res);
					}
					token_type=REAL;
					ungetc(curr_ch,res);
				}
				else
				{
					error("unexpected character in number");
					ungetc(curr_ch,res);
				}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品99久久久| 国产一区二区调教| 色综合久久久久综合体桃花网| 国产精品网站在线观看| 国产精品一区二区在线看| 国产视频一区在线播放| 国产成人免费视频一区| 亚洲欧洲精品一区二区精品久久久| 色网站国产精品| 蜜桃视频一区二区三区在线观看| 欧美v亚洲v综合ⅴ国产v| 国产不卡视频在线观看| 亚洲欧洲色图综合| 欧美日韩美少妇| 国内精品久久久久影院薰衣草 | 国产精品午夜免费| 天天综合日日夜夜精品| 国产人成一区二区三区影院| 国产成a人亚洲| 国产三级精品三级| 懂色一区二区三区免费观看 | 日韩一区二区三区高清免费看看| 亚洲高清免费观看高清完整版在线观看| 欧美日韩一卡二卡| 日本va欧美va瓶| 国产精品乱码妇女bbbb| 欧美在线观看视频在线| 国产精品自拍在线| 日日嗨av一区二区三区四区| 久久亚洲免费视频| 91麻豆福利精品推荐| 蜜桃91丨九色丨蝌蚪91桃色| 亚洲丝袜美腿综合| 国产亚洲精品免费| 日韩一区有码在线| 精品亚洲免费视频| 久久一夜天堂av一区二区三区| 欧美在线视频日韩| 日韩va欧美va亚洲va久久| 久久精品夜色噜噜亚洲a∨| 国产成人免费在线观看| 成人激情免费网站| 91在线视频播放| 欧美日韩在线播放三区| 91在线视频18| 色哟哟欧美精品| 免费在线看成人av| 亚洲黄网站在线观看| 欧美日本在线视频| 精品一区二区av| www国产成人| 久久久亚洲精品石原莉奈| 色婷婷久久综合| 国产一区二区三区黄视频 | 91精品国产91综合久久蜜臀| 亚洲国产一区二区在线播放| 91在线看国产| 亚洲乱码日产精品bd| 欧美剧在线免费观看网站| 狠狠狠色丁香婷婷综合激情 | zzijzzij亚洲日本少妇熟睡| 91香蕉视频mp4| 欧美成人福利视频| 亚洲欧洲在线观看av| 欧美一区二区大片| 国产亚洲欧美激情| 亚洲精品成人精品456| 高清不卡一二三区| 粉嫩aⅴ一区二区三区四区五区| 亚洲一二三四区| 国产精品色噜噜| 欧美色综合网站| 国产在线不卡视频| www.成人在线| 国产成人精品亚洲午夜麻豆| av电影在线观看不卡| 欧美日韩激情在线| 国产日韩欧美精品在线| 亚洲主播在线播放| 国产在线麻豆精品观看| 99r国产精品| 欧美大片在线观看一区二区| 亚洲天堂2014| 成人免费观看av| 欧美一级欧美一级在线播放| 国产精品久久久久久久久免费相片| 日韩在线一区二区三区| av激情综合网| 国产精品视频一二| 国产激情91久久精品导航 | 欧美精三区欧美精三区| 成人黄色软件下载| 色婷婷综合久久久久中文一区二区 | 亚洲午夜精品网| 国产一区二区导航在线播放| 精品成人一区二区三区四区| 91精品国产综合久久久蜜臀图片| 欧美xxxx在线观看| wwwwxxxxx欧美| 亚洲国产综合色| 国产麻豆精品久久一二三| 6080yy午夜一二三区久久| 精品裸体舞一区二区三区| 一区二区三区在线视频观看58 | 成人高清av在线| 国产欧美一区二区精品忘忧草| 国产综合色产在线精品| 精品99一区二区三区| 国产一区二区在线影院| 精品欧美乱码久久久久久1区2区 | 亚洲国产视频a| 欧美男女性生活在线直播观看| 天堂在线一区二区| 欧美一级日韩不卡播放免费| 激情文学综合插| 国产精品婷婷午夜在线观看| 一本大道久久精品懂色aⅴ| 亚洲午夜精品在线| 久久久久久久久久久久久女国产乱| 国模少妇一区二区三区| 成人欧美一区二区三区小说| 在线观看视频欧美| 国产在线乱码一区二区三区| 亚洲丝袜精品丝袜在线| 日韩一级成人av| 色综合夜色一区| 久久99精品一区二区三区| 中文字幕亚洲成人| 日韩欧美国产系列| 91视频免费观看| 九九久久精品视频| 国产精品天天摸av网| 欧美撒尿777hd撒尿| 高清国产一区二区三区| 日韩激情在线观看| 国产精品麻豆久久久| 日韩精品一区二区三区四区视频 | 99久久伊人网影院| 免费高清视频精品| 亚洲国产精品一区二区久久 | 亚洲女女做受ⅹxx高潮| 久久综合中文字幕| 日韩欧美的一区| 欧美一区二区三区日韩| 欧美午夜在线一二页| 91捆绑美女网站| av在线一区二区三区| 成人性色生活片| 国产成人在线观看| 丁香啪啪综合成人亚洲小说| 蜜臀久久久久久久| 久久99深爱久久99精品| 精品一区二区三区免费| 久久国产精品露脸对白| 久久99精品视频| 国产一区二区伦理| 国产成人在线观看免费网站| 不卡av电影在线播放| 99精品国产一区二区三区不卡| 成人美女在线观看| 91亚洲精品久久久蜜桃网站| 日本国产一区二区| 777亚洲妇女| 欧美激情艳妇裸体舞| 亚洲自拍另类综合| 麻豆91精品视频| av不卡在线播放| 91精品在线免费观看| 精品成人免费观看| 国产精品久久久久久久久免费相片| 亚洲男人天堂av| 久久超碰97中文字幕| 国产91精品一区二区麻豆网站 | 国产精品一区二区在线观看不卡| av一区二区三区在线| 欧美r级在线观看| 亚洲六月丁香色婷婷综合久久| 偷窥国产亚洲免费视频| 国产馆精品极品| 91麻豆精品91久久久久久清纯| 久久久久9999亚洲精品| 亚洲国产精品欧美一二99| 高清视频一区二区| 日韩精品一区二区三区老鸭窝| 亚洲欧美日韩国产综合| 国产一区二区三区四区五区美女| 欧美日韩在线播放一区| 1区2区3区精品视频| 国产成人av一区二区三区在线观看| 911国产精品| 亚洲一区二区三区在线看| av成人免费在线观看| 国产欧美精品一区二区色综合 | 9191成人精品久久| 午夜视频一区二区三区| 欧美日韩一区 二区 三区 久久精品| 国产精品不卡一区| 成人小视频在线| 国产视频911| 亚洲免费资源在线播放|