X-Git-Url: http://gitweb.hugovil.com/?a=blobdiff_plain;f=src%2Ffilemenu.c;h=ce13368ef44697259e3afd1041ab1b3f49d8b71c;hb=c361bcde92ff71208eded7e706f25f567c1de793;hp=bb7489ccd4c96c7653062d9fdf58287c5467e193;hpb=b23541495010180e3a69e3e1f64c934b28775878;p=emu8051.git diff --git a/src/filemenu.c b/src/filemenu.c index bb7489c..ce13368 100644 --- a/src/filemenu.c +++ b/src/filemenu.c @@ -34,64 +34,81 @@ #define FILENAME_DESCRIPTION "Open Intel Hex file" +static char previous_folder[MAX_FILENAME_LENGTH + 1]; + static void -FileOpenDialog_OK(GtkWidget *widget, gpointer file_dialog) +remember_current_folder(GtkFileChooser *chooser) { - char *selected_file; + char *folder; + + folder = gtk_file_chooser_get_current_folder(chooser); + if (folder != NULL) { + if (strlen(folder) >= MAX_FILENAME_LENGTH) { + /* Non-critical error */ + g_print("current folder name too long for buffer\n"); + } else { #if defined(DEBUG) - g_print("FileOpenDialog_OK()\n"); + g_print("current folder = %s\n", folder); #endif - /* - * The cast to (char *) is to remove a warning in GTK2, because the - * return value of the gtk_file_selection_get_filename() function is - * 'G_CONST_RETURN gchar *'. - */ - selected_file = (char *) gtk_file_selection_get_filename( - GTK_FILE_SELECTION(file_dialog)); - - g_print("emugtk_File = %s\n", selected_file); - - emugtk_new_file(selected_file); + strncpy(previous_folder, folder, MAX_FILENAME_LENGTH); + } - gtk_widget_destroy(GTK_WIDGET(file_dialog)); + g_free(folder); + } } void FileOpenEvent(GtkObject *object, gpointer data) { GtkWidget *file_dialog; + char *dir; + char *cwd = NULL; #if defined(DEBUG) g_print("FileOpenEvent()\n"); #endif /* Create a new file selection widget. */ - file_dialog = gtk_file_selection_new(FILENAME_DESCRIPTION); - - /* Connect the file dialog's OK button up to a handler. */ - gtk_signal_connect( - GTK_OBJECT(GTK_FILE_SELECTION(file_dialog)->ok_button), - "clicked", GTK_SIGNAL_FUNC(FileOpenDialog_OK), file_dialog); - - /* - * Ensure that the file selection dialog box is destroyed when the user - * clicks CANCEL. - */ - gtk_signal_connect_object( - GTK_OBJECT(GTK_FILE_SELECTION(file_dialog)->cancel_button), - "clicked", GTK_SIGNAL_FUNC(gtk_widget_destroy), - (gpointer) file_dialog); - - /* Show the dialog. */ - gtk_widget_show(GTK_WIDGET(file_dialog)); - - /* - * To have the main window of our application being unusable while - * using the dialog. - */ - gtk_window_set_modal(GTK_WINDOW(file_dialog), TRUE); + file_dialog = gtk_file_chooser_dialog_new( + FILENAME_DESCRIPTION, NULL, GTK_FILE_CHOOSER_ACTION_OPEN, + GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, + GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT, NULL); + + if (strlen(previous_folder) == 0) { + /* Opening file chooser to current working directory. */ + cwd = g_get_current_dir(); + dir = cwd; + } else { + /* Opening file chooser to previous opened directory. */ + dir = previous_folder; + } + + gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(file_dialog), dir); + + if (cwd) + g_free(cwd); + + if (gtk_dialog_run(GTK_DIALOG(file_dialog)) == GTK_RESPONSE_ACCEPT) { + char *selected_file; + + selected_file = gtk_file_chooser_get_filename( + GTK_FILE_CHOOSER(file_dialog)); + + if (selected_file != NULL) { +#if defined(DEBUG) + g_print("emugtk_File = %s\n", selected_file); +#endif + + remember_current_folder(GTK_FILE_CHOOSER(file_dialog)); + + emugtk_new_file(selected_file); + g_free(selected_file); + } + } + + gtk_widget_destroy(file_dialog); } static void @@ -101,7 +118,6 @@ FileQuitEvent(gchar *string) g_print("%s\n", string); #endif - emugtk_StopRunning(); gtk_main_quit(); } @@ -115,7 +131,7 @@ FileAddMenu(GtkWidget *menu_bar) /* Create the 'open' item. */ item = gtk_menu_item_new_with_label(FILENAME_DESCRIPTION); - gtk_menu_append(GTK_MENU(menu), item); + gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); /* Attach the callback functions to the activate signal. */ gtk_signal_connect_object(GTK_OBJECT(item), "activate", GTK_SIGNAL_FUNC(FileOpenEvent), NULL); @@ -123,7 +139,7 @@ FileAddMenu(GtkWidget *menu_bar) AddMenuSeparator(menu); item = gtk_menu_item_new_with_label("Exit"); - gtk_menu_append(GTK_MENU(menu), item); + gtk_menu_shell_append(GTK_MENU_SHELL(menu), item); /* We can attach the Quit menu item to our exit function */ gtk_signal_connect_object(GTK_OBJECT(item), "activate", GTK_SIGNAL_FUNC(FileQuitEvent),