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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? cdecl.c

?? guide and some example with visualC++
?? C
?? 第 1 頁 / 共 4 頁
字號:
	    init_ident(e1, EiC_work_tab);	    new_var(e1);	    EiC_work_tab = h;	    if (EiC_lexan() == '{') {		enum_list(e1);		EiC_match('}', " }");		 e1->Type = e1->Val.sym->type;	    } else                retractlexan();	    break;	} else if (t == t_enum) {	    EiC_freetype(e1->Type);	    e1->Type = EiC_copytype(token->Val.sym->type);	} else	    EiC_error("Enumeration declaration error");	break;      case '{':	EiC_work_tab = h;	enum_list(e1);	EiC_match('}', " }");	break;      default:	EiC_error("Enumeration declaration error");	retractlexan();    }    EiC_work_tab = h;}static void enum_list(token_t * e1){    int ENUMVAL = 0;    token_t e2;    token_t e3;    do {	EiC_inittoken(&e2);	/*	 *  now do enumerator part	 */	if (EiC_lexan() == ID) {	    e2.Type = EiC_addtype(t_int, NULL);	    setConst(e2.Type);	    EiC_setAsBaseType(e2.Type);	    e2.Sclass = c_enum;	    init_ident(&e2, EiC_work_tab);	    new_var(&e2);	    if (EiC_lexan() == ASS) {		EiC_inittoken(&e3);		cond_expr(&e3);		if (isconst(e3.Type) && EiC_gettype(e3.Type) == t_int)		    ENUMVAL = e3.Val.ival;		else {		    EiC_freetoken(&e3);		    EiC_error("Assignment must be constant");		    break;		}		EiC_freetoken(&e3);	    } else		retractlexan();	    e2.Sym->val.ival = ENUMVAL++;	} else {	    EiC_error("Expected identifier in enumeration");	    break;	}    } while (EiC_lexan() == ',');    retractlexan();}static void array_decl(token_t * e1){    int t;    token_t e2;    EiC_inittoken(&e2);    EiC_assign_expr(&e2);    if (isconst(e2.Type)) { 	if ((t=EiC_gettype(e2.Type)) != t_int && t != t_uint) {	    if(sizeof(int) != sizeof(long) || t != t_ulong) {		EiC_error("Constant int expression needed");		e2.Val.ival = 0;	    }	}    } else {	if(!ABSDECL && /*((t == t_void && EiC_INFUNC) || */	   EiC_gettype(e2.Type) != t_void )	    EiC_error("Constant int expression needed");	e2.Val.ival = 0;    }    e1->Type = EiC_addtype(t_array, e1->Type);    setNumElems(e1->Type,e2.Val.ival);    EiC_freetoken(&e2);    EiC_match(']', " ] ");}static void st_un_spec(token_t * e1, int t){    switch (t) {      case structsym:	e1->Type = EiC_addtype(t_struct, e1->Type);	break;      case unionsym:	e1->Type = EiC_addtype(t_union, e1->Type);	break;    }    f_st_un_spec(e1);}static eicstack_t stun;static void f_st_un_spec(token_t * e1){    val_t val;    int t,nxtt;    symentry_t *sym;    int h = EiC_work_tab;    EiC_work_tab = tag_tab;    val.p.p = INSTUN;    INSTUN = e1;    EiC_eicpush(&stun,val);    switch (EiC_lexan()) {      case ID:			/* struct or union tag */	EiC_work_tab = h;	sym = token->Val.sym;	t = EiC_gettype(sym->type);	nxtt = EiC_lexan();	retractlexan();       	if(t==ID || (nxtt == '{' && token->Val.sym->level<EiC_S_LEVEL)) {	    init_ident(e1, tag_tab);	    new_var(e1);	    setInf(e1->Type,xcalloc(1, sizeof(struct_t)));	    if(nxtt == '{') {				EiC_lexan();		EiC_S_LEVEL++;		s_decl_list(e1);		EiC_match('}', " }");		EiC_S_LEVEL--;		if(EiC_lexan() == ';' && EiC_S_LEVEL == 1)		    e1->Type = NULL;		retractlexan();		   	    } 	    	} else {	    if (t == t_struct || t == t_union) {		EiC_freetype(e1->Type);		e1->Type = EiC_copytype(sym->type);	    } else {		init_ident(e1, tag_tab);		new_var(e1);		setInf(e1->Type,xcalloc(1, sizeof(struct_t)));	    }	    if(nxtt == '{') {		EiC_lexan();		EiC_S_LEVEL++;		s_decl_list(e1);		EiC_match('}', " }");		EiC_S_LEVEL--;		if(EiC_lexan() == ';' && EiC_S_LEVEL == 1) {		    EiC_freetype(e1->Type);		    e1->Type = NULL;		}		retractlexan();	    } 	}	break;      case '{':	EiC_work_tab = h;	EiC_S_LEVEL++;	s_decl_list(e1);	EiC_match('}', " }");	EiC_S_LEVEL--;	break;    }    EiC_work_tab = h;    EiC_eicpop(&stun,&val);    INSTUN = val.p.p;}static void s_decl_list(token_t * e1){    int f = 0, bp = EiC_ENV->lsp;    struct_t *S;        if(!EiC_getInf(e1->Type)) 	setInf(e1->Type,xcalloc(1, sizeof(struct_t)));    /*    if(((struct_t*)EiC_getInf(e1->Type))->cl) {	EiC_error("Illegal use of struct/union");	return;    }    */        while (1) {	switch (EiC_lexan()) {	  TYPESPEC:	  TYPEQUAL:		f = 1;	    st_decl(e1, token->Tok);	    break;	  default:	    if (!f)		EiC_error("Struct/Union list declaration error");	    S = EiC_getInf(e1->Type);	    S->cl = 1;	    /*	     * determine structure alignment.	     */	    S->tsize = RoundUp(S->tsize,S->align); 	    retractlexan();	    EiC_reset_env_pointers(e1, bp);	    return;	}    }}static void st_decl(token_t * e1, int t){    token_t e2;    EiC_inittoken(&e2);    spec_qual_list(&e2, t);    EiC_setAsBaseType(e2.Type);    spec_declor_list(e1, &e2);    EiC_freetype(e2.Type);    EiC_match(';', " ; ");}static void spec_qual_list(token_t * e1, int t){    /*type_spec(e1, t);*/    specifier(e1,t,NULL);    r_spec_qual_list(e1);}static void r_spec_qual_list(token_t * e1){    switch (EiC_lexan()) {      TYPESPEC:	    spec_qual_list(e1, token->Tok);	break;      default:	retractlexan();    }}void EiC_free_un_mem(type_expr * e){    struct_t *S = EiC_getInf(e);    if (S) {	int i;	if(S->n) {	    for (i = 0; i < S->n; i++) {		xfree(S->id[i]);		EiC_freetype(S->type[i]);	    }	    xfree(S->offset);	    xfree(S->id);	    xfree(S->type);	}	if(S->ntags) {	    for(i=0;i<S->ntags;++i)		EiC_freetype(S->tag[i]);	    xfree(S->tag);	}	xfree(S);    }}static void addst_un_tag(symentry_t *sym){    struct_t *S;    S = EiC_getInf(INSTUN->Val.sym->type);    S->ntags++;    if(S->ntags == 1)	S->tag = (type_expr**)xmalloc(sizeof(type_expr*));    else	S->tag = (type_expr**)xrealloc(S->tag,				      sizeof(type_expr*)*S->ntags);    S->tag[S->ntags - 1] = EiC_transtype(sym->type);    EiC_setaliases(sym->type,1);}	static void addst_un_mem(token_t * e1, token_t * e2){    struct_t *S;    int off, s;    S = EiC_getInf(e1->Type);    if (S->n == 0) {	S->id = (char **) xcalloc(1, sizeof(char *));	S->offset = (int *) xcalloc(1, sizeof(int));	S->type = (type_expr **) xcalloc(1, sizeof(type_expr *));    } else {	/*	 * first check for duplication of names	 */	int i;	for(i=0;i<S->n;++i) 	    if(strcmp(S->id[i], e2->Val.sym->id) == 0)		EiC_error("Duplication of identifier in struct/union");	S->id = (char **) xrealloc(S->id,				   (S->n + 1) * sizeof(char *));	S->offset = (int *) xrealloc(S->offset,				     (S->n + 1) * sizeof(int));	S->type = (type_expr **) xrealloc(S->type,					  (S->n + 1) * sizeof(type_expr *));    }    if(isconst(e2->Type)) {	unsetConst(e2->Type);	setConstp(e2->Type);    }    if(EiC_gettype(e2->Type) == t_enum)      cast_t_enum(e2);    S->id[S->n] = (char *) EiC_strsave(e2->Val.sym->id);    S->type[S->n] = EiC_transtype(e2->Type);            if(!(s = EiC_get_sizeof(S->type[S->n]))) {     EiC_error("Incomplete data type for struct/union member %s",S->id[S->n]);    }    off = EiC_get_align(e2->Type);	    if (EiC_gettype(e1->Type) == t_struct) {        	S->offset[S->n] = RoundUp(S->tsize,off);	S->tsize += s + S->offset[S->n] - S->tsize;    } else { /* handle union */		S->offset[S->n] = 0;	S->tsize = S->tsize > s ? S->tsize : s;    }    /*     * structure alignment is equal to the     * maximum alignment of its members.     */    if(S->align < off)	S->align = off;    S->n++;}static void spec_declor_list(token_t * e1, token_t * e2){    int ftime = 1, cl;    token_t e3;    cl = ((struct_t*)EiC_getInf(e1->Type))->cl;    do {	switch (EiC_lexan()) {	  case '*':	  case ID:	  case '(':	  case ':':	    EiC_inittoken(&e3);	    e3.Type = EiC_transtype(e2->Type);	    st_declor(&e3, token->Tok);	    if (EiC_gettype(e3.Type) == t_struct ||		EiC_gettype(e3.Type) == t_union) {		struct_t *S;		S = EiC_getInf(e3.Type);		if (!S->cl)	/* check for closure */		    EiC_error("Illegal Struct/Union member");	    }	    /* if structure/union is already closed,	     * then assume structure is being re-entered.	     */	    if (e3.Val.sym && !cl) {		e3.Type = EiC_revtype(e3.Type);		if (ftime)		    EiC_setaliases(e2->Type, 1);		addst_un_mem(e1, &e3);		if (ftime) {		    EiC_setaliases(e3.Type, 1);		    ftime = 0;		}	    }	    EiC_freetype(e3.Type);	    EiC_remsym(e3.Val.sym);	    break;	  default:	    retractlexan();	    EiC_error("Struct/Union member declaration error");	}    } while (EiC_lexan() == ',');    retractlexan();}static void st_declor(token_t * e1, int t){    switch (t) {      case '*':      case ID:      case '(':	  decl(e1, t);	  /*setBoundaryLimits(e1);*/	  f_st_declor();	  establish_id(e1);	  break;      case ':':	  EiC_error("Bit fields not supported");	  break;    }}static void f_st_declor(){    if (EiC_lexan() == ':')	EiC_error("Bit fields not supported");    else	retractlexan();}int EiC_type_name(token_t * e1){    switch (EiC_lexan()) {      TYPEQUAL:      TYPESPEC:	spec_qual_list(e1, token->Tok);	EiC_setAsBaseType(e1->Type);	switch (EiC_lexan()) {	  case '*':	  case '(':	  case '[':	    abs_decl(e1, token->Tok);	    e1->Type = EiC_revtype(e1->Type);	    break;	  default:	    retractlexan();	}	break;      default:	retractlexan();	return 0;    }    return 1;}static void abs_decl(token_t * e1, int t){    type_expr *P = NULL;    ABSDECL++;    switch (t) {      case '*':	P = pointer();	f_abs_decl(e1);	if(P)	    e1->Type = EiC_catTypes(P,e1->Type);	break;      case '(':      case '[':	dir_abs_decl(e1, t);	break;      case ID:	EiC_error("extraneous identifier `%s'",token->Val.sym->id);	break;    }    ABSDECL--;}static void f_abs_decl(token_t * e1){    switch (EiC_lexan()) {      case '(':      case '[':	dir_abs_decl(e1, token->Tok);	break;      case ID:	EiC_error("extraneous identifier `%s'",token->Val.sym->id);	break;      default:	retractlexan();    }}static void dir_abs_decl(token_t * e1, int t){    switch (t) {      case '(':	f1_dir_abs(e1);	EiC_f2_dir_abs(e1);	break;      case '[':	array_decl(e1);	EiC_f2_dir_abs(e1);	break;    }}static void f1_dir_abs(token_t * e1){    switch (EiC_lexan()) {      case ')':      TYPEQUAL:      STORECLASS:      TYPESPEC:	retractlexan();	ff_dir_decl(e1);	EiC_remlevel(EiC_S_LEVEL+1);	break;      case '*':      case '(':      case '[':	abs_decl(e1, token->Tok);	EiC_match(')', " )");	break;      default:	EiC_error("Abstract declaration error");    }}static void EiC_f2_dir_abs(token_t * e1){    switch (EiC_lexan()) {      case '[':	array_decl(e1);	EiC_f2_dir_abs(e1);	break;      case '(':	ff_dir_decl(e1);	EiC_remlevel(EiC_S_LEVEL+1);	EiC_f2_dir_abs(e1);	break;      default:	retractlexan();    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久毛片| 日韩一区二区三区免费看| 国产欧美日韩亚州综合| 成年人午夜久久久| ...av二区三区久久精品| 国产日韩精品视频一区| 97成人超碰视| 久久草av在线| 亚洲婷婷国产精品电影人久久| 欧美美女黄视频| 国产又黄又大久久| 一区二区免费在线播放| 久久人人爽爽爽人久久久| 在线影院国内精品| 国产黑丝在线一区二区三区| 亚洲精品成人在线| 久久先锋影音av| 欧美日韩久久不卡| 99riav久久精品riav| 日韩综合在线视频| 最新久久zyz资源站| 欧美一区二区三级| 色综合欧美在线| 国产成人在线视频播放| 亚洲免费视频成人| 久久麻豆一区二区| 制服丝袜亚洲精品中文字幕| 99久久精品99国产精品| 国产盗摄一区二区三区| 日韩影院免费视频| 亚洲成人资源在线| 亚洲色欲色欲www在线观看| 久久久久一区二区三区四区| 69堂成人精品免费视频| 欧美伊人精品成人久久综合97 | 亚洲高清不卡在线观看| 国产欧美日产一区| 精品久久五月天| 日韩亚洲欧美一区| 欧美男生操女生| 欧美三级资源在线| 91美女片黄在线观看91美女| 国产麻豆视频一区| 青青草国产成人99久久| 亚洲日本免费电影| 国产精品免费丝袜| 国产精品理论在线观看| 久久精品视频在线看| 欧美mv日韩mv| 精品女同一区二区| 精品国产a毛片| 欧美日韩国产精品自在自线| 精品视频色一区| 欧美视频一区二区三区在线观看| 色婷婷av久久久久久久| 久久色在线视频| 欧美一区二区三区免费视频 | 不卡在线视频中文字幕| 国产一区二区三区免费| 精品综合免费视频观看| 久久97超碰国产精品超碰| 国产免费成人在线视频| 成人av网站在线观看免费| 日本美女一区二区| 亚洲乱码国产乱码精品精的特点| 日韩免费看网站| 日韩三级视频在线看| 欧美一级黄色录像| 国产日韩精品一区二区浪潮av | 国产999精品久久| av在线播放一区二区三区| av电影在线观看不卡| 欧美老女人在线| 久久久蜜桃精品| 一区二区三区在线观看欧美| 日韩黄色免费网站| 不卡一区二区在线| 91精品国产综合久久福利| 久久精品亚洲精品国产欧美kt∨| 一区二区三区在线视频观看| 九色综合狠狠综合久久| 91一区二区在线观看| 久久久噜噜噜久久中文字幕色伊伊| 国产精品伦理在线| 国产一本一道久久香蕉| 欧美亚洲精品一区| 日韩毛片在线免费观看| 韩国三级中文字幕hd久久精品| 91精品办公室少妇高潮对白| 国产亲近乱来精品视频| 毛片一区二区三区| 91精品国产91久久久久久最新毛片| 日本一区二区成人在线| 精品亚洲成a人在线观看| 51精品久久久久久久蜜臀| 亚洲视频免费在线观看| 成人爱爱电影网址| 国产精品萝li| 成人av在线影院| 久久精品人人做| eeuss鲁片一区二区三区在线看| 一区二区三区波多野结衣在线观看 | 99re热这里只有精品免费视频| |精品福利一区二区三区| 日韩美女主播在线视频一区二区三区| 国产91在线观看| 天堂va蜜桃一区二区三区漫画版| 欧美国产成人精品| 日韩欧美aaaaaa| 欧美精品色一区二区三区| 成人黄色国产精品网站大全在线免费观看 | 理论片日本一区| 久久欧美中文字幕| 色综合 综合色| 久久国产精品露脸对白| 欧美韩国日本一区| 欧美色图免费看| 精品一区二区在线观看| 亚洲人快播电影网| 日韩一区二区三区在线视频| 成人午夜电影小说| 亚洲电影欧美电影有声小说| 欧美成人午夜电影| 日本黄色一区二区| 国产精品一区三区| 亚洲成人激情自拍| 国产精品每日更新| 2021中文字幕一区亚洲| 欧美伦理视频网站| 成人av午夜影院| 高清日韩电视剧大全免费| 日本午夜一本久久久综合| 亚洲精品成人a在线观看| 91精品欧美综合在线观看最新| 日本精品裸体写真集在线观看| 国产一区二区在线观看视频| 亚洲国产精品人人做人人爽| 国产精品情趣视频| 国产喷白浆一区二区三区| 欧美一区二区大片| 日韩亚洲电影在线| 欧美丰满美乳xxx高潮www| 欧美午夜精品电影| 欧美无乱码久久久免费午夜一区| 色婷婷久久久久swag精品| 成人理论电影网| 99re这里只有精品首页| eeuss影院一区二区三区| 91亚洲精品久久久蜜桃| 99久久精品久久久久久清纯| 不卡的av中国片| 成人黄色777网| 欧美网站大全在线观看| 欧美电影影音先锋| 精品久久国产字幕高潮| 国产日韩欧美精品电影三级在线| 中文字幕一区不卡| 亚洲777理论| 自拍偷拍亚洲欧美日韩| 欧美tk—视频vk| 91免费视频网| 国产一区二区三区在线看麻豆| 国产精品视频一二三| 色偷偷久久人人79超碰人人澡| 成人av在线播放网址| 国产99久久久久| 一本久久精品一区二区| 欧美日韩你懂的| 久久亚洲精精品中文字幕早川悠里 | 91色婷婷久久久久合中文| 欧美三片在线视频观看| 久久久五月婷婷| 亚洲一区中文日韩| 久久99精品久久久久久久久久久久 | 亚洲精品国产精品乱码不99| 麻豆国产欧美一区二区三区| 99久久精品国产一区二区三区| 欧美高清性hdvideosex| 国产精品久久看| 国产在线精品一区二区夜色| 欧美日韩免费一区二区三区| 久久久精品tv| 狠狠色综合播放一区二区| 欧美日韩三级一区二区| 亚洲精品乱码久久久久久久久 | 国产精品亚洲一区二区三区在线| 欧美在线观看一区二区| 成人欧美一区二区三区视频网页| 日本欧美一区二区三区| 欧美精品欧美精品系列| 亚洲午夜精品网| 色综合天天综合| 亚洲欧美一区二区三区久本道91| 国产乱人伦偷精品视频不卡| 久久婷婷国产综合国色天香| 国产资源精品在线观看| 国产日韩欧美电影| 成人视屏免费看| 国产精品美女久久久久aⅴ国产馆| 韩国成人在线视频|