!C99Shell v. 1.0 pre-release build #16!

Software: Apache/2.0.54 (Fedora). PHP/5.0.4 

uname -a: Linux mina-info.me 2.6.17-1.2142_FC4smp #1 SMP Tue Jul 11 22:57:02 EDT 2006 i686 

uid=48(apache) gid=48(apache) groups=48(apache)
context=system_u:system_r:httpd_sys_script_t
 

Safe-mode: OFF (not secure)

/usr/include/rpm/   drwxr-xr-x
Free 3.83 GB of 27.03 GB (14.19%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     rpmts.h (31.07 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
#ifndef H_RPMTS
#define H_RPMTS

/** \ingroup rpmts
* \file lib/rpmts.h
* Structures and prototypes used for an "rpmts" transaction set.
*/

#include "rpmps.h"
#include "rpmsw.h"
#include "rpmsx.h"

/*@-exportlocal@*/
/*@unchecked@*/
extern int _rpmts_debug;
/*@unchecked@*/
extern int _rpmts_stats;
/*@unchecked@*/
extern int _fps_debug;
/*@=exportlocal@*/

/**
* Bit(s) to control digest and signature verification.
*/
typedef enum rpmVSFlags_e {
    RPMVSF_DEFAULT    = 0,
    RPMVSF_NOHDRCHK    = (1 <<  0),
    RPMVSF_NEEDPAYLOAD    = (1 <<  1),
    /* bit(s) 2-7 unused */
    RPMVSF_NOSHA1HEADER    = (1 <<  8),
    RPMVSF_NOMD5HEADER    = (1 <<  9),    /* unimplemented */
    RPMVSF_NODSAHEADER    = (1 << 10),
    RPMVSF_NORSAHEADER    = (1 << 11),    /* unimplemented */
    /* bit(s) 12-15 unused */
    RPMVSF_NOSHA1    = (1 << 16),    /* unimplemented */
    RPMVSF_NOMD5    = (1 << 17),
    RPMVSF_NODSA    = (1 << 18),
    RPMVSF_NORSA    = (1 << 19)
    /* bit(s) 16-31 unused */
} rpmVSFlags;

/**
* Transaction Types
*/
typedef enum rpmtsType_e {
    RPMTRANS_TYPE_NORMAL       = 0,
    RPMTRANS_TYPE_ROLLBACK     = (1 << 0),
    RPMTRANS_TYPE_AUTOROLLBACK = (1 << 1)
} rpmtsType;

#define    _RPMVSF_NODIGESTS    \
  ( RPMVSF_NOSHA1HEADER |    \
    RPMVSF_NOMD5HEADER |    \
    RPMVSF_NOSHA1 |        \
    RPMVSF_NOMD5 )

#define    _RPMVSF_NOSIGNATURES    \
  ( RPMVSF_NODSAHEADER |    \
    RPMVSF_NORSAHEADER |    \
    RPMVSF_NODSA |        \
    RPMVSF_NORSA )

#define    _RPMVSF_NOHEADER    \
  ( RPMVSF_NOSHA1HEADER |    \
    RPMVSF_NOMD5HEADER |    \
    RPMVSF_NODSAHEADER |    \
    RPMVSF_NORSAHEADER )

#define    _RPMVSF_NOPAYLOAD    \
  ( RPMVSF_NOSHA1 |        \
    RPMVSF_NOMD5 |        \
    RPMVSF_NODSA |        \
    RPMVSF_NORSA )

/**
* Indices for timestamps.
*/
typedef    enum rpmtsOpX_e {
    RPMTS_OP_TOTAL        =  0,
    RPMTS_OP_CHECK        =  1,
    RPMTS_OP_ORDER        =  2,
    RPMTS_OP_FINGERPRINT    =  3,
    RPMTS_OP_REPACKAGE        =  4,
    RPMTS_OP_INSTALL        =  5,
    RPMTS_OP_ERASE        =  6,
    RPMTS_OP_SCRIPTLETS        =  7,
    RPMTS_OP_COMPRESS        =  8,
    RPMTS_OP_UNCOMPRESS        =  9,
    RPMTS_OP_DIGEST        = 10,
    RPMTS_OP_SIGNATURE        = 11,
    RPMTS_OP_DBADD        = 12,
    RPMTS_OP_DBREMOVE        = 13,
    RPMTS_OP_DBGET        = 14,
    RPMTS_OP_DBPUT        = 15,
    RPMTS_OP_DBDEL        = 16,
    RPMTS_OP_MAX        = 17
} rpmtsOpX;

#if defined(_RPMTS_INTERNAL)

#include "rpmhash.h"    /* XXX hashTable */
#include "rpmal.h"    /* XXX availablePackage/relocateFileList ,*/

/**********************
* Transaction Scores *
**********************
*
* In order to allow instance counts to be adjusted properly when an
* autorollback transaction is ran, we keep a list that is indexed
* by rpm name of whether the rpm has been installed or erased.  This listed
* is only updated:
*
*    iif autorollbacks are enabled.
*    iif this is not a rollback or autorollback transaction.
*
* When creating an autorollback transaction, its rpmts points to the same
* rpmtsScore object as the running transaction.  So when the autorollback
* transaction runs it can see where each package was in the running transaction
* at the point the running transaction failed, and thus on a per package
* basis make adjustments to the instance counts.
*
* XXX: Jeff, I am not convinced that this does not need to be in its own file
*      (i.e. rpmtsScore.{h,c}), but I first wanted to get it working.
*/
struct rpmtsScoreEntry_s {
    char *         N;            /*!<Name of package                */
    rpmElementType te_types;        /*!<te types this entry represents */
    int            installed;        /*!<Was the new header installed   */
    int            erased;        /*!<Was the old header removed     */
};

typedef /*@abstract@*/ struct rpmtsScoreEntry_s * rpmtsScoreEntry;

struct rpmtsScore_s {
    int entries;            /*!< Number of scores       */
    rpmtsScoreEntry * scores;    /*!< Array of score entries */
        int nrefs;            /*!< Reference count.       */
};

typedef /*@abstract@*/ struct rpmtsScore_s * rpmtsScore;


/** \ingroup rpmts
* initialize rpmtsScore for running transaction and autorollback
* transaction.
* @param runningTS    Running Transaction.
* @param rollbackTS    Rollback Transaction.
* @return        RPMRC_OK
*/
rpmRC rpmtsScoreInit(rpmts runningTS, rpmts rollbackTS)
    /*@globals fileSystem @*/
    /*@modifies runningTS, rollbackTS, fileSystem @*/;

/** \ingroup rpmts
* Free rpmtsScore provided no more references exist against it.
* @param score        rpmtsScore to free
* @return        NULL always
*/
/*@-exportlocal@*/
/*@null@*/
rpmtsScore rpmtsScoreFree(/*@only@*/ /*@null@*/ rpmtsScore score)
    /*@modifies score @*/;
/*@=exportlocal@*/

/** \ingroup rpmts
* Get rpmtsScore from transaction.
* @param ts    RPM Transaction.
* @return    rpmtsScore or NULL.
*/
/*@exposed@*/ /*@null@*/
rpmtsScore rpmtsGetScore(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get rpmtsScoreEntry from rpmtsScore.
* @param score   RPM Transaction Score.
* @return      rpmtsScoreEntry or NULL.
*/
/*@null@*/
rpmtsScoreEntry rpmtsScoreGetEntry(rpmtsScore score, const char *N)
    /*@*/;

/** \ingroup rpmts
* \file lib/rpmts.h
* Structures and prototypes used for an "rpmts" transaction set.
*/

/**************************
* END Transaction Scores *
**************************/

/*@unchecked@*/
/*@-exportlocal@*/
extern int _cacheDependsRC;
/*@=exportlocal@*/

/** \ingroup rpmts
*/
typedef    /*@abstract@*/ struct diskspaceInfo_s * rpmDiskSpaceInfo;

/** \ingroup rpmts
*/
struct diskspaceInfo_s {
    dev_t dev;            /*!< File system device number. */
    signed long bneeded;    /*!< No. of blocks needed. */
    signed long ineeded;    /*!< No. of inodes needed. */
    int bsize;            /*!< File system block size. */
    signed long long bavail;    /*!< No. of blocks available. */
    signed long long iavail;    /*!< No. of inodes available. */
};

/** \ingroup rpmts
* Adjust for root only reserved space. On linux e2fs, this is 5%.
*/
#define    adj_fs_blocks(_nb)    (((_nb) * 21) / 20)

/* argon thought a shift optimization here was a waste of time...  he's
   probably right :-( */
#define BLOCK_ROUND(size, block) (((size) + (block) - 1) / (block))

/** \ingroup rpmts
*/
typedef enum tsStage_e {
    TSM_UNKNOWN        =  0,
    TSM_INSTALL        =  7,
    TSM_ERASE        =  8,
} tsmStage;

/** \ingroup rpmts
* The set of packages to be installed/removed atomically.
*/
struct rpmts_s {
    rpmtransFlags transFlags;    /*!< Bit(s) to control operation. */
    tsmStage goal;        /*!< Transaction goal (i.e. mode) */
    rpmtsType type;             /*!< default, rollback, autorollback */

/*@refcounted@*/ /*@null@*/
    rpmdb sdb;            /*!< Solve database handle. */
    int sdbmode;        /*!< Solve database open mode. */
/*@null@*/
    int (*solve) (rpmts ts, rpmds key, const void * data)
    /*@modifies ts @*/;    /*!< Search for NEVRA key. */
/*@relnull@*/
    const void * solveData;    /*!< Solve callback data */
    int nsuggests;        /*!< No. of depCheck suggestions. */
/*@only@*/ /*@null@*/
    const void ** suggests;    /*!< Possible depCheck suggestions. */

/*@observer@*/ /*@null@*/
    rpmCallbackFunction notify;    /*!< Callback function. */
/*@observer@*/ /*@null@*/
    rpmCallbackData notifyData;    /*!< Callback private data. */

/*@refcounted@*/ /*@null@*/
    rpmps probs;        /*!< Current problems in transaction. */
    rpmprobFilterFlags ignoreSet;
                /*!< Bits to filter current problems. */

    int filesystemCount;    /*!< No. of mounted filesystems. */
/*@dependent@*/ /*@null@*/
    const char ** filesystems;    /*!< Mounted filesystem names. */
/*@only@*/ /*@null@*/
    rpmDiskSpaceInfo dsi;    /*!< Per filesystem disk/inode usage. */

/*@refcounted@*/ /*@null@*/
    rpmdb rdb;            /*!< Install database handle. */
    int dbmode;            /*!< Install database open mode. */
/*@only@*/
    hashTable ht;        /*!< Fingerprint hash table. */

/*@only@*/ /*@null@*/
    int * removedPackages;    /*!< Set of packages being removed. */
    int numRemovedPackages;    /*!< No. removed package instances. */
    int allocedRemovedPackages;    /*!< Size of removed packages array. */

/*@only@*/
    rpmal addedPackages;    /*!< Set of packages being installed. */
    int numAddedPackages;    /*!< No. added package instances. */

#ifndef    DYING
/*@only@*/
    rpmal availablePackages;    /*!< Universe of available packages. */
    int numAvailablePackages;    /*!< No. available package instances. */
#endif

/*@refcounted@*/ /*@null@*/
    rpmsx sx;            /*!< Security context patterns. */

/*@null@*/
    rpmte relocateElement;    /*!< Element to use when relocating packages. */

/*@owned@*/ /*@relnull@*/
    rpmte * order;        /*!< Packages sorted by dependencies. */
    int orderCount;        /*!< No. of transaction elements. */
    int orderAlloced;        /*!< No. of allocated transaction elements. */
    int unorderedSuccessors;    /*!< Index of 1st element of successors. */
    int ntrees;            /*!< No. of dependency trees. */
    int maxDepth;        /*!< Maximum depth of dependency tree(s). */

    int selinuxEnabled;        /*!< Is SE linux enabled? */
    int chrootDone;        /*!< Has chroot(2) been been done? */
/*@only@*/ /*@null@*/
    const char * rootDir;    /*!< Path to top of install tree. */
/*@only@*/ /*@null@*/
    const char * currDir;    /*!< Current working directory. */
/*@null@*/
    FD_t scriptFd;        /*!< Scriptlet stdout/stderr. */
    int delta;            /*!< Delta for reallocation. */
    int_32 tid;            /*!< Transaction id. */

    uint_32 color;        /*!< Transaction color bits. */

    rpmVSFlags vsflags;        /*!< Signature/digest verification flags. */

/*@observer@*/ /*@dependent@*/ /*@null@*/
    const char * fn;        /*!< Current package fn. */
    int_32  sigtag;        /*!< Current package signature tag. */
    int_32  sigtype;        /*!< Current package signature data type. */
/*@null@*/
    const void * sig;        /*!< Current package signature. */
    int_32 siglen;        /*!< Current package signature length. */

/*@only@*/ /*@null@*/
    const unsigned char * pkpkt;/*!< Current pubkey packet. */
    size_t pkpktlen;        /*!< Current pubkey packet length. */
    unsigned char pksignid[8];    /*!< Current pubkey fingerprint. */

    struct rpmop_s ops[RPMTS_OP_MAX];

/*@null@*/
    pgpDig dig;            /*!< Current signature/pubkey parameters. */

/*@null@*/
    Spec spec;            /*!< Spec file control structure. */

/*@kept@*/ /*@null@*/
    rpmtsScore score;        /*!< Transaction Score (autorollback). */

/*@refs@*/
    int nrefs;            /*!< Reference count. */
};
#endif    /* _RPMTS_INTERNAL */

#ifdef __cplusplus
extern "C" {
#endif

/** \ingroup rpmts
* Check that all dependencies can be resolved.
* @param ts        transaction set
* @return        0 on success
*/
int rpmtsCheck(rpmts ts)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Determine package order in a transaction set according to dependencies.
*
* Order packages, returning error if circular dependencies cannot be
* eliminated by removing Requires's from the loop(s). Only dependencies from
* added or removed packages are used to determine ordering using a
* topological sort (Knuth vol. 1, p. 262). Use rpmtsCheck() to verify
* that all dependencies can be resolved.
*
* The final order ends up as installed packages followed by removed packages,
* with packages removed for upgrades immediately following the new package
* to be installed.
*
* @param ts        transaction set
* @return        no. of (added) packages that could not be ordered
*/
int rpmtsOrder(rpmts ts)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Process all package elements in a transaction set.  Before calling
* rpmtsRun be sure to have:
*
*    - setup the rpm root dir via rpmtsSetRoot().
*    - setup the rpm notify callback via rpmtsSetNotifyCallback().
*    - setup the rpm transaction flags via rpmtsSetFlags().
*
* Additionally, though not required you may want to:
*
*    - setup the rpm verify signature flags via rpmtsSetVSFlags().
*       
* @param ts        transaction set
* @param okProbs    previously known problems (or NULL)
* @param ignoreSet    bits to filter problem types
* @return        0 on success, -1 on error, >0 with newProbs set
*/
int rpmtsRun(rpmts ts, rpmps okProbs, rpmprobFilterFlags ignoreSet)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Unreference a transaction instance.
* @param ts        transaction set
* @param msg
* @return        NULL always
*/
/*@unused@*/ /*@null@*/
rpmts rpmtsUnlink (/*@killref@*/ /*@only@*/ rpmts ts,
        const char * msg)
    /*@modifies ts @*/;

/** @todo Remove debugging entry from the ABI. */
/*@-exportlocal@*/
/*@null@*/
rpmts XrpmtsUnlink (/*@killref@*/ /*@only@*/ rpmts ts,
        const char * msg, const char * fn, unsigned ln)
    /*@modifies ts @*/;
/*@=exportlocal@*/
#define    rpmtsUnlink(_ts, _msg)    XrpmtsUnlink(_ts, _msg, __FILE__, __LINE__)

/** \ingroup rpmts
* Reference a transaction set instance.
* @param ts        transaction set
* @param msg
* @return        new transaction set reference
*/
/*@unused@*/
rpmts rpmtsLink (rpmts ts, const char * msg)
    /*@modifies ts @*/;

/** @todo Remove debugging entry from the ABI. */
rpmts XrpmtsLink (rpmts ts,
        const char * msg, const char * fn, unsigned ln)
        /*@modifies ts @*/;
#define    rpmtsLink(_ts, _msg)    XrpmtsLink(_ts, _msg, __FILE__, __LINE__)

/** \ingroup rpmts
* Close the database used by the transaction.
* @param ts        transaction set
* @return        0 on success
*/
int rpmtsCloseDB(rpmts ts)
    /*@globals fileSystem @*/
    /*@modifies ts, fileSystem @*/;

/** \ingroup rpmts
* Open the database used by the transaction.
* @param ts        transaction set
* @param dbmode    O_RDONLY or O_RDWR
* @return        0 on success
*/
int rpmtsOpenDB(rpmts ts, int dbmode)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Initialize the database used by the transaction.
* @deprecated An explicit rpmdbInit() is almost never needed.
* @param ts        transaction set
* @param dbmode    O_RDONLY or O_RDWR
* @return        0 on success
*/
int rpmtsInitDB(rpmts ts, int dbmode)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Rebuild the database used by the transaction.
* @param ts        transaction set
* @return        0 on success
*/
int rpmtsRebuildDB(rpmts ts)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Verify the database used by the transaction.
* @param ts        transaction set
* @return        0 on success
*/
int rpmtsVerifyDB(rpmts ts)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Return transaction database iterator.
* @param ts        transaction set
* @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 rpmtsInitIterator(const rpmts ts, rpmTag rpmtag,
            /*@null@*/ const void * keyp, size_t keylen)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;

/**
* Retrieve pubkey from rpm database.
* @param ts        rpm transaction
* @return        RPMRC_OK on success, RPMRC_NOKEY if not found
*/
/*@-exportlocal@*/
rpmRC rpmtsFindPubkey(rpmts ts)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState */;
/*@=exportlocal@*/

/** \ingroup rpmts
* Close the database used by the transaction to solve dependencies.
* @param ts        transaction set
* @return        0 on success
*/
/*@-exportlocal@*/
int rpmtsCloseSDB(rpmts ts)
    /*@globals fileSystem @*/
    /*@modifies ts, fileSystem @*/;
/*@=exportlocal@*/

/** \ingroup rpmts
* Open the database used by the transaction to solve dependencies.
* @param ts        transaction set
* @param dbmode    O_RDONLY or O_RDWR
* @return        0 on success
*/
/*@-exportlocal@*/
int rpmtsOpenSDB(rpmts ts, int dbmode)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;
/*@=exportlocal@*/

/**
* Attempt to solve a needed dependency using the solve database.
* @param ts        transaction set
* @param ds        dependency set
* @param data        opaque data associated with callback
* @return        -1 retry, 0 ignore, 1 not found
*/
/*@-exportlocal@*/
int rpmtsSolve(rpmts ts, rpmds ds, const void * data)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, rpmGlobalMacroContext, fileSystem, internalState @*/;
/*@=exportlocal@*/

/**
* Attempt to solve a needed dependency using memory resident tables.
* @deprecated This function will move from rpmlib to the python bindings.
* @param ts        transaction set
* @param ds        dependency set
* @return        0 if resolved (and added to ts), 1 not found
*/
/*@unused@*/
int rpmtsAvailable(rpmts ts, const rpmds ds)
    /*@globals fileSystem @*/
    /*@modifies ts, fileSystem @*/;

/**
* Set dependency solver callback.
* @param ts        transaction set
* @param (*solve)    dependency solver callback
* @param solveData    dependency solver callback data (opaque)
* @return        0 on success
*/
int rpmtsSetSolveCallback(rpmts ts,
        int (*solve) (rpmts ts, rpmds ds, const void * data),
        const void * solveData)
    /*@modifies ts @*/;

/**
* Return the type of a transaction.
* @param ts        transaction set
* @return        0 it is not, 1 it is.
*/
rpmtsType rpmtsGetType(rpmts ts)
    /*@*/;

/**
* Set transaction type.   Allowed types are:
*
*     RPMTRANS_TYPE_NORMAL
*    RPMTRANS_TYPE_ROLLBACK
*     RPMTRANS_TYPE_AUTOROLLBACK
*
* @param ts        transaction set
* @param type        transaction type
* @return        void
*/
void rpmtsSetType(rpmts ts, rpmtsType type)
    /*@modifies ts @*/;

/**
* Return current transaction set problems.
* @param ts        transaction set
* @return        current problem set (or NULL)
*/
/*@null@*/
rpmps rpmtsProblems(rpmts ts)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Free signature verification data.
* @param ts        transaction set
*/
void rpmtsCleanDig(rpmts ts)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Free memory needed only for dependency checks and ordering.
* @param ts        transaction set
*/
void rpmtsClean(rpmts ts)
    /*@globals fileSystem, internalState @*/
    /*@modifies ts, fileSystem , internalState@*/;

/** \ingroup rpmts
* Re-create an empty transaction set.
* @param ts        transaction set
*/
void rpmtsEmpty(rpmts ts)
    /*@globals fileSystem, internalState @*/
    /*@modifies ts, fileSystem, internalState @*/;

/** \ingroup rpmts
* Destroy transaction set, closing the database as well.
* @param ts        transaction set
* @return        NULL always
*/
/*@null@*/
rpmts rpmtsFree(/*@killref@*/ /*@only@*//*@null@*/ rpmts ts)
    /*@globals fileSystem, internalState @*/
    /*@modifies ts, fileSystem, internalState @*/;

/** \ingroup rpmts
* Get verify signatures flag(s).
* @param ts        transaction set
* @return        verify signatures flags
*/
rpmVSFlags rpmtsVSFlags(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set verify signatures flag(s).
* @param ts        transaction set
* @param vsflags    new verify signatures flags
* @return        previous value
*/
rpmVSFlags rpmtsSetVSFlags(rpmts ts, rpmVSFlags vsflags)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Set index of 1st element of successors.
* @param ts        transaction set
* @param first        new index of 1st element of successors
* @return        previous value
*/
int rpmtsUnorderedSuccessors(rpmts ts, int first)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get transaction rootDir, i.e. path to chroot(2).
* @param ts        transaction set
* @return        transaction rootDir
*/
/*@observer@*/ /*@null@*/
extern const char * rpmtsRootDir(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set transaction rootDir, i.e. path to chroot(2).
* @param ts        transaction set
* @param rootDir    new transaction rootDir (or NULL)
*/
void rpmtsSetRootDir(rpmts ts, /*@null@*/ const char * rootDir)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get transaction currDir, i.e. current directory before chroot(2).
* @param ts        transaction set
* @return        transaction currDir
*/
/*@observer@*/ /*@null@*/
extern const char * rpmtsCurrDir(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set transaction currDir, i.e. current directory before chroot(2).
* @param ts        transaction set
* @param currDir    new transaction currDir (or NULL)
*/
void rpmtsSetCurrDir(rpmts ts, /*@null@*/ const char * currDir)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get transaction script file handle, i.e. stdout/stderr on scriptlet execution
* @param ts        transaction set
* @return        transaction script file handle
*/
/*@null@*/
FD_t rpmtsScriptFd(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set transaction script file handle, i.e. stdout/stderr on scriptlet execution
* @param ts        transaction set
* @param scriptFd    new script file handle (or NULL)
*/
void rpmtsSetScriptFd(rpmts ts, /*@null@*/ FD_t scriptFd)
    /*@modifies ts, scriptFd @*/;

/** \ingroup rpmts
* Get selinuxEnabled flag, i.e. is SE linux enabled?
* @param ts        transaction set
* @return        selinuxEnabled flag
*/
int rpmtsSELinuxEnabled(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get chrootDone flag, i.e. has chroot(2) been performed?
* @param ts        transaction set
* @return        chrootDone flag
*/
int rpmtsChrootDone(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set chrootDone flag, i.e. has chroot(2) been performed?
* @param ts        transaction set
* @param chrootDone    new chrootDone flag
* @return        previous chrootDone flag
*/
int rpmtsSetChrootDone(rpmts ts, int chrootDone)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get file security context patterns.
* @param ts        transaction set
* @return        file security context patterns
*/
/*@null@*/
rpmsx rpmtsREContext(const rpmts ts)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get file security context patterns.
* @param ts        transaction set
* @param sx        security context patterns
* @return        0 on success
*/
int rpmtsSetREContext(rpmts ts, rpmsx sx)
    /*@modifies ts, sx @*/;

/** \ingroup rpmts
* Get transaction id, i.e. transaction time stamp.
* @param ts        transaction set
* @return        transaction id
*/
int_32 rpmtsGetTid(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set transaction id, i.e. transaction time stamp.
* @param ts        transaction set
* @param tid        new transaction id
* @return        previous transaction id
*/
int_32 rpmtsSetTid(rpmts ts, int_32 tid)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get signature tag.
* @param ts        transaction set
* @return        signature tag
*/
int_32 rpmtsSigtag(const rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get signature tag type.
* @param ts        transaction set
* @return        signature tag type
*/
int_32 rpmtsSigtype(const rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get signature tag data, i.e. from header.
* @param ts        transaction set
* @return        signature tag data
*/
/*@observer@*/ /*@null@*/
extern const void * rpmtsSig(const rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get signature tag data length, i.e. no. of bytes of data.
* @param ts        transaction set
* @return        signature tag data length
*/
int_32 rpmtsSiglen(const rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set signature tag info, i.e. from header.
* @param ts        transaction set
* @param sigtag    signature tag
* @param sigtype    signature tag type
* @param sig        signature tag data
* @param siglen    signature tag data length
* @return        0 always
*/
int rpmtsSetSig(rpmts ts,
        int_32 sigtag, int_32 sigtype,
        /*@kept@*/ /*@null@*/ const void * sig, int_32 siglen)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get OpenPGP packet parameters, i.e. signature/pubkey constants.
* @param ts        transaction set
* @return        signature/pubkey constants.
*/
/*@exposed@*/ /*@null@*/
pgpDig rpmtsDig(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get OpenPGP signature constants.
* @param ts        transaction set
* @return        signature constants.
*/
/*@exposed@*/ /*@null@*/
pgpDigParams rpmtsSignature(const rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get OpenPGP pubkey constants.
* @param ts        transaction set
* @return        pubkey constants.
*/
/*@exposed@*/ /*@null@*/
pgpDigParams rpmtsPubkey(const rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get transaction set database handle.
* @param ts        transaction set
* @return        transaction database handle
*/
/*@null@*/
rpmdb rpmtsGetRdb(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Initialize disk space info for each and every mounted file systems.
* @param ts        transaction set
* @return        0 on success
*/
int rpmtsInitDSI(const rpmts ts)
    /*@globals fileSystem, internalState @*/
    /*@modifies ts, fileSystem, internalState @*/;

/** \ingroup rpmts
* Update disk space info for a file.
* @param ts        transaction set
* @param dev        mount point device
* @param fileSize    file size
* @param prevSize    previous file size (if upgrading)
* @param fixupSize    size difference (if
* @param action    file disposition
*/
void rpmtsUpdateDSI(const rpmts ts, dev_t dev,
        uint_32 fileSize, uint_32 prevSize, uint_32 fixupSize,
        fileAction action)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Check a transaction element for disk space problems.
* @param ts        transaction set
* @param te        current transaction element
*/
void rpmtsCheckDSIProblems(const rpmts ts, const rpmte te)
    /*@modifies ts @*/;

/**
* Perform transaction progress notify callback.
* @param ts        transaction set
* @param te        current transaction element
* @param what        type of call back
* @param amount    current value
* @param total        final value
* @return        callback dependent pointer
*/
/*@null@*/
void * rpmtsNotify(rpmts ts, rpmte te,
                rpmCallbackType what, unsigned long amount, unsigned long total)
    /*@*/;

/**
* Return number of (ordered) transaction set elements.
* @param ts        transaction set
* @return        no. of transaction set elements
*/
int rpmtsNElements(rpmts ts)
    /*@*/;

/**
* Return (ordered) transaction set element.
* @param ts        transaction set
* @param ix        transaction element index
* @return        transaction element (or NULL)
*/
/*@null@*/ /*@dependent@*/
rpmte rpmtsElement(rpmts ts, int ix)
    /*@*/;

/** \ingroup rpmts
* Get problem ignore bit mask, i.e. bits to filter encountered problems.
* @param ts        transaction set
* @return        ignore bit mask
*/
rpmprobFilterFlags rpmtsFilterFlags(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Get transaction flags, i.e. bits that control rpmtsRun().
* @param ts        transaction set
* @return        transaction flags
*/
rpmtransFlags rpmtsFlags(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set transaction flags, i.e. bits that control rpmtsRun().
* @param ts        transaction set
* @param transFlags    new transaction flags
* @return        previous transaction flags
*/
rpmtransFlags rpmtsSetFlags(rpmts ts, rpmtransFlags transFlags)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get spec control structure from transaction set.
* @param ts        transaction set
* @return        spec control structure
*/
/*@null@*/
Spec rpmtsSpec(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set a spec control structure in transaction set.
* @param ts        transaction set
* @param spec        new spec control structure
* @return        previous spec control structure
*/
/*@null@*/
Spec rpmtsSetSpec(rpmts ts, /*@null@*/ Spec spec)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Get current relocate transaction element.
* @param ts        transaction set
* @return        current relocate transaction element
*/
/*@null@*/
rpmte rpmtsRelocateElement(rpmts ts)
    /*@*/;

/** \ingroup rpmts
* Set current relocate transaction element.
* @param ts        transaction set
* @param relocateElement new relocate transaction element
* @return        previous relocate transaction element
*/
/*@null@*/
rpmte rpmtsSetRelocateElement(rpmts ts, /*@null@*/ rpmte relocateElement)
    /*@modifies ts @*/;

/**
* Retrieve color bits of transaction set.
* @param ts        transaction set
* @return        color bits
*/
uint_32 rpmtsColor(rpmts ts)
    /*@*/;

/**
* Set color bits of transaction set.
* @param ts        transaction set
* @param color        new color bits
* @return        previous color bits
*/
uint_32 rpmtsSetColor(rpmts ts, uint_32 color)
    /*@modifies ts @*/;

/**
* Retrieve operation timestamp from a transaction set.
* @param ts        transaction set
* @param opx        operation timestamp index
* @return        pointer to operation timestamp.
*/
/*@relnull@*/
rpmop rpmtsOp(rpmts ts, rpmtsOpX opx)
    /*@*/;

/** \ingroup rpmts
* Set transaction notify callback function and argument.
*
* @warning This call must be made before rpmtsRun() for
*    install/upgrade/freshen to function correctly.
*
* @param ts        transaction set
* @param notify    progress callback
* @param notifyData    progress callback private data
* @return        0 on success
*/
int rpmtsSetNotifyCallback(rpmts ts,
        /*@observer@*/ rpmCallbackFunction notify,
        /*@observer@*/ rpmCallbackData notifyData)
    /*@modifies ts @*/;

/** \ingroup rpmts
* Create an empty transaction set.
* @return        new transaction set
*/
/*@newref@*/
rpmts rpmtsCreate(void)
    /*@globals rpmGlobalMacroContext, h_errno, internalState @*/
    /*@modifies rpmGlobalMacroContext, internalState @*/;

/** \ingroup rpmts
* Add package to be installed to transaction set.
*
* The transaction set is checked for duplicate package names.
* If found, the package with the "newest" EVR will be replaced.
*
* @param ts        transaction set
* @param h        header
* @param key        package retrieval key (e.g. file name)
* @param upgrade    is package being upgraded?
* @param relocs    package file relocations
* @return        0 on success, 1 on I/O error, 2 needs capabilities
*/
int rpmtsAddInstallElement(rpmts ts, Header h,
        /*@exposed@*/ /*@null@*/ const fnpyKey key, int upgrade,
        /*@null@*/ rpmRelocation * relocs)
    /*@globals rpmcliPackagesTotal, rpmGlobalMacroContext, h_errno,
        fileSystem, internalState @*/
    /*@modifies ts, h, rpmcliPackagesTotal, rpmGlobalMacroContext,
        fileSystem, internalState @*/;

/** \ingroup rpmts
* Add package to be erased to transaction set.
* @param ts        transaction set
* @param h        header
* @param dboffset    rpm database instance
* @return        0 on success
*/
int rpmtsAddEraseElement(rpmts ts, Header h, int dboffset)
    /*@globals rpmGlobalMacroContext, h_errno, fileSystem, internalState @*/
    /*@modifies ts, h, rpmGlobalMacroContext, fileSystem, internalState @*/;

/** \ingroup rpmts
* Retrieve keys from ordered transaction set.
* @todo Removed packages have no keys, returned as interleaved NULL pointers.
* @param ts        transaction set
* @retval ep        address of returned element array pointer (or NULL)
* @retval nep        address of no. of returned elements (or NULL)
* @return        0 always
*/
/*@unused@*/
int rpmtsGetKeys(rpmts ts,
        /*@null@*/ /*@out@*/ fnpyKey ** ep,
        /*@null@*/ /*@out@*/ int * nep)
    /*@globals fileSystem, internalState @*/
    /*@modifies ts, ep, nep, fileSystem, internalState @*/;

/**
* Return (malloc'd) header name-version-release string.
* @param h        header
* @retval np        name tag value
* @return        name-version-release string
*/
/*@only@*/ char * hGetNEVR(Header h, /*@null@*/ /*@out@*/ const char ** np )
    /*@modifies *np @*/;

/**
* Return (malloc'd) header name-version-release.arch string.
* @param h        header
* @retval np        name tag value
* @return        name-version-release string
*/
/*@only@*/ char * hGetNEVRA(Header h, /*@null@*/ /*@out@*/ const char ** np )
    /*@modifies *np @*/;

/**
* Return header color.
* @param h        header
* @return        header color
*/
uint_32 hGetColor(Header h)
    /*@modifies h @*/;

#ifdef __cplusplus
}
#endif


#endif    /* H_RPMTS */

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 1.0 pre-release build #16 powered by Captain Crunch Security Team | http://ccteam.ru | Generation time: 0.0043 ]--