aboutsummaryrefslogtreecommitdiffstats
path: root/shell/e-shell-view.c
diff options
context:
space:
mode:
Diffstat (limited to 'shell/e-shell-view.c')
-rw-r--r--shell/e-shell-view.c151
1 files changed, 92 insertions, 59 deletions
diff --git a/shell/e-shell-view.c b/shell/e-shell-view.c
index c20c7b043a..3654e31fe4 100644
--- a/shell/e-shell-view.c
+++ b/shell/e-shell-view.c
@@ -69,6 +69,12 @@
static BonoboWindowClass *parent_class = NULL;
+struct _View {
+ char *uri;
+ GtkWidget *control;
+};
+typedef struct _View View;
+
struct _EShellViewPrivate {
/* The shell. */
EShell *shell;
@@ -122,7 +128,7 @@ struct _EShellViewPrivate {
GtkWidget *folder_bar_popup;
/* The views we have already open. */
- GHashTable *uri_to_control;
+ GHashTable *uri_to_view;
/* Position of the handles in the paneds, to be restored when we show elements
after hiding them. */
@@ -174,6 +180,29 @@ static const char *get_storage_set_path_from_uri (const char *uri);
static void new_folder_cb (EStorageSet *storage_set, const char *path, void *data);
+/* View handling. */
+
+static View *
+view_new (const char *uri,
+ GtkWidget *control)
+{
+ View *new;
+
+ new = g_new (View, 1);
+ new->uri = g_strdup (uri);
+ new->control = control;
+
+ return new;
+}
+
+static void
+view_destroy (View *view)
+{
+ g_free (view->uri);
+ g_free (view);
+}
+
+
/* Utility functions. */
static GtkWidget *
@@ -961,16 +990,17 @@ setup_widgets (EShellView *shell_view)
/* GtkObject methods. */
static void
-hash_forall_destroy_control (void *name,
- void *value,
- void *data)
+hash_forall_destroy_view (void *name,
+ void *value,
+ void *data)
{
- BonoboWidget *bonobo_widget;
+ View *view;
+
+ view = (View *) value;
- bonobo_widget = BONOBO_WIDGET (value);
- gtk_widget_destroy (GTK_WIDGET (bonobo_widget));
+ gtk_widget_destroy (view->control);
- g_free (name);
+ view_destroy (view);
}
static void
@@ -1001,8 +1031,8 @@ destroy (GtkObject *object)
gtk_signal_disconnect (GTK_OBJECT (socket_widget), destroy_connection_id);
}
- g_hash_table_foreach (priv->uri_to_control, hash_forall_destroy_control, NULL);
- g_hash_table_destroy (priv->uri_to_control);
+ g_hash_table_foreach (priv->uri_to_view, hash_forall_destroy_view, NULL);
+ g_hash_table_destroy (priv->uri_to_view);
bonobo_object_unref (BONOBO_OBJECT (priv->ui_component));
@@ -1097,7 +1127,7 @@ init (EShellView *shell_view)
priv->hpaned_position = 0;
priv->view_hpaned_position = 0;
- priv->uri_to_control = g_hash_table_new (g_str_hash, g_str_equal);
+ priv->uri_to_view = g_hash_table_new (g_str_hash, g_str_equal);
priv->sockets = NULL;
@@ -1432,6 +1462,9 @@ update_for_current_uri (EShellView *shell_view)
path = get_storage_set_path_from_uri (priv->uri);
+ title = NULL;
+ type = NULL;
+
if (path == NULL) {
folder = NULL;
} else {
@@ -1444,10 +1477,7 @@ update_for_current_uri (EShellView *shell_view)
EStorage *storage;
storage = e_storage_set_get_storage (e_shell_get_storage_set (priv->shell), path + 1);
- if (storage == NULL) {
- title = NULL;
- type = NULL;
- } else {
+ if (storage != NULL) {
title = e_storage_get_display_name (storage);
type = e_storage_get_toplevel_node_type (storage);
}
@@ -1628,7 +1658,7 @@ socket_destroy_cb (GtkWidget *socket_widget, gpointer data)
EShellView *shell_view;
EShellViewPrivate *priv;
EFolder *folder;
- GtkWidget *control;
+ View *view;
const char *uri;
gboolean viewing_closed_uri;
char *copy_of_uri;
@@ -1644,8 +1674,9 @@ socket_destroy_cb (GtkWidget *socket_widget, gpointer data)
/* Strdup here as the string will be freed when the socket is destroyed. */
copy_of_uri = g_strdup (uri);
- control = g_hash_table_lookup (priv->uri_to_control, uri);
- if (control == NULL) {
+ view = g_hash_table_lookup (priv->uri_to_view, uri);
+
+ if (view == NULL) {
g_warning ("What?! Destroyed socket for non-existing URI? -- %s", uri);
g_free (copy_of_uri);
return;
@@ -1653,8 +1684,10 @@ socket_destroy_cb (GtkWidget *socket_widget, gpointer data)
priv->sockets = g_list_remove (priv->sockets, socket_widget);
- gtk_widget_destroy (control);
- g_hash_table_remove (priv->uri_to_control, uri);
+ gtk_widget_destroy (view->control);
+
+ view_destroy (view);
+ g_hash_table_remove (priv->uri_to_view, uri);
path = get_storage_set_path_from_uri (uri);
folder = e_storage_set_get_folder (e_shell_get_storage_set (priv->shell), path);
@@ -1739,9 +1772,9 @@ get_type_for_folder (EShellView *shell_view,
}
/* Create a new view for @uri with @control. It assumes a view for @uri does not exist yet. */
-static GtkWidget *
-get_control_for_uri (EShellView *shell_view,
- const char *uri)
+static View *
+get_view_for_uri (EShellView *shell_view,
+ const char *uri)
{
EShellViewPrivate *priv;
CORBA_Environment ev;
@@ -1815,43 +1848,44 @@ get_control_for_uri (EShellView *shell_view,
setup_corba_interface (shell_view, control);
- return control;
+ return view_new (uri, control);
}
static gboolean
show_existing_view (EShellView *shell_view,
const char *uri,
- GtkWidget *control)
+ View *view)
{
EShellViewPrivate *priv;
int notebook_page;
priv = shell_view->priv;
- notebook_page = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook), control);
+ notebook_page = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook), view->control);
g_assert (notebook_page != -1);
/* A BonoboWidget can be a "zombie" in the sense that its actual
control is dead; if it's zombie, we have to recreate it. */
- if (bonobo_widget_is_dead (BONOBO_WIDGET (control))) {
+ if (bonobo_widget_is_dead (BONOBO_WIDGET (view->control))) {
GtkWidget *parent;
- parent = control->parent;
+ parent = view->control->parent;
/* Out with the old. */
- gtk_container_remove (GTK_CONTAINER (parent), control);
- g_hash_table_remove (priv->uri_to_control, uri);
+ gtk_container_remove (GTK_CONTAINER (parent), view->control);
+ view_destroy (view);
+ g_hash_table_remove (priv->uri_to_view, uri);
/* In with the new. */
- control = get_control_for_uri (shell_view, uri);
- if (control == NULL)
+ view = get_view_for_uri (shell_view, uri);
+ if (view == NULL)
return FALSE;
- gtk_container_add (GTK_CONTAINER (parent), control);
- g_hash_table_insert (priv->uri_to_control, g_strdup (uri), control);
+ gtk_container_add (GTK_CONTAINER (parent), view->control);
+ g_hash_table_insert (priv->uri_to_view, g_strdup (uri), view);
/* Show. */
- gtk_widget_show (control);
+ gtk_widget_show (view->control);
}
g_free (priv->uri);
@@ -1866,28 +1900,28 @@ static gboolean
create_new_view_for_uri (EShellView *shell_view,
const char *uri)
{
- GtkWidget *control;
+ View *view;
EShellViewPrivate *priv;
int page_num;
priv = shell_view->priv;
- control = get_control_for_uri (shell_view, uri);
- if (control == NULL)
+ view = get_view_for_uri (shell_view, uri);
+ if (view == NULL)
return FALSE;
g_free (priv->uri);
priv->uri = g_strdup (uri);
- gtk_widget_show (control);
+ gtk_widget_show (view->control);
- gtk_notebook_append_page (GTK_NOTEBOOK (priv->notebook), control, NULL);
+ gtk_notebook_append_page (GTK_NOTEBOOK (priv->notebook), view->control, NULL);
- page_num = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook), control);
+ page_num = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook), view->control);
g_assert (page_num != -1);
set_current_notebook_page (shell_view, page_num);
- g_hash_table_insert (priv->uri_to_control, g_strdup (uri), control);
+ g_hash_table_insert (priv->uri_to_view, g_strdup (uri), view);
return TRUE;
}
@@ -1897,7 +1931,7 @@ e_shell_view_display_uri (EShellView *shell_view,
const char *uri)
{
EShellViewPrivate *priv;
- GtkWidget *control;
+ View *view;
gboolean retval;
g_return_val_if_fail (shell_view != NULL, FALSE);
@@ -1925,11 +1959,10 @@ e_shell_view_display_uri (EShellView *shell_view,
goto end;
}
- control = g_hash_table_lookup (priv->uri_to_control, uri);
- if (control != NULL) {
- g_assert (GTK_IS_WIDGET (control));
- show_existing_view (shell_view, uri, control);
- } else if (!create_new_view_for_uri (shell_view, uri)) {
+ view = g_hash_table_lookup (priv->uri_to_view, uri);
+ if (view != NULL) {
+ show_existing_view (shell_view, uri, view);
+ } else if (! create_new_view_for_uri (shell_view, uri)) {
cleanup_delayed_selection (shell_view);
priv->delayed_selection = g_strdup (uri);
gtk_signal_connect_after (GTK_OBJECT (e_shell_get_storage_set (priv->shell)), "new_folder",
@@ -1961,7 +1994,7 @@ e_shell_view_remove_control_for_uri (EShellView *shell_view,
const char *uri)
{
EShellViewPrivate *priv;
- GtkWidget *control;
+ View *view;
GtkWidget *socket;
int page_num;
@@ -1971,26 +2004,26 @@ e_shell_view_remove_control_for_uri (EShellView *shell_view,
priv = shell_view->priv;
/* Get the control, remove it from our hash of controls */
- control = g_hash_table_lookup (priv->uri_to_control, uri);
- if (control != NULL)
- g_hash_table_remove (priv->uri_to_control, uri);
- else
+ view = g_hash_table_lookup (priv->uri_to_view, uri);
+ if (view != NULL) {
+ view_destroy (view);
+ g_hash_table_remove (priv->uri_to_view, uri);
+ } else {
return FALSE;
+ }
/* Get the socket, remove it from our list of sockets */
- socket = find_socket (GTK_CONTAINER (control));
+ socket = find_socket (GTK_CONTAINER (view->control));
priv->sockets = g_list_remove (priv->sockets, socket);
/* Remove the notebook page */
- page_num = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook),
- control);
- gtk_notebook_remove_page (GTK_NOTEBOOK (priv->notebook),
- page_num);
+ page_num = gtk_notebook_page_num (GTK_NOTEBOOK (priv->notebook), view->control);
+ gtk_notebook_remove_page (GTK_NOTEBOOK (priv->notebook), page_num);
/* Destroy things, socket first because otherwise shell will
think the control crashed */
gtk_widget_destroy (socket);
- gtk_widget_destroy (control);
+ gtk_widget_destroy (view->control);
return TRUE;
}