X-Git-Url: http://pileus.org/git/?a=blobdiff_plain;f=tests%2Ftestfilechooserbutton.c;h=40270110991df5ec704bfd9c923e7b475b5cfbe5;hb=9d0febc9a64a5bfb0fcfc3a88de4757f6c1ff090;hp=e4774e5ee67247506fc71aa69059a15b5c15feb2;hpb=24295f3a5f5a14a535e862a6978df179cd3dc162;p=~andy%2Fgtk diff --git a/tests/testfilechooserbutton.c b/tests/testfilechooserbutton.c index e4774e5ee..402701109 100644 --- a/tests/testfilechooserbutton.c +++ b/tests/testfilechooserbutton.c @@ -1,7 +1,31 @@ +/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 2 -*- */ + +/* GTK+: gtkfilechooserbutton.c + * + * Copyright (c) 2004 James M. Cape + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Library General Public + * License as published by the Free Software Foundation; either + * version 2 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Library General Public License for more details. + * + * You should have received a copy of the GNU Library General Public + * License along with this library. If not, see . + */ + +#include "config.h" + +#ifdef HAVE_UNISTD_H +#include +#endif #include #include -#include #include @@ -9,14 +33,29 @@ #include "prop-editor.h" +static gchar *backend = "gtk+"; +static gboolean rtl = FALSE; +static GOptionEntry entries[] = { + { "backend", 'b', 0, G_OPTION_ARG_STRING, &backend, "The filesystem backend to use.", "gtk+" }, + { "right-to-left", 'r', 0, G_OPTION_ARG_NONE, &rtl, "Force right-to-left layout.", NULL }, + { NULL } +}; + +static gchar *gtk_src_dir = NULL; + static void win_style_set_cb (GtkWidget *win) { - gtk_container_set_border_width (GTK_CONTAINER (GTK_DIALOG (win)->vbox), 12); - gtk_box_set_spacing (GTK_BOX (GTK_DIALOG (win)->vbox), 24); - gtk_container_set_border_width (GTK_CONTAINER (GTK_DIALOG (win)->action_area), 0); - gtk_box_set_spacing (GTK_BOX (GTK_DIALOG (win)->action_area), 6); + GtkWidget *content_area, *action_area; + + content_area = gtk_dialog_get_content_area (GTK_DIALOG (win)); + action_area = gtk_dialog_get_action_area (GTK_DIALOG (win)); + + gtk_container_set_border_width (GTK_CONTAINER (content_area), 12); + gtk_box_set_spacing (GTK_BOX (content_area), 24); + gtk_container_set_border_width (GTK_CONTAINER (action_area), 0); + gtk_box_set_spacing (GTK_BOX (action_area), 6); } static gboolean @@ -67,7 +106,50 @@ print_selected_path_clicked_cb (GtkWidget *button, } static void -tests_button_clicked_cb (GtkWidget *button, +add_pwds_parent_as_shortcut_clicked_cb (GtkWidget *button, + gpointer user_data) +{ + GError *err = NULL; + + if (!gtk_file_chooser_add_shortcut_folder (user_data, gtk_src_dir, &err)) + { + g_message ("Couldn't add `%s' as shortcut folder: %s", gtk_src_dir, + err->message); + g_error_free (err); + } + else + { + g_message ("Added `%s' as shortcut folder.", gtk_src_dir); + } +} + +static void +del_pwds_parent_as_shortcut_clicked_cb (GtkWidget *button, + gpointer user_data) +{ + GError *err = NULL; + + if (!gtk_file_chooser_remove_shortcut_folder (user_data, gtk_src_dir, &err)) + { + g_message ("Couldn't remove `%s' as shortcut folder: %s", gtk_src_dir, + err->message); + g_error_free (err); + } + else + { + g_message ("Removed `%s' as shortcut folder.", gtk_src_dir); + } +} + +static void +unselect_all_clicked_cb (GtkWidget *button, + gpointer user_data) +{ + gtk_file_chooser_unselect_all (user_data); +} + +static void +tests_button_clicked_cb (GtkButton *real_button, gpointer user_data) { GtkWidget *tests; @@ -76,24 +158,42 @@ tests_button_clicked_cb (GtkWidget *button, if (tests == NULL) { - GtkWidget *box, *button1; + GtkWidget *box, *button; tests = gtk_window_new (GTK_WINDOW_TOPLEVEL); gtk_window_set_title (GTK_WINDOW (tests), "Tests - TestFileChooserButton"); gtk_container_set_border_width (GTK_CONTAINER (tests), 12); gtk_window_set_transient_for (GTK_WINDOW (tests), - GTK_WINDOW (gtk_widget_get_toplevel (button))); + GTK_WINDOW (gtk_widget_get_toplevel (user_data))); - box = gtk_vbox_new (FALSE, 0); + box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0); gtk_container_add (GTK_CONTAINER (tests), box); gtk_widget_show (box); - button1 = gtk_button_new_with_label ("Print Selected Path"); - g_signal_connect (button1, "clicked", + button = gtk_button_new_with_label ("Print Selected Path"); + g_signal_connect (button, "clicked", G_CALLBACK (print_selected_path_clicked_cb), user_data); - gtk_box_pack_start (GTK_BOX (box), button1, FALSE, FALSE, 0); - gtk_widget_show (button1); + gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 0); + gtk_widget_show (button); + + button = gtk_button_new_with_label ("Add $PWD's Parent as Shortcut"); + g_signal_connect (button, "clicked", + G_CALLBACK (add_pwds_parent_as_shortcut_clicked_cb), user_data); + gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 0); + gtk_widget_show (button); + + button = gtk_button_new_with_label ("Remove $PWD's Parent as Shortcut"); + g_signal_connect (button, "clicked", + G_CALLBACK (del_pwds_parent_as_shortcut_clicked_cb), user_data); + gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 0); + gtk_widget_show (button); + + button = gtk_button_new_with_label ("Unselect all"); + g_signal_connect (button, "clicked", + G_CALLBACK (unselect_all_clicked_cb), user_data); + gtk_box_pack_start (GTK_BOX (box), button, FALSE, FALSE, 0); + gtk_widget_show (button); g_signal_connect (tests, "delete-event", G_CALLBACK (delete_event_cb), NULL); g_object_set_data (user_data, "tests-dialog", tests); @@ -108,8 +208,8 @@ chooser_current_folder_changed_cb (GtkFileChooser *chooser, { gchar *folder, *filename; - folder = gtk_file_chooser_get_current_folder (chooser); - filename = gtk_file_chooser_get_filename (chooser); + folder = gtk_file_chooser_get_current_folder_uri (chooser); + filename = gtk_file_chooser_get_uri (chooser); g_message ("%s::current-folder-changed\n\tFolder: `%s'\n\tFilename: `%s'\nDone.\n", G_OBJECT_TYPE_NAME (chooser), folder, filename); g_free (folder); @@ -122,7 +222,7 @@ chooser_selection_changed_cb (GtkFileChooser *chooser, { gchar *filename; - filename = gtk_file_chooser_get_filename (chooser); + filename = gtk_file_chooser_get_uri (chooser); g_message ("%s::selection-changed\n\tSelection:`%s'\nDone.\n", G_OBJECT_TYPE_NAME (chooser), filename); g_free (filename); @@ -134,8 +234,8 @@ chooser_file_activated_cb (GtkFileChooser *chooser, { gchar *folder, *filename; - folder = gtk_file_chooser_get_current_folder (chooser); - filename = gtk_file_chooser_get_filename (chooser); + folder = gtk_file_chooser_get_current_folder_uri (chooser); + filename = gtk_file_chooser_get_uri (chooser); g_message ("%s::file-activated\n\tFolder: `%s'\n\tFilename: `%s'\nDone.\n", G_OBJECT_TYPE_NAME (chooser), folder, filename); g_free (folder); @@ -148,10 +248,13 @@ chooser_update_preview_cb (GtkFileChooser *chooser, { gchar *filename; - filename = gtk_file_chooser_get_preview_filename (chooser); - g_message ("%s::update-preview\n\tPreview Filename: `%s'\nDone.\n", - G_OBJECT_TYPE_NAME (chooser), filename); - g_free (filename); + filename = gtk_file_chooser_get_preview_uri (chooser); + if (filename != NULL) + { + g_message ("%s::update-preview\n\tPreview Filename: `%s'\nDone.\n", + G_OBJECT_TYPE_NAME (chooser), filename); + g_free (filename); + } } @@ -162,19 +265,32 @@ main (int argc, GtkWidget *win, *vbox, *frame, *alignment, *group_box; GtkWidget *hbox, *label, *chooser, *button; GtkSizeGroup *label_group; + GOptionContext *context; + gchar *cwd; + + context = g_option_context_new ("- test GtkFileChooserButton widget"); + g_option_context_add_main_entries (context, entries, GETTEXT_PACKAGE); + g_option_context_add_group (context, gtk_get_option_group (TRUE)); + g_option_context_parse (context, &argc, &argv, NULL); + g_option_context_free (context); + gtk_init (&argc, &argv); - /* to test rtl layout, set RTL=1 in the environment */ - if (g_getenv ("RTL")) + /* to test rtl layout, use "--right-to-left" */ + if (rtl) gtk_widget_set_default_direction (GTK_TEXT_DIR_RTL); - win = gtk_dialog_new_with_buttons ("TestFileChooserButton", NULL, GTK_DIALOG_NO_SEPARATOR, + cwd = g_get_current_dir(); + gtk_src_dir = g_path_get_dirname (cwd); + g_free (cwd); + + win = gtk_dialog_new_with_buttons ("TestFileChooserButton", NULL, 0, GTK_STOCK_QUIT, GTK_RESPONSE_CLOSE, NULL); g_signal_connect (win, "style-set", G_CALLBACK (win_style_set_cb), NULL); g_signal_connect (win, "response", G_CALLBACK (gtk_main_quit), NULL); - vbox = gtk_vbox_new (FALSE, 18); - gtk_container_add (GTK_CONTAINER (GTK_DIALOG (win)->vbox), vbox); + vbox = gtk_box_new (GTK_ORIENTATION_VERTICAL, 18); + gtk_container_add (GTK_CONTAINER (gtk_dialog_get_content_area (GTK_DIALOG (win))), vbox); frame = gtk_frame_new ("GtkFileChooserButton"); gtk_frame_set_shadow_type (GTK_FRAME (frame), GTK_SHADOW_NONE); @@ -187,11 +303,11 @@ main (int argc, label_group = gtk_size_group_new (GTK_SIZE_GROUP_HORIZONTAL); - group_box = gtk_vbox_new (FALSE, 6); + group_box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 6); gtk_container_add (GTK_CONTAINER (alignment), group_box); - /* open mode */ - hbox = gtk_hbox_new (FALSE, 12); + /* OPEN */ + hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 12); gtk_box_pack_start (GTK_BOX (group_box), hbox, FALSE, FALSE, 0); label = gtk_label_new_with_mnemonic ("_Open:"); @@ -199,14 +315,17 @@ main (int argc, gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0); - chooser = gtk_file_chooser_button_new ("Select A File - testfilechooserbutton"); + chooser = gtk_file_chooser_button_new ("Select A File - testfilechooserbutton", + GTK_FILE_CHOOSER_ACTION_OPEN); + gtk_file_chooser_add_shortcut_folder (GTK_FILE_CHOOSER (chooser), gtk_src_dir, NULL); + gtk_file_chooser_remove_shortcut_folder (GTK_FILE_CHOOSER (chooser), gtk_src_dir, NULL); gtk_label_set_mnemonic_widget (GTK_LABEL (label), chooser); g_signal_connect (chooser, "current-folder-changed", G_CALLBACK (chooser_current_folder_changed_cb), NULL); g_signal_connect (chooser, "selection-changed", G_CALLBACK (chooser_selection_changed_cb), NULL); g_signal_connect (chooser, "file-activated", G_CALLBACK (chooser_file_activated_cb), NULL); g_signal_connect (chooser, "update-preview", G_CALLBACK (chooser_update_preview_cb), NULL); - gtk_container_add (GTK_CONTAINER (hbox), chooser); + gtk_box_pack_start (GTK_BOX (hbox), chooser, TRUE, TRUE, 0); button = gtk_button_new_from_stock (GTK_STOCK_PROPERTIES); g_signal_connect (button, "clicked", G_CALLBACK (properties_button_clicked_cb), chooser); @@ -216,8 +335,8 @@ main (int argc, g_signal_connect (button, "clicked", G_CALLBACK (tests_button_clicked_cb), chooser); gtk_box_pack_start (GTK_BOX (hbox), button, FALSE, FALSE, 0); - /* select folder mode */ - hbox = gtk_hbox_new (FALSE, 12); + /* SELECT_FOLDER */ + hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 12); gtk_box_pack_start (GTK_BOX (group_box), hbox, FALSE, FALSE, 0); label = gtk_label_new_with_mnemonic ("Select _Folder:"); @@ -225,15 +344,18 @@ main (int argc, gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5); gtk_box_pack_start (GTK_BOX (hbox), label, FALSE, FALSE, 0); - chooser = gtk_file_chooser_button_new ("Select A File - testfilechooserbutton"); - gtk_file_chooser_set_action (GTK_FILE_CHOOSER (chooser), GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER); + chooser = gtk_file_chooser_button_new ("Select A Folder - testfilechooserbutton", + GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER); + gtk_file_chooser_add_shortcut_folder (GTK_FILE_CHOOSER (chooser), gtk_src_dir, NULL); + gtk_file_chooser_remove_shortcut_folder (GTK_FILE_CHOOSER (chooser), gtk_src_dir, NULL); + gtk_file_chooser_add_shortcut_folder (GTK_FILE_CHOOSER (chooser), gtk_src_dir, NULL); gtk_label_set_mnemonic_widget (GTK_LABEL (label), chooser); g_signal_connect (chooser, "current-folder-changed", G_CALLBACK (chooser_current_folder_changed_cb), NULL); g_signal_connect (chooser, "selection-changed", G_CALLBACK (chooser_selection_changed_cb), NULL); g_signal_connect (chooser, "file-activated", G_CALLBACK (chooser_file_activated_cb), NULL); g_signal_connect (chooser, "update-preview", G_CALLBACK (chooser_update_preview_cb), NULL); - gtk_container_add (GTK_CONTAINER (hbox), chooser); + gtk_box_pack_start (GTK_BOX (hbox), chooser, TRUE, TRUE, 0); button = gtk_button_new_from_stock (GTK_STOCK_PROPERTIES); g_signal_connect (button, "clicked", G_CALLBACK (properties_button_clicked_cb), chooser); @@ -250,7 +372,5 @@ main (int argc, gtk_main (); - gtk_widget_destroy (win); - return 0; }