Kaydet (Commit) d7f53f7f authored tarafından Nick Treleaven's avatar Nick Treleaven

Fix offscreen window after quitting when minimized

Fixes #3421282.
Occurred with Windows e.g. Vista, 7.
üst 3baaa536
...@@ -546,6 +546,8 @@ static void save_ui_prefs(GKeyFile *config) ...@@ -546,6 +546,8 @@ static void save_ui_prefs(GKeyFile *config)
if (prefs.save_winpos) if (prefs.save_winpos)
{ {
GdkWindowState wstate;
g_key_file_set_integer(config, PACKAGE, "treeview_position", g_key_file_set_integer(config, PACKAGE, "treeview_position",
gtk_paned_get_position(GTK_PANED(ui_lookup_widget(main_widgets.window, "hpaned1")))); gtk_paned_get_position(GTK_PANED(ui_lookup_widget(main_widgets.window, "hpaned1"))));
g_key_file_set_integer(config, PACKAGE, "msgwindow_position", g_key_file_set_integer(config, PACKAGE, "msgwindow_position",
...@@ -553,11 +555,8 @@ static void save_ui_prefs(GKeyFile *config) ...@@ -553,11 +555,8 @@ static void save_ui_prefs(GKeyFile *config)
gtk_window_get_position(GTK_WINDOW(main_widgets.window), &ui_prefs.geometry[0], &ui_prefs.geometry[1]); gtk_window_get_position(GTK_WINDOW(main_widgets.window), &ui_prefs.geometry[0], &ui_prefs.geometry[1]);
gtk_window_get_size(GTK_WINDOW(main_widgets.window), &ui_prefs.geometry[2], &ui_prefs.geometry[3]); gtk_window_get_size(GTK_WINDOW(main_widgets.window), &ui_prefs.geometry[2], &ui_prefs.geometry[3]);
if (gdk_window_get_state(gtk_widget_get_window(main_widgets.window)) & GDK_WINDOW_STATE_MAXIMIZED) wstate = gdk_window_get_state(gtk_widget_get_window(main_widgets.window));
ui_prefs.geometry[4] = 1; ui_prefs.geometry[4] = (wstate & GDK_WINDOW_STATE_MAXIMIZED) ? 1 : 0;
else
ui_prefs.geometry[4] = 0;
g_key_file_set_integer_list(config, PACKAGE, "geometry", ui_prefs.geometry, 5); g_key_file_set_integer_list(config, PACKAGE, "geometry", ui_prefs.geometry, 5);
} }
...@@ -938,13 +937,11 @@ static void load_ui_prefs(GKeyFile *config) ...@@ -938,13 +937,11 @@ static void load_ui_prefs(GKeyFile *config)
/* don't use insane values but when main windows was maximized last time, pos might be /* don't use insane values but when main windows was maximized last time, pos might be
* negative (due to differences in root window and window decorations) */ * negative (due to differences in root window and window decorations) */
if (ui_prefs.geometry[4] != 1) /* quitting when minimized can make pos -32000, -32000 on Windows! */
for (i = 0; i < 4; i++)
{ {
for (i = 2; i < 4; i++) if (ui_prefs.geometry[i] < -1)
{ ui_prefs.geometry[i] = -1;
if (ui_prefs.geometry[i] < -1)
ui_prefs.geometry[i] = -1;
}
} }
} }
hpan_position = utils_get_setting_integer(config, PACKAGE, "treeview_position", 156); hpan_position = utils_get_setting_integer(config, PACKAGE, "treeview_position", 156);
......
...@@ -156,13 +156,19 @@ static GOptionEntry entries[] = ...@@ -156,13 +156,19 @@ static GOptionEntry entries[] =
static void setup_window_position(void) static void setup_window_position(void)
{ {
/* interprets the saved window geometry */ /* interprets the saved window geometry */
if (prefs.save_winpos && ui_prefs.geometry[0] != -1) if (!prefs.save_winpos)
{ return;
gtk_window_move(GTK_WINDOW(main_widgets.window), ui_prefs.geometry[0], ui_prefs.geometry[1]);
gtk_window_set_default_size(GTK_WINDOW(main_widgets.window), ui_prefs.geometry[2], ui_prefs.geometry[3]); if (ui_prefs.geometry[0] != -1 && ui_prefs.geometry[1] != -1)
if (ui_prefs.geometry[4] == 1) gtk_window_move(GTK_WINDOW(main_widgets.window),
gtk_window_maximize(GTK_WINDOW(main_widgets.window)); ui_prefs.geometry[0], ui_prefs.geometry[1]);
}
if (ui_prefs.geometry[2] != -1 && ui_prefs.geometry[3] != -1)
gtk_window_set_default_size(GTK_WINDOW(main_widgets.window),
ui_prefs.geometry[2], ui_prefs.geometry[3]);
if (ui_prefs.geometry[4] == 1)
gtk_window_maximize(GTK_WINDOW(main_widgets.window));
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment