1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
|
// -*- mode: cpp; mode: fold -*-
// Description /*{{{*/
// $Id: indexrecords.cc,v 1.1.2.4 2003/12/30 02:11:43 mdz Exp $
/*}}}*/
// Include Files /*{{{*/
#include <apt-pkg/indexrecords.h>
#include <apt-pkg/tagfile.h>
#include <apt-pkg/error.h>
#include <apt-pkg/strutl.h>
#include <apti18n.h>
#include <sys/stat.h>
string indexRecords::GetDist() const
{
return this->Dist;
}
bool indexRecords::CheckDist(const string MaybeDist) const
{
return (this->Dist == MaybeDist
|| this->Suite == MaybeDist);
}
string indexRecords::GetExpectedDist() const
{
return this->ExpectedDist;
}
const indexRecords::checkSum *indexRecords::Lookup(const string MetaKey)
{
return Entries[MetaKey];
}
bool indexRecords::Load(const string Filename)
{
FileFd Fd(Filename, FileFd::ReadOnly);
pkgTagFile TagFile(&Fd, Fd.Size() + 256); // XXX
if (_error->PendingError() == true)
{
ErrorText = _(("Unable to parse Release file " + Filename).c_str());
return false;
}
pkgTagSection Section;
if (TagFile.Step(Section) == false)
{
ErrorText = _(("No sections in Release file " + Filename).c_str());
return false;
}
const char *Start, *End;
Section.Get (Start, End, 0);
Suite = Section.FindS("Suite");
Dist = Section.FindS("Codename");
// if (Dist.empty())
// {
// ErrorText = _(("No Codename entry in Release file " + Filename).c_str());
// return false;
// }
if (!Section.Find("MD5Sum", Start, End))
{
ErrorText = _(("No MD5Sum entry in Release file " + Filename).c_str());
return false;
}
string Name;
string MD5Hash;
size_t Size;
while (Start < End)
{
if (!parseSumData(Start, End, Name, MD5Hash, Size))
return false;
indexRecords::checkSum *Sum = new indexRecords::checkSum;
Sum->MetaKeyFilename = Name;
Sum->MD5Hash = MD5Hash;
Sum->Size = Size;
Entries[Name] = Sum;
}
string Strdate = Section.FindS("Date"); // FIXME: verify this somehow?
return true;
}
vector<string> indexRecords::MetaKeys()
{
std::vector<std::string> keys;
std::map<string,checkSum *>::iterator I = Entries.begin();
while(I != Entries.end()) {
keys.push_back((*I).first);
++I;
}
return keys;
}
bool indexRecords::parseSumData(const char *&Start, const char *End,
string &Name, string &Hash, size_t &Size)
{
Name = "";
Hash = "";
Size = 0;
/* Skip over the first blank */
while ((*Start == '\t' || *Start == ' ' || *Start == '\n')
&& Start < End)
Start++;
if (Start >= End)
return false;
/* Move EntryEnd to the end of the first entry (the hash) */
const char *EntryEnd = Start;
while ((*EntryEnd != '\t' && *EntryEnd != ' ')
&& EntryEnd < End)
EntryEnd++;
if (EntryEnd == End)
return false;
Hash.append(Start, EntryEnd-Start);
/* Skip over intermediate blanks */
Start = EntryEnd;
while (*Start == '\t' || *Start == ' ')
Start++;
if (Start >= End)
return false;
EntryEnd = Start;
/* Find the end of the second entry (the size) */
while ((*EntryEnd != '\t' && *EntryEnd != ' ' )
&& EntryEnd < End)
EntryEnd++;
if (EntryEnd == End)
return false;
Size = strtol (Start, NULL, 10);
/* Skip over intermediate blanks */
Start = EntryEnd;
while (*Start == '\t' || *Start == ' ')
Start++;
if (Start >= End)
return false;
EntryEnd = Start;
/* Find the end of the third entry (the filename) */
while ((*EntryEnd != '\t' && *EntryEnd != ' ' && *EntryEnd != '\n')
&& EntryEnd < End)
EntryEnd++;
Name.append(Start, EntryEnd-Start);
Start = EntryEnd; //prepare for the next round
return true;
}
indexRecords::indexRecords()
{
}
indexRecords::indexRecords(const string ExpectedDist) :
ExpectedDist(ExpectedDist)
{
}
|