]> git.saurik.com Git - apt.git/blame_incremental - apt-pkg/packagemanager.h
releasing package apt version 1.0.9.7
[apt.git] / apt-pkg / packagemanager.h
... / ...
CommitLineData
1// -*- mode: cpp; mode: fold -*-
2// Description /*{{{*/
3// $Id: packagemanager.h,v 1.14 2001/05/07 04:24:08 jgg Exp $
4/* ######################################################################
5
6 Package Manager - Abstacts the package manager
7
8 Three steps are
9 - Aquiration of archives (stores the list of final file names)
10 - Sorting of operations
11 - Invokation of package manager
12
13 This is the final stage when the package cache entities get converted
14 into file names and the state stored in a DepCache is transformed
15 into a series of operations.
16
17 In the final scheme of things this may serve as a director class to
18 access the actual install methods based on the file type being
19 installed.
20
21 ##################################################################### */
22 /*}}}*/
23#ifndef PKGLIB_PACKAGEMANAGER_H
24#define PKGLIB_PACKAGEMANAGER_H
25
26#include <apt-pkg/pkgcache.h>
27#include <apt-pkg/init.h>
28#include <apt-pkg/macros.h>
29
30#include <string>
31#include <set>
32
33#ifndef APT_10_CLEANER_HEADERS
34#include <apt-pkg/install-progress.h>
35#include <iostream>
36#endif
37#ifndef APT_8_CLEANER_HEADERS
38#include <apt-pkg/depcache.h>
39using std::string;
40#endif
41
42class pkgAcquire;
43class pkgDepCache;
44class pkgSourceList;
45class pkgOrderList;
46class pkgRecords;
47
48
49class pkgPackageManager : protected pkgCache::Namespace
50{
51 public:
52
53 enum OrderResult {Completed,Failed,Incomplete};
54 static bool SigINTStop;
55
56 protected:
57 std::string *FileNames;
58 pkgDepCache &Cache;
59 pkgOrderList *List;
60 bool Debug;
61 bool NoImmConfigure;
62 bool ImmConfigureAll;
63
64 /** \brief saves packages dpkg let disappear
65
66 This way APT can retreat from trying to configure these
67 packages later on and a frontend can choose to display a
68 notice to inform the user about these disappears.
69 */
70 std::set<std::string> disappearedPkgs;
71
72 void ImmediateAdd(PkgIterator P, bool UseInstallVer, unsigned const int &Depth = 0);
73 virtual OrderResult OrderInstall();
74 bool CheckRConflicts(PkgIterator Pkg,DepIterator Dep,const char *Ver);
75 bool CreateOrderList();
76
77 // Analysis helpers
78 bool DepAlwaysTrue(DepIterator D) APT_PURE;
79
80 // Install helpers
81 bool ConfigureAll();
82 bool SmartConfigure(PkgIterator Pkg, int const Depth) APT_MUSTCHECK;
83 //FIXME: merge on abi break
84 bool SmartUnPack(PkgIterator Pkg) APT_MUSTCHECK;
85 bool SmartUnPack(PkgIterator Pkg, bool const Immediate, int const Depth) APT_MUSTCHECK;
86 bool SmartRemove(PkgIterator Pkg) APT_MUSTCHECK;
87 bool EarlyRemove(PkgIterator Pkg, DepIterator const * const Dep) APT_MUSTCHECK;
88 APT_DEPRECATED bool EarlyRemove(PkgIterator Pkg) APT_MUSTCHECK;
89
90 // The Actual installation implementation
91 virtual bool Install(PkgIterator /*Pkg*/,std::string /*File*/) {return false;};
92 virtual bool Configure(PkgIterator /*Pkg*/) {return false;};
93 virtual bool Remove(PkgIterator /*Pkg*/,bool /*Purge*/=false) {return false;};
94#if (APT_PKG_MAJOR >= 4 && APT_PKG_MINOR >= 13)
95 virtual bool Go(APT::Progress::PackageManager * /*progress*/) {return true;};
96#else
97 virtual bool Go(int /*statusFd*/=-1) {return true;};
98#endif
99
100 virtual void Reset() {};
101
102 // the result of the operation
103 OrderResult Res;
104
105 public:
106
107 // Main action members
108 bool GetArchives(pkgAcquire *Owner,pkgSourceList *Sources,
109 pkgRecords *Recs);
110
111 // Do the installation
112#if (APT_PKG_MAJOR >= 4 && APT_PKG_MINOR >= 13)
113 OrderResult DoInstall(APT::Progress::PackageManager *progress);
114 // compat
115 APT_DEPRECATED OrderResult DoInstall(int statusFd=-1);
116#else
117 OrderResult DoInstall(int statusFd=-1);
118#endif
119
120 // stuff that needs to be done before the fork() of a library that
121 // uses apt
122 OrderResult DoInstallPreFork() {
123 Res = OrderInstall();
124 return Res;
125 };
126#if (APT_PKG_MAJOR >= 4 && APT_PKG_MINOR >= 13)
127 // stuff that needs to be done after the fork
128 OrderResult DoInstallPostFork(APT::Progress::PackageManager *progress);
129 // compat
130 APT_DEPRECATED OrderResult DoInstallPostFork(int statusFd=-1);
131#else
132 OrderResult DoInstallPostFork(int statusFd=-1);
133#endif
134
135 // ?
136 bool FixMissing();
137
138 /** \brief returns all packages dpkg let disappear */
139 inline std::set<std::string> GetDisappearedPackages() { return disappearedPkgs; };
140
141 pkgPackageManager(pkgDepCache *Cache);
142 virtual ~pkgPackageManager();
143
144 private:
145 enum APT_HIDDEN SmartAction { UNPACK_IMMEDIATE, UNPACK, CONFIGURE };
146 APT_HIDDEN bool NonLoopingSmart(SmartAction const action, pkgCache::PkgIterator &Pkg,
147 pkgCache::PkgIterator DepPkg, int const Depth, bool const PkgLoop,
148 bool * const Bad, bool * const Changed) APT_MUSTCHECK;
149};
150
151#endif