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

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

?? decl.c

?? 本程序集是Allen I. Holub所寫的《Compiler Design in C》一書的附隨軟件
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
 * 68K/386 32-bit C compiler.
 *
 * copyright (c) 1997, David Lindauer
 * 
 * This compiler is intended for educational use.  It may not be used
 * for profit without the express written consent of the author.
 *
 * It may be freely redistributed, as long as this notice remains intact
 * and either the original sources or derived sources 
 * are distributed along with any executables derived from the originals.
 *
 * The author is not responsible for any damages that may arise from use
 * of this software, either idirect or consequential.
 *
 * v1.35 March 1997
 * David Lindauer, gclind01@starbase.spd.louisville.edu
 *
 * Credits to Mathew Brandt for original K&R C compiler
 *
 */
/*
 * handle ALL declarative statements
 */
#include        <stdio.h>
#include				<limits.h>
#include        "expr.h"
#include        "c.h"
#include        "errors.h"

extern int stdinttype,stdunstype,stdintsize, stdldoublesize,stdaddrsize;
extern int strucadd,strucmod;

extern char laststr[];
extern int global_flag;
extern TABLE gsyms,lsyms;
extern	SNODE *cbautoinithead;
extern int prm_packing;
extern int prm_revbits;
extern int prm_68020;
extern int prm_ansi;
extern HASHREC **globalhash;
extern SYM *currentfunc;
extern int prm_cplusplus;
extern char * tn_unnamed;
extern TYP stdconst;
extern enum e_sym lastst;
extern char lastid[];
extern int block_nesting;
extern long nextlabel;

char *Cstr = "C";

TABLE *active_table;		/* This is so enums will not be put in structre tabs */

int mangleflag;
int skm_declopenpa[] = { semicolon, comma,openpa, eq,0 };
int skm_declclosepa[] = { semicolon, comma,closepa, eq,0 };
int skm_declclosebr[] = { comma,closebr, eq,0 };
int skm_declend[] = { semicolon, comma, end, eq,0 };
int skm_decl[] = {semicolon,kw_int, kw_long, kw_short, kw_char, kw_float,
		kw_double, kw_struct, kw_union, kw_enum, kw_unsigned, kw_signed, kw_auto,
		kw_extern, kw_static, kw_register, kw_typedef, id, kw_void, 0 };

TYP             *head = 0;
TYP             *tail = 0;
char            declid[100];
TABLE           tagtable = {0,0};
int ispascal;

static					SYM *lastdecl;
static 					int pcount=0;
static int bittype = -1;
static int curbit = 0;
static int curofs = 0;
static int manglelevel;
static int intflag;

void declini(void)
/*
 * init
 */
{
	bittype = -1;
	head = tail = 0;
	declid[0] = 0;
	tagtable.head = tagtable.tail = 0;
	pcount = 0;
	mangleflag = TRUE;
}
	
int     imax(int i,int j)
{       return (i > j) ? i : j;
}

char    *litlate(char *s)
{       char    *p;
        p = xalloc(strlen(s) + 1);
        strcpy(p,s);
        return p;
}

TYP     *maketype(int bt,int siz)
/*
 * Create a type list entry
 */
{       TYP     *tp;
				
        tp = xalloc(sizeof(TYP));
        tp->val_flag = 0;
				tp->bits = tp->startbit = -1;
        tp->size = siz;
        tp->type = bt;
        tp->sname = 0;
				tp->cflags = 0;
				tp->uflags = 0;
        tp->lst.head = tp->lst.tail = 0;
				tp->tdef = 0;
        return tp;
}
TYP *cponetype(TYP *t)
/*
 * Copy a entry
 */
{				TYP *tp;
	tp = xalloc(sizeof(TYP));
	tp->type = t->type;
	tp->val_flag = t->val_flag;
	tp->cflags = t->cflags;
	tp->bits = t->bits;
	tp->startbit = t->startbit;
	tp->size = t->size;
	tp->lst = t->lst;
	tp->btp = t->btp;
	tp->sname = t->sname;
	tp->uflags = t->uflags;
	tp->tdef = t->tdef;
	return tp;
}
TYP *copytype(TYP *itp, int flags)
/*
 * copy a type tree
 */
{
	TYP *head, *tail,*x=itp;
	while (x->type == bt_pointer)
		x = x->btp;
	if (x->type == bt_struct || x->type == bt_union)
		if (!x->lst.head) {
			itp->cflags = flags;
			return head = tail = itp;
		}
	head = tail = cponetype(itp);
	while (itp->type == bt_pointer) {
		tail = tail->btp = cponetype(itp->btp);
		itp = itp->btp;
	}
	if (itp->type == bt_func || itp->type == bt_ptrfunc || itp->type == bt_ifunc) {
			tail->btp = cponetype(itp->btp);
	}
	else {
		tail->cflags |= flags;
	}
	return head;
}
void     decl(TABLE *table)
/*
 * parse the declare keywords and create a basic type
 */
{
				int tp;
				SYM *sp;
				int flags = 0;
				while (lastst == kw_const || lastst == kw_volatile) {
					if (lastst == kw_const)
						flags |= DF_CONST;
					else
						flags |= DF_VOL;
					getsym();
				}
        switch (lastst) {
								case kw_void:
                        head = tail = maketype(bt_void,0);
												getsym();
												break;
                case kw_char:
                        head = tail = maketype(bt_char,1);
                        getsym();
                        break;
                case kw_short:
												getsym();
												tp = bt_short;
												if (lastst == kw_unsigned) {
													tp = bt_unsignedshort;
													getsym();
												}
												if (lastst == kw_int)
													getsym();
                        head = tail = maketype(tp,2);
                        break;
                case kw_int: 
                        head = tail = maketype(stdinttype,stdintsize);
                        getsym();
                        break;
                case kw_unsigned:
												getsym();
												switch (lastst) {
													case kw_char:
														getsym();
                        		head = tail = maketype(bt_unsignedchar,1);
														break;
													case kw_short:
														getsym();
														if (lastst == kw_int)
															getsym();
                        		head = tail = maketype(bt_unsignedshort,2);
														break;
													case kw_long:
														getsym();
														if (lastst == kw_long) {
															getsym();
															generror(ERR_LONGLONG,0,0);
														}
														if (lastst == kw_int)
															getsym();
                        		head = tail = maketype(bt_unsigned,4);
														break;
													case kw_int:
														getsym();
													default:
                        		head = tail = maketype(stdunstype,stdintsize);
														break;
												}
                        break;
                case kw_signed:
												getsym();
												switch (lastst) {
													case kw_char:
														getsym();
                        		head = tail = maketype(bt_char,1);
														break;
													case kw_short:
														getsym();
														if (lastst == kw_int)
															getsym();
                        		head = tail = maketype(bt_short,2);
														break;
													case kw_long:
														getsym();
														if (lastst == kw_long) {
															getsym();
															generror(ERR_LONGLONG,0,0);
														}
														if (lastst == kw_int)
															getsym();
                        		head = tail = maketype(bt_long,4);
														break;
													case kw_int:
														getsym();
													default:
                        		head = tail = maketype(stdinttype,stdintsize);
														break;
												}
                        break;
                case id:                /* no type declarator */
												if ((sp = gsearch(lastid)) != 0 && sp->storage_class == sc_type) {
													head = tail = copytype(sp->tp,flags);
													getsym();
												}
												else
                       		head = tail = maketype(bt_long,4);
                        break;
                case kw_float:
                        head = tail = maketype(bt_float,4);
                        getsym();
                        break;
								case kw_long:
												getsym();
												if (lastst==kw_double) {
													getsym();
                        	head = tail = maketype(bt_longdouble,stdldoublesize);
													break;
												}
												if (lastst==kw_float) {
													getsym();
                        	head = tail = maketype(bt_double,8);
													break;
												}
												if (lastst == kw_long) {
													getsym();
													generror(ERR_LONGLONG,0,0);
												}
												tp = bt_long;
												if (lastst == kw_unsigned) {
													tp = bt_unsigned;
													getsym();
												}
												if (lastst == kw_long) {
													getsym();
													generror(ERR_LONGLONG,0,0);
												}
												if (lastst == kw_int)
													getsym();
                        head = tail = maketype(tp,4);
                        break;
                case kw_double:
                        head = tail = maketype(bt_double,8);
                        getsym();
                        break;
                case kw_enum:
                        getsym();
                        declenum(table);
                        break;
                case kw_struct:
                        getsym();
                        declstruct(table, bt_struct,flags);
                        break;
                case kw_union:
                        getsym();
                        declstruct(table, bt_union,flags);
                        break;
                }
	head->cflags |= flags;
	head->uflags |= UF_CANASSIGN;
}

void decl1(void)
/*
 * Modifiers that could occur BEFORE the name of the var
 */
{       TYP     *temp1, *temp2, *temp3, *temp4;
lp:
        switch (lastst) {
								case kw_const:
									head->cflags |= DF_CONST;
									getsym();
									goto lp;
								case kw_volatile:
									head->cflags |= DF_VOL;
									getsym();
									goto lp;
								case kw__pascal:
									ispascal = TRUE;
									getsym();
									goto lp;
                case id:
												strcpy(declid,lastid);
                        getsym();
                        decl2();
                        break;
								case and:
#ifdef CPLUSPLUS
												if (prm_cplusplus) {
													getsym();
													if (prm_cplusplus) {
														decl1();
														if (head->type == bt_ref || head->type == bt_pointer)
															generror(ERR_CANTREF,0,0);
														else {
															temp1 = maketype(bt_ref,4);
															temp1->btp = head;
															head = temp1;
															if (tail == NULL)
																tail = head;
														}
													}
													else 
														generror(ERR_NOREF,0,0);
												}
												else
#endif
												{
													decl2();
													break;
												}
												break;
                case star:
												head->uflags &= ~UF_CANASSIGN;
                        temp1 = maketype(bt_pointer,4);
                        temp1->btp = head;
                        head = temp1;
												head->uflags |= UF_CANASSIGN;
                        if(tail == NULL)
                                tail = head;
                        getsym();
                        decl1();
                        break;
                case openpa:
                        getsym();
	                      temp1 = head;
  	                    temp2 = tail;
/* Check here for function pointer */
												if (lastst == star) {
													getsym();
													{
		  	                    head = tail = maketype(bt_ptrfunc,4);
    		  	                head->btp = temp1;
											
														decl1();
														if (needpunc(closepa,skm_declclosepa)) {
															char temp[40];
															/* in case we have a pointer type in
															 * parenthesis
															 * Isn't C grand? */
															if (lastst != openpa) {
																/* change the pointerfunc to a pointer */
																if (head->type == bt_ptrfunc) 
																	head->type = bt_pointer;
																else {
																	temp3 = head;
																	while (temp3->type != bt_ptrfunc)
																		temp3 = temp3->btp;
																	temp3->type = bt_pointer;
																}
																tail = temp2;
																decl2();
																break;
															}
															strcpy(temp,declid);
															if (head->type == bt_func) {
																declid[0] = 0;
																temp1 = head;
																head = head->btp;
															}
															else
																temp1 = 0;
															getsym();
															declfuncarg(intflag);
															if (temp1) {
																strcpy(declid,temp);
																temp1->btp = head;
																head = temp1;
															}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产成都精品91一区二区三| 国产婷婷一区二区| 欧美日韩视频在线观看一区二区三区| 顶级嫩模精品视频在线看| 国产一区二区免费在线| 韩国中文字幕2020精品| 国产一二精品视频| 国产成人h网站| 99re成人精品视频| 色天使久久综合网天天| 欧美亚洲高清一区| 欧美日韩国产一二三| 欧美精品在线观看播放| 欧美成人a∨高清免费观看| 久久综合色播五月| 国产精品福利一区二区三区| 亚洲图片激情小说| 亚洲电影第三页| 蜜臀av在线播放一区二区三区| 极品销魂美女一区二区三区| 成人一级视频在线观看| 91搞黄在线观看| 日韩一区二区中文字幕| 国产亚洲美州欧州综合国| 国产精品国产a| 亚洲午夜精品一区二区三区他趣| 性做久久久久久久免费看| 久久97超碰国产精品超碰| 岛国精品在线播放| 色婷婷久久综合| 日韩一区二区免费在线观看| 国产婷婷色一区二区三区| 亚洲免费在线视频一区 二区| 亚洲成人手机在线| 国产乱码一区二区三区| 99久久精品情趣| 欧美顶级少妇做爰| 久久久精品黄色| 亚洲在线视频一区| 久久er99热精品一区二区| 成人免费看黄yyy456| 欧美卡1卡2卡| 国产欧美久久久精品影院| 亚洲综合免费观看高清完整版在线 | 久久草av在线| 91美女在线看| 久久婷婷国产综合精品青草| 日韩理论片在线| 九一九一国产精品| 97国产精品videossex| 日韩精品一区二区在线观看| 中文字幕一区在线观看视频| 日本在线播放一区二区三区| 懂色av中文字幕一区二区三区| 欧美日韩免费观看一区二区三区 | 国产精品美女久久久久久久| 亚洲精品高清视频在线观看| 韩国一区二区三区| 欧洲精品视频在线观看| 精品久久久久久久人人人人传媒| 亚洲另类在线制服丝袜| 精品亚洲成a人| 欧美性猛交xxxx乱大交退制版 | 一二三四社区欧美黄| 国产美女娇喘av呻吟久久| 亚洲国产精品高清| 亚洲特级片在线| 国产精品一品二品| 制服丝袜中文字幕一区| 亚洲欧洲av色图| 国产一区二区三区电影在线观看| 欧美日韩国产电影| 亚洲欧美另类在线| 粉嫩绯色av一区二区在线观看| 日韩一区二区三区av| 亚洲国产美国国产综合一区二区| 成人国产精品免费观看动漫| 精品国产乱码91久久久久久网站| 亚洲不卡在线观看| 91视频一区二区| 欧美国产日韩在线观看| 激情偷乱视频一区二区三区| 91精品国产高清一区二区三区| 夜夜嗨av一区二区三区网页| 播五月开心婷婷综合| 欧美精品一区二| 激情文学综合丁香| 日韩欧美的一区二区| 奇米影视在线99精品| 91麻豆精品国产综合久久久久久 | 亚洲免费毛片网站| 91在线丨porny丨国产| 国产精品免费视频网站| 国产成人午夜精品5599| 国产婷婷一区二区| 国产精品一区二区在线观看网站| 精品免费日韩av| 经典一区二区三区| 国产亚洲一区二区三区在线观看| 国模冰冰炮一区二区| 久久久精品人体av艺术| 国产精品自拍在线| 国产欧美日产一区| www.在线欧美| 最新高清无码专区| 色综合天天性综合| 亚洲精品国产无套在线观| 色伊人久久综合中文字幕| 亚洲久本草在线中文字幕| 91丝袜呻吟高潮美腿白嫩在线观看| 国产精品网曝门| 91视频在线观看| 亚洲国产一区二区视频| 制服丝袜av成人在线看| 美女视频一区在线观看| 久久久久久电影| 99久久婷婷国产| 亚洲一二三四在线观看| 欧美日韩国产片| 美腿丝袜亚洲一区| 国产色产综合色产在线视频| 99国产精品久久久| 亚洲国产中文字幕在线视频综合| 欧美日韩精品免费观看视频| 日韩成人伦理电影在线观看| 26uuu国产电影一区二区| 懂色av噜噜一区二区三区av| 亚洲欧美日韩国产综合| 欧美精品一级二级三级| 久久精品国产免费| 国产精品久久777777| 在线亚洲一区观看| 蜜臀av性久久久久蜜臀aⅴ| 国产清纯白嫩初高生在线观看91| 色哟哟在线观看一区二区三区| 日本伊人精品一区二区三区观看方式| 日韩精品一区在线观看| 99九九99九九九视频精品| 日韩精彩视频在线观看| 2020国产精品| 色狠狠桃花综合| 麻豆成人久久精品二区三区红| 欧美激情一区二区三区在线| 在线精品视频一区二区三四| 黄一区二区三区| 依依成人精品视频| 欧美精品一区二区三区蜜桃 | 国产偷国产偷亚洲高清人白洁| 91免费观看在线| 捆绑调教美女网站视频一区| 最近日韩中文字幕| 精品久久久久一区| 91精品办公室少妇高潮对白| 蜜臀av一区二区在线免费观看 | 国产一区二区不卡在线 | 成人国产亚洲欧美成人综合网| 亚洲高清视频在线| 欧美激情一区二区三区| 91精品国产入口| 色哟哟国产精品| 国产精品456露脸| 日日夜夜免费精品| 1000精品久久久久久久久| 日韩精品一区国产麻豆| 欧美在线观看18| 精品美女在线观看| 激情偷乱视频一区二区三区| 一区二区欧美视频| 国产无人区一区二区三区| 欧美福利一区二区| 91麻豆6部合集magnet| 黑人巨大精品欧美黑白配亚洲| 亚洲成人av一区二区三区| 国产精品久久久久久久岛一牛影视 | 国产精品午夜春色av| 欧美xxxx老人做受| 欧美久久久影院| 91天堂素人约啪| 粉嫩aⅴ一区二区三区四区五区 | 一本大道久久精品懂色aⅴ| 国产一区二区三区蝌蚪| 日韩一区欧美二区| 亚洲国产精品人人做人人爽| 亚洲男女一区二区三区| 国产精品久久久久久久浪潮网站| 精品久久久久久久久久久久久久久 | 99re在线精品| 成人午夜电影久久影院| 国产一区二区美女| 麻豆成人久久精品二区三区小说| 午夜精品久久久久久久蜜桃app| 亚洲欧洲韩国日本视频| 中文字幕精品—区二区四季| 久久久久久久综合| 2020日本不卡一区二区视频| 日韩亚洲欧美高清| 91精品国产91久久综合桃花| 欧美日韩一级视频| 欧美视频自拍偷拍| 欧美亚洲动漫制服丝袜|