diff options
-rw-r--r-- | ChangeLog | 10 | ||||
-rw-r--r-- | src/ephy-extensions-manager.c | 4 | ||||
-rw-r--r-- | src/ephy-extensions-manager.h | 3 | ||||
-rw-r--r-- | src/ephy-shell.c | 6 |
4 files changed, 19 insertions, 4 deletions
@@ -1,3 +1,13 @@ +2004-02-01 Christian Persch <chpe@cvs.gnome.org> + + * src/ephy-extensions-manager.c: (ephy_extensions_manager_init): + * src/ephy-extensions-manager.h: + * src/ephy-shell.c: (ephy_shell_get_extensions_manager): + + Decouple extensions manager initialisation and extensions loading. + Fixes a crash when an extensions tried to get the session, + causing us to load extensions more than once. + 2004-02-01 Marco Pesenti Gritti <marco@gnome.org> * lib/ephy-stock-icons.h: diff --git a/src/ephy-extensions-manager.c b/src/ephy-extensions-manager.c index d7d44d521..9dc4d6842 100644 --- a/src/ephy-extensions-manager.c +++ b/src/ephy-extensions-manager.c @@ -130,7 +130,7 @@ ephy_extensions_manager_load (EphyExtensionsManager *manager, return extension; } -static void +void ephy_extensions_manager_load_dir (EphyExtensionsManager *manager, const char *path) { @@ -187,8 +187,6 @@ ephy_extensions_manager_init (EphyExtensionsManager *manager) manager->priv->loaders = NULL; manager->priv->extensions = NULL; - - ephy_extensions_manager_load_dir (manager, EXTENSIONS_DIR); } static void diff --git a/src/ephy-extensions-manager.h b/src/ephy-extensions-manager.h index 481b13ccf..22e956a0b 100644 --- a/src/ephy-extensions-manager.h +++ b/src/ephy-extensions-manager.h @@ -60,6 +60,9 @@ EphyExtensionsManager *ephy_extensions_manager_new (void); EphyExtension *ephy_extensions_manager_load (EphyExtensionsManager *manager, const char *filename); +void ephy_extensions_manager_load_dir (EphyExtensionsManager *manager, + const char *path); + EphyExtension *ephy_extensions_manager_add (EphyExtensionsManager *manager, GType type); diff --git a/src/ephy-shell.c b/src/ephy-shell.c index 8d65f60cb..f22da2cc0 100644 --- a/src/ephy-shell.c +++ b/src/ephy-shell.c @@ -710,8 +710,12 @@ ephy_shell_get_extensions_manager (EphyShell *es) if (es->priv->extensions_manager == NULL) { - /* Instantiate extensions manager; this will load the extensions */ + /* Instantiate extensions manager */ es->priv->extensions_manager = ephy_extensions_manager_new (); + + /* load the extensions */ + ephy_extensions_manager_load_dir (es->priv->extensions_manager, + EXTENSIONS_DIR); } return G_OBJECT (es->priv->extensions_manager); |