|
4 | 4 | #include "sway/server.h" |
5 | 5 | #include "util.h" |
6 | 6 |
|
7 | | -struct cmd_results *cmd_xwayland(int argc, char **argv) { |
8 | | - struct cmd_results *error = NULL; |
9 | | - if ((error = checkarg(argc, "xwayland", EXPECTED_EQUAL_TO, 1))) { |
10 | | - return error; |
11 | | - } |
| 7 | +// must be in order for the bsearch |
| 8 | +static struct cmd_handler xwayland_handlers[] = { |
| 9 | + { "enable", xwayland_cmd_enable }, |
| 10 | + { "disable", xwayland_cmd_disable }, |
| 11 | + { "force", xwayland_cmd_force }, |
| 12 | + { "scale", xwayland_cmd_scale }, |
| 13 | +}; |
12 | 14 |
|
| 15 | +struct cmd_results *cmd_xwayland(int argc, char **argv) { |
13 | 16 | #ifdef HAVE_XWAYLAND |
14 | | - enum xwayland_mode xwayland; |
15 | | - if (strcmp(argv[0], "force") == 0) { |
16 | | - xwayland = XWAYLAND_MODE_IMMEDIATE; |
17 | | - } else if (parse_boolean(argv[0], true)) { |
18 | | - xwayland = XWAYLAND_MODE_LAZY; |
19 | | - } else { |
20 | | - xwayland = XWAYLAND_MODE_DISABLED; |
21 | | - } |
| 17 | + struct cmd_results *error; |
| 18 | + while (argc > 0) { |
| 19 | + config->handler_context.leftovers.argc = 0; |
| 20 | + config->handler_context.leftovers.argv = NULL; |
22 | 21 |
|
23 | | - if (config->reloading && config->xwayland != xwayland) { |
24 | | - return cmd_results_new(CMD_FAILURE, |
25 | | - "xwayland can only be enabled/disabled at launch"); |
| 22 | + if (find_handler(*argv, xwayland_handlers, sizeof(xwayland_handlers))) { |
| 23 | + error = config_subcommand(argv, argc, xwayland_handlers, |
| 24 | + sizeof(xwayland_handlers)); |
| 25 | + } else { |
| 26 | + error = cmd_results_new(CMD_INVALID, |
| 27 | + "Invalid output subcommand: %s.", *argv); |
| 28 | + } |
| 29 | + |
| 30 | + if (error != NULL) { |
| 31 | + return error; |
| 32 | + } |
| 33 | + |
| 34 | + argc = config->handler_context.leftovers.argc; |
| 35 | + argv = config->handler_context.leftovers.argv; |
26 | 36 | } |
27 | | - config->xwayland = xwayland; |
| 37 | + |
| 38 | + config->handler_context.leftovers.argc = 0; |
| 39 | + config->handler_context.leftovers.argv = NULL; |
28 | 40 | #else |
29 | 41 | sway_log(SWAY_INFO, "Ignoring `xwayland` command, " |
30 | 42 | "sway hasn't been built with Xwayland support"); |
|
0 commit comments