1 // -*- mode: cpp; mode: fold -*-
3 // $Id: pkgcache.h,v 1.25 2001/07/01 22:28:24 jgg Exp $
4 /* ######################################################################
6 Cache - Structure definitions for the cache file
8 Please see doc/apt-pkg/cache.sgml for a more detailed description of
9 this format. Also be sure to keep that file up-to-date!!
11 Clients should always use the CacheIterators classes for access to the
12 cache. They provide a simple STL-like method for traversing the links
15 See pkgcachegen.h for information about generating cache structures.
17 ##################################################################### */
19 #ifndef PKGLIB_PKGCACHE_H
20 #define PKGLIB_PKGCACHE_H
25 #include <apt-pkg/mmap.h>
29 class pkgVersioningSystem
;
30 class pkgCache
/*{{{*/
33 // Cache element predeclarations
47 template<typename Str
, typename Itr
> class Iterator
;
54 class PkgFileIterator
;
55 class VerFileIterator
;
56 class DescFileIterator
;
60 // These are all the constants used in the cache structures
62 // WARNING - if you change these lists you must also edit
63 // the stringification in pkgcache.cc and also consider whether
64 // the cache file will become incompatible.
67 enum DepType
{Depends
=1,PreDepends
=2,Suggests
=3,Recommends
=4,
68 Conflicts
=5,Replaces
=6,Obsoletes
=7,DpkgBreaks
=8,Enhances
=9};
69 enum DepCompareOp
{Or
=0x10,NoOp
=0,LessEq
=0x1,GreaterEq
=0x2,Less
=0x3,
70 Greater
=0x4,Equals
=0x5,NotEquals
=0x6};
75 enum VerPriority
{Important
=1,Required
=2,Standard
=3,Optional
=4,Extra
=5};
76 enum PkgSelectedState
{Unknown
=0,Install
=1,Hold
=2,DeInstall
=3,Purge
=4};
77 enum PkgInstState
{Ok
=0,ReInstReq
=1,HoldInst
=2,HoldReInstReq
=3};
78 enum PkgCurrentState
{NotInstalled
=0,UnPacked
=1,HalfConfigured
=2,
79 HalfInstalled
=4,ConfigFiles
=5,Installed
=6,
80 TriggersAwaited
=7,TriggersPending
=8};
85 enum PkgFlags
{Auto
=(1<<0),Essential
=(1<<3),Important
=(1<<4)};
86 enum PkgFFlags
{NotSource
=(1<<0),NotAutomatic
=(1<<1)};
91 // Memory mapped cache file
95 unsigned long sHash(const string
&S
) const;
96 unsigned long sHash(const char *S
) const;
100 // Pointers to the arrays of items
106 PackageFile
*PkgFileP
;
111 StringItem
*StringItemP
;
114 virtual bool ReMap();
115 inline bool Sync() {return Map
.Sync();};
116 inline MMap
&GetMap() {return Map
;};
117 inline void *DataEnd() {return ((unsigned char *)Map
.Data()) + Map
.Size();};
119 // String hashing function (512 range)
120 inline unsigned long Hash(const string
&S
) const {return sHash(S
);};
121 inline unsigned long Hash(const char *S
) const {return sHash(S
);};
123 // Usefull transformation things
124 const char *Priority(unsigned char Priority
);
127 GrpIterator
FindGrp(const string
&Name
);
128 PkgIterator
FindPkg(const string
&Name
);
129 PkgIterator
FindPkg(const string
&Name
, string Arch
);
131 Header
&Head() {return *HeaderP
;};
132 inline GrpIterator
GrpBegin();
133 inline GrpIterator
GrpEnd();
134 inline PkgIterator
PkgBegin();
135 inline PkgIterator
PkgEnd();
136 inline PkgFileIterator
FileBegin();
137 inline PkgFileIterator
FileEnd();
139 // Make me a function
140 pkgVersioningSystem
*VS
;
143 static const char *CompTypeDeb(unsigned char Comp
);
144 static const char *CompType(unsigned char Comp
);
145 static const char *DepType(unsigned char Dep
);
147 pkgCache(MMap
*Map
,bool DoMap
= true);
148 virtual ~pkgCache() {};
151 // Header structure /*{{{*/
152 struct pkgCache::Header
154 // Signature information
155 unsigned long Signature
;
160 // Size of structure values
161 unsigned short HeaderSz
;
162 unsigned short PackageSz
;
163 unsigned short PackageFileSz
;
164 unsigned short VersionSz
;
165 unsigned short DescriptionSz
;
166 unsigned short DependencySz
;
167 unsigned short ProvidesSz
;
168 unsigned short VerFileSz
;
169 unsigned short DescFileSz
;
172 unsigned long GroupCount
;
173 unsigned long PackageCount
;
174 unsigned long VersionCount
;
175 unsigned long DescriptionCount
;
176 unsigned long DependsCount
;
177 unsigned long PackageFileCount
;
178 unsigned long VerFileCount
;
179 unsigned long DescFileCount
;
180 unsigned long ProvidesCount
;
183 map_ptrloc FileList
; // struct PackageFile
184 map_ptrloc StringList
; // struct StringItem
185 map_ptrloc VerSysName
; // StringTable
186 map_ptrloc Architecture
; // StringTable
187 unsigned long MaxVerFileSize
;
188 unsigned long MaxDescFileSize
;
190 /* Allocation pools, there should be one of these for each structure
191 excluding the header */
192 DynamicMMap::Pool Pools
[9];
194 // Rapid package and group name lookup
195 // Notice: Increase only both table sizes as the
196 // hashmethod assume the size of the Pkg one
197 map_ptrloc PkgHashTable
[2*1048];
198 map_ptrloc GrpHashTable
[2*1048];
200 bool CheckSizes(Header
&Against
) const;
204 struct pkgCache::Group
{ /*{{{*/
205 map_ptrloc Name
; // Stringtable
208 map_ptrloc FirstPackage
;// Package
209 map_ptrloc LastPackage
; // Package
210 map_ptrloc Next
; // Group
213 struct pkgCache::Package
/*{{{*/
216 map_ptrloc Name
; // Stringtable
217 map_ptrloc Arch
; // StringTable (StringItem)
218 map_ptrloc VersionList
; // Version
219 map_ptrloc CurrentVer
; // Version
220 map_ptrloc Section
; // StringTable (StringItem)
221 map_ptrloc Group
; // Group the Package belongs to
224 map_ptrloc NextPackage
; // Package
225 map_ptrloc RevDepends
; // Dependency
226 map_ptrloc ProvidesList
; // Provides
228 // Install/Remove/Purge etc
229 unsigned char SelectedState
; // What
230 unsigned char InstState
; // Flags
231 unsigned char CurrentState
; // State
237 struct pkgCache::PackageFile
/*{{{*/
240 map_ptrloc FileName
; // Stringtable
241 map_ptrloc Archive
; // Stringtable
242 map_ptrloc Codename
; // Stringtable
243 map_ptrloc Component
; // Stringtable
244 map_ptrloc Version
; // Stringtable
245 map_ptrloc Origin
; // Stringtable
246 map_ptrloc Label
; // Stringtable
247 map_ptrloc Architecture
; // Stringtable
248 map_ptrloc Site
; // Stringtable
249 map_ptrloc IndexType
; // Stringtable
254 map_ptrloc NextFile
; // PackageFile
256 time_t mtime
; // Modification time for the file
259 struct pkgCache::VerFile
/*{{{*/
261 map_ptrloc File
; // PackageFile
262 map_ptrloc NextFile
; // PkgVerFile
263 map_ptrloc Offset
; // File offset
267 struct pkgCache::DescFile
/*{{{*/
269 map_ptrloc File
; // PackageFile
270 map_ptrloc NextFile
; // PkgVerFile
271 map_ptrloc Offset
; // File offset
275 struct pkgCache::Version
/*{{{*/
277 map_ptrloc VerStr
; // Stringtable
278 map_ptrloc Section
; // StringTable (StringItem)
279 enum {None
, All
, Foreign
, Same
, Allowed
} MultiArch
;
282 map_ptrloc FileList
; // VerFile
283 map_ptrloc NextVer
; // Version
284 map_ptrloc DescriptionList
; // Description
285 map_ptrloc DependsList
; // Dependency
286 map_ptrloc ParentPkg
; // Package
287 map_ptrloc ProvidesList
; // Provides
289 map_ptrloc Size
; // These are the .deb size
290 map_ptrloc InstalledSize
;
293 unsigned char Priority
;
296 struct pkgCache::Description
/*{{{*/
298 // Language Code store the description translation language code. If
299 // the value has a 0 lenght then this is readed using the Package
300 // file else the Translation-CODE are used.
301 map_ptrloc language_code
; // StringTable
302 map_ptrloc md5sum
; // StringTable
305 map_ptrloc FileList
; // DescFile
306 map_ptrloc NextDesc
; // Description
307 map_ptrloc ParentPkg
; // Package
312 struct pkgCache::Dependency
/*{{{*/
314 map_ptrloc Version
; // Stringtable
315 map_ptrloc Package
; // Package
316 map_ptrloc NextDepends
; // Dependency
317 map_ptrloc NextRevDepends
; // Dependency
318 map_ptrloc ParentVer
; // Version
320 // Specific types of depends
323 unsigned char CompareOp
;
326 struct pkgCache::Provides
/*{{{*/
328 map_ptrloc ParentPkg
; // Pacakge
329 map_ptrloc Version
; // Version
330 map_ptrloc ProvideVersion
; // Stringtable
331 map_ptrloc NextProvides
; // Provides
332 map_ptrloc NextPkgProv
; // Provides
335 struct pkgCache::StringItem
/*{{{*/
337 map_ptrloc String
; // Stringtable
338 map_ptrloc NextItem
; // StringItem
341 #include <apt-pkg/cacheiterators.h>
343 inline pkgCache::GrpIterator
pkgCache::GrpBegin()
344 {return GrpIterator(*this);};
345 inline pkgCache::GrpIterator
pkgCache::GrpEnd()
346 {return GrpIterator(*this,GrpP
);};
347 inline pkgCache::PkgIterator
pkgCache::PkgBegin()
348 {return PkgIterator(*this);};
349 inline pkgCache::PkgIterator
pkgCache::PkgEnd()
350 {return PkgIterator(*this,PkgP
);};
351 inline pkgCache::PkgFileIterator
pkgCache::FileBegin()
352 {return PkgFileIterator(*this,PkgFileP
+ HeaderP
->FileList
);};
353 inline pkgCache::PkgFileIterator
pkgCache::FileEnd()
354 {return PkgFileIterator(*this,PkgFileP
);};
356 // Oh I wish for Real Name Space Support
357 class pkgCache::Namespace
/*{{{*/
361 typedef pkgCache::PkgIterator PkgIterator
;
362 typedef pkgCache::VerIterator VerIterator
;
363 typedef pkgCache::DescIterator DescIterator
;
364 typedef pkgCache::DepIterator DepIterator
;
365 typedef pkgCache::PrvIterator PrvIterator
;
366 typedef pkgCache::PkgFileIterator PkgFileIterator
;
367 typedef pkgCache::VerFileIterator VerFileIterator
;
368 typedef pkgCache::Version Version
;
369 typedef pkgCache::Description Description
;
370 typedef pkgCache::Package Package
;
371 typedef pkgCache::Header Header
;
372 typedef pkgCache::Dep Dep
;
373 typedef pkgCache::Flag Flag
;