* code cleanups (thanks matt!), moved UsePackage before the description list build...
[ntk/apt.git] / apt-pkg / deb / debmetaindex.cc
CommitLineData
7db98ffc
MZ
1// ijones, walters
2
3#ifdef __GNUG__
4#pragma implementation "apt-pkg/debmetaindex.h"
5#endif
6
7#include <apt-pkg/debmetaindex.h>
8#include <apt-pkg/debindexfile.h>
9#include <apt-pkg/strutl.h>
10#include <apt-pkg/acquire-item.h>
11#include <apt-pkg/configuration.h>
12#include <apt-pkg/error.h>
13
14using namespace std;
15
16string debReleaseIndex::Info(const char *Type, const string Section) const
17{
18 string Info = ::URI::SiteOnly(URI) + ' ';
19 if (Dist[Dist.size() - 1] == '/')
20 {
21 if (Dist != "/")
22 Info += Dist;
23 }
24 else
25 Info += Dist + '/' + Section;
26 Info += " ";
27 Info += Type;
28 return Info;
29}
30
31string debReleaseIndex::MetaIndexInfo(const char *Type) const
32{
33 string Info = ::URI::SiteOnly(URI) + ' ';
34 if (Dist[Dist.size() - 1] == '/')
35 {
36 if (Dist != "/")
37 Info += Dist;
38 }
39 else
40 Info += Dist;
41 Info += " ";
42 Info += Type;
43 return Info;
44}
45
46string debReleaseIndex::MetaIndexFile(const char *Type) const
47{
48 return _config->FindDir("Dir::State::lists") +
49 URItoFileName(MetaIndexURI(Type));
50}
51
52string debReleaseIndex::MetaIndexURI(const char *Type) const
53{
54 string Res;
55
56 if (Dist == "/")
57 Res = URI;
58 else if (Dist[Dist.size()-1] == '/')
59 Res = URI + Dist;
60 else
61 Res = URI + "dists/" + Dist + "/";
62
63 Res += Type;
64 return Res;
65}
66
67string debReleaseIndex::IndexURISuffix(const char *Type, const string Section) const
68{
69 string Res ="";
70 if (Dist[Dist.size() - 1] != '/')
71 Res += Section + "/binary-" + _config->Find("APT::Architecture") + '/';
72 return Res + Type;
73}
74
75
76string debReleaseIndex::IndexURI(const char *Type, const string Section) const
77{
78 if (Dist[Dist.size() - 1] == '/')
79 {
80 string Res;
81 if (Dist != "/")
82 Res = URI + Dist;
83 else
84 Res = URI;
85 return Res + Type;
86 }
87 else
88 return URI + "dists/" + Dist + '/' + IndexURISuffix(Type, Section);
89 }
90
91string debReleaseIndex::SourceIndexURISuffix(const char *Type, const string Section) const
92{
93 string Res ="";
94 if (Dist[Dist.size() - 1] != '/')
95 Res += Section + "/source/";
96 return Res + Type;
97}
98
99string debReleaseIndex::SourceIndexURI(const char *Type, const string Section) const
100{
101 string Res;
102 if (Dist[Dist.size() - 1] == '/')
103 {
104 if (Dist != "/")
105 Res = URI + Dist;
106 else
107 Res = URI;
108 return Res + Type;
109 }
110 else
111 return URI + "dists/" + Dist + "/" + SourceIndexURISuffix(Type, Section);
112}
113
114debReleaseIndex::debReleaseIndex(string URI,string Dist)
115{
116 this->URI = URI;
117 this->Dist = Dist;
118 this->Indexes = NULL;
119 this->Type = "deb";
120}
121
122vector <struct IndexTarget *>* debReleaseIndex::ComputeIndexTargets() const
123{
124 vector <struct IndexTarget *>* IndexTargets = new vector <IndexTarget *>;
125 for (vector <const debSectionEntry *>::const_iterator I = SectionEntries.begin();
126 I != SectionEntries.end();
127 I++)
128 {
129 IndexTarget * Target = new IndexTarget();
130 Target->ShortDesc = (*I)->IsSrc ? "Sources" : "Packages";
131 Target->MetaKey
132 = (*I)->IsSrc ? SourceIndexURISuffix(Target->ShortDesc.c_str(), (*I)->Section)
133 : IndexURISuffix(Target->ShortDesc.c_str(), (*I)->Section);
134 Target->URI
135 = (*I)->IsSrc ? SourceIndexURI(Target->ShortDesc.c_str(), (*I)->Section)
136 : IndexURI(Target->ShortDesc.c_str(), (*I)->Section);
137
138 Target->Description = Info (Target->ShortDesc.c_str(), (*I)->Section);
139 IndexTargets->push_back (Target);
140 }
141 return IndexTargets;
142}
143 /*}}}*/
144bool debReleaseIndex::GetIndexes(pkgAcquire *Owner, bool GetAll) const
145{
146 // special case for --print-uris
147 if (GetAll) {
148 vector <struct IndexTarget *> *targets = ComputeIndexTargets();
149 for (vector <struct IndexTarget*>::const_iterator Target = targets->begin(); Target != targets->end(); Target++) {
150 new pkgAcqIndex(Owner, (*Target)->URI, (*Target)->Description,
151 (*Target)->ShortDesc, "");
152 }
153 }
154 new pkgAcqMetaSig(Owner, MetaIndexURI("Release.gpg"),
155 MetaIndexInfo("Release.gpg"), "Release.gpg",
156 MetaIndexURI("Release"), MetaIndexInfo("Release"), "Release",
157 ComputeIndexTargets(),
158 new indexRecords (Dist));
159
97234432
MV
160 // Queue the translations
161 for (vector<const debSectionEntry *>::const_iterator I = SectionEntries.begin();
162 I != SectionEntries.end(); I++) {
163
164 debTranslationsIndex i = debTranslationsIndex(URI,Dist,(*I)->Section);
165 i.GetIndexes(Owner);
166 }
167
7db98ffc
MZ
168 return true;
169}
170
171bool debReleaseIndex::IsTrusted() const
172{
173 string VerifiedSigFile = _config->FindDir("Dir::State::lists") +
174 URItoFileName(MetaIndexURI("Release")) + ".gpg";
175
176 if (FileExists(VerifiedSigFile))
177 return true;
178 return false;
179}
180
181vector <pkgIndexFile *> *debReleaseIndex::GetIndexFiles()
182{
183 if (Indexes != NULL)
184 return Indexes;
185
186 Indexes = new vector <pkgIndexFile*>;
187 for (vector<const debSectionEntry *>::const_iterator I = SectionEntries.begin();
a7a5b0d9 188 I != SectionEntries.end(); I++) {
7db98ffc
MZ
189 if ((*I)->IsSrc)
190 Indexes->push_back(new debSourcesIndex (URI, Dist, (*I)->Section, IsTrusted()));
191 else
770c32ec 192 {
7db98ffc 193 Indexes->push_back(new debPackagesIndex (URI, Dist, (*I)->Section, IsTrusted()));
770c32ec
MV
194 Indexes->push_back(new debTranslationsIndex(URI, Dist, (*I)->Section));
195 }
a7a5b0d9
OS
196 }
197
7db98ffc
MZ
198 return Indexes;
199}
200
201void debReleaseIndex::PushSectionEntry(const debSectionEntry *Entry)
202{
203 SectionEntries.push_back(Entry);
204}
205
206debReleaseIndex::debSectionEntry::debSectionEntry (string Section, bool IsSrc): Section(Section)
207{
208 this->IsSrc = IsSrc;
209}
210
211class debSLTypeDebian : public pkgSourceList::Type
212{
213 protected:
214
215 bool CreateItemInternal(vector<metaIndex *> &List,string URI,
216 string Dist,string Section,
217 bool IsSrc) const
218 {
219 for (vector<metaIndex *>::const_iterator I = List.begin();
220 I != List.end(); I++)
221 {
222 // This check insures that there will be only one Release file
223 // queued for all the Packages files and Sources files it
224 // corresponds to.
225 if ((*I)->GetType() == "deb")
226 {
227 debReleaseIndex *Deb = (debReleaseIndex *) (*I);
228 // This check insures that there will be only one Release file
229 // queued for all the Packages files and Sources files it
230 // corresponds to.
231 if (Deb->GetURI() == URI && Deb->GetDist() == Dist)
232 {
233 Deb->PushSectionEntry(new debReleaseIndex::debSectionEntry(Section, IsSrc));
234 return true;
235 }
236 }
237 }
238 // No currently created Release file indexes this entry, so we create a new one.
239 // XXX determine whether this release is trusted or not
240 debReleaseIndex *Deb = new debReleaseIndex(URI,Dist);
241 Deb->PushSectionEntry (new debReleaseIndex::debSectionEntry(Section, IsSrc));
242 List.push_back(Deb);
243 return true;
244 }
245};
246
247class debSLTypeDeb : public debSLTypeDebian
248{
249 public:
250
251 bool CreateItem(vector<metaIndex *> &List,string URI,
252 string Dist,string Section) const
253 {
254 return CreateItemInternal(List, URI, Dist, Section, false);
255 }
256
257 debSLTypeDeb()
258 {
259 Name = "deb";
260 Label = "Standard Debian binary tree";
261 }
262};
263
264class debSLTypeDebSrc : public debSLTypeDebian
265{
266 public:
267
268 bool CreateItem(vector<metaIndex *> &List,string URI,
269 string Dist,string Section) const
270 {
271 return CreateItemInternal(List, URI, Dist, Section, true);
272 }
273
274 debSLTypeDebSrc()
275 {
276 Name = "deb-src";
277 Label = "Standard Debian source tree";
278 }
279};
280
281debSLTypeDeb _apt_DebType;
282debSLTypeDebSrc _apt_DebSrcType;