2002-03-25 23:16:26 +03:00
# ifndef H_HEADER_INTERNAL
# define H_HEADER_INTERNAL
/** \ingroup header
* \ file lib / header_internal . h
*/
2006-05-15 02:57:16 +04:00
# include "header.h"
2002-03-25 23:16:26 +03:00
# if !defined(__LCLINT__)
# include <netinet/in.h>
# endif /* __LCLINT__ */
# define INDEX_MALLOC_SIZE 8
/*
* Teach header . c about legacy tags .
*/
# define HEADER_OLDFILENAMES 1027
# define HEADER_BASENAMES 1117
/** \ingroup header
* Description of tag data .
*/
typedef /*@abstract@*/ struct entryInfo * entryInfo ;
struct entryInfo {
int_32 tag ; /*!< Tag identifier. */
int_32 type ; /*!< Tag data type. */
int_32 offset ; /*!< Offset into data segment (ondisk only). */
int_32 count ; /*!< Number of tag elements. */
} ;
# define REGION_TAG_TYPE RPM_BIN_TYPE
# define REGION_TAG_COUNT sizeof(struct entryInfo)
# define ENTRY_IS_REGION(_e) \
( ( ( _e ) - > info . tag > = HEADER_IMAGE ) & & ( ( _e ) - > info . tag < HEADER_REGIONS ) )
# define ENTRY_IN_REGION(_e) ((_e)->info.offset < 0)
/** \ingroup header
* A single tag from a Header .
*/
typedef /*@abstract@*/ struct indexEntry * indexEntry ;
struct indexEntry {
struct entryInfo info ; /*!< Description of tag data. */
/*@owned@*/ void * data ; /*!< Location of tag data. */
int length ; /*!< No. bytes of data. */
int rdlen ; /*!< No. bytes of data in region. */
} ;
/** \ingroup header
* The Header data structure .
*/
struct headerToken {
/*@unused@*/ struct HV_s hv ; /*!< Header public methods. */
void * blob ; /*!< Header region blob. */
/*@owned@*/ indexEntry index ; /*!< Array of tags. */
int indexUsed ; /*!< Current size of tag array. */
int indexAlloced ; /*!< Allocated size of tag array. */
int flags ;
# define HEADERFLAG_SORTED (1 << 0) /*!< Are header entries sorted? */
# define HEADERFLAG_ALLOCATED (1 << 1) /*!< Is 1st header region allocated? */
# define HEADERFLAG_LEGACY (1 << 2) /*!< Header came from legacy source? */
/*@refs@*/ int nrefs ; /*!< Reference count. */
} ;
/** \ingroup header
*/
typedef /*@abstract@*/ struct sprintfTag * sprintfTag ;
struct sprintfTag {
/*@null@*/ headerTagTagFunction ext ; /*!< if NULL tag element is invalid */
int extNum ;
int_32 tag ;
int justOne ;
int arrayCount ;
/*@kept@*/ char * format ;
/*@kept@*/ /*@null@*/ char * type ;
int pad ;
} ;
/** \ingroup header
*/
typedef /*@abstract@*/ struct extensionCache * extensionCache ;
struct extensionCache {
int_32 type ;
int_32 count ;
int avail ;
int freeit ;
/*@owned@*/ const void * data ;
} ;
/** \ingroup header
*/
/*@-fielduse@*/
typedef /*@abstract@*/ struct sprintfToken * sprintfToken ;
struct sprintfToken {
enum {
PTOK_NONE = 0 ,
PTOK_TAG ,
PTOK_ARRAY ,
PTOK_STRING ,
PTOK_COND
} type ;
union {
struct {
/*@only@*/ sprintfToken format ;
int numTokens ;
} array ;
struct sprintfTag tag ;
struct {
/*@dependent@*/ char * string ;
int len ;
} string ;
struct {
/*@only@*/ /*@null@*/ sprintfToken ifFormat ;
int numIfTokens ;
/*@only@*/ /*@null@*/ sprintfToken elseFormat ;
int numElseTokens ;
2002-07-20 14:39:40 +04:00
struct {
enum { TRIVIAL , StringTAG_String3 } type ;
union {
struct sprintfTag tag ;
struct {
int ( * predicate ) ( const char * head , const char * const tail [ 3 ] ) ;
/* args */
sprintfToken headFormat ;
int numHeadTokens ;
const char * tail [ 3 ] ;
} tag_str3 ;
} u ;
} test ;
2002-03-25 23:16:26 +03:00
} cond ;
} u ;
} ;
/*@=fielduse@*/
# ifdef __cplusplus
extern " C " {
# endif
/** \ingroup header
* Return array of locales found in header .
* The array is terminated with a NULL sentinel .
* @ param h header
* @ return array of locales ( or NULL on error )
*/
/*@unused@*/
/*@only@*/ /*@null@*/ char * * headerGetLangs ( Header h )
/*@*/ ;
/** \ingroup header
* Retrieve tag value with type match .
* If * type is RPM_NULL_TYPE any type will match , otherwise only * type will
* match .
*
* @ param h header
* @ param tag tag
* @ retval type address of tag value data type ( or NULL )
* @ retval p address of pointer to tag value ( s ) ( or NULL )
* @ retval c address of number of values ( or NULL )
* @ return 1 on success , 0 on failure
*/
/*@-exportlocal@*/
int headerGetRawEntry ( Header h , int_32 tag ,
/*@null@*/ /*@out@*/ hTYP_t type ,
/*@null@*/ /*@out@*/ hPTR_t * p ,
/*@null@*/ /*@out@*/ hCNT_t c )
/*@modifies *type, *p, *c @*/ ;
/*@=exportlocal@*/
/** \ingroup header
* Return header reference count .
* @ param h header
* @ return no . of references
*/
/*@unused@*/ static inline int headerUsageCount ( Header h ) /*@*/ {
return h - > nrefs ;
}
/** \ingroup header
* Dump a header in human readable format ( for debugging ) .
* @ param h header
2002-08-03 20:35:14 +04:00
* @ param f
2002-03-25 23:16:26 +03:00
* @ param flags 0 or HEADER_DUMP_INLINE
* @ param tags array of tag name / value pairs
*/
/*@unused@*/
void headerDump ( Header h , FILE * f , int flags ,
const struct headerTagTableEntry_s * tags )
/*@modifies f, fileSystem @*/ ;
# define HEADER_DUMP_INLINE 1
# ifdef __cplusplus
}
# endif
# endif /* H_HEADER_INTERNAL */