[epiphany/wip/exalm/firefox-import: 3/3] window-commands: Port Firefox profile listing to GKeyFile
- From: Alexander Mikhaylenko <alexm src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [epiphany/wip/exalm/firefox-import: 3/3] window-commands: Port Firefox profile listing to GKeyFile
- Date: Tue, 30 Nov 2021 09:01:17 +0000 (UTC)
commit 630a57404dbbe9fdd2b6009698140b9b981f1829
Author: Alexander Mikhaylenko <alexm gnome org>
Date: Tue Nov 30 14:00:18 2021 +0500
window-commands: Port Firefox profile listing to GKeyFile
No need to reimplement it, and it was failing when profiles were out of
order.
src/window-commands.c | 79 ++++++++++++++++++---------------------------------
1 file changed, 28 insertions(+), 51 deletions(-)
---
diff --git a/src/window-commands.c b/src/window-commands.c
index af272faa6..6397d9a51 100644
--- a/src/window-commands.c
+++ b/src/window-commands.c
@@ -133,72 +133,49 @@ combo_box_changed_cb (GtkComboBox *combo_box,
gtk_button_set_label (button, _("I_mport"));
}
-static gchar *
-get_path (GIOChannel *channel)
-{
- gchar *line;
- const gchar *path;
- gchar *result;
- gsize length;
-
- do {
- g_io_channel_read_line (channel, &line, &length, NULL, NULL);
-
- if (g_str_has_prefix (line, "Path")) {
- path = line;
-
- /* Extract value (e.g. Path=Value\n -> Value) */
- path = strchr (path, '=');
- path++;
- ((gchar *)path)[strcspn (path, "\n")] = '\0';
- result = g_strdup (path);
-
- g_free (line);
- return result;
- }
-
- g_free (line);
- /* Until '\n' */
- } while (length != 1);
-
- return NULL;
-}
-
static GSList *
get_firefox_profiles (void)
{
- GIOChannel *channel;
+ GKeyFile *keyfile;
GSList *profiles = NULL;
- gchar *filename;
- gchar *line;
- gchar *profile;
- int count = 0;
- gsize length;
+ g_autofree gchar *filename = NULL;
+ g_autoptr (GError) error = NULL;
+ GStrv groups = NULL;
+ int i = 0;
filename = g_build_filename (g_get_home_dir (),
FIREFOX_PROFILES_DIR,
FIREFOX_PROFILES_FILE,
NULL);
- channel = g_io_channel_new_file (filename, "r", NULL);
- g_free (filename);
+ keyfile = g_key_file_new ();
+ g_key_file_load_from_file (keyfile, filename, G_KEY_FILE_NONE, &error);
+ if (error) {
+ g_critical ("Failed to load %s: %s", filename, error->message);
- if (channel) {
- do {
- g_io_channel_read_line (channel, &line, &length, NULL, NULL);
+ return NULL;
+ }
- profile = g_strdup_printf ("[Profile%d]\n", count);
- if (g_strcmp0 (line, profile) == 0) {
- profiles = g_slist_append (profiles, get_path (channel));
+ groups = g_key_file_get_groups (keyfile, NULL);
+ while (groups[i]) {
+ const char *group = groups[i++];
+ char *path;
- count++;
- }
- g_free (profile);
- g_free (line);
- } while (length != 0);
+ if (!g_str_has_prefix (group, "Profile"))
+ continue;
- g_io_channel_unref (channel);
+ path = g_key_file_get_string (keyfile, group, "Path", &error);
+ if (error) {
+ g_critical ("Failed to parse profile %s in %s: %s",
+ groups[i], filename, error->message);
+
+ continue;
+ }
+
+ profiles = g_slist_append (profiles, path);
}
+ g_strfreev (groups);
+
return profiles;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]