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

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

?? ejparse.c

?? 開發板bios源碼 開發板bios源碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
		}
	}

	if (numeric) {
		l = gatoi(lhs);
		r = gatoi(rhs);
		switch (rel) {
		case EXPR_PLUS:
			lval = l + r;
			break;
		case EXPR_INC:
			lval = l + 1;
			break;
		case EXPR_MINUS:
			lval = l - r;
			break;
		case EXPR_DEC:
			lval = l - 1;
			break;
		case EXPR_MUL:
			lval = l * r;
			break;
		case EXPR_DIV:
			if (r != 0) {
				lval = l / r;
			} else {
				lval = 0;
			}
			break;
		case EXPR_MOD:
			if (r != 0) {
				lval = l % r;
			} else {
				lval = 0;
			}
			break;
		case EXPR_LSHIFT:
			lval = l << r;
			break;
		case EXPR_RSHIFT:
			lval = l >> r;
			break;
		case EXPR_EQ:
			lval = l == r;
			break;
		case EXPR_NOTEQ:
			lval = l != r;
			break;
		case EXPR_LESS:
			lval = (l < r) ? 1 : 0;
			break;
		case EXPR_LESSEQ:
			lval = (l <= r) ? 1 : 0;
			break;
		case EXPR_GREATER:
			lval = (l > r) ? 1 : 0;
			break;
		case EXPR_GREATEREQ:
			lval = (l >= r) ? 1 : 0;
			break;
		case EXPR_BOOL_COMP:
			lval = (r == 0) ? 1 : 0;
			break;
		default:
			ejError(ep, T("Bad operator %d"), rel);
			return -1;
		}

	} else {
		switch (rel) {
		case EXPR_PLUS:
			clearString(&ep->result);
			appendString(&ep->result, lhs);
			appendString(&ep->result, rhs);
			return 0;
		case EXPR_LESS:
			lval = gstrcmp(lhs, rhs) < 0;
			break;
		case EXPR_LESSEQ:
			lval = gstrcmp(lhs, rhs) <= 0;
			break;
		case EXPR_GREATER:
			lval = gstrcmp(lhs, rhs) > 0;
			break;
		case EXPR_GREATEREQ:
			lval = gstrcmp(lhs, rhs) >= 0;
			break;
		case EXPR_EQ:
			lval = gstrcmp(lhs, rhs) == 0;
			break;
		case EXPR_NOTEQ:
			lval = gstrcmp(lhs, rhs) != 0;
			break;
		case EXPR_INC:
		case EXPR_DEC:
		case EXPR_MINUS:
		case EXPR_DIV:
		case EXPR_MOD:
		case EXPR_LSHIFT:
		case EXPR_RSHIFT:
		default:
			ejError(ep, T("Bad operator"));
			return -1;
		}
	}

	stritoa(lval, buf, sizeof(buf));
	setString(B_L, &ep->result, buf);
	return 0;
}

/******************************************************************************/
/*
 *	Evaluate a function
 */

static int evalFunction(ej_t *ep)
{
	sym_t	*sp;
	int		(*fn)(int eid, void *handle, int argc, char_t **argv);

	if ((sp = symLookup(ep->functions, ep->func->fname)) == NULL) {
		ejError(ep, T("Undefined procedure %s"), ep->func->fname);
		return -1;
	}

	fn = (int (*)(int, void*, int, char_t**)) sp->content.value.integer;
	if (fn == NULL) {
		ejError(ep, T("Undefined procedure %s"), ep->func->fname);
		return -1;
	}

	return (*fn)(ep->eid, (void*) ep->userHandle, ep->func->nArgs,
		ep->func->args);
}

/******************************************************************************/
/*
 *	Output a parse ej_error message
 */

void ejError(ej_t* ep, char_t* fmt, ...)
{
	va_list		args;
	ejinput_t	*ip;
	char_t		*errbuf, *msgbuf;

	a_assert(ep);
	a_assert(fmt);
	ip = ep->input;

	va_start(args, fmt);
	msgbuf = NULL;
	fmtValloc(&msgbuf, E_MAX_ERROR, fmt, args);
	va_end(args);

	if (ep && ip) {
		fmtAlloc(&errbuf, E_MAX_ERROR, T("%s\n At line %d, line => \n\n%s\n"),
			msgbuf, ip->lineNumber, ip->line);
		bfreeSafe(B_L, ep->error);
		ep->error = errbuf;
	}
	bfreeSafe(B_L, msgbuf);
}

/******************************************************************************/
/*
 *	Clear a string value
 */

static void clearString(char_t **ptr)
{
	a_assert(ptr);

	if (*ptr) {
		bfree(B_L, *ptr);
	}
	*ptr = NULL;
}

/******************************************************************************/
/*
 *	Set a string value
 */

static void setString(B_ARGS_DEC, char_t **ptr, char_t *s)
{
	a_assert(ptr);

	if (*ptr) {
		bfree(B_ARGS, *ptr);
	}
	*ptr = bstrdup(B_ARGS, s);
}

/******************************************************************************/
/*
 *	Append to the pointer value
 */

static void appendString(char_t **ptr, char_t *s)
{
	int	len, oldlen;

	a_assert(ptr);

	if (*ptr) {
		len = gstrlen(s);
		oldlen = gstrlen(*ptr);
		*ptr = brealloc(B_L, *ptr, (len + oldlen + 1) * sizeof(char_t));
		gstrcpy(&(*ptr)[oldlen], s);
	} else {
		*ptr = bstrdup(B_L, s);
	}
}

/******************************************************************************/
/*
 *	Define a function
 */

int ejSetGlobalFunction(int eid, char_t *name,
	int (*fn)(int eid, void *handle, int argc, char_t **argv))
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return -1;
	}
	return ejSetGlobalFunctionDirect(ep->functions, name, fn);
}

/******************************************************************************/
/*
 *	Define a function directly into the function symbol table.
 */

int ejSetGlobalFunctionDirect(sym_fd_t functions, char_t *name,
	int (*fn)(int eid, void *handle, int argc, char_t **argv))
{
	if (symEnter(functions, name, valueInteger((long) fn), 0) == NULL) {
		return -1;
	}
	return 0;
}

/******************************************************************************/
/*
 *	Remove ("undefine") a function
 */

int ejRemoveGlobalFunction(int eid, char_t *name)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return -1;
	}
	return symDelete(ep->functions, name);
}

/******************************************************************************/
/*
 *	Get a function definition
 */

void *ejGetGlobalFunction(int eid, char_t *name)
{
	ej_t	*ep;
	sym_t	*sp;
	int		(*fn)(int eid, void *handle, int argc, char_t **argv);

	if ((ep = ejPtr(eid)) == NULL) {
		return NULL;
	}

	if ((sp = symLookup(ep->functions, name)) != NULL) {
		fn = (int (*)(int, void*, int, char_t**)) sp->content.value.integer;
		return (void*) fn;
	}
	return NULL;
}

/******************************************************************************/
/*
 *	Utility routine to crack Ejscript arguments. Return the number of args
 *	seen. This routine only supports %s and %d type args.
 *
 *	Typical usage:
 *
 *		if (ejArgs(argc, argv, "%s %d", &name, &age) < 2) {
 *			error("Insufficient args\n");
 *			return -1;
 *		}
 */

int ejArgs(int argc, char_t **argv, char_t *fmt, ...)
{
	va_list	vargs;
	char_t	*cp, **sp;
	int		*ip;
	int		argn;

	va_start(vargs, fmt);

	if (argv == NULL) {
		return 0;
	}

	for (argn = 0, cp = fmt; cp && *cp && argv[argn]; ) {
		if (*cp++ != '%') {
			continue;
		}

		switch (*cp) {
		case 'd':
			ip = va_arg(vargs, int*);
			*ip = gatoi(argv[argn]);
			break;

		case 's':
			sp = va_arg(vargs, char_t**);
			*sp = argv[argn];
			break;

		default:
/*
 *			Unsupported
 */
			a_assert(0);
		}
		argn++;
	}

	va_end(vargs);
	return argn;
}

/******************************************************************************/
/*
 *	Define the user handle
 */

void ejSetUserHandle(int eid, int handle)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return;
	}
	ep->userHandle = handle;
}

/******************************************************************************/
/*
 *	Get the user handle
 */

int ejGetUserHandle(int eid)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return -1;
	}
	return ep->userHandle;
}

/******************************************************************************/
/*
 *	Get the current line number
 */

int ejGetLineNumber(int eid)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return -1;
	}
	return ep->input->lineNumber;
}

/******************************************************************************/
/*
 *	Set the result
 */

void ejSetResult(int eid, char_t *s)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return;
	}
	setString(B_L, &ep->result, s);
}

/******************************************************************************/
/*
 *	Get the result
 */

char_t *ejGetResult(int eid)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return NULL;
	}
	return ep->result;
}

/******************************************************************************/
/*
 *	Set a variable. Note: a variable with a value of NULL means declared but
 *	undefined. The value is defined in the top-most variable frame.
 */

void ejSetVar(int eid, char_t *var, char_t *value)
{
	ej_t	*ep;
	value_t	v;

	a_assert(var && *var);

	if ((ep = ejPtr(eid)) == NULL) {
		return;
	}

	if (value == NULL) {
		v = valueString(value, 0);
	} else {
		v = valueString(value, VALUE_ALLOCATE);
	}
	symEnter(ep->variables[ep->variableMax - 1] - EJ_OFFSET, var, v, 0);
}

/******************************************************************************/
/*
 *	Set a local variable. Note: a variable with a value of NULL means
 *	declared but undefined. The value is defined in the top-most variable frame.
 */

void ejSetLocalVar(int eid, char_t *var, char_t *value)
{
	ej_t	*ep;
	value_t	v;

	a_assert(var && *var);

	if ((ep = ejPtr(eid)) == NULL) {
		return;
	}

	if (value == NULL) {
		v = valueString(value, 0);
	} else {
		v = valueString(value, VALUE_ALLOCATE);
	}
	symEnter(ep->variables[ep->variableMax - 1] - EJ_OFFSET, var, v, 0);
}

/******************************************************************************/
/*
 *	Set a global variable. Note: a variable with a value of NULL means
 *	declared but undefined. The value is defined in the global variable frame.
 */

void ejSetGlobalVar(int eid, char_t *var, char_t *value)
{
	ej_t	*ep;
	value_t v;

	a_assert(var && *var);

	if ((ep = ejPtr(eid)) == NULL) {
		return;
	}

	if (value == NULL) {
		v = valueString(value, 0);
	} else {
		v = valueString(value, VALUE_ALLOCATE);
	}
	symEnter(ep->variables[0] - EJ_OFFSET, var, v, 0);
}

/******************************************************************************/
/*
 *	Get a variable
 */

int ejGetVar(int eid, char_t *var, char_t **value)
{
	ej_t	*ep;
	sym_t	*sp;
	int		i;

	a_assert(var && *var);
	a_assert(value);

	if ((ep = ejPtr(eid)) == NULL) {
		return -1;
	}

	i = ep->variableMax - 1;
	if ((sp = symLookup(ep->variables[i] - EJ_OFFSET, var)) == NULL) {
		i = 0;
		if ((sp = symLookup(ep->variables[0] - EJ_OFFSET, var)) == NULL) {
			return -1;
		}
	}
	a_assert(sp->content.type == string);
	*value = sp->content.value.string;
	return i;
}

/******************************************************************************/
/*
 *	Get the variable symbol table
 */

sym_fd_t ejGetVariableTable(int eid)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return -1;
	}
	return *ep->variables;
}

/******************************************************************************/
/*
 *	Get the functions symbol table
 */

sym_fd_t ejGetFunctionTable(int eid)
{
	ej_t	*ep;

	if ((ep = ejPtr(eid)) == NULL) {
		return -1;
	}
	return ep->functions;
}

/******************************************************************************/
/*
 *	Free an argument list
 */

static void freeFunc(ejfunc_t *func)
{
	int	i;

	for (i = func->nArgs - 1; i >= 0; i--) {
		bfree(B_L, func->args[i]);
		func->nArgs = hFree((void***) &func->args, i);
	}

	if (func->fname) {
		bfree(B_L, func->fname);
		func->fname = NULL;
	}
}

/******************************************************************************/
/*
 *	Get Ejscript pointer
 */

static ej_t *ejPtr(int eid)
{
	a_assert(0 <= eid && eid < ejMax);

	if (eid < 0 || eid >= ejMax || ejHandles[eid] == NULL) {
		ejError(NULL, T("Bad handle %d"), eid);
		return NULL;
	}
	return ejHandles[eid];
}

/******************************************************************************/
/*
 *	This function removes any new lines.  Used for else	cases, etc.
 */
static void ejRemoveNewlines(ej_t *ep, int state)
{
	int tid;

	do {
		tid = ejLexGetToken(ep, state);
	} while (tid == TOK_NEWLINE);

	ejLexPutbackToken(ep, tid, ep->token);
}

/******************************************************************************/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
男男视频亚洲欧美| 91精品国产91热久久久做人人 | 国产精品第一页第二页第三页| 亚洲另类春色国产| 国模套图日韩精品一区二区| 欧美在线看片a免费观看| 中文成人综合网| 激情欧美日韩一区二区| 91福利国产成人精品照片| 中文字幕av在线一区二区三区| 天堂va蜜桃一区二区三区 | 亚洲人成网站精品片在线观看| 麻豆国产精品777777在线| 欧美在线高清视频| 日韩码欧中文字| 成人深夜在线观看| 26uuu色噜噜精品一区| 日日摸夜夜添夜夜添精品视频| 色综合天天狠狠| 亚洲色图欧美偷拍| 97精品久久久午夜一区二区三区| 久久久精品免费网站| 精品一区二区在线视频| 777久久久精品| 亚洲va国产天堂va久久en| 日本韩国欧美在线| 一区二区三区四区乱视频| 成人精品在线视频观看| 国产精品少妇自拍| av成人免费在线| 中文字幕制服丝袜成人av| 波多野洁衣一区| 亚洲日本乱码在线观看| 99国产精品国产精品毛片| 国产精品国产三级国产普通话99| 不卡av免费在线观看| 国产精品私房写真福利视频| 成人免费观看av| 亚洲日本在线天堂| 欧美日韩一区视频| 日本亚洲一区二区| 日韩精品最新网址| 国产成人在线网站| **欧美大码日韩| 欧美视频一区二区三区在线观看 | 亚洲天堂av一区| 色偷偷成人一区二区三区91| 亚洲免费在线看| 欧美日韩一级二级三级| 美女国产一区二区三区| 久久久影视传媒| 色欧美片视频在线观看在线视频| 亚洲精品国产精华液| 欧美日韩mp4| 裸体在线国模精品偷拍| 国产精品毛片高清在线完整版| 一本色道久久综合精品竹菊| 五月激情综合婷婷| 久久综合色天天久久综合图片| 盗摄精品av一区二区三区| 伊人夜夜躁av伊人久久| 日韩一区二区视频| 99精品久久99久久久久| 婷婷成人激情在线网| 久久亚洲春色中文字幕久久久| 99久久久国产精品| 蜜桃一区二区三区四区| 国产精品视频第一区| 91精品国产综合久久香蕉麻豆 | 日本一区二区三区四区在线视频 | 亚洲综合在线视频| 欧美mv日韩mv国产| 91蜜桃视频在线| 久久爱www久久做| 亚洲精品亚洲人成人网| 精品国产一区二区三区忘忧草| 99精品欧美一区二区三区小说| 欧美bbbbb| 亚洲综合精品久久| 国产欧美日韩在线视频| 欧美精品tushy高清| av欧美精品.com| 美女视频黄久久| 亚洲精品一卡二卡| 中文字幕va一区二区三区| 日韩欧美在线123| 91久久香蕉国产日韩欧美9色| 国产一区二区三区在线观看免费| 亚洲一区二区不卡免费| 国产精品久久看| 精品欧美一区二区在线观看| 欧美精品欧美精品系列| 91欧美一区二区| 国产成人自拍高清视频在线免费播放| 日韩影院在线观看| 有坂深雪av一区二区精品| 国产精品欧美综合在线| 久久婷婷国产综合精品青草| 91麻豆精品国产91久久久使用方法 | 青青草国产精品97视觉盛宴| 亚洲欧洲中文日韩久久av乱码| 久久亚洲精品小早川怜子| 欧美一区二区人人喊爽| 欧美色综合网站| 欧美在线观看视频一区二区| 97se亚洲国产综合自在线不卡| 国产成人av电影在线| 国产在线播放一区| 国产一区二区三区在线观看免费| 久久99热国产| 久久国产精品99久久人人澡| 日本成人在线看| 毛片av一区二区三区| 日韩精品五月天| 美女性感视频久久| 免费xxxx性欧美18vr| 日韩精品成人一区二区在线| 天天综合色天天| 美国毛片一区二区| 国产美女久久久久| 国产成人综合视频| av一区二区不卡| 色欲综合视频天天天| 欧美在线观看视频一区二区三区| 欧美三级在线视频| 日韩欧美亚洲国产另类| 欧美mv日韩mv国产网站app| 久久亚洲私人国产精品va媚药| 国产日韩精品视频一区| 亚洲人成伊人成综合网小说| 亚洲人成精品久久久久久| 亚洲综合无码一区二区| 日本午夜精品一区二区三区电影| 丝袜亚洲另类欧美综合| 久久综合综合久久综合| 国产一区二区三区最好精华液| 盗摄精品av一区二区三区| 欧美综合欧美视频| 精品国产免费一区二区三区香蕉| 国产丝袜欧美中文另类| 一区二区三区国产豹纹内裤在线| 性做久久久久久免费观看欧美| 美女国产一区二区三区| www.性欧美| 欧美日韩高清不卡| 久久亚洲春色中文字幕久久久| 国产精品国产三级国产aⅴ入口| 亚洲一区二区综合| 国产乱子伦视频一区二区三区| 91在线视频播放地址| 宅男在线国产精品| 成人免费在线视频| 久久精品国产99| 色综合久久综合网欧美综合网| 91麻豆精品国产91久久久久| 国产欧美精品国产国产专区| 亚洲.国产.中文慕字在线| 国产精品一区二区果冻传媒| 精品视频在线免费| 国产日韩欧美一区二区三区综合| 一区二区久久久久久| 国产精品亚洲一区二区三区在线| 欧亚一区二区三区| 国产精品久久久久aaaa| 青青草国产精品97视觉盛宴| 91丨国产丨九色丨pron| 久久久久久免费毛片精品| 亚洲成年人网站在线观看| 成人av电影在线| 久久久亚洲精品石原莉奈| 爽好多水快深点欧美视频| www.日韩av| 久久精品一区二区三区四区| 日韩精品福利网| 精品视频在线视频| 一区二区三区**美女毛片| 成人午夜免费av| 国产丝袜美腿一区二区三区| 久久成人免费网站| 欧美日韩国产经典色站一区二区三区| 国产精品美女www爽爽爽| 韩国成人在线视频| 日韩欧美资源站| 日韩福利视频导航| 欧美老人xxxx18| 亚洲国产精品视频| 欧美在线一二三四区| 亚洲色图在线视频| 色综合色综合色综合| 亚洲欧洲av色图| 99视频一区二区| 国产精品久久久久久久久快鸭 | 狠狠狠色丁香婷婷综合激情| 91.com在线观看| 亚洲一二三四在线观看| 一本久久a久久免费精品不卡| 中文字幕制服丝袜成人av| eeuss鲁片一区二区三区| 亚洲国产精华液网站w| 成人av影视在线观看|