[gegl] gegl-init: Split out module directory logic to function



commit 89775bd29970ca26961b5b5bc49f500f696b4d76
Author: Jon Nordby <jononor gmail com>
Date:   Mon Jan 19 23:51:18 2015 +0100

    gegl-init: Split out module directory logic to function

 gegl/gegl-init-private.h |   12 ++++++-
 gegl/gegl-init.c         |   85 ++++++++++++++++++++++++++-------------------
 2 files changed, 60 insertions(+), 37 deletions(-)
---
diff --git a/gegl/gegl-init-private.h b/gegl/gegl-init-private.h
index 31e5dba..bc40865 100644
--- a/gegl/gegl-init-private.h
+++ b/gegl/gegl-init-private.h
@@ -31,6 +31,16 @@ G_BEGIN_DECLS
  */
 gboolean      gegl_get_debug_enabled     (void);
 
+/**
+ * gegl_get_default_module_paths:
+ *
+ * Paths which modules should be loaded from
+ *
+ * Returns: ordered #GSList of #gchar* to load. Free using g_slist_free(l, g_free)
+ */
+GSList *
+gegl_get_default_module_paths(void);
+
 G_END_DECLS
 
-#endif /* __GEGL_INIT_PRIVATE_H__ */
\ No newline at end of file
+#endif /* __GEGL_INIT_PRIVATE_H__ */
diff --git a/gegl/gegl-init.c b/gegl/gegl-init.c
index c19a0d3..caebbf1 100644
--- a/gegl/gegl-init.c
+++ b/gegl/gegl-init.c
@@ -558,6 +558,52 @@ gegl_load_module_directory (const gchar *path)
   gegl_module_db_load (module_db, path);
 }
 
+
+GSList *
+gegl_get_default_module_paths(void)
+{
+  GSList *list = NULL;
+  gchar *module_path = NULL;
+
+  // GEGL_PATH
+  const gchar *gegl_path = g_getenv ("GEGL_PATH");
+  if (gegl_path)
+    {
+      list = g_slist_append (list, g_strdup (gegl_path));
+      return list;
+    }
+
+  // System library dir
+#ifdef G_OS_WIN32
+  {
+    gchar *prefix;
+    prefix = g_win32_get_package_installation_directory_of_module ( hLibGeglModule );
+    module_path = g_build_filename (prefix, "lib", GEGL_LIBRARY, NULL);
+    g_free(prefix);
+  }
+#else
+  module_path = g_build_filename (LIBDIR, GEGL_LIBRARY, NULL);
+#endif
+  list = g_slist_append (list, g_strdup (gegl_path));
+
+  /* User data dir
+   * ~/.local/share/gegl-x.y/plug-ins */
+  module_path = g_build_filename (g_get_user_data_dir (),
+                                  GEGL_LIBRARY,
+                                  "plug-ins",
+                                  NULL);
+  g_mkdir_with_parents (module_path, S_IRUSR | S_IWUSR | S_IXUSR);
+  list = g_slist_append (list, g_strdup (gegl_path));
+
+  return list;
+}
+
+static void
+load_module_path(gchar *path, GeglModuleDB *db)
+{
+  gegl_module_db_load (db, path);
+}
+
 static gboolean
 gegl_post_parse_hook (GOptionContext *context,
                       GOptionGroup   *group,
@@ -624,43 +670,10 @@ gegl_post_parse_hook (GOptionContext *context,
 
   if (!module_db)
     {
-      const gchar *gegl_path = g_getenv ("GEGL_PATH");
-
+      GSList *paths = gegl_get_default_module_paths ();
       module_db = gegl_module_db_new (FALSE);
-
-      if (gegl_path)
-        {
-          gegl_module_db_load (module_db, gegl_path);
-        }
-      else
-        {
-          gchar *module_path;
-
-#ifdef G_OS_WIN32
-          {
-            gchar *prefix;
-            prefix = g_win32_get_package_installation_directory_of_module ( hLibGeglModule );
-            module_path = g_build_filename (prefix, "lib", GEGL_LIBRARY, NULL);
-            g_free(prefix);
-          }
-#else
-          module_path = g_build_filename (LIBDIR, GEGL_LIBRARY, NULL);
-#endif
-
-          gegl_module_db_load (module_db, module_path);
-          g_free (module_path);
-
-          /* also load plug-ins from ~/.local/share/gegl-0.0/plug-ins */
-          module_path = g_build_filename (g_get_user_data_dir (),
-                                          GEGL_LIBRARY,
-                                          "plug-ins",
-                                          NULL);
-
-          g_mkdir_with_parents (module_path, S_IRUSR | S_IWUSR | S_IXUSR);
-
-          gegl_module_db_load (module_db, module_path);
-          g_free (module_path);
-        }
+      g_slist_foreach(paths, (GFunc)load_module_path, module_db);
+      g_slist_free_full (paths, g_free);
     }
 
   GEGL_INSTRUMENT_END ("gegl_init", "load modules");


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]