]> git.saurik.com Git - apt.git/blob - apt-pkg/srcrecords.h
support comments in debian/control parsing
[apt.git] / apt-pkg / srcrecords.h
1 // -*- mode: cpp; mode: fold -*-
2 // Description /*{{{*/
3 /* ######################################################################
4
5 Source Package Records - Allows access to source package records
6
7 Parses and allows access to the list of source records and searching by
8 source name on that list.
9
10 ##################################################################### */
11 /*}}}*/
12 #ifndef PKGLIB_SRCRECORDS_H
13 #define PKGLIB_SRCRECORDS_H
14
15 #include <apt-pkg/macros.h>
16 #include <apt-pkg/hashes.h>
17
18 #include <string>
19 #include <vector>
20
21 #ifndef APT_8_CLEANER_HEADERS
22 using std::string;
23 using std::vector;
24 #endif
25
26 class pkgSourceList;
27 class pkgIndexFile;
28 class pkgSrcRecords
29 {
30 public:
31
32 APT_IGNORE_DEPRECATED_PUSH
33 // Describes a single file
34 struct File
35 {
36 APT_DEPRECATED_MSG("Use Hashes member instead of hardcoded hash algorithm") std::string MD5Hash;
37 APT_DEPRECATED_MSG("Use FileSize member instead") unsigned long Size;
38 std::string Path;
39 std::string Type;
40 };
41 struct File2 : public File
42 {
43 unsigned long long FileSize;
44 HashStringList Hashes;
45 };
46 APT_IGNORE_DEPRECATED_POP
47
48 // Abstract parser for each source record
49 class Parser
50 {
51 void * const d;
52 protected:
53
54 const pkgIndexFile *iIndex;
55
56 public:
57
58 enum BuildDep {BuildDepend=0x0,BuildDependIndep=0x1,
59 BuildConflict=0x2,BuildConflictIndep=0x3};
60
61 struct BuildDepRec
62 {
63 std::string Package;
64 std::string Version;
65 unsigned int Op;
66 unsigned char Type;
67 };
68
69 inline const pkgIndexFile &Index() const {return *iIndex;};
70
71 virtual bool Restart() = 0;
72 virtual bool Step() = 0;
73 virtual bool Jump(unsigned long const &Off) = 0;
74 virtual unsigned long Offset() = 0;
75 virtual std::string AsStr() = 0;
76
77 virtual std::string Package() const = 0;
78 virtual std::string Version() const = 0;
79 virtual std::string Maintainer() const = 0;
80 virtual std::string Section() const = 0;
81 virtual const char **Binaries() = 0; // Ownership does not transfer
82
83 //FIXME: Add a parameter to specify which architecture to use for [wildcard] matching
84 virtual bool BuildDepends(std::vector<BuildDepRec> &BuildDeps, bool const &ArchOnly, bool const &StripMultiArch = true) = 0;
85 static const char *BuildDepType(unsigned char const &Type) APT_PURE;
86
87 virtual bool Files(std::vector<pkgSrcRecords::File> &F) = 0;
88 bool Files2(std::vector<pkgSrcRecords::File2> &F);
89
90 explicit Parser(const pkgIndexFile *Index);
91 virtual ~Parser();
92 };
93
94 private:
95 /** \brief dpointer placeholder (for later in case we need it) */
96 void * const d;
97
98 // The list of files and the current parser pointer
99 std::vector<Parser*> Files;
100 std::vector<Parser *>::iterator Current;
101
102 public:
103
104 // Reset the search
105 bool Restart();
106
107 // Step to the next SourcePackage and return pointer to the
108 // next SourceRecord. The pointer is owned by libapt.
109 const Parser* Step();
110
111 // Locate a package by name and return pointer to the Parser.
112 // The pointer is owned by libapt.
113 Parser* Find(const char *Package,bool const &SrcOnly = false);
114
115 explicit pkgSrcRecords(pkgSourceList &List);
116 virtual ~pkgSrcRecords();
117 };
118
119 #endif