// -*- mode: cpp; mode: fold -*-
// Description /*{{{*/
-// $Id: pkgrecords.cc,v 1.1 1998/08/09 00:51:35 jgg Exp $
+// $Id: pkgrecords.cc,v 1.6 2001/02/20 07:03:17 jgg Exp $
/* ######################################################################
Package Records - Allows access to complete package description records
#pragma implementation "apt-pkg/pkgrecords.h"
#endif
#include <apt-pkg/pkgrecords.h>
-#include <apt-pkg/debrecords.h>
+#include <apt-pkg/indexfile.h>
#include <apt-pkg/error.h>
+#include <apt-pkg/configuration.h>
+
+#include <apti18n.h>
/*}}}*/
// Records::pkgRecords - Constructor /*{{{*/
/* This will create the necessary structures to access the status files */
pkgRecords::pkgRecords(pkgCache &Cache) : Cache(Cache), Files(0)
{
- Files = new PkgFile[Cache.HeaderP->PackageFileCount];
+ Files = new Parser *[Cache.HeaderP->PackageFileCount];
+ memset(Files,0,sizeof(*Files)*Cache.HeaderP->PackageFileCount);
+
for (pkgCache::PkgFileIterator I = Cache.FileBegin();
I.end() == false; I++)
{
- Files[I->ID].File = new FileFd(I.FileName(),FileFd::ReadOnly);
- if (_error->PendingError() == true)
+ const pkgIndexFile::Type *Type = pkgIndexFile::Type::GetType(I.IndexType());
+ if (Type == 0)
+ {
+ _error->Error(_("Index file type '%s' is not supported"),I.IndexType());
return;
- Files[I->ID].Parse = new debRecordParser(*Files[I->ID].File);
- if (_error->PendingError() == true)
+ }
+
+ Files[I->ID] = Type->CreatePkgParser(I);
+ if (Files[I->ID] == 0)
return;
}
}
/* */
pkgRecords::~pkgRecords()
{
+ for (unsigned I = 0; I != Cache.HeaderP->PackageFileCount; I++)
+ delete Files[I];
delete [] Files;
}
/*}}}*/
// Records::Lookup - Get a parser for the package version file /*{{{*/
// ---------------------------------------------------------------------
/* */
-pkgRecords::Parser &pkgRecords::Lookup(pkgCache::VerFileIterator &Ver)
-{
- PkgFile &File = Files[Ver.File()->ID];
- File.Parse->Jump(Ver);
-
- return *File.Parse;
-}
- /*}}}*/
-// Records::Pkgfile::~PkgFile - Destructor /*{{{*/
-// ---------------------------------------------------------------------
-/* */
-pkgRecords::PkgFile::~PkgFile()
+pkgRecords::Parser &pkgRecords::Lookup(pkgCache::VerFileIterator const &Ver)
{
- delete Parse;
- delete File;
+ Files[Ver.File()->ID]->Jump(Ver);
+ return *Files[Ver.File()->ID];
}
/*}}}*/