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

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

?? intexpr.c

?? C編譯器源碼是我到處找來的,看了之后很有收獲
?? C
字號:
/*
 * 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
 *
 */
/*
 * Evaluate an expression which should be known at compile time.
 * This uses recursive descent.  It is roughly analogous to the
 * primary expression handler except it returns a value rather than
 * an enode list
 */
#include        <stdio.h>
#include        "expr.h"
#include        "c.h"
#include				"errors.h"

extern enum e_sym lastst;
extern char lastid[];
extern long ival;
extern TABLE defsyms;
extern TYP stdint, stdchar,stduns, stdunsigned, stdlong, *head;
extern int prm_cmangle;
static long ieprimary(TYP **tp)   
/*
 * PRimary integer
 *    defined(MACRO)
 *    id
 *    iconst
 *    (cast )intexpr
 *    (intexpr)
 */
{       long     temp=0;
        SYM     *sp;
				if (tp)
					*tp = &stdint;
        if(lastst == id) {
					char *lid = lastid;
					if (prm_cmangle)
						lid++;
                	sp = gsearch(lastid);
                	if(sp == NULL) {
												gensymerror(ERR_UNDEFINED,lastid);
                        getsym();
                        return 0;
                        }
                	if(sp->storage_class != sc_const && sp->tp->type != bt_enum) {
                        generror(ERR_NEEDCONST,0,0);
                        getsym();
                        return 0;
                        }
                	getsym();
                	return sp->value.i;
        }
        else if(lastst == iconst) {
                temp = ival;
                getsym();
                return temp;
                }
        else if(lastst == lconst) {
								if (tp)
									*tp = &stdlong;
                temp = ival;
                getsym();
                return temp;
                }
        else if(lastst == iuconst) {
								if (tp)
									*tp = &stduns;
                temp = ival;
                getsym();
                return temp;
                }
        else if(lastst == luconst) {
								if (tp)
									*tp = &stdunsigned;
                temp = ival;
                getsym();
                return temp;
                }
        else if(lastst == cconst) {
								if (tp)
									*tp = &stdchar;
                temp = ival;
                getsym();
                return temp;
                }
				else if (lastst == openpa) {
					getsym();
					if (castbegin(lastst)) {
						decl(0);
						decl1();
						needpunc(closepa,0);
						if (tp)
						  *tp = head;
						return intexpr(0);
					}
					else {
				  	temp = intexpr(tp);
						return(temp);
					}
				}
        getsym();
        generror(ERR_NEEDCONST,0,0);
        return 0;
}
/*
 * Integer unary
 *   - unary
 *   ! unary
 *   ~unary
 *   primary
 */
static long ieunary(TYP **tp)
{
	long temp;
	switch (lastst) {
		case minus:
				getsym();
				temp = -ieunary(tp);
				break;
		case not:
				getsym();
				temp = !ieunary(tp);
				break;
		case compl:
				getsym();
				temp = ~ieunary(tp);
				break;
		default:
				temp = ieprimary(tp);
				break;
	}
	return(temp);
}
static long iemultops(TYP **tp)
/* Multiply ops */
{
	long val1 = ieunary(tp),val2;
	while (lastst == star || lastst == divide || lastst == modop) {
		TYP *tp1;
		long oper = lastst;
		getsym();
		val2 = ieunary(&tp1);
		switch(oper) {
			case star:
					val1 = val1 * val2;
					break;
			case divide:
					val1 = val1 / val2;
					break;
			case modop:
					val1 = val1 % val2;
					break;
		}
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long ieaddops(TYP **tp)
/* Add ops */
{
	long val1 = iemultops(tp),val2;
	while (lastst == plus || lastst == minus)	{
		long oper = lastst;
		TYP *tp1;
		getsym();
		val2 = iemultops(&tp1);
		if (oper == plus) 
			val1 = val1 + val2;
		else
			val1 = val1 - val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long ieshiftops(TYP **tp)
/* Shift ops */
{
	long val1 = ieaddops(tp), val2;
	while (lastst == lshift || lastst == rshift) {
		long oper = lastst;
		TYP *tp1;
		getsym();
		val2 = ieaddops(&tp1);
		if (oper == lshift)
			val1 <<= val2;
		else
			val1 >>= val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long ierelation(TYP **tp)
/* non-eq relations */
{
	long val1 = ieshiftops(tp), val2;
	while (lastst == lt || lastst == gt || lastst == leq || lastst == geq) {
		long oper = lastst;
		TYP *tp1;
		getsym();
		val2 = ieshiftops(&tp1);
		switch(oper) {
			case lt:
					val1 = val1 < val2;
					break;
			case gt:
					val1 = val1 > val2;
					break;
			case leq:
					val1 = val1 <= val2;
					break;
			case geq:
					val1 = val1 >= val2;
					break;
		}
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long ieequalops(TYP **tp)
/* eq relations */
{
	long val1 = ierelation(tp),val2;
	while (lastst == eq || lastst == neq) {
		long oper = lastst;
		TYP *tp1;
		getsym();
		val2 = ierelation(&tp1);
		if (oper == neq)
			val1 = val1 != val2;
		else
			val1 = val1 == val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long ieandop(TYP **tp)
/* and op */
{
	long val1 = ieequalops(tp),val2;
	while (lastst == and) {
		TYP *tp1;
		getsym();
		val2 = ieequalops(&tp1);
		val1 = val1 & val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long iexorop(TYP **tp)
/* xor op */
{
	long val1 = ieandop(tp),val2;
	while (lastst == uparrow) {
		TYP *tp1;
		getsym();
		val2 = ieandop(&tp1);
		val1 = val1 ^ val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}         
	return(val1);
}
static long ieorop(TYP **tp)
/* or op */
{
	long val1 = iexorop(tp),val2;
	while (lastst == or) {
		TYP *tp1;
		getsym();
		val2 = iexorop(&tp1);
		val1 = val1 | val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long ielandop(TYP **tp)
/* logical and op */
{
	long val1 = ieorop(tp),val2;
	while (lastst == land) {
		TYP *tp1;
		getsym();
		val2 = ieorop(&tp1);
		val1 = val1 && val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long ielorop(TYP **tp)
/* logical or op */
{
	long val1 = ielandop(tp),val2;
	while (lastst == lor) {
		TYP *tp1;
		getsym();
		val2 = ielandop(&tp1);
		val1 = val1 || val2;
		if (tp)
			*tp = maxsize(*tp,tp1);
	}
	return(val1);
}
static long iecondop(TYP **tp)
/* Hook op */
{
	long val1 = ielorop(tp),val2, val3;
		if (lastst == hook) {
			TYP *tp1, *tp2;
			getsym();
			val2 = iecondop(&tp1);
			needpunc(colon,0);
			val3 = iecondop(&tp2);
			if (val1)
				val1 = val2;
			else
				val1 = val3;
		if (tp)
			*tp = maxsize(tp2,tp1);
		}
	return(val1);
}
long intexpr(TYP **tp)
/* Integer expressions */
{
	return(iecondop(tp));
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人黄色国产精品网站大全在线免费观看 | 欧美一二三区在线| caoporen国产精品视频| 国产成人av电影在线观看| 狠狠色狠狠色综合系列| 精品亚洲欧美一区| 激情伊人五月天久久综合| 精久久久久久久久久久| 国产99久久久国产精品| 成人精品视频网站| 欧美日韩电影一区| 欧美日韩大陆在线| 在线综合+亚洲+欧美中文字幕| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 日韩电影在线免费观看| 日韩精品一级二级| 国产一区二区三区av电影| 国产精品2024| 色综合久久久久久久| 7777精品伊人久久久大香线蕉经典版下载 | 伊人夜夜躁av伊人久久| 亚洲一区在线观看免费| 日本一区二区三区视频视频| 国产精品白丝在线| 亚洲电影第三页| 国产美女一区二区三区| 91蜜桃视频在线| 7777精品伊人久久久大香线蕉最新版| 日韩丝袜美女视频| 国产精品女同互慰在线看| 一区二区欧美视频| 激情综合色播激情啊| 91丨porny丨蝌蚪视频| 日韩一级免费一区| 亚洲日韩欧美一区二区在线| 奇米色一区二区三区四区| 成人免费视频视频| 日韩欧美国产综合| 国产精品久久久久影院老司| 一区二区在线观看免费| 国产在线播放一区| 欧美日韩国产经典色站一区二区三区| xfplay精品久久| 亚洲成人综合网站| 成年人午夜久久久| 精品奇米国产一区二区三区| 亚洲电影激情视频网站| 97久久精品人人做人人爽50路| 成人v精品蜜桃久久一区| 日韩一级在线观看| 亚洲大型综合色站| 91美女片黄在线观看91美女| 久久久噜噜噜久久中文字幕色伊伊| 亚洲一二三区视频在线观看| 成年人网站91| 久久久噜噜噜久久人人看| 日本视频免费一区| 69堂成人精品免费视频| 亚洲综合男人的天堂| 色综合久久久久综合体桃花网| 久久只精品国产| 久久精品国产亚洲5555| 欧美一区二区视频免费观看| 亚洲一本大道在线| 色婷婷香蕉在线一区二区| 欧美激情综合在线| 国产大陆亚洲精品国产| 国产欧美日本一区视频| 国产盗摄一区二区| 中文字幕乱码亚洲精品一区 | 国产精品午夜免费| 欧美在线不卡视频| 中文字幕在线免费不卡| 成人免费观看视频| 自拍偷拍亚洲激情| 不卡影院免费观看| 亚洲天堂a在线| 日韩和欧美的一区| 懂色av中文一区二区三区| 亚洲视频图片小说| 亚洲已满18点击进入久久| 蜜臀av一区二区三区| av在线一区二区| 中文字幕在线播放不卡一区| 成人国产精品免费观看视频| 国产精品毛片大码女人| 93久久精品日日躁夜夜躁欧美| 久久久久久久久伊人| 国产成人自拍在线| 日韩理论片网站| 波多野结衣91| 一区二区三区国产| 欧美一区二区三区在线视频| 奇米四色…亚洲| 国产欧美日韩三区| 在线免费不卡视频| 日本sm残虐另类| 国产午夜精品一区二区三区嫩草| 国产一区二区免费在线| 中文字幕中文字幕一区| 在线一区二区视频| 蜜桃av一区二区三区| 国产亚洲精品精华液| 欧美视频三区在线播放| 久久精品国产免费| 中文字幕亚洲一区二区va在线| 欧美视频精品在线| 国产一区在线不卡| 一区二区三区91| 欧美一二三四在线| 色综合一区二区三区| 精品一区精品二区高清| 亚洲免费毛片网站| 久久久午夜精品理论片中文字幕| 色婷婷综合久久久中文一区二区| 日韩福利电影在线观看| 一色桃子久久精品亚洲| 在线综合视频播放| 日本黄色一区二区| 国产成人av一区| 蜜桃一区二区三区四区| 亚洲欧美日韩国产手机在线 | 波多野结衣91| 免费在线一区观看| 亚洲综合另类小说| 亚洲国产经典视频| 日韩免费看的电影| 欧美日韩亚洲国产综合| 91污在线观看| 成人永久aaa| 国产精品亚洲а∨天堂免在线| 日韩制服丝袜av| 亚洲激情欧美激情| 中文字幕一区二区三区在线播放 | 亚洲手机成人高清视频| 亚洲国产精品av| 精品国产乱码久久久久久久久 | 欧美一卡二卡三卡四卡| 欧美综合一区二区| 色一情一乱一乱一91av| 成人免费观看av| 国产精品99久| 国产毛片精品一区| 狠狠色狠狠色合久久伊人| 奇米综合一区二区三区精品视频| 亚洲一区二区三区在线播放| 尤物av一区二区| 亚洲精品精品亚洲| 一区二区三区在线观看视频| 亚洲日本在线天堂| 亚洲人午夜精品天堂一二香蕉| 国产精品拍天天在线| 中文字幕一区二区三区av| 最新中文字幕一区二区三区| 国产精品国产自产拍高清av王其| 国产女同互慰高潮91漫画| 久久先锋资源网| 欧美韩国日本一区| 中文字幕欧美一| 亚洲国产日韩a在线播放| 亚洲成a天堂v人片| 免费不卡在线观看| 国产一区二区不卡| 成人性生交大片免费看在线播放| 成人午夜免费av| 99国产精品国产精品久久| 色综合天天做天天爱| 欧美日韩视频一区二区| 日韩欧美一区二区久久婷婷| 久久久精品天堂| 亚洲三级在线免费| 日韩激情av在线| 国产一区在线视频| 一本一道久久a久久精品 | 亚洲成av人影院| 日本不卡在线视频| 国产精品一级二级三级| 色诱视频网站一区| 日韩一区二区三区视频在线| 中文字幕欧美日韩一区| 一区二区欧美视频| 国产综合色精品一区二区三区| av一区二区三区四区| 欧美日韩国产美女| 国产欧美一区二区精品忘忧草| 一区二区三区日韩欧美| 激情av综合网| 欧美色涩在线第一页| www国产亚洲精品久久麻豆| 一区二区三区鲁丝不卡| 国产精品综合二区| 欧美美女黄视频| 亚洲国产精品国自产拍av| 日韩av中文在线观看| 99视频热这里只有精品免费| 日韩欧美卡一卡二| 亚洲一区二区三区四区五区中文 | 99re亚洲国产精品| 亚洲精品一区二区三区精华液| 一区二区三区中文字幕|