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

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

?? engine.c

?? Vovida 社區(qū)開源的 SIP 協(xié)議源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * The matching engine and friends.  This file is #included by regexec.c * after suitable #defines of a variety of macros used herein, so that * different state representations can be used without duplicating masses * of code. */#ifdef SNAMES#define	matcher	smatcher#define	fast	sfast#define	slow	sslow#define	dissect	sdissect#define	backref	sbackref#define	step	sstep#define	print	sprint#define	at	sat#define	match	smat#endif#ifdef LNAMES#define	matcher	lmatcher#define	fast	lfast#define	slow	lslow#define	dissect	ldissect#define	backref	lbackref#define	step	lstep#define	print	lprint#define	at	lat#define	match	lmat#endif/* another structure passed up and down to avoid zillions of parameters */struct match {	struct re_guts *g;	int eflags;	regmatch_t *pmatch;	/* [nsub+1] (0 element unused) */	char *offp;		/* offsets work from here */	char *beginp;		/* start of string -- virtual NUL precedes */	char *endp;		/* end of string -- virtual NUL here */	char *coldp;		/* can be no match starting before here */	char **lastpos;		/* [nplus+1] */	STATEVARS;	states st;		/* current states */	states fresh;		/* states for a fresh start */	states tmp;		/* temporary */	states empty;		/* empty set of states */};#include "engine.ih"#ifdef REDEBUG#define	SP(t, s, c)	print(m, t, s, c, stdout)#define	AT(t, p1, p2, s1, s2)	at(m, t, p1, p2, s1, s2)#define	NOTE(str)	{ if (m->eflags&REG_TRACE) printf("=%s\n", (str)); }#else#define	SP(t, s, c)	/* nothing */#define	AT(t, p1, p2, s1, s2)	/* nothing */#define	NOTE(s)	/* nothing */#endif/* - matcher - the actual matching engine == static int matcher(register struct re_guts *g, char *string, \ ==	size_t nmatch, regmatch_t pmatch[], int eflags); */static int			/* 0 success, REG_NOMATCH failure */matcher(g, string, nmatch, pmatch, eflags)register struct re_guts *g;char *string;size_t nmatch;regmatch_t pmatch[];int eflags;{	register char *endp;	register size_t i;	struct match mv;	register struct match *m = &mv;	register char *dp;	const register sopno gf = g->firststate+1;	/* +1 for OEND */	const register sopno gl = g->laststate;	char *start;	char *stop;	/* simplify the situation where possible */	if (g->cflags&REG_NOSUB)		nmatch = 0;	if (eflags&REG_STARTEND) {		start = string + pmatch[0].rm_so;		stop = string + pmatch[0].rm_eo;	} else {		start = string;		stop = start + strlen(start);	}	if (stop < start)		return(REG_INVARG);	/* prescreening; this does wonders for this rather slow code */	if (g->must != NULL) {		for (dp = start; dp < stop; dp++)			if (*dp == g->must[0] && stop - dp >= g->mlen &&				memcmp(dp, g->must, (size_t)g->mlen) == 0)				break;		if (dp == stop)		/* we didn't find g->must */			return(REG_NOMATCH);	}	/* match struct setup */	m->g = g;	m->eflags = eflags;	m->pmatch = NULL;	m->lastpos = NULL;	m->offp = string;	m->beginp = start;	m->endp = stop;	STATESETUP(m, 4);	SETUP(m->st);	SETUP(m->fresh);	SETUP(m->tmp);	SETUP(m->empty);	CLEAR(m->empty);	/* this loop does only one repetition except for backrefs */	for (;;) {		endp = fast(m, start, stop, gf, gl);		if (endp == NULL) {		/* a miss */			STATETEARDOWN(m);			return(REG_NOMATCH);		}		if (nmatch == 0 && !g->backrefs)			break;		/* no further info needed */		/* where? */		assert(m->coldp != NULL);		for (;;) {			NOTE("finding start");			endp = slow(m, m->coldp, stop, gf, gl);			if (endp != NULL)				break;			assert(m->coldp < m->endp);			m->coldp++;		}		if (nmatch == 1 && !g->backrefs)			break;		/* no further info needed */		/* oh my, he wants the subexpressions... */		if (m->pmatch == NULL)			m->pmatch = (regmatch_t *)malloc((m->g->nsub + 1) *							sizeof(regmatch_t));		if (m->pmatch == NULL) {			STATETEARDOWN(m);			return(REG_ESPACE);		}		for (i = 1; i <= m->g->nsub; i++)			m->pmatch[i].rm_so = m->pmatch[i].rm_eo = -1;		if (!g->backrefs && !(m->eflags&REG_BACKR)) {			NOTE("dissecting");			dp = dissect(m, m->coldp, endp, gf, gl);		} else {			if (g->nplus > 0 && m->lastpos == NULL)				m->lastpos = (char **)malloc((g->nplus+1) *							sizeof(char *));			if (g->nplus > 0 && m->lastpos == NULL) {				free(m->pmatch);				STATETEARDOWN(m);				return(REG_ESPACE);			}			NOTE("backref dissect");			dp = backref(m, m->coldp, endp, gf, gl, (sopno)0);		}		if (dp != NULL)			break;		/* uh-oh... we couldn't find a subexpression-level match */		assert(g->backrefs);	/* must be back references doing it */		assert(g->nplus == 0 || m->lastpos != NULL);		for (;;) {			if (dp != NULL || endp <= m->coldp)				break;		/* defeat */			NOTE("backoff");			endp = slow(m, m->coldp, endp-1, gf, gl);			if (endp == NULL)				break;		/* defeat */			/* try it on a shorter possibility */#ifndef NDEBUG			for (i = 1; i <= m->g->nsub; i++) {				assert(m->pmatch[i].rm_so == -1);				assert(m->pmatch[i].rm_eo == -1);			}#endif			NOTE("backoff dissect");			dp = backref(m, m->coldp, endp, gf, gl, (sopno)0);		}		assert(dp == NULL || dp == endp);		if (dp != NULL)		/* found a shorter one */			break;		/* despite initial appearances, there is no match here */		NOTE("false alarm");		start = m->coldp + 1;	/* recycle starting later */		assert(start <= stop);	}	/* fill in the details if requested */	if (nmatch > 0) {		pmatch[0].rm_so = m->coldp - m->offp;		pmatch[0].rm_eo = endp - m->offp;	}	if (nmatch > 1) {		assert(m->pmatch != NULL);		for (i = 1; i < nmatch; i++)			if (i <= m->g->nsub)				pmatch[i] = m->pmatch[i];			else {				pmatch[i].rm_so = -1;				pmatch[i].rm_eo = -1;			}	}	if (m->pmatch != NULL)		free((char *)m->pmatch);	if (m->lastpos != NULL)		free((char *)m->lastpos);	STATETEARDOWN(m);	return(0);}/* - dissect - figure out what matched what, no back references == static char *dissect(register struct match *m, char *start, \ ==	char *stop, sopno startst, sopno stopst); */static char *			/* == stop (success) always */dissect(m, start, stop, startst, stopst)register struct match *m;char *start;char *stop;sopno startst;sopno stopst;{	register int i;	register sopno ss;	/* start sop of current subRE */	register sopno es;	/* end sop of current subRE */	register char *sp;	/* start of string matched by it */	register char *stp;	/* string matched by it cannot pass here */	register char *rest;	/* start of rest of string */	register char *tail;	/* string unmatched by rest of RE */	register sopno ssub;	/* start sop of subsubRE */	register sopno esub;	/* end sop of subsubRE */	register char *ssp;	/* start of string matched by subsubRE */	register char *sep;	/* end of string matched by subsubRE */	register char *oldssp;	/* previous ssp */	register char *dp;	AT("diss", start, stop, startst, stopst);	sp = start;	for (ss = startst; ss < stopst; ss = es) {		/* identify end of subRE */		es = ss;		switch (OP(m->g->strip[es])) {		case OPLUS_:		case OQUEST_:			es += OPND(m->g->strip[es]);			break;		case OCH_:			while (OP(m->g->strip[es]) != O_CH)				es += OPND(m->g->strip[es]);			break;		}		es++;		/* figure out what it matched */		switch (OP(m->g->strip[ss])) {		case OEND:			assert(nope);			break;		case OCHAR:			sp++;			break;		case OBOL:		case OEOL:		case OBOW:		case OEOW:			break;		case OANY:		case OANYOF:			sp++;			break;		case OBACK_:		case O_BACK:			assert(nope);			break;		/* cases where length of match is hard to find */		case OQUEST_:			stp = stop;			for (;;) {				/* how long could this one be? */				rest = slow(m, sp, stp, ss, es);				assert(rest != NULL);	/* it did match */				/* could the rest match the rest? */				tail = slow(m, rest, stop, es, stopst);				if (tail == stop)					break;		/* yes! */				/* no -- try a shorter match for this one */				stp = rest - 1;				assert(stp >= sp);	/* it did work */			}			ssub = ss + 1;			esub = es - 1;			/* did innards match? */			if (slow(m, sp, rest, ssub, esub) != NULL) {				dp = dissect(m, sp, rest, ssub, esub);				assert(dp == rest);			} else		/* no */				assert(sp == rest);			sp = rest;			break;		case OPLUS_:			stp = stop;			for (;;) {				/* how long could this one be? */				rest = slow(m, sp, stp, ss, es);				assert(rest != NULL);	/* it did match */				/* could the rest match the rest? */				tail = slow(m, rest, stop, es, stopst);				if (tail == stop)					break;		/* yes! */				/* no -- try a shorter match for this one */				stp = rest - 1;				assert(stp >= sp);	/* it did work */			}			ssub = ss + 1;			esub = es - 1;			ssp = sp;			oldssp = ssp;			for (;;) {	/* find last match of innards */				sep = slow(m, ssp, rest, ssub, esub);				if (sep == NULL || sep == ssp)					break;	/* failed or matched null */				oldssp = ssp;	/* on to next try */				ssp = sep;			}			if (sep == NULL) {				/* last successful match */				sep = ssp;				ssp = oldssp;			}			assert(sep == rest);	/* must exhaust substring */			assert(slow(m, ssp, sep, ssub, esub) == rest);			dp = dissect(m, ssp, sep, ssub, esub);			assert(dp == sep);			sp = rest;			break;		case OCH_:			stp = stop;			for (;;) {				/* how long could this one be? */				rest = slow(m, sp, stp, ss, es);				assert(rest != NULL);	/* it did match */				/* could the rest match the rest? */				tail = slow(m, rest, stop, es, stopst);				if (tail == stop)					break;		/* yes! */				/* no -- try a shorter match for this one */				stp = rest - 1;				assert(stp >= sp);	/* it did work */			}			ssub = ss + 1;			esub = ss + OPND(m->g->strip[ss]) - 1;			assert(OP(m->g->strip[esub]) == OOR1);			for (;;) {	/* find first matching branch */				if (slow(m, sp, rest, ssub, esub) == rest)					break;	/* it matched all of it */				/* that one missed, try next one */				assert(OP(m->g->strip[esub]) == OOR1);				esub++;				assert(OP(m->g->strip[esub]) == OOR2);				ssub = esub + 1;				esub += OPND(m->g->strip[esub]);				if (OP(m->g->strip[esub]) == OOR2)					esub--;				else					assert(OP(m->g->strip[esub]) == O_CH);			}			dp = dissect(m, sp, rest, ssub, esub);			assert(dp == rest);			sp = rest;			break;		case O_PLUS:		case O_QUEST:		case OOR1:		case OOR2:		case O_CH:			assert(nope);			break;		case OLPAREN:			i = OPND(m->g->strip[ss]);			assert(0 < i && i <= m->g->nsub);			m->pmatch[i].rm_so = sp - m->offp;			break;		case ORPAREN:			i = OPND(m->g->strip[ss]);			assert(0 < i && i <= m->g->nsub);			m->pmatch[i].rm_eo = sp - m->offp;			break;		default:		/* uh oh */			assert(nope);			break;		}	}	assert(sp == stop);	return(sp);}/* - backref - figure out what matched what, figuring in back references == static char *backref(register struct match *m, char *start, \ ==	char *stop, sopno startst, sopno stopst, sopno lev); */static char *			/* == stop (success) or NULL (failure) */backref(m, start, stop, startst, stopst, lev)register struct match *m;char *start;char *stop;sopno startst;sopno stopst;sopno lev;			/* PLUS nesting level */{	register int i;	register sopno ss;	/* start sop of current subRE */	register char *sp;	/* start of string matched by it */	register sopno ssub;	/* start sop of subsubRE */	register sopno esub;	/* end sop of subsubRE */	register char *ssp;	/* start of string matched by subsubRE */	register char *dp;	register size_t len;	register int hard;	register sop s;	register regoff_t offsave;	register cset *cs;	AT("back", start, stop, startst, stopst);	sp = start;	/* get as far as we can with easy stuff */	hard = 0;	for (ss = startst; !hard && ss < stopst; ss++)		switch (OP(s = m->g->strip[ss])) {		case OCHAR:			if (sp == stop || *sp++ != (char)OPND(s))				return(NULL);			break;		case OANY:			if (sp == stop)				return(NULL);			sp++;			break;		case OANYOF:			cs = &m->g->sets[OPND(s)];			if (sp == stop || !CHIN(cs, *sp++))				return(NULL);			break;		case OBOL:			if ( (sp == m->beginp && !(m->eflags&REG_NOTBOL)) ||					(sp < m->endp && *(sp-1) == '\n' &&						(m->g->cflags&REG_NEWLINE)) )				{ /* yes */ }			else				return(NULL);			break;		case OEOL:			if ( (sp == m->endp && !(m->eflags&REG_NOTEOL)) ||					(sp < m->endp && *sp == '\n' &&						(m->g->cflags&REG_NEWLINE)) )				{ /* yes */ }			else				return(NULL);			break;		case OBOW:			if (( (sp == m->beginp && !(m->eflags&REG_NOTBOL)) ||					(sp < m->endp && *(sp-1) == '\n' &&						(m->g->cflags&REG_NEWLINE)) ||					(sp > m->beginp &&							!ISWORD(*(sp-1))) ) &&					(sp < m->endp && ISWORD(*sp)) )				{ /* yes */ }			else				return(NULL);			break;		case OEOW:			if (( (sp == m->endp && !(m->eflags&REG_NOTEOL)) ||					(sp < m->endp && *sp == '\n' &&						(m->g->cflags&REG_NEWLINE)) ||					(sp < m->endp && !ISWORD(*sp)) ) &&					(sp > m->beginp && ISWORD(*(sp-1))) )				{ /* yes */ }			else				return(NULL);			break;		case O_QUEST:			break;		case OOR1:	/* matches null but needs to skip */			ss++;			s = m->g->strip[ss];			do {				assert(OP(s) == OOR2);				ss += OPND(s);			} while (OP(s = m->g->strip[ss]) != O_CH);			/* note that the ss++ gets us past the O_CH */			break;		default:	/* have to make a choice */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美大片一区二区三区| 国产精品白丝jk白祙喷水网站| 日韩精品资源二区在线| 91麻豆国产在线观看| 蜜臀久久99精品久久久久久9| 亚洲天天做日日做天天谢日日欢| 精品久久久久久久久久久久久久久久久| 国产精品一区二区视频| 石原莉奈在线亚洲二区| 亚洲欧洲国产日韩| 2欧美一区二区三区在线观看视频| 欧美欧美欧美欧美| 欧美亚洲综合在线| 色狠狠综合天天综合综合| 韩国三级电影一区二区| 秋霞成人午夜伦在线观看| 亚洲老妇xxxxxx| 亚洲一区二区精品久久av| 亚洲综合免费观看高清完整版 | 亚洲一区中文日韩| 亚洲免费在线观看| 亚洲欧美日韩电影| 亚洲蜜臀av乱码久久精品| 一区在线观看视频| 樱桃国产成人精品视频| 亚洲高清视频在线| 秋霞国产午夜精品免费视频| 日韩电影在线观看电影| 蜜臀va亚洲va欧美va天堂| 韩国av一区二区三区在线观看| 激情综合色播激情啊| 国产精品亚洲一区二区三区在线 | 亚洲三级免费电影| 婷婷六月综合网| 精品亚洲免费视频| av午夜一区麻豆| 欧美人与性动xxxx| 国产亚洲欧美激情| 亚洲自拍偷拍欧美| 国产成人啪午夜精品网站男同| 成人免费毛片aaaaa**| 欧美日韩一区二区三区高清| wwwwww.欧美系列| 亚洲午夜免费视频| 国产在线播放一区二区三区| 91啪亚洲精品| 日韩精品一区二区三区蜜臀| 亚洲激情自拍视频| 国产麻豆视频一区| 欧美日韩一区二区三区四区五区| www国产精品av| 麻豆国产精品官网| 欧美日韩小视频| 亚洲女同ⅹxx女同tv| 国产一区二区三区免费看 | 日韩美女视频一区二区在线观看| 国产精品久久久久9999吃药| 免费高清不卡av| 欧美一区日本一区韩国一区| 亚洲与欧洲av电影| 成人a区在线观看| 久久人人爽人人爽| 久久国产欧美日韩精品| 91精品国产综合久久香蕉的特点| 亚洲婷婷综合久久一本伊一区| 国产精品18久久久久久久久久久久| 欧美日韩国产美| 调教+趴+乳夹+国产+精品| 欧美日韩免费一区二区三区 | 精品99一区二区三区| 久久国产夜色精品鲁鲁99| 欧美日韩一区国产| 久久精品免视看| 91免费看`日韩一区二区| 高清在线成人网| 国产精品麻豆99久久久久久| 欧美日高清视频| 丁香婷婷深情五月亚洲| 久久久亚洲高清| 成人在线视频首页| 亚洲欧洲日韩综合一区二区| 成人国产精品视频| 亚洲精品视频一区二区| 99re在线精品| 最好看的中文字幕久久| 在线观看日韩高清av| 蜜桃av一区二区三区| 337p日本欧洲亚洲大胆色噜噜| 国产盗摄一区二区三区| 天天做天天摸天天爽国产一区| 欧美电视剧在线观看完整版| 国精产品一区一区三区mba桃花| 中文字幕一区二区三区四区| 欧美一级久久久| 一本大道综合伊人精品热热| 免费人成精品欧美精品| 一色屋精品亚洲香蕉网站| 日韩欧美国产一区在线观看| 欧美亚洲禁片免费| 亚洲一级二级三级| 欧美视频自拍偷拍| 91黄视频在线| 欧美片网站yy| 精品福利视频一区二区三区| 99久久99久久精品免费观看| 激情成人综合网| 蜜臀av一区二区在线观看| 亚洲高清中文字幕| 亚洲成人免费观看| 亚洲免费在线观看视频| 自拍偷在线精品自拍偷无码专区| 欧美一区二区久久久| 色伊人久久综合中文字幕| 国产不卡在线一区| 91老师片黄在线观看| 老司机精品视频导航| 日日骚欧美日韩| 久久精品国产一区二区三区免费看 | 亚洲精品亚洲人成人网| 国产免费久久精品| 国产精品美女一区二区三区| 亚洲国产成人一区二区三区| 久久综合一区二区| 国产亚洲va综合人人澡精品| 久久精品视频一区二区三区| www久久精品| 最新中文字幕一区二区三区| 亚洲精品福利视频网站| 日韩精品成人一区二区三区| 国产一区二区美女| 色嗨嗨av一区二区三区| 欧美大片拔萝卜| 一区二区在线观看视频在线观看| 国产精品久久久久久久久免费樱桃| 欧美不卡123| 国产欧美精品一区| 亚洲综合免费观看高清完整版在线| 亚洲精品成a人| 精品影院一区二区久久久| 国产成人三级在线观看| 色丁香久综合在线久综合在线观看| 欧美精品乱码久久久久久按摩| 日韩亚洲欧美一区| 综合激情成人伊人| 亚洲bt欧美bt精品| 国产一级精品在线| 色成年激情久久综合| 久久影院午夜论| 久久久高清一区二区三区| 一区二区三区欧美日| 麻豆久久久久久| 欧美特级限制片免费在线观看| 欧美不卡一区二区三区| 亚洲免费电影在线| 高清久久久久久| 日韩一区二区三区电影在线观看 | 91在线国内视频| 久久中文娱乐网| 日韩精品成人一区二区三区| www.99精品| 久久精品在这里| 国产自产视频一区二区三区| 欧美性极品少妇| 一区二区三区精品在线观看| 国产99精品国产| 国产欧美日韩视频一区二区| 久久国内精品自在自线400部| 欧美日韩免费电影| 有码一区二区三区| 在线视频综合导航| 亚洲最大的成人av| 色欧美片视频在线观看在线视频| 亚洲天堂av老司机| 色综合天天综合网天天看片| 日本一区二区动态图| 成人性生交大片免费看视频在线 | 一区二区三区在线视频观看| 91免费版在线看| 亚洲国产三级在线| 欧美一级久久久| 国产真实乱偷精品视频免| 欧美不卡一区二区三区| 国产精品资源在线观看| 国产精品萝li| 91精品免费观看| 国产一区二区在线免费观看| 国产精品人成在线观看免费| 色综合久久久久综合99| 五月激情综合婷婷| 久久久www免费人成精品| 成人av网站大全| 亚洲免费在线电影| 日韩一二在线观看| 91麻豆免费观看| 六月丁香综合在线视频| 亚洲婷婷在线视频| 日韩欧美中文一区二区| 国产成+人+日韩+欧美+亚洲| 午夜欧美视频在线观看| 国产精品天美传媒沈樵|