]> git.saurik.com Git - apt.git/blame - apt-pkg/srcrecords.cc
avoid depends on std::string implementation for pkgAcquire::Item::Mode
[apt.git] / apt-pkg / srcrecords.cc
CommitLineData
11e7af84
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
b3d44315 3// $Id: srcrecords.cc,v 1.7.2.2 2003/12/26 16:27:34 mdz Exp $
11e7af84
AL
4/* ######################################################################
5
6 Source Package Records - Allows access to source package records
7
8 Parses and allows access to the list of source records and searching by
9 source name on that list.
10
11 ##################################################################### */
12 /*}}}*/
13// Include Files /*{{{*/
ea542140
DK
14#include<config.h>
15
11e7af84 16#include <apt-pkg/srcrecords.h>
3a2b39ee 17#include <apt-pkg/debsrcrecords.h>
11e7af84 18#include <apt-pkg/error.h>
b2e465d6 19#include <apt-pkg/sourcelist.h>
472ff00e 20#include <apt-pkg/metaindex.h>
453b82a3
DK
21#include <apt-pkg/indexfile.h>
22#include <apt-pkg/macros.h>
23
24#include <string.h>
25#include <string>
26#include <vector>
ea542140
DK
27
28#include <apti18n.h>
11e7af84
AL
29 /*}}}*/
30
31// SrcRecords::pkgSrcRecords - Constructor /*{{{*/
32// ---------------------------------------------------------------------
33/* Open all the source index files */
dcaa1185 34pkgSrcRecords::pkgSrcRecords(pkgSourceList &List) : d(NULL), Files(0), Current(0)
11e7af84 35{
f7f0d6c7 36 for (pkgSourceList::const_iterator I = List.begin(); I != List.end(); ++I)
b2e465d6 37 {
73688d27
DK
38 std::vector<pkgIndexFile *> *Indexes = (*I)->GetIndexFiles();
39 for (std::vector<pkgIndexFile *>::const_iterator J = Indexes->begin();
f7f0d6c7 40 J != Indexes->end(); ++J)
b3d44315
MV
41 {
42 Parser* P = (*J)->CreateSrcParser();
43 if (_error->PendingError() == true)
44 return;
45 if (P != 0)
46 Files.push_back(P);
47 }
b2e465d6 48 }
b2e465d6 49
0e72dd52 50 // Doesn't work without any source index files
69c2ecbd 51 if (Files.empty() == true)
11e7af84 52 {
677cbcbc 53 _error->Error(_("You must put some 'source' URIs"
b2e465d6 54 " in your sources.list"));
11e7af84
AL
55 return;
56 }
57
11e7af84
AL
58 Restart();
59}
60 /*}}}*/
61// SrcRecords::~pkgSrcRecords - Destructor /*{{{*/
62// ---------------------------------------------------------------------
63/* */
64pkgSrcRecords::~pkgSrcRecords()
65{
11e7af84 66 // Blow away all the parser objects
73688d27 67 for(std::vector<Parser*>::iterator I = Files.begin(); I != Files.end(); ++I)
b3d44315 68 delete *I;
11e7af84
AL
69}
70 /*}}}*/
71// SrcRecords::Restart - Restart the search /*{{{*/
72// ---------------------------------------------------------------------
73/* Return all of the parsers to their starting position */
74bool pkgSrcRecords::Restart()
75{
b3d44315 76 Current = Files.begin();
73688d27 77 for (std::vector<Parser*>::iterator I = Files.begin();
f7f0d6c7 78 I != Files.end(); ++I)
6a9c9d63
DK
79 if ((*I)->Offset() != 0)
80 (*I)->Restart();
81
11e7af84
AL
82 return true;
83}
84 /*}}}*/
401e5db1 85// SrcRecords::Step - Step to the next Source Record /*{{{*/
46255701
MV
86// ---------------------------------------------------------------------
87/* Step to the next source package record */
401e5db1 88const pkgSrcRecords::Parser* pkgSrcRecords::Step()
46255701
MV
89{
90 if (Current == Files.end())
91 return 0;
92
93 // Step to the next record, possibly switching files
94 while ((*Current)->Step() == false)
95 {
96 if (_error->PendingError() == true)
97 return 0;
98 ++Current;
99 if (Current == Files.end())
100 return 0;
101 }
102
103 return *Current;
104}
105 /*}}}*/
11e7af84
AL
106// SrcRecords::Find - Find the first source package with the given name /*{{{*/
107// ---------------------------------------------------------------------
108/* This searches on both source package names and output binary names and
109 returns the first found. A 'cursor' like system is used to allow this
110 function to be called multiple times to get successive entries */
41c81fd8 111pkgSrcRecords::Parser *pkgSrcRecords::Find(const char *Package,bool const &SrcOnly)
11e7af84 112{
11e7af84
AL
113 while (true)
114 {
401e5db1 115 if(Step() == 0)
46255701
MV
116 return 0;
117
11e7af84
AL
118 // IO error somehow
119 if (_error->PendingError() == true)
120 return 0;
121
122 // Source name hit
123 if ((*Current)->Package() == Package)
124 return *Current;
125
126 if (SrcOnly == true)
127 continue;
128
129 // Check for a binary hit
130 const char **I = (*Current)->Binaries();
f7f0d6c7 131 for (; I != 0 && *I != 0; ++I)
11e7af84
AL
132 if (strcmp(Package,*I) == 0)
133 return *Current;
134 }
135}
136 /*}}}*/
b2e465d6
AL
137// Parser::BuildDepType - Convert a build dep to a string /*{{{*/
138// ---------------------------------------------------------------------
139/* */
41c81fd8 140const char *pkgSrcRecords::Parser::BuildDepType(unsigned char const &Type)
b2e465d6 141{
69c2ecbd
DK
142 const char *fields[] = {"Build-Depends",
143 "Build-Depends-Indep",
b2e465d6
AL
144 "Build-Conflicts",
145 "Build-Conflicts-Indep"};
69c2ecbd 146 if (unlikely(Type >= sizeof(fields)/sizeof(fields[0])))
b2e465d6 147 return "";
69c2ecbd 148 return fields[Type];
b2e465d6
AL
149}
150 /*}}}*/
3a2b39ee
DK
151bool pkgSrcRecords::Parser::Files2(std::vector<pkgSrcRecords::File2> &F2)/*{{{*/
152{
153 debSrcRecordParser * const deb = dynamic_cast<debSrcRecordParser*>(this);
154 if (deb != NULL)
155 return deb->Files2(F2);
b2e465d6 156
3a2b39ee
DK
157 std::vector<pkgSrcRecords::File> F;
158 if (Files(F) == false)
159 return false;
160 for (std::vector<pkgSrcRecords::File>::const_iterator f = F.begin(); f != F.end(); ++f)
161 {
162 pkgSrcRecords::File2 f2;
163#if __GNUC__ >= 4
164 #pragma GCC diagnostic push
165 #pragma GCC diagnostic ignored "-Wdeprecated-declarations"
166#endif
167 f2.MD5Hash = f->MD5Hash;
168 f2.Size = f->Size;
169 f2.Hashes.push_back(HashString("MD5Sum", f->MD5Hash));
170 f2.FileSize = f->Size;
171#if __GNUC__ >= 4
172 #pragma GCC diagnostic pop
173#endif
174 f2.Path = f->Path;
175 f2.Type = f->Type;
176 F2.push_back(f2);
177 }
178 return true;
179}
180 /*}}}*/