summaryrefslogtreecommitdiffstats
path: root/sway/commands
diff options
context:
space:
mode:
Diffstat (limited to 'sway/commands')
-rw-r--r--sway/commands/bar/status_command.c2
-rw-r--r--sway/commands/opacity.c4
-rw-r--r--sway/commands/swaybg_command.c15
-rw-r--r--sway/commands/swaynag_command.c15
-rw-r--r--sway/commands/urgent.c3
5 files changed, 29 insertions, 10 deletions
diff --git a/sway/commands/bar/status_command.c b/sway/commands/bar/status_command.c
index 5ea22525..5b4fdc87 100644
--- a/sway/commands/bar/status_command.c
+++ b/sway/commands/bar/status_command.c
@@ -20,6 +20,8 @@ struct cmd_results *bar_cmd_status_command(int argc, char **argv) {
20 config->current_bar->status_command = new_command; 20 config->current_bar->status_command = new_command;
21 wlr_log(WLR_DEBUG, "Feeding bar with status command: %s", 21 wlr_log(WLR_DEBUG, "Feeding bar with status command: %s",
22 config->current_bar->status_command); 22 config->current_bar->status_command);
23 } else {
24 free(new_command);
23 } 25 }
24 26
25 if (config->active && !config->validating) { 27 if (config->active && !config->validating) {
diff --git a/sway/commands/opacity.c b/sway/commands/opacity.c
index 9cdaad7f..4e4fc994 100644
--- a/sway/commands/opacity.c
+++ b/sway/commands/opacity.c
@@ -21,6 +21,10 @@ struct cmd_results *cmd_opacity(int argc, char **argv) {
21 21
22 struct sway_container *con = config->handler_context.container; 22 struct sway_container *con = config->handler_context.container;
23 23
24 if (con == NULL) {
25 return cmd_results_new(CMD_FAILURE, "opacity", "No current container");
26 }
27
24 float opacity = 0.0f; 28 float opacity = 0.0f;
25 29
26 if (!parse_opacity(argv[0], &opacity)) { 30 if (!parse_opacity(argv[0], &opacity)) {
diff --git a/sway/commands/swaybg_command.c b/sway/commands/swaybg_command.c
index 36f7fdcd..b184b193 100644
--- a/sway/commands/swaybg_command.c
+++ b/sway/commands/swaybg_command.c
@@ -9,12 +9,17 @@ struct cmd_results *cmd_swaybg_command(int argc, char **argv) {
9 return error; 9 return error;
10 } 10 }
11 11
12 if (config->swaybg_command) { 12 free(config->swaybg_command);
13 free(config->swaybg_command); 13 config->swaybg_command = NULL;
14
15 char *new_command = join_args(argv, argc);
16 if (strcmp(new_command, "-") != 0) {
17 config->swaybg_command = new_command;
18 wlr_log(WLR_DEBUG, "Using custom swaybg command: %s",
19 config->swaybg_command);
20 } else {
21 free(new_command);
14 } 22 }
15 config->swaybg_command = join_args(argv, argc);
16 wlr_log(WLR_DEBUG, "Using custom swaybg command: %s",
17 config->swaybg_command);
18 23
19 return cmd_results_new(CMD_SUCCESS, NULL, NULL); 24 return cmd_results_new(CMD_SUCCESS, NULL, NULL);
20} 25}
diff --git a/sway/commands/swaynag_command.c b/sway/commands/swaynag_command.c
index c57a80a6..6c86f1a7 100644
--- a/sway/commands/swaynag_command.c
+++ b/sway/commands/swaynag_command.c
@@ -9,12 +9,17 @@ struct cmd_results *cmd_swaynag_command(int argc, char **argv) {
9 return error; 9 return error;
10 } 10 }
11 11
12 if (config->swaynag_command) { 12 free(config->swaynag_command);
13 free(config->swaynag_command); 13 config->swaynag_command = NULL;
14
15 char *new_command = join_args(argv, argc);
16 if (strcmp(new_command, "-") != 0) {
17 config->swaybg_command = new_command;
18 wlr_log(WLR_DEBUG, "Using custom swaynag command: %s",
19 config->swaynag_command);
20 } else {
21 free(new_command);
14 } 22 }
15 config->swaynag_command = join_args(argv, argc);
16 wlr_log(WLR_DEBUG, "Using custom swaynag command: %s",
17 config->swaynag_command);
18 23
19 return cmd_results_new(CMD_SUCCESS, NULL, NULL); 24 return cmd_results_new(CMD_SUCCESS, NULL, NULL);
20} 25}
diff --git a/sway/commands/urgent.c b/sway/commands/urgent.c
index 53c37d4d..4f283c55 100644
--- a/sway/commands/urgent.c
+++ b/sway/commands/urgent.c
@@ -12,6 +12,9 @@ struct cmd_results *cmd_urgent(int argc, char **argv) {
12 return error; 12 return error;
13 } 13 }
14 struct sway_container *container = config->handler_context.container; 14 struct sway_container *container = config->handler_context.container;
15 if (!container) {
16 return cmd_results_new(CMD_FAILURE, "urgent", "No current container");
17 }
15 if (!container->view) { 18 if (!container->view) {
16 return cmd_results_new(CMD_INVALID, "urgent", 19 return cmd_results_new(CMD_INVALID, "urgent",
17 "Only views can be urgent"); 20 "Only views can be urgent");