From 3e262913e83b3813b5cf95c562d6dd2b78bd3d9a Mon Sep 17 00:00:00 2001 From: Bapt Date: Tue, 21 Jul 2009 21:32:29 +0200 Subject: [PATCH] Implements next-previous workspace --- src/commands.c | 34 +++++++++++++++++++++++++++++++++- 1 file changed, 33 insertions(+), 1 deletion(-) diff --git a/src/commands.c b/src/commands.c index 275f8f96..b57b3ac5 100644 --- a/src/commands.c +++ b/src/commands.c @@ -845,6 +845,31 @@ static char **append_argument(char **original, char *argument) { return result; } +/* + * switch to next or previous existing workspace + */ +static void next_previous_workspace(xcb_connection_t *conn, int direction) { + Workspace *t_ws; + int i; + if (direction == 'n') { + if (c_ws->num == 9) + return; + for ( i = c_ws->num + 1; i <= 9; i++) { + t_ws = &(workspaces[i]); + if (t_ws->screen != NULL) break; + } + } else if (direction == 'p' ) { + if (c_ws->num == 0) + return; + for (i = c_ws->num - 1; i >= 0 ; i--) { + t_ws = &(workspaces[i]); + if (t_ws->screen != NULL) break; + } + } + if (t_ws->screen != NULL) + show_workspace(conn,i+1); +} + /* * Parses a command, see file CMDMODE for more information @@ -982,7 +1007,14 @@ void parse_command(xcb_connection_t *conn, const char *command) { return; } - + /* Is it 'n' for next workspace (nw) */ + if (command[0] == 'n' && command[1] == 'w') { + next_previous_workspace(conn, command[0]); + } + + if (command[0] == 'p' && command[1] == 'w') { + next_previous_workspace(conn, command[0]); + } /* It’s a normal */ char *rest = NULL; enum { ACTION_FOCUS, ACTION_MOVE, ACTION_SNAP } action = ACTION_FOCUS; -- 2.39.5