diff options
Diffstat (limited to 'sway/commands/debuglog.c')
-rw-r--r-- | sway/commands/debuglog.c | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/sway/commands/debuglog.c b/sway/commands/debuglog.c new file mode 100644 index 00000000..76192fb0 --- /dev/null +++ b/sway/commands/debuglog.c | |||
@@ -0,0 +1,26 @@ | |||
1 | #include <string.h> | ||
2 | #include "sway/commands.h" | ||
3 | #include "log.h" | ||
4 | |||
5 | struct cmd_results *cmd_debuglog(int argc, char **argv) { | ||
6 | struct cmd_results *error = NULL; | ||
7 | if ((error = checkarg(argc, "debuglog", EXPECTED_EQUAL_TO, 1))) { | ||
8 | return error; | ||
9 | } else if (strcasecmp(argv[0], "toggle") == 0) { | ||
10 | if (config->reading) { | ||
11 | return cmd_results_new(CMD_FAILURE, "debuglog toggle", "Can't be used in config file."); | ||
12 | } | ||
13 | if (toggle_debug_logging()) { | ||
14 | sway_log(L_DEBUG, "Debuglog turned on."); | ||
15 | } | ||
16 | } else if (strcasecmp(argv[0], "on") == 0) { | ||
17 | set_log_level(L_DEBUG); | ||
18 | sway_log(L_DEBUG, "Debuglog turned on."); | ||
19 | } else if (strcasecmp(argv[0], "off") == 0) { | ||
20 | reset_log_level(); | ||
21 | } else { | ||
22 | return cmd_results_new(CMD_FAILURE, "debuglog", "Expected 'debuglog on|off|toggle'"); | ||
23 | } | ||
24 | return cmd_results_new(CMD_SUCCESS, NULL, NULL); | ||
25 | } | ||
26 | |||