aboutsummaryrefslogtreecommitdiffstats
path: root/shell/test/e-test-shell-view.c
diff options
context:
space:
mode:
Diffstat (limited to 'shell/test/e-test-shell-view.c')
-rw-r--r--shell/test/e-test-shell-view.c90
1 files changed, 84 insertions, 6 deletions
diff --git a/shell/test/e-test-shell-view.c b/shell/test/e-test-shell-view.c
index adba6ae3b8..05d19c13f1 100644
--- a/shell/test/e-test-shell-view.c
+++ b/shell/test/e-test-shell-view.c
@@ -20,20 +20,76 @@
#include "e-test-shell-view.h"
-#include <glib/gi18n.h>
-
#define E_TEST_SHELL_VIEW_GET_PRIVATE(obj) \
(G_TYPE_INSTANCE_GET_PRIVATE \
((obj), E_TYPE_TEST_SHELL_VIEW, ETestShellViewPrivate))
struct _ETestShellViewPrivate {
- gint dummy_value;
+ GtkWidget *content_widget;
+ GtkWidget *sidebar_widget;
+ GtkWidget *status_widget;
};
GType e_test_shell_view_type = 0;
static gpointer parent_class;
static void
+test_shell_view_dispose (GObject *object)
+{
+ ETestShellViewPrivate *priv;
+
+ priv = E_TEST_SHELL_VIEW_GET_PRIVATE (object);
+
+ if (priv->content_widget != NULL) {
+ g_object_unref (priv->content_widget);
+ priv->content_widget = NULL;
+ }
+
+ if (priv->sidebar_widget != NULL) {
+ g_object_unref (priv->sidebar_widget);
+ priv->sidebar_widget = NULL;
+ }
+
+ if (priv->status_widget != NULL) {
+ g_object_unref (priv->status_widget);
+ priv->status_widget = NULL;
+ }
+
+ /* Chain up to parent's dispose() method. */
+ G_OBJECT_CLASS (parent_class)->dispose (object);
+}
+
+static GtkWidget *
+test_shell_view_get_content_widget (EShellView *shell_view)
+{
+ ETestShellViewPrivate *priv;
+
+ priv = E_TEST_SHELL_VIEW_GET_PRIVATE (shell_view);
+
+ return priv->content_widget;
+}
+
+static GtkWidget *
+test_shell_view_get_sidebar_widget (EShellView *shell_view)
+{
+ ETestShellViewPrivate *priv;
+
+ priv = E_TEST_SHELL_VIEW_GET_PRIVATE (shell_view);
+
+ return priv->sidebar_widget;
+}
+
+static GtkWidget *
+test_shell_view_get_status_widget (EShellView *shell_view)
+{
+ ETestShellViewPrivate *priv;
+
+ priv = E_TEST_SHELL_VIEW_GET_PRIVATE (shell_view);
+
+ return priv->status_widget;
+}
+
+static void
test_shell_view_class_init (ETestShellViewClass *class,
GTypeModule *type_module)
{
@@ -43,15 +99,37 @@ test_shell_view_class_init (ETestShellViewClass *class,
g_type_class_add_private (class, sizeof (ETestShellViewPrivate));
shell_view_class = E_SHELL_VIEW_CLASS (class);
- shell_view_class->label = N_("Test");
+ shell_view_class->label = "Test";
shell_view_class->icon_name = "face-monkey";
shell_view_class->type_module = type_module;
+
+ shell_view_class->get_content_widget =
+ test_shell_view_get_content_widget;
+ shell_view_class->get_sidebar_widget =
+ test_shell_view_get_sidebar_widget;
+ shell_view_class->get_status_widget =
+ test_shell_view_get_status_widget;
}
static void
-test_shell_view_init (ETestShellView *view)
+test_shell_view_init (ETestShellView *test_shell_view)
{
- view->priv = E_TEST_SHELL_VIEW_GET_PRIVATE (view);
+ GtkWidget *widget;
+
+ test_shell_view->priv =
+ E_TEST_SHELL_VIEW_GET_PRIVATE (test_shell_view);
+
+ widget = gtk_label_new ("Content Widget");
+ test_shell_view->priv->content_widget = g_object_ref_sink (widget);
+ gtk_widget_show (widget);
+
+ widget = gtk_label_new ("Sidebar Widget");
+ test_shell_view->priv->sidebar_widget = g_object_ref_sink (widget);
+ gtk_widget_show (widget);
+
+ widget = gtk_label_new ("Status Widget");
+ test_shell_view->priv->status_widget = g_object_ref_sink (widget);
+ gtk_widget_show (widget);
}
GType