rpm  4.9.1.3
Data Structures | Functions
RPM Tag Data Container API.

Data Structures

struct  rpmtd_s
 Container for rpm tag data (from headers or extensions). More...

Functions

rpmtd rpmtdNew (void)
 Create new tag data container.
rpmtd rpmtdFree (rpmtd td)
 Destroy tag data container.
void rpmtdReset (rpmtd td)
 (Re-)initialize tag data container.
void rpmtdFreeData (rpmtd td)
 Free contained data.
rpm_count_t rpmtdCount (rpmtd td)
 Retrieve array size of the container.
rpmTagVal rpmtdTag (rpmtd td)
 Retrieve tag of the container.
rpmTagType rpmtdType (rpmtd td)
 Retrieve type of the container.
rpmTagClass rpmtdClass (rpmtd td)
 Retrieve class of the container.
int rpmtdGetIndex (rpmtd td)
 Retrieve current iteration index of the container.
int rpmtdSetIndex (rpmtd td, int index)
 Set iteration index of the container.
int rpmtdInit (rpmtd td)
 Initialize tag container for iteration.
int rpmtdNext (rpmtd td)
 Iterate over tag data container.
uint32_t * rpmtdNextUint32 (rpmtd td)
 Iterate over uint32_t type tag data container.
uint64_t * rpmtdNextUint64 (rpmtd td)
 Iterate over uint64_t type tag data container.
const char * rpmtdNextString (rpmtd td)
 Iterate over string / string array type tag data container.
char * rpmtdGetChar (rpmtd td)
 Return char data from tag container.
uint16_t * rpmtdGetUint16 (rpmtd td)
 Return uint16_t data from tag container.
uint32_t * rpmtdGetUint32 (rpmtd td)
 Return uint32_t data from tag container.
uint64_t * rpmtdGetUint64 (rpmtd td)
 Return uint64_t data from tag container.
const char * rpmtdGetString (rpmtd td)
 Return string data from tag container.
uint64_t rpmtdGetNumber (rpmtd td)
 Return numeric value from tag container.
char * rpmtdFormat (rpmtd td, rpmtdFormats fmt, const char *errmsg)
 Format data from tag container to string presentation of given format.
int rpmtdSetTag (rpmtd td, rpmTagVal tag)
 Set container tag and type.
int rpmtdFromUint8 (rpmtd td, rpmTagVal tag, uint8_t *data, rpm_count_t count)
 Construct tag container from uint8_t pointer.
int rpmtdFromUint16 (rpmtd td, rpmTagVal tag, uint16_t *data, rpm_count_t count)
 Construct tag container from uint16_t pointer.
int rpmtdFromUint32 (rpmtd td, rpmTagVal tag, uint32_t *data, rpm_count_t count)
 Construct tag container from uint32_t pointer.
int rpmtdFromUint64 (rpmtd td, rpmTagVal tag, uint64_t *data, rpm_count_t count)
 Construct tag container from uint64_t pointer.
int rpmtdFromString (rpmtd td, rpmTagVal tag, const char *data)
 Construct tag container from a string.
int rpmtdFromStringArray (rpmtd td, rpmTagVal tag, const char **data, rpm_count_t count)
 Construct tag container from a string array.
int rpmtdFromArgv (rpmtd td, rpmTagVal tag, ARGV_t argv)
 Construct tag container from ARGV_t array.
int rpmtdFromArgi (rpmtd td, rpmTagVal tag, ARGI_t argi)
 Construct tag container from ARGI_t array.

Function Documentation

rpmTagClass rpmtdClass ( rpmtd  td)

Retrieve class of the container.

Parameters:
tdTag data container
Returns:
Rpm tag class
rpm_count_t rpmtdCount ( rpmtd  td)

Retrieve array size of the container.

For non-array types this is always 1.

Parameters:
tdTag data container
Returns:
Number of entries in contained data.
char* rpmtdFormat ( rpmtd  td,
rpmtdFormats  fmt,
const char *  errmsg 
)

Format data from tag container to string presentation of given format.

Return malloced string presentation of current data in container, converting from integers etc as necessary. On array types, data from current iteration index is used for formatting.

Parameters:
tdTag data container
fmtFormat to apply
errmsgError message from conversion (or NULL)
Returns:
String representation of current data (malloc'ed), NULL on error
rpmtd rpmtdFree ( rpmtd  td)

Destroy tag data container.

Parameters:
tdTag data container
Returns:
NULL always
void rpmtdFreeData ( rpmtd  td)

Free contained data.

This is always safe to call as the container knows if data was malloc'ed or not. Container is reinitialized.

Parameters:
tdTag data container
int rpmtdFromArgi ( rpmtd  td,
rpmTagVal  tag,
ARGI_t  argi 
)

Construct tag container from ARGI_t array.

Tag type is checked to be of integer array type and array is checked to be non-empty.

Parameters:
tdTag data container
tagRpm tag to construct
argiARGI array
Returns:
1 on success, 0 on error (eg wrong type)
int rpmtdFromArgv ( rpmtd  td,
rpmTagVal  tag,
ARGV_t  argv 
)

Construct tag container from ARGV_t array.

Tag type is checked to be of string array type and array is checked to be non-empty.

Parameters:
tdTag data container
tagRpm tag to construct
argvARGV array
Returns:
1 on success, 0 on error (eg wrong type)
int rpmtdFromString ( rpmtd  td,
rpmTagVal  tag,
const char *  data 
)

Construct tag container from a string.

Tag type is checked to be of string type.

Parameters:
tdTag data container
tagRpm tag to construct
dataString to use
Returns:
1 on success, 0 on error (eg wrong type)
int rpmtdFromStringArray ( rpmtd  td,
rpmTagVal  tag,
const char **  data,
rpm_count_t  count 
)

Construct tag container from a string array.

Tag type is checked to be of string or string array type. For non-array types count must be exactly 1.

Parameters:
tdTag data container
tagRpm tag to construct
dataPointer to string array
countNumber of entries
Returns:
1 on success, 0 on error (eg wrong type)
int rpmtdFromUint16 ( rpmtd  td,
rpmTagVal  tag,
uint16_t *  data,
rpm_count_t  count 
)

Construct tag container from uint16_t pointer.

Tag type is checked to be of INT16 type. For non-array types count must be exactly 1.

Parameters:
tdTag data container
tagRpm tag to construct
dataPointer to uint16_t (value or array)
countNumber of entries
Returns:
1 on success, 0 on error (eg wrong type)
int rpmtdFromUint32 ( rpmtd  td,
rpmTagVal  tag,
uint32_t *  data,
rpm_count_t  count 
)

Construct tag container from uint32_t pointer.

Tag type is checked to be of INT32 type. For non-array types count must be exactly 1.

Parameters:
tdTag data container
tagRpm tag to construct
dataPointer to uint32_t (value or array)
countNumber of entries
Returns:
1 on success, 0 on error (eg wrong type)
int rpmtdFromUint64 ( rpmtd  td,
rpmTagVal  tag,
uint64_t *  data,
rpm_count_t  count 
)

Construct tag container from uint64_t pointer.

Tag type is checked to be of INT64 type. For non-array types count must be exactly 1.

Parameters:
tdTag data container
tagRpm tag to construct
dataPointer to uint64_t (value or array)
countNumber of entries
Returns:
1 on success, 0 on error (eg wrong type)
int rpmtdFromUint8 ( rpmtd  td,
rpmTagVal  tag,
uint8_t *  data,
rpm_count_t  count 
)

Construct tag container from uint8_t pointer.

Tag type is checked to be of compatible type (CHAR, INT8 or BIN). For non-array types (BIN is a special case of INT8 array) count must be exactly 1.

Parameters:
tdTag data container
tagRpm tag to construct
dataPointer to uint8_t (value or array)
countNumber of entries
Returns:
1 on success, 0 on error (eg wrong type)
char* rpmtdGetChar ( rpmtd  td)

Return char data from tag container.

For scalar return type, just return pointer to the integer. On array types, return pointer to current iteration index. If the tag container is not for char type, NULL is returned.

Parameters:
tdTag data container
Returns:
Pointer to uint16_t, NULL on error
int rpmtdGetIndex ( rpmtd  td)

Retrieve current iteration index of the container.

Parameters:
tdTag data container
Returns:
Iteration index (or -1 if not iterating)
uint64_t rpmtdGetNumber ( rpmtd  td)

Return numeric value from tag container.

Returns the value of numeric container (RPM_NUMERIC_CLASS) from current iteration index as uint64_t regardless of its internal presentation (8/16/32/64-bit integer).

Parameters:
tdTag data container
Returns:
Value of current iteration item as uint64_t, 0 for non-numeric types (error)
const char* rpmtdGetString ( rpmtd  td)

Return string data from tag container.

For string types, just return the string. On string array types, return the string from current iteration index. If the tag container is not for a string type, NULL is returned.

Parameters:
tdTag data container
Returns:
String constant from container, NULL on error
uint16_t* rpmtdGetUint16 ( rpmtd  td)

Return uint16_t data from tag container.

For scalar return type, just return pointer to the integer. On array types, return pointer to current iteration index. If the tag container is not for int16 type, NULL is returned.

Parameters:
tdTag data container
Returns:
Pointer to uint16_t, NULL on error
uint32_t* rpmtdGetUint32 ( rpmtd  td)

Return uint32_t data from tag container.

For scalar return type, just return pointer to the integer. On array types, return pointer to current iteration index. If the tag container is not for int32 type, NULL is returned.

Parameters:
tdTag data container
Returns:
Pointer to uint32_t, NULL on error
uint64_t* rpmtdGetUint64 ( rpmtd  td)

Return uint64_t data from tag container.

For scalar return type, just return pointer to the integer. On array types, return pointer to current iteration index. If the tag container is not for int64 type, NULL is returned.

Parameters:
tdTag data container
Returns:
Pointer to uint64_t, NULL on error
int rpmtdInit ( rpmtd  td)

Initialize tag container for iteration.

Parameters:
tdTag data container
Returns:
0 on success
rpmtd rpmtdNew ( void  )

Create new tag data container.

Returns:
New, initialized tag data container.
int rpmtdNext ( rpmtd  td)

Iterate over tag data container.

Parameters:
tdTag data container
Returns:
Tag data container iterator index, -1 on termination
const char* rpmtdNextString ( rpmtd  td)

Iterate over string / string array type tag data container.

Parameters:
tdTag data container
Returns:
Pointer to next value, NULL on termination or error
uint32_t* rpmtdNextUint32 ( rpmtd  td)

Iterate over uint32_t type tag data container.

Parameters:
tdTag data container
Returns:
Pointer to next value, NULL on termination or error
uint64_t* rpmtdNextUint64 ( rpmtd  td)

Iterate over uint64_t type tag data container.

Parameters:
tdTag data container
Returns:
Pointer to next value, NULL on termination or error
void rpmtdReset ( rpmtd  td)

(Re-)initialize tag data container.

Contents will be zeroed out and iteration index reset.

Parameters:
tdTag data container
int rpmtdSetIndex ( rpmtd  td,
int  index 
)

Set iteration index of the container.

If new index is out of bounds for the container, -1 is returned and iteration index is left untouched.

Parameters:
tdTag data container
indexNew index
Returns:
New index, or -1 if index out of bounds
int rpmtdSetTag ( rpmtd  td,
rpmTagVal  tag 
)

Set container tag and type.

For empty container, any valid tag can be set. If the container has data, changing is only permitted to tag of same type.

Parameters:
tdTag data container
tagNew tag
Returns:
1 on success, 0 on error
rpmTagVal rpmtdTag ( rpmtd  td)

Retrieve tag of the container.

Parameters:
tdTag data container
Returns:
Rpm tag.
rpmTagType rpmtdType ( rpmtd  td)

Retrieve type of the container.

Parameters:
tdTag data container
Returns:
Rpm tag type.