55 if (filename == NULL || group == NULL)
58 gchar *contents = NULL;
60 if (!g_file_get_contents (filename, &contents, NULL, &error))
68 gchar *contents_with_group = g_strjoin (
"\n",
"[Misc]", contents, NULL);
69 settings->
key_file = g_key_file_new ();
71 if (!g_key_file_load_from_data
72 (settings->
key_file, contents_with_group, strlen (contents_with_group),
73 G_KEY_FILE_KEEP_COMMENTS | G_KEY_FILE_KEEP_TRANSLATIONS, &error))
75 g_warning (
"Failed to load configuration from %s: %s", filename,
78 g_free (contents_with_group);
82 g_free (contents_with_group);
87 settings->
file_name = g_strdup (filename);
102 g_key_file_free (settings->
key_file);
116 filename,
const gchar * group)
120 GError *error = NULL;
130 if (iterator->
keys == NULL)
134 g_warning (
"Failed to retrieve keys of group %s from %s: %s", group,
135 filename, error->message);
136 g_error_free (error);
156 g_strfreev (iterator->
keys);
const gchar * settings_iterator_name(settings_iterator_t *iterator)
Get the name from a settings iterator.
gboolean settings_iterator_next(settings_iterator_t *iterator)
Increment an iterator.
void settings_cleanup(settings_t *settings)
Cleanup a settings structure.
void cleanup_settings_iterator(settings_iterator_t *iterator)
Cleanup a settings iterator.
const gchar * settings_iterator_value(settings_iterator_t *iterator)
Get the value from a settings iterator.
Protos and data structures for configuration file management.
int init_settings_iterator_from_file(settings_iterator_t *iterator, const gchar *filename, const gchar *group)
Initialise a settings iterator from a file.
int settings_init_from_file(settings_t *settings, const gchar *filename, const gchar *group)
Initialise a settings struct from a file.