]> git.saurik.com Git - apt.git/blame - apt-pkg/acquire-item.h
s/make/$(MAKE)/
[apt.git] / apt-pkg / acquire-item.h
CommitLineData
0118833a
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
c5ccf175 3// $Id: acquire-item.h,v 1.24 2000/01/27 04:15:09 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();};
c5ccf175
AL
74 pkgAcquire *GetOwner() {return Owner;};
75
0118833a
AL
76 Item(pkgAcquire *Owner);
77 virtual ~Item();
78};
79
80// Item class for index files
81class pkgAcqIndex : public pkgAcquire::Item
82{
83 protected:
84
85 const pkgSourceList::Item *Location;
8b89e57f 86 bool Decompression;
bfd22fc0 87 bool Erase;
8267fe24 88 pkgAcquire::ItemDesc Desc;
0118833a
AL
89
90 public:
91
17caf1b1 92 // Specialized action members
459681d3
AL
93 virtual void Done(string Message,unsigned long Size,string Md5Hash,
94 pkgAcquire::MethodConfig *Cnf);
0a8a80e5 95 virtual string Custom600Headers();
36375005 96 virtual string DescURI() {return Location->PackagesURI();};
0118833a
AL
97
98 pkgAcqIndex(pkgAcquire *Owner,const pkgSourceList::Item *Location);
99};
100
101// Item class for index files
102class pkgAcqIndexRel : public pkgAcquire::Item
103{
104 protected:
105
106 const pkgSourceList::Item *Location;
8267fe24 107 pkgAcquire::ItemDesc Desc;
0118833a
AL
108
109 public:
110
17caf1b1 111 // Specialized action members
681d76d0 112 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
113 virtual void Done(string Message,unsigned long Size,string Md5Hash,
114 pkgAcquire::MethodConfig *Cnf);
0a8a80e5 115 virtual string Custom600Headers();
36375005 116 virtual string DescURI() {return Location->ReleaseURI();};
0a8a80e5 117
0118833a
AL
118 pkgAcqIndexRel(pkgAcquire *Owner,const pkgSourceList::Item *Location);
119};
120
03e39e59
AL
121// Item class for archive files
122class pkgAcqArchive : public pkgAcquire::Item
123{
124 protected:
125
17caf1b1 126 // State information for the retry mechanism
03e39e59
AL
127 pkgCache::VerIterator Version;
128 pkgAcquire::ItemDesc Desc;
129 pkgSourceList *Sources;
130 pkgRecords *Recs;
131 string MD5;
30e1eab5 132 string &StoreFilename;
b185acc2 133 pkgCache::VerFileIterator Vf;
7d8afa39 134 unsigned int Retries;
17caf1b1
AL
135
136 // Queue the next available file for download.
b185acc2 137 bool QueueNext();
03e39e59
AL
138
139 public:
140
17caf1b1 141 // Specialized action members
7d8afa39 142 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
143 virtual void Done(string Message,unsigned long Size,string Md5Hash,
144 pkgAcquire::MethodConfig *Cnf);
17caf1b1 145 virtual string MD5Sum() {return MD5;};
36375005 146 virtual string DescURI() {return Desc.URI;};
ab559b35 147 virtual void Finished();
03e39e59
AL
148
149 pkgAcqArchive(pkgAcquire *Owner,pkgSourceList *Sources,
30e1eab5
AL
150 pkgRecords *Recs,pkgCache::VerIterator const &Version,
151 string &StoreFilename);
03e39e59
AL
152};
153
36375005
AL
154// Fetch a generic file to the current directory
155class pkgAcqFile : public pkgAcquire::Item
156{
157 pkgAcquire::ItemDesc Desc;
b3c39978 158 string Md5Hash;
08cfc005 159 unsigned int Retries;
36375005
AL
160
161 public:
162
163 // Specialized action members
08cfc005 164 virtual void Failed(string Message,pkgAcquire::MethodConfig *Cnf);
459681d3
AL
165 virtual void Done(string Message,unsigned long Size,string Md5Hash,
166 pkgAcquire::MethodConfig *Cnf);
b3c39978 167 virtual string MD5Sum() {return Md5Hash;};
36375005
AL
168 virtual string DescURI() {return Desc.URI;};
169
170 pkgAcqFile(pkgAcquire *Owner,string URI,string MD5,unsigned long Size,
171 string Desc,string ShortDesc);
172};
173
0118833a 174#endif