summaryrefslogtreecommitdiffstats
path: root/gtk/src/create_resources.c
diff options
context:
space:
mode:
Diffstat (limited to 'gtk/src/create_resources.c')
-rw-r--r--gtk/src/create_resources.c64
1 files changed, 34 insertions, 30 deletions
diff --git a/gtk/src/create_resources.c b/gtk/src/create_resources.c
index 233c468a9..d9a5e7668 100644
--- a/gtk/src/create_resources.c
+++ b/gtk/src/create_resources.c
@@ -40,7 +40,7 @@ typedef struct
{
gchar *key;
gchar *value;
- GValue *plist;
+ GhbValue *plist;
GQueue *stack;
GQueue *tag_stack;
gboolean closed_top;
@@ -91,12 +91,12 @@ lookup_attr_value(
return NULL;
}
-static GValue*
+static GhbValue*
read_string_from_file(const gchar *fname)
{
gchar *buffer;
size_t size;
- GValue *gval;
+ GhbValue *gval;
FILE *fd;
fd = g_fopen(fname, "r");
@@ -108,13 +108,13 @@ read_string_from_file(const gchar *fname)
buffer = g_malloc(size+1);
size = fread(buffer, 1, size, fd);
buffer[size] = 0;
- gval = ghb_value_new(G_TYPE_STRING);
- g_value_take_string(gval, buffer);
+ gval = ghb_string_value_new(buffer);
+ g_free(buffer);
fclose(fd);
return gval;
}
-static void add_icon(GValue *dict, const char *fname)
+static void add_icon(GhbValue *dict, const char *fname)
{
FILE *f;
@@ -132,30 +132,36 @@ static void add_icon(GValue *dict, const char *fname)
return;
}
- ghb_rawdata_t *rd;
- rd = g_malloc(sizeof(ghb_rawdata_t));
+ char* base64;
+ guint8 *data;
+ gsize data_size;
+
fseek(f, 0, SEEK_END);
- rd->size = ftell(f);
+ data_size = ftell(f);
fseek(f, 0, SEEK_SET);
- rd->data = g_malloc(rd->size);
- fread(rd->data, 1, rd->size, f);
+ data = g_malloc(data_size);
+ fread(data, 1, data_size, f);
+ base64 = g_base64_encode(data, data_size);
- GValue *data = ghb_rawdata_value_new(rd);
- ghb_dict_insert(dict, g_strdup("svg"), ghb_boolean_value_new(svg));
- ghb_dict_insert(dict, g_strdup("data"), data);
+ GhbValue *icon = ghb_string_value_new(base64);
+ ghb_dict_insert(dict, "svg", ghb_boolean_value_new(svg));
+ ghb_dict_insert(dict, "data", icon);
+
+ g_free(base64);
+ g_free(data);
}
-static void insert_value(GValue *container, const char *key, GValue *element)
+static void insert_value(GhbValue *container, const char *key, GhbValue *element)
{
- GType gtype;
+ GhbType gtype;
- gtype = G_VALUE_TYPE(container);
- if (gtype == ghb_array_get_type())
+ gtype = ghb_value_type(container);
+ if (gtype == GHB_ARRAY)
{
ghb_array_append(container, element);
}
- else if (gtype == ghb_dict_get_type())
+ else if (gtype == GHB_DICT)
{
if (key == NULL)
{
@@ -164,7 +170,7 @@ static void insert_value(GValue *container, const char *key, GValue *element)
}
else
{
- ghb_dict_insert(container, g_strdup(key), element);
+ ghb_dict_insert(container, key, element);
}
}
else
@@ -209,9 +215,8 @@ start_element(
return;
}
g_queue_push_head(pd->tag_stack, id.pid);
- GType gtype = 0;
- GValue *gval = NULL;
- GValue *current = g_queue_peek_head(pd->stack);
+ GhbValue *gval = NULL;
+ GhbValue *current = g_queue_peek_head(pd->stack);
switch (id.id)
{
case R_SECTION:
@@ -397,9 +402,8 @@ end_element(
if (start_id.id != id)
g_warning("start tag != end tag: (%s %d) %d", name, id, id);
- GValue *gval = NULL;
- GValue *current = g_queue_peek_head(pd->stack);
- GType gtype = 0;
+ GhbValue *gval = NULL;
+ GhbValue *current = g_queue_peek_head(pd->stack);
switch (id)
{
case R_SECTION:
@@ -462,7 +466,7 @@ destroy_notify(gpointer data)
//g_debug("destroy parser");
}
-GValue*
+GhbValue*
ghb_resource_parse(const gchar *buf, gssize len)
{
GMarkupParseContext *ctx;
@@ -493,12 +497,12 @@ ghb_resource_parse(const gchar *buf, gssize len)
return pd.plist;
}
-GValue*
+GhbValue*
ghb_resource_parse_file(FILE *fd)
{
gchar *buffer;
size_t size;
- GValue *gval;
+ GhbValue *gval;
if (fd == NULL)
return NULL;
@@ -535,7 +539,7 @@ gint
main(gint argc, gchar *argv[])
{
FILE *file;
- GValue *gval;
+ GhbValue *gval;
int opt;
const gchar *src, *dst;