X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/85f72a56931e4e9994aa811a77c9d2fec973e30d..c040d0b5e811399359c62fde1d5916b240053bda:/methods/http.h diff --git a/methods/http.h b/methods/http.h index 700587048..dec5cd80f 100644 --- a/methods/http.h +++ b/methods/http.h @@ -1,8 +1,9 @@ // -*- mode: cpp; mode: fold -*- -// Description /*{{{*/// $Id: http.h,v 1.6 1998/12/10 05:39:56 jgg Exp $ +// Description /*{{{*/// $Id: http.h,v 1.12 2002/04/18 05:09:38 jgg Exp $ +// $Id: http.h,v 1.12 2002/04/18 05:09:38 jgg Exp $ /* ###################################################################### - HTTP Aquire Method - This is the HTTP aquire method for APT. + HTTP Acquire Method - This is the HTTP aquire method for APT. ##################################################################### */ /*}}}*/ @@ -12,6 +13,11 @@ #define MAXLEN 360 + + +using std::cout; +using std::endl; + class HttpMethod; class CircleBuf @@ -25,6 +31,11 @@ class CircleBuf unsigned long MaxGet; struct timeval Start; + static unsigned long BwReadLimit; + static unsigned long BwTickReadData; + static struct timeval BwReadTick; + static const unsigned int BW_HZ; + unsigned long LeftRead() { unsigned long Sz = Size - (InP - OutP); @@ -45,7 +56,7 @@ class CircleBuf public: - MD5Summation *MD5; + Hashes *Hash; // Read data in bool Read(int Fd); @@ -69,7 +80,7 @@ class CircleBuf void Stats(); CircleBuf(unsigned long Size); - ~CircleBuf() {delete [] Buf;}; + ~CircleBuf() {delete [] Buf; delete Hash;}; }; struct ServerState @@ -87,6 +98,10 @@ struct ServerState bool HaveContent; enum {Chunked,Stream,Closes} Encoding; enum {Header, Data} State; + bool Persistent; + + // This is a Persistent attribute of the server itself. + bool Pipeline; HttpMethod *Owner; @@ -99,7 +114,8 @@ struct ServerState bool HeaderLine(string Line); bool Comp(URI Other) {return Other.Host == ServerName.Host && Other.Port == ServerName.Port;}; void Reset() {Major = 0; Minor = 0; Result = 0; Size = 0; StartPos = 0; - Encoding = Closes; time(&Date); ServerFd = -1;}; + Encoding = Closes; time(&Date); ServerFd = -1; + Pipeline = true;}; int RunHeaders(); bool RunData(); @@ -118,7 +134,6 @@ class HttpMethod : public pkgAcqMethod bool ServerDie(ServerState *Srv); int DealWithHeaders(FetchResult &Res,ServerState *Srv); - virtual bool Fetch(FetchItem *); virtual bool Configuration(string Message); // In the event of a fatal signal this file will be closed and timestamped. @@ -126,9 +141,12 @@ class HttpMethod : public pkgAcqMethod static int FailFd; static time_t FailTime; static void SigTerm(int); + + protected: + virtual bool Fetch(FetchItem *); public: - friend ServerState; + friend class ServerState; FileFd *File; ServerState *Server; @@ -142,6 +160,4 @@ class HttpMethod : public pkgAcqMethod }; }; -URI Proxy; - #endif