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

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

?? preproc.c

?? 本程序集是Allen I. Holub所寫的《Compiler Design in C》一書的附隨軟件
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*                               `
 * 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
 *
 */
#include        <stdio.h>
#include 				<ctype.h>
#include				"utype.h"
#include				"cmdline.h"
#include        "expr.h"
#include        "c.h"
#include        "errors.h"
#include				"time.h"

extern short inputline[];
extern FILE *inputFile;
extern TABLE gsyms,defsyms;
extern long ival;
extern char laststr[];
extern HASHREC **defhash;
extern char *infile;
extern int incconst;
extern char *prm_searchpath;
extern int prm_cplusplus, prm_ansi;
extern short *lptr;
extern int cantnewline;
extern char *infile;
extern int backupchar;
extern int floatregs,dataregs,addrregs,basefr,basedr,basear;
extern int prm_cmangle;
extern enum e_sym lastst;
extern char lastid[];
extern int lastch;
extern int lineno;
extern int global_flag;
typedef struct _list {
		struct _list *link;
		char *data;
} LIST;
typedef struct _startups_ {
		struct _startups_ *link;
		char *name;
		int prio;
} STARTUPS;
char *errfile;
int errlineno = 0;
IFSTRUCT			  *ifshold[10];
char 						*inclfname[10];
FILE            *inclfile[10];
int             incldepth = 0;
int             inclline[10];
short            *lptr;
LIST *incfiles = 0,*lastinc;

IFSTRUCT *ifs = 0;
int ifskip = 0;
int elsetaken = 0;

void filemac(short *string);
void datemac(short *string);
void timemac(short *string);
void linemac(short *string);

static char *unmangid;		/* In this module we have to ignore leading underscores */
static STARTUPS *startuplist, *rundownlist;
static short defkw[] = { 'd','e','f','i','n','e','d', 0 };

/* List of standard macros */
#define INGROWNMACROS 4

struct inmac {
		char *s;
		void (*func)();
} ingrownmacros[INGROWNMACROS] = { 
			{ "__FILE__",filemac }, { "__DATE__",datemac, },
			{ "__TIME__", timemac }, { "__LINE__",linemac } };

void pushif(void);

/* Moudle init */
void preprocini()
{
	floatregs = basefr;
	dataregs = basedr;
	addrregs = basear;
	incldepth = 0;
	incfiles = 0;
	ifs = 0;
	ifskip = elsetaken = 0;
	unmangid = lastid;
	if (prm_cmangle)
		unmangid++;
	startuplist = rundownlist = 0;
}
/* Preprocessor dispatch */
int preprocess(void)
{
        ++lptr;
        lastch = ' ';
        getsym();               /* get first word on line */

        if( lastst != id  && lastst != kw_else && lastst!= kw_if) {
                generror(ERR_IDEXPECT,0,0);
                return incldepth == 0;
                }
        if( strcmp(unmangid,"include") == 0 )
                return doinclude();
        else if( strcmp(unmangid,"define") == 0 )
                return dodefine();
				else if (strcmp(unmangid,"endif") == 0)
								return doendif();
				else if (lastst == kw_else)
								return doelse();
				else if (strcmp(unmangid,"ifdef") == 0)
								return doifdef(TRUE);
				else if (strcmp(unmangid,"ifndef") == 0)
								return doifdef(FALSE);
				else if (lastst == kw_if) {
								repdefines(lptr);
								defcheck(lptr);
								return doif(0);
				}
        else if( strcmp(unmangid,"elif") == 0 ) {
								repdefines(lptr);
								defcheck(lptr);
                return doelif();
				}
				else if (strcmp(unmangid,"undef") == 0)
								return(doundef());
				else if (strcmp(unmangid,"error") == 0)
								return(doerror());
				else if (strcmp(unmangid,"pragma") == 0)
								return(dopragma());
				else if (strcmp(unmangid,"line") == 0)
								return(doline());
        else    {
                gensymerror(ERR_PREPROCID,unmangid);
                return incldepth == 0;
                }
}

int doerror(void)
{
	char *temp;
	int i=0;
	if (ifskip)
		return incldepth == 0;
	global_flag++;
	temp = xalloc(pstrlen(lptr)*3+2);
	pstrcpy(temp,lptr);
	while (*lptr)
		i+=installphichar(*lptr++,temp,i);
	temp[i-1] = 0;
	global_flag--;
	basicerror(ERR_ERROR,temp);
	return incldepth == 0;
}
int dopragma(void)
{
	char buf[40],*p=buf;
  STARTUPS *a;
	int val = 0,sflag;
	if (ifskip)
		return incldepth == 0;
	lineToCpp();
	getsym();
	if (lastst != id)
		return incldepth == 0;
	if (!strcmp(unmangid,"startup"))
		sflag = 1;
	else if (!strcmp(unmangid,"rundown"))
		sflag = 0;
	else if (!strncmp(unmangid,"regopt",6)) {
		short *s = lptr;
		dataregs = floatregs = addrregs = 0;
		while (*s != '\n') {
			switch (*s) {
				case 'a':
				case 'A':
					addrregs = 1;
					break;
				case 'f':
				case 'F':
					floatregs = 1;
					break;
				case 'd':
				case 'D':
					dataregs = 1;
					break;
			}
			s++;
		}
		return incldepth == 0;
	}
	else return incldepth == 0;

	if (prm_cmangle)	
		*p++ = '_';
	while (isalnum(*lptr) || *lptr == '_')
		*p++=*lptr++;
	*p=0;
	while (*lptr && (*lptr == ' ' || *lptr == '\t' || *lptr == ','))
		lptr++;
	if (*lptr  && *lptr != '\n' && !isdigit(*lptr)) {
		generror(ERR_ILLCHAR,*lptr,0);
		while (*lptr)
			lptr++;
	}

	if (isdigit(*lptr))
		while (isdigit(*lptr)) {
			val *= 10;
			val += (*lptr++)-'0';
		}
	else
		val = 64;
	++global_flag;
	a = xalloc(sizeof(STARTUPS));
	a->name = litlate(buf);
	a->prio = val;
  if (sflag) {
		a->link = startuplist;
		startuplist = a;
	}
	else {
		a->link = rundownlist;
		rundownlist = a;
	}
	--global_flag;
	while (*lptr && (*lptr == ' ' || *lptr == '\t'))
		lptr++;
	if (*lptr  && *lptr != '\n')
		generror(ERR_ILLCHAR,*lptr,0);
	return incldepth == 0;
}
void dumpstartups(void)
/*
 * Dump references to startup/rundown code
 */
{
	SYM *s;
	if (startuplist) {
		startupseg();
		while (startuplist) {
			s = search(startuplist->name,&gsyms);
			if (!s || s->tp->type != bt_ifunc)
				gensymerror(ERR_UPDOWN,startuplist->name);
			else  {
				gensrref(s,startuplist->prio);
				s->tp->uflags |= UF_USED;
			}
			startuplist = startuplist->link;
		}
	}
	if (rundownlist) {
		rundownseg();
		while (rundownlist) {
			s = search(rundownlist->name,&gsyms);
			if (!s || s->tp->type != bt_ifunc)
				gensymerror(ERR_UPDOWN,rundownlist->name);
			else {
				gensrref(s,rundownlist->prio);
				s->tp->uflags |= UF_USED;
			}
			rundownlist = rundownlist->link;
		}
	}
}
int doline(void)
/*
 * Handle #line directive
 */
{
	int n;
	getsym();
	if (lastst != iconst) 
		gensymerror(ERR_PREPROCID,"#line");
	else {
		n = ival;
		getsym();
		if (lastst != sconst) 
			gensymerror(ERR_PREPROCID,"#line");
		else 
			if (!ifskip) {
				errfile = litlate(laststr);
				errlineno = n-1;
			}
	}
	return incldepth == 0;
}
int doinclude(void)
/*
 * HAndle include files
 */
{       int     rv;
				FILE *oldfile = inputFile;
				incconst = TRUE;
        getsym();               /* get file to include */
				incconst = FALSE;
				if (ifskip)
					return incldepth == 0;
        if( lastst != sconst ) {
                gensymerror(ERR_INCLFILE,"include");
                return incldepth == 0;
                }
				if (incldepth > 9) {
					generror(ERR_PREPROCID, 0,0);
					return incldepth == 0;
				}
        inputFile = SearchPath(laststr,prm_searchpath,"r");
        if( inputFile == 0 ) {
                gensymerror(ERR_CANTOPEN,laststr);
                inputFile = oldfile;
                rv = incldepth == 0;
                }
        else    {
								LIST *list;
								pushif();
								ifshold[incldepth] = ifs;
								elsetaken = 0;
								ifskip = 0;
								ifs = 0;
				        inclline[incldepth] = lineno;
        				inclfile[incldepth] = oldfile;  /* push current input file */
								inclfname[incldepth++] = infile;
								global_flag++;
								infile = litlate(laststr);
								list = xalloc(sizeof(LIST));
								list->data = infile;
								list->link = 0;
								if (incfiles)
									lastinc = lastinc->link = list;
								else
									incfiles = lastinc = list;
								errfile = infile;
								errlineno = 0;
								global_flag--;
                rv = incldepth == 1;
                lineno = 0;
                }
        return rv;
}

short *plitlate(short *string)
{
	short *temp = xalloc(pstrlen(string)*sizeof(short)+sizeof(short));
	pstrcpy(temp,string);
	return temp;
}
void glbdefine(char *name, char*value)
{
{       SYM     *sp;
				short *p;
				DEFSTRUCT *def;
				if (( sp = search(name,&defsyms) )!= 0)
					return;
        ++global_flag;          /* always do #define as globals */
        sp = xalloc(sizeof(SYM));
        sp->name = litlate(name);
				def = xalloc(sizeof(DEFSTRUCT));
				def->args = 0;
				def->argcount = 0;
				def->string = p = xalloc(strlen(value)*sizeof(short));
				while (*value)
					*p++=*value++;
				*p++=0;
        sp->value.s = (char *) def;
        insert(sp,&defsyms);
        --global_flag;
        return;
}
}
/* Handle #defines
 * Doesn't check for redefine with different value
 * Does handle ANSI macros
 */
int dodefine(void)
{       SYM     *sp;
				DEFSTRUCT *def;
				short *args[40],count=0;
				short *olptr;
				int p;
        getsym();               /* get past #define */
				if (ifskip)
					return incldepth == 0;
				olptr = lptr;
        if( lastst != id ) {
                generror(ERR_IDEXPECT,0,0);
                return incldepth == 0;
                }
				if (( sp = search(unmangid,&defsyms) )!= 0)
					undef2();
        ++global_flag;          /* always do #define as globals */
        sp = xalloc(sizeof(SYM));
        sp->name = litlate(unmangid);
				def = xalloc(sizeof(DEFSTRUCT));
				def->args = 0;
				def->argcount = 0;
				if (lastch == '(') {
					getdefsym();
					getdefsym();
					while (lastst == id) {
						args[count++] = plitlate(unmangid);
						getdefsym();
						if (lastst != comma)
							break;
						getdefsym();
					}
					if (lastst != closepa)
					  generror(ERR_PUNCT,closepa,0);
					olptr = lptr;
					def->args = xalloc(count*sizeof(short *));
					memcpy(def->args,args,count*sizeof(short *));
					def->argcount = count+1;
				}
				while (iswhitespacechar(*olptr))
					olptr++;
				p = pstrlen(olptr);
				if (olptr[p-1] == 0x0a)
					olptr[p-1] = 0;
				def->string = plitlate(olptr);
        sp->value.s = (char *) def;
        insert(sp,&defsyms);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91色在线porny| 国产亚洲短视频| 91麻豆自制传媒国产之光| 久久精品国产亚洲高清剧情介绍| 亚洲欧美日韩久久| 精品国产污网站| 欧美久久一二三四区| 色综合视频一区二区三区高清| 日本成人在线看| 中文字幕一区二区视频| 国产午夜久久久久| 精品日韩在线观看| 欧美色爱综合网| 色婷婷av一区二区三区gif | 国产麻豆成人传媒免费观看| 婷婷综合另类小说色区| 国产精品毛片无遮挡高清| 精品av综合导航| 日韩你懂的在线观看| 日韩一区二区三区免费看| 在线国产电影不卡| 在线观看三级视频欧美| 97久久久精品综合88久久| 成人高清免费观看| www.欧美亚洲| 风间由美一区二区av101 | 国产精品亚洲а∨天堂免在线| 卡一卡二国产精品 | 欧美日韩中文一区| 欧洲精品中文字幕| 91丨porny丨国产| 色婷婷精品久久二区二区蜜臀av | 一本一道久久a久久精品综合蜜臀| 成人性视频网站| 成人网在线免费视频| 国产黑丝在线一区二区三区| 国产91露脸合集magnet| 粉嫩av一区二区三区粉嫩| 成人美女视频在线观看18| 国产综合色视频| 国产激情偷乱视频一区二区三区 | 在线观看一区二区精品视频| 欧美日韩国产123区| 日韩一区二区三区免费观看| 久久久久久久综合狠狠综合| 国产女人aaa级久久久级| 日韩伦理免费电影| 亚洲丝袜自拍清纯另类| 性感美女极品91精品| 紧缚奴在线一区二区三区| 国产成人免费视频| 97国产一区二区| 欧美久久久一区| 精品国产制服丝袜高跟| 亚洲精品一区二区三区在线观看 | 亚洲国产精品视频| 男女性色大片免费观看一区二区| 久久99精品久久久久久动态图| 丁香婷婷综合五月| 顶级嫩模精品视频在线看| 在线91免费看| 久久亚洲综合色一区二区三区| 成人欧美一区二区三区在线播放| 亚洲精品久久嫩草网站秘色| 青青草91视频| av一区二区三区| 91精品啪在线观看国产60岁| 欧美国产视频在线| 亚洲午夜久久久久久久久电影院| 国精产品一区一区三区mba桃花 | 欧美日韩国产大片| 久久久蜜桃精品| 中文字幕一区不卡| 日韩va亚洲va欧美va久久| 粉嫩13p一区二区三区| 欧美日韩一区二区三区高清| 日韩你懂的电影在线观看| 亚洲视频在线一区观看| 国内精品自线一区二区三区视频| 在线视频你懂得一区| 久久精子c满五个校花| 国产精品久久久久久久久快鸭| 五月综合激情网| av在线播放成人| 欧美精品一区二区三| 亚洲影视在线观看| 国产成人av一区二区三区在线 | 7777精品伊人久久久大香线蕉最新版| 国产精品久久精品日日| 国产精品99久久久久久有的能看| 日韩一区二区在线看片| 午夜久久电影网| 色一区在线观看| 亚洲精品你懂的| 91论坛在线播放| 国产精品麻豆欧美日韩ww| 高清成人在线观看| 久久久久88色偷偷免费| 激情五月播播久久久精品| 日韩欧美国产一区二区在线播放| 日韩精品一二区| 欧美一区二区三区免费视频 | 夫妻av一区二区| 久久综合国产精品| 久久不见久久见免费视频1| 91精品国产一区二区| 日韩二区在线观看| 日韩欧美一级二级三级久久久| 美女诱惑一区二区| 精品国产凹凸成av人导航| 紧缚奴在线一区二区三区| 精品sm在线观看| 福利91精品一区二区三区| 国产精品免费久久| 91免费在线播放| 夜夜嗨av一区二区三区网页| eeuss国产一区二区三区| 国产亚洲一区二区三区四区 | 国产女人aaa级久久久级| 欧美极品xxx| 91在线码无精品| 亚洲午夜久久久久久久久电影院 | 欧美综合一区二区| 亚洲国产综合91精品麻豆| 欧美日韩一级视频| 美国一区二区三区在线播放| 精品久久久久久久久久久久久久久 | 7777精品伊人久久久大香线蕉 | 天堂久久一区二区三区| 正在播放一区二区| 韩国三级在线一区| 中文字幕在线播放不卡一区| 在线看国产一区| 美女被吸乳得到大胸91| 国产欧美视频在线观看| 99久久国产综合精品女不卡| 亚洲丰满少妇videoshd| 欧美成人高清电影在线| 成人免费观看男女羞羞视频| 亚洲国产精品一区二区久久| 精品国产91九色蝌蚪| 成人国产精品免费观看动漫| 亚洲大片在线观看| 久久精品亚洲一区二区三区浴池| 97久久精品人人做人人爽| 日本午夜一区二区| 国产亚洲人成网站| 欧美亚男人的天堂| 国产最新精品精品你懂的| 亚洲欧美日韩国产一区二区三区 | 欧美xxxxxxxx| 成人精品国产福利| 婷婷开心激情综合| 国产色一区二区| 欧美日韩一级片在线观看| 国产乱人伦精品一区二区在线观看| 国产欧美综合在线观看第十页| 91久久久免费一区二区| 加勒比av一区二区| 亚洲一区免费视频| 久久青草国产手机看片福利盒子| 在线免费观看成人短视频| 国产高清精品久久久久| 亚洲成人在线免费| 国产精品久久久久久久久图文区| 欧美久久一二三四区| 99视频国产精品| 国产麻豆日韩欧美久久| 亚洲成a人v欧美综合天堂| 国产精品美女久久久久aⅴ国产馆| 制服丝袜亚洲网站| 99re视频精品| 高清不卡一区二区| 美国av一区二区| 亚洲综合久久久久| 中文字幕在线不卡一区二区三区| 日韩美女主播在线视频一区二区三区 | 欧美日韩在线播放三区四区| 成人午夜碰碰视频| 久久精品国产免费| 亚洲超丰满肉感bbw| 亚洲欧美日韩精品久久久久| 国产日韩三级在线| 日韩美女一区二区三区四区| 欧美日韩国产另类一区| 99久久777色| 风间由美一区二区av101| 国产在线精品一区二区夜色| 日韩精品乱码av一区二区| 亚洲柠檬福利资源导航| 中文成人av在线| 亚洲国产精品传媒在线观看| 久久先锋影音av鲁色资源| 日韩欧美国产高清| 8x福利精品第一导航| 欧美视频一区在线| 日本久久一区二区三区| 一本一道久久a久久精品| 99久久er热在这里只有精品15 | 99久久伊人网影院|