The "dpms" command refers to VESA Display Power Management Signaling, a deprecated standard. It's superseded by VESA DPM. Instead of tying out command name to a particular standard, use the neutral term "power".master
parent
122d8ce954
commit
445bc2a943
@ -1,45 +1,8 @@
|
||||
#include "log.h"
|
||||
#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) {
|
||||
return cmd_results_new(CMD_FAILURE, "Missing output config");
|
||||
}
|
||||
if (!argc) {
|
||||
return cmd_results_new(CMD_INVALID, "Missing dpms argument.");
|
||||
}
|
||||
|
||||
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;
|
||||
}
|
||||
|
||||
config->handler_context.leftovers.argc = argc - 1;
|
||||
config->handler_context.leftovers.argv = argv + 1;
|
||||
return NULL;
|
||||
sway_log(SWAY_INFO, "The \"output dpms\" command is deprecated, "
|
||||
"use \"output power\" instead");
|
||||
return output_cmd_power(argc, argv);
|
||||
}
|
||||
|
@ -0,0 +1,43 @@
|
||||
#include <strings.h>
|
||||
#include "sway/commands.h"
|
||||
#include "sway/config.h"
|
||||
#include "sway/output.h"
|
||||
#include "util.h"
|
||||
|
||||
struct cmd_results *output_cmd_power(int argc, char **argv) {
|
||||
if (!config->handler_context.output_config) {
|
||||
return cmd_results_new(CMD_FAILURE, "Missing output config");
|
||||
}
|
||||
if (argc == 0) {
|
||||
return cmd_results_new(CMD_INVALID, "Missing power argument");
|
||||
}
|
||||
|
||||
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;
|
||||
}
|
||||
|
||||
config->handler_context.leftovers.argc = argc - 1;
|
||||
config->handler_context.leftovers.argv = argv + 1;
|
||||
return NULL;
|
||||
}
|
Loading…
Reference in new issue