diff options
author | Ryan Dwyer <ryandwyer1@gmail.com> | 2018-09-19 21:54:27 +1000 |
---|---|---|
committer | Ryan Dwyer <ryandwyer1@gmail.com> | 2018-09-19 21:54:27 +1000 |
commit | db2845963408dd0d66a3587469c6f26bfa4d9e1f (patch) | |
tree | 35826f54035df759914a7c406757a6ef1bf6939a /sway | |
parent | Merge pull request #2640 from ianyfan/swaybar (diff) | |
download | sway-db2845963408dd0d66a3587469c6f26bfa4d9e1f.tar.gz sway-db2845963408dd0d66a3587469c6f26bfa4d9e1f.tar.zst sway-db2845963408dd0d66a3587469c6f26bfa4d9e1f.zip |
Introduce create_output command (for developer use)
Should help with testing hotplugging.
Diffstat (limited to 'sway')
-rw-r--r-- | sway/commands.c | 1 | ||||
-rw-r--r-- | sway/commands/create_output.c | 39 | ||||
-rw-r--r-- | sway/meson.build | 1 |
3 files changed, 41 insertions, 0 deletions
diff --git a/sway/commands.c b/sway/commands.c index 41e1c653..27a88319 100644 --- a/sway/commands.c +++ b/sway/commands.c | |||
@@ -143,6 +143,7 @@ static struct cmd_handler config_handlers[] = { | |||
143 | /* Runtime-only commands. Keep alphabetized */ | 143 | /* Runtime-only commands. Keep alphabetized */ |
144 | static struct cmd_handler command_handlers[] = { | 144 | static struct cmd_handler command_handlers[] = { |
145 | { "border", cmd_border }, | 145 | { "border", cmd_border }, |
146 | { "create_output", cmd_create_output }, | ||
146 | { "exit", cmd_exit }, | 147 | { "exit", cmd_exit }, |
147 | { "floating", cmd_floating }, | 148 | { "floating", cmd_floating }, |
148 | { "fullscreen", cmd_fullscreen }, | 149 | { "fullscreen", cmd_fullscreen }, |
diff --git a/sway/commands/create_output.c b/sway/commands/create_output.c new file mode 100644 index 00000000..a852c2a0 --- /dev/null +++ b/sway/commands/create_output.c | |||
@@ -0,0 +1,39 @@ | |||
1 | #include <wlr/backend/multi.h> | ||
2 | #include <wlr/backend/wayland.h> | ||
3 | #include <wlr/backend/x11.h> | ||
4 | #include "sway/commands.h" | ||
5 | #include "sway/server.h" | ||
6 | #include "log.h" | ||
7 | |||
8 | static void create_output(struct wlr_backend *backend, void *data) { | ||
9 | bool *done = data; | ||
10 | if (*done) { | ||
11 | return; | ||
12 | } | ||
13 | |||
14 | if (wlr_backend_is_wl(backend)) { | ||
15 | wlr_wl_output_create(backend); | ||
16 | *done = true; | ||
17 | } else if (wlr_backend_is_x11(backend)) { | ||
18 | wlr_x11_output_create(backend); | ||
19 | *done = true; | ||
20 | } | ||
21 | } | ||
22 | |||
23 | /** | ||
24 | * This command is intended for developer use only. | ||
25 | */ | ||
26 | struct cmd_results *cmd_create_output(int argc, char **argv) { | ||
27 | sway_assert(wlr_backend_is_multi(server.backend), | ||
28 | "Expected a multi backend"); | ||
29 | |||
30 | bool done = false; | ||
31 | wlr_multi_for_each_backend(server.backend, create_output, &done); | ||
32 | |||
33 | if (!done) { | ||
34 | return cmd_results_new(CMD_INVALID, "create_output", | ||
35 | "Can only create outputs for Wayland or X11 backends"); | ||
36 | } | ||
37 | |||
38 | return cmd_results_new(CMD_SUCCESS, NULL, NULL); | ||
39 | } | ||
diff --git a/sway/meson.build b/sway/meson.build index 01c83a33..d67a4c64 100644 --- a/sway/meson.build +++ b/sway/meson.build | |||
@@ -35,6 +35,7 @@ sway_sources = files( | |||
35 | 'commands/bind.c', | 35 | 'commands/bind.c', |
36 | 'commands/border.c', | 36 | 'commands/border.c', |
37 | 'commands/client.c', | 37 | 'commands/client.c', |
38 | 'commands/create_output.c', | ||
38 | 'commands/default_border.c', | 39 | 'commands/default_border.c', |
39 | 'commands/default_floating_border.c', | 40 | 'commands/default_floating_border.c', |
40 | 'commands/default_orientation.c', | 41 | 'commands/default_orientation.c', |