aboutsummaryrefslogtreecommitdiff
path: root/sway/commands.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2015-08-30 21:03:35 -0400
committerDrew DeVault <sir@cmpwn.com>2015-08-30 21:03:35 -0400
commit0ab71f5f0a47fd87bb71d7361ea90a8fa88c8361 (patch)
treeabbc99ff9749bd8d051572c2c1b3fbd1ee17ea30 /sway/commands.c
parent7fbb8b785e229341171470228fea22caac3ee896 (diff)
parent23f040133d93ae6d1bf1dc328e3f67f43fa3aeef (diff)
Merge pull request #155 from Luminarys/master
Added in workspace back_and_forth
Diffstat (limited to 'sway/commands.c')
-rw-r--r--sway/commands.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/sway/commands.c b/sway/commands.c
index 9a90fe5f..1825be4f 100644
--- a/sway/commands.c
+++ b/sway/commands.c
@@ -800,26 +800,36 @@ static bool cmd_workspace(struct sway_config *config, int argc, char **argv) {
if (argc == 1) {
// Handle workspace next/prev
- if (strcmp(argv[0], "next") == 0) {
+ if (strcasecmp(argv[0], "next") == 0) {
workspace_switch(workspace_next());
return true;
}
- if (strcmp(argv[0], "prev") == 0) {
+ if (strcasecmp(argv[0], "prev") == 0) {
workspace_switch(workspace_prev());
return true;
}
// Handle workspace output_next/prev
- if (strcmp(argv[0], "next_on_output") == 0) {
+ if (strcasecmp(argv[0], "next_on_output") == 0) {
workspace_switch(workspace_output_next());
return true;
}
- if (strcmp(argv[0], "prev_on_output") == 0) {
+ if (strcasecmp(argv[0], "prev_on_output") == 0) {
workspace_switch(workspace_output_prev());
return true;
}
+ if (strcasecmp(argv[0], "back_and_forth") == 0) {
+ if (prev_workspace_name) {
+ if (workspace_by_name(prev_workspace_name)) {
+ workspace_switch(workspace_by_name(prev_workspace_name));
+ } else {
+ workspace_switch(workspace_create(prev_workspace_name));
+ }
+ }
+ return true;
+ }
swayc_t *workspace = workspace_by_name(argv[0]);
if (!workspace) {