]> git.saurik.com Git - apt.git/blobdiff - apt-pkg/srcrecords.h
rework dpkg-wrapping in test framework
[apt.git] / apt-pkg / srcrecords.h
index ed69d0d72d470cfa9dfe18406c394c432c1b6bf3..de2b6ff648987038ed175d0e75a90bc66e5a00e3 100644 (file)
@@ -13,6 +13,8 @@
 #ifndef PKGLIB_SRCRECORDS_H
 #define PKGLIB_SRCRECORDS_H
 
 #ifndef PKGLIB_SRCRECORDS_H
 #define PKGLIB_SRCRECORDS_H
 
+#include <apt-pkg/macros.h>
+#include <apt-pkg/hashes.h>
 
 #include <string>
 #include <vector>
 
 #include <string>
 #include <vector>
@@ -28,15 +30,18 @@ class pkgSrcRecords
 {
    public:
 
 {
    public:
 
+APT_IGNORE_DEPRECATED_PUSH
    // Describes a single file
    struct File
    {
    // Describes a single file
    struct File
    {
-      std::string MD5Hash;
-      unsigned long Size;
       std::string Path;
       std::string Type;
       std::string Path;
       std::string Type;
+      unsigned long long Size;
+      HashStringList Hashes;
+      APT_DEPRECATED std::string MD5Hash;
    };
    };
-   
+APT_IGNORE_DEPRECATED_POP
+
    // Abstract parser for each source record
    class Parser
    {
    // Abstract parser for each source record
    class Parser
    {
@@ -73,7 +78,7 @@ class pkgSrcRecords
 
       //FIXME: Add a parameter to specify which architecture to use for [wildcard] matching
       virtual bool BuildDepends(std::vector<BuildDepRec> &BuildDeps, bool const &ArchOnly, bool const &StripMultiArch = true) = 0;
 
       //FIXME: Add a parameter to specify which architecture to use for [wildcard] matching
       virtual bool BuildDepends(std::vector<BuildDepRec> &BuildDeps, bool const &ArchOnly, bool const &StripMultiArch = true) = 0;
-      static const char *BuildDepType(unsigned char const &Type);
+      static const char *BuildDepType(unsigned char const &Type) APT_PURE;
 
       virtual bool Files(std::vector<pkgSrcRecords::File> &F) = 0;
       
 
       virtual bool Files(std::vector<pkgSrcRecords::File> &F) = 0;
       
@@ -94,8 +99,13 @@ class pkgSrcRecords
    // Reset the search
    bool Restart();
 
    // Reset the search
    bool Restart();
 
-   // Locate a package by name
-   Parser *Find(const char *Package,bool const &SrcOnly = false);
+   // Step to the next SourcePackage and return pointer to the 
+   // next SourceRecord. The pointer is owned by libapt.
+   const Parser* Step();
+
+   // Locate a package by name and return pointer to the Parser.
+   // The pointer is owned by libapt.
+   Parser* Find(const char *Package,bool const &SrcOnly = false);
    
    pkgSrcRecords(pkgSourceList &List);
    virtual ~pkgSrcRecords();
    
    pkgSrcRecords(pkgSourceList &List);
    virtual ~pkgSrcRecords();