]>
git.saurik.com Git - apt.git/blob - apt-pkg/deb/debsystem.cc
1 // -*- mode: cpp; mode: fold -*-
3 // $Id: debsystem.cc,v 1.4 2004/01/26 17:01:53 mdz Exp $
4 /* ######################################################################
6 System - Abstraction for running on different systems.
8 Basic general structure..
10 ##################################################################### */
12 // Include Files /*{{{*/
15 #include <apt-pkg/debsystem.h>
16 #include <apt-pkg/debversion.h>
17 #include <apt-pkg/debindexfile.h>
18 #include <apt-pkg/dpkgpm.h>
19 #include <apt-pkg/configuration.h>
20 #include <apt-pkg/error.h>
21 #include <apt-pkg/fileutl.h>
22 #include <apt-pkg/pkgcache.h>
23 #include <apt-pkg/cacheiterators.h>
41 class debSystemPrivate
{
43 debSystemPrivate() : LockFD(-1), LockCount(0), StatusFile(0)
46 // For locking support
50 debStatusIndex
*StatusFile
;
53 // System::debSystem - Constructor /*{{{*/
54 // ---------------------------------------------------------------------
56 debSystem::debSystem()
58 d
= new debSystemPrivate();
59 Label
= "Debian dpkg interface";
63 // System::~debSystem - Destructor /*{{{*/
64 // ---------------------------------------------------------------------
66 debSystem::~debSystem()
72 // System::Lock - Get the lock /*{{{*/
73 // ---------------------------------------------------------------------
74 /* This mirrors the operations dpkg does when it starts up. Note the
75 checking of the updates directory. */
76 bool debSystem::Lock()
78 // Disable file locking
79 if (_config
->FindB("Debug::NoLocking",false) == true || d
->LockCount
> 1)
85 // Create the lockfile
86 string AdminDir
= flNotFile(_config
->Find("Dir::State::status"));
87 d
->LockFD
= GetLock(AdminDir
+ "lock");
90 if (errno
== EACCES
|| errno
== EAGAIN
)
91 return _error
->Error(_("Unable to lock the administration directory (%s), "
92 "is another process using it?"),AdminDir
.c_str());
94 return _error
->Error(_("Unable to lock the administration directory (%s), "
95 "are you root?"),AdminDir
.c_str());
98 // See if we need to abort with a dirty journal
99 if (CheckUpdates() == true)
104 if (getenv("SUDO_USER") != NULL
)
105 cmd
= "sudo dpkg --configure -a";
107 cmd
= "dpkg --configure -a";
108 // TRANSLATORS: the %s contains the recovery command, usually
109 // dpkg --configure -a
110 return _error
->Error(_("dpkg was interrupted, you must manually "
111 "run '%s' to correct the problem. "), cmd
);
119 // System::UnLock - Drop a lock /*{{{*/
120 // ---------------------------------------------------------------------
122 bool debSystem::UnLock(bool NoErrors
)
124 if (d
->LockCount
== 0 && NoErrors
== true)
127 if (d
->LockCount
< 1)
128 return _error
->Error(_("Not locked"));
129 if (--d
->LockCount
== 0)
138 // System::CheckUpdates - Check if the updates dir is dirty /*{{{*/
139 // ---------------------------------------------------------------------
140 /* This does a check of the updates directory (dpkg journal) to see if it has
141 any entries in it. */
142 bool debSystem::CheckUpdates()
144 // Check for updates.. (dirty)
145 string File
= flNotFile(_config
->Find("Dir::State::status")) + "updates/";
146 DIR *DirP
= opendir(File
.c_str());
150 /* We ignore any files that are not all digits, this skips .,.. and
151 some tmp files dpkg will leave behind.. */
152 bool Damaged
= false;
153 for (struct dirent
*Ent
= readdir(DirP
); Ent
!= 0; Ent
= readdir(DirP
))
156 for (unsigned int I
= 0; Ent
->d_name
[I
] != 0; I
++)
158 // Check if its not a digit..
159 if (isdigit(Ent
->d_name
[I
]) == 0)
173 // System::CreatePM - Create the underlying package manager /*{{{*/
174 // ---------------------------------------------------------------------
176 pkgPackageManager
*debSystem::CreatePM(pkgDepCache
*Cache
) const
178 return new pkgDPkgPM(Cache
);
181 // System::Initialize - Setup the configuration space.. /*{{{*/
182 // ---------------------------------------------------------------------
183 /* These are the Debian specific configuration variables.. */
184 bool debSystem::Initialize(Configuration
&Cnf
)
186 /* These really should be jammed into a generic 'Local Database' engine
187 which is yet to be determined. The functions in pkgcachegen should
188 be the only users of these */
189 Cnf
.CndSet("Dir::State::extended_states", "extended_states");
190 Cnf
.CndSet("Dir::State::status","/var/lib/dpkg/status");
191 Cnf
.CndSet("Dir::Bin::dpkg","/usr/bin/dpkg");
194 delete d
->StatusFile
;
201 // System::ArchiveSupported - Is a file format supported /*{{{*/
202 // ---------------------------------------------------------------------
203 /* The standard name for a deb is 'deb'.. There are no separate versions
204 of .deb to worry about.. */
205 bool debSystem::ArchiveSupported(const char *Type
)
207 if (strcmp(Type
,"deb") == 0)
212 // System::Score - Determine how 'Debiany' this sys is.. /*{{{*/
213 // ---------------------------------------------------------------------
214 /* We check some files that are sure tell signs of this being a Debian
216 signed debSystem::Score(Configuration
const &Cnf
)
219 if (FileExists(Cnf
.FindFile("Dir::State::status","/var/lib/dpkg/status")) == true)
221 if (FileExists(Cnf
.FindFile("Dir::Bin::dpkg","/usr/bin/dpkg")) == true)
223 if (FileExists("/etc/debian_version") == true)
228 // System::AddStatusFiles - Register the status files /*{{{*/
229 // ---------------------------------------------------------------------
231 bool debSystem::AddStatusFiles(std::vector
<pkgIndexFile
*> &List
)
233 if (d
->StatusFile
== 0)
234 d
->StatusFile
= new debStatusIndex(_config
->FindFile("Dir::State::status"));
235 List
.push_back(d
->StatusFile
);
239 // System::FindIndex - Get an index file for status files /*{{{*/
240 // ---------------------------------------------------------------------
242 bool debSystem::FindIndex(pkgCache::PkgFileIterator File
,
243 pkgIndexFile
*&Found
) const
245 if (d
->StatusFile
== 0)
247 if (d
->StatusFile
->FindInCache(*File
.Cache()) == File
)
249 Found
= d
->StatusFile
;