diff options
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | shell/ev-window.c | 12 |
2 files changed, 19 insertions, 1 deletions
@@ -1,3 +1,11 @@ +2008-08-24 Carlos Garcia Campos <carlosgc@gnome.org> + + * shell/ev-window.c: (ev_window_setup_document), + (ev_window_set_document), (ev_window_dispose): + + Remove the idle function for setting the document up when the + window is destroyed. Fixes bug #549163. + 2008-08-22 Carlos Garcia Campos <carlosgc@gnome.org> * shell/ev-jobs.[ch]: (ev_job_attachments_init), diff --git a/shell/ev-window.c b/shell/ev-window.c index 0293229..7b5a770 100644 --- a/shell/ev-window.c +++ b/shell/ev-window.c @@ -166,6 +166,7 @@ struct _EvWindowPrivate { gboolean unlink_temp_file; gboolean in_reload; EvFileMonitor *monitor; + guint setup_document_idle; EvDocument *document; EvHistory *history; @@ -1138,6 +1139,8 @@ ev_window_setup_document (EvWindow *ev_window) EvDocument *document = ev_window->priv->document; EvSidebar *sidebar = EV_SIDEBAR (ev_window->priv->sidebar); GtkAction *action; + + ev_window->priv->setup_document_idle = 0; if (EV_IS_DOCUMENT_FIND (document)) { g_signal_connect_object (G_OBJECT (document), @@ -1203,7 +1206,9 @@ ev_window_set_document (EvWindow *ev_window, EvDocument *document) _("The document contains no pages")); } - g_idle_add ((GSourceFunc)ev_window_setup_document, ev_window); + if (ev_window->priv->setup_document_idle > 0) + g_source_remove (ev_window->priv->setup_document_idle); + ev_window->priv->setup_document_idle = g_idle_add ((GSourceFunc)ev_window_setup_document, ev_window); } static void @@ -4168,6 +4173,11 @@ ev_window_dispose (GObject *object) } #endif /* ENABLE_DBUS */ + if (priv->setup_document_idle > 0) { + g_source_remove (priv->setup_document_idle); + priv->setup_document_idle = 0; + } + if (priv->monitor) { g_object_unref (priv->monitor); priv->monitor = NULL; |