X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=include%2Fwindow.h;h=77e3f48f2b0caca04c08a1ecae328b88256c76f9;hb=5720ba65ab073fff40cdf89f598d560e40741967;hp=044bde708682060f6bfe604ba12e381e8f26cb93;hpb=7415f1444894805d39b3f5400e887302a0fdf69f;p=i3%2Fi3 diff --git a/include/window.h b/include/window.h index 044bde70..77e3f48f 100644 --- a/include/window.h +++ b/include/window.h @@ -1,19 +1,35 @@ -#ifndef _WINDOW_H -#define _WINDOW_H +/* + * vim:ts=4:sw=4:expandtab + * + * i3 - an improved dynamic tiling window manager + * © 2009 Michael Stapelberg and contributors (see also: LICENSE) + * + * window.c: Updates window attributes (X11 hints/properties). + * + */ +#pragma once + +#include + +/** + * Frees an i3Window and all its members. + * + */ +void window_free(i3Window *win); /** * Updates the WM_CLASS (consisting of the class and instance) for the * given window. * */ -void window_update_class(i3Window *win, xcb_get_property_reply_t *prop); +void window_update_class(i3Window *win, xcb_get_property_reply_t *prop, bool before_mgmt); /** * Updates the name by using _NET_WM_NAME (encoded in UTF-8) for the given * window. Further updates using window_update_name_legacy will be ignored. * */ -void window_update_name(i3Window *win, xcb_get_property_reply_t *prop); +void window_update_name(i3Window *win, xcb_get_property_reply_t *prop, bool before_mgmt); /** * Updates the name by using WM_NAME (encoded in COMPOUND_TEXT). We do not @@ -22,6 +38,54 @@ void window_update_name(i3Window *win, xcb_get_property_reply_t *prop); * window_update_name()). * */ -void window_update_name_legacy(i3Window *win, xcb_get_property_reply_t *prop); +void window_update_name_legacy(i3Window *win, xcb_get_property_reply_t *prop, bool before_mgmt); + +/** + * Updates the CLIENT_LEADER (logical parent window). + * + */ +void window_update_leader(i3Window *win, xcb_get_property_reply_t *prop); + +/** + * Updates the TRANSIENT_FOR (logical parent window). + * + */ +void window_update_transient_for(i3Window *win, xcb_get_property_reply_t *prop); + +/** + * Updates the _NET_WM_STRUT_PARTIAL (reserved pixels at the screen edges) + * + */ +void window_update_strut_partial(i3Window *win, xcb_get_property_reply_t *prop); + +/** + * Updates the WM_WINDOW_ROLE + * + */ +void window_update_role(i3Window *win, xcb_get_property_reply_t *prop, bool before_mgmt); + +/** + * Updates the _NET_WM_WINDOW_TYPE property. + * + */ +void window_update_type(i3Window *window, xcb_get_property_reply_t *reply); -#endif +/** + * Updates the WM_HINTS (we only care about the input focus handling part). + * + */ +void window_update_hints(i3Window *win, xcb_get_property_reply_t *prop, bool *urgency_hint); + +/** + * Updates the MOTIF_WM_HINTS. The container's border style should be set to + * `motif_border_style' if border style is not BS_NORMAL. + * + * i3 only uses this hint when it specifies a window should have no + * title bar, or no decorations at all, which is how most window managers + * handle it. + * + * The EWMH spec intended to replace Motif hints with _NET_WM_WINDOW_TYPE, but + * it is still in use by popular widget toolkits such as GTK+ and Java AWT. + * + */ +void window_update_motif_hints(i3Window *win, xcb_get_property_reply_t *prop, border_style_t *motif_border_style);