45 if (filename == NULL || group == NULL)
48 gchar *contents = NULL;
50 if (!g_file_get_contents (filename, &contents, NULL, &error))
58 gchar *contents_with_group = g_strjoin (
"\n",
"[Misc]", contents, NULL);
59 settings->
key_file = g_key_file_new ();
61 if (!g_key_file_load_from_data (
62 settings->
key_file, contents_with_group,
63 strlen (contents_with_group),
64 G_KEY_FILE_KEEP_COMMENTS | G_KEY_FILE_KEEP_TRANSLATIONS, &error))
66 g_warning (
"Failed to load configuration from %s: %s", filename,
69 g_free (contents_with_group);
73 g_free (contents_with_group);
78 settings->
file_name = g_strdup (filename);
93 g_key_file_free (settings->
key_file);
107 const gchar *filename,
const gchar *group)
111 GError *error = NULL;
118 &keys_length, &error);
120 if (iterator->
keys == NULL)
124 g_warning (
"Failed to retrieve keys of group %s from %s: %s", group,
125 filename, error->message);
126 g_error_free (error);
146 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.
Struct holding options for settings taken from a key-value config file.
Struct holding options to iterate over a GKeyFile.
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.