aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Barnes <mbarnes@redhat.com>2009-12-02 12:53:36 +0800
committerMatthew Barnes <mbarnes@redhat.com>2009-12-02 12:53:36 +0800
commitf1825606e64f59f1c3af2310f16a543f2df5c0d4 (patch)
tree075c7e6955e7452bbcd3925c3d5f1bb0f33403dc
parent793e57e24ca2ac458baa0897ad971dfbf08e8291 (diff)
downloadgsoc2013-evolution-f1825606e64f59f1c3af2310f16a543f2df5c0d4.tar
gsoc2013-evolution-f1825606e64f59f1c3af2310f16a543f2df5c0d4.tar.gz
gsoc2013-evolution-f1825606e64f59f1c3af2310f16a543f2df5c0d4.tar.bz2
gsoc2013-evolution-f1825606e64f59f1c3af2310f16a543f2df5c0d4.tar.lz
gsoc2013-evolution-f1825606e64f59f1c3af2310f16a543f2df5c0d4.tar.xz
gsoc2013-evolution-f1825606e64f59f1c3af2310f16a543f2df5c0d4.tar.zst
gsoc2013-evolution-f1825606e64f59f1c3af2310f16a543f2df5c0d4.zip
Allow EShellWindow "construct" methods to return NULL.
Also allow the methods themselves to be NULL.
-rw-r--r--shell/e-shell-window-private.c39
1 files changed, 25 insertions, 14 deletions
diff --git a/shell/e-shell-window-private.c b/shell/e-shell-window-private.c
index 57f5b326a1..0d9dda59cb 100644
--- a/shell/e-shell-window-private.c
+++ b/shell/e-shell-window-private.c
@@ -160,7 +160,8 @@ shell_window_construct_menubar (EShellWindow *shell_window)
EShellWindowClass *class;
class = E_SHELL_WINDOW_GET_CLASS (shell_window);
- g_return_val_if_fail (class->construct_menubar != NULL, NULL);
+ if (class->construct_menubar == NULL)
+ return NULL;
return class->construct_menubar (shell_window);
}
@@ -171,7 +172,8 @@ shell_window_construct_toolbar (EShellWindow *shell_window)
EShellWindowClass *class;
class = E_SHELL_WINDOW_GET_CLASS (shell_window);
- g_return_val_if_fail (class->construct_toolbar != NULL, NULL);
+ if (class->construct_toolbar == NULL)
+ return NULL;
return class->construct_toolbar (shell_window);
}
@@ -182,7 +184,8 @@ shell_window_construct_sidebar (EShellWindow *shell_window)
EShellWindowClass *class;
class = E_SHELL_WINDOW_GET_CLASS (shell_window);
- g_return_val_if_fail (class->construct_sidebar != NULL, NULL);
+ if (class->construct_sidebar == NULL)
+ return NULL;
return class->construct_sidebar (shell_window);
}
@@ -193,7 +196,8 @@ shell_window_construct_content (EShellWindow *shell_window)
EShellWindowClass *class;
class = E_SHELL_WINDOW_GET_CLASS (shell_window);
- g_return_val_if_fail (class->construct_content != NULL, NULL);
+ if (class->construct_content == NULL)
+ return NULL;
return class->construct_content (shell_window);
}
@@ -204,7 +208,8 @@ shell_window_construct_taskbar (EShellWindow *shell_window)
EShellWindowClass *class;
class = E_SHELL_WINDOW_GET_CLASS (shell_window);
- g_return_val_if_fail (class->construct_taskbar != NULL, NULL);
+ if (class->construct_taskbar == NULL)
+ return NULL;
return class->construct_taskbar (shell_window);
}
@@ -269,7 +274,8 @@ e_shell_window_private_constructed (EShellWindow *shell_window)
GtkAction *action;
GtkActionGroup *action_group;
GtkUIManager *ui_manager;
- GtkWidget *container;
+ GtkBox *box;
+ GtkPaned *paned;
GtkWidget *widget;
GtkWindow *window;
GObject *object;
@@ -289,29 +295,34 @@ e_shell_window_private_constructed (EShellWindow *shell_window)
gtk_container_add (GTK_CONTAINER (shell_window), widget);
gtk_widget_show (widget);
- container = widget;
+ box = GTK_BOX (widget);
widget = shell_window_construct_menubar (shell_window);
- gtk_box_pack_start (GTK_BOX (container), widget, FALSE, FALSE, 0);
+ if (widget != NULL)
+ gtk_box_pack_start (box, widget, FALSE, FALSE, 0);
widget = shell_window_construct_toolbar (shell_window);
- gtk_box_pack_start (GTK_BOX (container), widget, FALSE, FALSE, 0);
+ if (widget != NULL)
+ gtk_box_pack_start (box, widget, FALSE, FALSE, 0);
widget = gtk_hpaned_new ();
- gtk_box_pack_start (GTK_BOX (container), widget, TRUE, TRUE, 0);
+ gtk_box_pack_start (box, widget, TRUE, TRUE, 0);
priv->content_pane = g_object_ref (widget);
gtk_widget_show (widget);
widget = shell_window_construct_taskbar (shell_window);
- gtk_box_pack_start (GTK_BOX (container), widget, FALSE, FALSE, 0);
+ if (widget != NULL)
+ gtk_box_pack_start (box, widget, FALSE, FALSE, 0);
- container = priv->content_pane;
+ paned = GTK_PANED (priv->content_pane);
widget = shell_window_construct_sidebar (shell_window);
- gtk_paned_pack1 (GTK_PANED (container), widget, FALSE, FALSE);
+ if (widget != NULL)
+ gtk_paned_pack1 (paned, widget, FALSE, FALSE);
widget = shell_window_construct_content (shell_window);
- gtk_paned_pack2 (GTK_PANED (container), widget, TRUE, FALSE);
+ if (widget != NULL)
+ gtk_paned_pack2 (paned, widget, TRUE, FALSE);
/* Create the switcher actions before we set the initial
* shell view, because the shell view relies on them for