|
|
|
swaymsg(1)
|
|
|
|
|
|
|
|
# NAME
|
|
|
|
|
|
|
|
swaymsg - Send messages to a running instance of sway over the IPC socket.
|
|
|
|
|
|
|
|
# SYNOPSIS
|
|
|
|
|
|
|
|
_swaymsg_ [options...] [message]
|
|
|
|
|
|
|
|
# OPTIONS
|
|
|
|
|
|
|
|
*-h, --help*
|
|
|
|
Show help message and quit.
|
|
|
|
|
|
|
|
*-m, --monitor*
|
|
|
|
Monitor for responses until killed instead of exiting after the first
|
|
|
|
response. This can only be used with the IPC message type _subscribe_. If
|
|
|
|
there is a malformed response or an invalid event type was requested,
|
|
|
|
swaymsg will stop monitoring and exit.
|
|
|
|
|
|
|
|
*-p, --pretty*
|
|
|
|
Use pretty output even when not using a tty.
|
|
|
|
Not available for all message types.
|
|
|
|
|
|
|
|
*-q, --quiet*
|
|
|
|
Sends the IPC message but does not print the response from sway.
|
|
|
|
|
|
|
|
*-r, --raw*
|
|
|
|
Use raw JSON output even if using a tty.
|
|
|
|
|
|
|
|
*-s, --socket* <path>
|
|
|
|
Use the specified socket path. Otherwise, swaymsg will ask sway where the
|
|
|
|
socket is (which is the value of $SWAYSOCK, then of $I3SOCK).
|
|
|
|
|
|
|
|
*-t, --type* <type>
|
|
|
|
Specify the type of IPC message. See below.
|
|
|
|
|
|
|
|
*-v, --version*
|
|
|
|
Print the version (of swaymsg) and quit.
|
|
|
|
|
|
|
|
# IPC MESSAGE TYPES
|
|
|
|
|
|
|
|
*<command>*
|
|
|
|
The message is a sway command (the same commands you can bind to keybindings
|
|
|
|
in your sway config file). It will be executed immediately.
|
|
|
|
|
|
|
|
See *sway*(5) for a list of commands.
|
|
|
|
|
|
|
|
_swaymsg_ can return pretty printed (standalone-default) or JSON-formatted
|
|
|
|
(*--raw*) output. For detailed documentation on the returned JSON-data of
|
|
|
|
each message type listed below, refer to *sway-ipc*(7). The JSON-format can
|
|
|
|
contain more information than the pretty print.
|
|
|
|
|
|
|
|
Tips:
|
|
|
|
- Command expansion is performed twice: once by swaymsg, and again by sway.
|
|
|
|
If you have quoted multi-word strings in your command, enclose the entire
|
|
|
|
command in single-quotes. For example, use
|
|
|
|
_swaymsg 'output "Foobar Display" enable'_ instead of
|
|
|
|
_swaymsg output "Foobar Display" enable_. Furthermore, note that comma
|
|
|
|
separated options also count as multi-word strings, because commas can be
|
|
|
|
used to execute commands on the same line.
|
|
|
|
- If you are providing a command that contains a leading hyphen (_-_), insert
|
|
|
|
two hyphens (_--_) before the command to signal to swaymsg not to parse
|
|
|
|
anything beyond that point as an option. For example, use
|
|
|
|
_swaymsg -- mark --add test_ instead of _swaymsg mark --add test_.
|
|
|
|
|
|
|
|
*get\_workspaces*
|
|
|
|
Gets a list of workspaces and their status.
|
|
|
|
|
|
|
|
*get\_inputs*
|
|
|
|
Gets a list of current inputs.
|
|
|
|
|
|
|
|
*get\_outputs*
|
|
|
|
Gets a list of current outputs.
|
|
|
|
|
|
|
|
*get\_tree*
|
|
|
|
Gets a JSON-encoded layout tree of all open windows, containers, outputs,
|
|
|
|
workspaces, and so on.
|
|
|
|
|
|
|
|
*get\_seats*
|
|
|
|
Gets a list of all seats,
|
|
|
|
its properties and all assigned devices.
|
|
|
|
|
|
|
|
*get\_marks*
|
|
|
|
Get a JSON-encoded list of marks.
|
|
|
|
|
|
|
|
*get\_bar\_config*
|
|
|
|
Get a JSON-encoded configuration for swaybar.
|
|
|
|
|
|
|
|
*get\_version*
|
|
|
|
Get version information for the running instance of sway.
|
|
|
|
|
|
|
|
*get\_binding\_modes*
|
|
|
|
Gets a JSON-encoded list of currently configured binding modes.
|
|
|
|
|
|
|
|
*get\_binding\_state*
|
|
|
|
Gets JSON-encoded info about the current binding state.
|
|
|
|
|
|
|
|
*get\_config*
|
|
|
|
Gets a copy of the current configuration. Doesn't expand includes.
|
|
|
|
|
|
|
|
*send\_tick*
|
|
|
|
Sends a tick event to all subscribed clients.
|
|
|
|
|
|
|
|
*subscribe*
|
|
|
|
Subscribe to a list of event types. The argument for this type should be
|
|
|
|
provided in the form of a valid JSON array. If any of the types are invalid
|
|
|
|
or if a valid JSON array is not provided, this will result in a failure.
|
|
|
|
|
|
|
|
# RETURN CODES
|
|
|
|
|
|
|
|
*0*
|
|
|
|
Success
|
|
|
|
|
|
|
|
*1*
|
|
|
|
swaymsg errors such as invalid syntax, unable to connect to the ipc socket
|
|
|
|
or unable to parse sway's reply
|
|
|
|
|
|
|
|
*2*
|
|
|
|
Sway returned an error when processing the command (ex. invalid command,
|
|
|
|
command failed, and invalid subscription request)
|
|
|
|
|
|
|
|
# SEE ALSO
|
|
|
|
|
|
|
|
*sway*(5) *sway-bar*(5) *sway-input*(5) *sway-output*(5) *sway-ipc*(7)
|