summaryrefslogtreecommitdiff
path: root/tests/testfilechooserbutton.c
diff options
context:
space:
mode:
authorJames M. Cape <jcape@ignore-your.tv>2004-12-15 14:58:39 +0000
committerJames M. Cape <jcape@src.gnome.org>2004-12-15 14:58:39 +0000
commitb418bf3aa4428c0c2189d846d64cd77ca8205841 (patch)
treebeeddab1e80bb79093d0f6ca11ba8d1288e4cfcf /tests/testfilechooserbutton.c
parent43f8526198c6ad98f7160a748d22d6f5e00e6f6c (diff)
downloadgtk+-b418bf3aa4428c0c2189d846d64cd77ca8205841.tar.gz
Use a GtkComboBox in SELECT_FOLDER mode (#157726).
2004-12-15 James M. Cape <jcape@ignore-your.tv> * gtk/gtkfilechooserbutton.c (struct _GtkFileChooserButtonPrivate) (gtk_file_chooser_button_init) (gtk_file_chooser_button_file_chooser_iface_init) (gtk_file_chooser_button_add_shortcut_folder) (gtk_file_chooser_button_remove_shortcut_folder) (gtk_file_chooser_button_constructor) (gtk_file_chooser_button_set_property) (gtk_file_chooser_button_destroy) (gtk_file_chooser_button_finalize) (get_icon_theme) (get_display_name_for_path) (model_get_type_position) (model_free_row_data) (model_add_special) (model_add_other) (model_add_volumes) (model_add_bookmarks) (model_update_current_folder) (model_remove_rows) (filter_model_visible_func) (combo_box_row_separator_func) (name_cell_data_func) (update_combo_box) (fs_volumes_changed_cb) (fs_bookmarks_changed_cb) (combo_box_changed_cb) (change_icon_size): Use a GtkComboBox in SELECT_FOLDER mode (#157726). * gtk/gtkfilechooserbutton.c: * gtk/gtkfilechooserbutton.h (gtk_file_chooser_button_new) (gtk_file_chooser_button_new_with_backend): Add @action to constructors to match other GtkFileChooser impls. API CHANGE. * docs/tools/widgets.c (create_file_button): * tests/testfilechooserbutton.c (main): Update callers. * docs/reference/gtk/tmpl/gtkfilechooserbutton.sgml: Reflect API change. * tests/testfilechooserbutton.c: Add LGPL license. (main): Added GOption parser for --backend and --right-to-left cmd line args. (add_pwds_parent_as_shortcut_clicked_cb) (del_pwds_parent_as_shortcut_clicked_cb) (tests_button_clicked_cb): Add shortcut_folders test. (chooser_current_folder_changed_cb) (chooser_selection_changed_cb) (chooser_file_activated_cb) (chooser_update_preview_cb): Print URIS, not filenames.
Diffstat (limited to 'tests/testfilechooserbutton.c')
-rw-r--r--tests/testfilechooserbutton.c145
1 files changed, 125 insertions, 20 deletions
diff --git a/tests/testfilechooserbutton.c b/tests/testfilechooserbutton.c
index e4774e5ee6..00215302dc 100644
--- a/tests/testfilechooserbutton.c
+++ b/tests/testfilechooserbutton.c
@@ -1,3 +1,30 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 2 -*- */
+
+/* GTK+: gtkfilechooserbutton.c
+ *
+ * Copyright (c) 2004 James M. Cape <jcape@ignore-your.tv>
+ *
+ * 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, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ */
+
+#include <config.h>
+
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif
#include <sys/types.h>
#include <sys/stat.h>
@@ -9,6 +36,16 @@
#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)
@@ -67,7 +104,43 @@ 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
+tests_button_clicked_cb (GtkButton *real_button,
gpointer user_data)
{
GtkWidget *tests;
@@ -76,24 +149,36 @@ 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);
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);
g_signal_connect (tests, "delete-event", G_CALLBACK (delete_event_cb), NULL);
g_object_set_data (user_data, "tests-dialog", tests);
@@ -108,8 +193,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 +207,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 +219,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,7 +233,7 @@ chooser_update_preview_cb (GtkFileChooser *chooser,
{
gchar *filename;
- filename = gtk_file_chooser_get_preview_filename (chooser);
+ filename = gtk_file_chooser_get_preview_uri (chooser);
g_message ("%s::update-preview\n\tPreview Filename: `%s'\nDone.\n",
G_OBJECT_TYPE_NAME (chooser), filename);
g_free (filename);
@@ -162,12 +247,24 @@ main (int argc,
GtkWidget *win, *vbox, *frame, *alignment, *group_box;
GtkWidget *hbox, *label, *chooser, *button;
GtkSizeGroup *label_group;
+ GOptionContext *context;
+ gchar cwd[2048];
+
+ 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);
+ getcwd (cwd, sizeof (cwd));
+ gtk_src_dir = g_path_get_dirname (cwd);
+
win = gtk_dialog_new_with_buttons ("TestFileChooserButton", NULL, GTK_DIALOG_NO_SEPARATOR,
GTK_STOCK_QUIT, GTK_RESPONSE_CLOSE, NULL);
g_signal_connect (win, "style-set", G_CALLBACK (win_style_set_cb), NULL);
@@ -190,7 +287,7 @@ main (int argc,
group_box = gtk_vbox_new (FALSE, 6);
gtk_container_add (GTK_CONTAINER (alignment), group_box);
- /* open mode */
+ /* OPEN */
hbox = gtk_hbox_new (FALSE, 12);
gtk_box_pack_start (GTK_BOX (group_box), hbox, FALSE, FALSE, 0);
@@ -199,7 +296,11 @@ 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_with_backend ("Select A File - testfilechooserbutton",
+ GTK_FILE_CHOOSER_ACTION_OPEN,
+ backend);
+ 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);
@@ -216,7 +317,7 @@ 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 */
+ /* SELECT_FOLDER */
hbox = gtk_hbox_new (FALSE, 12);
gtk_box_pack_start (GTK_BOX (group_box), hbox, FALSE, FALSE, 0);
@@ -225,8 +326,12 @@ 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_with_backend ("Select A Folder - testfilechooserbutton",
+ GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER,
+ backend);
+ 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);