aboutsummaryrefslogtreecommitdiff
path: root/sway/commands/reload.c
diff options
context:
space:
mode:
authorDominique Martinet <asmadeus@codewreck.org>2018-01-05 22:05:48 +0100
committerDominique Martinet <asmadeus@codewreck.org>2018-01-22 07:25:23 +0100
commit869be4378d44e08c686b550a86a5e4fa60915edb (patch)
tree46eea43b22af55497c9f0a832bf6405a54cf5c5e /sway/commands/reload.c
parent0c58673c6a108ba241419a0f1d5fecd47f22370e (diff)
commands: add 'reload' command
Diffstat (limited to 'sway/commands/reload.c')
-rw-r--r--sway/commands/reload.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/sway/commands/reload.c b/sway/commands/reload.c
new file mode 100644
index 00000000..2b553845
--- /dev/null
+++ b/sway/commands/reload.c
@@ -0,0 +1,21 @@
+#include "sway/commands.h"
+#include "sway/config.h"
+#include "sway/layout.h"
+
+struct cmd_results *cmd_reload(int argc, char **argv) {
+ struct cmd_results *error = NULL;
+ if (config->reading) {
+ return cmd_results_new(CMD_FAILURE, "reload", "Can't be used in config file.");
+ }
+ if ((error = checkarg(argc, "reload", EXPECTED_EQUAL_TO, 0))) {
+ return error;
+ }
+ if (!load_main_config(config->current_config, true)) {
+ return cmd_results_new(CMD_FAILURE, "reload", "Error(s) reloading config.");
+ }
+
+ load_swaybars();
+
+ arrange_windows(&root_container, -1, -1);
+ return cmd_results_new(CMD_SUCCESS, NULL, NULL);
+}