diff options
-rw-r--r-- | apt-pkg/pkgcache.h | 89 | ||||
-rw-r--r-- | apt-pkg/pkgcachegen.cc | 8 |
2 files changed, 51 insertions, 46 deletions
diff --git a/apt-pkg/pkgcache.h b/apt-pkg/pkgcache.h index 23c60af9..037f8f05 100644 --- a/apt-pkg/pkgcache.h +++ b/apt-pkg/pkgcache.h @@ -1,6 +1,6 @@ // -*- mode: cpp; mode: fold -*- // Description /*{{{*/ -// $Id: pkgcache.h,v 1.9 1998/11/08 23:29:18 jgg Exp $ +// $Id: pkgcache.h,v 1.10 1998/11/12 03:28:29 jgg Exp $ /* ###################################################################### Cache - Structure definitions for the cache file @@ -28,6 +28,11 @@ #include <time.h> #include <apt-pkg/mmap.h> +/* This should be a 32 bit type, larger tyes use too much ram and smaller + types are too small. Where ever possible 'unsigned long' should be used + instead of this internal type */ +typedef unsigned int __apt_ptrloc; + class pkgCache { public: @@ -149,8 +154,8 @@ struct pkgCache::Header unsigned long PackageFileCount; // Offsets - unsigned long FileList; // struct PackageFile - unsigned long StringList; // struct StringItem + __apt_ptrloc FileList; // struct PackageFile + __apt_ptrloc StringList; // struct StringItem unsigned long MaxVerFileSize; /* Allocation pools, there should be one of these for each structure @@ -158,7 +163,7 @@ struct pkgCache::Header DynamicMMap::Pool Pools[7]; // Rapid package name lookup - unsigned long HashTable[512]; + __apt_ptrloc HashTable[512]; bool CheckSizes(Header &Against) const; Header(); @@ -167,17 +172,17 @@ struct pkgCache::Header struct pkgCache::Package { // Pointers - unsigned long Name; // Stringtable - unsigned long VersionList; // Version - unsigned long TargetVer; // Version - unsigned long CurrentVer; // Version - unsigned long TargetDist; // StringTable (StringItem) - unsigned long Section; // StringTable (StringItem) + __apt_ptrloc Name; // Stringtable + __apt_ptrloc VersionList; // Version + __apt_ptrloc TargetVer; // Version + __apt_ptrloc CurrentVer; // Version + __apt_ptrloc TargetDist; // StringTable (StringItem) + __apt_ptrloc Section; // StringTable (StringItem) // Linked list - unsigned long NextPackage; // Package - unsigned long RevDepends; // Dependency - unsigned long ProvidesList; // Provides + __apt_ptrloc NextPackage; // Package + __apt_ptrloc RevDepends; // Dependency + __apt_ptrloc ProvidesList; // Provides // Install/Remove/Purge etc unsigned char SelectedState; // What @@ -191,13 +196,13 @@ struct pkgCache::Package struct pkgCache::PackageFile { // Names - unsigned long FileName; // Stringtable - unsigned long Version; // Stringtable - unsigned long Distribution; // Stringtable - unsigned long Size; + __apt_ptrloc FileName; // Stringtable + __apt_ptrloc Version; // Stringtable + __apt_ptrloc Distribution; // Stringtable + __apt_ptrloc Size; // Linked list - unsigned long NextFile; // PackageFile + __apt_ptrloc NextFile; // PackageFile unsigned short ID; unsigned long Flags; time_t mtime; // Modification time for the file @@ -205,37 +210,37 @@ struct pkgCache::PackageFile struct pkgCache::VerFile { - unsigned long File; // PackageFile - unsigned long NextFile; // PkgVerFile - unsigned long Offset; + __apt_ptrloc File; // PackageFile + __apt_ptrloc NextFile; // PkgVerFile + __apt_ptrloc Offset; // File offset unsigned short Size; }; struct pkgCache::Version { - unsigned long VerStr; // Stringtable - unsigned long Section; // StringTable (StringItem) + __apt_ptrloc VerStr; // Stringtable + __apt_ptrloc Section; // StringTable (StringItem) // Lists - unsigned long FileList; // VerFile - unsigned long NextVer; // Version - unsigned long DependsList; // Dependency - unsigned long ParentPkg; // Package - unsigned long ProvidesList; // Provides + __apt_ptrloc FileList; // VerFile + __apt_ptrloc NextVer; // Version + __apt_ptrloc DependsList; // Dependency + __apt_ptrloc ParentPkg; // Package + __apt_ptrloc ProvidesList; // Provides - unsigned long Size; - unsigned long InstalledSize; + __apt_ptrloc Size; // These are the .deb size + __apt_ptrloc InstalledSize; unsigned short ID; unsigned char Priority; }; struct pkgCache::Dependency { - unsigned long Version; // Stringtable - unsigned long Package; // Package - unsigned long NextDepends; // Dependency - unsigned long NextRevDepends; // Dependency - unsigned long ParentVer; // Version + __apt_ptrloc Version; // Stringtable + __apt_ptrloc Package; // Package + __apt_ptrloc NextDepends; // Dependency + __apt_ptrloc NextRevDepends; // Dependency + __apt_ptrloc ParentVer; // Version // Specific types of depends unsigned char Type; @@ -245,17 +250,17 @@ struct pkgCache::Dependency struct pkgCache::Provides { - unsigned long ParentPkg; // Pacakge - unsigned long Version; // Version - unsigned long ProvideVersion; // Stringtable - unsigned long NextProvides; // Provides - unsigned long NextPkgProv; // Provides + __apt_ptrloc ParentPkg; // Pacakge + __apt_ptrloc Version; // Version + __apt_ptrloc ProvideVersion; // Stringtable + __apt_ptrloc NextProvides; // Provides + __apt_ptrloc NextPkgProv; // Provides }; struct pkgCache::StringItem { - unsigned long String; // Stringtable - unsigned long NextItem; // StringItem + __apt_ptrloc String; // Stringtable + __apt_ptrloc NextItem; // StringItem }; #include <apt-pkg/cacheiterators.h> diff --git a/apt-pkg/pkgcachegen.cc b/apt-pkg/pkgcachegen.cc index 25704e05..0bec88fc 100644 --- a/apt-pkg/pkgcachegen.cc +++ b/apt-pkg/pkgcachegen.cc @@ -1,6 +1,6 @@ // -*- mode: cpp; mode: fold -*- // Description /*{{{*/ -// $Id: pkgcachegen.cc,v 1.21 1998/11/11 23:45:28 jgg Exp $ +// $Id: pkgcachegen.cc,v 1.22 1998/11/12 03:28:31 jgg Exp $ /* ###################################################################### Package Cache Generator - Generator for the cache structure. @@ -94,7 +94,7 @@ bool pkgCacheGenerator::MergeList(ListParser &List) } pkgCache::VerIterator Ver = Pkg.VersionList(); - unsigned long *Last = &Pkg->VersionList; + __apt_ptrloc *Last = &Pkg->VersionList; int Res = 1; for (; Ver.end() == false; Last = &Ver->NextVer, Ver++) { @@ -254,7 +254,7 @@ bool pkgCacheGenerator::ListParser::NewDepends(pkgCache::VerIterator Ver, Pkg->RevDepends = Dep.Index(); // Link it to the version (at the end of the list) - unsigned long *Last = &Ver->DependsList; + __apt_ptrloc *Last = &Ver->DependsList; for (pkgCache::DepIterator D = Ver.DependsList(); D.end() == false; D++) Last = &D->NextDepends; Dep->NextDepends = *Last; @@ -345,7 +345,7 @@ unsigned long pkgCacheGenerator::WriteUniqString(const char *S, // Search for an insertion point pkgCache::StringItem *I = Cache.StringItemP + Cache.HeaderP->StringList; int Res = 1; - unsigned long *Last = &Cache.HeaderP->StringList; + __apt_ptrloc *Last = &Cache.HeaderP->StringList; for (; I != Cache.StringItemP; Last = &I->NextItem, I = Cache.StringItemP + I->NextItem) { |