From 4654c4625e79a0d36ef25d81a0c6f53fcd714837 Mon Sep 17 00:00:00 2001 From: Ettore Perazzoli Date: Sat, 2 Sep 2000 19:01:04 +0000 Subject: Make the `Home' and `End' keys do the Right Thing. Remove circular reference to the shell. Bind "Open in New Window" to `Ctrl-O'. svn path=/trunk/; revision=5181 --- mail/folder-browser.c | 57 ++++++++++++++++++++++++++++++--------------------- 1 file changed, 34 insertions(+), 23 deletions(-) (limited to 'mail/folder-browser.c') diff --git a/mail/folder-browser.c b/mail/folder-browser.c index 44f33a22cf..99365678a3 100644 --- a/mail/folder-browser.c +++ b/mail/folder-browser.c @@ -49,13 +49,8 @@ folder_browser_destroy (GtkObject *object) { FolderBrowser *folder_browser = FOLDER_BROWSER (object); - if (folder_browser->shell) { - CORBA_Environment ev; - - CORBA_exception_init (&ev); - Bonobo_Unknown_unref (folder_browser->shell, &ev); - CORBA_exception_free (&ev); - } + if (folder_browser->shell) + CORBA_free (folder_browser->shell); if (folder_browser->uri) g_free (folder_browser->uri); @@ -308,7 +303,10 @@ etable_key (ETable *table, int row, int col, GdkEvent *ev, FolderBrowser *fb) if ((ev->key.state & !(GDK_SHIFT_MASK | GDK_LOCK_MASK)) != 0) return FALSE; - if (ev->key.keyval == GDK_space || ev->key.keyval == GDK_BackSpace) { + switch (ev->key.keyval) { + case GDK_space: + case GDK_BackSpace: + { GtkAdjustment *vadj; gfloat page_size; @@ -329,20 +327,42 @@ etable_key (ETable *table, int row, int col, GdkEvent *ev, FolderBrowser *fb) gtk_adjustment_value_changed (vadj); return TRUE; - } else if (ev->key.keyval == GDK_Delete || - ev->key.keyval == GDK_KP_Delete) { + } + + case GDK_Delete: + case GDK_KP_Delete: delete_msg (NULL, fb); message_list_select (fb->message_list, row, MESSAGE_LIST_SELECT_NEXT, 0, CAMEL_MESSAGE_DELETED); return TRUE; - } else if (ev->key.keyval == 'n' || ev->key.keyval == 'N' || - ev->key.keyval == 'p' || ev->key.keyval == 'P') { + + case GDK_Home: + case GDK_KP_Home: + message_list_home (fb->message_list); + return TRUE; + + case GDK_End: + case GDK_KP_End: + message_list_end (fb->message_list); + return TRUE; + + case 'n': + case 'N': message_list_select (fb->message_list, row, - tolower (ev->key.keyval) == 'p' ? - MESSAGE_LIST_SELECT_PREVIOUS : MESSAGE_LIST_SELECT_NEXT, 0, CAMEL_MESSAGE_SEEN); + return TRUE; + + case 'p': + case 'P': + message_list_select (fb->message_list, row, + MESSAGE_LIST_SELECT_PREVIOUS, + 0, CAMEL_MESSAGE_SEEN); + return TRUE; + + default: + return FALSE; } return FALSE; @@ -441,21 +461,12 @@ folder_browser_new (Evolution_Shell shell) { static int serial; FolderBrowser *folder_browser = gtk_type_new (folder_browser_get_type ()); - CORBA_Environment ev; my_folder_browser_init (GTK_OBJECT (folder_browser)); folder_browser->uri = NULL; folder_browser->serial = serial++; folder_browser->shell = shell; -#ifndef NO_WARNINGS -#warning "is this a circular reference???" -#endif - - CORBA_exception_init (&ev); - Bonobo_Unknown_ref (shell, &ev); - CORBA_exception_free (&ev); - return GTK_WIDGET (folder_browser); } -- cgit