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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? 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));
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲欧美日韩在线一区| 亚洲特黄一级片| 国产欧美精品一区| 亚洲欧美激情视频在线观看一区二区三区 | 成人一级片网址| 色域天天综合网| 久久久影视传媒| 日韩在线一二三区| 91丨porny丨户外露出| 日韩美一区二区三区| 亚洲日本韩国一区| 国产精品综合二区| 91精品欧美久久久久久动漫| 亚洲精品中文字幕乱码三区| 国产一区二区导航在线播放| 欧美性xxxxxxxx| 日韩一区在线播放| 国产精品1024久久| 日韩午夜电影av| 丝袜国产日韩另类美女| 91高清在线观看| 国产亚洲精品7777| 另类小说一区二区三区| 欧美日韩视频在线第一区| 国产精品国产精品国产专区不蜜| 美女网站色91| 成人av网站免费观看| 亚洲欧美aⅴ...| 成人黄色电影在线 | 欧美一区二区三区性视频| 亚洲男女毛片无遮挡| 成人免费看视频| 国产婷婷精品av在线| 国产精品性做久久久久久| 日韩精品一区二区三区三区免费| 天堂久久一区二区三区| 欧美日韩国产综合一区二区三区| 亚洲午夜av在线| 欧美色网站导航| 午夜国产不卡在线观看视频| 欧美mv日韩mv国产| 麻豆免费看一区二区三区| 制服丝袜中文字幕亚洲| 日韩高清不卡一区二区三区| 日韩一级完整毛片| 久久精品噜噜噜成人av农村| 日韩欧美高清在线| 国产精品香蕉一区二区三区| 国产三级欧美三级日产三级99| 国内精品伊人久久久久av一坑 | 91丨porny丨首页| 亚洲另类在线视频| 欧美视频精品在线观看| 美日韩一级片在线观看| 久久久午夜精品理论片中文字幕| 国产成人免费高清| 最好看的中文字幕久久| 欧美最猛黑人xxxxx猛交| 性做久久久久久久免费看| 欧美岛国在线观看| 国产一区二区在线影院| 国产精品国产三级国产aⅴ原创 | 日韩欧美一区二区久久婷婷| 韩国三级中文字幕hd久久精品| 国产日韩v精品一区二区| 99综合电影在线视频| 亚洲一区二区三区四区五区黄| 91精品国产日韩91久久久久久| 久草在线在线精品观看| 亚洲欧洲精品天堂一级| 欧美日韩不卡在线| 国产精品伊人色| 一区二区三区在线免费视频| 91精品中文字幕一区二区三区| 国产精品综合一区二区| 亚洲精品午夜久久久| 精品少妇一区二区三区日产乱码| 成人ar影院免费观看视频| 亚洲国产精品自拍| 久久久久久麻豆| 色婷婷一区二区| 毛片一区二区三区| 亚洲美女精品一区| 精品99999| 色综合久久综合网欧美综合网| 日韩成人精品在线| 亚洲欧美韩国综合色| 日韩午夜精品视频| 91亚洲精品久久久蜜桃网站| 美国十次综合导航| 亚洲免费观看高清在线观看| 精品国产第一区二区三区观看体验| k8久久久一区二区三区| 日本v片在线高清不卡在线观看| 亚洲视频资源在线| 久久久亚洲高清| 欧美日韩免费电影| 91一区一区三区| 成人app在线观看| 国产成人激情av| 日韩av午夜在线观看| 一区二区不卡在线视频 午夜欧美不卡在| 精品精品国产高清一毛片一天堂| 欧美怡红院视频| 91免费国产在线| www.成人网.com| 粉嫩av一区二区三区在线播放| 美女被吸乳得到大胸91| 日本中文字幕一区二区视频 | 波多野结衣中文字幕一区二区三区| 秋霞电影网一区二区| 亚洲不卡av一区二区三区| 亚洲欧美日韩小说| 亚洲免费三区一区二区| 中文字幕亚洲精品在线观看| 国产女人水真多18毛片18精品视频 | 一本久久综合亚洲鲁鲁五月天 | 国产日韩欧美激情| 欧美精品一区二| 精品美女在线播放| 欧美成人官网二区| 色天使色偷偷av一区二区| 五月激情综合色| 日韩欧美一级特黄在线播放| 国产成人av电影在线播放| 一区二区三区精品视频| 亚洲午夜免费福利视频| 亚洲人精品一区| 久久久久久久久岛国免费| 国产亚洲精品7777| 中文字幕久久午夜不卡| 国产女同互慰高潮91漫画| 日韩欧美自拍偷拍| 中文字幕在线不卡视频| 久久久久久电影| 久久久99精品久久| 日韩理论电影院| 亚洲一区在线观看免费观看电影高清| 亚洲黄色在线视频| 婷婷久久综合九色综合绿巨人| 蜜臀久久99精品久久久画质超高清| 看电视剧不卡顿的网站| 国产成人免费网站| 色天天综合久久久久综合片| 欧美日韩1234| xfplay精品久久| 亚洲欧洲综合另类| 日韩精品免费专区| 国产精品一级在线| 欧洲精品一区二区三区在线观看| 91.xcao| 久久精品欧美一区二区三区不卡| 国产精品久久久久久久久动漫| 亚洲国产精品久久艾草纯爱| 老司机一区二区| av在线综合网| 欧美一区二区大片| 国产精品久久看| 日韩国产欧美在线观看| 成人一级视频在线观看| 91精品国产免费| 亚洲欧美在线aaa| 免费的国产精品| 色综合久久88色综合天天免费| 日韩欧美国产午夜精品| 一区精品在线播放| 精品一区二区三区在线播放视频| 99久久综合99久久综合网站| 日韩一级片网站| 亚洲精品乱码久久久久久黑人| 久久99国产精品免费网站| 99re热视频精品| 久久亚洲综合色一区二区三区| 亚洲男人的天堂在线观看| 国产美女视频一区| 制服丝袜一区二区三区| 国产精品国产三级国产三级人妇| 亚洲婷婷在线视频| 国产一区 二区| 欧美一级黄色片| 亚洲第一搞黄网站| 99re热这里只有精品免费视频 | 国产精品一品二品| 4438x成人网最大色成网站| 日韩一区在线免费观看| 国产九色sp调教91| 欧美xxxx在线观看| 一区二区三区四区在线播放| 成人aaaa免费全部观看| 精品免费视频.| 欧美aaaaaa午夜精品| 不卡一区二区三区四区| 久久久美女毛片| 蜜桃一区二区三区在线观看| 欧美在线观看视频在线| 亚洲人午夜精品天堂一二香蕉| 成人激情午夜影院| 欧美日韩国产精品自在自线| 亚洲欧洲日本在线| av电影一区二区|