createrepo_c library  0.9.1
C library for metadata manipulation
Miscellaneous useful functions and macros.

Data Structures

struct  cr_EVR
 
struct  cr_NEVR
 
struct  cr_NEVRA
 
struct  cr_Version
 
struct  cr_HeaderRangeStruct
 

Macros

#define CR_STATICSTRLEN(s)   (sizeof(s)/sizeof(s[0]))
 
#define CR_ARRAYLEN(x)   ((sizeof(x)/sizeof(0[x])) / ((size_t)(!(sizeof(x) % sizeof(0[x])))))
 
#define cr_compress_file(SRC, DST, COMTYPE, ERR)   cr_compress_file_with_stat(SRC, DST, COMTYPE, NULL, ERR)
 
#define cr_decompress_file(SRC, DST, COMTYPE, ERR)   cr_decompress_file_with_stat(SRC, DST, COMTYPE, NULL, ERR)
 
#define cr_cmp_nevra(A, B)
 

Enumerations

enum  cr_CpFlags { CR_CP_DEFAULT = (1<<0), CR_CP_RECURSIVE = (1<<1), CR_CP_PRESERVE_ALL = (1<<2) }
 
enum  cr_RmFlags { CR_RM_DEFAULT = (1<<0), CR_RM_RECURSIVE = (1<<1), CR_RM_FORCE = (1<<2) }
 

Functions

const char * cr_flag_to_str (gint64 flags)
 
cr_EVRcr_str_to_evr (const char *string, GStringChunk *chunk)
 
void cr_evr_free (cr_EVR *evr)
 
struct cr_HeaderRangeStruct cr_get_header_byte_range (const char *filename, GError **err)
 
char * cr_get_filename (const char *filepath)
 
int cr_download (CURL *handle, const char *url, const char *destination, GError **err)
 
gboolean cr_copy_file (const char *src, const char *dst, GError **err)
 
int cr_compress_file_with_stat (const char *src, const char *dst, cr_CompressionType comtype, cr_ContentStat *stat, GError **err)
 
int cr_decompress_file_with_stat (const char *src, const char *dst, cr_CompressionType comtype, cr_ContentStat *stat, GError **err)
 
gboolean cr_better_copy_file (const char *src, const char *dst, GError **err)
 
int cr_remove_dir (const char *path, GError **err)
 
char * cr_normalize_dir_path (const char *path)
 
struct cr_Version cr_str_to_version (const char *str)
 
int cr_cmp_version_str (const char *str1, const char *str2)
 
void cr_null_log_fn (const gchar *log_domain, GLogLevelFlags log_level, const gchar *message, gpointer user_data)
 
void cr_log_fn (const gchar *log_domain, GLogLevelFlags log_level, const gchar *message, gpointer user_data)
 
void cr_slist_free_full (GSList *list, GDestroyNotify free_f)
 
void cr_queue_free_full (GQueue *queue, GDestroyNotify free_f)
 
cr_NEVRAcr_split_rpm_filename (const char *filename)
 
int cr_cmp_evr (const char *e1, const char *v1, const char *r1, const char *e2, const char *v2, const char *r2)
 
int cr_warning_cb (cr_XmlParserWarningType type, char *msg, void *cbdata, GError **err)
 
gboolean cr_write_to_file (GError **err, gchar *filename, const char *format,...)
 
gboolean cr_cp (const char *src, const char *dst, cr_CpFlags flags, const char *working_directory, GError **err)
 
gboolean cr_rm (const char *path, cr_RmFlags flags, const char *working_dir, GError **err)
 
gchar * cr_append_pid_and_datetime (const char *str, const char *suffix)
 
gboolean cr_spawn_check_exit_status (gint exit_status, GError **error)
 
cr_NEVRcr_str_to_nevr (const char *str)
 
void cr_nevr_free (cr_NEVR *nevr)
 
cr_NEVRAcr_str_to_nevra (const char *str)
 
void cr_nevra_free (cr_NEVRA *nevra)
 
gboolean cr_identical_files (const gchar *fn1, const gchar *fn2, gboolean *identical, GError **err)
 
gchar * cr_cut_dirs (gchar *path, gint cut_dirs)
 

Detailed Description

Macro Definition Documentation

#define cr_cmp_nevra (   A,
 
)
Value:
(cr_cmp_evr((A)->epoch, (A)->version, (A)->release,\
(B)->epoch, (B)->version, (B)->release))
int cr_cmp_evr(const char *e1, const char *v1, const char *r1, const char *e2, const char *v2, const char *r2)

Compare evr of two cr_NEVRA. Name and arch are ignored.

Parameters
Apointer to first cr_NEVRA
Bpointer to second cr_NEVRA
Returns
0 = same, 1 = first is newer, -1 = second is newer

Definition at line 316 of file misc.h.

#define cr_compress_file (   SRC,
  DST,
  COMTYPE,
  ERR 
)    cr_compress_file_with_stat(SRC, DST, COMTYPE, NULL, ERR)

Compress file.

Parameters
SRCsource filename
DSTdestination (If dst is dir, filename of src + compression suffix is used. If dst is NULL, src + compression suffix is used)
COMTYPEtype of compression
ERRGError **
Returns
cr_Error return code

Definition at line 174 of file misc.h.

#define cr_decompress_file (   SRC,
  DST,
  COMTYPE,
  ERR 
)    cr_decompress_file_with_stat(SRC, DST, COMTYPE, NULL, ERR)

Decompress file.

Parameters
SRCsource filename
DSTdestination (If dst is dir, filename of src without compression suffix (if present) is used. If dst is NULL, src without compression suffix is used) Otherwise ".decompressed" suffix is used
COMTYPEtype of compression
ERRGError **
Returns
cr_Error return code

Definition at line 203 of file misc.h.

#define CR_STATICSTRLEN (   s)    (sizeof(s)/sizeof(s[0]))

Lenght of static string (including last '\0' byte)

Definition at line 40 of file misc.h.

Enumeration Type Documentation

enum cr_CpFlags
Enumerator
CR_CP_DEFAULT 

No attributes - default

CR_CP_RECURSIVE 

Copy directories recursively

CR_CP_PRESERVE_ALL 

preserve the all attributes (if possible)

Definition at line 420 of file misc.h.

enum cr_RmFlags
Enumerator
CR_RM_DEFAULT 

No attributes - default

CR_RM_RECURSIVE 

Copy directories recursively

CR_RM_FORCE 

Use force

Definition at line 443 of file misc.h.

Function Documentation

gchar* cr_append_pid_and_datetime ( const char *  str,
const char *  suffix 
)

Append "YYYYmmddHHMMSS.MICROSECONDS.PID" suffix to the str.

Parameters
strString or NULL
suffixAnother string that will be appended or NULL
returnNewly allocated string
gboolean cr_better_copy_file ( const char *  src,
const char *  dst,
GError **  err 
)

Better copy file. Source (src) could be remote address (http:// or ftp://).

Parameters
srcsource filename
dstdestination (if dst is dir, filename of src is used)
errGError **
Returns
TRUE on success, FALSE if an error occured
int cr_cmp_evr ( const char *  e1,
const char *  v1,
const char *  r1,
const char *  e2,
const char *  v2,
const char *  r2 
)

Compare two version strings splited into evr chunks.

Parameters
e11. epoch
v11. version
r11. release
e22. epoch
v22. version
r22. release
Returns
0 = same, 1 = first is newer, -1 = second is newer
int cr_cmp_version_str ( const char *  str1,
const char *  str2 
)

Compare two version string.

Parameters
str1first version string
str2second version string
Returns
0 - versions are same, 1 - first string is bigger version, 2 - second string is bigger version
int cr_compress_file_with_stat ( const char *  src,
const char *  dst,
cr_CompressionType  comtype,
cr_ContentStat stat,
GError **  err 
)

Compress file.

Parameters
srcsource filename
dstdestination (If dst is dir, filename of src + compression suffix is used. If dst is NULL, src + compression suffix is used)
comtypetype of compression
statpointer to cr_ContentStat or NULL
errGError **
Returns
cr_Error return code
gboolean cr_copy_file ( const char *  src,
const char *  dst,
GError **  err 
)

Copy file.

Parameters
srcsource filename
dstdestination (if dst is dir, filename of src is used)
errGError **
Returns
TRUE on success, FALSE if an error occured
gboolean cr_cp ( const char *  src,
const char *  dst,
cr_CpFlags  flags,
const char *  working_directory,
GError **  err 
)

Recursive copy of directory (works on files as well)

Parameters
srcSource (supports wildcards)
dstDestination (supports wildcards)
flagsFlags
working_dirWorking directory
errGError **
gchar* cr_cut_dirs ( gchar *  path,
gint  cut_dirs 
)

Cut first N components of path. Note: Basename is never cut out.

int cr_decompress_file_with_stat ( const char *  src,
const char *  dst,
cr_CompressionType  comtype,
cr_ContentStat stat,
GError **  err 
)

Decompress file.

Parameters
srcsource filename
dstdestination (If dst is dir, filename of src without compression suffix (if present) is used. If dst is NULL, src without compression suffix is used) Otherwise ".decompressed" suffix is used
comtypetype of compression
statpointer to cr_ContentStat or NULL
errGError **
Returns
cr_Error return code
int cr_download ( CURL *  handle,
const char *  url,
const char *  destination,
GError **  err 
)

Download a file from the URL into the in_dst via curl handle.

Parameters
handleCURL handle
urlsource url
destinationdestination (if destination is dir, filename from the url is used)
errGError **
Returns
cr_Error
void cr_evr_free ( cr_EVR evr)

Free cr_EVR Warning: Do not use this function when a string chunk was used in the cr_str_to_evr! In that case use only g_free on the cr_EVR pointer.

Parameters
evrcr_EVR structure
const char* cr_flag_to_str ( gint64  flags)

Convert flags from RPM header to a string representation.

Parameters
flagsflags
Returns
flags as constant string
char* cr_get_filename ( const char *  filepath)

Return pointer to the rest of string after last '/'. (e.g. for "/foo/bar" returns "bar")

Parameters
filepathpath
Returns
pointer into the path
struct cr_HeaderRangeStruct cr_get_header_byte_range ( const char *  filename,
GError **  err 
)

Return header byte range.

Parameters
filenamefilename
errGError **
Returns
header range (start = end = 0 on error)
gboolean cr_identical_files ( const gchar *  fn1,
const gchar *  fn2,
gboolean *  identical,
GError **  err 
)

Are the files identical? Different paths could point to the same file. This functions checks if both paths point to the same file or not. If one of the files doesn't exists, the funcion doesn't fail and just put FALSE into "indentical" value and returns.

Parameters
fn1First path
fn2Second path
identicalAre the files same or not
errGError **
Returns
FALSE if an error was encountered, TRUE otherwise
void cr_log_fn ( const gchar *  log_domain,
GLogLevelFlags  log_level,
const gchar *  message,
gpointer  user_data 
)

Createrepo_c library standard logging function.

Parameters
log_domainlogging domain
log_levellogging level
messagemessage
user_datauser data
void cr_nevr_free ( cr_NEVR nevr)

Free cr_NEVR

Parameters
nevrcr_NEVR structure
void cr_nevra_free ( cr_NEVRA nevra)

Free cr_NEVRA

Parameters
nevracr_NEVRA structure
char* cr_normalize_dir_path ( const char *  path)

Normalize path (Path with exactly one trailing '/').

Parameters
pathpath
Returns
mallocated string with normalized path or NULL
void cr_null_log_fn ( const gchar *  log_domain,
GLogLevelFlags  log_level,
const gchar *  message,
gpointer  user_data 
)

Logging function with no output.

Parameters
log_domainlogging domain
log_levellogging level
messagemessage
user_datauser data
void cr_queue_free_full ( GQueue *  queue,
GDestroyNotify  free_f 
)

Convenience method, which frees all the memory used by a GQueue, and calls the specified destroy function on every element's data. This is the same function as g_queue_free_full(). The original function is implemented in glib since 2.32 but we need to support the older glib too.

Parameters
queuea pointer to a GQueue
thefunction to be called to free each element's data
int cr_remove_dir ( const char *  path,
GError **  err 
)

Recursively remove directory.

Parameters
pathfilepath
errGError **
Returns
cr_Error return code
gboolean cr_rm ( const char *  path,
cr_RmFlags  flags,
const char *  working_dir,
GError **  err 
)

Wrapper over rm command

Parameters
pathPath (supports wildcards)
flagsFlags
working_dirWorking directory
errGError **
void cr_slist_free_full ( GSList *  list,
GDestroyNotify  free_f 
)

Frees all the memory used by a GSList, and calls the specified destroy function on every element's data. This is the same function as g_slist_free_full(). The original function is implemented in glib since 2.28 but we need to support the older glib too.

Parameters
listpointer to GSList
free_fthe function to be called to free each element's data
gboolean cr_spawn_check_exit_status ( gint  exit_status,
GError **  error 
)

Createrepo_c's reimplementation of convinient g_spawn_check_exit_status() function which is available since glib 2.34 (createrepo_c is currently compatible with glib >= 2.28)

Parameters
exit_statusAn exit code as returned from g_spawn_sync()
errorGError **
Returns
TRUE if child exited successfully, FALSE otherwise (and error will be set)
cr_NEVRA* cr_split_rpm_filename ( const char *  filename)

Split filename into the NEVRA. Supported formats: [path/]N-V-R:E.A[.rpm] [path/]E:N-V-R.A[.rpm] [path/]N-E:V-R.A[.rpm] [path/]N-V-R.A[.rpm]:E

Parameters
filenamefilename
Returns
cr_NEVRA
cr_EVR* cr_str_to_evr ( const char *  string,
GStringChunk *  chunk 
)

Convert epoch-version-release string into cr_EVR structure. If no GStringChunk passed, all non NULL items in returned structure are malloced and in that case, you have to free all non-NULL element yourself.

Parameters
stringNULL terminated n-v-r string
chunkstring chunk for strings (optional - could be NULL)
Returns
filled NVR
cr_NEVR* cr_str_to_nevr ( const char *  str)

Parse E:N-V-R or N-V-R:E or N-E:V-R string

Parameters
strNEVR string
Returns
Malloced cr_NEVR or NULL on error
cr_NEVRA* cr_str_to_nevra ( const char *  str)

Parse E:N-V-R.A, N-V-R:E.A, N-E:V-R.A or N-V-R.A:E string.

Parameters
strNEVRA string
Returns
Malloced cr_NEVRA or NULL on error
struct cr_Version cr_str_to_version ( const char *  str)

Convert version string into cr_Version struct.

Parameters
strversion string
Returns
cr_Version
int cr_warning_cb ( cr_XmlParserWarningType  type,
char *  msg,
void *  cbdata,
GError **  err 
)

Warning callback for xml parser warnings. For use in xml parsers like primary, filelists, other or repomd parser. Name of the parser should be passed as a string via warning callback data (warningcb_data) argument of the parser.

gboolean cr_write_to_file ( GError **  err,
gchar *  filename,
const char *  format,
  ... 
)

Open file and write content.

Parameters
errGError **
filenameFilename
formatFormat string
...Arguments