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

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

?? preproc.c

?? 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一区二区三区免费野_久草精品视频
色婷婷久久久亚洲一区二区三区| 亚洲精品一区在线观看| 日本欧美肥老太交大片| 亚洲国产高清aⅴ视频| 美女久久久精品| 秋霞成人午夜伦在线观看| 日本va欧美va瓶| 激情五月婷婷综合| 久久99久久久欧美国产| 国产精品一色哟哟哟| av在线一区二区| 欧美性猛片aaaaaaa做受| 91精品国产综合久久国产大片| 51午夜精品国产| 国产欧美日本一区视频| 亚洲欧洲国产日韩| 亚洲精品国产精华液| 日本欧美在线看| 国产91精品入口| 欧美日韩国产综合视频在线观看 | 亚洲永久精品国产| 婷婷六月综合亚洲| 天涯成人国产亚洲精品一区av| 老司机午夜精品| 成人免费三级在线| 欧美一区二区三区电影| 国产精品视频一二| 日本va欧美va欧美va精品| 成人午夜视频网站| 日韩欧美在线影院| 亚洲高清视频在线| aaa欧美日韩| 9191久久久久久久久久久| 国产片一区二区| 香蕉av福利精品导航| 成人午夜精品一区二区三区| 麻豆精品视频在线观看视频| 欧美一区二区人人喊爽| 色成年激情久久综合| 亚洲日本一区二区三区| 久久99久久99精品免视看婷婷| 欧美色视频一区| 麻豆成人久久精品二区三区红| 欧美tickling网站挠脚心| 91色乱码一区二区三区| 亚洲女人小视频在线观看| 六月丁香婷婷色狠狠久久| 一本色道久久加勒比精品| 中文字幕免费一区| 日韩不卡一区二区三区| 精品国产sm最大网站免费看| 久久久久久日产精品| 午夜精品福利久久久| 色综合久久久久久久久久久| 久久伊99综合婷婷久久伊| 美国十次综合导航| 在线不卡a资源高清| 亚洲一区二区三区四区的| 成人午夜av电影| 久久五月婷婷丁香社区| 日韩vs国产vs欧美| 欧美电影在线免费观看| 午夜久久久久久久久久一区二区| 91福利国产成人精品照片| 亚洲少妇30p| 国产黑丝在线一区二区三区| 欧美成人精品二区三区99精品| 亚洲第一综合色| 欧美三级三级三级爽爽爽| 亚洲免费观看高清完整版在线| 国产精品一二三区| 337p粉嫩大胆噜噜噜噜噜91av| 青青草国产精品97视觉盛宴| 欧美肥妇bbw| 蜜桃久久久久久| 精品女同一区二区| 欧美aa在线视频| 精品女同一区二区| 高清国产一区二区| 国产精品久久久久久久久免费相片 | 成人精品高清在线| 欧美日韩精品一区二区天天拍小说| 日韩高清中文字幕一区| 日韩黄色一级片| 蜜臀精品久久久久久蜜臀| 久久精品国产第一区二区三区| 一区二区三区鲁丝不卡| 亚洲精品v日韩精品| 一区二区三区日本| 精品日韩成人av| 国产一区二区免费看| 国产日本欧美一区二区| 男女性色大片免费观看一区二区 | 色丁香久综合在线久综合在线观看| 国产精品福利电影一区二区三区四区| jvid福利写真一区二区三区| 亚洲三级在线免费观看| 在线观看亚洲专区| 欧美精品亚洲二区| 国产亚洲午夜高清国产拍精品| 成人午夜免费视频| 亚洲国产美国国产综合一区二区| 色素色在线综合| 水野朝阳av一区二区三区| 精品欧美一区二区在线观看| av在线不卡免费看| 日韩av一级电影| 中文字幕佐山爱一区二区免费| 91黄色免费版| 国产永久精品大片wwwapp| 中文字幕亚洲精品在线观看| 欧美久久久久久蜜桃| 懂色一区二区三区免费观看| 亚洲一区日韩精品中文字幕| www一区二区| 91福利社在线观看| 亚洲成人动漫精品| 波多野结衣亚洲一区| 蜜桃av一区二区| 欧美精品视频www在线观看| 中文字幕五月欧美| 欧美aa在线视频| 91精品国产入口在线| 亚洲综合视频在线观看| 成人黄色在线看| 1024精品合集| 日韩激情视频在线观看| 欧美日韩视频不卡| 国产成人午夜高潮毛片| 亚洲欧美另类小说| 国产色爱av资源综合区| 91精品视频网| 99视频在线精品| 高清久久久久久| 激情五月激情综合网| 亚洲大型综合色站| 亚洲欧美日韩国产综合在线| 久久综合色综合88| 在线观看日韩一区| 成人av免费网站| 国产一区二区0| 亚洲h在线观看| 亚洲综合色成人| 日韩一区中文字幕| 欧美激情艳妇裸体舞| 精品欧美一区二区三区精品久久| 欧美精品自拍偷拍| 在线精品视频免费观看| 成人免费三级在线| 国产91在线看| 久久精品免费观看| 日韩av高清在线观看| 天堂久久久久va久久久久| 亚洲成人一二三| 在线亚洲一区观看| 夜夜揉揉日日人人青青一国产精品| 国产精品国产三级国产| 精品国产成人系列| ww亚洲ww在线观看国产| 精品国产sm最大网站| 精品国产亚洲在线| 久久日韩精品一区二区五区| 日韩欧美视频一区| 国产福利一区在线观看| 亚洲免费大片在线观看| 日韩欧美一级在线播放| 欧美色图在线观看| 欧美唯美清纯偷拍| 欧美性大战久久久久久久蜜臀 | 国产人成亚洲第一网站在线播放 | 欧美国产精品一区| 久久久av毛片精品| 一区二区三区久久| 欧美aaa在线| 成人免费视频免费观看| 精品视频在线看| 久久亚洲一级片| 一区二区三区在线免费| 免费观看在线色综合| av网站一区二区三区| 欧美精品亚洲一区二区在线播放| 日韩美一区二区三区| 欧美国产国产综合| 亚洲精品乱码久久久久久黑人| 亚洲国产一区二区a毛片| 国产精品一区一区三区| 色老综合老女人久久久| 在线综合+亚洲+欧美中文字幕| 欧美成人a∨高清免费观看| 亚洲人成精品久久久久| 美女网站色91| 色拍拍在线精品视频8848| 26uuu另类欧美| 午夜不卡在线视频| 成人国产精品免费网站| 精品久久久影院| 亚洲一区二区高清| 粉嫩欧美一区二区三区高清影视| 欧美日韩国产一级片| 日韩毛片在线免费观看|