diff options
author | Ivan Fedotov <17356208+ivanfed0t0v@users.noreply.github.com> | 2021-03-15 19:06:46 +0300 |
---|---|---|
committer | Simon Ser <contact@emersion.fr> | 2021-03-25 11:01:04 +0100 |
commit | 346f5a9d14e260405598fc530fb260c894db397f (patch) | |
tree | cf45e016607cd346784fde5dfbe2a44103a86ff2 /sway/commands | |
parent | a9563a37101e022d5e9c14f8244b1f8a109b4536 (diff) |
Add toggle logic inside DPMS handler
Logic that obtains current DPMS state is put inside the handler.
sway_output from which the current DPMS state will be obtained is selected by the following logic:
* For '-' and '--' the focused output is used;
* For '*' error "Cannot apply toggle to all outputs" is reported;
* For everything else all_output_by_name_or_id() is used.
Fixes #5929.
Diffstat (limited to 'sway/commands')
-rw-r--r-- | sway/commands/output/dpms.c | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/sway/commands/output/dpms.c b/sway/commands/output/dpms.c index 9d75a80e..638c0ade 100644 --- a/sway/commands/output/dpms.c +++ b/sway/commands/output/dpms.c @@ -1,6 +1,8 @@ #include "sway/commands.h" #include "sway/config.h" +#include "sway/output.h" #include "util.h" +#include <strings.h> struct cmd_results *output_cmd_dpms(int argc, char **argv) { if (!config->handler_context.output_config) { @@ -10,7 +12,28 @@ struct cmd_results *output_cmd_dpms(int argc, char **argv) { return cmd_results_new(CMD_INVALID, "Missing dpms argument."); } - if (parse_boolean(argv[0], true)) { + enum config_dpms current_dpms = DPMS_ON; + + if (strcasecmp(argv[0], "toggle") == 0) { + + const char *oc_name = config->handler_context.output_config->name; + if (strcmp(oc_name, "*") == 0) { + return cmd_results_new(CMD_INVALID, + "Cannot apply toggle to all outputs."); + } + + struct sway_output *sway_output = all_output_by_name_or_id(oc_name); + if (!sway_output || !sway_output->wlr_output) { + return cmd_results_new(CMD_FAILURE, + "Cannot apply toggle to unknown output %s", oc_name); + } + + if (sway_output->enabled && !sway_output->wlr_output->enabled) { + current_dpms = DPMS_OFF; + } + } + + if (parse_boolean(argv[0], current_dpms == DPMS_ON)) { config->handler_context.output_config->dpms_state = DPMS_ON; } else { config->handler_context.output_config->dpms_state = DPMS_OFF; |