- backport forgotten Valid-Until patch from the obsolete experimental
[ntk/apt.git] / apt-pkg / deb / dpkgpm.h
CommitLineData
03e39e59
AL
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
233b185f 3// $Id: dpkgpm.h,v 1.8 2001/05/07 05:05:13 jgg Exp $
03e39e59
AL
4/* ######################################################################
5
6 DPKG Package Manager - Provide an interface to dpkg
7
8 ##################################################################### */
9 /*}}}*/
03e39e59
AL
10#ifndef PKGLIB_DPKGPM_H
11#define PKGLIB_DPKGPM_H
12
03e39e59
AL
13#include <apt-pkg/packagemanager.h>
14#include <vector>
09fa2df2 15#include <map>
b2e465d6 16#include <stdio.h>
03e39e59 17
233b185f 18using std::vector;
09fa2df2
MV
19using std::map;
20
233b185f 21
03e39e59
AL
22class pkgDPkgPM : public pkgPackageManager
23{
6191b008 24 private:
6191b008 25
9983591d
OS
26 bool stdin_is_dev_null;
27
09fa2df2
MV
28 // the buffer we use for the dpkg status-fd reading
29 char dpkgbuf[1024];
30 int dpkgbuf_pos;
1ba38171 31 FILE *term_out;
9169c871
MV
32 FILE *history_out;
33 string dpkg_error;
34
eb6f9bac
DK
35 /** \brief record the disappear action and handle accordingly
36
37 dpkg let packages disappear then they have no files any longer and
38 nothing depends on them. We need to collect this as dpkg as well as
39 APT doesn't know beforehand that the package will disappear, so the
40 only possible option is to tell the user afterwards about it.
41 To enhance the experience we also try to forward the auto-install
42 flag so the disappear-causer(s) are not autoremoved next time -
43 for the transfer to happen the disappeared version needs to depend
44 on the package the flag should be forwarded to and this package
45 needs to declare a Replaces on the disappeared package.
46 \param pkgname Name of the package that disappeared
47 */
48 void handleDisappearAction(string const &pkgname);
49
ff56e980
MV
50 protected:
51
09fa2df2 52 // progress reporting
2a7e07c7
MV
53 struct DpkgState
54 {
55 const char *state; // the dpkg state (e.g. "unpack")
56 const char *str; // the human readable translation of the state
57 };
09fa2df2
MV
58
59 // the dpkg states that the pkg will run through, the string is
60 // the package, the vector contains the dpkg states that the package
61 // will go through
62 map<string,vector<struct DpkgState> > PackageOps;
63 // the dpkg states that are already done; the string is the package
64 // the int is the state that is already done (e.g. a package that is
65 // going to be install is already in state "half-installed")
4b7c5a3f 66 map<string,unsigned int> PackageOpsDone;
09fa2df2 67 // progress reporting
4b7c5a3f
MV
68 unsigned int PackagesDone;
69 unsigned int PackagesTotal;
09fa2df2 70
03e39e59
AL
71 struct Item
72 {
5e312de7 73 enum Ops {Install, Configure, Remove, Purge, ConfigurePending, TriggersPending} Op;
03e39e59
AL
74 string File;
75 PkgIterator Pkg;
b2e465d6 76 Item(Ops Op,PkgIterator Pkg,string File = "") : Op(Op),
03e39e59
AL
77 File(File), Pkg(Pkg) {};
78 Item() {};
79
80 };
81 vector<Item> List;
6dd55be7
AL
82
83 // Helpers
db0c350f 84 bool RunScriptsWithPkgs(const char *Cnf);
b2e465d6 85 bool SendV2Pkgs(FILE *F);
6cb1060b 86 void WriteHistoryTag(string const &tag, string value);
afb1e2e3 87
2e1715ea
MV
88 // dpkg log
89 bool OpenLog();
90 bool CloseLog();
91
ceabc520
MV
92 // input processing
93 void DoStdin(int master);
1ba38171 94 void DoTerminalPty(int master);
09fa2df2
MV
95 void DoDpkgStatusFd(int statusfd, int OutStatusFd);
96 void ProcessDpkgStatusLine(int OutStatusFd, char *line);
6191b008 97
03e39e59
AL
98 // The Actuall installation implementation
99 virtual bool Install(PkgIterator Pkg,string File);
100 virtual bool Configure(PkgIterator Pkg);
fc4b5c9f 101 virtual bool Remove(PkgIterator Pkg,bool Purge = false);
2a7e07c7 102 virtual bool Go(int StatusFd=-1);
281daf46 103 virtual void Reset();
03e39e59
AL
104
105 public:
106
b2e465d6 107 pkgDPkgPM(pkgDepCache *Cache);
03e39e59
AL
108 virtual ~pkgDPkgPM();
109};
110
111#endif