save/restore window position and size
[ptask.git] / src / ui.c
index 8567d4f..a63288b 100644 (file)
--- a/src/ui.c
+++ b/src/ui.c
  * 02110-1301 USA
  */
 
+#include <log.h>
 #include <ui.h>
 
-GtkWindow *create_window()
+static void save_settings(GtkWindow *window, GSettings *settings)
 {
-       return NULL;
+       int w, h, x, y;
+
+       gtk_window_get_size(window, &w, &h);
+       gtk_window_get_position(window, &x, &y);
+
+       log_debug("save_settings(): x=%d, y=%d, w=%d, h=%d", x, y, w, h);
+
+       g_settings_set_int(settings, "window-width", w);
+       g_settings_set_int(settings, "window-height", h);
+       g_settings_set_int(settings, "window-x", x);
+       g_settings_set_int(settings, "window-y", y);
+
+       g_settings_sync();
+}
+
+static gboolean delete_event_cbk(GtkWidget *w, GdkEvent *evt, gpointer data)
+{
+       log_debug("delete_event_cbk");
+
+       save_settings(GTK_WINDOW(w), (GSettings *)data);
+       gtk_widget_destroy(w);
+       gtk_main_quit();
+
+       return TRUE;
 }
+
+GtkWindow *create_window(GtkBuilder *builder, GSettings *settings)
+{
+       GtkWindow *window;
+       int x, y, h, w;
+
+       window = GTK_WINDOW(gtk_builder_get_object(builder, "window"));
+
+       x = g_settings_get_int(settings, "window-x");
+       y = g_settings_get_int(settings, "window-y");
+       w = g_settings_get_int(settings, "window-width");
+       h = g_settings_get_int(settings, "window-height");
+
+       gtk_window_set_default_size(window, w, h);
+       gtk_window_move(window, x, y);
+
+       g_signal_connect(window, "delete_event",
+                        G_CALLBACK(delete_event_cbk), settings);
+
+       return window;
+}
+