summaryrefslogtreecommitdiff
path: root/sway/commands/bar/tray_padding.c
diff options
context:
space:
mode:
authorZandr Martin <[email protected]>2016-09-01 21:39:08 -0500
committerZandr Martin <[email protected]>2016-09-01 21:39:08 -0500
commitb374c35758777f98e5ddbe4b0dc43bd7c80f36d7 (patch)
tree04bb4cfc3da7d2e0de7fbc38db42f65c66d2df4c /sway/commands/bar/tray_padding.c
parent050704ab23b698b00ee2ded8dbd4df9afceb8844 (diff)
refactor commands.c
Diffstat (limited to 'sway/commands/bar/tray_padding.c')
-rw-r--r--sway/commands/bar/tray_padding.c29
1 files changed, 29 insertions, 0 deletions
diff --git a/sway/commands/bar/tray_padding.c b/sway/commands/bar/tray_padding.c
new file mode 100644
index 00000000..978ce0b7
--- /dev/null
+++ b/sway/commands/bar/tray_padding.c
@@ -0,0 +1,29 @@
+#include <stdlib.h>
+#include <string.h>
+#include "commands.h"
+#include "log.h"
+
+struct cmd_results *bar_cmd_tray_padding(int argc, char **argv) {
+ struct cmd_results *error = NULL;
+ if ((error = checkarg(argc, "tray_padding", EXPECTED_AT_LEAST, 1))) {
+ return error;
+ }
+
+ if (!config->current_bar) {
+ return cmd_results_new(CMD_FAILURE, "tray_padding", "No bar defined.");
+ }
+
+ int padding = atoi(argv[0]);
+ if (padding < 0) {
+ return cmd_results_new(CMD_INVALID, "tray_padding",
+ "Invalid padding value %s, minimum is 0", argv[0]);
+ }
+
+ if (argc > 1 && strcasecmp("px", argv[1]) != 0) {
+ return cmd_results_new(CMD_INVALID, "tray_padding",
+ "Unknown unit %s", argv[1]);
+ }
+ config->current_bar->tray_padding = padding;
+ sway_log(L_DEBUG, "Enabling tray padding of %d px on bar: %s", padding, config->current_bar->id);
+ return cmd_results_new(CMD_SUCCESS, NULL, NULL);
+}