4.0.4-alt98.5

- rpmdb: Removed db1 support.
- db3.c (db3close): Backported fix for double close (RH#138589).
This commit is contained in:
Alexey Tourbin 2009-04-23 17:51:22 +04:00
commit d7abcfb9dc
15 changed files with 20 additions and 1497 deletions

View File

@ -394,11 +394,8 @@ INPUT = \
@top_srcdir@/lib/tagtable.c \
@top_srcdir@/lib/transaction.c \
@top_srcdir@/lib/verify.c \
@top_srcdir@/rpmdb/db1.c \
@top_srcdir@/rpmdb/db3.c \
@top_srcdir@/rpmdb/dbconfig.c \
@top_srcdir@/rpmdb/falloc.c \
@top_srcdir@/rpmdb/falloc.h \
@top_srcdir@/rpmdb/fprint.c \
@top_srcdir@/rpmdb/fprint.h \
@top_srcdir@/rpmdb/poptDB.c \

View File

@ -300,66 +300,6 @@ dnl for this macro (not LIBS=...), otherwise the check for dbopen
dnl will fail.
AC_CHECK_LIB(port, writev)
WITH_DB_SUBDIR=
WITH_INTERNAL_DB=0
DBLIBSRCS="db3.c db1.c falloc.c"
libdb3=""
libdb3a=""
dnl
dnl Detect whether internal Berkeley DB should be built.
dnl
withval=no
AC_ARG_WITH(db, [ --with-db use internal Berkeley db])
if test $withval = no ; then
dnl ------------------ without internal db
AC_CHECK_HEADERS([db4/db.h] [db3/db.h])
dnl Check for Berkeley db3 API.
AC_CHECK_FUNC(db_create, ,
AC_CHECK_LIB(db, db_create, [libdb3="-ldb"],
AC_MSG_ERROR([sorry rpm requires Berkeley db3/db4])
)
)
if test -n "$libdb3" -a -n "$libthread" ; then
AC_MSG_CHECKING(whether $libdb3 needs $libthread)
saveLIBS="$LIBS"
LIBS="$LIBS $libdb3"
AC_TRY_LINK_FUNC(db_create, AC_MSG_RESULT(no),
[libdb3="$libdb3 $libthread"; AC_MSG_RESULT(yes)])
LIBS="$saveLIBS"
fi
else
dnl ------------------ with internal db
AC_DEFINE(HAVE_DB3_DB_H, 1, [Define if you have the <db3/db.h> header file])
WITH_DB_SUBDIR=db3
WITH_INTERNAL_DB=1
libdb3="# \$(top_builddir)/db3/libdb.la"
libdb3a="\$(top_builddir)/db3/libdb.a"
dnl INCPATH="-I\$(top_builddir)/$(WITH_DB_SUBDIR) $INCPATH"
fi
AC_SUBST(WITH_DB_SUBDIR)
AC_SUBST(WITH_INTERNAL_DB)
DBLIBOBJS=`echo $DBLIBSRCS | sed -e "s/\.c/\.lo/g"`
AC_SUBST(DBLIBSRCS)
AC_SUBST(DBLIBOBJS)
AC_SUBST(libdb3)
AC_SUBST(libdb3a)
for dbi in $DBLIBSRCS; do
case $dbi in
db3.c) AC_DEFINE(USE_DB3, 1, [Use the Berkeley db3 API?]) ;;
db1.c) AC_DEFINE(USE_DB1, 1, [Use the Berkeley db1 retrofit to db3 API?]) ;;
esac
done
dnl AmigaOS and IXEmul have a fork() dummy
case "$target" in
m68k-*-amigaos )
@ -943,7 +883,7 @@ AC_DEFINE_UNQUOTED(SYSCONFIGDIR, "$SYSCONFIGDIR",
[Full path to rpm system configuration directory (usually /etc/rpm)])
AC_SUBST(SYSCONFIGDIR)
MACROFILES="${RPMCONFIGDIR}/macros:${RPMCONFIGDIR}/%{_target}/macros:${RPMCONFIGDIR}/macros.d/*:${SYSCONFIGDIR}/macros.specspo:${SYSCONFIGDIR}/macros.db1:${SYSCONFIGDIR}/macros.cdb:${SYSCONFIGDIR}/macros:${SYSCONFIGDIR}/%{_target}/macros:${SYSCONFIGDIR}/macros.d/*:~/.rpmmacros"
MACROFILES="${RPMCONFIGDIR}/macros:${RPMCONFIGDIR}/%{_target}/macros:${RPMCONFIGDIR}/macros.d/*:${SYSCONFIGDIR}/macros.specspo:${SYSCONFIGDIR}/macros.cdb:${SYSCONFIGDIR}/macros:${SYSCONFIGDIR}/%{_target}/macros:${SYSCONFIGDIR}/macros.d/*:~/.rpmmacros"
AC_DEFINE_UNQUOTED(MACROFILES, "$MACROFILES",
[Colon separated paths of macro files to read.])
AC_SUBST(MACROFILES)

View File

@ -49,10 +49,8 @@ lib/signature.c
lib/stringbuf.c
lib/transaction.c
lib/verify.c
rpmdb/db1.c
rpmdb/db3.c
rpmdb/dbconfig.c
rpmdb/falloc.c
rpmdb/fprint.c
rpmdb/poptDB.c
rpmdb/rpmhash.c

View File

@ -4,7 +4,7 @@
Name: %rpm_name
Version: %rpm_version
Release: alt98.4
Release: alt98.5
%define ifdef() %if %{expand:%%{?%{1}:1}%%{!?%{1}:0}}
%define get_dep() %(rpm -q --qf '%%{NAME} >= %%|SERIAL?{%%{SERIAL}:}|%%{VERSION}-%%{RELEASE}' %1 2>/dev/null || echo '%1 >= unknown')
@ -271,9 +271,6 @@ chmod a-w %buildroot%_usrsrc/RPM{,/RPMS/*}
mkdir -p %buildroot{%_rpmlibdir/macros.d,%_sysconfdir/%name/macros.d}
touch %buildroot%_sysconfdir/%name/macros
cat << E_O_F > %buildroot%_sysconfdir/%name/macros.db1
%%_dbapi 1
E_O_F
cat << E_O_F > %buildroot%_sysconfdir/%name/macros.cdb
%{?enable_cdb:#%%__dbi_cdb %enable_cdb}
E_O_F
@ -339,34 +336,12 @@ sh -n %buildroot%_rpmlibdir/functions
sh -n %buildroot%_rpmlibdir/find-package
%pre
if [ -f %_localstatedir/%name/Packages -a -f %_localstatedir/%name/packages.rpm ]; then
echo "
You have both
%_localstatedir/%name/packages.rpm db1 format installed package headers
%_localstatedir/%name/Packages db3 format installed package headers
Please remove (or at least rename) one of those files, and re-install.
" >&2
exit 1
fi
[ ! -L %_rpmlibdir/noarch-alt-%_target_os ] || rm -f %_rpmlibdir/noarch-alt-%_target_os ||:
%post
if [ -f %_localstatedir/%name/packages.rpm ]; then
chgrp %name %_localstatedir/%name/*.rpm
# Migrate to db3 database.
%_rpmlibdir/pdeath_execute $PPID %_rpmlibdir/delayed_rebuilddb
elif [ -f %_localstatedir/%name/Packages ]; then
chgrp %name %_localstatedir/%name/[A-Z]*
# Undo db1 configuration.
rm -f %_sysconfdir/%name/macros.db1
[ -n "$DURING_INSTALL" -o -n "$BTE_INSTALL" ] ||
%_rpmlibdir/pdeath_execute $PPID %_rpmlibdir/delayed_rebuilddb
else
# Initialize db3 database.
rm -f %_sysconfdir/%name/macros.db1
%_bindir/rpmdb --initdb
fi
chgrp %name %_localstatedir/%name/[A-Z]*
[ -n "$DURING_INSTALL" -o -n "$BTE_INSTALL" ] ||
%_rpmlibdir/pdeath_execute $PPID rpmdb -v --rebuilddb
# Invalidate apt cache, due to e.g. rpmlib(PayloadIsLzma).
if set /var/cache/apt/*.bin && [ -f "$1" ]; then
@ -450,7 +425,6 @@ fi
%_bindir/rpminit
%_bindir/rpm*cmp
%rpmattr %_rpmlibdir/delayed_rebuilddb
%rpmattr %_rpmlibdir/pdeath_execute
%rpmattr %_rpmlibdir/rpm[dikq]
%_rpmlibdir/rpm[euv]
@ -547,6 +521,10 @@ fi
%endif #with contrib
%changelog
* Thu Apr 23 2009 Alexey Tourbin <at@altlinux.ru> 4.0.4-alt98.5
- rpmdb: Removed db1 support.
- db3.c (db3close): Backported fix for double close (RH#138589).
* Sat Apr 18 2009 Dmitry V. Levin <ldv@altlinux.org> 4.0.4-alt98.4
- rpm.8: Fixed typo (closes: #19356).
- platform.in: Added macros: %%_logrotatedir, %%_runtimedir (closes: #13639).

View File

@ -8,15 +8,13 @@ INCLUDES = -I. \
-I$(top_srcdir)/rpmio \
@INCPATH@
DBLIBSRCS = db3.c db1.c falloc.c
LIBDB = @libdb3@
LIBDB = -ldb
LIBELF = @WITH_LIBELF_LIB@
LIBPOPT = @LIBPOPT@
pkgincdir = $(pkgincludedir)
pkginc_HEADERS = hdrinline.h rpmdb.h
noinst_HEADERS = falloc.h fprint.h rpmhash.h jhash.h
noinst_HEADERS = fprint.h rpmhash.h jhash.h
mylibpaths = -L$(top_builddir)/lib/.libs
mylibs = -lrpm
@ -24,10 +22,10 @@ mylibs = -lrpm
LIBS =
lib_LTLIBRARIES = librpmdb.la
librpmdb_la_SOURCES = $(DBLIBSRCS) \
librpmdb_la_SOURCES = db3.c \
dbconfig.c hdrNVR.c header.c fprint.c legacy.c merge.c poptDB.c \
rpmhash.c rpmdb.c rpmvercmp.c tagname.c tagtbl.c
librpmdb_la_LDFLAGS = -release @VERSION@ @libdb3@
librpmdb_la_LDFLAGS = -release @VERSION@
librpmdb_la_LIBADD = $(LIBDB) $(LIBELF) $(LIBPOPT) $(top_builddir)/rpmio/librpmio.la
librpmdb_la_DEPENDENCIES = $(top_builddir)/rpmio/librpmio.la
@ -48,9 +46,6 @@ tagtbl.c: Makefile.am $(top_srcdir)/lib/rpmlib.h
BUILT_SOURCES = tagtbl.c
falloc.lo: falloc.c $(top_srcdir)/system.h $(top_srcdir)/rpmio/rpmio.h falloc.h
$(LIBTOOL) --mode=compile $(COMPILE) -c $<
clean-local:
rm -f $(DB3LOBJS) *.o
@ -64,6 +59,3 @@ lclint:
tdbi: librpmdb.la tdbi.o
$(LINK) -all-static $@.o $< $(mylibpaths) $(mylibs) $(LIBS)
tfalloc: librpmdb.la tfalloc.o
$(LINK) -all-static $@.o $< $(mylibpaths) $(mylibs) $(LIBS)

View File

@ -1,626 +0,0 @@
/*@-type@*/ /* FIX: shrug */
/** \ingroup db1
* \file rpmdb/db1.c
*/
#include "system.h"
#ifdef DYING
/*@unused@*/ static int _debug = 1; /* XXX if < 0 debugging, > 0 unusual error returns */
#endif
#define _mymemset(_a, _b, _c)
#include "rpmio_internal.h"
#include "rpmlib.h"
#include "rpmmacro.h" /* XXX rpmGenPath */
#include "rpmurl.h" /* XXX urlGetPath */
#include "falloc.h"
#include "misc.h"
#include "rpmdb.h"
/* XXX must follow rpmdb.h */
#define DB_VERSION_MAJOR 1
#define DB_VERSION_MINOR 85
#define DB_VERSION_PATCH 0
struct _DBT1 {
void * data; /* data */
size_t size; /* data length */
};
#undef DBT
#define DBT struct _DBT1
#include "debug.h"
/*@access Header@*/ /* XXX compared with NULL */
/*@access rpmdb@*/
/*@access dbiIndex@*/
/*@access dbiIndexSet@*/
/*@-onlytrans@*/
#ifdef DYING
/* XXX remap DB3 types back into DB1 types */
static inline DBTYPE db3_to_dbtype(int dbitype)
{
switch(dbitype) {
case 1: return DB_BTREE;
case 2: return DB_HASH;
case 3: return DB_RECNO;
case 4: return DB_HASH; /* XXX W2DO? */
case 5: return DB_HASH; /* XXX W2DO? */
}
/*@notreached@*/ return DB_HASH;
}
/*@-shadow@*/
static /*@observer@*/ char * db_strerror(int error)
/*@=shadow@*/
{
if (error == 0)
return ("Successful return: 0");
if (error > 0)
return (strerror(error));
switch (error) {
default:
{
/*
* !!!
* Room for a 64-bit number + slop. This buffer is only used
* if we're given an unknown error, which should never happen.
* Note, however, we're no longer thread-safe if it does.
*/
static char ebuf[40];
char * t = ebuf;
*t = '\0';
t = stpcpy(t, "Unknown error: ");
sprintf(t, "%d", error);
return(ebuf);
}
}
/*@notreached@*/
}
static int cvtdberr(dbiIndex dbi, const char * msg, int error, int printit)
/*@*/
{
int rc = 0;
if (error == 0)
rc = 0;
else if (error < 0)
rc = errno;
else if (error > 0)
rc = -1;
if (printit && rc) {
if (msg)
rpmError(RPMERR_DBERR, _("db%d error(%d) from %s: %s\n"),
dbi->dbi_api, rc, msg, db_strerror(error));
else
rpmError(RPMERR_DBERR, _("db%d error(%d): %s\n"),
dbi->dbi_api, rc, db_strerror(error));
}
return rc;
}
#endif /* DYING */
static int db1sync(dbiIndex dbi, /*@unused@*/ unsigned int flags)
/*@globals fileSystem @*/
/*@modifies fileSystem @*/
{
int rc = 0;
if (dbi->dbi_db) {
if (dbi->dbi_rpmtag == RPMDBI_PACKAGES) {
FD_t pkgs = dbi->dbi_db;
int fdno = Fileno(pkgs);
if (fdno >= 0 && (rc = fsync(fdno)) != 0)
rc = errno;
}
#ifdef DYING
else {
DB * db = dbi->dbi_db;
rc = db->sync(db, flags);
rc = cvtdberr(dbi, "db->sync", rc, _debug);
}
#endif
}
return rc;
}
/*@null@*/ static void * doGetRecord(dbiIndex dbi, unsigned int offset)
/*@globals fileSystem @*/
/*@modifies dbi, fileSystem @*/
{
FD_t pkgs = dbi->dbi_db;
void * uh = NULL;
Header h = NULL;
const char ** fileNames;
int fileCount = 0;
int lasto = 0;
int i;
retry:
if (offset >= fadGetFileSize(pkgs))
goto exit;
(void)Fseek(pkgs, offset, SEEK_SET);
h = headerRead(pkgs, HEADER_MAGIC_NO);
/* let's sanity check this record a bit, otherwise just skip it */
if (h != NULL &&
!( headerIsEntry(h, RPMTAG_NAME) &&
headerIsEntry(h, RPMTAG_VERSION) &&
headerIsEntry(h, RPMTAG_RELEASE) &&
headerIsEntry(h, RPMTAG_BUILDTIME)))
{
h = headerFree(h);
}
if (h == NULL) {
/* XXX HACK: try to reconnect broken chain. */
if (lasto == 0) {
rpmMessage(RPMMESS_WARNING,
_("Broken package chain at offset %d(0x%08x), attempting to reconnect ...\n"),
(int) offset, offset);
lasto = (offset ? offset : -1);
offset = fadNextOffset(pkgs, offset);
if (offset > 0)
goto retry;
}
goto exit;
}
if (lasto) {
rpmMessage(RPMMESS_WARNING,
_("Reconnecting broken chain at offset %d(0x%08x).\n"),
(int) offset, offset);
dbi->dbi_lastoffset = offset;
}
/* Retrofit "Provide: name = EVR" for binary packages. */
providePackageNVR(h);
/*
* The RPM used to build much of RH 5.1 could produce packages whose
* file lists did not have leading /'s. Now is a good time to fix that.
*/
/*
* If this tag isn't present, either no files are in the package or
* we're dealing with a package that has just the compressed file name
* list.
*/
if (!headerGetEntryMinMemory(h, RPMTAG_OLDFILENAMES, NULL,
(const void **) &fileNames, &fileCount))
goto exit;
for (i = 0; i < fileCount; i++)
if (*fileNames[i] != '/') break;
if (i == fileCount) {
free(fileNames);
} else { /* bad header -- let's clean it up */
const char ** newFileNames = alloca(sizeof(*newFileNames) * fileCount);
for (i = 0; i < fileCount; i++) {
char * newFileName = alloca(strlen(fileNames[i]) + 2);
if (*fileNames[i] != '/') {
newFileName[0] = '/';
newFileName[1] = '\0';
} else
newFileName[0] = '\0';
strcat(newFileName, fileNames[i]);
newFileNames[i] = newFileName;
}
free(fileNames);
(void) headerModifyEntry(h, RPMTAG_OLDFILENAMES, RPM_STRING_ARRAY_TYPE,
newFileNames, fileCount);
}
/*
* The file list was moved to a more compressed format which not
* only saves memory (nice), but gives fingerprinting a nice, fat
* speed boost (very nice). Go ahead and convert old headers to
* the new style (this is a noop for new headers).
*/
compressFilelist(h);
exit:
/*@-branchstate@*/
if (h != NULL) {
uh = headerUnload(h);
h = headerFree(h);
}
/*@=branchstate@*/
return uh;
}
static int db1copen(/*@unused@*/ dbiIndex dbi,
/*@unused@*/ DBC ** dbcp, unsigned int flags)
/*@modifies *dbcp @*/
{
/* XXX per-iterator cursors need to be set to non-NULL. */
if (flags)
*dbcp = (DBC *)-1;
return 0;
}
static int db1cclose(dbiIndex dbi,
/*@unused@*/ DBC * dbcursor, /*@unused@*/ unsigned int flags)
/*@modifies dbi @*/
{
dbi->dbi_lastoffset = 0;
return 0;
}
/*@-compmempass@*/
static int db1cget(dbiIndex dbi, /*@unused@*/ DBC * dbcursor,
/*@null@*/ void ** keyp,
/*@null@*/ size_t * keylen,
/*@null@*/ void ** datap,
/*@null@*/ size_t * datalen,
/*@unused@*/ unsigned int flags)
/*@globals fileSystem @*/
/*@modifies dbi, *keyp, *keylen, *datap, *datalen, fileSystem @*/
{
DBT key, data;
int rc = 0;
if (dbi == NULL)
return EFAULT;
memset(&key, 0, sizeof(key));
memset(&data, 0, sizeof(data));
/*@-unqualifiedtrans@*/
if (keyp) key.data = *keyp;
if (keylen) key.size = *keylen;
if (datap) data.data = *datap;
if (datalen) data.size = *datalen;
/*@=unqualifiedtrans@*/
if (dbi->dbi_rpmtag == RPMDBI_PACKAGES) {
FD_t pkgs = dbi->dbi_db;
unsigned int offset;
unsigned int newSize;
if (key.data == NULL) { /* XXX simulated DB_NEXT */
if (dbi->dbi_lastoffset == 0) {
dbi->dbi_lastoffset = fadFirstOffset(pkgs);
} else {
dbi->dbi_lastoffset = fadNextOffset(pkgs, dbi->dbi_lastoffset);
}
/*@-immediatetrans@*/
key.data = &dbi->dbi_lastoffset;
/*@=immediatetrans@*/
key.size = sizeof(dbi->dbi_lastoffset);
/* Catch end-of-chain conditions. */
if (dbi->dbi_lastoffset == 0)
goto bail;
}
memcpy(&offset, key.data, sizeof(offset));
/* XXX hack to pass sizeof header to fadAlloc */
newSize = data.size;
if (offset == 0) { /* XXX simulated offset 0 record */
offset = fadAlloc(pkgs, newSize);
if (offset == 0)
return ENOMEM;
offset--; /* XXX hack: caller will increment */
/* XXX hack: return offset as data, free in db1cput */
data.data = xmalloc(sizeof(offset));
memcpy(data.data, &offset, sizeof(offset));
data.size = sizeof(offset);
} else { /* XXX simulated retrieval */
data.data = doGetRecord(dbi, offset);
data.size = 0; /* XXX WRONG */
}
}
#ifdef DYING
else {
DB * db;
int _printit;
if ((db = dbi->dbi_db) == NULL)
return EFAULT;
if (key.data == NULL) {
rc = db->seq(db, &key, &data, (dbi->dbi_lastoffset++ ? R_NEXT : R_FIRST));
_printit = (rc == 1 ? 0 : _debug);
rc = cvtdberr(dbi, "db->seq", rc, _printit);
} else {
rc = db->get(db, &key, &data, 0);
_printit = (rc == 1 ? 0 : _debug);
rc = cvtdberr(dbi, "db1cget", rc, _printit);
}
}
#else
else
rc = EINVAL;
#endif
bail:
if (rc == 0) {
if (keyp) *keyp = key.data;
if (keylen) *keylen = key.size;
if (datap) *datap = data.data;
if (datalen) *datalen = data.size;
}
/*@-nullstate@*/
return rc;
/*@=nullstate@*/
}
/*@=compmempass@*/
static int db1cdel(dbiIndex dbi, /*@unused@*/ DBC * dbcursor, const void * keyp,
size_t keylen, /*@unused@*/ unsigned int flags)
/*@globals fileSystem @*/
/*@modifies dbi, fileSystem @*/
{
DBT key;
int rc = 0;
memset(&key, 0, sizeof(key));
key.data = (void *)keyp;
key.size = keylen;
if (dbi->dbi_rpmtag == RPMDBI_PACKAGES) {
FD_t pkgs = dbi->dbi_db;
unsigned int offset;
memcpy(&offset, keyp, sizeof(offset));
fadFree(pkgs, offset);
}
#ifdef DYING
else {
DB * db = dbi->dbi_db;
if (db)
rc = db->del(db, &key, 0);
rc = cvtdberr(dbi, "db->del", rc, _debug);
}
#else
else
rc = EINVAL;
#endif
return rc;
}
static int db1cput(dbiIndex dbi, /*@unused@*/ DBC * dbcursor,
const void * keyp, size_t keylen,
const void * datap, size_t datalen,
/*@unused@*/ unsigned int flags)
/*@globals fileSystem @*/
/*@modifies dbi, datap, fileSystem @*/
{
DBT key, data;
int rc = 0;
memset(&key, 0, sizeof(key));
memset(&data, 0, sizeof(data));
key.data = (void *)keyp;
key.size = keylen;
data.data = (void *)datap;
data.size = datalen;
if (dbi->dbi_rpmtag == RPMDBI_PACKAGES) {
FD_t pkgs = dbi->dbi_db;
unsigned int offset;
memcpy(&offset, key.data, sizeof(offset));
if (offset == 0) { /* XXX simulated offset 0 record */
/* XXX hack: return offset as data, free in db1cput */
if (data.size == sizeof(offset))
/*@-unqualifiedtrans@*/ free(data.data); /*@=unqualifiedtrans@*/
} else { /* XXX simulated DB_KEYLAST */
Header h = headerLoad(data.data);
int newSize = headerSizeof(h, HEADER_MAGIC_NO);
(void)Fseek(pkgs, offset, SEEK_SET);
fdSetContentLength(pkgs, newSize);
rc = headerWrite(pkgs, h, HEADER_MAGIC_NO);
fdSetContentLength(pkgs, -1);
if (rc)
rc = EIO;
h = headerFree(h);
}
}
#ifdef DYING
else {
DB * db = dbi->dbi_db;
if (db)
rc = db->put(db, &key, &data, 0);
rc = cvtdberr(dbi, "db->put", rc, _debug);
}
#else
else
rc = EINVAL;
#endif
return rc;
}
static int db1ccount(/*@unused@*/ dbiIndex dbi, /*@unused@*/ DBC * dbcursor,
/*@unused@*/ /*@out@*/ unsigned int * countp,
/*@unused@*/ unsigned int flags)
/*@*/
{
return EINVAL;
}
static int db1byteswapped(/*@unused@*/dbiIndex dbi)
/*@*/
{
return 0;
}
static int db1stat(/*@unused@*/ dbiIndex dbi, /*@unused@*/ unsigned int flags)
/*@*/
{
return EINVAL;
}
static int db1close(/*@only@*/ dbiIndex dbi, /*@unused@*/ unsigned int flags)
/*@globals rpmGlobalMacroContext,
fileSystem @*/
/*@modifies dbi, rpmGlobalMacroContext, fileSystem @*/
{
rpmdb rpmdb = dbi->dbi_rpmdb;
const char * base = db1basename(dbi->dbi_rpmtag);
const char * urlfn = rpmGenPath(rpmdb->db_root, rpmdb->db_home, base);
const char * fn;
int rc = 0;
(void) urlPath(urlfn, &fn);
/*@-branchstate@*/
if (dbi->dbi_db) {
if (dbi->dbi_rpmtag == RPMDBI_PACKAGES) {
FD_t pkgs = dbi->dbi_db;
rc = Fclose(pkgs);
}
#ifdef DYING
else {
DB * db = dbi->dbi_db;
rc = db->close(db);
rc = cvtdberr(dbi, "db->close", rc, _debug);
}
#else
else
rc = EINVAL;
#endif
dbi->dbi_db = NULL;
}
/*@=branchstate@*/
rpmMessage(RPMMESS_DEBUG, _("closed db file %s\n"), urlfn);
/* Remove temporary databases */
if (dbi->dbi_temporary) {
rpmMessage(RPMMESS_DEBUG, _("removed db file %s\n"), urlfn);
(void) unlink(fn);
}
dbi = db3Free(dbi);
base = _free(base);
urlfn = _free(urlfn);
return rc;
}
static int db1open(/*@keep@*/ rpmdb rpmdb, int rpmtag,
/*@out@*/ dbiIndex * dbip)
/*@globals rpmGlobalMacroContext,
fileSystem @*/
/*@modifies *dbip, rpmGlobalMacroContext, fileSystem @*/
{
/*@-nestedextern@*/
extern struct _dbiVec db1vec;
/*@=nestedextern@*/
const char * base = NULL;
const char * urlfn = NULL;
const char * fn = NULL;
dbiIndex dbi = NULL;
int rc = 0;
if (dbip)
*dbip = NULL;
if ((dbi = db3New(rpmdb, rpmtag)) == NULL)
return EFAULT;
dbi->dbi_api = DB_VERSION_MAJOR;
base = db1basename(rpmtag);
urlfn = rpmGenPath(rpmdb->db_root, rpmdb->db_home, base);
(void) urlPath(urlfn, &fn);
if (!(fn && *fn != '\0')) {
rpmError(RPMERR_DBOPEN, _("bad db file %s\n"), urlfn);
rc = EFAULT;
goto exit;
}
rpmMessage(RPMMESS_DEBUG, _("opening db file %s mode 0x%x\n"),
urlfn, dbi->dbi_mode);
if (dbi->dbi_rpmtag == RPMDBI_PACKAGES) {
FD_t pkgs;
pkgs = fadOpen(fn, dbi->dbi_mode, dbi->dbi_perms);
if (Ferror(pkgs)) {
rc = errno; /* XXX check errno validity */
goto exit;
}
/* XXX HACK: fcntl lock if db3 (DB_INIT_CDB | DB_INIT_LOCK) specified */
if (dbi->dbi_lockdbfd || (dbi->dbi_eflags & 0x30)) {
struct flock l;
l.l_whence = 0;
l.l_start = 0;
l.l_len = 0;
l.l_type = (dbi->dbi_mode & O_RDWR) ? F_WRLCK : F_RDLCK;
if (Fcntl(pkgs, F_SETLK, (void *) &l)) {
rc = errno; /* XXX check errno validity */
rpmError(RPMERR_FLOCK, _("cannot get %s lock on database\n"),
((dbi->dbi_mode & O_RDWR) ? _("exclusive") : _("shared")));
goto exit;
}
}
dbi->dbi_db = pkgs;
}
#ifdef DYING
else {
void * dbopeninfo = NULL;
int dbimode = dbi->dbi_mode;
if (dbi->dbi_temporary)
dbimode |= (O_CREAT | O_RDWR);
dbi->dbi_db = dbopen(fn, dbimode, dbi->dbi_perms,
db3_to_dbtype(dbi->dbi_type), dbopeninfo);
if (dbi->dbi_db == NULL) rc = errno;
}
#else
else
rc = EINVAL;
#endif
exit:
if (rc == 0 && dbi->dbi_db != NULL && dbip) {
dbi->dbi_vec = &db1vec;
if (dbip) *dbip = dbi;
} else
(void) db1close(dbi, 0);
base = _free(base);
urlfn = _free(urlfn);
return rc;
}
/*@=onlytrans@*/
/** \ingroup db1
*/
/*@-exportheadervar@*/
/*@observer@*/ /*@unchecked@*/
struct _dbiVec db1vec = {
DB_VERSION_MAJOR, DB_VERSION_MINOR, DB_VERSION_PATCH,
db1open, db1close, db1sync, db1copen, db1cclose, db1cdel, db1cget, db1cput,
db1ccount, db1byteswapped, db1stat
};
/*@=exportheadervar@*/
/*@=type@*/

View File

@ -23,11 +23,7 @@ typedef int int32_t;
/*@=redef@*/
#endif
#if defined(HAVE_DB4_DB_H)
#include <db4/db.h>
#elif defined(HAVE_DB3_DB_H)
#include <db3/db.h>
#endif
#include <db.h>
#include "rpmlib.h"
#include "rpmmacro.h"
@ -847,15 +843,9 @@ static int db3close(/*@only@*/ dbiIndex dbi, /*@unused@*/ unsigned int flags)
(dbfile ? dbfile : tagName(dbi->dbi_rpmtag)));
/*
* Depending on the DB version,
* the DB handle may not be accessed again after
* The DB handle may not be accessed again after
* DB->verify is called, regardless of its return.
*/
#if (DB_VERSION_MAJOR <= 3) || (DB_VERSION_MAJOR == 4 && DB_VERSION_MINOR <= 1)
xx = db->close(db, 0);
xx = cvtdberr(dbi, "db->close", xx, _debug);
if (rc == 0 && xx) rc = xx;
#endif
db = NULL;
dbf = _free(dbf);
}

View File

@ -15,11 +15,7 @@ typedef int int32_t;
/*@=redef@*/
#endif
#if defined(HAVE_DB4_DB_H)
#include <db4/db.h>
#elif defined(HAVE_DB3_DB_H)
#include <db3/db.h>
#endif
#include <db.h>
#include "rpmlib.h"
#include "rpmmacro.h"
@ -35,9 +31,6 @@ typedef int int32_t;
/*@access dbiIndex@*/
/*@access dbiIndexSet@*/
#if (DB_VERSION_MAJOR == 3) || (DB_VERSION_MAJOR == 4)
#define __USE_DB3 1
/*@-exportlocal -exportheadervar@*/
/*@unchecked@*/
struct _dbiIndex db3dbi;
@ -573,5 +566,3 @@ const char * prDbiOpenFlags(int dbflags, int print_dbenv_flags)
}
return buf;
}
#endif

View File

@ -1,523 +0,0 @@
/** \ingroup rpmio db1
* \file rpmdb/falloc.c
*
* The entire file space is thus divided into blocks with a "struct fablock"
* at the header of each. The size fields doubly link this block list.
*
* There is an additional free list weaved through the block list, which
* keeps new allocations fast.
*
* Much of this was inspired by Knuth vol 1.
*
*/
#include "system.h"
#include "rpmio_internal.h"
#include "rpmmessages.h"
#include "rpmerr.h"
#include "falloc.h"
#include "debug.h"
/** \ingroup db1
*/
#define FA_MAGIC 0x02050920
struct faFileHeader {
unsigned int magic;
unsigned int firstFree;
};
struct faHeader {
unsigned int size;
unsigned int freeNext; /* offset of the next free block, 0 if none */
unsigned int freePrev;
unsigned int isFree;
/* note that the u16's appear last for alignment/space reasons */
};
struct faFooter {
unsigned int size;
unsigned int isFree;
} ;
/* =============================================================== */
/*@-nullassign@*/
static struct FDIO_s fadio_s = {
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
fadOpen, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL
};
/*@=nullassign@*/
FDIO_t fadio = /*@-compmempass@*/ &fadio_s /*@=compmempass@*/ ;
/* =============================================================== */
/**
* pread(2) clone.
*/
static
ssize_t Pread(FD_t fd, void * buf, size_t count, _libio_off_t offset)
/*@globals fileSystem @*/
/*@modifies fd, *buf, fileSystem @*/
{
if (Fseek(fd, offset, SEEK_SET) < 0)
return -1;
/*@-sizeoftype@*/
return Fread(buf, sizeof(char), count, fd);
/*@=sizeoftype@*/
}
/**
* pwrite(2) clone.
*/
static
ssize_t Pwrite(FD_t fd, const void * buf, size_t count, _libio_off_t offset)
/*@globals fileSystem @*/
/*@modifies fd, fileSystem @*/
{
if (Fseek(fd, offset, SEEK_SET) < 0)
return -1;
/*@-sizeoftype@*/
return Fwrite(buf, sizeof(char), count, fd);
/*@=sizeoftype@*/
}
/* flags are the same as for open(2) - NULL returned on error */
FD_t fadOpen(const char * path, int flags, mode_t perms)
{
struct faFileHeader newHdr;
FD_t fd;
if (flags & O_WRONLY)
return NULL;
/*@-type@*/ /* FIX: cast? */
fd = ufdio->_open(path, flags, perms);
/*@=type@*/
if (Ferror(fd))
/* XXX Fstrerror */
return NULL;
/*@-modobserver -observertrans -mods @*/
memcpy(fadio, fdio, sizeof(*fadio));
fadio->_open = fadOpen;
/*@=modobserver =observertrans =mods @*/
fdSetIo(fd, fadio);
fadSetFirstFree(fd, 0);
fadSetFileSize(fd, Fseek(fd, 0, SEEK_END));
/* is this file brand new? */
if (fadGetFileSize(fd) == 0) {
newHdr.magic = FA_MAGIC;
newHdr.firstFree = 0;
/*@-sizeoftype@*/
if (Fwrite(&newHdr, sizeof(char), sizeof(newHdr), fd) != sizeof(newHdr)) {
(void) Fclose(fd);
return NULL;
}
/*@=sizeoftype@*/
fadSetFirstFree(fd, 0);
fadSetFileSize(fd, sizeof(newHdr));
} else {
memset(&newHdr, 0, sizeof(newHdr));
if (Pread(fd, &newHdr, sizeof(newHdr), 0) != sizeof(newHdr)) {
(void) Fclose(fd);
return NULL;
}
if (newHdr.magic != FA_MAGIC) {
(void) Fclose(fd);
return NULL;
}
fadSetFirstFree(fd, newHdr.firstFree);
fadSetFileSize(fd, Fseek(fd, 0, SEEK_END));
if (fadGetFileSize(fd) < 0) {
(void) Fclose(fd);
return NULL;
}
}
/*@-refcounttrans@*/ return fd /*@=refcounttrans@*/ ;
}
/* returns 0 on failure */
unsigned int fadAlloc(FD_t fd, unsigned int size)
{
unsigned int nextFreeBlock;
unsigned int newBlockOffset;
unsigned int footerOffset;
int failed = 0;
struct faFileHeader faHeader;
struct faHeader header, origHeader;
struct faHeader * restoreHeader = NULL;
struct faHeader nextFreeHeader, origNextFreeHeader;
struct faHeader * restoreNextHeader = NULL;
struct faHeader prevFreeHeader, origPrevFreeHeader;
struct faHeader * restorePrevHeader = NULL;
struct faFooter footer, origFooter;
struct faFooter * restoreFooter = NULL;
int updateHeader = 0;
memset(&header, 0, sizeof(header));
/* our internal idea of size includes overhead */
/*@-sizeoftype@*/
size += sizeof(struct faHeader) + sizeof(struct faFooter);
/*@=sizeoftype@*/
/* Make sure they are allocing multiples of 64 bytes. It'll keep
things less fragmented that way */
(size % 64) ? size += (64 - (size % 64)) : 0;
/* find a block via first fit - see Knuth vol 1 for why */
/* XXX this could be optimized a bit still */
nextFreeBlock = fadGetFirstFree(fd);
newBlockOffset = 0;
while (nextFreeBlock && !newBlockOffset) {
if (Pread(fd, &header, sizeof(header), nextFreeBlock) != sizeof(header)) return 0;
/* XXX W2DO? exit(EXIT_FAILURE) forces the user to discover rpm --rebuilddb */
if (!header.isFree) {
rpmError(RPMERR_FREELIST, _("free list corrupt (%u)- please run\n"
"\t\"rpm --rebuilddb\"\n"
"More information is available from http://www.rpm.org "
"or the rpm-list@redhat.com mailing list\n"
"if \"rpm --rebuilddb\" fails to correct the problem.\n"),
nextFreeBlock);
exit(EXIT_FAILURE);
/*@notreached@*/
}
if (header.size >= size) {
newBlockOffset = nextFreeBlock;
} else {
nextFreeBlock = header.freeNext;
}
}
if (newBlockOffset) {
/* header should still be good from the search */
origHeader = header;
footerOffset = newBlockOffset + header.size - sizeof(footer);
if (Pread(fd, &footer, sizeof(footer), footerOffset) != sizeof(footer))
return 0;
origFooter = footer;
/* should we split this block into two? */
/* XXX implement fragment creation here */
footer.isFree = header.isFree = 0;
/* remove it from the free list before */
if (newBlockOffset == fadGetFirstFree(fd)) {
faHeader.magic = FA_MAGIC;
faHeader.firstFree = header.freeNext;
fadSetFirstFree(fd, header.freeNext);
updateHeader = 1;
} else {
if (Pread(fd, &prevFreeHeader, sizeof(prevFreeHeader),
header.freePrev) != sizeof(prevFreeHeader))
return 0;
origPrevFreeHeader = prevFreeHeader;
prevFreeHeader.freeNext = header.freeNext;
}
/* and after */
if (header.freeNext) {
if (Pread(fd, &nextFreeHeader, sizeof(nextFreeHeader),
header.freeNext) != sizeof(nextFreeHeader))
return 0;
origNextFreeHeader = nextFreeHeader;
nextFreeHeader.freePrev = header.freePrev;
}
/* if any of these fail, try and restore everything before leaving */
if (updateHeader) {
if (Pwrite(fd, &faHeader, sizeof(faHeader), 0) !=
sizeof(faHeader))
return 0;
} else {
if (Pwrite(fd, &prevFreeHeader, sizeof(prevFreeHeader),
header.freePrev) != sizeof(prevFreeHeader))
return 0;
restorePrevHeader = &origPrevFreeHeader;
}
if (header.freeNext) {
if (Pwrite(fd, &nextFreeHeader, sizeof(nextFreeHeader),
header.freeNext) != sizeof(nextFreeHeader))
return 0;
restoreNextHeader = &origNextFreeHeader;
}
if (!failed) {
if (Pwrite(fd, &header, sizeof(header), newBlockOffset) !=
sizeof(header)) {
failed = 1;
restoreHeader = &origHeader;
}
}
if (!failed) {
if (Pwrite(fd, &footer, sizeof(footer),
footerOffset) != sizeof(footer)) {
failed = 1;
restoreFooter = &origFooter;
}
}
if (failed) {
if (updateHeader) {
faHeader.firstFree = newBlockOffset;
fadSetFirstFree(fd, newBlockOffset);
(void)Pwrite(fd, &faHeader, sizeof(faHeader), 0);
}
if (restorePrevHeader)
(void)Pwrite(fd, restorePrevHeader, sizeof(*restorePrevHeader),
header.freePrev);
if (restoreNextHeader)
(void)Pwrite(fd, restoreNextHeader, sizeof(*restoreNextHeader),
header.freeNext);
if (restoreHeader)
(void)Pwrite(fd, restoreHeader, sizeof(header),
newBlockOffset);
if (restoreFooter)
(void)Pwrite(fd, restoreFooter, sizeof(footer),
footerOffset);
return 0;
}
} else {
char * space;
/* make a new block */
newBlockOffset = fadGetFileSize(fd);
footerOffset = newBlockOffset + size - sizeof(footer);
space = alloca(size);
if (space == NULL) return 0;
memset(space, 0, size);
footer.isFree = header.isFree = 0;
footer.size = header.size = size;
header.freePrev = header.freeNext = 0;
/* reserve all space up front */
/* XXX TODO: check max. no. of bytes to write */
if (Pwrite(fd, space, size, newBlockOffset) != size)
return 0;
if (Pwrite(fd, &header, sizeof(header), newBlockOffset) != sizeof(header))
return 0;
if (Pwrite(fd, &footer, sizeof(footer), footerOffset) != sizeof(footer))
return 0;
fadSetFileSize(fd, fadGetFileSize(fd) + size);
}
return newBlockOffset + sizeof(header);
}
void fadFree(FD_t fd, unsigned int offset)
{
struct faHeader header;
struct faFooter footer;
int footerOffset;
int prevFreeOffset, nextFreeOffset;
struct faHeader prevFreeHeader, nextFreeHeader;
struct faFileHeader faHeader;
/* any errors cause this to die, and thus result in lost space in the
database. which is at least better then corruption */
offset -= sizeof(header);
/* find out where in the (sorted) free list to put this */
prevFreeOffset = fadGetFirstFree(fd);
if (!prevFreeOffset || (prevFreeOffset > offset)) {
nextFreeOffset = fadGetFirstFree(fd);
prevFreeOffset = 0;
} else {
memset(&prevFreeHeader, 0, sizeof(prevFreeHeader));
if (Pread(fd, &prevFreeHeader, sizeof(prevFreeHeader),
prevFreeOffset) != sizeof(prevFreeHeader))
return;
while (prevFreeHeader.freeNext && prevFreeHeader.freeNext < offset) {
prevFreeOffset = prevFreeHeader.freeNext;
if (Pread(fd, &prevFreeHeader, sizeof(prevFreeHeader),
prevFreeOffset) != sizeof(prevFreeHeader))
return;
}
nextFreeOffset = prevFreeHeader.freeNext;
}
if (nextFreeOffset) {
memset(&nextFreeHeader, 0, sizeof(nextFreeHeader));
if (Pread(fd, &nextFreeHeader, sizeof(nextFreeHeader),
nextFreeOffset) != sizeof(nextFreeHeader))
return;
}
memset(&header, 0, sizeof(header));
if (Pread(fd, &header, sizeof(header), offset) != sizeof(header))
return;
footerOffset = offset + header.size - sizeof(footer);
memset(&footer, 0, sizeof(footer));
if (Pread(fd, &footer, sizeof(footer), footerOffset) != sizeof(footer))
return;
header.isFree = 1;
header.freeNext = nextFreeOffset;
header.freePrev = prevFreeOffset;
footer.isFree = 1;
/* XXX TODO: set max. no. of bytes to write */
(void)Pwrite(fd, &header, sizeof(header), offset);
(void)Pwrite(fd, &footer, sizeof(footer), footerOffset);
if (nextFreeOffset) {
nextFreeHeader.freePrev = offset;
if (Pwrite(fd, &nextFreeHeader, sizeof(nextFreeHeader),
nextFreeOffset) != sizeof(nextFreeHeader))
return;
}
if (prevFreeOffset) {
prevFreeHeader.freeNext = offset;
if (Pwrite(fd, &prevFreeHeader, sizeof(prevFreeHeader),
prevFreeOffset) != sizeof(prevFreeHeader))
return;
} else {
fadSetFirstFree(fd, offset);
faHeader.magic = FA_MAGIC;
faHeader.firstFree = fadGetFirstFree(fd);
/* XXX TODO: set max. no. of bytes to write */
if (Pwrite(fd, &faHeader, sizeof(faHeader), 0) != sizeof(faHeader))
return;
}
}
static int fadSanity(FD_t fd, int offset, const struct faHeader * fh, int printit)
/*@*/
{
int rc = 0;
/*@-sizeoftype@*/
/* Check size range and alignment. */
if (!(fh->size > 0 && fh->size <= 0x00200000 && (fh->size & 0x3f) == 0))
rc |= 0x1;
/* Check forward link range, alignment and offset. */
if (fh->freeNext &&
!( fh->freeNext > sizeof(struct faFileHeader) &&
fh->freeNext < fadGetFileSize(fd) &&
(fh->freeNext & 0x3f) == sizeof(struct faFileHeader)) )
rc |= 0x2;
/* Check backward link range, alignment and offset. */
if (fh->freePrev &&
!( fh->freePrev > sizeof(struct faFileHeader) &&
fh->freePrev < fadGetFileSize(fd) &&
(fh->freePrev & 0x3f) == sizeof(struct faFileHeader)) )
rc |= 0x4;
/*@=sizeoftype@*/
/* Check that only the isFree bit is (possibly) set. */
if (fh->isFree & ~1)
rc |= 0x8;
if (printit && rc) {
rpmMessage(RPMMESS_DEBUG,
"offset %d(0x%08x) rc %d: size 0x%08x next %d(0x%08x) prev %d(0x%08x) isFree 0x%08x\n",
offset, (unsigned) offset, rc,
(unsigned) fh->size,
(int) fh->freeNext, fh->freeNext,
(int) fh->freePrev, fh->freePrev,
(unsigned) fh->isFree);
}
return rc;
}
int fadFirstOffset(FD_t fd)
{
return fadNextOffset(fd, 0);
}
int fadNextOffset(FD_t fd, unsigned int lastoff)
{
struct faHeader header;
int offset;
/*@-sizeoftype@*/
offset = (lastoff)
? (lastoff - sizeof(header))
: sizeof(struct faFileHeader);
/*@=sizeoftype@*/
if (offset >= fadGetFileSize(fd))
return 0;
memset(&header, 0, sizeof(header));
if (Pread(fd, &header, sizeof(header), offset) != sizeof(header))
return 0;
if (!lastoff && header.isFree == 0)
return (offset + sizeof(header));
/*
* XXX Try to reconnect at next record found. This isn't perfect
* XXX but handles many common db1 corruption problems.
*/
if (fadSanity(fd, offset, &header, 0)) {
struct faHeader myheader;
int o = offset;
memset(&myheader, 0, sizeof(myheader));
do {
o += 0x40; /* XXX allocation chunks are padded to 64b */
if (o >= fadGetFileSize(fd))
return 0;
if (Pread(fd, &myheader, sizeof(myheader), o) != sizeof(header))
return 0;
} while (fadSanity(fd, o, &myheader, 0));
return (o + sizeof(header));
}
do {
offset += header.size;
if (offset >= fadGetFileSize(fd))
return 0;
if (Pread(fd, &header, sizeof(header), offset) != sizeof(header))
return 0;
} while (header.isFree == 1);
/* Sanity check this to make sure we're not going in loops */
offset += sizeof(header);
if (offset <= lastoff)
return 0; /* XXX used to return -1 */
return offset;
}

View File

@ -1,82 +0,0 @@
#ifndef H_FALLOC
#define H_FALLOC
/** \ingroup db1
* \file rpmdb/falloc.h
* File space allocation routines.
*
* Best fit allocation is used, free blocks are compacted. Minimal
* fragmentation is more important then speed. This uses 32 bit
* offsets on all platforms and should be byte order independent.
*/
/*@access FD_t@*/
#ifdef __cplusplus
extern "C" {
#endif
/*@unused@*/ static inline long int fadGetFileSize(FD_t fd) /*@*/ {
return fd->fileSize;
}
/*@unused@*/ static inline void fadSetFileSize(FD_t fd, long int fileSize)
/*@modifies fd @*/
{
fd->fileSize = fileSize;
}
/*@unused@*/ static inline unsigned int fadGetFirstFree(FD_t fd) /*@*/ {
return fd->firstFree;
}
/*@unused@*/ static inline void fadSetFirstFree(FD_t fd, unsigned int firstFree)
/*@modifies fd @*/
{
fd->firstFree = firstFree;
}
/** \ingroup db1
*/
/*@null@*/ FD_t fadOpen(const char * path, int flags, mode_t perms)
/*@globals fileSystem @*/
/*@modifies fileSystem @*/;
/** \ingroup db1
* @param fd file handle
* @param size
* @return 0 on failure
*/
unsigned int fadAlloc(FD_t fd, unsigned int size)
/*@globals fileSystem @*/
/*@modifies fd, fileSystem @*/;
/** \ingroup db1
* @param fd file handle
* @param offset
*/
void fadFree(FD_t fd, unsigned int offset)
/*@globals fileSystem @*/
/*@modifies fd, fileSystem @*/;
/** \ingroup db1
* @param fd file handle
*/
int fadFirstOffset(FD_t fd)
/*@globals fileSystem @*/
/*@modifies fd, fileSystem @*/;
/** \ingroup db1
* @param fd file handle
* @param lastoff
* @return next offset, 0 to terminate
*/
int fadNextOffset(FD_t fd, unsigned int lastoff)
/*@globals fileSystem @*/
/*@modifies fd, fileSystem @*/;
#ifdef __cplusplus
}
#endif
#endif /* H_FALLOC */

View File

@ -173,29 +173,12 @@ static void dbiTagsInit(void)
}
/*@-redecl@*/
#if USE_DB1
/*@unchecked@*/
extern struct _dbiVec db1vec;
#define DB1vec &db1vec
#else
#define DB1vec NULL
#endif
#if USE_DB2
/*@unchecked@*/
extern struct _dbiVec db2vec;
#define DB2vec &db2vec
#else
#define DB2vec NULL
#endif
#if USE_DB3
/*@unchecked@*/
extern struct _dbiVec db3vec;
#define DB3vec &db3vec
#else
#define DB3vec NULL
#endif
/*@=redecl@*/
/*@-nullassign@*/
@ -1058,32 +1041,6 @@ static int openDatabase(/*@null@*/ const char * prefix,
if (minimal)
goto exit;
/*@switchbreak@*/ break;
case RPMTAG_BASENAMES:
{ void * keyp = NULL;
DBC * dbcursor;
/* We used to store the fileindexes as complete paths, rather then
plain basenames. Let's see which version we are... */
/*
* XXX FIXME: db->fileindex can be NULL under pathological (e.g. mixed
* XXX db1/db2 linkage) conditions.
*/
if (justCheck)
/*@switchbreak@*/ break;
dbcursor = NULL;
xx = dbiCopen(dbi, &dbcursor, 0);
xx = dbiGet(dbi, dbcursor, &keyp, NULL, NULL, NULL, gflags);
if (xx == 0) {
const char * akey = keyp;
if (akey && strchr(akey, '/')) {
rpmError(RPMERR_OLDDB, _("old format database is present; "
"use --rebuilddb to generate a new format database\n"));
rc |= 1;
}
}
xx = dbiCclose(dbi, dbcursor, 0);
dbcursor = NULL;
} /*@switchbreak@*/ break;
default:
/*@switchbreak@*/ break;
}
@ -2102,17 +2059,10 @@ top:
keylen = mi->mi_keylen;
rc = dbiGet(dbi, mi->mi_dbc, &keyp, &keylen, &uh, &uhlen, gflags);
if (dbi->dbi_api == 1 && dbi->dbi_rpmtag == RPMDBI_PACKAGES && rc == EFAULT) {
rpmError(RPMERR_INTERNAL,
_("record number %u in database is bad -- skipping.\n"), dbi->dbi_lastoffset);
if (keyp && dbi->dbi_lastoffset)
memcpy(&mi->mi_offset, keyp, sizeof(mi->mi_offset));
continue;
}
/*
* If we got the next key, save the header instance number.
* For db1 Packages (db1->dbi_lastoffset != 0), always copy.
*
* For db3 Packages, instance 0 (i.e. mi->mi_setx == 0) is the
* largest header instance in the database, and should be
* skipped.
@ -3102,29 +3052,6 @@ int rpmdbFindFpList(rpmdb db, fingerPrint * fpList, dbiIndexSet * matchList,
}
char * db1basename (int rpmtag)
{
char * base = NULL;
/*@-branchstate@*/
switch (rpmtag) {
case RPMDBI_PACKAGES: base = "packages.rpm"; break;
case RPMTAG_NAME: base = "nameindex.rpm"; break;
case RPMTAG_BASENAMES: base = "fileindex.rpm"; break;
case RPMTAG_GROUP: base = "groupindex.rpm"; break;
case RPMTAG_REQUIRENAME: base = "requiredby.rpm"; break;
case RPMTAG_PROVIDENAME: base = "providesindex.rpm"; break;
case RPMTAG_CONFLICTNAME: base = "conflictsindex.rpm"; break;
case RPMTAG_TRIGGERNAME: base = "triggerindex.rpm"; break;
default:
{ const char * tn = tagName(rpmtag);
base = alloca( strlen(tn) + sizeof(".idx") + 1 );
(void) stpcpy( stpcpy(base, tn), ".idx");
} break;
}
/*@=branchstate@*/
return xstrdup(base);
}
/**
* Check if file esists using stat(2).
* @param urlfn file name (may be URL)
@ -3207,16 +3134,6 @@ static int rpmdbRemoveDatabase(const char * prefix,
case 2:
case 1:
case 0:
if (dbiTags != NULL)
for (i = 0; i < dbiTagsMax; i++) {
const char * base = db1basename(dbiTags[i]);
sprintf(filename, "%s/%s/%s", prefix, dbpath, base);
(void)rpmCleanPath(filename);
if (!rpmioFileExists(filename))
continue;
xx = unlink(filename);
base = _free(base);
}
break;
}
@ -3311,34 +3228,6 @@ static int rpmdbMoveDatabase(const char * prefix,
case 2:
case 1:
case 0:
if (dbiTags != NULL)
for (i = 0; i < dbiTagsMax; i++) {
const char * base;
int rpmtag;
/* Filter out temporary databases */
switch ((rpmtag = dbiTags[i])) {
case RPMDBI_AVAILABLE:
case RPMDBI_ADDED:
case RPMDBI_REMOVED:
case RPMDBI_DEPENDS:
continue;
/*@notreached@*/ /*@switchbreak@*/ break;
default:
/*@switchbreak@*/ break;
}
base = db1basename(rpmtag);
sprintf(ofilename, "%s/%s/%s", prefix, olddbpath, base);
(void)rpmCleanPath(ofilename);
if (!rpmioFileExists(ofilename))
continue;
sprintf(nfilename, "%s/%s/%s", prefix, newdbpath, base);
(void)rpmCleanPath(nfilename);
if ((xx = Rename(ofilename, nfilename)) != 0)
rc = 1;
base = _free(base);
}
break;
}
if (rc || _olddbapi == _newdbapi)
@ -3346,15 +3235,6 @@ static int rpmdbMoveDatabase(const char * prefix,
rc = rpmdbRemoveDatabase(prefix, newdbpath, _newdbapi);
/* Remove /etc/rpm/macros.db1 configuration file if db3 rebuilt. */
if (rc == 0 && _newdbapi == 1 && _olddbapi == 3) {
const char * mdb1 = "/etc/rpm/macros.db1";
struct stat st;
if (!stat(mdb1, &st) && S_ISREG(st.st_mode) && !unlink(mdb1))
rpmMessage(RPMMESS_DEBUG,
_("removing %s after successful db3 rebuild.\n"), mdb1);
}
return rc;
}

View File

@ -510,14 +510,6 @@ int dbiSync (dbiIndex dbi, unsigned int flags)
*/
int dbiByteSwapped(dbiIndex dbi)
/*@*/;
/** \ingroup db1
* Return base file name for db1 database (legacy).
* @param rpmtag rpm tag
* @return base file name of db1 database
*/
char * db1basename(int rpmtag)
/*@*/;
/*@=exportlocal@*/
/** \ingroup rpmdb

View File

@ -420,7 +420,7 @@ buildarch_compat: ia64: noarch
buildarch_compat: s390: noarch
buildarch_compat: s390x: noarch
macrofiles: @RPMCONFIGDIR@/macros:@RPMCONFIGDIR@/%{_target}/macros:@RPMCONFIGDIR@/macros.d/*:@SYSCONFIGDIR@/macros.specspo:@SYSCONFIGDIR@/macros.db1:@SYSCONFIGDIR@/macros.cdb:@SYSCONFIGDIR@/macros:@SYSCONFIGDIR@/%{_target}/macros:@SYSCONFIGDIR@/macros.d/*:~/.rpmmacros
macrofiles: @RPMCONFIGDIR@/macros:@RPMCONFIGDIR@/%{_target}/macros:@RPMCONFIGDIR@/macros.d/*:@SYSCONFIGDIR@/macros.specspo:@SYSCONFIGDIR@/macros.cdb:@SYSCONFIGDIR@/macros:@SYSCONFIGDIR@/%{_target}/macros:@SYSCONFIGDIR@/macros.d/*:~/.rpmmacros
# \endverbatim
#*/

View File

@ -9,7 +9,7 @@ EXTRA_DIST = \
brp-adjust_libraries brp-alt brp-bytecompile_python \
brp-cleanup brp-compress brp-fix-perms brp-fixup brp-strip brp-verify_elf \
compress_files check-files convertrpmrc.sh cross-build \
delayed_rebuilddb find-lang find-prov.pl find-req.pl \
find-lang find-prov.pl find-req.pl \
cpanflute cpanflute2 Specfile.pm find-provides.perl find-requires.perl \
fixup-binconfig fixup-pkgconfig fixup-libtool fixup-libraries \
get_magic.pl getpo.sh http.req \
@ -40,7 +40,7 @@ config_SCRIPTS = \
brp-adjust_libraries brp-alt brp-bytecompile_python \
brp-cleanup brp-compress brp-fix-perms brp-fixup brp-strip brp-verify_elf \
compress_files check-files convertrpmrc.sh cross-build \
delayed_rebuilddb find-lang find-prov.pl find-req.pl \
find-lang find-prov.pl find-req.pl \
cpanflute cpanflute2 Specfile.pm find-provides.perl find-requires.perl \
fixup-binconfig fixup-pkgconfig fixup-libtool fixup-libraries \
get_magic.pl getpo.sh http.req \

View File

@ -1,4 +0,0 @@
#!/bin/sh -e
rpmdb -v --rebuilddb &&
rm -f /etc/rpm/macros.db1