aboutsummaryrefslogtreecommitdiffstats
path: root/shell/e-shell.c
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2010-03-20 12:00:28 +0800
committerMatthew Barnes <mbarnes@redhat.com>2010-03-20 23:49:46 +0800
commit185b7b2a0b5641bdfafd440568d11c4521c42573 (patch)
treea3bd40fdb185b14a3e1bf06ed473e765a5419526 /shell/e-shell.c
parent8ffcfb4e106bb0081714455239cfe13a524c365f (diff)
downloadgsoc2013-evolution-185b7b2a0b5641bdfafd440568d11c4521c42573.tar.gz
gsoc2013-evolution-185b7b2a0b5641bdfafd440568d11c4521c42573.tar.zst
gsoc2013-evolution-185b7b2a0b5641bdfafd440568d11c4521c42573.zip
Make EShell and related classes extensible.
Diffstat (limited to 'shell/e-shell.c')
-rw-r--r--shell/e-shell.c47
1 files changed, 13 insertions, 34 deletions
diff --git a/shell/e-shell.c b/shell/e-shell.c
index 00c1e4a7a7..8bbcde784d 100644
--- a/shell/e-shell.c
+++ b/shell/e-shell.c
@@ -24,9 +24,10 @@
#include <glib/gi18n.h>
#include <libedataserverui/e-passwords.h>
+#include "e-util/e-module.h"
+#include "e-util/e-extensible.h"
#include "e-util/e-util-private.h"
#include "e-util/e-util.h"
-#include "e-util/e-module.h"
#include "smclient/eggsmclient.h"
#include "widgets/misc/e-preferences-window.h"
@@ -94,7 +95,6 @@ static GDebugKey debug_keys[] = {
{ "settings", DEBUG_KEY_SETTINGS }
};
-static gpointer parent_class;
static gpointer default_shell;
static guint signals[LAST_SIGNAL];
@@ -102,6 +102,10 @@ static guint signals[LAST_SIGNAL];
gboolean e_shell_dbus_initialize (EShell *shell);
#endif
+G_DEFINE_TYPE_WITH_CODE (
+ EShell, e_shell, UNIQUE_TYPE_APP,
+ G_IMPLEMENT_INTERFACE (E_TYPE_EXTENSIBLE, NULL))
+
static void
shell_parse_debug_string (EShell *shell)
{
@@ -606,7 +610,7 @@ shell_dispose (GObject *object)
}
/* Chain up to parent's dispose() method. */
- G_OBJECT_CLASS (parent_class)->dispose (object);
+ G_OBJECT_CLASS (e_shell_parent_class)->dispose (object);
}
static void
@@ -627,7 +631,7 @@ shell_finalize (GObject *object)
g_free (priv->module_directory);
/* Chain up to parent's finalize() method. */
- G_OBJECT_CLASS (parent_class)->finalize (object);
+ G_OBJECT_CLASS (e_shell_parent_class)->finalize (object);
}
static void
@@ -656,6 +660,8 @@ shell_constructed (GObject *object)
e_type_traverse (
E_TYPE_SHELL_BACKEND, (ETypeFunc)
shell_add_backend, object);
+
+ e_extensible_load_extensions (E_EXTENSIBLE (object));
}
static UniqueResponse
@@ -740,7 +746,7 @@ shell_message_received (UniqueApp *app,
}
/* Chain up to parent's message_received() method. */
- return UNIQUE_APP_CLASS (parent_class)->
+ return UNIQUE_APP_CLASS (e_shell_parent_class)->
message_received (app, command, data, time_);
}
@@ -752,12 +758,11 @@ shell_window_destroyed (EShell *shell)
}
static void
-shell_class_init (EShellClass *class)
+e_shell_class_init (EShellClass *class)
{
GObjectClass *object_class;
UniqueAppClass *unique_app_class;
- parent_class = g_type_class_peek_parent (class);
g_type_class_add_private (class, sizeof (EShellPrivate));
object_class = G_OBJECT_CLASS (class);
@@ -1061,7 +1066,7 @@ shell_class_init (EShellClass *class)
}
static void
-shell_init (EShell *shell)
+e_shell_init (EShell *shell)
{
GHashTable *backends_by_name;
GHashTable *backends_by_scheme;
@@ -1150,32 +1155,6 @@ shell_init (EShell *shell)
G_CALLBACK (shell_sm_quit_cb), shell);
}
-GType
-e_shell_get_type (void)
-{
- static GType type = 0;
-
- if (G_UNLIKELY (type == 0)) {
- const GTypeInfo type_info = {
- sizeof (EShellClass),
- (GBaseInitFunc) NULL,
- (GBaseFinalizeFunc) NULL,
- (GClassInitFunc) shell_class_init,
- (GClassFinalizeFunc) NULL,
- NULL, /* class_data */
- sizeof (EShell),
- 0, /* n_preallocs */
- (GInstanceInitFunc) shell_init,
- NULL /* value_table */
- };
-
- type = g_type_register_static (
- UNIQUE_TYPE_APP, "EShell", &type_info, 0);
- }
-
- return type;
-}
-
/**
* e_shell_get_default:
*