]> git.saurik.com Git - apt.git/blob - apt-pkg/indexfile.h
Refactor InternalReadLine to not unroll Size == 0 case
[apt.git] / apt-pkg / indexfile.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description /*{{{*/
3 /* ######################################################################
4
5 Index File - Abstraction for an index of archive/source file.
6
7 There are 4 primary sorts of index files, all represented by this
8 class:
9
10 Binary index files
11 Binary translation files
12 Binary index files describing the local system
13 Source index files
14
15 They are all bundled together here, and the interfaces for
16 sources.list, acquire, cache gen and record parsing all use this class
17 to access the underlying representation.
18
19 ##################################################################### */
20 /*}}}*/
21 #ifndef PKGLIB_INDEXFILE_H
22 #define PKGLIB_INDEXFILE_H
23
24 #include <apt-pkg/srcrecords.h>
25 #include <apt-pkg/pkgrecords.h>
26 #include <apt-pkg/pkgcache.h>
27 #include <apt-pkg/cacheiterators.h>
28 #include <apt-pkg/macros.h>
29
30 #include <map>
31 #include <string>
32
33 #ifndef APT_8_CLEANER_HEADERS
34 using std::string;
35 #endif
36 #ifndef APT_10_CLEANER_HEADERS
37 class pkgAcquire;
38 #endif
39
40 class pkgCacheGenerator;
41 class pkgCacheListParser;
42 class OpProgress;
43
44 class IndexTarget /*{{{*/
45 /** \brief Information about an index file. */
46 {
47 public:
48 /** \brief A URI from which the index file can be downloaded. */
49 std::string URI;
50
51 /** \brief A description of the index file. */
52 std::string Description;
53
54 /** \brief A shorter description of the index file. */
55 std::string ShortDesc;
56
57 /** \brief The key by which this index file should be
58 looked up within the meta index file. */
59 std::string MetaKey;
60
61 /** \brief Is it okay if the file isn't found in the meta index */
62 bool IsOptional;
63
64 /** \brief If the file is downloaded compressed, do not unpack it */
65 bool KeepCompressed;
66
67 /** \brief options with which this target was created
68 Prefer the usage of #Option if at all possible.
69 Beware: Not all of these options are intended for public use */
70 std::map<std::string, std::string> Options;
71
72 IndexTarget(std::string const &MetaKey, std::string const &ShortDesc,
73 std::string const &LongDesc, std::string const &URI, bool const IsOptional,
74 bool const KeepCompressed, std::map<std::string, std::string> const &Options);
75
76 enum OptionKeys {
77 SITE,
78 RELEASE,
79 COMPONENT,
80 LANGUAGE,
81 ARCHITECTURE,
82 BASE_URI,
83 REPO_URI,
84 CREATED_BY,
85 TARGET_OF,
86 FILENAME,
87 EXISTING_FILENAME,
88 PDIFFS,
89 COMPRESSIONTYPES,
90 DEFAULTENABLED,
91 SOURCESENTRY,
92 BY_HASH,
93 };
94 std::string Option(OptionKeys const Key) const;
95 bool OptionBool(OptionKeys const Key) const;
96 std::string Format(std::string format) const;
97 };
98 /*}}}*/
99
100 class pkgIndexFile
101 {
102 void * const d;
103 protected:
104 bool Trusted;
105
106 public:
107
108 class Type
109 {
110 public:
111
112 // Global list of Items supported
113 static Type **GlobalList;
114 static unsigned long GlobalListLen;
115 static Type *GetType(const char * const Type) APT_PURE;
116
117 const char *Label;
118
119 virtual pkgRecords::Parser *CreatePkgParser(pkgCache::PkgFileIterator const &/*File*/) const {return 0;};
120 virtual pkgSrcRecords::Parser *CreateSrcPkgParser(std::string const &/*File*/) const {return 0;};
121 Type();
122 virtual ~Type() {};
123 };
124
125 virtual const Type *GetType() const = 0;
126
127 // Return descriptive strings of various sorts
128 virtual std::string ArchiveInfo(pkgCache::VerIterator const &Ver) const;
129 virtual std::string SourceInfo(pkgSrcRecords::Parser const &Record,
130 pkgSrcRecords::File const &File) const;
131 virtual std::string Describe(bool const Short = false) const = 0;
132
133 // Interface for acquire
134 virtual std::string ArchiveURI(std::string const &/*File*/) const {return std::string();};
135
136 // Interface for the record parsers
137 virtual pkgSrcRecords::Parser *CreateSrcParser() const {return 0;};
138
139 // Interface for the Cache Generator
140 virtual bool Exists() const = 0;
141 virtual bool HasPackages() const = 0;
142 virtual unsigned long Size() const = 0;
143 virtual bool Merge(pkgCacheGenerator &/*Gen*/, OpProgress* const /*Prog*/) { return true; };
144 virtual pkgCache::PkgFileIterator FindInCache(pkgCache &Cache) const;
145
146 APT_DEPRECATED_MSG("These methods make no sense anymore with multi-language support") static bool TranslationsAvailable();
147 /* No intern need for this method anymore as the check for correctness
148 is already done in getLanguages(). Note also that this check is
149 rather bad (doesn't take three character like ast into account).*/
150 APT_DEPRECATED_MSG("These methods make no sense anymore with multi-language support") static bool CheckLanguageCode(const char * const Lang);
151 /* As we have now possibly more than one LanguageCode this method is
152 superseeded by a) private classmembers or b) getLanguages() */
153 APT_DEPRECATED_MSG("These methods make no sense anymore with multi-language support") static std::string LanguageCode();
154
155 bool IsTrusted() const { return Trusted; };
156
157 explicit pkgIndexFile(bool const Trusted);
158 virtual ~pkgIndexFile();
159 };
160
161 class pkgDebianIndexFile : public pkgIndexFile
162 {
163 protected:
164 virtual std::string IndexFileName() const = 0;
165 virtual std::string GetComponent() const = 0;
166 virtual std::string GetArchitecture() const = 0;
167 virtual std::string GetProgressDescription() const = 0;
168 virtual uint8_t GetIndexFlags() const = 0;
169 virtual bool OpenListFile(FileFd &Pkg, std::string const &FileName) = 0;
170 APT_HIDDEN virtual pkgCacheListParser * CreateListParser(FileFd &Pkg);
171
172 public:
173 virtual bool Merge(pkgCacheGenerator &Gen, OpProgress* const Prog) APT_OVERRIDE;
174 virtual pkgCache::PkgFileIterator FindInCache(pkgCache &Cache) const APT_OVERRIDE;
175
176 explicit pkgDebianIndexFile(bool const Trusted);
177 virtual ~pkgDebianIndexFile();
178 };
179
180 class pkgDebianIndexTargetFile : public pkgDebianIndexFile
181 {
182 void * const d;
183 protected:
184 IndexTarget const Target;
185
186 virtual std::string IndexFileName() const APT_OVERRIDE;
187 virtual std::string GetComponent() const APT_OVERRIDE;
188 virtual std::string GetArchitecture() const APT_OVERRIDE;
189 virtual std::string GetProgressDescription() const APT_OVERRIDE;
190 virtual bool OpenListFile(FileFd &Pkg, std::string const &FileName) APT_OVERRIDE;
191
192 public:
193 virtual std::string ArchiveURI(std::string const &File) const APT_OVERRIDE;
194 virtual std::string Describe(bool const Short = false) const APT_OVERRIDE;
195 virtual bool Exists() const APT_OVERRIDE;
196 virtual unsigned long Size() const APT_OVERRIDE;
197
198 pkgDebianIndexTargetFile(IndexTarget const &Target, bool const Trusted);
199 virtual ~pkgDebianIndexTargetFile();
200 };
201
202 class pkgDebianIndexRealFile : public pkgDebianIndexFile
203 {
204 void * const d;
205 protected:
206 std::string File;
207
208 virtual std::string IndexFileName() const APT_OVERRIDE;
209 virtual std::string GetProgressDescription() const APT_OVERRIDE;
210 virtual bool OpenListFile(FileFd &Pkg, std::string const &FileName) APT_OVERRIDE;
211 public:
212 virtual std::string Describe(bool const /*Short*/ = false) const APT_OVERRIDE;
213 virtual bool Exists() const APT_OVERRIDE;
214 virtual unsigned long Size() const APT_OVERRIDE;
215 virtual std::string ArchiveURI(std::string const &/*File*/) const APT_OVERRIDE;
216
217 pkgDebianIndexRealFile(std::string const &File, bool const Trusted);
218 virtual ~pkgDebianIndexRealFile();
219 };
220
221 #endif