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

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

?? htreqman.c

?? www工具包. 這是W3C官方支持的www支撐庫(kù). 其中提供通用目的的客戶端的WebAPI: complete HTTP/1.1 (with caching, pipelining, PUT, POS
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/*								     HTReqMan.c**	REQUEST MANAGER****	(c) COPYRIGHT MIT 1995.**	Please first read the full copyright statement in the file COPYRIGH.**	@(#) $Id: HTReqMan.c,v 2.83 2002/05/29 16:09:13 kirschpi Exp $**** Authors**	TBL	Tim Berners-Lee timbl@w3.org**	JFG	Jean-Francois Groff jfg@dxcern.cern.ch**	DD	Denis DeLaRoca (310) 825-4580  <CSP1DWD@mvs.oac.ucla.edu>**	HFN	Henrik Frystyk, frystyk@w3.org** Contribution**      MKP     Manuele Kirsch, Manuele.Kirsch_Pinheiro@inrialpes.fr or manuele@inf.ufrgs.br** History**       8 Jun 92 Telnet hopping prohibited as telnet is not secure TBL**	26 Jun 92 When over DECnet, suppressed FTP, Gopher and News. JFG**	 6 Oct 92 Moved HTClientHost and HTlogfile into here. TBL**	17 Dec 92 Tn3270 added, bug fix. DD**	 4 Feb 93 Access registration, Search escapes bad chars TBL**		  PARAMETERS TO HTSEARCH AND HTLOADRELATIVE CHANGED**	28 May 93 WAIS gateway explicit if no WAIS library linked in.**	   Dec 93 Bug change around, more reentrant, etc**	09 May 94 logfile renamed to HTlogfile to avoid clash with WAIS**	 8 Jul 94 Insulate free() from _free structure element.**	02 Sep 95 Rewritten and spawned from HTAccess.c, HFN**      14 Fev 02 Message body added to HTRequest*/#if !defined(HT_DIRECT_WAIS) && !defined(HT_DEFAULT_WAIS_GATEWAY)#define HT_DEFAULT_WAIS_GATEWAY "http://www.w3.org:8001/"#endif/* Library include files */#include "wwwsys.h"#include "WWWUtil.h"#include "HTParse.h"#include "HTNoFree.h"#include "HTAlert.h"#include "HTError.h"#include "HTNetMan.h"#include "HTEvent.h"#include "HTProt.h"#include "HTHeader.h"#include "HTLib.h"#include "HTReqMan.h"					 /* Implemented here */#ifndef HT_MAX_RELOADS#define HT_MAX_RELOADS	6#endifPRIVATE int HTMaxRetry = HT_MAX_RELOADS;struct _HTStream {	HTStreamClass * isa;	/* ... */};/* --------------------------------------------------------------------------*//*			Create and delete the HTRequest Object		     *//* --------------------------------------------------------------------------*/PUBLIC HTRequest * HTRequest_new (void){    HTRequest * me;    if ((me = (HTRequest *) HT_CALLOC(1, sizeof(HTRequest))) == NULL)        HT_OUTOFMEM("HTRequest_new()");       /* Force Reload */    me->reload = HT_CACHE_OK;    /* no default PUT name */    me->default_put_name = NULL;    /* Set the default user profile */    me->userprofile = HTLib_userProfile();    /* Format of output */    me->output_format	= WWW_PRESENT;	    /* default it to present to user */    me->debug_format	= WWW_DEBUG;	 /* default format of error messages */    /* HTTP headers */    me->GenMask		= DEFAULT_GENERAL_HEADERS;    me->RequestMask	= DEFAULT_REQUEST_HEADERS;    me->ResponseMask	= DEFAULT_RESPONSE_HEADERS;    me->EntityMask	= DEFAULT_ENTITY_HEADERS;    /* Default retry after value */    me->priority = HT_PRIORITY_MAX;    /* Default max forward value */    me->max_forwards = -1;    /* Content negotiation */    me->ContentNegotiation = YES;		       /* Do this by default */#ifdef HT_EXT    /* Message Body */    me->messageBody = NULL;             /* MKP: default value is NULL - no message body set */    me->messageBodyLength = -1;         /* MKP: default value is -1 */    me->messageBodyFormat = NULL;       /* MKP: default value is NULL */#endif        HTTRACE(CORE_TRACE, "Request..... Created %p\n" _ me);    return me;}/*	HTRequest_clear**	---------------**	Clears all protocol specific information so that the request object**	can be used for another request.**	Returns YES if OK, else NO*/PUBLIC BOOL HTRequest_clear (HTRequest * me){    if (me) {	me->error_stack = NULL;	me->net = NULL;	me->realm = NULL;	me->credentials = NULL;	me->connected = NO;        if (me->default_put_name)          HTRequest_deleteDefaultPutName (me);	if (me->response) {	    HTResponse_delete(me->response);	    me->response = NULL;	}        #ifdef HT_EXT        if (me->messageBody)                    /* MKP: clear message body */            HTRequest_deleteMessageBody(me);            me->messageBodyFormat = NULL;        me->messageBodyLength = -1;     #endif        	return YES;    }    return NO;}/*	HTRequest_dup**	-------------**	Creates a new HTRequest object as a duplicate of the src request.**	Returns YES if OK, else NO*/PUBLIC HTRequest * HTRequest_dup (HTRequest * src){    HTRequest * me;    if (!src) return NULL;    if ((me = (HTRequest  *) HT_MALLOC(sizeof(HTRequest))) == NULL)        HT_OUTOFMEM("HTRequest_dup");    memcpy(me, src, sizeof(HTRequest));    HTTRACE(CORE_TRACE, "Request..... Duplicated %p to %p\n" _ src _ me);    return me;}/*	HTRequest_dupInternal**	---------------------**	Creates a new HTRequest object as a duplicate of the src request.**	The difference to the HTRequest_dup function is that we don't copy the**	error_stack and other information that the application keeps in its**	copy of the request object. Otherwise it will be freed multiple times**	Returns YES if OK, else NO*/PUBLIC HTRequest * HTRequest_dupInternal (HTRequest * src){    HTRequest * me;    if (!src) return 0;    if ((me = (HTRequest  *) HT_MALLOC(sizeof(HTRequest))) == NULL)        HT_OUTOFMEM("HTRequest_dup");    memcpy(me, src, sizeof(HTRequest));    HTRequest_clear(me);    return me;}PUBLIC void HTRequest_delete (HTRequest * me){    if (me) {	HTTRACE(CORE_TRACE, "Request..... Delete %p\n" _ me);	if (me->net) HTNet_setRequest(me->net, NULL);	/*	** Make sure we don't delete the same stream twice, when the output	** stream and the debug stream are the same.	*/	if (me->orig_output_stream == me->orig_debug_stream)	{	    me->orig_debug_stream = NULL;	}	/* Should we delete the output stream? */	if (me->orig_output_stream) {	    HTTRACE(CORE_TRACE, "Request..... Deleting dangling output stream\n");	    (*me->orig_output_stream->isa->_free)(me->orig_output_stream);	    me->orig_output_stream = NULL;	    HTNoFreeStream_delete(me->output_stream);	    me->output_stream = NULL;	}	/* Should we delete the debug stream? */	if (me->orig_debug_stream) {	    HTTRACE(CORE_TRACE, "Request..... Deleting dangling debug stream\n");	    (*me->orig_debug_stream->isa->_free)(me->orig_debug_stream);	    me->orig_debug_stream = NULL;	    HTNoFreeStream_delete(me->debug_stream);	    me->debug_stream = NULL;	}	/* Clean up the error stack */	if (me->error_stack) HTError_deleteAll(me->error_stack);	/* Before and After Filters */	if (me->afters) HTNetCall_deleteAfterAll(me->afters);	if (me->befores) HTNetCall_deleteBeforeAll(me->befores);        /* default PUT name */        if (me->default_put_name)          HTRequest_deleteDefaultPutName (me);	/* Access Authentication */	HT_FREE(me->realm);	if (me->credentials) HTAssocList_delete(me->credentials);	/* Cache control headers */	if (me->cache_control)	    HTAssocList_delete(me->cache_control);	/* Byte ranges */	if (me->byte_ranges) HTAssocList_delete(me->byte_ranges);	/* Connection headers */	if (me->connection) HTAssocList_delete(me->connection);	/* Connection headers */	if (me->expect) HTAssocList_delete(me->expect);	/* Proxy information */	HT_FREE(me->proxy);	/* Extra header fields */	if (me->extra_headers) HTAssocList_delete(me->extra_headers);	/* HTTP Extension Information */	if (me->optional) HTAssocList_delete(me->optional);	if (me->mandatory) HTAssocList_delete(me->mandatory);	/* Any response object */	if (me->response) HTResponse_delete(me->response);#ifdef HT_EXT        if (me->messageBody) HTRequest_deleteMessageBody(me); /* MKP: clear message body*/              me->messageBodyFormat = NULL;        me->messageBodyLength = -1;     #endif        	HT_FREE(me);    }}/***	Kill this request*/PUBLIC BOOL HTRequest_kill(HTRequest * me){    return me ? HTNet_kill(me->net) : NO;}/* --------------------------------------------------------------------------*//*			Methods on the HTRequest Object			     *//* --------------------------------------------------------------------------*//***  Internal request object*/PUBLIC BOOL HTRequest_setInternal (HTRequest * me, BOOL mode){    if (me) {	me->internal = mode;	return YES;    }    return NO;}PUBLIC BOOL HTRequest_internal (HTRequest * me){    return (me ? me->internal : NO);}/***  Should we flush immediately?*/PUBLIC BOOL HTRequest_setFlush (HTRequest * me, BOOL mode){    if (me) {	me->flush = mode;	return YES;    }    return NO;}PUBLIC BOOL HTRequest_flush (HTRequest * me){    return (me ? me->flush : NO);}/***	Date/time stamp when then request was issued**	This is normally set when generating the request headers.*/PUBLIC time_t HTRequest_date (HTRequest * me){    return me ? me->date : -1;}PUBLIC BOOL HTRequest_setDate (HTRequest * me, time_t date){    if (me) {	me->date = date;	return YES;    }    return NO;}/***	Method*/PUBLIC void HTRequest_setMethod (HTRequest * me, HTMethod method){    if (me) me->method = method;}PUBLIC HTMethod HTRequest_method (HTRequest * me){    return me ? me->method : METHOD_INVALID;}/***  Priority to be inherited by all HTNet object hanging off this request**  The priority can later be chaned by calling the HTNet object directly*/PUBLIC BOOL HTRequest_setPriority (HTRequest * me, HTPriority priority){    if (me) {	me->priority = priority;	return YES;    }    return NO;}PUBLIC HTPriority HTRequest_priority (HTRequest * me){    return (me ? me->priority : HT_PRIORITY_INV);}/***	User Profile*/PUBLIC BOOL HTRequest_setUserProfile (HTRequest * me, HTUserProfile * up){    if (me) {	me->userprofile = up;	return YES;    }    return NO;}PUBLIC HTUserProfile * HTRequest_userProfile (HTRequest * me){    return me ? me->userprofile : NULL;}/***	Net Object*/PUBLIC BOOL HTRequest_setNet (HTRequest * me, HTNet * net){    if (me) {	me->net = net;	return YES;    }    return NO;}PUBLIC HTNet * HTRequest_net (HTRequest * me){    return me ? me->net : NULL;}/***	Response Object. If the object does not exist then create it at the**	same time it is asked for.*/PUBLIC HTResponse * HTRequest_response (HTRequest * me){    if (me) {	if (!me->response)	    me->response = HTResponse_new();	return me->response;    }    return NULL;}PUBLIC BOOL HTRequest_setResponse (HTRequest * me, HTResponse * response){    if (me) {	if (me->response) HTResponse_delete(me->response);	me->response = response;	return YES;    }    return NO;}/*	Error Management**	----------------**	Returns the error stack if a stream is */PUBLIC HTList * HTRequest_error (HTRequest * me){    return me ? me->error_stack : NULL;}PUBLIC void HTRequest_setError (HTRequest * me, HTList * list){    if (me) me->error_stack = list;}/* begin _GM_ *//* Note: libwww bug ID: GM11 */PUBLIC void HTRequest_deleteAllErrors (HTRequest * request){    HTError_deleteAll(request->error_stack);    HTRequest_setError(request, NULL);}/* end _GM_ */PUBLIC BOOL HTRequest_addError (HTRequest * 	me,				HTSeverity	severity,				BOOL		ignore,				int		element,				void *		par,				unsigned int	length,				char *		where){    if (me) {	if (!me->error_stack) me->error_stack = HTList_new();	return HTError_add(me->error_stack, severity, ignore, element,			   par, length, where);    }    return NO;}PUBLIC BOOL HTRequest_addSystemError (HTRequest * 	me,				      HTSeverity 	severity,				      int		errornumber,				      BOOL		ignore,				      char *		syscall){    if (me) {	if (!me->error_stack) me->error_stack = HTList_new();	return HTError_addSystem(me->error_stack, severity, errornumber,				 ignore, syscall);    }    return NO;}/***  Set max number of automatic reload. Default is HT_MAX_RELOADS*/PUBLIC BOOL HTRequest_setMaxRetry (int newmax){    if (newmax > 0) {	HTMaxRetry = newmax;	return YES;    }    return NO;}PUBLIC int HTRequest_maxRetry (void){    return HTMaxRetry;}PUBLIC int HTRequest_retrys (HTRequest * me){    return me ? me->retrys : 0;}PUBLIC BOOL HTRequest_addRetry (HTRequest * me){    return (me && me->retrys++);}PUBLIC int HTRequest_AAretrys (HTRequest * me){    return me ? me->AAretrys : 0;}PUBLIC BOOL HTRequest_addAARetry (HTRequest * me){    return (me && me->AAretrys++);}/***	Should we try again?**	--------------------**	Returns YES if we are to retry the load, NO otherwise. We check**	this so that we don't go into an infinte loop*/PUBLIC BOOL HTRequest_doRetry (HTRequest * me){    return (me && me->retrys < HTMaxRetry-1);}/***	Socket mode: preemptive or non-preemptive (blocking or non-blocking)*/PUBLIC void HTRequest_setPreemptive (HTRequest * me, BOOL mode){    if (me) me->preemptive = mode;}PUBLIC BOOL HTRequest_preemptive (HTRequest * me){    return me ? me->preemptive : NO;}/***	Should we use content negotiation?*/PUBLIC void HTRequest_setNegotiation (HTRequest * me, BOOL mode){    if (me) me->ContentNegotiation = mode;}PUBLIC BOOL HTRequest_negotiation (HTRequest * me){    return me ? me->ContentNegotiation : NO;}/***  Use preconditions when doing a PUT or a POST. These are the**  if-* header fields that can be used to avoid version conflicts**  etc.*/PUBLIC void HTRequest_setPreconditions (HTRequest * me, HTPreconditions mode){    if (me) me->preconditions = mode;}PUBLIC HTPreconditions HTRequest_preconditions (HTRequest * me){    return me ? me->preconditions : NO;}/***	Set General Headers*/PUBLIC void HTRequest_setGnHd (HTRequest * me, HTGnHd gnhd){    if (me) me->GenMask = gnhd;}PUBLIC void HTRequest_addGnHd (HTRequest * me, HTGnHd gnhd){    if (me) me->GenMask |= gnhd;}PUBLIC HTGnHd HTRequest_gnHd (HTRequest * me){    return me ? me->GenMask : 0;}/***	Set Request Headers*/PUBLIC void HTRequest_setRqHd (HTRequest * me, HTRqHd rqhd){    if (me) me->RequestMask = rqhd;}PUBLIC void HTRequest_addRqHd (HTRequest * me, HTRqHd rqhd){    if (me) me->RequestMask |= rqhd;}PUBLIC HTRqHd HTRequest_rqHd (HTRequest * me){    return me ? me->RequestMask : 0;}/***	Set Response Headers*/PUBLIC void HTRequest_setRsHd (HTRequest * me, HTRsHd rshd){    if (me) me->ResponseMask = rshd;}PUBLIC void HTRequest_addRsHd (HTRequest * me, HTRsHd rshd){    if (me) me->ResponseMask |= rshd;}PUBLIC HTRsHd HTRequest_rsHd (HTRequest * me){    return me ? me->ResponseMask : 0;}/***	Set Entity Headers (for the object)*/PUBLIC void HTRequest_setEnHd (HTRequest * me, HTEnHd enhd){    if (me) me->EntityMask = enhd;}PUBLIC void HTRequest_addEnHd (HTRequest * me, HTEnHd enhd){    if (me) me->EntityMask |= enhd;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品成人精品456| 久久综合久久综合久久综合| 成人丝袜视频网| 黄色日韩三级电影| 国产精品自拍网站| 国产成人福利片| 国产麻豆成人精品| 国产成a人亚洲| 99久久婷婷国产| 91色婷婷久久久久合中文| 色八戒一区二区三区| 色av综合在线| 日韩一区二区免费在线观看| 欧美成人精品3d动漫h| 欧美成va人片在线观看| 国产日韩欧美精品在线| 国产精品久久99| 亚洲精品中文字幕乱码三区 | 日韩精品久久久久久| 久久精品国产秦先生| 国产一区久久久| 成人高清免费观看| 欧美日韩视频第一区| 欧美tickle裸体挠脚心vk| 国产精品视频免费| 午夜在线电影亚洲一区| 国产精品夜夜嗨| 91福利区一区二区三区| 精品成人一区二区三区四区| 最新欧美精品一区二区三区| 日本成人在线网站| 不卡av免费在线观看| 9191成人精品久久| 中文字幕视频一区| 喷白浆一区二区| 91啪在线观看| 国产亚洲欧美日韩俺去了| 亚洲一区二区成人在线观看| 国模冰冰炮一区二区| 精品视频资源站| 国产精品午夜在线| 久久精品久久99精品久久| 成人黄色小视频在线观看| 911精品产国品一二三产区| 国产精品素人一区二区| 男人的天堂久久精品| 色爱区综合激月婷婷| 国产色综合久久| 日本午夜精品一区二区三区电影 | 成人欧美一区二区三区小说| 日本不卡123| 欧美在线影院一区二区| 国产精品免费久久| 国产精品资源在线观看| 91麻豆精品国产| 亚洲国产精品精华液网站| 国产99久久久国产精品潘金网站| 日韩一本二本av| 亚洲亚洲人成综合网络| 91国在线观看| 亚洲精品免费播放| 99久久伊人精品| 国产精品欧美一级免费| 国产在线乱码一区二区三区| 91精品国产一区二区| 日韩成人一区二区三区在线观看| 欧美日韩国产在线播放网站| 亚洲三级小视频| 99精品视频一区二区三区| 欧美国产日韩精品免费观看| 国产福利一区二区三区视频| 久久先锋影音av| 国产在线观看一区二区| 久久品道一品道久久精品| 精品一区二区影视| 日韩精品一区国产麻豆| 国产在线不卡一区| 中文字幕乱码一区二区免费| 成人午夜精品在线| 国产精品毛片久久久久久久| av亚洲精华国产精华精华| 1000精品久久久久久久久| 色欧美88888久久久久久影院| 亚洲人成电影网站色mp4| 色狠狠一区二区三区香蕉| 亚洲bdsm女犯bdsm网站| 欧美一级淫片007| 久久国产三级精品| 中文字幕第一区二区| 91在线国产福利| 天天av天天翘天天综合网色鬼国产| 91精品国产综合久久婷婷香蕉 | 欧美精品一区二区三区蜜桃| 国产91精品露脸国语对白| 亚洲精选一二三| 欧美一三区三区四区免费在线看| 精品一区在线看| 国产精品白丝在线| 欧美精品丝袜久久久中文字幕| 毛片基地黄久久久久久天堂| 国产欧美日韩视频一区二区| 欧美性猛交xxxx黑人交| 免费观看成人鲁鲁鲁鲁鲁视频| 欧美国产综合一区二区| 欧美羞羞免费网站| 国产专区综合网| 亚洲尤物在线视频观看| 欧美精品一区二| 欧美性猛交一区二区三区精品| 美女一区二区三区在线观看| 亚洲男女一区二区三区| 欧美一区二区在线视频| av在线免费不卡| 韩国精品一区二区| 亚洲一二三四区不卡| 久久精品在线观看| 欧美日韩一区不卡| 成人黄色大片在线观看| 免费欧美日韩国产三级电影| 中文字幕中文字幕在线一区| 日韩免费视频一区二区| 欧美做爰猛烈大尺度电影无法无天| 国内外成人在线| 天堂久久久久va久久久久| 国产精品人妖ts系列视频| 欧美成人女星排行榜| 欧美日韩午夜精品| 91网上在线视频| 成人午夜电影网站| 免费观看在线色综合| 亚洲成人在线观看视频| 亚洲男人的天堂一区二区| 中文字幕不卡一区| 26uuu精品一区二区三区四区在线| 欧美亚洲国产一区二区三区va| av电影天堂一区二区在线| 国产乱对白刺激视频不卡| 日本sm残虐另类| 亚洲第一久久影院| 亚洲午夜在线电影| 亚洲一区二区三区中文字幕在线| 中文字幕国产精品一区二区| 国产亚洲一本大道中文在线| 欧美变态tickle挠乳网站| 这里只有精品99re| 欧美美女一区二区在线观看| 在线看不卡av| 欧美影院精品一区| 欧美日韩亚洲不卡| 欧美喷潮久久久xxxxx| 欧美精品在线一区二区| 8x8x8国产精品| 欧美一区二区三区思思人| 日韩视频在线你懂得| 精品国产欧美一区二区| 精品国产三级电影在线观看| 精品福利在线导航| 欧美精品一区二区三区一线天视频| 日韩欧美中文字幕制服| 精品噜噜噜噜久久久久久久久试看 | 欧美精品乱码久久久久久按摩| 在线视频一区二区三| 欧美日韩一区二区三区四区五区| 欧美日韩一区二区三区不卡| 欧美高清性hdvideosex| 欧美一区二区三区在线| 久久伊99综合婷婷久久伊| 国产亚洲欧美日韩日本| 亚洲男人天堂av网| 日韩电影免费在线看| 国产一区二区精品在线观看| yourporn久久国产精品| 欧美性感一类影片在线播放| 4438x成人网最大色成网站| 精品美女一区二区| |精品福利一区二区三区| 天天色综合天天| 国产麻豆日韩欧美久久| 色屁屁一区二区| 欧美大片免费久久精品三p| 欧美国产欧美综合| 亚洲另类在线一区| 久久99蜜桃精品| 在线观看欧美黄色| 欧美va亚洲va| 一区二区三区国产豹纹内裤在线| 日本免费在线视频不卡一不卡二| 国产传媒久久文化传媒| 欧美区视频在线观看| 国产精品嫩草99a| 日韩av中文在线观看| 不卡区在线中文字幕| 欧美一区二区在线不卡| 国产精品毛片久久久久久久| 蜜臀av性久久久久蜜臀aⅴ| 97精品久久久久中文字幕| 91精品国产品国语在线不卡| 中文字幕日本不卡| 国产综合色精品一区二区三区| 在线观看不卡视频|