From 3bbc37ff26b4c29ce699691edf1035851bfbd171 Mon Sep 17 00:00:00 2001 From: Xan Lopez Date: Tue, 17 Feb 2009 18:19:12 +0000 Subject: Fix finding extensions in system dir. Also use g_build_filename to build paths and plug a leak. Based on a patch by Diego Escalante Urrelo. Bug #571379 svn path=/trunk/; revision=8791 --- src/ephy-seed-extension.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) (limited to 'src') diff --git a/src/ephy-seed-extension.c b/src/ephy-seed-extension.c index 12ff3ebbf..fa0cfff91 100644 --- a/src/ephy-seed-extension.c +++ b/src/ephy-seed-extension.c @@ -136,17 +136,19 @@ G_DEFINE_TYPE_WITH_CODE (EphySeedExtension, ephy_seed_extension, G_TYPE_OBJECT, static gchar * ephy_seed_extension_get_file (const gchar * name) { - gchar *dot_dir, *dot_path, *system_path, *dirname; + gchar *dot_path, *system_path, *dirname, *filename; - dot_dir = g_strconcat (ephy_dot_dir (), "/extensions", NULL); - dot_path = g_strconcat (dot_dir, "/", name, ".js", NULL); - g_free (dot_dir); + filename = g_strconcat (name, ".js", NULL); + dot_path = g_build_filename (ephy_dot_dir(), "extensions", filename, NULL); if (g_file_test (dot_path, G_FILE_TEST_EXISTS)) { + g_free(filename); return dot_path; } + g_free (dot_path); - system_path = g_strconcat (EXTENSIONS_DIR, name, NULL); + system_path = g_build_filename (EXTENSIONS_DIR, filename, NULL); + g_free (filename); if (g_file_test (system_path, G_FILE_TEST_EXISTS)) { return system_path; } -- cgit v1.2.3