summaryrefslogtreecommitdiff
path: root/gtk/gtkfilechooserdialog.c
diff options
context:
space:
mode:
authorFederico Mena Quintero <federico@novell.com>2009-01-14 20:18:54 +0000
committerFederico Mena Quintero <federico@src.gnome.org>2009-01-14 20:18:54 +0000
commitd133ab3ac0cb7065f9fda9e576d063298c654ffd (patch)
tree4c244149ba7e0be755b2ee81dc016b57204448c4 /gtk/gtkfilechooserdialog.c
parent1d4694ec799a0ade83ea071d929e41aa980fe21b (diff)
downloadgtk+-d133ab3ac0cb7065f9fda9e576d063298c654ffd.tar.gz
Don't clamp the restored size of the file chooser dialog
* gtk/gtkfilechooserdialog.c (file_chooser_widget_default_size_changed): Simply resize the dialog to the default size without any fancy clamping. Also, leave in place ifdef-ed out code to restore the file chooser's position in addition to its size. The code to restore the position doesn't quite work yet, but we'll leave it in as a reference. Signed-off-by: Federico Mena Quintero <federico@novell.com> svn path=/trunk/; revision=22118
Diffstat (limited to 'gtk/gtkfilechooserdialog.c')
-rw-r--r--gtk/gtkfilechooserdialog.c65
1 files changed, 32 insertions, 33 deletions
diff --git a/gtk/gtkfilechooserdialog.c b/gtk/gtkfilechooserdialog.c
index ec42374de1..cfa836d45e 100644
--- a/gtk/gtkfilechooserdialog.c
+++ b/gtk/gtkfilechooserdialog.c
@@ -25,6 +25,7 @@
#include "gtkfilechooserwidget.h"
#include "gtkfilechooserutils.h"
#include "gtkfilechooserembed.h"
+#include "gtkfilechoosersettings.h"
#include "gtkfilesystem.h"
#include "gtktypebuiltins.h"
#include "gtkintl.h"
@@ -154,37 +155,33 @@ file_chooser_widget_file_activated (GtkFileChooser *chooser,
g_list_free (children);
}
+#if 0
+/* FIXME: to see why this function is ifdef-ed out, see the comment below in
+ * file_chooser_widget_default_size_changed().
+ */
static void
-clamp_to_screen (GtkWidget *widget,
- gint *width,
- gint *height)
+load_position (int *out_xpos, int *out_ypos)
{
- GdkScreen *screen;
- int monitor_num;
- GdkRectangle monitor;
-
- g_return_if_fail (GTK_WIDGET_REALIZED (widget));
-
- screen = gtk_widget_get_screen (widget);
- monitor_num = gdk_screen_get_monitor_at_window (screen, widget->window);
-
- gdk_screen_get_monitor_geometry (screen, monitor_num, &monitor);
+ GtkFileChooserSettings *settings;
+ int x, y, width, height;
- if (width)
- *width = MIN (*width, (monitor.width * 3) / 4);
+ settings = _gtk_file_chooser_settings_new ();
+ _gtk_file_chooser_settings_get_geometry (settings, &x, &y, &width, &height);
+ g_object_unref (settings);
- if (height)
- *height = MIN (*height, (monitor.height * 3) / 4);
+ *out_xpos = x;
+ *out_ypos = y;
}
+#endif
static void
file_chooser_widget_default_size_changed (GtkWidget *widget,
GtkFileChooserDialog *dialog)
{
GtkFileChooserDialogPrivate *priv;
- gint width, height;
gint default_width, default_height;
GtkRequisition req, widget_req;
+ int xpos, ypos;
priv = GTK_FILE_CHOOSER_DIALOG_GET_PRIVATE (dialog);
@@ -197,27 +194,29 @@ file_chooser_widget_default_size_changed (GtkWidget *widget,
* that widget->requisition is meaningful. */
gtk_widget_size_request (GTK_WIDGET (dialog), &req);
gtk_widget_size_request (widget, &widget_req);
-
- width = req.width - widget_req.width;
- height = req.height - widget_req.height;
- }
- else
- {
- width = GTK_WIDGET (dialog)->allocation.width - widget->allocation.width;
- height = GTK_WIDGET (dialog)->allocation.height - widget->allocation.height;
}
_gtk_file_chooser_embed_get_default_size (GTK_FILE_CHOOSER_EMBED (priv->widget),
&default_width, &default_height);
- /* Ideal target size plus any extra size */
- width = default_width + width + (2 * GTK_CONTAINER (dialog)->border_width);
- height = default_height + height + (2 * GTK_CONTAINER (dialog)->border_width);
-
- if (GTK_WIDGET_REALIZED (dialog))
- clamp_to_screen (GTK_WIDGET (dialog), &width, &height);
+ gtk_window_resize (GTK_WINDOW (dialog), default_width, default_height);
- gtk_window_resize (GTK_WINDOW (dialog), width, height);
+ if (!GTK_WIDGET_MAPPED (dialog))
+ {
+#if 0
+ /* FIXME: the code to restore the position does not work yet. It is not
+ * clear whether it is actually desirable --- if enabled, applications
+ * would not be able to say "center the file chooser on top of my toplevel
+ * window". So, we don't use this code at all.
+ */
+ load_position (&xpos, &ypos);
+ if (xpos >= 0 && ypos >= 0)
+ {
+ gtk_window_set_position (GTK_WINDOW (dialog), GTK_WIN_POS_NONE);
+ gtk_window_move (GTK_WINDOW (dialog), xpos, ypos);
+ }
+#endif
+ }
}
static void