File: history.h

package info (click to toggle)
apt 3.1.13
  • links: PTS, VCS
  • area: main
  • in suites: forky
  • size: 22,764 kB
  • sloc: cpp: 71,085; sh: 31,750; xml: 5,553; perl: 217; python: 197; ansic: 191; makefile: 41
file content (119 lines) | stat: -rw-r--r-- 2,660 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// -*- mode: cpp; mode: fold -*-
// Description								/*{{{*/
/* ######################################################################

   History - Parse history logs to structured data.

   ##################################################################### */
/*}}}*/
#ifndef APTPKG_HISTORY_H
#define APTPKG_HISTORY_H

#include <apt-pkg/fileutl.h>
#include <apt-pkg/macros.h>
#include <apt-pkg/tagfile.h>

#include <map>
#include <string>
#include <vector>

namespace APT::History
{

/**
 * @enum class Kind
 * @brief Represents the possible actions of APT transactions in history.
 */
enum class Kind
{
   Install,
   Reinstall,
   Upgrade,
   Downgrade,
   InstallEnd = Downgrade,
   Remove,
   Purge,
};

/**
 * Get the string parsing specific string representation 
 * of a @ref Kind.
 *
 * @param kind An action kind.
 * @return A string representation.
 *
 * @note This string representation is not localized.
 */
std::string KindToString(const Kind &kind);

/**
 * @struct Change
 * @brief Represents a package change.
 */
struct Change
{
   Kind kind;
   std::string package;
   std::string currentVersion;
   std::string candidateVersion;
   bool automatic = false; ///< If the change was automatically performed.

   private:
   void *d; // pointer for future extension;
};

static inline bool IsRemoval(const Kind &kind) { return kind > Kind::InstallEnd; }

/**
 * @struct Entry
 * @brief Represents an entry in the APT history log.
 */
struct Entry
{
   // Strings instead of string_view to avoid reference errors
   std::string startDate;  
   std::string endDate;
   std::string cmdLine;
   std::string comment;
   std::string error;
   std::string requestingUser;
   std::map<Kind, std::vector<Change>> changeMap;

   private:
   void *d;
};

// History is defined as the collection of entries in the history log(s).
typedef std::vector<Entry> HistoryBuffer;

/**
 * Parse a tag section as history log entry.
 *
 * @param section A tag section.
 * @return A history log entry.
 */
APT_PUBLIC Entry ParseSection(const pkgTagSection &section);

/**
 * Parse a file descriptor to a history buffer.
 *
 * @param fd A file descriptor.
 * @param buf A history buffer.
 * @return true if successful, false otherwise.
 *
 * @note Caller is responsible for closing the file descriptor.
 */
APT_PUBLIC bool ParseFile(FileFd &fd, HistoryBuffer &buf);

// ParseLogDir - Parse the apt history log directory to the buffer.
/**
 * Parse the APT history log directory to a buffer.
 *
 * @param buf A history buffer.
 * @return true if successful, false otherwise.
 */
APT_PUBLIC bool ParseLogDir(HistoryBuffer &buf);

} // namespace APT::History

#endif