/* glib_compat.h replacement functionality for glib code used in qemu Copyright (C) 2016 Chris Eagle cseagle at gmail dot com This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef QEMU_GLIB_COMPAT_H #define QEMU_GLIB_COMPAT_H #include "unicorn/platform.h" #include #include #include #ifndef TRUE #define TRUE 1 #endif #ifndef FALSE #define FALSE 0 #endif #define g_assert(expr) assert(expr) #define g_assert_not_reached() assert(0) #define g_assert_cmpstr(s1, cmp, s2) do { const char *__s1 = (s1), *__s2 = (s2); \ if (strcmp (__s1, __s2) cmp 0) ; else \ assert(false); \ } while (0) #define g_assert_cmpint(n1, cmp, n2) do { gint64 __n1 = (n1), __n2 = (n2); \ if (__n1 cmp __n2) ; else \ assert (false); \ } while (0) #define g_assert_cmpuint(n1, cmp, n2) do { guint64 __n1 = (n1), __n2 = (n2); \ if (__n1 cmp __n2) ; else \ assert(false); \ } while (0) #define g_assert_cmphex(n1, cmp, n2) do { guint64 __n1 = (n1), __n2 = (n2); \ if (__n1 cmp __n2) ; else \ assert(false); \ } while (0) #define g_assert_cmpfloat(n1,cmp,n2) do { long double __n1 = (n1), __n2 = (n2); \ if (__n1 cmp __n2) ; else \ assert(false); \ } while (0) /* typedefs for glib related types that may still be referenced */ typedef void* gpointer; typedef const void *gconstpointer; typedef int gint; typedef signed char gint8; typedef unsigned char guint8; typedef signed short gint16; typedef unsigned short guint16; typedef uint32_t guint32; typedef uint64_t guint64; typedef unsigned int guint; typedef char gchar; typedef unsigned char guchar; typedef int gboolean; typedef unsigned long gulong; typedef unsigned long gsize; typedef signed long gssize; typedef gint (*GCompareFunc)(gconstpointer a, gconstpointer b); typedef gint (*GCompareDataFunc)(gconstpointer a, gconstpointer b, gpointer user_data); typedef gboolean (*GEqualFunc)(gconstpointer a, gconstpointer b); typedef void (*GDestroyNotify)(gpointer data); typedef void (*GFunc)(gpointer data, gpointer user_data); typedef guint (*GHashFunc)(gconstpointer key); typedef void (*GHFunc)(gpointer key, gpointer value, gpointer user_data); typedef void (*GFreeFunc)(gpointer data); /* Tree traverse orders */ typedef enum { G_IN_ORDER, G_PRE_ORDER, G_POST_ORDER, G_LEVEL_ORDER } GTraverseType; guint g_direct_hash(gconstpointer v); gboolean g_direct_equal(gconstpointer v1, gconstpointer v2); guint g_str_hash(gconstpointer v); gboolean g_str_equal(gconstpointer v1, gconstpointer v2); gboolean g_str_has_suffix(const gchar *str, const gchar *prefix); gboolean g_str_has_prefix(const gchar *str, const gchar *prefix); guint g_int_hash(gconstpointer v); gboolean g_int_equal(gconstpointer v1, gconstpointer v2); typedef struct _GList { gpointer data; struct _GList *next; struct _GList *prev; } GList; GList *g_list_first(GList *list); void g_list_foreach(GList *list, GFunc func, gpointer user_data); void g_list_free(GList *list); GList* g_list_insert_before(GList *list, GList *sibling, gpointer data); GList *g_list_insert_sorted(GList *list, gpointer data, GCompareFunc compare); #define g_list_next(list) (list->next) GList *g_list_prepend(GList *list, gpointer data); GList *g_list_remove_link(GList *list, GList *llink); GList *g_list_delete_link (GList *list, GList *link_); GList *g_list_sort(GList *list, GCompareFunc compare); typedef struct _GSList { gpointer data; struct _GSList *next; } GSList; GSList *g_slist_append(GSList *list, gpointer data); void g_slist_foreach(GSList *list, GFunc func, gpointer user_data); void g_slist_free(GSList *list); GSList *g_slist_prepend(GSList *list, gpointer data); GSList *g_slist_sort(GSList *list, GCompareFunc compare); typedef struct _GString GString; struct _GString { gchar *str; gsize len; gsize allocated_len; }; GString* g_string_new(const gchar *init); GString* g_string_sized_new(gsize dfl_size); gchar* g_string_free(GString *string, gboolean free_segment); GString* g_string_erase(GString *string, gssize pos, gssize len); GString* g_string_append_len(GString *string, const gchar *val, gssize len); GString* g_string_insert_c(GString *string, gssize pos, gchar c); GString* g_string_insert_len(GString *string, gssize pos, const gchar *val, gssize len); GString* g_string_prepend(GString *string, const gchar *val); GString* g_string_prepend_c(GString *string, gchar c); GString* g_string_truncate(GString *string, gsize len); GString* g_string_set_size(GString *string, gsize len); typedef guint (*GHashFunc)(gconstpointer key); typedef gboolean (*GEqualFunc)(gconstpointer a, gconstpointer b); typedef void (*GHFunc)(gpointer key, gpointer value, gpointer user_data); typedef gboolean (*GHRFunc)(gpointer key, gpointer value, gpointer user_data); typedef struct _GHashTable GHashTable; typedef struct _GHashTableIter GHashTableIter; struct _GHashTableIter { /*< private >*/ gpointer dummy1; gpointer dummy2; gpointer dummy3; int dummy4; gboolean dummy5; gpointer dummy6; }; void g_hash_table_destroy(GHashTable *hash_table); gpointer g_hash_table_find(GHashTable *hash_table, GHRFunc predicate, gpointer user_data); void g_hash_table_foreach(GHashTable *hash_table, GHFunc func, gpointer user_data); void g_hash_table_insert(GHashTable *hash_table, gpointer key, gpointer value); void g_hash_table_replace(GHashTable *hash_table, gpointer key, gpointer value); gpointer g_hash_table_lookup(GHashTable *hash_table, gconstpointer key); GHashTable *g_hash_table_new(GHashFunc hash_func, GEqualFunc key_equal_func); GHashTable *g_hash_table_new_full(GHashFunc hash_func, GEqualFunc key_equal_func, GDestroyNotify key_destroy_func, GDestroyNotify value_destroy_func); void g_hash_table_remove_all(GHashTable *hash_table); gboolean g_hash_table_remove(GHashTable *hash_table, gconstpointer key); void g_hash_table_unref(GHashTable *hash_table); GHashTable *g_hash_table_ref(GHashTable *hash_table); guint g_hash_table_size(GHashTable *hash_table); void g_hash_table_iter_init(GHashTableIter *iter, GHashTable *hash_table); gboolean g_hash_table_iter_next(GHashTableIter *iter, gpointer *key, gpointer *value); GHashTable *g_hash_table_iter_get_hash_table(GHashTableIter *iter); void g_hash_table_iter_remove(GHashTableIter *iter); void g_hash_table_iter_steal(GHashTableIter *iter); /* Tree code */ typedef struct _GTree GTree; typedef gboolean (*GTraverseFunc) (gpointer key, gpointer value, gpointer data); GTree *g_tree_new(GCompareFunc key_compare_func); GTree *g_tree_new_with_data(GCompareDataFunc key_compare_func, gpointer key_compare_data); GTree *g_tree_new_full(GCompareDataFunc key_compare_func, gpointer key_compare_data, GDestroyNotify key_destroy_func, GDestroyNotify value_destroy_func); GTree *g_tree_ref(GTree *tree); void g_tree_unref(GTree *tree); void g_tree_destroy(GTree *tree); void g_tree_insert(GTree *tree, gpointer key, gpointer value); void g_tree_replace(GTree *tree, gpointer key, gpointer value); gboolean g_tree_remove(GTree *tree, gconstpointer key); gboolean g_tree_steal(GTree *tree, gconstpointer key); gpointer g_tree_lookup(GTree *tree, gconstpointer key); gboolean g_tree_lookup_extended(GTree *tree, gconstpointer lookup_key, gpointer *orig_key, gpointer *value); void g_tree_foreach(GTree *tree, GTraverseFunc func, gpointer user_data); gpointer g_tree_search(GTree *tree, GCompareFunc search_func, gconstpointer user_data); gint g_tree_height(GTree *tree); gint g_tree_nnodes(GTree *tree); void g_tree_traverse(GTree *tree, GTraverseFunc traverse_func, GTraverseType traverse_type, gpointer user_data); /* replacement for g_malloc dependency */ void g_free(gpointer ptr); gpointer g_malloc(size_t size); gpointer g_malloc0(size_t size); gpointer g_try_malloc0(size_t size); gpointer g_realloc(gpointer ptr, size_t size); char *g_strdup(const char *str); char *g_strdup_printf(const char *format, ...); char *g_strdup_vprintf(const char *format, va_list ap); char *g_strndup(const char *str, size_t n); void g_strfreev(char **v); gpointer g_memdup(gconstpointer mem, size_t byte_size); gpointer g_new_(size_t sz, size_t n_structs); gpointer g_new0_(size_t sz, size_t n_structs); gpointer g_renew_(size_t sz, gpointer mem, size_t n_structs); gchar* g_strconcat (const gchar *string1, ...); gchar** g_strsplit (const gchar *string, const gchar *delimiter, gint max_tokens); /* replacement for base64 dependency */ gsize g_base64_encode_close(gboolean break_lines, gchar *out, gint *state, gint *save); gchar *g_base64_encode(const guchar *data, gsize len); guchar *g_base64_decode(const gchar *text, gsize *out_len); guchar *g_base64_decode_inplace(gchar *text, gsize *out_len); #define g_new(struct_type, n_structs) ((struct_type*)g_new_(sizeof(struct_type), n_structs)) #define g_new0(struct_type, n_structs) ((struct_type*)g_new0_(sizeof(struct_type), n_structs)) #define g_renew(struct_type, mem, n_structs) ((struct_type*)g_renew_(sizeof(struct_type), mem, n_structs)) #endif