#ifndef H_RPMDB #define H_RPMDB /*@-bounds@*/ /** \ingroup rpmdb dbi db1 db3 * \file rpmdb/rpmdb.h * Access RPM indices using Berkeley DB interface(s). */ #include #include "rpmlib.h" #include "rpmsw.h" #include "db.h" /*@-exportlocal@*/ /*@unchecked@*/ extern int _rpmdb_debug; /*@=exportlocal@*/ #ifdef NOTYET /** \ingroup rpmdb * Database of headers and tag value indices. */ typedef /*@abstract@*/ /*@refcounted@*/ struct rpmdb_s * rpmdb; /** \ingroup rpmdb * Database iterator. */ typedef /*@abstract@*/ struct _rpmdbMatchIterator * rpmdbMatchIterator; #endif /** * Tag value pattern match mode. */ typedef enum rpmMireMode_e { RPMMIRE_DEFAULT = 0, /*!< regex with \., .* and ^...$ added */ RPMMIRE_STRCMP = 1, /*!< strings using strcmp(3) */ RPMMIRE_REGEX = 2, /*!< regex(7) patterns through regcomp(3) */ RPMMIRE_GLOB = 3 /*!< glob(7) patterns through fnmatch(3) */ } rpmMireMode; /** */ typedef /*@abstract@*/ struct _dbiIndexItem * dbiIndexItem; /** \ingroup rpmdb * A single element (i.e. inverted list from tag values) of a database. */ typedef /*@abstract@*/ struct _dbiIndexSet * dbiIndexSet; /** */ typedef /*@abstract@*/ struct _dbiIndex * dbiIndex; /* this will break if sizeof(int) != 4 */ /** \ingroup dbi * A single item from an index database (i.e. the "data returned"). * Note: In rpm-3.0.4 and earlier, this structure was passed by value, * and was identical to the "data saved" structure below. */ struct _dbiIndexItem { unsigned int hdrNum; /*!< header instance in db */ unsigned int tagNum; /*!< tag index in header */ unsigned int fpNum; /*!< finger print index */ }; /** \ingroup dbi * Items retrieved from the index database. */ struct _dbiIndexSet { /*@owned@*/ struct _dbiIndexItem * recs; /*!< array of records */ int count; /*!< number of records */ }; /** \ingroup dbi * Private methods for accessing an index database. */ struct _dbiVec { int dbv_major; /*!< Berkeley db version major */ int dbv_minor; /*!< Berkeley db version minor */ int dbv_patch; /*!< Berkeley db version patch */ /** \ingroup dbi * Return handle for an index database. * @param rpmdb rpm database * @param rpmtag rpm tag * @return 0 on success */ int (*open) (rpmdb rpmdb, rpmTag rpmtag, /*@out@*/ dbiIndex * dbip) /*@globals fileSystem @*/ /*@modifies *dbip, fileSystem @*/; /** \ingroup dbi * Close index database, and destroy database handle. * @param dbi index database handle * @param flags (unused) * @return 0 on success */ int (*close) (/*@only@*/ dbiIndex dbi, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, fileSystem @*/; /** \ingroup dbi * Flush pending operations to disk. * @param dbi index database handle * @param flags (unused) * @return 0 on success */ int (*sync) (dbiIndex dbi, unsigned int flags) /*@globals fileSystem @*/ /*@modifies fileSystem @*/; /** \ingroup dbi * Associate secondary database with primary. * @param dbi index database handle * @param dbisecondary secondary index database handle * @param callback create secondary key from primary (NULL if DB_RDONLY) * @param flags DB_CREATE or 0 * @return 0 on success */ int (*associate) (dbiIndex dbi, dbiIndex dbisecondary, int (*callback) (DB *, const DBT *, const DBT *, DBT *), unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, fileSystem @*/; /** \ingroup dbi * Return join cursor for list of cursors. * @param dbi index database handle * @param curslist NULL terminated list of database cursors * @retval dbcp address of join database cursor * @param flags DB_JOIN_NOSORT or 0 * @return 0 on success */ int (*join) (dbiIndex dbi, DBC ** curslist, /*@out@*/ DBC ** dbcp, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, *dbcp, fileSystem @*/; /** \ingroup dbi * Open database cursor. * @param dbi index database handle * @param txnid database transaction handle * @retval dbcp address of new database cursor * @param dbiflags DB_WRITECURSOR or 0 * @return 0 on success */ int (*copen) (dbiIndex dbi, /*@null@*/ DB_TXN * txnid, /*@out@*/ DBC ** dbcp, unsigned int dbiflags) /*@globals fileSystem @*/ /*@modifies dbi, *txnid, *dbcp, fileSystem @*/; /** \ingroup dbi * Close database cursor. * @param dbi index database handle * @param dbcursor database cursor * @param flags (unused) * @return 0 on success */ int (*cclose) (dbiIndex dbi, /*@only@*/ DBC * dbcursor, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, *dbcursor, fileSystem @*/; /** \ingroup dbi * Duplicate a database cursor. * @param dbi index database handle * @param dbcursor database cursor * @retval dbcp address of new database cursor * @param flags DB_POSITION for same position, 0 for uninitialized * @return 0 on success */ int (*cdup) (dbiIndex dbi, DBC * dbcursor, /*@out@*/ DBC ** dbcp, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, *dbcp, fileSystem @*/; /** \ingroup dbi * Delete (key,data) pair(s) using db->del or dbcursor->c_del. * @param dbi index database handle * @param dbcursor database cursor (NULL will use db->del) * @param key delete key value/length/flags * @param data delete data value/length/flags * @param flags (unused) * @return 0 on success */ int (*cdel) (dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * data, unsigned int flags) /*@globals fileSystem @*/ /*@modifies *dbcursor, fileSystem @*/; /** \ingroup dbi * Retrieve (key,data) pair using db->get or dbcursor->c_get. * @param dbi index database handle * @param dbcursor database cursor (NULL will use db->get) * @param key retrieve key value/length/flags * @param data retrieve data value/length/flags * @param flags (unused) * @return 0 on success */ int (*cget) (dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * data, unsigned int flags) /*@globals fileSystem @*/ /*@modifies *dbcursor, *key, *data, fileSystem @*/; /** \ingroup dbi * Retrieve (key,data) pair using dbcursor->c_pget. * @param dbi index database handle * @param dbcursor database cursor * @param key secondary retrieve key value/length/flags * @param pkey primary retrieve key value/length/flags * @param data primary retrieve data value/length/flags * @param flags DB_NEXT, DB_SET, or 0 * @return 0 on success */ int (*cpget) (dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * pkey, DBT * data, unsigned int flags) /*@globals fileSystem @*/ /*@modifies *dbcursor, *key, *pkey, *data, fileSystem @*/; /** \ingroup dbi * Store (key,data) pair using db->put or dbcursor->c_put. * @param dbi index database handle * @param dbcursor database cursor (NULL will use db->put) * @param key store key value/length/flags * @param data store data value/length/flags * @param flags (unused) * @return 0 on success */ int (*cput) (dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * data, unsigned int flags) /*@globals fileSystem @*/ /*@modifies *dbcursor, fileSystem @*/; /** \ingroup dbi * Retrieve count of (possible) duplicate items using dbcursor->c_count. * @param dbi index database handle * @param dbcursor database cursor * @param countp address of count * @param flags (unused) * @return 0 on success */ int (*ccount) (dbiIndex dbi, DBC * dbcursor, /*@out@*/ unsigned int * countp, unsigned int flags) /*@globals fileSystem @*/ /*@modifies *dbcursor, fileSystem @*/; /** \ingroup dbi * Is database byte swapped? * @param dbi index database handle * @return 0 no */ int (*byteswapped) (dbiIndex dbi) /*@globals fileSystem @*/ /*@modifies fileSystem @*/; /** \ingroup dbi * Save statistics in database handle. * @param dbi index database handle * @param flags retrieve statistics that don't require traversal? * @return 0 on success */ int (*stat) (dbiIndex dbi, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, fileSystem @*/; }; /** \ingroup dbi * Describes an index database (implemented on Berkeley db3 functionality). */ struct _dbiIndex { /*@null@*/ const char * dbi_root; /*!< chroot(2) component of path */ /*@null@*/ const char * dbi_home; /*!< directory component of path */ /*@null@*/ const char * dbi_file; /*!< file component of path */ /*@null@*/ const char * dbi_subfile; /*@null@*/ const char * dbi_tmpdir; /*!< temporary directory */ int dbi_ecflags; /*!< db_env_create flags */ int dbi_cflags; /*!< db_create flags */ int dbi_oeflags; /*!< common (db,dbenv}->open flags */ int dbi_eflags; /*!< dbenv->open flags */ int dbi_oflags; /*!< db->open flags */ int dbi_tflags; /*!< dbenv->txn_begin flags */ int dbi_type; /*!< db index type */ unsigned dbi_mode; /*!< mode to use on open */ int dbi_perms; /*!< file permission to use on open */ long dbi_shmkey; /*!< shared memory base key */ int dbi_api; /*!< Berkeley API type */ int dbi_verify_on_close; int dbi_use_dbenv; /*!< use db environment? */ int dbi_permit_dups; /*!< permit duplicate entries? */ int dbi_no_fsync; /*!< no-op fsync for db */ int dbi_no_dbsync; /*!< don't call dbiSync */ int dbi_lockdbfd; /*!< do fcntl lock on db fd */ int dbi_temporary; /*!< non-persistent */ int dbi_debug; int dbi_byteswapped; /*@null@*/ char * dbi_host; unsigned long dbi_cl_timeout; unsigned long dbi_sv_timeout; /* dbenv parameters */ int dbi_lorder; /*@unused@*/ /* XXX db-4.3.14 adds dbenv as 1st arg. */ void (*db_errcall) (void * dbenv, const char *db_errpfx, char *buffer) /*@globals fileSystem @*/ /*@modifies fileSystem @*/; /*@unused@*/ /*@shared@*/ FILE * dbi_errfile; const char * dbi_errpfx; int dbi_verbose; int dbi_region_init; int dbi_tas_spins; /* mpool sub-system parameters */ int dbi_mmapsize; /*!< (10Mb) */ int dbi_cachesize; /*!< (128Kb) */ /* lock sub-system parameters */ unsigned int dbi_lk_max; unsigned int dbi_lk_detect; /*@unused@*/ int dbi_lk_nmodes; /*@unused@*/ unsigned char * dbi_lk_conflicts; /* log sub-system parameters */ unsigned int dbi_lg_max; unsigned int dbi_lg_bsize; /* transaction sub-system parameters */ unsigned int dbi_tx_max; #if 0 int (*dbi_tx_recover) (DB_ENV *dbenv, DBT *log_rec, DB_LSN *lsnp, int redo, void *info) /*@globals fileSystem @*/ /*@modifies fileSystem @*/; #endif /* dbinfo parameters */ int dbi_pagesize; /*!< (fs blksize) */ /*@unused@*/ /*@null@*/ void * (*dbi_malloc) (size_t nbytes) /*@*/; /* hash access parameters */ unsigned int dbi_h_ffactor; /*!< */ unsigned int (*dbi_h_hash_fcn) (DB *, const void *bytes, unsigned int length) /*@*/; unsigned int dbi_h_nelem; /*!< */ unsigned int dbi_h_flags; /*!< DB_DUP, DB_DUPSORT */ int (*dbi_h_dup_compare_fcn) (DB *, const DBT *, const DBT *) /*@*/; /* btree access parameters */ int dbi_bt_flags; int dbi_bt_minkey; int (*dbi_bt_compare_fcn) (DB *, const DBT *, const DBT *) /*@*/; int (*dbi_bt_dup_compare_fcn) (DB *, const DBT *, const DBT *) /*@*/; size_t (*dbi_bt_prefix_fcn) (DB *, const DBT *, const DBT *) /*@*/; /* recno access parameters */ int dbi_re_flags; int dbi_re_delim; unsigned int dbi_re_len; int dbi_re_pad; const char * dbi_re_source; /* queue access parameters */ unsigned int dbi_q_extentsize; /*@refcounted@*/ rpmdb dbi_rpmdb; /*!< the parent rpm database */ rpmTag dbi_rpmtag; /*!< rpm tag used for index */ int dbi_jlen; /*!< size of join key */ /*@only@*//*@null@*/ DB * dbi_db; /*!< Berkeley DB * handle */ /*@only@*//*@null@*/ DB_TXN * dbi_txnid; /*!< Bekerley DB_TXN * transaction id */ /*@only@*//*@null@*/ void * dbi_stats; /*!< Berkeley db statistics */ /*@observer@*/ const struct _dbiVec * dbi_vec; /*!< private methods */ }; /** \ingroup rpmdb * Describes the collection of index databases used by rpm. */ struct rpmdb_s { /*@owned@*/ const char * db_root;/*!< path prefix */ /*@owned@*/ const char * db_home;/*!< directory path */ int db_flags; int db_mode; /*!< open mode */ int db_perms; /*!< open permissions */ int db_api; /*!< Berkeley API type */ /*@owned@*/ const char * db_errpfx; int db_remove_env; int db_filter_dups; int db_chrootDone; /*!< If chroot(2) done, ignore db_root. */ void (*db_errcall) (const char *db_errpfx, char *buffer) /*@*/; /*@shared@*/ FILE * db_errfile; /*@only@*/ void * (*db_malloc) (size_t nbytes) /*@*/; /*@only@*/ void * (*db_realloc) (/*@only@*//*@null@*/ void * ptr, size_t nbytes) /*@*/; void (*db_free) (/*@only@*/ void * ptr) /*@modifies *ptr @*/; /*@only@*/ /*@null@*/ unsigned char * db_bits; /*!< package instance bit mask. */ int db_nbits; /*!< no. of bits in mask. */ rpmdb db_next; int db_opens; /*@only@*/ /*@null@*/ void * db_dbenv; /*!< Berkeley DB_ENV handle. */ int db_ndbi; /*!< No. of tag indices. */ dbiIndex * _dbi; /*!< Tag indices. */ struct rpmop_s db_getops; struct rpmop_s db_putops; struct rpmop_s db_delops; /*@refs@*/ int nrefs; /*!< Reference count. */ }; /* for RPM's internal use only */ /** \ingroup rpmdb */ enum rpmdbFlags { RPMDB_FLAG_JUSTCHECK = (1 << 0), RPMDB_FLAG_MINIMAL = (1 << 1), /*@-enummemuse@*/ RPMDB_FLAG_CHROOT = (1 << 2) /*@=enummemuse@*/ }; #ifdef __cplusplus extern "C" { #endif /*@-exportlocal@*/ /** \ingroup db3 * Return new configured index database handle instance. * @param rpmdb rpm database * @param rpmtag rpm tag * @return index database handle */ /*@unused@*/ /*@only@*/ /*@null@*/ dbiIndex db3New(rpmdb rpmdb, rpmTag rpmtag) /*@globals rpmGlobalMacroContext, h_errno @*/ /*@modifies rpmGlobalMacroContext @*/; /** \ingroup db3 * Destroy index database handle instance. * @param dbi index database handle * @return NULL always */ /*@null@*/ dbiIndex db3Free( /*@only@*/ /*@null@*/ dbiIndex dbi) /*@*/; /** \ingroup db3 * Format db3 open flags for debugging print. * @param dbflags db open flags * @param print_dbenv_flags format db env flags instead? * @return formatted flags (static buffer) */ /*@-redecl@*/ /*@exposed@*/ extern const char *const prDbiOpenFlags(int dbflags, int print_dbenv_flags) /*@*/; /*@=redecl@*/ /** \ingroup dbi * Return handle for an index database. * @param db rpm database * @param rpmtag rpm tag * @param flags (unused) * @return index database handle */ /*@only@*/ /*@null@*/ dbiIndex dbiOpen(/*@null@*/ rpmdb db, rpmTag rpmtag, unsigned int flags) /*@globals rpmGlobalMacroContext, errno, h_errno @*/ /*@modifies db, rpmGlobalMacroContext, errno @*/; /*@-globuse -mustmod @*/ /* FIX: vector annotations */ /** \ingroup dbi * Open a database cursor. * @param dbi index database handle * @param txnid database transaction handle * @retval dbcp returned database cursor * @param flags DB_WRITECURSOR if writing, or 0 * @return 0 on success */ /*@unused@*/ static inline int dbiCopen(dbiIndex dbi, /*@null@*/ DB_TXN * txnid, /*@out@*/ DBC ** dbcp, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, *dbcp, fileSystem @*/ { return (*dbi->dbi_vec->copen) (dbi, txnid, dbcp, flags); } /** \ingroup dbi * Close a database cursor. * @param dbi index database handle * @param dbcursor database cursor * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiCclose(dbiIndex dbi, /*@only@*/ DBC * dbcursor, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, *dbcursor, fileSystem @*/ { return (*dbi->dbi_vec->cclose) (dbi, dbcursor, flags); } /** \ingroup dbi * Duplicate a database cursor. * @param dbi index database handle * @param dbcursor database cursor * @retval dbcp address of new database cursor * @param flags DB_POSITION for same position, 0 for uninitialized * @return 0 on success */ /*@unused@*/ static inline int dbiCdup(dbiIndex dbi, DBC * dbcursor, /*@out@*/ DBC ** dbcp, unsigned int flags) /*@modifies dbi, *dbcp @*/ { return (*dbi->dbi_vec->cdup) (dbi, dbcursor, dbcp, flags); } /** \ingroup dbi * Delete (key,data) pair(s) from index database. * @param dbi index database handle * @param dbcursor database cursor (NULL will use db->del) * @param key delete key value/length/flags * @param data delete data value/length/flags * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiDel(dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * data, unsigned int flags) /*@globals fileSystem, internalState @*/ /*@modifies dbi, *dbcursor, fileSystem, internalState @*/ { int rc; assert(key->data != NULL && key->size > 0); (void) rpmswEnter(&dbi->dbi_rpmdb->db_delops, 0); rc = (dbi->dbi_vec->cdel) (dbi, dbcursor, key, data, flags); (void) rpmswExit(&dbi->dbi_rpmdb->db_delops, data->size); return rc; } /** \ingroup dbi * Retrieve (key,data) pair from index database. * @param dbi index database handle * @param dbcursor database cursor (NULL will use db->get) * @param key retrieve key value/length/flags * @param data retrieve data value/length/flags * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiGet(dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * data, unsigned int flags) /*@globals fileSystem, internalState @*/ /*@modifies dbi, *dbcursor, *key, *data, fileSystem, internalState @*/ { int rc; assert((flags == DB_NEXT) || (key->data != NULL && key->size > 0)); (void) rpmswEnter(&dbi->dbi_rpmdb->db_getops, 0); rc = (dbi->dbi_vec->cget) (dbi, dbcursor, key, data, flags); (void) rpmswExit(&dbi->dbi_rpmdb->db_getops, data->size); return rc; } /** \ingroup dbi * Retrieve (key,data) pair using dbcursor->c_pget. * @param dbi index database handle * @param dbcursor database cursor (NULL will use db->get) * @param key secondary retrieve key value/length/flags * @param pkey primary retrieve key value/length/flags * @param data primary retrieve data value/length/flags * @param flags DB_NEXT, DB_SET, or 0 * @return 0 on success */ /*@unused@*/ static inline int dbiPget(dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * pkey, DBT * data, unsigned int flags) /*@globals fileSystem, internalState @*/ /*@modifies dbi, *dbcursor, *key, *pkey, *data, fileSystem, internalState @*/ { int rc; assert((flags == DB_NEXT) || (key->data != NULL && key->size > 0)); (void) rpmswEnter(&dbi->dbi_rpmdb->db_getops, 0); rc = (dbi->dbi_vec->cpget) (dbi, dbcursor, key, pkey, data, flags); (void) rpmswExit(&dbi->dbi_rpmdb->db_getops, data->size); return rc; } /** \ingroup dbi * Store (key,data) pair in index database. * @param dbi index database handle * @param dbcursor database cursor (NULL will use db->put) * @param key store key value/length/flags * @param data store data value/length/flags * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiPut(dbiIndex dbi, /*@null@*/ DBC * dbcursor, DBT * key, DBT * data, unsigned int flags) /*@globals fileSystem, internalState @*/ /*@modifies dbi, *dbcursor, *key, fileSystem, internalState @*/ { int rc; assert(key->data != NULL && key->size > 0 && data->data != NULL && data->size > 0); (void) rpmswEnter(&dbi->dbi_rpmdb->db_putops, 0); rc = (dbi->dbi_vec->cput) (dbi, dbcursor, key, data, flags); (void) rpmswExit(&dbi->dbi_rpmdb->db_putops, data->size); return rc; } /** \ingroup dbi * Retrieve count of (possible) duplicate items. * @param dbi index database handle * @param dbcursor database cursor * @param countp address of count * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiCount(dbiIndex dbi, DBC * dbcursor, /*@out@*/ unsigned int * countp, unsigned int flags) /*@globals fileSystem @*/ /*@modifies *dbcursor, fileSystem @*/ { return (*dbi->dbi_vec->ccount) (dbi, dbcursor, countp, flags); } /** \ingroup dbi * Verify (and close) index database. * @param dbi index database handle * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiVerify(/*@only@*/ dbiIndex dbi, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, fileSystem @*/ { dbi->dbi_verify_on_close = 1; return (*dbi->dbi_vec->close) (dbi, flags); } /** \ingroup dbi * Close index database. * @param dbi index database handle * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiClose(/*@only@*/ dbiIndex dbi, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, fileSystem @*/ { return (*dbi->dbi_vec->close) (dbi, flags); } /** \ingroup dbi * Flush pending operations to disk. * @param dbi index database handle * @param flags (unused) * @return 0 on success */ /*@unused@*/ static inline int dbiSync (dbiIndex dbi, unsigned int flags) /*@globals fileSystem @*/ /*@modifies fileSystem @*/ { return (*dbi->dbi_vec->sync) (dbi, flags); } /** \ingroup dbi * Associate secondary database with primary. * @param dbi index database handle * @param dbisecondary secondary index database handle * @param callback create secondary key from primary (NULL if DB_RDONLY) * @param flags DB_CREATE or 0 * @return 0 on success */ /*@unused@*/ static inline int dbiAssociate(dbiIndex dbi, dbiIndex dbisecondary, int (*callback) (DB *, const DBT *, const DBT *, DBT *), unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, fileSystem @*/ { return (*dbi->dbi_vec->associate) (dbi, dbisecondary, callback, flags); } /** \ingroup dbi * Return join cursor for list of cursors. * @param dbi index database handle * @param curslist NULL terminated list of database cursors * @retval dbcp address of join database cursor * @param flags DB_JOIN_NOSORT or 0 * @return 0 on success */ /*@unused@*/ static inline int dbiJoin(dbiIndex dbi, DBC ** curslist, /*@out@*/ DBC ** dbcp, unsigned int flags) /*@globals fileSystem @*/ /*@modifies dbi, *dbcp, fileSystem @*/ { return (*dbi->dbi_vec->join) (dbi, curslist, dbcp, flags); } /** \ingroup dbi * Is database byte swapped? * @param dbi index database handle * @return 0 same order, 1 swapped order */ /*@unused@*/ static inline int dbiByteSwapped(dbiIndex dbi) /*@modifies dbi @*/ { if (dbi->dbi_byteswapped == -1) dbi->dbi_byteswapped = (*dbi->dbi_vec->byteswapped) (dbi); return dbi->dbi_byteswapped; } /** \ingroup dbi * Is database byte swapped? * @param dbi index database handle * @param flags DB_FAST_STAT or 0 * @return 0 on success */ /*@unused@*/ static inline int dbiStat(dbiIndex dbi, unsigned int flags) /*@modifies dbi @*/ { return (*dbi->dbi_vec->stat) (dbi, flags); } /*@=globuse =mustmod @*/ /*@=exportlocal@*/ /** \ingroup rpmdb */ unsigned int rpmdbGetIteratorFileNum(rpmdbMatchIterator mi) /*@*/; /** \ingroup dbi * Destroy set of index database items. * @param set set of index database items * @return NULL always */ /*@null@*/ dbiIndexSet dbiFreeIndexSet(/*@only@*/ /*@null@*/ dbiIndexSet set) /*@modifies set @*/; /** \ingroup dbi * Count items in index database set. * @param set set of index database items * @return number of items */ unsigned int dbiIndexSetCount(dbiIndexSet set) /*@*/; /** \ingroup dbi * Return record offset of header from element in index database set. * @param set set of index database items * @param recno index of item in set * @return record offset of header */ unsigned int dbiIndexRecordOffset(dbiIndexSet set, int recno) /*@*/; /** \ingroup dbi * Return file index from element in index database set. * @param set set of index database items * @param recno index of item in set * @return file index */ unsigned int dbiIndexRecordFileNumber(dbiIndexSet set, int recno) /*@*/; /** \ingroup rpmdb * Tags for which rpmdb indices will be built. */ /*@-exportlocal@*/ /*@unchecked@*/ /*@only@*/ /*@null@*/ extern int * dbiTags; /*@unchecked@*/ extern int dbiTagsMax; /*@=exportlocal@*/ /** \ingroup rpmdb * Unreference a database instance. * @param db rpm database * @param msg * @return NULL always */ /*@unused@*/ /*@null@*/ rpmdb rpmdbUnlink (/*@killref@*/ /*@only@*/ rpmdb db, const char * msg) /*@modifies db @*/; /** @todo Remove debugging entry from the ABI. */ /*@-exportlocal@*/ /*@null@*/ rpmdb XrpmdbUnlink (/*@killref@*/ /*@only@*/ rpmdb db, const char * msg, const char * fn, unsigned ln) /*@modifies db @*/; /*@=exportlocal@*/ #define rpmdbUnlink(_db, _msg) XrpmdbUnlink(_db, _msg, __FILE__, __LINE__) /** \ingroup rpmdb * Reference a database instance. * @param db rpm database * @param msg * @return new rpm database reference */ /*@unused@*/ rpmdb rpmdbLink (rpmdb db, const char * msg) /*@modifies db @*/; /** @todo Remove debugging entry from the ABI. */ /*@-exportlocal@*/ rpmdb XrpmdbLink (rpmdb db, const char * msg, const char * fn, unsigned ln) /*@modifies db @*/; /*@=exportlocal@*/ #define rpmdbLink(_db, _msg) XrpmdbLink(_db, _msg, __FILE__, __LINE__) /** \ingroup rpmdb * Open rpm database. * @param prefix path to top of install tree * @retval dbp address of rpm database * @param mode open(2) flags: O_RDWR or O_RDONLY (O_CREAT also) * @param perms database permissions * @return 0 on success */ int rpmdbOpen (/*@null@*/ const char * prefix, /*@null@*/ /*@out@*/ rpmdb * dbp, int mode, int perms) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies *dbp, rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Initialize database. * @param prefix path to top of install tree * @param perms database permissions * @return 0 on success */ int rpmdbInit(/*@null@*/ const char * prefix, int perms) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Verify database components. * @param prefix path to top of install tree * @return 0 on success */ int rpmdbVerify(/*@null@*/ const char * prefix) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies rpmGlobalMacroContext, fileSystem, internalState @*/; /** * Close a single database index. * @param db rpm database * @param rpmtag rpm tag * @return 0 on success */ int rpmdbCloseDBI(/*@null@*/ rpmdb db, int rpmtag) /*@globals fileSystem @*/ /*@modifies db, fileSystem @*/; /** \ingroup rpmdb * Close all database indices and free rpmdb. * @param db rpm database * @return 0 on success */ int rpmdbClose (/*@killref@*/ /*@only@*/ /*@null@*/ rpmdb db) /*@globals fileSystem @*/ /*@modifies db, fileSystem @*/; /** \ingroup rpmdb * Sync all database indices. * @param db rpm database * @return 0 on success */ int rpmdbSync (/*@null@*/ rpmdb db) /*@globals fileSystem @*/ /*@modifies fileSystem @*/; /** \ingroup rpmdb * Open all database indices. * @param db rpm database * @return 0 on success */ /*@-exportlocal@*/ int rpmdbOpenAll (/*@null@*/ rpmdb db) /*@globals rpmGlobalMacroContext, h_errno @*/ /*@modifies db, rpmGlobalMacroContext @*/; /*@=exportlocal@*/ /** \ingroup rpmdb * Return number of instances of package in rpm database. * @param db rpm database * @param name rpm package name * @return number of instances */ int rpmdbCountPackages(/*@null@*/ rpmdb db, const char * name) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies db, rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Return header join key for current position of rpm database iterator. * @param mi rpm database iterator * @return current header join key */ unsigned int rpmdbGetIteratorOffset(/*@null@*/ rpmdbMatchIterator mi) /*@*/; /** \ingroup rpmdb * Return number of elements in rpm database iterator. * @param mi rpm database iterator * @return number of elements */ int rpmdbGetIteratorCount(/*@null@*/ rpmdbMatchIterator mi) /*@*/; /** \ingroup rpmdb * Append items to set of package instances to iterate. * @param mi rpm database iterator * @param hdrNums array of package instances * @param nHdrNums number of elements in array * @return 0 on success, 1 on failure (bad args) */ int rpmdbAppendIterator(/*@null@*/ rpmdbMatchIterator mi, /*@null@*/ const int * hdrNums, int nHdrNums) /*@modifies mi @*/; /** \ingroup rpmdb * Remove items from set of package instances to iterate. * @note Sorted hdrNums are always passed in rpmlib. * @param mi rpm database iterator * @param hdrNums array of package instances * @param nHdrNums number of elements in array * @param sorted is the array sorted? (array will be sorted on return) * @return 0 on success, 1 on failure (bad args) */ int rpmdbPruneIterator(/*@null@*/ rpmdbMatchIterator mi, /*@null@*/ int * hdrNums, int nHdrNums, int sorted) /*@modifies mi, hdrNums @*/; /** \ingroup rpmdb * Add pattern to iterator selector. * @param mi rpm database iterator * @param tag rpm tag * @param mode type of pattern match * @param pattern pattern to match * @return 0 on success */ int rpmdbSetIteratorRE(/*@null@*/ rpmdbMatchIterator mi, rpmTag tag, rpmMireMode mode, /*@null@*/ const char * pattern) /*@globals rpmGlobalMacroContext, h_errno @*/ /*@modifies mi, mode, rpmGlobalMacroContext @*/; /** \ingroup rpmdb * Prepare iterator for lazy writes. * @note Must be called before rpmdbNextIterator() with CDB model database. * @param mi rpm database iterator * @param rewrite new value of rewrite * @return previous value */ int rpmdbSetIteratorRewrite(/*@null@*/ rpmdbMatchIterator mi, int rewrite) /*@modifies mi @*/; /** \ingroup rpmdb * Modify iterator to mark header for lazy write on release. * @param mi rpm database iterator * @param modified new value of modified * @return previous value */ int rpmdbSetIteratorModified(/*@null@*/ rpmdbMatchIterator mi, int modified) /*@modifies mi @*/; /** \ingroup rpmdb * Modify iterator to verify retrieved header blobs. * @param mi rpm database iterator * @param ts transaction set * @param (*hdrchk) headerCheck() vector * @return 0 always */ int rpmdbSetHdrChk(/*@null@*/ rpmdbMatchIterator mi, /*@null@*/ rpmts ts, /*@null@*/ rpmRC (*hdrchk) (rpmts ts, const void * uh, size_t uc, const char ** msg)) /*@modifies mi @*/; /** \ingroup rpmdb * Return database iterator. * @param db rpm database * @param rpmtag rpm tag * @param keyp key data (NULL for sequential access) * @param keylen key data length (0 will use strlen(keyp)) * @return NULL on failure */ /*@only@*/ /*@null@*/ rpmdbMatchIterator rpmdbInitIterator(/*@null@*/ rpmdb db, rpmTag rpmtag, /*@null@*/ const void * keyp, size_t keylen) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies db, rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Return next package header from iteration. * @param mi rpm database iterator * @return NULL on end of iteration. */ /*@null@*/ Header rpmdbNextIterator(/*@null@*/ rpmdbMatchIterator mi) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies mi, rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Check rpmdb signal handler for trapped signal exit. */ /*@mayexit@*/ int rpmdbCheckSignals(void) /*@globals fileSystem, internalState @*/ /*@modifies fileSystem, internalState @*/; /** \ingroup rpmdb * Destroy rpm database iterator. * @param mi rpm database iterator * @return NULL always */ /*@null@*/ rpmdbMatchIterator rpmdbFreeIterator(/*@only@*/ /*@null@*/rpmdbMatchIterator mi) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies mi, rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Add package header to rpm database and indices. * @param db rpm database * @param iid install transaction id (iid = 0 or -1 to skip) * @param h header * @param ts (unused) transaction set (or NULL) * @param (*hdrchk) (unused) headerCheck() vector (or NULL) * @return 0 on success */ int rpmdbAdd(/*@null@*/ rpmdb db, int iid, Header h, /*@null@*/ rpmts ts, /*@null@*/ rpmRC (*hdrchk) (rpmts ts, const void *uh, size_t uc, const char ** msg)) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies db, h, rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Remove package header from rpm database and indices. * @param db rpm database * @param rid (unused) remove transaction id (rid = 0 or -1 to skip) * @param hdrNum package instance number in database * @param ts (unused) transaction set (or NULL) * @param (*hdrchk) (unused) headerCheck() vector (or NULL) * @return 0 on success */ int rpmdbRemove(/*@null@*/ rpmdb db, /*@unused@*/ int rid, unsigned int hdrNum, /*@null@*/ rpmts ts, /*@null@*/ rpmRC (*hdrchk) (rpmts ts, const void *uh, size_t uc, const char ** msg)) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies db, rpmGlobalMacroContext, fileSystem, internalState @*/; /** \ingroup rpmdb * Rebuild database indices from package headers. * @param prefix path to top of install tree * @param ts transaction set (or NULL) * @param (*hdrchk) headerCheck() vector (or NULL) * @return 0 on success */ int rpmdbRebuild(/*@null@*/ const char * prefix, /*@null@*/ rpmts ts, /*@null@*/ rpmRC (*hdrchk) (rpmts ts, const void *uh, size_t uc, const char ** msg)) /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/ /*@modifies rpmGlobalMacroContext, fileSystem, internalState @*/; #ifndef __APPLE__ /** * Mergesort, same arguments as qsort(2). */ /*@unused@*/ int mergesort(void *base, size_t nmemb, size_t size, int (*cmp) (const void *, const void *)) /*@globals errno @*/ /*@modifies base, errno @*/; #else /* mergesort is defined in stdlib.h on Mac OS X */ #endif /* __APPLE__ */ #ifdef __cplusplus } #endif /*@=bounds@*/ #endif /* H_RPMDB */