]> git.sur5r.net Git - i3/i3/blobdiff - include/manage.h
Merge pull request #3448 from orestisf1993/sticky
[i3/i3] / include / manage.h
index 10beeb525c523b61724d9309cd3311543a569962..55b0a85b9a8d78d331c27cb796cee3f0284f71a6 100644 (file)
@@ -1,47 +1,39 @@
 /*
- * vim:ts=8:expandtab
+ * vim:ts=4:sw=4:expandtab
  *
  * i3 - an improved dynamic tiling window manager
+ * © 2009 Michael Stapelberg and contributors (see also: LICENSE)
  *
- * © 2009 Michael Stapelberg and contributors
- *
- * See file LICENSE for license information.
+ * manage.c: Initially managing new windows (or existing ones on restart).
  *
  */
-#include <xcb/xcb.h>
+#pragma once
 
-#include "data.h"
+#include <config.h>
 
-#ifndef _MANAGE_H
-#define _MANAGE_H
+#include "data.h"
 
 /**
  * Go through all existing windows (if the window manager is restarted) and
  * manage them
  *
  */
-void manage_existing_windows(xcb_connection_t *conn, xcb_property_handlers_t
-                             *prophs, xcb_window_t root);
+void manage_existing_windows(xcb_window_t root);
 
 /**
- * Do some sanity checks and then reparent the window.
+ * Restores the geometry of each window by reparenting it to the root window
+ * at the position of its frame.
+ *
+ * This is to be called *only* before exiting/restarting i3 because of evil
+ * side-effects which are to be expected when continuing to run i3.
  *
  */
-void manage_window(xcb_property_handlers_t *prophs, xcb_connection_t *conn,
-                   xcb_window_t window,
-                   xcb_get_window_attributes_cookie_t cookie,
-                   bool needs_to_be_mapped);
+void restore_geometry(void);
 
 /**
- * reparent_window() gets called when a new window was opened and becomes a
- * child of the root window, or it gets called by us when we manage the
- * already existing windows at startup.
- *
- * Essentially, this is the point where we take over control.
+ * Do some sanity checks and then reparent the window.
  *
  */
-void reparent_window(xcb_connection_t *conn, xcb_window_t child,
-                     xcb_visualid_t visual, xcb_window_t root, uint8_t depth,
-                     int16_t x, int16_t y, uint16_t width, uint16_t height);
-
-#endif
+void manage_window(xcb_window_t window,
+                   xcb_get_window_attributes_cookie_t cookie,
+                   bool needs_to_be_mapped);