save and restore selection states before/after calling dpkg
[apt.git] / apt-pkg / pkgrecords.h
CommitLineData
f55ece0e
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
a7c835af 3// $Id: pkgrecords.h,v 1.6 2001/03/13 06:51:46 jgg Exp $
f55ece0e
AL
4/* ######################################################################
5
6 Package Records - Allows access to complete package description records
7 directly from the file.
8
9 The package record system abstracts the actual parsing of the
10 package files. This is different than the generators parser in that
11 it is used to access information not generate information. No
12 information touched by the generator should be parable from here as
13 it can always be retreived directly from the cache.
14
15 ##################################################################### */
16 /*}}}*/
f55ece0e
AL
17#ifndef PKGLIB_PKGRECORDS_H
18#define PKGLIB_PKGRECORDS_H
19
f55ece0e 20#include <apt-pkg/pkgcache.h>
b3501edb
DK
21#include <apt-pkg/hashes.h>
22#include <apt-pkg/macros.h>
453b82a3
DK
23
24#include <string>
30257943 25#include <vector>
f55ece0e 26
92fcbfc1 27class pkgRecords /*{{{*/
f55ece0e
AL
28{
29 public:
30 class Parser;
31
32 private:
be9b62f7 33 /** \brief dpointer placeholder (for later in case we need it) */
6c55f07a 34 void * const d;
f55ece0e
AL
35
36 pkgCache &Cache;
30257943
MV
37 std::vector<Parser *>Files;
38
be9b62f7 39 public:
f55ece0e 40 // Lookup function
03e39e59 41 Parser &Lookup(pkgCache::VerFileIterator const &Ver);
a52f938b 42 Parser &Lookup(pkgCache::DescFileIterator const &Desc);
03e39e59 43
f55ece0e 44 // Construct destruct
e8afd168 45 explicit pkgRecords(pkgCache &Cache);
c8a4ce6c 46 virtual ~pkgRecords();
f55ece0e 47};
92fcbfc1
DK
48 /*}}}*/
49class pkgRecords::Parser /*{{{*/
f55ece0e 50{
7e798dd7 51 protected:
f55ece0e 52
03e39e59 53 virtual bool Jump(pkgCache::VerFileIterator const &Ver) = 0;
a52f938b 54 virtual bool Jump(pkgCache::DescFileIterator const &Desc) = 0;
f55ece0e 55
7e798dd7 56 public:
b2e465d6 57 friend class pkgRecords;
7e798dd7
AL
58
59 // These refer to the archive file for the Version
8f3ba4e8 60 virtual std::string FileName() {return std::string();};
8f3ba4e8
DK
61 virtual std::string SourcePkg() {return std::string();};
62 virtual std::string SourceVer() {return std::string();};
b2e465d6 63
b3501edb
DK
64 /** return all known hashes in this record.
65 *
66 * For authentication proposes packages come with hashsums which
67 * this method is supposed to parse and return so that clients can
68 * choose the hash to be used.
69 */
70 virtual HashStringList Hashes() const { return HashStringList(); };
5dd00edb
DK
71 APT_DEPRECATED_MSG("Use .Hashes instead of a hardcoded hash algorithm") std::string MD5Hash() const { return GetHashFromHashes("MD5Sum"); };
72 APT_DEPRECATED_MSG("Use .Hashes instead of a hardcoded hash algorithm") std::string SHA1Hash() const { return GetHashFromHashes("SHA1"); };
73 APT_DEPRECATED_MSG("Use .Hashes instead of a hardcoded hash algorithm") std::string SHA256Hash() const { return GetHashFromHashes("SHA256"); };
74 APT_DEPRECATED_MSG("Use .Hashes instead of a hardcoded hash algorithm") std::string SHA512Hash() const { return GetHashFromHashes("SHA512"); };
b3501edb 75
7e798dd7 76 // These are some general stats about the package
8f3ba4e8 77 virtual std::string Maintainer() {return std::string();};
ffe3c68e
DK
78 /** return short description in language from record.
79 *
80 * @see #LongDesc
81 */
82 virtual std::string ShortDesc(std::string const &/*lang*/) {return std::string();};
83 /** return long description in language from record.
84 *
85 * If \b lang is empty the "best" available language will be
86 * returned as determined by the APT::Languages configuration.
87 * If a (requested) language can't be found in this record an empty
88 * string will be returned.
89 */
90 virtual std::string LongDesc(std::string const &/*lang*/) {return std::string();};
91 std::string ShortDesc() {return ShortDesc("");};
92 std::string LongDesc() {return LongDesc("");};
93
8f3ba4e8
DK
94 virtual std::string Name() {return std::string();};
95 virtual std::string Homepage() {return std::string();}
75bda619
MV
96
97 // An arbitrary custom field
65512241 98 virtual std::string RecordField(const char * /*fieldName*/) { return std::string();};
75bda619 99
b2e465d6
AL
100 // The record in binary form
101 virtual void GetRec(const char *&Start,const char *&Stop) {Start = Stop = 0;};
c8a4ce6c
DK
102
103 Parser();
104 virtual ~Parser();
b3501edb
DK
105
106 private:
6c55f07a 107 void * const d;
b3501edb
DK
108 APT_HIDDEN std::string GetHashFromHashes(char const * const type) const
109 {
110 HashStringList const hashes = Hashes();
111 HashString const * const hs = hashes.find(type);
112 return hs != NULL ? hs->HashValue() : "";
113 };
f55ece0e 114};
92fcbfc1 115 /*}}}*/
f55ece0e 116#endif