diff options
author | Milan Crha <mcrha@redhat.com> | 2011-08-04 13:43:31 +0800 |
---|---|---|
committer | Milan Crha <mcrha@redhat.com> | 2011-08-04 13:43:31 +0800 |
commit | 90f7050236c48d42c4b416748aede29265519f2d (patch) | |
tree | f82dc1322dbd06345e3ec5cb4e44beefb51f54c2 | |
parent | ec5405520472835d49ed19055ad144bebeb9babd (diff) | |
download | gsoc2013-evolution-90f7050236c48d42c4b416748aede29265519f2d.tar.gz gsoc2013-evolution-90f7050236c48d42c4b416748aede29265519f2d.tar.zst gsoc2013-evolution-90f7050236c48d42c4b416748aede29265519f2d.zip |
Bug #655507 - Do not unload extensions, keep them preloaded
-rw-r--r-- | e-util/e-extensible.c | 24 |
1 files changed, 13 insertions, 11 deletions
diff --git a/e-util/e-extensible.c b/e-util/e-extensible.c index a7523deb21..6e49e9dba7 100644 --- a/e-util/e-extensible.c +++ b/e-util/e-extensible.c @@ -94,17 +94,19 @@ extensible_load_extension (GType extension_type, extension_class = g_type_class_ref (extension_type); /* Only load extensions that extend the given extensible object. */ - if (!g_type_is_a (extensible_type, extension_class->extensible_type)) - goto exit; - - extension = g_object_new ( - extension_type, "extensible", extensible, NULL); - - extensions = extensible_get_extensions (extensible); - g_ptr_array_add (extensions, extension); - -exit: - g_type_class_unref (extension_class); + if (g_type_is_a (extensible_type, extension_class->extensible_type)) { + extension = g_object_new ( + extension_type, "extensible", extensible, NULL); + + extensions = extensible_get_extensions (extensible); + g_ptr_array_add (extensions, extension); + + g_type_class_unref (extension_class); + } else { + /* keep the class referenced forever, later may anyone need it anyway, + and unref it may mean module unload, which breaks static strings + in GType */ + } } static void |