Fixed a bug with deep sub sections..
[ntk/apt.git] / apt-pkg / acquire.h
CommitLineData
0118833a
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
024d1123 3// $Id: acquire.h,v 1.21 1999/06/13 05:06:40 jgg Exp $
0118833a
AL
4/* ######################################################################
5
6 Acquire - File Acquiration
7
8 This module contians the Acquire system. It is responsible for bringing
9 files into the local pathname space. It deals with URIs for files and
10 URI handlers responsible for downloading or finding the URIs.
11
12 Each file to download is represented by an Acquire::Item class subclassed
13 into a specialization. The Item class can add itself to several URI
14 acquire queues each prioritized by the download scheduler. When the
15 system is run the proper URI handlers are spawned and the the acquire
16 queues are fed into the handlers by the schedular until the queues are
17 empty. This allows for an Item to be downloaded from an alternate source
18 if the first try turns out to fail. It also alows concurrent downloading
19 of multiple items from multiple sources as well as dynamic balancing
20 of load between the sources.
21
22 Schedualing of downloads is done on a first ask first get basis. This
23 preserves the order of the download as much as possible. And means the
24 fastest source will tend to process the largest number of files.
25
26 Internal methods and queues for performing gzip decompression,
27 md5sum hashing and file copying are provided to allow items to apply
28 a number of transformations to the data files they are working with.
29
30 ##################################################################### */
31 /*}}}*/
32#ifndef PKGLIB_ACQUIRE_H
33#define PKGLIB_ACQUIRE_H
34
35#include <vector>
36#include <string>
37
38#ifdef __GNUG__
39#pragma interface "apt-pkg/acquire.h"
40#endif
41
b98f2859 42#include <sys/time.h>
0a8a80e5
AL
43#include <unistd.h>
44
8267fe24 45class pkgAcquireStatus;
0118833a
AL
46class pkgAcquire
47{
48 public:
49
50 class Item;
51 class Queue;
52 class Worker;
53 struct MethodConfig;
8267fe24 54 struct ItemDesc;
0118833a 55 friend Item;
0a8a80e5 56 friend Queue;
0118833a
AL
57
58 protected:
59
0a8a80e5 60 // List of items to fetch
0118833a 61 vector<Item *> Items;
0a8a80e5
AL
62
63 // List of active queues and fetched method configuration parameters
0118833a 64 Queue *Queues;
0a8a80e5 65 Worker *Workers;
0118833a 66 MethodConfig *Configs;
8267fe24 67 pkgAcquireStatus *Log;
0a8a80e5 68 unsigned long ToFetch;
8267fe24 69
0a8a80e5
AL
70 // Configurable parameters for the schedular
71 enum {QueueHost,QueueAccess} QueueMode;
72 bool Debug;
8b89e57f 73 bool Running;
0118833a
AL
74
75 void Add(Item *Item);
76 void Remove(Item *Item);
0a8a80e5
AL
77 void Add(Worker *Work);
78 void Remove(Worker *Work);
79
8267fe24 80 void Enqueue(ItemDesc &Item);
0a8a80e5 81 void Dequeue(Item *Item);
e331f6ed 82 string QueueName(string URI,MethodConfig const *&Config);
0a8a80e5
AL
83
84 // FDSET managers for derived classes
85 void SetFds(int &Fd,fd_set *RSet,fd_set *WSet);
86 void RunFds(fd_set *RSet,fd_set *WSet);
93bf083d
AL
87
88 // A queue calls this when it dequeues an item
89 void Bump();
0118833a
AL
90
91 public:
3b5421b4 92
0a8a80e5 93 MethodConfig *GetConfig(string Access);
024d1123
AL
94
95 enum RunResult {Continue,Failed,Cancelled};
96
97 RunResult Run();
8267fe24
AL
98
99 // Simple iteration mechanism
100 inline Worker *WorkersBegin() {return Workers;};
101 Worker *WorkerStep(Worker *I);
102 inline Item **ItemsBegin() {return Items.begin();};
103 inline Item **ItemsEnd() {return Items.end();};
f7a08e33
AL
104
105 // Iterate over queued Item URIs
106 class UriIterator;
107 UriIterator UriBegin();
108 UriIterator UriEnd();
109
7a7fa5f0
AL
110 // Cleans out the download dir
111 bool Clean(string Dir);
a6568219
AL
112
113 // Returns the size of the total download set
114 unsigned long TotalNeeded();
115 unsigned long FetchNeeded();
6b1ff003 116 unsigned long PartialPresent();
0118833a 117
8267fe24 118 pkgAcquire(pkgAcquireStatus *Log = 0);
0118833a
AL
119 ~pkgAcquire();
120};
121
8267fe24
AL
122// Description of an Item+URI
123struct pkgAcquire::ItemDesc
124{
125 string URI;
126 string Description;
127 string ShortDesc;
128 Item *Owner;
129};
130
0118833a
AL
131// List of possible items queued for download.
132class pkgAcquire::Queue
133{
134 friend pkgAcquire;
f7a08e33 135 friend pkgAcquire::UriIterator;
0118833a
AL
136 Queue *Next;
137
138 protected:
3b5421b4 139
0a8a80e5 140 // Queued item
8267fe24 141 struct QItem : pkgAcquire::ItemDesc
0a8a80e5 142 {
8267fe24 143 QItem *Next;
c88edf1d 144 pkgAcquire::Worker *Worker;
8267fe24
AL
145
146 void operator =(pkgAcquire::ItemDesc const &I)
147 {
148 URI = I.URI;
149 Description = I.Description;
150 ShortDesc = I.ShortDesc;
151 Owner = I.Owner;
152 };
153 };
0a8a80e5
AL
154
155 // Name of the queue
156 string Name;
157
158 // Items queued into this queue
159 QItem *Items;
160 pkgAcquire::Worker *Workers;
161 pkgAcquire *Owner;
e7432370 162 signed long PipeDepth;
b185acc2 163 unsigned long MaxPipeDepth;
0118833a
AL
164
165 public:
0a8a80e5
AL
166
167 // Put an item into this queue
8267fe24 168 void Enqueue(ItemDesc &Item);
bfd22fc0 169 bool Dequeue(Item *Owner);
0a8a80e5 170
c88edf1d
AL
171 // Find a Queued item
172 QItem *FindItem(string URI,pkgAcquire::Worker *Owner);
8267fe24 173 bool ItemStart(QItem *Itm,unsigned long Size);
c88edf1d
AL
174 bool ItemDone(QItem *Itm);
175
0a8a80e5
AL
176 bool Startup();
177 bool Shutdown();
93bf083d 178 bool Cycle();
be4401bf 179 void Bump();
0a8a80e5
AL
180
181 Queue(string Name,pkgAcquire *Owner);
182 ~Queue();
0118833a
AL
183};
184
f7a08e33
AL
185class pkgAcquire::UriIterator
186{
187 pkgAcquire::Queue *CurQ;
188 pkgAcquire::Queue::QItem *CurItem;
189
190 public:
191
192 // Advance to the next item
193 inline void operator ++() {operator ++();};
194 void operator ++(int)
195 {
196 CurItem = CurItem->Next;
197 while (CurItem == 0 && CurQ != 0)
198 {
199 CurItem = CurQ->Items;
200 CurQ = CurQ->Next;
201 }
202 };
203
204 // Accessors
205 inline pkgAcquire::ItemDesc const *operator ->() const {return CurItem;};
206 inline bool operator !=(UriIterator const &rhs) const {return rhs.CurQ != CurQ || rhs.CurItem != CurItem;};
207 inline bool operator ==(UriIterator const &rhs) const {return rhs.CurQ == CurQ && rhs.CurItem == CurItem;};
208
209 UriIterator(pkgAcquire::Queue *Q) : CurQ(Q), CurItem(0)
210 {
211 while (CurItem == 0 && CurQ != 0)
212 {
213 CurItem = CurQ->Items;
214 CurQ = CurQ->Next;
215 }
216 }
217};
218
0118833a
AL
219// Configuration information from each method
220struct pkgAcquire::MethodConfig
221{
3b5421b4
AL
222 MethodConfig *Next;
223
0118833a
AL
224 string Access;
225
226 string Version;
227 bool SingleInstance;
0a8a80e5
AL
228 bool Pipeline;
229 bool SendConfig;
e331f6ed
AL
230 bool LocalOnly;
231
0118833a 232 MethodConfig();
0118833a
AL
233};
234
8267fe24
AL
235class pkgAcquireStatus
236{
b98f2859
AL
237 protected:
238
239 struct timeval Time;
240 struct timeval StartTime;
241 unsigned long LastBytes;
242 double CurrentCPS;
243 unsigned long CurrentBytes;
244 unsigned long TotalBytes;
245 unsigned long FetchedBytes;
246 unsigned long ElapsedTime;
d568ed2d
AL
247 unsigned long TotalItems;
248 unsigned long CurrentItems;
b98f2859 249
8267fe24
AL
250 public:
251
252 bool Update;
253
b98f2859
AL
254 // Called by items when they have finished a real download
255 virtual void Fetched(unsigned long Size,unsigned long ResumePoint);
256
542ec555
AL
257 // Called to change media
258 virtual bool MediaChange(string Media,string Drive) = 0;
259
8267fe24
AL
260 // Each of these is called by the workers when an event occures
261 virtual void IMSHit(pkgAcquire::ItemDesc &Itm) {};
262 virtual void Fetch(pkgAcquire::ItemDesc &Itm) {};
263 virtual void Done(pkgAcquire::ItemDesc &Itm) {};
542ec555 264 virtual void Fail(pkgAcquire::ItemDesc &Itm) {};
024d1123 265 virtual bool Pulse(pkgAcquire *Owner); // returns false on user cancel
b98f2859
AL
266 virtual void Start();
267 virtual void Stop();
a6568219 268
b98f2859 269 pkgAcquireStatus();
8267fe24
AL
270 virtual ~pkgAcquireStatus() {};
271};
272
0118833a 273#endif