]> git.saurik.com Git - apt.git/blob - apt-pkg/indexrecords.h
explicit overload methods instead of adding parameters
[apt.git] / apt-pkg / indexrecords.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description /*{{{*/
3 // $Id: indexrecords.h,v 1.1.2.1 2003/12/24 23:09:17 mdz Exp $
4 /*}}}*/
5 #ifndef PKGLIB_INDEXRECORDS_H
6 #define PKGLIB_INDEXRECORDS_H
7
8 #include <apt-pkg/hashes.h>
9
10 #include <map>
11 #include <vector>
12 #include <ctime>
13 #include <string>
14
15 #ifndef APT_8_CLEANER_HEADERS
16 #include <apt-pkg/fileutl.h>
17 #endif
18 #ifndef APT_10_CLEANER_HEADERS
19 #include <apt-pkg/pkgcache.h>
20 #endif
21
22 class indexRecords
23 {
24 APT_HIDDEN bool parseSumData(const char *&Start, const char *End, std::string &Name,
25 std::string &Hash, unsigned long long &Size);
26 public:
27 struct checkSum;
28 std::string ErrorText;
29
30 private:
31 enum APT_HIDDEN { ALWAYS_TRUSTED, NEVER_TRUSTED, CHECK_TRUST } Trusted;
32 // dpointer (for later)
33 void * d;
34
35 protected:
36 std::string Dist;
37 std::string Suite;
38 std::string ExpectedDist;
39 time_t ValidUntil;
40 bool SupportsAcquireByHash;
41
42 std::map<std::string,checkSum *> Entries;
43
44 public:
45 #if APT_PKG_ABI >= 413
46 indexRecords(const std::string &ExpectedDist = "");
47 #else
48 indexRecords();
49 indexRecords(const std::string ExpectedDist);
50 #endif
51
52 // Lookup function
53 virtual checkSum *Lookup(const std::string MetaKey);
54 /** \brief tests if a checksum for this file is available */
55 bool Exists(std::string const &MetaKey) const;
56 std::vector<std::string> MetaKeys();
57
58 virtual bool Load(std::string Filename);
59 virtual bool CheckDist(const std::string MaybeDist) const;
60
61 std::string GetDist() const;
62 std::string GetSuite() const;
63 bool GetSupportsAcquireByHash() const;
64 time_t GetValidUntil() const;
65 std::string GetExpectedDist() const;
66
67 /** \brief check if source is marked as always trusted */
68 bool IsAlwaysTrusted() const;
69 /** \brief check if source is marked as never trusted */
70 bool IsNeverTrusted() const;
71
72 /** \brief sets an explicit trust value
73 *
74 * \b true means that the source should always be considered trusted,
75 * while \b false marks a source as always untrusted, even if we have
76 * a valid signature and everything.
77 */
78 void SetTrusted(bool const Trusted);
79
80 virtual ~indexRecords();
81 };
82
83 APT_IGNORE_DEPRECATED_PUSH
84 struct indexRecords::checkSum
85 {
86 std::string MetaKeyFilename;
87 HashStringList Hashes;
88 unsigned long long Size;
89
90 APT_DEPRECATED HashString Hash;
91 };
92 APT_IGNORE_DEPRECATED_POP
93
94 #endif