4 * i3 - an improved dynamic tiling window manager
6 * © 2009-2010 Michael Stapelberg and contributors
8 * See file LICENSE for license information.
10 * This public header defines the different constants and message types to use
11 * for the IPC interface to i3 (see docs/ipc for more information).
19 * Messages from clients to i3
23 /** Never change this, only on major IPC breakage (don’t do that) */
24 #define I3_IPC_MAGIC "i3-ipc"
26 /** The payload of the message will be interpreted as a command */
27 #define I3_IPC_MESSAGE_TYPE_COMMAND 0
29 /** Requests the current workspaces from i3 */
30 #define I3_IPC_MESSAGE_TYPE_GET_WORKSPACES 1
32 /** Subscribe to the specified events */
33 #define I3_IPC_MESSAGE_TYPE_SUBSCRIBE 2
35 /** Requests the current outputs from i3 */
36 #define I3_IPC_MESSAGE_TYPE_GET_OUTPUTS 3
38 /** Requests the tree layout from i3 */
39 #define I3_IPC_MESSAGE_TYPE_GET_TREE 4
41 /** Request the current defined marks from i3 */
42 #define I3_IPC_MESSAGE_TYPE_GET_MARKS 5
45 * Messages from i3 to clients
49 /** Command reply type */
50 #define I3_IPC_REPLY_TYPE_COMMAND 0
52 /** Workspaces reply type */
53 #define I3_IPC_REPLY_TYPE_WORKSPACES 1
55 /** Subscription reply type */
56 #define I3_IPC_REPLY_TYPE_SUBSCRIBE 2
58 /** Outputs reply type */
59 #define I3_IPC_REPLY_TYPE_OUTPUTS 3
61 /** Tree reply type */
62 #define I3_IPC_REPLY_TYPE_TREE 4
64 /** Marks reply type*/
65 #define I3_IPC_REPLY_TYPE_MARKS 5
68 * Events from i3 to clients. Events have the first bit set high.
71 #define I3_IPC_EVENT_MASK (1 << 31)
73 /* The workspace event will be triggered upon changes in the workspace list */
74 #define I3_IPC_EVENT_WORKSPACE (I3_IPC_EVENT_MASK | 0)
76 /* The output event will be triggered upon changes in the output list */
77 #define I3_IPC_EVENT_OUTPUT (I3_IPC_EVENT_MASK | 1)