diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/config.c | 44 | ||||
-rw-r--r-- | src/config.h | 6 |
2 files changed, 49 insertions, 1 deletions
diff --git a/src/config.c b/src/config.c index d28b939..96c193c 100644 --- a/src/config.c +++ b/src/config.c @@ -34,12 +34,14 @@ enum type { TYPE_BOOLEAN, TYPE_INTEGER, TYPE_DOUBLE, + TYPE_STRING, }; union callback { void (*boolean_cb)(const gchar *, gboolean, gpointer); void (*integer_cb)(const gchar *, gint, gpointer); void (*double_cb)(const gchar *, gdouble, gpointer); + void (*string_cb)(const gchar *, gchar *, gpointer); }; struct callbacks { @@ -85,6 +87,11 @@ set_type_or_run_callbacks(MqConfig *config, const gchar *name, gpointer value, *((gdouble *) value), cbs->user_data); break; + case TYPE_STRING: + cbs->cb.string_cb(name, + (gchar *) value, + cbs->user_data); + break; } } } @@ -93,7 +100,7 @@ set_type_or_run_callbacks(MqConfig *config, const gchar *name, gpointer value, #define SET_BOOL(NAME, VALUE) mq_config_set_boolean(config, NAME, VALUE) #define SET_INT( NAME, VALUE) mq_config_set_integer(config, NAME, VALUE) #define SET_DBL( NAME, VALUE) mq_config_set_double (config, NAME, VALUE) -#define SET_STR( NAME, VALUE) do { *NAME = *NAME; *VALUE = *VALUE; } while (0) +#define SET_STR( NAME, VALUE) mq_config_set_string (config, NAME, VALUE) #define SET_STRL(NAME, VALUE) do { *NAME = *NAME; *VALUE = *VALUE; } while (0) static void @@ -300,6 +307,23 @@ mq_config_get_double(MqConfig *config, const gchar *name) return value; } +gchar * +mq_config_get_string(MqConfig *config, const gchar *name) +{ + gchar *group; + gchar *key; + gchar *value; + + split_name(name, &group, &key); + + /* TODO: Handle value parsing errors? */ + value = g_key_file_get_string(config->key_file, group, key, NULL); + + g_free(group); + + return value; +} + void mq_config_set_boolean(MqConfig *config, const gchar *name, gboolean value) { @@ -345,6 +369,21 @@ mq_config_set_double(MqConfig *config, const gchar *name, gdouble value) set_type_or_run_callbacks(config, name, &value, TYPE_DOUBLE); } +void +mq_config_set_string(MqConfig *config, const gchar *name, const gchar *value) +{ + gchar *group; + gchar *key; + + split_name(name, &group, &key); + + g_key_file_set_string(config->key_file, group, key, value); + + g_free(group); + + set_type_or_run_callbacks(config, name, value, TYPE_STRING); +} + gboolean mq_config_set(MqConfig *config, const gchar *name, const gchar *value) { @@ -377,6 +416,9 @@ mq_config_set(MqConfig *config, const gchar *name, const gchar *value) } mq_config_set_double(config, name, double_value); return TRUE; + case TYPE_STRING: + mq_config_set_string(config, name, value); + return TRUE; } g_assert_not_reached(); diff --git a/src/config.h b/src/config.h index b37c6bb..60aead7 100644 --- a/src/config.h +++ b/src/config.h @@ -52,6 +52,9 @@ mq_config_get_integer(MqConfig *config, const gchar *name); gdouble mq_config_get_double(MqConfig *config, const gchar *name); +gchar * +mq_config_get_string(MqConfig *config, const gchar *name); + void mq_config_set_boolean(MqConfig *config, const gchar *name, gboolean value); @@ -61,6 +64,9 @@ mq_config_set_integer(MqConfig *config, const gchar *name, gint value); void mq_config_set_double(MqConfig *config, const gchar *name, gdouble value); +void +mq_config_set_string(MqConfig *config, const gchar *name, const gchar *value); + gboolean mq_config_set(MqConfig *config, const gchar *name, const gchar *value); |