]> git.saurik.com Git - apt.git/blob - apt-pkg/packagemanager.h
implement Fail-Ignore bool in FetchItem that tells the method that a failure of this...
[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
32 using std::string;
33
34 class pkgAcquire;
35 class pkgDepCache;
36 class pkgSourceList;
37 class pkgOrderList;
38 class pkgRecords;
39 class pkgPackageManager : protected pkgCache::Namespace
40 {
41 public:
42
43 enum OrderResult {Completed,Failed,Incomplete};
44
45 protected:
46 string *FileNames;
47 pkgDepCache &Cache;
48 pkgOrderList *List;
49 bool Debug;
50
51 bool DepAdd(pkgOrderList &Order,PkgIterator P,int Depth = 0);
52 // binary-compat change, fix on next abi break
53 void ImmediateAdd(PkgIterator P, bool UseInstallVer) {
54 ImmediateAdd(P, UseInstallVer, 0);
55 }
56 void ImmediateAdd(PkgIterator P, bool UseInstallVer, unsigned const int &Depth);
57 virtual OrderResult OrderInstall();
58 bool CheckRConflicts(PkgIterator Pkg,DepIterator Dep,const char *Ver);
59 bool CreateOrderList();
60
61 // Analysis helpers
62 bool DepAlwaysTrue(DepIterator D);
63
64 // Install helpers
65 bool ConfigureAll();
66 bool SmartConfigure(PkgIterator Pkg);
67 bool SmartUnPack(PkgIterator Pkg);
68 bool SmartRemove(PkgIterator Pkg);
69 bool EarlyRemove(PkgIterator Pkg);
70
71 // The Actual installation implementation
72 virtual bool Install(PkgIterator /*Pkg*/,string /*File*/) {return false;};
73 virtual bool Configure(PkgIterator /*Pkg*/) {return false;};
74 virtual bool Remove(PkgIterator /*Pkg*/,bool /*Purge*/=false) {return false;};
75 virtual bool Go(int statusFd=-1) {return true;};
76 virtual void Reset() {};
77
78 // the result of the operation
79 OrderResult Res;
80
81 public:
82
83 // Main action members
84 bool GetArchives(pkgAcquire *Owner,pkgSourceList *Sources,
85 pkgRecords *Recs);
86
87 // Do the installation
88 OrderResult DoInstall(int statusFd=-1);
89
90 // stuff that needs to be done before the fork() of a library that
91 // uses apt
92 OrderResult DoInstallPreFork() {
93 Res = OrderInstall();
94 return Res;
95 };
96
97 // stuff that needs to be done after the fork
98 OrderResult DoInstallPostFork(int statusFd=-1);
99 bool FixMissing();
100
101 pkgPackageManager(pkgDepCache *Cache);
102 virtual ~pkgPackageManager();
103 };
104
105 #endif