do not pollute namespace in the headers with using (Closes: #500198)
[ntk/apt.git] / apt-pkg / packagemanager.h
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
27 #include <string>
28 #include <iostream>
29 #include <apt-pkg/pkgcache.h>
30 #include <apt-pkg/depcache.h>
31 #include <set>
32
33 class pkgAcquire;
34 class pkgDepCache;
35 class pkgSourceList;
36 class pkgOrderList;
37 class pkgRecords;
38 class pkgPackageManager : protected pkgCache::Namespace
39 {
40 public:
41
42 enum OrderResult {Completed,Failed,Incomplete};
43 static bool SigINTStop;
44
45 protected:
46 std::string *FileNames;
47 pkgDepCache &Cache;
48 pkgOrderList *List;
49 bool Debug;
50 bool NoImmConfigure;
51 bool ImmConfigureAll;
52
53 /** \brief saves packages dpkg let disappear
54
55 This way APT can retreat from trying to configure these
56 packages later on and a frontend can choose to display a
57 notice to inform the user about these disappears.
58 */
59 std::set<std::string> disappearedPkgs;
60
61 void ImmediateAdd(PkgIterator P, bool UseInstallVer, unsigned const int &Depth = 0);
62 virtual OrderResult OrderInstall();
63 bool CheckRConflicts(PkgIterator Pkg,DepIterator Dep,const char *Ver);
64 bool CreateOrderList();
65
66 // Analysis helpers
67 bool DepAlwaysTrue(DepIterator D);
68
69 // Install helpers
70 bool ConfigureAll();
71 bool SmartConfigure(PkgIterator Pkg, int const Depth);
72 //FIXME: merge on abi break
73 bool SmartUnPack(PkgIterator Pkg);
74 bool SmartUnPack(PkgIterator Pkg, bool const Immediate, int const Depth);
75 bool SmartRemove(PkgIterator Pkg);
76 bool EarlyRemove(PkgIterator Pkg);
77
78 // The Actual installation implementation
79 virtual bool Install(PkgIterator /*Pkg*/,std::string /*File*/) {return false;};
80 virtual bool Configure(PkgIterator /*Pkg*/) {return false;};
81 virtual bool Remove(PkgIterator /*Pkg*/,bool /*Purge*/=false) {return false;};
82 virtual bool Go(int statusFd=-1) {return true;};
83 virtual void Reset() {};
84
85 // the result of the operation
86 OrderResult Res;
87
88 public:
89
90 // Main action members
91 bool GetArchives(pkgAcquire *Owner,pkgSourceList *Sources,
92 pkgRecords *Recs);
93
94 // Do the installation
95 OrderResult DoInstall(int statusFd=-1);
96
97 // stuff that needs to be done before the fork() of a library that
98 // uses apt
99 OrderResult DoInstallPreFork() {
100 Res = OrderInstall();
101 return Res;
102 };
103
104 // stuff that needs to be done after the fork
105 OrderResult DoInstallPostFork(int statusFd=-1);
106 bool FixMissing();
107
108 /** \brief returns all packages dpkg let disappear */
109 inline std::set<std::string> GetDisappearedPackages() { return disappearedPkgs; };
110
111 pkgPackageManager(pkgDepCache *Cache);
112 virtual ~pkgPackageManager();
113 };
114
115 #endif