diff options
author | Matthias Clasen <mclasen@redhat.com> | 2004-09-17 18:13:26 +0000 |
---|---|---|
committer | Matthias Clasen <matthiasc@src.gnome.org> | 2004-09-17 18:13:26 +0000 |
commit | 350559dea8f48114796c2c895dab0d0cb66413d2 (patch) | |
tree | c74d1f188236d749701d1fc8b910e15dbdcabf2b /gtk | |
parent | 4e7e40493853047d2bc91d1b4c4bd00ba8405d19 (diff) | |
download | gtk+-350559dea8f48114796c2c895dab0d0cb66413d2.tar.gz |
Remove leftover debug code.
2004-09-17 Matthias Clasen <mclasen@redhat.com>
* gtk/gtkcellrenderertext.c (gtk_cell_renderer_text_render): Remove
leftover debug code.
Improve the behaviour of the file chooser in save mode. Fixes bugs
#151031, #151608, #151994 reported by Owen Taylor and Alexander
Larsson.
* gtk/gtkfilechooserdefault.c (gtk_file_chooser_default_set_property):
(location_entry_create): Propagate the action to the file
chooser entries.
(gtk_file_chooser_default_should_respond): Switch folders if
the user enters a directory name in the entry and clear the entry
after switching folders.
(gtk_file_chooser_default_should_respond, shortcuts_row_activated_cb):
Move focus to the file list when activating a shortcut.
(gtk_file_chooser_default_should_respond): Handle the case where the
user clicks on "Save" after selecting a folder in the file list.
* gtk/gtkfilechooserbutton.c (gtk_file_chooser_button_set_property):
Propagate the action to the file chooser entries.
* gtk/gtkfilechooserentry.h:
* gtk/gtkfilechooserentry.c (_gtk_file_chooser_entry_set_action):
(_gtk_file_chooser_entry_get_action): New functions to propagate
the GtkFileChooserAction of the file chooser to the file chooser
entry.
(check_completion_callback): If we are in save mode, only do
inline completion for directories.
Diffstat (limited to 'gtk')
-rw-r--r-- | gtk/gtkcellrenderertext.c | 10 | ||||
-rw-r--r-- | gtk/gtkfilechooserbutton.c | 1 | ||||
-rw-r--r-- | gtk/gtkfilechooserdefault.c | 41 | ||||
-rw-r--r-- | gtk/gtkfilechooserentry.c | 66 | ||||
-rw-r--r-- | gtk/gtkfilechooserentry.h | 4 |
5 files changed, 106 insertions, 16 deletions
diff --git a/gtk/gtkcellrenderertext.c b/gtk/gtkcellrenderertext.c index 6516ff11fc..dfb770d57a 100644 --- a/gtk/gtkcellrenderertext.c +++ b/gtk/gtkcellrenderertext.c @@ -1416,8 +1416,6 @@ gtk_cell_renderer_text_get_size (GtkCellRenderer *cell, (1.0 - cell->xalign) : cell->xalign) * (cell_area->width - rect.width - (2 * cell->xpad)); if (gtk_widget_get_direction (widget) == GTK_TEXT_DIR_RTL) *x_offset -= rect.width; - if (celltext->text && !strcmp ("Makefile", celltext->text)) - g_print ("x_offset: %d %d %d\n", cell_area->width, *x_offset, rect.width); *x_offset = MAX (*x_offset, 0); } if (y_offset) @@ -1509,8 +1507,6 @@ gtk_cell_renderer_text_render (GtkCellRenderer *cell, else pango_layout_set_width (layout, -1); - if (celltext->text && !strcmp ("Makefile", celltext->text)) - g_print ("render: %d %d %d\n", cell_area->x, cell_area->width, cell_area->x + x_offset + cell->xpad); gtk_paint_layout (widget->style, window, state, @@ -1521,12 +1517,6 @@ gtk_cell_renderer_text_render (GtkCellRenderer *cell, cell_area->x + x_offset + cell->xpad, cell_area->y + y_offset + cell->ypad, layout); - gdk_draw_line (window, widget->style->black_gc, - cell_area->x + x_offset + cell->xpad, - cell_area->y + y_offset + cell->ypad, - cell_area->x + x_offset + cell->xpad, - cell_area->y + y_offset + cell->ypad + 20); - g_object_unref (layout); } diff --git a/gtk/gtkfilechooserbutton.c b/gtk/gtkfilechooserbutton.c index 27bb1f47b4..17490fd972 100644 --- a/gtk/gtkfilechooserbutton.c +++ b/gtk/gtkfilechooserbutton.c @@ -340,6 +340,7 @@ gtk_file_chooser_button_set_property (GObject *object, case GTK_FILE_CHOOSER_PROP_ACTION: g_object_set_property (G_OBJECT (priv->dialog), pspec->name, value); + _gtk_file_chooser_entry_set_action (priv->entry, g_value_get_enum (value)); switch (g_value_get_enum (value)) { diff --git a/gtk/gtkfilechooserdefault.c b/gtk/gtkfilechooserdefault.c index 4b840580d8..fef3911630 100644 --- a/gtk/gtkfilechooserdefault.c +++ b/gtk/gtkfilechooserdefault.c @@ -3644,6 +3644,10 @@ gtk_file_chooser_default_set_property (GObject *object, impl->action = action; update_appearance (impl); } + + if (impl->save_file_name_entry) + _gtk_file_chooser_entry_set_action (GTK_FILE_CHOOSER_ENTRY (impl->save_file_name_entry), + action); } break; case GTK_FILE_CHOOSER_PROP_FILE_SYSTEM_BACKEND: @@ -4933,20 +4937,26 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed) gboolean is_valid, is_empty; gboolean is_folder; gboolean retval; + GtkFileChooserEntry *entry; save_entry: g_assert (impl->action == GTK_FILE_CHOOSER_ACTION_SAVE || impl->action == GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER); + entry = GTK_FILE_CHOOSER_ENTRY (impl->save_file_name_entry); path = check_save_entry (impl, &is_valid, &is_empty); - if (!is_valid) + if (!is_empty && !is_valid) return FALSE; + if (is_empty) + path = gtk_file_path_copy (_gtk_file_chooser_entry_get_current_folder (entry)); + is_folder = check_is_folder (impl->file_system, path, NULL); if (is_folder) { + _gtk_file_chooser_entry_set_file_part (entry, ""); change_folder_and_display_error (impl, path); retval = FALSE; } @@ -4965,15 +4975,31 @@ gtk_file_chooser_default_should_respond (GtkFileChooserEmbed *chooser_embed) GtkTreeIter iter; if (shortcuts_get_selected (impl, &iter)) - shortcuts_activate_iter (impl, &iter); + { + shortcuts_activate_iter (impl, &iter); + + gtk_widget_grab_focus (impl->browse_files_tree_view); + } else goto file_list; return FALSE; } + else if (impl->toplevel_last_focus_widget == impl->browse_files_tree_view) + { + /* The focus is on a dialog's action area button, *and* the widget that + * was focused immediately before it is the file list. + */ + goto file_list; + } else - goto file_list; /* The focus is on a dialog's action area button or something else */ - + /* The focus is on a dialog's action area button or something else */ + if (impl->action == GTK_FILE_CHOOSER_ACTION_SAVE + || impl->action == GTK_FILE_CHOOSER_ACTION_CREATE_FOLDER) + goto save_entry; + else + goto file_list; + g_assert_not_reached (); return FALSE; } @@ -5174,13 +5200,14 @@ shortcuts_activate_iter (GtkFileChooserDefault *impl, -1); if (!col_data) - return; /* We are on a separator */ + return FALSE; /* We are on a separator */ if (is_volume) { GtkFileSystemVolume *volume; volume = col_data; + shortcuts_activate_volume (impl, volume); } else @@ -5209,6 +5236,8 @@ shortcuts_row_activated_cb (GtkTreeView *tree_view, &child_iter, &iter); shortcuts_activate_iter (impl, &child_iter); + + gtk_widget_grab_focus (impl->browse_files_tree_view); } /* Handler for GtkWidget::key-press-event on the shortcuts list */ @@ -5500,7 +5529,7 @@ location_entry_create (GtkFileChooserDefault *impl) gtk_entry_set_activates_default (GTK_ENTRY (entry), TRUE); _gtk_file_chooser_entry_set_file_system (GTK_FILE_CHOOSER_ENTRY (entry), impl->file_system); _gtk_file_chooser_entry_set_base_folder (GTK_FILE_CHOOSER_ENTRY (entry), impl->current_folder); - + _gtk_file_chooser_entry_set_action (GTK_FILE_CHOOSER_ENTRY (entry), impl->action); if (impl->action == GTK_FILE_CHOOSER_ACTION_OPEN || impl->action == GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER) _gtk_file_chooser_entry_set_file_part (GTK_FILE_CHOOSER_ENTRY (entry), ""); diff --git a/gtk/gtkfilechooserentry.c b/gtk/gtkfilechooserentry.c index 1d942a099d..4d9a098560 100644 --- a/gtk/gtkfilechooserentry.c +++ b/gtk/gtkfilechooserentry.c @@ -43,6 +43,8 @@ struct _GtkFileChooserEntry { GtkEntry parent_instance; + GtkFileChooserAction action; + GtkFileSystem *file_system; GtkFilePath *base_folder; GtkFilePath *current_folder_path; @@ -175,6 +177,7 @@ gtk_file_chooser_entry_init (GtkFileChooserEntry *chooser_entry) GtkCellRenderer *cell; comp = gtk_entry_completion_new (); + gtk_entry_completion_set_match_func (comp, completion_match_func, chooser_entry, @@ -451,6 +454,19 @@ check_completion_callback (GtkFileChooserEntry *chooser_entry) gtk_file_path_free (unique_path); } + switch (chooser_entry->action) + { + case GTK_FILE_CHOOSER_ACTION_SAVE: + case GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER: + if (common_prefix && !g_str_has_suffix (common_prefix, "/")) + { + g_free (common_prefix); + common_prefix = NULL; + } + break; + default: ; + } + if (common_prefix) { gint file_part_len; @@ -874,6 +890,11 @@ _gtk_file_chooser_entry_set_base_folder (GtkFileChooserEntry *chooser_entry, const GtkFilePath * _gtk_file_chooser_entry_get_current_folder (GtkFileChooserEntry *chooser_entry) { + if (chooser_entry->has_completion) + { + gtk_editable_set_position (GTK_EDITABLE (chooser_entry), + GTK_ENTRY (chooser_entry)->text_length); + } return chooser_entry->current_folder_path; } @@ -892,6 +913,11 @@ _gtk_file_chooser_entry_get_current_folder (GtkFileChooserEntry *chooser_entry) const gchar * _gtk_file_chooser_entry_get_file_part (GtkFileChooserEntry *chooser_entry) { + if (chooser_entry->has_completion) + { + gtk_editable_set_position (GTK_EDITABLE (chooser_entry), + GTK_ENTRY (chooser_entry)->text_length); + } return chooser_entry->file_part; } @@ -910,3 +936,43 @@ _gtk_file_chooser_entry_set_file_part (GtkFileChooserEntry *chooser_entry, gtk_entry_set_text (GTK_ENTRY (chooser_entry), file_part); } + + +/** + * _gtk_file_chooser_entry_set_action: + * @chooser_entry: a #GtkFileChooserEntry + * @action: the action which is performed by the file selector using this entry + * + * Sets action which is performed by the file selector using this entry. + * The #GtkFileChooserEntry will use different completion strategies for + * different actions. + **/ +void +_gtk_file_chooser_entry_set_action (GtkFileChooserEntry *chooser_entry, + GtkFileChooserAction action) +{ + g_return_if_fail (GTK_IS_FILE_CHOOSER_ENTRY (chooser_entry)); + + if ( chooser_entry->action != action) + { + chooser_entry->action = action; + } +} + + +/** + * _gtk_file_chooser_entry_get_action: + * @chooser_entry: a #GtkFileChooserEntry + * + * Gets the action for this entry. + * + * Returns: the action + **/ +GtkFileChooserAction +_gtk_file_chooser_entry_get_action (GtkFileChooserEntry *chooser_entry) +{ + g_return_val_if_fail (GTK_IS_FILE_CHOOSER_ENTRY (chooser_entry), + GTK_FILE_CHOOSER_ACTION_OPEN); + + return chooser_entry->action; +} diff --git a/gtk/gtkfilechooserentry.h b/gtk/gtkfilechooserentry.h index 3a47869c02..df8017bacb 100644 --- a/gtk/gtkfilechooserentry.h +++ b/gtk/gtkfilechooserentry.h @@ -22,6 +22,7 @@ #define __GTK_FILE_CHOOSER_ENTRY_H__ #include "gtkfilesystem.h" +#include "gtkfilechooser.h" #include <gtk/gtkwidget.h> G_BEGIN_DECLS @@ -34,6 +35,9 @@ typedef struct _GtkFileChooserEntry GtkFileChooserEntry; GType _gtk_file_chooser_entry_get_type (void); GtkWidget * _gtk_file_chooser_entry_new (gboolean eat_tab); +void _gtk_file_chooser_entry_set_action (GtkFileChooserEntry *chooser_entry, + GtkFileChooserAction action); +GtkFileChooserAction _gtk_file_chooser_entry_get_action (GtkFileChooserEntry *chooser_entry); void _gtk_file_chooser_entry_set_file_system (GtkFileChooserEntry *chooser_entry, GtkFileSystem *file_system); void _gtk_file_chooser_entry_set_base_folder (GtkFileChooserEntry *chooser_entry, |