亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
亚洲裸体xxx| 欧美国产日本韩| 国产精品私房写真福利视频| 偷拍自拍另类欧美| www.亚洲人| www一区二区| 天天色天天操综合| 91啪亚洲精品| 国产日韩精品一区| 麻豆精品久久久| 欧美天堂亚洲电影院在线播放| 久久亚洲一区二区三区四区| 五月婷婷色综合| 91一区在线观看| 日本一区二区三区久久久久久久久不| 肉色丝袜一区二区| 欧美亚洲精品一区| 亚洲色图欧洲色图| 国产 日韩 欧美大片| 欧美xxxxx裸体时装秀| 91欧美激情一区二区三区成人| 久久人人97超碰com| 日韩二区在线观看| 欧美日韩免费高清一区色橹橹 | 国产一区二区电影| 欧美一区二区性放荡片| 亚洲国产精品一区二区久久| 99这里只有精品| 亚洲国产精品成人综合 | 亚洲天堂网中文字| 成人av资源网站| 中文一区二区完整视频在线观看| 久久66热偷产精品| 日韩午夜电影在线观看| 日韩av电影免费观看高清完整版在线观看| 在线观看亚洲a| 一区二区三区 在线观看视频| 91在线看国产| 亚洲女同ⅹxx女同tv| 99久久亚洲一区二区三区青草| 国产精品热久久久久夜色精品三区 | 欧美少妇xxx| 亚洲一区二区在线视频| 欧美性猛片aaaaaaa做受| 亚洲乱码精品一二三四区日韩在线| 成人av在线网| 中文字幕一区二区三区不卡在线| 成人av电影免费在线播放| 国产精品私房写真福利视频| 99久免费精品视频在线观看| 亚洲欧洲美洲综合色网| 99视频精品全部免费在线| 亚洲女人****多毛耸耸8| 在线这里只有精品| 婷婷成人综合网| 91精品国产一区二区人妖| 青青草国产精品亚洲专区无| 欧美一区二区三区免费观看视频| 看片的网站亚洲| 久久精品日韩一区二区三区| 国产成a人无v码亚洲福利| 欧美国产乱子伦| 99视频热这里只有精品免费| 亚洲在线视频一区| 91精品国产综合久久精品app | 国产拍欧美日韩视频二区| 99久久精品国产毛片| 亚洲精品第1页| 欧美酷刑日本凌虐凌虐| 欧美四级电影网| 亚洲一区二区高清| 欧美一二三在线| 国产精品夜夜嗨| 亚洲天堂精品视频| 欧美日韩性生活| 久久97超碰国产精品超碰| 国产精品丝袜91| 91福利视频网站| 久久精品国产澳门| 国产精品久久久久一区二区三区共| 色欧美乱欧美15图片| 麻豆久久久久久| 国产精品免费aⅴ片在线观看| 在线亚洲欧美专区二区| 蜜桃久久精品一区二区| 国产日韩av一区二区| 欧美艳星brazzers| 国产麻豆精品视频| 一区二区久久久久| 欧美成人aa大片| 99久久精品情趣| 免费观看久久久4p| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 欧美在线综合视频| 国模少妇一区二区三区| 亚洲色图另类专区| 欧美大片一区二区| 91亚洲精品久久久蜜桃网站| 蜜臀久久久99精品久久久久久| 国产精品系列在线| 欧美一区二区三区公司| 99视频精品在线| 久久国产欧美日韩精品| 亚洲精品写真福利| 久久精品网站免费观看| 精品1区2区3区| 成人精品一区二区三区四区 | 欧美激情一区二区三区四区| 欧美日韩中文另类| gogogo免费视频观看亚洲一| 日韩不卡在线观看日韩不卡视频| 国产精品丝袜久久久久久app| 91精品欧美久久久久久动漫| 懂色av一区二区夜夜嗨| 日日夜夜免费精品| 亚洲精品日韩专区silk| 国产午夜精品福利| 91精品国产全国免费观看| 91丨九色丨蝌蚪富婆spa| 国模一区二区三区白浆| 五月天久久比比资源色| 一区二区中文视频| 久久精品视频一区二区三区| 欧美一区二区三区免费大片| 色播五月激情综合网| 国产精品1024久久| 日本不卡免费在线视频| 亚洲综合在线五月| 国产精品久久国产精麻豆99网站 | 91免费看视频| 国产毛片精品一区| 免费一级欧美片在线观看| 一区二区三区不卡在线观看 | 亚洲男人的天堂在线aⅴ视频| 久久网站最新地址| 日韩视频免费直播| 欧美精品1区2区3区| 91成人在线精品| 丁香一区二区三区| 国产乱国产乱300精品| 久久国产日韩欧美精品| 蜜桃视频一区二区三区| 丝瓜av网站精品一区二区| 伊人色综合久久天天人手人婷| 国产精品久久久久天堂| 国产午夜精品福利| 久久久99免费| 久久综合九色综合欧美亚洲| 日韩精品一区二区三区视频在线观看 | 亚洲一区在线观看免费| 亚洲精品乱码久久久久久 | 欧美日韩国产123区| 欧洲视频一区二区| 91国模大尺度私拍在线视频| 色综合色综合色综合| 99久久99久久精品免费看蜜桃| 成人激情校园春色| caoporn国产精品| k8久久久一区二区三区 | 男女男精品视频| 三级成人在线视频| 蜜臀av性久久久久蜜臀aⅴ四虎| 日欧美一区二区| 日韩国产欧美在线播放| 免费在线观看精品| 久久国产精品72免费观看| 捆绑调教美女网站视频一区| 极品少妇一区二区三区精品视频 | 亚洲免费大片在线观看| 亚洲欧美视频一区| 亚洲一区自拍偷拍| 亚洲成人中文在线| 日韩av电影天堂| 韩国三级电影一区二区| 国产精品1区2区| 成人91在线观看| 色婷婷精品久久二区二区蜜臀av | 国产成人精品aa毛片| 成人av资源网站| 91国偷自产一区二区三区成为亚洲经典 | 亚洲欧美激情在线| 亚洲一区二区三区爽爽爽爽爽 | 久久久精品天堂| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 国产乱淫av一区二区三区 | av电影在线观看一区| av亚洲精华国产精华精华 | 国模一区二区三区白浆| 丁香婷婷综合五月| 日本高清不卡aⅴ免费网站| 欧美日韩一区视频| 日韩你懂的电影在线观看| 国产亚洲人成网站| 亚洲美女在线国产| 日韩国产精品大片| 国产成人免费在线观看| 色综合久久中文字幕综合网| 欧美电影在哪看比较好| 久久精品日产第一区二区三区高清版 | 91麻豆精品在线观看|