4 * i3 - an improved dynamic tiling window manager
6 * (c) 2009 Michael Stapelberg and contributors
8 * See file LICENSE for license information.
15 * Due to bindings like Mode_switch + <a>, we need to bind some keys in
16 * XCB_GRAB_MODE_SYNC. Therefore, we just replay all key presses.
19 int handle_key_release(void *ignored, xcb_connection_t *conn,
20 xcb_key_release_event_t *event);
23 * There was a key press. We compare this key code with our bindings table and
24 * pass the bound action to parse_command().
27 int handle_key_press(void *ignored, xcb_connection_t *conn,
28 xcb_key_press_event_t *event);
31 * When the user moves the mouse pointer onto a window, this callback gets
35 int handle_enter_notify(void *ignored, xcb_connection_t *conn,
36 xcb_enter_notify_event_t *event);
39 * When the user moves the mouse but does not change the active window
40 * (e.g. when having no windows opened but moving mouse on the root screen
41 * and crossing virtual screen boundaries), this callback gets called.
44 int handle_motion_notify(void *ignored, xcb_connection_t *conn,
45 xcb_motion_notify_event_t *event);
48 * Called when the keyboard mapping changes (for example by using Xmodmap),
49 * we need to update our key bindings then (re-translate symbols).
52 int handle_mapping_notify(void *ignored, xcb_connection_t *conn,
53 xcb_mapping_notify_event_t *event);
56 * Checks if the button press was on a stack window, handles focus setting and
57 * returns true if so, or false otherwise.
60 int handle_button_press(void *ignored, xcb_connection_t *conn,
61 xcb_button_press_event_t *event);
64 * A new window appeared on the screen (=was mapped), so let’s manage it.
67 int handle_map_request(void *prophs, xcb_connection_t *conn,
68 xcb_map_request_event_t *event);
71 * Configuration notifies are only handled because we need to set up ignore
72 * for the following enter notify events
75 int handle_configure_event(void *prophs, xcb_connection_t *conn, xcb_configure_notify_event_t *event);
78 * Configure requests are received when the application wants to resize
79 * windows on their own.
81 * We generate a synthethic configure notify event to signalize the client its
85 int handle_configure_request(void *prophs, xcb_connection_t *conn,
86 xcb_configure_request_event_t *event);
89 * Our window decorations were unmapped. That means, the window will be killed
90 * now, so we better clean up before.
93 int handle_unmap_notify_event(void *data, xcb_connection_t *conn, xcb_unmap_notify_event_t *event);
96 * Called when a window changes its title
99 int handle_windowname_change(void *data, xcb_connection_t *conn, uint8_t state,
100 xcb_window_t window, xcb_atom_t atom,
101 xcb_get_property_reply_t *prop);
104 * We handle legacy window names (titles) which are in COMPOUND_TEXT
105 * encoding. However, we just pass them along, so when containing non-ASCII
106 * characters, those will be rendering incorrectly. In order to correctly
107 * render unicode window titles in i3, an application has to set _NET_WM_NAME,
108 * which is in UTF-8 encoding.
110 * On every update, a message is put out to the user, so he may improve the
111 * situation and update applications which display filenames in their title to
112 * correctly use _NET_WM_NAME and therefore support unicode.
115 int handle_windowname_change_legacy(void *data, xcb_connection_t *conn,
116 uint8_t state, xcb_window_t window,
117 xcb_atom_t atom, xcb_get_property_reply_t
121 * Store the window classes for jumping to them later.
124 int handle_windowclass_change(void *data, xcb_connection_t *conn, uint8_t state,
125 xcb_window_t window, xcb_atom_t atom,
126 xcb_get_property_reply_t *prop);
130 * Expose event means we should redraw our windows (= title bar)
133 int handle_expose_event(void *data, xcb_connection_t *conn,
134 xcb_expose_event_t *event);
137 * Handle client messages (EWMH)
140 int handle_client_message(void *data, xcb_connection_t *conn,
141 xcb_client_message_event_t *event);
144 * Handles _NET_WM_WINDOW_TYPE changes
147 int handle_window_type(void *data, xcb_connection_t *conn, uint8_t state,
148 xcb_window_t window, xcb_atom_t atom,
149 xcb_get_property_reply_t *property);
152 * Handles the size hints set by a window, but currently only the part
153 * necessary for displaying clients proportionally inside their frames
154 * (mplayer for example)
156 * See ICCCM 4.1.2.3 for more details
159 int handle_normal_hints(void *data, xcb_connection_t *conn, uint8_t state,
160 xcb_window_t window, xcb_atom_t name,
161 xcb_get_property_reply_t *reply);
164 * Handles the transient for hints set by a window, signalizing that this
165 * window is a popup window for some other window.
167 * See ICCCM 4.1.2.6 for more details
170 int handle_transient_for(void *data, xcb_connection_t *conn, uint8_t state,
171 xcb_window_t window, xcb_atom_t name,
172 xcb_get_property_reply_t *reply);
175 * Handles changes of the WM_CLIENT_LEADER atom which specifies if this is a
176 * toolwindow (or similar) and to which window it belongs (logical parent).
179 int handle_clientleader_change(void *data, xcb_connection_t *conn,
180 uint8_t state, xcb_window_t window,
181 xcb_atom_t name, xcb_get_property_reply_t *prop);