2009-07-28 20:51:29 +02:00
|
|
|
|
/*
|
2011-10-25 22:19:38 +02:00
|
|
|
|
* vim:ts=4:sw=4:expandtab
|
2009-07-28 20:51:29 +02:00
|
|
|
|
*
|
|
|
|
|
* i3 - an improved dynamic tiling window manager
|
2015-04-04 02:17:56 +02:00
|
|
|
|
* © 2009 Michael Stapelberg and contributors (see also: LICENSE)
|
2009-07-28 20:51:29 +02:00
|
|
|
|
*
|
|
|
|
|
* This public header defines the different constants and message types to use
|
|
|
|
|
* for the IPC interface to i3 (see docs/ipc for more information).
|
|
|
|
|
*
|
|
|
|
|
*/
|
2013-12-29 03:11:50 +01:00
|
|
|
|
#pragma once
|
2009-07-28 20:51:29 +02:00
|
|
|
|
|
2013-01-11 22:28:43 +01:00
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
2013-01-11 19:09:41 +01:00
|
|
|
|
typedef struct i3_ipc_header {
|
|
|
|
|
/* 6 = strlen(I3_IPC_MAGIC) */
|
|
|
|
|
char magic[6];
|
|
|
|
|
uint32_t size;
|
|
|
|
|
uint32_t type;
|
2014-06-19 11:20:32 +02:00
|
|
|
|
} __attribute__((packed)) i3_ipc_header_t;
|
2013-01-11 19:09:41 +01:00
|
|
|
|
|
2010-03-11 15:58:39 +01:00
|
|
|
|
/*
|
|
|
|
|
* Messages from clients to i3
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
2009-07-28 20:51:29 +02:00
|
|
|
|
/** Never change this, only on major IPC breakage (don’t do that) */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MAGIC "i3-ipc"
|
2009-07-28 20:51:29 +02:00
|
|
|
|
|
2017-09-17 15:25:00 +02:00
|
|
|
|
/** Deprecated: use I3_IPC_MESSAGE_TYPE_RUN_COMMAND */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_COMMAND 0
|
2010-03-11 15:58:39 +01:00
|
|
|
|
|
2017-09-17 15:25:00 +02:00
|
|
|
|
/** The payload of the message will be interpreted as a command */
|
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_RUN_COMMAND 0
|
|
|
|
|
|
2010-03-11 15:58:39 +01:00
|
|
|
|
/** Requests the current workspaces from i3 */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_WORKSPACES 1
|
2010-11-20 22:30:53 +01:00
|
|
|
|
|
|
|
|
|
/** Subscribe to the specified events */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_SUBSCRIBE 2
|
2010-11-20 22:30:53 +01:00
|
|
|
|
|
|
|
|
|
/** Requests the current outputs from i3 */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_OUTPUTS 3
|
2010-11-20 22:30:53 +01:00
|
|
|
|
|
|
|
|
|
/** Requests the tree layout from i3 */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_TREE 4
|
2010-03-11 15:58:39 +01:00
|
|
|
|
|
2011-08-06 20:23:18 +02:00
|
|
|
|
/** Request the current defined marks from i3 */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_MARKS 5
|
2010-03-19 22:24:52 +01:00
|
|
|
|
|
2011-10-13 00:23:09 +02:00
|
|
|
|
/** Request the configuration for a specific 'bar' */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_BAR_CONFIG 6
|
2011-10-13 00:23:09 +02:00
|
|
|
|
|
2012-08-05 14:29:19 +02:00
|
|
|
|
/** Request the i3 version */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_VERSION 7
|
2012-08-05 14:29:19 +02:00
|
|
|
|
|
2016-06-15 22:25:22 +02:00
|
|
|
|
/** Request a list of configured binding modes. */
|
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_BINDING_MODES 8
|
|
|
|
|
|
2017-08-19 17:29:03 +02:00
|
|
|
|
/** Request the raw last loaded i3 config. */
|
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_GET_CONFIG 9
|
|
|
|
|
|
2017-09-24 15:40:30 +02:00
|
|
|
|
/** Send a tick event to all subscribers. */
|
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_SEND_TICK 10
|
|
|
|
|
|
2018-03-30 21:06:18 +02:00
|
|
|
|
/** Trigger an i3 sync protocol message via IPC. */
|
|
|
|
|
#define I3_IPC_MESSAGE_TYPE_SYNC 11
|
|
|
|
|
|
2010-03-11 15:58:39 +01:00
|
|
|
|
/*
|
|
|
|
|
* Messages from i3 to clients
|
|
|
|
|
*
|
|
|
|
|
*/
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_REPLY_TYPE_COMMAND 0
|
|
|
|
|
#define I3_IPC_REPLY_TYPE_WORKSPACES 1
|
|
|
|
|
#define I3_IPC_REPLY_TYPE_SUBSCRIBE 2
|
|
|
|
|
#define I3_IPC_REPLY_TYPE_OUTPUTS 3
|
|
|
|
|
#define I3_IPC_REPLY_TYPE_TREE 4
|
|
|
|
|
#define I3_IPC_REPLY_TYPE_MARKS 5
|
|
|
|
|
#define I3_IPC_REPLY_TYPE_BAR_CONFIG 6
|
|
|
|
|
#define I3_IPC_REPLY_TYPE_VERSION 7
|
2016-06-15 22:25:22 +02:00
|
|
|
|
#define I3_IPC_REPLY_TYPE_BINDING_MODES 8
|
2017-08-19 17:29:03 +02:00
|
|
|
|
#define I3_IPC_REPLY_TYPE_CONFIG 9
|
2017-09-24 15:40:30 +02:00
|
|
|
|
#define I3_IPC_REPLY_TYPE_TICK 10
|
2018-03-30 21:06:18 +02:00
|
|
|
|
#define I3_IPC_REPLY_TYPE_SYNC 11
|
2012-08-05 14:29:19 +02:00
|
|
|
|
|
2010-03-12 21:05:05 +01:00
|
|
|
|
/*
|
2010-03-13 15:04:23 +01:00
|
|
|
|
* Events from i3 to clients. Events have the first bit set high.
|
2010-03-12 21:05:05 +01:00
|
|
|
|
*
|
|
|
|
|
*/
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_EVENT_MASK (1 << 31)
|
2010-03-12 21:05:05 +01:00
|
|
|
|
|
2010-03-19 22:40:43 +01:00
|
|
|
|
/* The workspace event will be triggered upon changes in the workspace list */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_EVENT_WORKSPACE (I3_IPC_EVENT_MASK | 0)
|
2010-03-12 21:05:05 +01:00
|
|
|
|
|
2010-03-19 22:40:43 +01:00
|
|
|
|
/* The output event will be triggered upon changes in the output list */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_EVENT_OUTPUT (I3_IPC_EVENT_MASK | 1)
|
2010-03-19 22:40:43 +01:00
|
|
|
|
|
2012-09-22 00:21:39 +02:00
|
|
|
|
/* The output event will be triggered upon mode changes */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_EVENT_MODE (I3_IPC_EVENT_MASK | 2)
|
2012-09-22 00:21:39 +02:00
|
|
|
|
|
2013-01-11 19:58:32 +01:00
|
|
|
|
/* The window event will be triggered upon window changes */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_EVENT_WINDOW (I3_IPC_EVENT_MASK | 3)
|
2013-01-11 19:58:32 +01:00
|
|
|
|
|
introduced i3 command for changing the hidden state and the mode of i3bar
The hidden_state and mode of each i3bar instance can now be controlled from within i3.
Therefore, two new i3 command were introduced:
_
bar hidden_state show|hide|toggle [<bar_id>]
show: always show the bar
hide: normal hide mode
toggle: toggle between show and hide (individually for each bar)
_
bar mode dock|hide|invisible|toggle [<bar_id>]
hide,dock: like before
invisible: always keep the bar hidden
toggle: toggle between dock and hide (individually for each bar)
This patch introduces a hidden_state ("hidden_state hide|show") in the
barconfig, which indicates the current hidden_state of each i3bar
instance. It only affects the bar when in hide mode. Additionally, a new
invisible mode was introduced. In order to change the hidden_state or
mode of the bar from i3, a barconfig-update event was introduced, for
which a bar can subscribe and the bar then gets notified about the
currently set hidden_state and mode in its barconfig.
For convenience, an id field ("id <bar_id>") was added to the barconfig, where one can
set the desired id for the corresponding bar. If the id is not specified, i3 will
deterministically choose an id; otherwise, with the previous random approach for finding
a new id, which is actually not shared with i3bar, as it would determine its id on
startup, the event-subscription would be destroyed on reload. Still, this issue remains
when manually changing the bar_id in the config and then reloading.
fixes #833, #651
2013-05-25 14:30:00 +02:00
|
|
|
|
/** Bar config update will be triggered to update the bar config */
|
2014-06-19 11:20:32 +02:00
|
|
|
|
#define I3_IPC_EVENT_BARCONFIG_UPDATE (I3_IPC_EVENT_MASK | 4)
|
2014-10-03 01:04:53 +02:00
|
|
|
|
|
|
|
|
|
/** The binding event will be triggered when bindings run */
|
|
|
|
|
#define I3_IPC_EVENT_BINDING (I3_IPC_EVENT_MASK | 5)
|
2017-01-22 23:08:32 +01:00
|
|
|
|
|
|
|
|
|
/** The shutdown event will be triggered when the ipc shuts down */
|
|
|
|
|
#define I3_IPC_EVENT_SHUTDOWN (I3_IPC_EVENT_MASK | 6)
|
2017-09-24 15:40:30 +02:00
|
|
|
|
|
|
|
|
|
/** The tick event will be sent upon a tick IPC message */
|
|
|
|
|
#define I3_IPC_EVENT_TICK (I3_IPC_EVENT_MASK | 7)
|