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

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

?? htrules.c

?? www工具包. 這是W3C官方支持的www支撐庫. 其中提供通用目的的客戶端的WebAPI: complete HTTP/1.1 (with caching, pipelining, PUT, POS
?? C
字號:
/*								      HTRules.c**	CONFIGURATION MANAGER FOR CLIENTS****	(c) COPYRIGHT MIT 1995.**	Please first read the full copyright statement in the file COPYRIGH.**	@(#) $Id: HTRules.c,v 2.61 1999/02/22 22:10:12 frystyk Exp $****	This module manages rule files in the Library**** History:**	 3 Jun 91	Written TBL**	10 Aug 91	Authorisation added after Daniel Martin (pass, fail)**			Rule order in file changed**			Comments allowed with # on 1st char of rule line**      17 Jun 92       Bug fix: pass and fail failed if didn't contain '*' TBL**       1 Sep 93       Bug fix: no memory check - Nathan Torkington**                      BYTE_ADDRESSING removed - Arthur Secret**	11 Sep 93  MD	Changed %i into %d in debug printf. **			VMS does not recognize %i.**			Bug Fix: in case of PASS, only one parameter to printf.**	19 Sep 93  AL	Added Access Authorization stuff.**	 1 Nov 93  AL	Added htbin.**	30 Nov 93  AL	Added HTTranslateReq().**	 4 Feb 94  AL	Took away all the daemon-specific stuff.**      28 Sep 94  HWL  Added field to HTPresentation_add call**	15 Nov 95  HFN	Made a stream, fixed interface and made new translater**** BUGS: We only have one wildcard match pr rule!*//* Library include files */#include "WWWLib.h"#include "WWWFile.h"#include "HTProxy.h"#include "HTRules.h"					 /* Implemented here */struct _HTStream {    const HTStreamClass *	isa;    HTRequest *			request;    HTChunk *			buffer;    HTEOLState			EOLstate;};struct _HTRule {    HTRuleOp	op;    char *	pattern;    char *	replace;    int   	insert;		       /* Index into any wildcard in replace */};PRIVATE HTList * rules = NULL;/* ------------------------------------------------------------------------- *//***	Rules are handled as list as everything else that has to do with**	preferences. We provide two functions for getting and setting the**	global rules*/PUBLIC HTList * HTRule_global (void){    if (!rules) rules = HTList_new();    return rules;}PUBLIC BOOL HTRule_setGlobal(HTList * list){    if (rules) HTRule_deleteAll(rules);    rules = list;    return YES;}PUBLIC BOOL HTRule_addGlobal(HTRuleOp op,			     const char * pattern, const char * replace){    if (!rules) rules = HTList_new();    return HTRule_add(rules, op, pattern, replace);}/*	Add rule to the list**	--------------------**	This function adds a rule to the list of rules. The**	pattern is a 0-terminated string containing a single**	"*". <CODE>equiv</CODE> points to the equivalent string with * for the**	place where the text matched by * goes.**  On entry,**	pattern		points to 0-terminated string containing a single "*"**	replace		points to the equivalent string with * for the**			place where the text matched by * goes.**  On exit,**	returns		YES if OK, else NO*/PUBLIC BOOL HTRule_add (HTList * list, HTRuleOp op,			const char * pattern, const char * replace){    if (list && pattern) {	HTRule * me;	if ((me = (HTRule  *) HT_CALLOC(1, sizeof(HTRule))) == NULL)	    HT_OUTOFMEM("HTRule_add");	me->op = op;	StrAllocCopy(me->pattern, pattern);	if (replace) {	    char *ptr = strchr(replace, '*');	    StrAllocCopy(me->replace, replace);	    me->insert = ptr ? ptr-replace : -1;	    HTTRACE(APP_TRACE, "Rule Add.... For `%s\' op %d `%s\'\n" _ 			 pattern _ op _ replace);	} else {	    HTTRACE(APP_TRACE, "Rule Add.... For `%s\' op %d\n" _ pattern _ op);	}	return HTList_appendObject(list, (void *) me);    }    return NO;}/*	Delete all rules**	----------------**	Deletes all the rules registered by this module*/PUBLIC BOOL HTRule_deleteAll (HTList * list){    if (list) {	HTList *cur = list;	HTRule *pres;	while ((pres = (HTRule *) HTList_nextObject(cur))) {	    HT_FREE(pres->pattern);	    HT_FREE(pres->replace);	    HT_FREE(pres);	}	return HTList_delete(list);    }    return NO;}/*	Translate by rules**	------------------**	The most recently defined rules are applied last.**	This function walks through the list of rules and translates the**	reference when matches are found. The list is traversed in order**	starting from the head of the list. It returns the address of the**	equivalent string allocated from the heap which the CALLER MUST**	FREE.*/PUBLIC char * HTRule_translate (HTList * list, const char * token,				BOOL ignore_case){    HTRule * pres;    char * replace = NULL;    if (!token || !list) return NULL;    HTTRACE(APP_TRACE, "Check rules. for `%s\'\n" _ token);    while ((pres = (HTRule *) HTList_nextObject(list))) {	char * rest = ignore_case ? HTStrCaseMatch(pres->pattern, token) :	    HTStrMatch(pres->pattern, token);	if (!rest) continue;				  /* No match at all */    	/* We found a match for this entry, now do operation */	switch (pres->op) {          case HT_Pass:	  case HT_Map:	    if (!pres->replace) {			       /* No replace */		StrAllocCopy(replace, token);	    } else if (*rest && pres->insert >= 0) {		if ((replace = (char  *) HT_MALLOC(strlen(pres->replace)+strlen(rest))) == NULL)		    HT_OUTOFMEM("HTRule_translate");		strcpy(replace, pres->replace);		strcpy(replace+pres->insert, rest);	    } else {		       /* Perfect match or no insetion point */		StrAllocCopy(replace, pres->replace);	    }	    if (pres->op == HT_Pass) {		HTTRACE(APP_TRACE, "............ map into `%s'\n" _ replace);		return replace;	    }	    break;	    	  case HT_Fail:	  default:	    HTTRACE(APP_TRACE, "............ FAIL `%s'\n" _ token);	    return NULL;	}    }    if (!replace) StrAllocCopy(replace, token);    return replace;}/*	Load one line of configuration**	------------------------------**	Call this, for example, to load a X resource with config info.**	Returns YES if line OK, else NO*/PUBLIC BOOL HTRule_parseLine (HTList * list, const char * config){    HTRuleOp op;    char * line = NULL;    char * ptr;    char * word1, * word2, * word3;    int status;    if (!config) return NO;    if ((ptr = strchr(config, '#'))) *ptr = '\0';    StrAllocCopy(line, config);				 /* Get our own copy */    ptr = line;    HTTRACE(APP_TRACE, "Rule Parse.. `%s\'\n" _ config ? config : "<null>");    if ((word1 = HTNextField(&ptr)) == NULL) {		       /* Empty line */	HT_FREE(line);	return YES;    }    if ((word2 = HTNextField(&ptr)) == NULL) {	HTTRACE(APP_TRACE, "Rule Parse.. Insufficient operands: `%s\'\n" _ line);	HT_FREE(line);	return NO;    }    word3 = HTNextField(&ptr);    /* Look for things we recognize */    if (!strcasecomp(word1, "addtype")) {	double quality;        char * encoding = HTNextField(&ptr);	status = ptr ? sscanf(ptr, "%lf", &quality) : 0;	HTBind_add(word2,				/* suffix */		   word3,				/* type */		   encoding ? encoding : "binary",	/* encoding */		   NULL,				/* cte */		   NULL,				/* language */		   status >= 1? quality : 1.0);		/* quality */    } else if (!strcasecomp(word1, "addencoding")) {	double quality;	status = ptr ? sscanf(ptr, "%lf", &quality) : 0;	HTBind_addEncoding(word2, word3, status >= 1 ? quality : 1.0);    } else if (!strcasecomp(word1, "addlanguage")) {	double quality;	status = ptr ? sscanf(ptr, "%lf", &quality) : 0;	HTBind_addLanguage(word2, word3, status >= 1 ? quality : 1.0);    } else if (!strcasecomp(word1, "presentation")) {	HTList * converters = HTFormat_conversion();	double quality, secs, secs_per_byte;        status = ptr ? sscanf(ptr,"%lf%lf%lf",&quality,&secs,&secs_per_byte):0;	HTPresentation_add(converters, word2, word3, NULL,			   status >= 1 ? quality : 1.0,			   status >= 2 ? secs : 0.0,			   status >= 3 ? secs_per_byte : 0.0);    } else if (!strcasecomp(word1, "proxy")) {	HTProxy_add(word2, word3);	    } else if (!strcasecomp(word1, "noproxy")) {	int port = 0;        status = ptr ? sscanf(ptr, "%d", &port) : 0;	HTNoProxy_add(word2, word3, port);    } else if (!strcasecomp(word1, "gateway")) {	HTGateway_add(word2, word3);    } else {	op =	0==strcasecomp(word1, "map")  ?	HT_Map	    :	0==strcasecomp(word1, "pass") ?	HT_Pass	    :	0==strcasecomp(word1, "fail") ?	HT_Fail	    :					HT_Invalid;	if (op == HT_Invalid) {	    HTTRACE(APP_TRACE, "Rule Parse.. Bad or unknown: `%s'\n" _ config);	} else	    HTRule_add(list, op, word2, word3);    }    HT_FREE(line);    return YES;}/***	Folding is either of CF LWS, LF LWS, CRLF LWS*/PRIVATE int HTRule_put_block (HTStream * me, const char * b, int l){    while (l > 0) {	if (me->EOLstate == EOL_FCR) {	    if (*b == LF)				   	     /* CRLF */		me->EOLstate = EOL_FLF;	    else if (isspace((int) *b))				   /* Folding: CR SP */		me->EOLstate = EOL_DOT;	    else {						 /* New line */		HTRule_parseLine(rules, HTChunk_data(me->buffer));		me->EOLstate = EOL_BEGIN;		HTChunk_clear(me->buffer);		continue;	    }	} else if (me->EOLstate == EOL_FLF) {	    if (isspace((int) *b))		       /* Folding: LF SP or CR LF SP */		me->EOLstate = EOL_DOT;	    else {						/* New line */		HTRule_parseLine(rules, HTChunk_data(me->buffer));		me->EOLstate = EOL_BEGIN;		HTChunk_clear(me->buffer);		continue;	    }	} else if (me->EOLstate == EOL_DOT) {	    if (isspace((int) *b)) {		me->EOLstate = EOL_BEGIN;		HTChunk_putc(me->buffer, ' ');	    } else {		HTRule_parseLine(rules, HTChunk_data(me->buffer));		me->EOLstate = EOL_BEGIN;		HTChunk_clear(me->buffer);		continue;	    }	} else if (*b == CR) {	    me->EOLstate = EOL_FCR;	} else if (*b == LF) {	    me->EOLstate = EOL_FLF;			       /* Line found */	} else	    HTChunk_putc(me->buffer, *b);	l--; b++;    }    return HT_OK;}PRIVATE int HTRule_put_character (HTStream * me, char c){    return HTRule_put_block(me, &c, 1);}PRIVATE int HTRule_put_string (HTStream * me, const char * s){    return HTRule_put_block(me, s, (int) strlen(s));}PRIVATE int HTRule_flush (HTStream * me){    if (me) {	char * flush = HTChunk_data(me->buffer);	if (flush) HTRule_parseLine(rules, flush);	HTChunk_clear(me->buffer);    }    return HT_OK;}PRIVATE int HTRule_free (HTStream * me){    if (me) {	int status = HTRule_flush(me);	HTTRACE(APP_TRACE, "Rules....... FREEING....\n");	HTChunk_delete(me->buffer);	HT_FREE(me);	return status;    }    return HT_ERROR;}PRIVATE int HTRule_abort (HTStream * me, HTList * e){    if (me) {	int status = HT_ERROR;	HTTRACE(APP_TRACE, "Rules....... ABORTING...\n");	HTChunk_delete(me->buffer);	HT_FREE(me);	return status;    }    return HT_ERROR;}/*	Structured Object Class**	-----------------------*/PRIVATE const HTStreamClass HTRuleClass ={		    "RuleParser",    HTRule_flush,    HTRule_free,    HTRule_abort,    HTRule_put_character,    HTRule_put_string,    HTRule_put_block};PUBLIC HTStream * HTRules (HTRequest *	request,			   void *	param,			   HTFormat	input_format,			   HTFormat	output_format,			   HTStream *	output_stream){    HTAlertCallback *cbf = HTAlert_find(HT_A_CONFIRM);        /*    **  If the library has been compiled so that we automatically accept    **  rule files then it's OK not to ask the user.    */#ifdef HT_AUTOMATIC_RULES    if (!cbf || (cbf && (*cbf)(request,HT_A_CONFIRM, HT_MSG_RULES, NULL,NULL,NULL))) {#else    if ((cbf && (*cbf)(request,HT_A_CONFIRM, HT_MSG_RULES, NULL,NULL,NULL))) {#endif	HTStream * me;	HTTRACE(APP_TRACE, "Rule file... Parser object created\n");	if ((me = (HTStream *) HT_CALLOC(1, sizeof(HTStream))) == NULL)	    HT_OUTOFMEM("HTRules");	me->isa = &HTRuleClass;	me->request = request;	me->buffer = HTChunk_new(512);	me->EOLstate = EOL_BEGIN;	if (!rules) rules = HTList_new();	return me;    } else {	HTRequest_addError(request, ERR_FATAL, NO, HTERR_NO_AUTO_RULES,			   NULL, 0, "HTRules");	return HTErrorStream();    }}/***  Parse a rule file - don't ask don't tell - be carefull with this one!*/PUBLIC HTStream * HTRules_parseAutomatically (HTRequest *	request,					      void *		param,					      HTFormat		input_format,					      HTFormat		output_format,					      HTStream *	output_stream){    if (request) {	HTStream * me;	HTTRACE(APP_TRACE, "Rule file... Automatic parser object created\n");	if ((me = (HTStream *) HT_CALLOC(1, sizeof(HTStream))) == NULL)	    HT_OUTOFMEM("HTRules");	me->isa = &HTRuleClass;	me->request = request;	me->buffer = HTChunk_new(512);	me->EOLstate = EOL_BEGIN;	if (!rules) rules = HTList_new();	return me;    } else {	HTRequest_addError(request, ERR_FATAL, NO, HTERR_NO_AUTO_RULES,			   NULL, 0, "HTRules");	return HTErrorStream();    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
最新日韩av在线| 欧美久久婷婷综合色| 日日夜夜精品视频免费| 《视频一区视频二区| 日本一区二区成人在线| 国产日韩v精品一区二区| 国产日韩欧美亚洲| 国产精品福利在线播放| 国产精品婷婷午夜在线观看| 国产亚洲美州欧州综合国| 国产欧美视频一区二区| 中文字幕免费在线观看视频一区| 国产精品高潮呻吟久久| 亚洲男人的天堂网| 亚洲mv在线观看| 国模冰冰炮一区二区| 国产激情91久久精品导航| 国产盗摄视频一区二区三区| 丁香婷婷综合色啪| 色综合天天综合网国产成人综合天| jiyouzz国产精品久久| 欧美日韩综合色| 26uuu久久综合| 中文成人综合网| 夜夜嗨av一区二区三区中文字幕 | 韩国中文字幕2020精品| 国产一区二区三区免费播放| 丁香激情综合国产| 欧美亚洲综合一区| 久久久久久久久久久久久夜| 亚洲欧美自拍偷拍| 日本在线观看不卡视频| 国产精品正在播放| 欧美日韩一二三| 国产欧美精品一区二区色综合 | 综合色中文字幕| 婷婷国产v国产偷v亚洲高清| 免费亚洲电影在线| 日本二三区不卡| 欧美精品一区二区三区蜜臀| 亚洲另类中文字| 激情综合一区二区三区| 欧美午夜在线观看| 精品福利一区二区三区免费视频| 亚洲视频综合在线| 美女视频黄免费的久久 | 秋霞国产午夜精品免费视频| 国产精品一区二区黑丝| 欧美日韩国产高清一区二区 | 国产亚洲一区字幕| 亚洲国产精品一区二区www| 盗摄精品av一区二区三区| 欧美一区午夜精品| 伊人性伊人情综合网| 国产一区二区三区免费观看| 7777精品伊人久久久大香线蕉经典版下载 | 成人午夜激情视频| 欧美大片在线观看一区二区| 悠悠色在线精品| 丁香啪啪综合成人亚洲小说| 日韩美女视频在线| 日本中文字幕一区二区视频 | 亚洲一区二区三区四区的| 狠狠色综合日日| 欧美一卡二卡三卡四卡| 一区二区三区四区乱视频| youjizz久久| 国产精品日韩成人| 国产91精品一区二区| 26uuu色噜噜精品一区| 久久精品国产亚洲高清剧情介绍 | 麻豆成人免费电影| 欧美一区二区人人喊爽| 性欧美大战久久久久久久久| 欧美亚一区二区| 亚洲丰满少妇videoshd| 日本高清视频一区二区| 亚洲免费观看高清| 91麻豆成人久久精品二区三区| 国产精品国产三级国产aⅴ入口| 东方欧美亚洲色图在线| 亚洲精品一线二线三线| 精品一区二区三区在线观看| 日韩三区在线观看| 国内精品久久久久影院色| 国产婷婷色一区二区三区| 国产高清精品在线| 国产精品视频九色porn| va亚洲va日韩不卡在线观看| 亚洲欧美偷拍三级| 欧美三级视频在线| 亚洲自拍都市欧美小说| 欧美精品久久久久久久久老牛影院| 亚洲香肠在线观看| 777色狠狠一区二区三区| 麻豆国产精品官网| 国产精品久久久久影视| 色菇凉天天综合网| 美女脱光内衣内裤视频久久网站| 亚洲精品在线观看网站| 波多野结衣在线aⅴ中文字幕不卡| 国产农村妇女毛片精品久久麻豆 | 欧美午夜精品一区二区蜜桃| 日日夜夜免费精品| 久久久久久亚洲综合| 国产98色在线|日韩| 亚洲一区在线观看免费| 欧美一个色资源| 国产成人精品网址| 一区二区三区不卡在线观看| 日韩一区二区三区电影在线观看| 国产精品一区2区| 一区二区免费在线| 精品88久久久久88久久久 | 久久婷婷国产综合精品青草| 国产激情视频一区二区在线观看 | 亚洲欧美一区二区不卡| 制服丝袜中文字幕一区| 国产福利不卡视频| 五月综合激情网| 欧美国产精品中文字幕| 91精品国产免费| 91在线免费播放| 国产美女精品人人做人人爽 | 精品日韩欧美在线| 99九九99九九九视频精品| 日韩精品一卡二卡三卡四卡无卡| 中文一区在线播放| 日韩一卡二卡三卡国产欧美| 91小视频在线| jizzjizzjizz欧美| 国产高清精品网站| 卡一卡二国产精品| 性做久久久久久| 亚洲一区二区三区视频在线| 国产精品私人自拍| 久久久综合网站| 欧美一级日韩免费不卡| 欧美日韩一区三区四区| 色综合久久久久综合| 国产成人亚洲综合色影视| 精品一区二区三区的国产在线播放| 一区二区三区在线观看网站| 亚洲天堂成人在线观看| 欧美国产日韩精品免费观看| 久久久国际精品| 国产日韩欧美一区二区三区综合| 精品欧美一区二区三区精品久久 | 五月婷婷色综合| 亚洲在线观看免费| 亚洲综合免费观看高清完整版在线| 国产精品午夜在线观看| 国产欧美日韩不卡免费| 国产欧美一区二区精品性色| 久久九九全国免费| 国产精品免费久久久久| 一区在线播放视频| 国产精品毛片大码女人| 亚洲欧美自拍偷拍| 亚洲精品免费在线观看| 亚洲国产aⅴ天堂久久| 午夜激情综合网| 激情久久久久久久久久久久久久久久| 日韩av一区二区在线影视| 久久66热偷产精品| 国产成人精品亚洲午夜麻豆| 成人app在线观看| 91在线丨porny丨国产| 欧美日韩免费高清一区色橹橹| 日韩一区二区在线看| 久久久久9999亚洲精品| 中文字幕一区二区三区视频| 亚洲第一久久影院| 另类小说一区二区三区| 国产**成人网毛片九色| 91浏览器打开| 欧美成人福利视频| 国产精品成人一区二区艾草| 亚洲成av人片一区二区| 蓝色福利精品导航| 91视频一区二区三区| 6080午夜不卡| 国产精品麻豆久久久| 亚洲va欧美va人人爽午夜| 精品写真视频在线观看| 色综合一区二区三区| 日韩欧美电影一二三| 亚洲欧洲日韩一区二区三区| 视频一区视频二区中文| 国产98色在线|日韩| 91首页免费视频| 精品久久免费看| 亚洲精品伦理在线| 国产精品自拍三区| 欧美日韩www| 亚洲情趣在线观看| 韩国成人精品a∨在线观看| 波多野结衣视频一区| 日韩精品在线网站| 亚洲图片欧美色图|