]> git.saurik.com Git - apt.git/blame - apt-pkg/acquire-item.h
Allowed getting the owner
[apt.git] / apt-pkg / acquire-item.h
CommitLineData
0118833a
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
459681d3 3// $Id: acquire-item.h,v 1.23 2000/01/17 07:11:49 jgg Exp $
0118833a
AL
4/* ######################################################################
5
6 Acquire Item - Item to acquire
7
8 When an item is instantiated it will add it self to the local list in
9 the Owner Acquire class. Derived classes will then call QueueURI to
17caf1b1 10 register all the URI's they wish to fetch at the initial moment.
0118833a
AL
11
12 Two item classes are provided to provide functionality for downloading
13 of Index files and downloading of Packages.
14
b185acc2 15 A Archive class is provided for downloading .deb files. It does Md5
17caf1b1 16 checking and source location as well as a retry algorithm.
b185acc2 17
0118833a
AL
18 ##################################################################### */
19 /*}}}*/
20#ifndef PKGLIB_ACQUIRE_ITEM_H
21#define PKGLIB_ACQUIRE_ITEM_H
22
23#include <apt-pkg/acquire.h>
24#include <apt-pkg/sourcelist.h>
03e39e59 25#include <apt-pkg/pkgrecords.h>
0118833a
AL
26
27#ifdef __GNUG__
28#pragma interface "apt-pkg/acquire-item.h"
29#endif
30
31// Item to acquire
32class pkgAcquire::Item
33{
34 protected:
35
17caf1b1 36 // Some private helper methods for registering URIs
0118833a 37 pkgAcquire *Owner;
8267fe24
AL
38 inline void QueueURI(ItemDesc &Item)
39 {Owner->Enqueue(Item);};
681d76d0 40 inline void Dequeue() {Owner->Dequeue(this);};
0118833a 41
17caf1b1 42 // Safe rename function with timestamp preservation
8b89e57f
AL
43 void Rename(string From,string To);
44
0118833a
AL
45 public:
46
c88edf1d
AL
47 // State of the item
48 enum {StatIdle, StatFetching, StatDone, StatError} Status;
49 string ErrorText;
8267fe24 50 unsigned long FileSize;
6b1ff003 51 unsigned long PartialSize;
b98f2859
AL
52 char *Mode;
53 unsigned long ID;
8267fe24 54 bool Complete;
a6568219 55 bool Local;
30e1eab5 56
0a8a80e5 57 // Number of queues we are inserted into
0118833a 58 unsigned int QueueCounter;
0118833a 59
0a8a80e5
AL
60 // File to write the fetch into
61 string DestFile;
7d8afa39 62
17caf1b1 63 // Action members invoked by the worker
7d8afa39 64 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
65 virtual void Done(string Message,unsigned long Size,string Md5Hash,
66 pkgAcquire::MethodConfig *Cnf);
8267fe24 67 virtual void Start(string Message,unsigned long Size);
17caf1b1 68 virtual string Custom600Headers() {return string();};
36375005 69 virtual string DescURI() = 0;
ab559b35 70 virtual void Finished() {};
17caf1b1
AL
71
72 // Inquire functions
f7a08e33 73 virtual string MD5Sum() {return string();};
17caf1b1 74
0118833a
AL
75 Item(pkgAcquire *Owner);
76 virtual ~Item();
77};
78
79// Item class for index files
80class pkgAcqIndex : public pkgAcquire::Item
81{
82 protected:
83
84 const pkgSourceList::Item *Location;
8b89e57f 85 bool Decompression;
bfd22fc0 86 bool Erase;
8267fe24 87 pkgAcquire::ItemDesc Desc;
0118833a
AL
88
89 public:
90
17caf1b1 91 // Specialized action members
459681d3
AL
92 virtual void Done(string Message,unsigned long Size,string Md5Hash,
93 pkgAcquire::MethodConfig *Cnf);
0a8a80e5 94 virtual string Custom600Headers();
36375005 95 virtual string DescURI() {return Location->PackagesURI();};
0118833a
AL
96
97 pkgAcqIndex(pkgAcquire *Owner,const pkgSourceList::Item *Location);
98};
99
100// Item class for index files
101class pkgAcqIndexRel : public pkgAcquire::Item
102{
103 protected:
104
105 const pkgSourceList::Item *Location;
8267fe24 106 pkgAcquire::ItemDesc Desc;
0118833a
AL
107
108 public:
109
17caf1b1 110 // Specialized action members
681d76d0 111 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
112 virtual void Done(string Message,unsigned long Size,string Md5Hash,
113 pkgAcquire::MethodConfig *Cnf);
0a8a80e5 114 virtual string Custom600Headers();
36375005 115 virtual string DescURI() {return Location->ReleaseURI();};
0a8a80e5 116
0118833a
AL
117 pkgAcqIndexRel(pkgAcquire *Owner,const pkgSourceList::Item *Location);
118};
119
03e39e59
AL
120// Item class for archive files
121class pkgAcqArchive : public pkgAcquire::Item
122{
123 protected:
124
17caf1b1 125 // State information for the retry mechanism
03e39e59
AL
126 pkgCache::VerIterator Version;
127 pkgAcquire::ItemDesc Desc;
128 pkgSourceList *Sources;
129 pkgRecords *Recs;
130 string MD5;
30e1eab5 131 string &StoreFilename;
b185acc2 132 pkgCache::VerFileIterator Vf;
7d8afa39 133 unsigned int Retries;
17caf1b1
AL
134
135 // Queue the next available file for download.
b185acc2 136 bool QueueNext();
03e39e59
AL
137
138 public:
139
17caf1b1 140 // Specialized action members
7d8afa39 141 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
142 virtual void Done(string Message,unsigned long Size,string Md5Hash,
143 pkgAcquire::MethodConfig *Cnf);
17caf1b1 144 virtual string MD5Sum() {return MD5;};
36375005 145 virtual string DescURI() {return Desc.URI;};
ab559b35 146 virtual void Finished();
03e39e59
AL
147
148 pkgAcqArchive(pkgAcquire *Owner,pkgSourceList *Sources,
30e1eab5
AL
149 pkgRecords *Recs,pkgCache::VerIterator const &Version,
150 string &StoreFilename);
03e39e59
AL
151};
152
36375005
AL
153// Fetch a generic file to the current directory
154class pkgAcqFile : public pkgAcquire::Item
155{
156 pkgAcquire::ItemDesc Desc;
b3c39978 157 string Md5Hash;
08cfc005 158 unsigned int Retries;
36375005
AL
159
160 public:
161
162 // Specialized action members
08cfc005 163 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
164 virtual void Done(string Message,unsigned long Size,string Md5Hash,
165 pkgAcquire::MethodConfig *Cnf);
b3c39978 166 virtual string MD5Sum() {return Md5Hash;};
36375005
AL
167 virtual string DescURI() {return Desc.URI;};
168
169 pkgAcqFile(pkgAcquire *Owner,string URI,string MD5,unsigned long Size,
170 string Desc,string ShortDesc);
171};
172
0118833a 173#endif