diff options
-rw-r--r-- | shell/ChangeLog | 9 | ||||
-rw-r--r-- | shell/evolution-shell-component.c | 29 | ||||
-rw-r--r-- | shell/evolution-shell-component.h | 2 |
3 files changed, 39 insertions, 1 deletions
diff --git a/shell/ChangeLog b/shell/ChangeLog index 004c44a304..884fa7fdef 100644 --- a/shell/ChangeLog +++ b/shell/ChangeLog @@ -1,5 +1,14 @@ 2001-10-05 Ettore Perazzoli <ettore@ximian.com> + * evolution-shell-component.c (impl_setOwner): If the owner is + dead, emit "owner_died" instead of "owner_unset". + (impl_owner_died): New, default implementation for "owner_died". + (class_init): Install it. + + * evolution-shell-component.h: New signal "owner_died". + +2001-10-05 Ettore Perazzoli <ettore@ximian.com> + * e-shell.c (set_owner_on_components): If setting the owner fails, print the a warning message out. Then restart the component. diff --git a/shell/evolution-shell-component.c b/shell/evolution-shell-component.c index 6fa1210f03..72ea36143b 100644 --- a/shell/evolution-shell-component.c +++ b/shell/evolution-shell-component.c @@ -72,6 +72,7 @@ struct _EvolutionShellComponentPrivate { enum { OWNER_SET, OWNER_UNSET, + OWNER_DIED, DEBUG, HANDLE_EXTERNAL_URI, USER_CREATE_NEW_ITEM, @@ -322,7 +323,7 @@ impl_setOwner (PortableServer_Servant servant, bonobo_object_unref (BONOBO_OBJECT (priv->owner_client)); priv->owner_client = NULL; - gtk_signal_emit (GTK_OBJECT (shell_component), signals[OWNER_UNSET]); + gtk_signal_emit (GTK_OBJECT (shell_component), signals[OWNER_DIED]); } return; @@ -616,11 +617,26 @@ destroy (GtkObject *object) } +/* EvolutionShellComponent methods. */ + +static void +impl_owner_died (EvolutionShellComponent *shell_component) +{ + /* The default implementation for ::owner_died emits ::owner_unset, so + that we make the behavior for old components kind of correct without + even if they don't handle the new ::owner_died signal correctly + yet. */ + + gtk_signal_emit (GTK_OBJECT (shell_component), signals[OWNER_UNSET]); +} + + /* Initialization. */ static void class_init (EvolutionShellComponentClass *klass) { + EvolutionShellComponentClass *shell_component_class; GtkObjectClass *object_class; POA_GNOME_Evolution_ShellComponent__epv *epv = &klass->epv; @@ -636,6 +652,14 @@ class_init (EvolutionShellComponentClass *klass) GTK_TYPE_NONE, 2, GTK_TYPE_POINTER, GTK_TYPE_POINTER); + signals[OWNER_DIED] + = gtk_signal_new ("owner_died", + GTK_RUN_FIRST, + object_class->type, + GTK_SIGNAL_OFFSET (EvolutionShellComponentClass, owner_died), + gtk_marshal_NONE__NONE, + GTK_TYPE_NONE, 0); + signals[OWNER_UNSET] = gtk_signal_new ("owner_unset", GTK_RUN_FIRST, @@ -689,6 +713,9 @@ class_init (EvolutionShellComponentClass *klass) epv->xferFolderAsync = impl_xferFolderAsync; epv->populateFolderContextMenu = impl_populateFolderContextMenu; epv->userCreateNewItem = impl_userCreateNewItem; + + shell_component_class = EVOLUTION_SHELL_COMPONENT_CLASS (object_class); + shell_component_class->owner_died = impl_owner_died; } static void diff --git a/shell/evolution-shell-component.h b/shell/evolution-shell-component.h index 6d273e5337..bf8eaf4776 100644 --- a/shell/evolution-shell-component.h +++ b/shell/evolution-shell-component.h @@ -139,6 +139,8 @@ struct _EvolutionShellComponentClass { EvolutionShellClient *shell_client, const char *evolution_homedir); void (* owner_unset) (EvolutionShellComponent *shell_component); + void (* owner_died) (EvolutionShellComponent *shell_component); + void (* debug) (EvolutionShellComponent *shell_component); void (* handle_external_uri) (EvolutionShellComponent *shell_component, |