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

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

?? engine.c

?? Vovida 社區開源的 SIP 協議源碼
?? 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 */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级理论性理论a| 国产精品麻豆一区二区| 久久久久久久久岛国免费| 一区二区三区日韩精品| 国产在线国偷精品免费看| 色哦色哦哦色天天综合| 久久久美女艺术照精彩视频福利播放| 一区二区三区在线视频观看| 国产精品一区在线观看你懂的| 91久久人澡人人添人人爽欧美| 久久婷婷国产综合国色天香 | www.日本不卡| 精品三级在线观看| 亚洲国产视频一区| 一本大道综合伊人精品热热 | 亚洲卡通动漫在线| 狠狠色狠狠色合久久伊人| 欧美性色黄大片手机版| 久久这里只精品最新地址| 午夜精品aaa| 欧美中文字幕不卡| 国产精品伦一区| 日本伊人午夜精品| 国产偷v国产偷v亚洲高清| 91久久精品一区二区二区| 精品一区二区三区视频在线观看| 国产色一区二区| 91国产精品成人| 亚洲国产一区二区三区| 国内精品免费**视频| 日本一区二区三区四区 | 中文字幕一区二区三区蜜月| 欧美不卡在线视频| 欧美男人的天堂一二区| 91麻豆.com| 国产不卡一区视频| 热久久国产精品| 国产精品婷婷午夜在线观看| 日韩午夜av一区| 91精品国产综合久久久久久久| 国产毛片精品国产一区二区三区| 国产最新精品免费| 国产精品一区不卡| 国产一区二区三区黄视频| 午夜精品在线看| 亚洲午夜久久久久久久久久久| 中文字幕av不卡| 亚洲免费资源在线播放| 午夜在线电影亚洲一区| 日本vs亚洲vs韩国一区三区二区| 亚洲一二三四在线观看| 亚洲成av人**亚洲成av**| 天天做天天摸天天爽国产一区| 蜜臀av一区二区在线免费观看| 日韩电影在线观看一区| 成人理论电影网| 国产一区二区三区蝌蚪| 色诱亚洲精品久久久久久| 精品国产乱码91久久久久久网站| 中文字幕亚洲电影| 久久精品国产第一区二区三区| 成人免费视频播放| 7777精品伊人久久久大香线蕉的 | 成人欧美一区二区三区在线播放| 亚洲国产日韩一区二区| 国产不卡在线一区| 2023国产精品| 日韩**一区毛片| 欧洲生活片亚洲生活在线观看| 国产精品三级电影| 国产一本一道久久香蕉| 日韩免费一区二区三区在线播放| 亚洲素人一区二区| 成人深夜福利app| 国产校园另类小说区| 极品少妇一区二区| 精品国产青草久久久久福利| 午夜一区二区三区视频| 在线视频欧美区| 麻豆久久久久久久| 欧美精品一区二区在线观看| 国产在线精品视频| 亚洲视频在线一区二区| 欧美性大战久久| 日日夜夜精品免费视频| 日韩三级伦理片妻子的秘密按摩| 日本一区中文字幕| 欧美精品自拍偷拍动漫精品| 五月婷婷激情综合网| 欧美精品高清视频| 极品少妇xxxx精品少妇偷拍| 久久久不卡影院| 一道本成人在线| 久久精品国产久精国产爱| 国产三区在线成人av| 91尤物视频在线观看| 日本欧美韩国一区三区| 久久久99精品免费观看不卡| 国产精品中文欧美| 亚洲激情图片一区| 67194成人在线观看| 国产成人啪午夜精品网站男同| 国产精品国产自产拍在线| 欧美揉bbbbb揉bbbbb| 国产99精品国产| 精品一区二区在线观看| 亚洲一区二区三区视频在线| 久久久久99精品一区| 91精品国产一区二区三区| 91麻豆文化传媒在线观看| 麻豆精品久久精品色综合| 亚洲精品国久久99热| 中文字幕不卡的av| 精品久久久久久亚洲综合网 | 久久激情五月激情| 午夜影视日本亚洲欧洲精品| 亚洲欧美色一区| 亚洲区小说区图片区qvod| 久久久久久夜精品精品免费| 欧美一级理论片| 日韩欧美二区三区| 精品88久久久久88久久久| 久久久久久久久久久久久久久99| 精品国产一区二区三区忘忧草 | 色菇凉天天综合网| 一本久久精品一区二区| 欧美日韩另类国产亚洲欧美一级| 777a∨成人精品桃花网| 日韩一区二区视频| 日韩精品影音先锋| 中文字幕欧美区| 亚洲欧美电影院| 日韩国产在线观看| caoporn国产精品| 4438x成人网最大色成网站| 欧美电影精品一区二区| 久久嫩草精品久久久精品| 国产精品电影院| 图片区小说区国产精品视频| 韩国三级中文字幕hd久久精品| 高清成人在线观看| 欧美久久久影院| 亚洲免费在线观看| 国产精品99久久久久久宅男| 色综合欧美在线视频区| 欧美xxxxx牲另类人与| 亚洲欧美欧美一区二区三区| 免费xxxx性欧美18vr| 欧美综合视频在线观看| 国产精品美女久久久久久久久久久 | 日韩美女久久久| 久久99国产精品久久99| 欧美亚洲日本一区| 欧美精品一区二区三区四区 | 国产亚洲精久久久久久| 日本三级亚洲精品| 在线观看国产日韩| 国产精品久久毛片| 久久99日本精品| 91精品视频网| 麻豆国产精品官网| 91精品国产综合久久久久久 | 亚洲欧洲精品成人久久奇米网| 国内外成人在线| 久久伊人中文字幕| 国产乱子轮精品视频| 精品动漫一区二区三区在线观看| 一区二区三区精品视频| 99久久国产综合精品色伊| 成人欧美一区二区三区| 91视频www| 在线观看www91| 亚洲国产精品一区二区久久| 欧美日韩不卡一区二区| 九九热在线视频观看这里只有精品| 精品国产乱码久久久久久图片| 国产成人av影院| 自拍视频在线观看一区二区| 7777精品伊人久久久大香线蕉超级流畅 | 国产在线看一区| 亚洲国产成人高清精品| 26uuu另类欧美| 在线视频欧美区| 精品一二三四区| 亚洲va欧美va天堂v国产综合| 日韩欧美第一区| 91久久国产综合久久| 精品一区二区在线免费观看| 国产精品毛片a∨一区二区三区| 欧美性色aⅴ视频一区日韩精品| 激情图区综合网| 亚洲国产另类av| 亚洲人123区| 91精品午夜视频| 色伊人久久综合中文字幕| 激情另类小说区图片区视频区| 亚洲一区二区中文在线| 久久综合网色—综合色88| 欧美精品在线视频| 欧美日韩视频在线第一区|