312 lines
10 KiB
Diff
312 lines
10 KiB
Diff
bnc355503 - Make the file chooser remember its size across invocations
|
|
|
|
diff --git a/gtk/gtkfilechooserdefault.c b/gtk/gtkfilechooserdefault.c
|
|
index 16759a1..436246f 100644
|
|
--- a/gtk/gtkfilechooserdefault.c
|
|
+++ b/gtk/gtkfilechooserdefault.c
|
|
@@ -34,6 +34,7 @@
|
|
#include "gtkexpander.h"
|
|
#include "gtkfilechooserprivate.h"
|
|
#include "gtkfilechooserdefault.h"
|
|
+#include "gtkfilechooserdialog.h"
|
|
#include "gtkfilechooserembed.h"
|
|
#include "gtkfilechooserentry.h"
|
|
#include "gtkfilechoosersettings.h"
|
|
@@ -5986,6 +5987,23 @@ settings_load (GtkFileChooserDefault *impl)
|
|
}
|
|
|
|
static void
|
|
+save_dialog_geometry (GtkFileChooserDefault *impl, GtkFileChooserSettings *settings)
|
|
+{
|
|
+ GtkWindow *toplevel;
|
|
+ int x, y, width, height;
|
|
+
|
|
+ toplevel = get_toplevel (GTK_WIDGET (impl));
|
|
+
|
|
+ if (!(toplevel && GTK_IS_FILE_CHOOSER_DIALOG (toplevel)))
|
|
+ return;
|
|
+
|
|
+ gtk_window_get_position (toplevel, &x, &y);
|
|
+ gtk_window_get_size (toplevel, &width, &height);
|
|
+
|
|
+ _gtk_file_chooser_settings_set_geometry (settings, x, y, width, height);
|
|
+}
|
|
+
|
|
+static void
|
|
settings_save (GtkFileChooserDefault *impl)
|
|
{
|
|
GtkFileChooserSettings *settings;
|
|
@@ -5996,6 +6014,8 @@ settings_save (GtkFileChooserDefault *impl)
|
|
_gtk_file_chooser_settings_set_show_hidden (settings, gtk_file_chooser_get_show_hidden (GTK_FILE_CHOOSER (impl)));
|
|
_gtk_file_chooser_settings_set_expand_folders (settings, impl->expand_folders);
|
|
|
|
+ save_dialog_geometry (impl, settings);
|
|
+
|
|
/* NULL GError */
|
|
_gtk_file_chooser_settings_save (settings, NULL);
|
|
|
|
@@ -7825,6 +7845,22 @@ gtk_file_chooser_default_get_default_size (GtkFileChooserEmbed *chooser_embed,
|
|
|| impl->action == GTK_FILE_CHOOSER_ACTION_SELECT_FOLDER
|
|
|| impl->expand_folders)
|
|
{
|
|
+ GtkFileChooserSettings *settings;
|
|
+ int x, y, width, height;
|
|
+
|
|
+ settings = _gtk_file_chooser_settings_new ();
|
|
+ _gtk_file_chooser_settings_get_geometry (settings, &x, &y, &width, &height);
|
|
+ g_object_unref (settings);
|
|
+
|
|
+ if (x >= 0 && y >= 0 && width > 0 && height > 0)
|
|
+ {
|
|
+ GtkWindow *toplevel;
|
|
+
|
|
+ *default_width = width;
|
|
+ *default_height = height;
|
|
+ return;
|
|
+ }
|
|
+
|
|
find_good_size_from_style (GTK_WIDGET (chooser_embed), default_width, default_height);
|
|
|
|
if (impl->preview_widget_active &&
|
|
diff --git a/gtk/gtkfilechooserdialog.c b/gtk/gtkfilechooserdialog.c
|
|
index ec42374..27e8225 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"
|
|
@@ -155,26 +156,17 @@ file_chooser_widget_file_activated (GtkFileChooser *chooser,
|
|
}
|
|
|
|
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;
|
|
+ GtkFileChooserSettings *settings;
|
|
+ int x, y, width, height;
|
|
|
|
- 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);
|
|
-
|
|
- 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;
|
|
}
|
|
|
|
static void
|
|
@@ -182,9 +174,9 @@ 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 +189,18 @@ 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);
|
|
+ load_position (&xpos, &ypos);
|
|
|
|
- /* 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), width, height);
|
|
+ gtk_window_resize (GTK_WINDOW (dialog), default_width, default_height);
|
|
+ if (xpos >= 0 && ypos >= 0)
|
|
+ {
|
|
+ gtk_window_set_position (GTK_WINDOW (dialog), GTK_WIN_POS_NONE);
|
|
+ gtk_window_move (GTK_WINDOW (dialog), xpos, ypos);
|
|
+ }
|
|
}
|
|
|
|
static void
|
|
diff --git a/gtk/gtkfilechoosersettings.c b/gtk/gtkfilechoosersettings.c
|
|
index b80d362..c887928 100644
|
|
--- a/gtk/gtkfilechoosersettings.c
|
|
+++ b/gtk/gtkfilechoosersettings.c
|
|
@@ -41,6 +41,10 @@
|
|
#define LOCATION_MODE_KEY "LocationMode"
|
|
#define SHOW_HIDDEN_KEY "ShowHidden"
|
|
#define EXPAND_FOLDERS_KEY "ExpandFolders"
|
|
+#define GEOMETRY_X_KEY "GeometryX"
|
|
+#define GEOMETRY_Y_KEY "GeometryY"
|
|
+#define GEOMETRY_WIDTH_KEY "GeometryWidth"
|
|
+#define GEOMETRY_HEIGHT_KEY "GeometryHeight"
|
|
|
|
#define MODE_PATH_BAR "path-bar"
|
|
#define MODE_FILENAME_ENTRY "filename-entry"
|
|
@@ -60,6 +64,24 @@ get_config_filename (void)
|
|
}
|
|
|
|
static void
|
|
+get_int_key (GKeyFile *key_file, const char *group, const char *key, int *out_value)
|
|
+{
|
|
+ GError *error;
|
|
+ int val;
|
|
+
|
|
+ error = NULL;
|
|
+ val = g_key_file_get_integer (key_file, group, key, &error);
|
|
+
|
|
+ if (val == 0 && error != NULL)
|
|
+ {
|
|
+ *out_value = -1;
|
|
+ g_error_free (error);
|
|
+ }
|
|
+ else
|
|
+ *out_value = val;
|
|
+}
|
|
+
|
|
+static void
|
|
ensure_settings_read (GtkFileChooserSettings *settings)
|
|
{
|
|
GError *error;
|
|
@@ -127,6 +149,11 @@ ensure_settings_read (GtkFileChooserSettings *settings)
|
|
else
|
|
settings->expand_folders = value != FALSE;
|
|
|
|
+ get_int_key (key_file, SETTINGS_GROUP, GEOMETRY_X_KEY, &settings->geometry_x);
|
|
+ get_int_key (key_file, SETTINGS_GROUP, GEOMETRY_Y_KEY, &settings->geometry_y);
|
|
+ get_int_key (key_file, SETTINGS_GROUP, GEOMETRY_WIDTH_KEY, &settings->geometry_width);
|
|
+ get_int_key (key_file, SETTINGS_GROUP, GEOMETRY_HEIGHT_KEY, &settings->geometry_height);
|
|
+
|
|
out:
|
|
|
|
g_key_file_free (key_file);
|
|
@@ -148,6 +175,11 @@ _gtk_file_chooser_settings_init (GtkFileChooserSettings *settings)
|
|
settings->location_mode = LOCATION_MODE_PATH_BAR;
|
|
settings->show_hidden = FALSE;
|
|
settings->expand_folders = FALSE;
|
|
+
|
|
+ settings->geometry_x = -1;
|
|
+ settings->geometry_y = -1;
|
|
+ settings->geometry_width = -1;
|
|
+ settings->geometry_height = -1;
|
|
}
|
|
|
|
GtkFileChooserSettings *
|
|
@@ -198,6 +230,34 @@ _gtk_file_chooser_settings_set_expand_folders (GtkFileChooserSettings *settings,
|
|
settings->expand_folders = expand_folders != FALSE;
|
|
}
|
|
|
|
+void
|
|
+_gtk_file_chooser_settings_get_geometry (GtkFileChooserSettings *settings,
|
|
+ int *out_x,
|
|
+ int *out_y,
|
|
+ int *out_width,
|
|
+ int *out_height)
|
|
+{
|
|
+ ensure_settings_read (settings);
|
|
+
|
|
+ *out_x = settings->geometry_x;
|
|
+ *out_y = settings->geometry_y;
|
|
+ *out_width = settings->geometry_width;
|
|
+ *out_height = settings->geometry_height;
|
|
+}
|
|
+
|
|
+void
|
|
+_gtk_file_chooser_settings_set_geometry (GtkFileChooserSettings *settings,
|
|
+ int x,
|
|
+ int y,
|
|
+ int width,
|
|
+ int height)
|
|
+{
|
|
+ settings->geometry_x = x;
|
|
+ settings->geometry_y = y;
|
|
+ settings->geometry_width = width;
|
|
+ settings->geometry_height = height;
|
|
+}
|
|
+
|
|
gboolean
|
|
_gtk_file_chooser_settings_save (GtkFileChooserSettings *settings,
|
|
GError **error)
|
|
@@ -238,6 +298,14 @@ _gtk_file_chooser_settings_save (GtkFileChooserSettings *settings,
|
|
SHOW_HIDDEN_KEY, settings->show_hidden);
|
|
g_key_file_set_boolean (key_file, SETTINGS_GROUP,
|
|
EXPAND_FOLDERS_KEY, settings->expand_folders);
|
|
+ g_key_file_set_integer (key_file, SETTINGS_GROUP,
|
|
+ GEOMETRY_X_KEY, settings->geometry_x);
|
|
+ g_key_file_set_integer (key_file, SETTINGS_GROUP,
|
|
+ GEOMETRY_Y_KEY, settings->geometry_y);
|
|
+ g_key_file_set_integer (key_file, SETTINGS_GROUP,
|
|
+ GEOMETRY_WIDTH_KEY, settings->geometry_width);
|
|
+ g_key_file_set_integer (key_file, SETTINGS_GROUP,
|
|
+ GEOMETRY_HEIGHT_KEY, settings->geometry_height);
|
|
|
|
contents = g_key_file_to_data (key_file, &len, error);
|
|
g_key_file_free (key_file);
|
|
diff --git a/gtk/gtkfilechoosersettings.h b/gtk/gtkfilechoosersettings.h
|
|
index c7c4179..94d2e3a 100644
|
|
--- a/gtk/gtkfilechoosersettings.h
|
|
+++ b/gtk/gtkfilechoosersettings.h
|
|
@@ -38,6 +38,11 @@ struct _GtkFileChooserSettings
|
|
|
|
LocationMode location_mode;
|
|
|
|
+ int geometry_x;
|
|
+ int geometry_y;
|
|
+ int geometry_width;
|
|
+ int geometry_height;
|
|
+
|
|
guint settings_read : 1;
|
|
|
|
guint show_hidden : 1;
|
|
@@ -66,6 +71,17 @@ gboolean _gtk_file_chooser_settings_get_expand_folders (GtkFileChooserSettings *
|
|
void _gtk_file_chooser_settings_set_expand_folders (GtkFileChooserSettings *settings,
|
|
gboolean expand_folders);
|
|
|
|
+void _gtk_file_chooser_settings_get_geometry (GtkFileChooserSettings *settings,
|
|
+ int *out_x,
|
|
+ int *out_y,
|
|
+ int *out_width,
|
|
+ int *out_heigth);
|
|
+void _gtk_file_chooser_settings_set_geometry (GtkFileChooserSettings *settings,
|
|
+ int x,
|
|
+ int y,
|
|
+ int width,
|
|
+ int heigth);
|
|
+
|
|
gboolean _gtk_file_chooser_settings_save (GtkFileChooserSettings *settings,
|
|
GError **error);
|
|
|