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

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

?? preproc.c

?? 本程序集是Allen I. Holub所寫的《Compiler Design in C》一書的附隨軟件
?? C
?? 第 1 頁 / 共 2 頁
字號:
        --global_flag;
        return incldepth == 0;
}
/*
 * Undefine
 */
int doundef(void)
{
	getsym();
	if (!ifskip)
		undef2();
	return(incldepth == 0);
}
int undef2(void)
{
	if (lastst != id) 
    generror(ERR_IDEXPECT,0,0);
	else {
		SYM **p = (SYM **)LookupHash(unmangid,defhash,HASHTABLESIZE);
		if (p) {
			*p = (*p)->next;
		}
	}
}
void getdefsym(void)
{
				if (backupchar != -1) {
					lastst = backupchar;
					backupchar = -1;
					return;
				}
restart:        /* we come back here after comments */
        while(iswhitespacechar(lastch))
                getch();
        if( lastch == -1)
                lastst = eof;
        else if(isdigit(lastch))
                getnum();
        else if(isstartchar(lastch)) {
								lptr--;
                defid(unmangid,&lptr,0);	
								lastch = *lptr++;
								lastst = id;
				}
        else if (getsym2())
					goto restart;
}
int defid(short *name, short **p, char *q)
/*
 * Get an identifier during macro replacement
 */
{
	int count = 0,i=0;
			while (issymchar(**p)) {
				if (count < 100) {
					name[count++] = *(*p);
					if (q)
						i+=installphichar(*(*p),q,i);
				}
				(*p)++;
			}
			if (q) {
				if ((q[i-1] & 0xf0) == 0x90)
					q[i-1] = 0x90;
    	  q[i] = '\0';
			}
	name[count] = 0;
	return(count);
}
/* 
 * Insert a replacement string
 */
int definsert(short *end, short *begin, short * text, int len, int replen)
{
	short *q;
	int i,p, r;
	int val;
	if (begin != inputline) 
		if (*(begin-1) == '#') {
			if (*(begin-2) != '#') {
				begin--;
				replen++;
				r = pstrlen(text);
			
				text[r++] = '\"';
				text[r] = 0;
				for (i=r; i >= 0; i--)
					text[i+1] = text[i];
				*text = '\"';
			}
		}
	p = pstrlen(text);
	val = p - replen;
	r = pstrlen(begin);
	if (val + strlen(begin) >= len-1) {
		generror(ERR_MACROSUBS,0,0);
		return(-8000);
	}
	if (val > 0)
		for (q = begin + r+1; q >= end; q--)
			*(q+val) = *q;
	else
		if (val < 0) {
			r = pstrlen(end)+1;
			for (q = end; q < end+r; q++ )
				*(q+val) = *q;
		}
	for (i=0; i < p; i++)
		begin[i] = text[i]; 
	return(val);
}
/* replace macro args */	
int defreplace(short *macro, int count, short **oldargs, short **newargs)
{
	int i,rv;
	int instring = 0;
	short narg[1024];
	short name[100];
	short *p=macro,*q;
	while (*p) {
		if (*p == instring)
			instring = 0;
		else if (*p == '\'' || *p == '"')
			instring = *p;
		else if (!instring && isstartchar(*p)) {
			q = p;
			defid(name,&p,0);
			for (i=0; i < count; i++)
				if (!pstrcmp(name,oldargs[i])) {
					pstrcpy(narg,newargs[i]);
					if ((rv = definsert(p,q,narg,1024-(q-macro),p-q)) == -8000)
						return(FALSE);
					else {
						p += rv;
						break;
					}
				}
		}
		p++;
	}
	return(TRUE);
}
/* Handlers for default macros */
void cnvt(short *out,char *in)
{
	while (*in) 
		*out++=*in++;
	*out = 0;
}
void filemac(short *string)
{
	char str1[40];
	sprintf(str1,"\"%s\"",infile);
	cnvt(string,str1);
}
void datemac(short *string)
{
	char str1[40];
	struct tm *t1;
	time_t t2;
	time(&t2);
	t1 = localtime(&t2);
 	strftime(str1,40,"\"%b %d %Y\"",t1);
	cnvt(string,str1);
}
void timemac(short *string)
{
	char str1[40];
	struct tm *t1;
	time_t t2;
	time(&t2);
	t1 = localtime(&t2);
	str1[0] = '"';
 	strftime(str1,40,"\"%X\"",t1);
	cnvt(string,str1);
}
void linemac(short *string)
{
	char str1[40];
	sprintf(str1,"%d",lineno);
	cnvt(string,str1);
}
/* Scan for default macros and replace them */
void defmacroreplace(short *macro, short *name)
{
	int i;
	macro[0] = 0;
	for (i=0; i < INGROWNMACROS; i++)
		if (!strcmp(name,ingrownmacros[i].s)) {
			(ingrownmacros[i].func)(macro);
			break;
		}
}
/* Scan line for macros and do replacements */
void defcheck(short *line)
{
	short macro[1024];
	short name[100];
	short *args[40];
	char ascii[60];
	int tryagain = TRUE, changed = FALSE, waiting = FALSE,rv;
	short *p = line,*q;
	SYM *sp;
	while (tryagain) {
		p = line;
		tryagain = FALSE;
		while(*p) {
			q = p;
			if (*p == '"') {
				waiting = !waiting;
				p++;
			}
			else if (waiting)
				p++;
			else if (isstartchar(*p)) {
				defid(name,&p,ascii);
				if ((sp = search(ascii,&defsyms)) != 0) {
					DEFSTRUCT *def = sp->value.s;
					pstrcpy(macro,def->string);
					if (def->argcount) {
						int count = 0;
						short *q = p;
							while (iswhitespacechar(*q))
								q++;
						if (*q++ != '(')
							goto join;
						p = q;
						if (def->argcount > 1) {
							do {
								short *nm = name;
								int nestedparen = 0;
								while (((*p != ',' && *p != ')') || nestedparen) && *p != '\n') {
										if (*p == '(')
											nestedparen++;
										if (*p == ')' && nestedparen)
											nestedparen--;
										*nm++ = *p++;
								}
								while (iswhitespacechar(*(nm-1)))
									nm--;
								*nm = 0;
								nm = name;
								while (iswhitespacechar(*nm))
									nm++;
								args[count++] = plitlate(nm);
							} while (*p++ == ',');
						}
						else while (iswhitespacechar(*p++));
						if (*(p-1) != ')' || count != def->argcount-1) {
							generror(ERR_MACROSUBS,0,0);
							return;
						}
						/* Can't replace if tokenizing next */
						if (*p == '#' && *(p+1) == '#')
							continue;
						if (count == 0)
							goto insert;
						if (!defreplace(macro,count,def->args,args))
							return;
					}
insert:
					if ((rv=definsert(p,q,macro,4096-(q-line),p-q))==-8000)
						return;
					p+=rv;
					changed = tryagain = TRUE;
				}
				else {
join:
					defmacroreplace(macro,ascii);
					if (macro[0]) {
						if ((rv=definsert(p,q,macro,4096-(q-line),p-q))==-8000)
							return;
						p += rv;
						changed = TRUE;
					}
				}
			}
			else p++;
		}
	}
	/* Token pasting */
	if (changed) {
		p = q = line;
		while (*p) {
			if (*p == '#' && *(p+1) == '#')
				p+=2;
			else
				*q++ = *p++;
		}
		*q = 0;
	}
}
static void repdefines(short *lptr)
/*
 * replace 'defined' keyword in #IF and #ELIF statements
 */
{
	short *q = lptr;
	short name[40];
	char ascii[60];
	while (*lptr) {
		if (!pstrncmp(lptr,defkw,7)) {
			lptr +=7;
			if (*lptr == '(') 
				lptr++;
			else 
		 		expecttoken(openpa,0);
      while(iswhitespacechar(*lptr))
              lptr++;
			defid(name,&lptr,ascii);
      while(iswhitespacechar(*lptr))
              lptr++;
			if (*lptr == ')')
				lptr++;
			else
				expecttoken(closepa,0);
			if (search(ascii,&defsyms) != 0)
				*q++ = '1';
			else
				*q++ = '0';
			*q++ = ' ';
				
		}
		else {
			*q++ = *lptr++;
		}
	}
  *q = 0;
}
void pushif(void)
/* Push an if context */
{
	IFSTRUCT *p;
	global_flag++;
	p = xalloc(sizeof(IFSTRUCT));
	global_flag--;
	p->link = ifs;
	p->iflevel = ifskip;
	p->elsetaken = elsetaken;
	elsetaken = FALSE;
	ifs = p;
}
void popif(void)
/* Pop an if context */
{
	if (ifs) {
		ifskip = ifs->iflevel;
		elsetaken = ifs->elsetaken;
		ifs = ifs->link;
	}
	else {
		ifskip = 0;
		elsetaken = 0;
	}
}	
void ansieol(void)
{
	if (prm_ansi) {
		while (iswhitespacechar(*lptr))
			lptr++;
		if (*lptr) {
			lastch = *lptr;
			lastst = kw_if;
			generror(ERR_UNEXPECT,0,0);
		}
	}
}
int doifdef (int flag)
/* Handle IFDEF */
{
	SYM *sp;
	getch();
	while(isspace(lastch))
		getch();
	if (!isstartchar(lastch)) {
    generror(ERR_IDEXPECT,0,0);
    return incldepth == 0;
	}
	else
		getid();
 	sp = search(unmangid,&defsyms);
  pushif();
	if (sp && !flag || !sp && flag)
		ifskip = TRUE;
	ansieol();
	return(incldepth == 0);
}
int doif(int flag)
/* Handle #if */
{
	getsym();
  pushif();
	cantnewline = TRUE;
	if (!intexpr(0))
		ifskip = TRUE;
	cantnewline = FALSE;
	ansieol();
	return(incldepth == 0);
}
int doelif(void)
/* Handle #elif */
{
	int is;
	getsym();
	cantnewline = TRUE;
	is = !intexpr(0);
	cantnewline = FALSE;
	if (ifs) {
		if (!ifs->iflevel)
			ifskip = !ifskip || is || elsetaken;
			if (!ifskip)
				elsetaken = TRUE;
	}
	else
		generror(ERR_PREPROCMATCH,0,0);
	ansieol();
	return(incldepth == 0);
}
/* handle else */
int doelse(void)
{
	if (ifs) {
		if (!ifs->iflevel)
			ifskip = !ifskip || elsetaken;
	}
	else
		generror(ERR_PREPROCMATCH,0,0);
	ansieol();
	return(incldepth == 0);
}
/* HAndle endif */
int doendif(void)
{
	if (!ifs)
		generror(ERR_PREPROCMATCH,0,0);
	popif();
	ansieol();
	return(incldepth == 0);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美日韩综合| 成人午夜激情片| 亚洲青青青在线视频| 久久影视一区二区| 中文字幕一区二区不卡| 久久免费午夜影院| 亚洲国产精品精华液2区45| 久久久久国产精品厨房| 中文字幕av一区二区三区| 国产精品萝li| 亚洲另类中文字| 天涯成人国产亚洲精品一区av| 性久久久久久久久久久久| 免费亚洲电影在线| 国产精品一二三四五| 福利一区在线观看| 在线视频你懂得一区| 在线电影一区二区三区| 日韩精品最新网址| 久久只精品国产| 一区二区三区成人| 久久精品国产精品亚洲综合| 国产一区二区三区电影在线观看| 国产91对白在线观看九色| 成人激情免费网站| 欧美日韩电影在线| 久久久精品tv| 一区二区三区在线免费观看| 日本在线不卡一区| 成人免费视频一区二区| 欧洲精品一区二区三区在线观看| 日韩一区二区三区三四区视频在线观看| 欧美成人video| 亚洲精品免费在线播放| 麻豆视频一区二区| av午夜精品一区二区三区| 欧美精选在线播放| 亚洲国产精品黑人久久久| 五月激情综合网| 高清久久久久久| 欧美嫩在线观看| 亚洲国产精品t66y| 首页国产丝袜综合| 不卡av电影在线播放| 在线播放/欧美激情| 日韩一区欧美小说| 久久99热狠狠色一区二区| 91福利在线观看| 中文字幕精品—区二区四季| 日韩精品久久理论片| 99久久综合精品| 久久美女艺术照精彩视频福利播放| 亚洲女同女同女同女同女同69| 久久成人久久爱| 欧美精品久久99久久在免费线| 国产精品传媒在线| 丁香婷婷综合五月| 精品久久人人做人人爱| 视频一区二区三区在线| 99久久99久久精品免费看蜜桃| 欧美精品一区二区三区高清aⅴ | a级高清视频欧美日韩| 欧美videofree性高清杂交| 日韩高清在线电影| 欧美日韩一区二区在线观看| 亚洲少妇30p| av电影天堂一区二区在线观看| 久久久久国产精品人| 国内久久精品视频| 精品区一区二区| 精品无人码麻豆乱码1区2区 | 在线观看区一区二| 亚洲欧美自拍偷拍色图| 国产精品一区二区三区99| 日韩免费成人网| 欧美aaaaa成人免费观看视频| 欧美午夜精品久久久久久孕妇| 亚洲乱码日产精品bd| 91浏览器入口在线观看| 一区二区三区四区中文字幕| 色悠悠久久综合| 玉足女爽爽91| 欧美裸体一区二区三区| 麻豆国产91在线播放| 精品国产乱码久久久久久图片| 精品一区二区成人精品| 久久精品欧美一区二区三区麻豆 | 亚洲综合免费观看高清完整版在线 | 麻豆久久一区二区| 26uuu另类欧美亚洲曰本| 韩国精品主播一区二区在线观看| 国产网站一区二区| 92国产精品观看| 亚洲综合在线第一页| 6080日韩午夜伦伦午夜伦| 麻豆精品一区二区综合av| 国产精品情趣视频| 一道本成人在线| 日本欧美大码aⅴ在线播放| 26uuu国产日韩综合| 99久久精品国产一区二区三区| 亚洲一区二区三区四区五区黄| 欧美人伦禁忌dvd放荡欲情| 国内外成人在线| 亚洲男人天堂一区| 亚洲精品在线电影| 在线观看欧美日本| 国模冰冰炮一区二区| 一区二区日韩电影| 久久久久久日产精品| 色老汉av一区二区三区| 国产在线视视频有精品| 亚洲欧美视频在线观看| 26uuu国产在线精品一区二区| 99精品偷自拍| 国产精品一区专区| 天天色 色综合| 国产精品久久久久久福利一牛影视| 欧美日韩免费一区二区三区视频| 久久99久久99| 午夜久久久久久电影| 欧美激情中文字幕| 欧美成人a∨高清免费观看| 在线观看欧美日本| 成人国产精品免费| 欧美aaa在线| 午夜精品视频一区| 亚洲免费观看在线视频| 国产午夜三级一区二区三| 欧美日韩一区二区电影| av高清久久久| 春色校园综合激情亚洲| 国内精品免费**视频| 日日夜夜精品视频天天综合网| 日韩毛片精品高清免费| 国产人成亚洲第一网站在线播放| 日韩午夜激情av| 欧美巨大另类极品videosbest | 国产超碰在线一区| 经典三级在线一区| 美女高潮久久久| 日本中文字幕一区| 日韩精品一级二级| 亚洲国产裸拍裸体视频在线观看乱了 | 777亚洲妇女| 欧美日韩亚洲综合一区二区三区| 97se亚洲国产综合自在线观| 白白色 亚洲乱淫| 成人高清免费在线播放| 国产成人在线看| 国产成人免费xxxxxxxx| 国产成人免费av在线| 国产超碰在线一区| 国产a区久久久| 不卡一二三区首页| 99精品热视频| 在线观看亚洲精品| 91黄色免费版| 欧美日本韩国一区二区三区视频| 欧美日韩视频一区二区| 91麻豆精品久久久久蜜臀| 5858s免费视频成人| 日韩精品一区二区三区四区视频| 欧美成人乱码一区二区三区| 日韩视频一区二区在线观看| 欧美一级日韩免费不卡| 亚洲444eee在线观看| 久久九九久久九九| 亚洲欧洲另类国产综合| 亚洲色欲色欲www在线观看| 亚洲一区二区三区在线| 日韩av在线免费观看不卡| 久88久久88久久久| 国产老女人精品毛片久久| 成人白浆超碰人人人人| 91蜜桃传媒精品久久久一区二区| 精品一区二区三区影院在线午夜| 亚洲成人一区二区在线观看| 亚洲bt欧美bt精品| 国产麻豆成人传媒免费观看| 福利一区二区在线| 不卡免费追剧大全电视剧网站| 欧美日韩一区二区三区不卡| 欧美精品一区二区三区很污很色的| 国产精品国产三级国产| 青青国产91久久久久久| 成人av在线网站| 日韩一级在线观看| 91精品国产综合久久精品app| 亚洲国产综合人成综合网站| 日韩福利电影在线观看| 国产成人一区二区精品非洲| 欧美性猛片xxxx免费看久爱 | 亚洲综合一区二区三区| 亚洲一区视频在线| 国产一区二区精品在线观看| 欧美午夜视频网站| 亚洲精品一区在线观看| 亚洲午夜激情av| 99这里都是精品|