27 #include "oscap_platforms.h" 36 #include "oscap_export.h" 38 #ifndef __attribute__nonnull__ 39 #define __attribute__nonnull__(x) assert((x) != NULL) 45 typedef void (*oscap_destruct_func) (
void *);
50 typedef void* (*oscap_clone_func) (
void *);
55 typedef void (*oscap_consumer_func) (
void *,
void *);
67 #define OSCAP_GENERIC_GETTER_CONV(RTYPE,CONV,SNAME,MNAME,MEXP) \ 68 RTYPE SNAME##_get_##MNAME(const struct SNAME* item) { return (CONV(item->MEXP)); } 78 #define OSCAP_GENERIC_GETTER(RTYPE,SNAME,MNAME,MEXP) \ 79 OSCAP_GENERIC_GETTER_CONV(RTYPE,,SNAME,MNAME,MEXP) 89 #define OSCAP_GENERIC_GETTER_FORCE(RTYPE,SNAME,MNAME,MEXP) \ 90 OSCAP_GENERIC_GETTER_CONV(RTYPE,(RTYPE),SNAME,MNAME,MEXP) 100 #define OSCAP_GETTER_FORCE(RTYPE,SNAME,MNAME) \ 101 OSCAP_GENERIC_GETTER_FORCE(RTYPE,SNAME,MNAME,MNAME) 111 #define OSCAP_GETTER(RTYPE,SNAME,MNAME) \ 112 OSCAP_GENERIC_GETTER(RTYPE,SNAME,MNAME,MNAME) 114 #define ITERATOR_CAST(x) ((struct oscap_iterator*)(x)) 115 #define OSCAP_ITERATOR(n) struct n##_iterator* 116 #define OSCAP_ITERATOR_FWD(n) struct n##_iterator; 117 #define OSCAP_ITERATOR_HAS_MORE(n) bool n##_iterator_has_more(OSCAP_ITERATOR(n) it) { return oscap_iterator_has_more(ITERATOR_CAST(it)); } 118 #define OSCAP_ITERATOR_NEXT(t,n) t n##_iterator_next(OSCAP_ITERATOR(n) it) { return oscap_iterator_next(ITERATOR_CAST(it)); } 119 #define OSCAP_ITERATOR_FREE(n) void n##_iterator_free(OSCAP_ITERATOR(n) it) { oscap_iterator_free(ITERATOR_CAST(it)); } 120 #define OSCAP_ITERATOR_RESET(n) void n##_iterator_reset(OSCAP_ITERATOR(n) it) { oscap_iterator_reset(ITERATOR_CAST(it)); } 121 #define OSCAP_ITERATOR_DETACH(t,n) t n##_iterator_detach(OSCAP_ITERATOR(n) it) { return oscap_iterator_detach(ITERATOR_CAST(it)); } 122 #define OSCAP_ITERATOR_GEN_T(t,n) OSCAP_ITERATOR_FWD(n) OSCAP_ITERATOR_HAS_MORE(n) OSCAP_ITERATOR_RESET(n) OSCAP_ITERATOR_NEXT(t,n) OSCAP_ITERATOR_FREE(n) 123 #define OSCAP_ITERATOR_GEN(n) OSCAP_ITERATOR_GEN_T(struct n*,n) 125 #define OSCAP_ITERATOR_REMOVE_T(t,n,destructor) \ 126 void n##_iterator_remove(OSCAP_ITERATOR(n) it) { destructor(oscap_iterator_detach(ITERATOR_CAST(it))); } 127 #define OSCAP_ITERATOR_REMOVE(n,destructor) OSCAP_ITERATOR_REMOVE_T(struct n*,n,destructor) 128 #define OSCAP_ITERATOR_REMOVE_F(n) OSCAP_ITERATOR_REMOVE(n, n##_free) 140 #define OSCAP_IGETTER_CONV(ITYPE,SNAME,MNAME,CONV) \ 141 struct ITYPE##_iterator* SNAME##_get_##MNAME(const struct SNAME* item) \ 142 { return oscap_iterator_new((CONV(item))->MNAME); } 152 #define OSCAP_IGETTER(ITYPE,SNAME,MNAME) OSCAP_IGETTER_CONV(ITYPE,SNAME,MNAME,) 159 #define OSCAP_IGETTER_GEN(ITYPE,SNAME,MNAME) OSCAP_IGETTER(ITYPE,SNAME,MNAME) OSCAP_ITERATOR_GEN(ITYPE) 170 #define OSCAP_HGETTER_EXP(RTYPE,SNAME,MNAME,MEXP) \ 171 RTYPE SNAME##_get_##MNAME(const struct SNAME* item, const char* key) \ 172 { return oscap_htable_get(item->MEXP, key); } 182 #define OSCAP_HGETTER(RTYPE,SNAME,MNAME) OSCAP_HGETTER_EXP(RTYPE,SNAME,MNAME,MNAME) 192 #define OSCAP_HGETTER_STRUCT(RTYPE,SNAME,MNAME) OSCAP_HGETTER_EXP(struct RTYPE*,SNAME,MNAME,MNAME) 194 #define OSCAP_SETTER_HEADER(SNAME, MTYPE, MNAME) bool SNAME##_set_##MNAME(struct SNAME *obj, MTYPE newval) 207 #define OSCAP_SETTER_GENERIC_CHECK(SNAME, MTYPE, MNAME, CHECK, DELETER, ASSIGNER) \ 208 OSCAP_SETTER_HEADER(SNAME, MTYPE, MNAME) \ 209 { if (!(CHECK)) return false; DELETER(obj->MNAME); obj->MNAME = ASSIGNER(newval); return true; } 215 #define OSCAP_SETTER_GENERIC(SNAME, MTYPE, MNAME, DELETER, ASSIGNER) \ 216 OSCAP_SETTER_HEADER(SNAME, MTYPE, MNAME) \ 217 { DELETER(obj->MNAME); obj->MNAME = ASSIGNER(newval); return true; } 223 #define OSCAP_SETTER_GENERIC_NODELETE(SNAME, MTYPE, MNAME, ASSIGNER) \ 224 OSCAP_SETTER_HEADER(SNAME, MTYPE, MNAME) \ 225 { obj->MNAME = ASSIGNER(newval); return true; } 231 #define OSCAP_SETTER_SIMPLE(SNAME, MTYPE, MNAME) \ 232 OSCAP_SETTER_GENERIC_NODELETE(SNAME, MTYPE, MNAME, ) 239 #define OSCAP_SETTER_STRING(SNAME, MNAME) \ 240 OSCAP_SETTER_GENERIC(SNAME, const char *, MNAME, free, oscap_strdup) 245 #define OSCAP_ACCESSOR_STRING(SNAME, MNAME) \ 246 OSCAP_GETTER(const char*, SNAME, MNAME) OSCAP_SETTER_STRING(SNAME, MNAME) 251 #define OSCAP_ACCESSOR_TEXT(SNAME, MNAME) \ 252 OSCAP_GETTER(struct oscap_text *, SNAME, MNAME) \ 253 OSCAP_SETTER_GENERIC(SNAME, struct oscap_text*, MNAME, oscap_text_free, ) 258 #define OSCAP_ACCESSOR_SIMPLE(MTYPE, SNAME, MNAME) \ 259 OSCAP_GETTER(MTYPE, SNAME, MNAME) OSCAP_SETTER_SIMPLE(SNAME, MTYPE, MNAME) 265 #define OSCAP_ACCESSOR_EXP(MTYPE, SNAME, MNAME, MEXP) \ 266 OSCAP_GENERIC_GETTER(MTYPE, SNAME, MNAME, MEXP) \ 267 OSCAP_SETTER_HEADER(SNAME, MTYPE, MNAME) { obj->MEXP = newval; return true; } 278 #define OSCAP_INSERTER(SNAME, FNAME, MTYPE, MNAME) \ 279 bool SNAME##_add_##FNAME(struct SNAME *obj, struct MTYPE *item) \ 280 { oscap_list_add(obj->MNAME, item); return true; } 283 #define OSCAP_IGETINS(ITYPE, SNAME, MNAME, FNAME) \ 284 OSCAP_IGETTER(ITYPE, SNAME, MNAME) OSCAP_INSERTER(SNAME, FNAME, ITYPE, MNAME) 286 #define OSCAP_IGETINS_GEN(ITYPE, SNAME, MNAME, FNAME) \ 287 OSCAP_IGETTER_GEN(ITYPE, SNAME, MNAME) OSCAP_INSERTER(SNAME, FNAME, ITYPE, MNAME) 305 static inline char *oscap_strdup(
const char *str) {
317 static inline int oscap_strcmp(
const char *s1,
const char *s2) {
318 if (s1 == NULL) s1 =
"";
319 if (s2 == NULL) s2 =
"";
320 return strcmp(s1, s2);
324 static inline bool oscap_streq(
const char *s1,
const char *s2) {
325 return oscap_strcmp(s1, s2) == 0;
329 static inline bool oscap_str_startswith(
const char *str,
const char *prefix) {
330 return strncmp(str, prefix, strlen(prefix)) == 0;
334 static inline bool oscap_str_endswith(
const char *str,
const char *suffix) {
335 const size_t str_len = strlen(str);
336 const size_t suffix_len = strlen(suffix);
337 if (suffix_len > str_len)
339 return strncmp(str + str_len - suffix_len, suffix, suffix_len) == 0;
343 static inline void *oscap_aligned_malloc(
size_t size,
size_t alignment) {
345 return _aligned_malloc(size, alignment);
348 posix_memalign(&ptr, alignment, size);
354 static inline void oscap_aligned_free(
void *memblock) {
356 _aligned_free(memblock);
363 char *oscap_trim(
char *str);
365 char *oscap_vsprintf(
const char *fmt, va_list ap);
376 char *oscap_path_join(
const char *path1,
const char *path2);
379 const char *oscap_strlist_find_value(
char **
const kvalues,
const char *key);
381 char *oscap_rtrim(
char *str,
char ch);
383 void oscap_strtoupper(
char *str);
386 bool oscap_ptr_cmp(
void *node1,
void *node2);
399 char *oscap_expand_ipv6(
const char *input);
402 # define OSCAP_CONCAT1(a,b) a ## b 403 # define OSCAP_CONCAT(a,b) OSCAP_CONCAT1(a,b) 412 #define OSCAP_GSYM(s) OSCAP_CONCAT(___G_, s) 414 #define protect_errno \ 415 for (int OSCAP_CONCAT(__e,__LINE__)=errno, OSCAP_CONCAT(__s,__LINE__)=1; OSCAP_CONCAT(__s,__LINE__)--; errno=OSCAP_CONCAT(__e,__LINE__)) 441 char **oscap_split(
char *str,
const char *delim);
451 int oscap_strcasecmp(
const char *s1,
const char *s2);
462 int oscap_strncasecmp(
const char *s1,
const char *s2,
size_t n);
470 char *oscap_strerror_r(
int errnum,
char *buf,
size_t buflen);
483 int oscap_get_substrings(
char *str,
int *ofs, pcre *re,
int want_substrs,
char ***substrings);
495 FILE *oscap_fopen_with_prefix(
const char *prefix,
const char *path);
506 char *oscap_windows_wstr_to_str(
const wchar_t *wstr);
515 wchar_t *oscap_windows_str_to_wstr(
const char *str);
524 char *oscap_windows_error_message(
unsigned long error_code);
General OpenScap functions and types.
Define mapping between symbolic constant and its string representation.
Definition: util.h:296
int oscap_string_to_enum(const struct oscap_string_map *map, const char *str)
Convert a string to an enumeration constant.
Definition: util.c:52
const char * oscap_enum_to_string(const struct oscap_string_map *map, int val)
Convert an enumeration constant to its corresponding string representation.
Definition: util.c:61