aboutsummaryrefslogtreecommitdiff
path: root/sway
diff options
context:
space:
mode:
Diffstat (limited to 'sway')
-rw-r--r--sway/commands.c2
-rw-r--r--sway/container.c33
-rw-r--r--sway/focus.c2
3 files changed, 22 insertions, 15 deletions
diff --git a/sway/commands.c b/sway/commands.c
index 487b6a8e..409afce9 100644
--- a/sway/commands.c
+++ b/sway/commands.c
@@ -2325,7 +2325,7 @@ static struct cmd_results *cmd_workspace(int argc, char **argv) {
// Handle workspace next/prev
swayc_t *ws = NULL;
if (argc == 2) {
- if (!(ws=workspace_by_number(argv[1]))) {
+ if (!(ws = workspace_by_number(argv[1]))) {
ws = workspace_create(argv[1]);
}
} else if (strcasecmp(argv[0], "next") == 0) {
diff --git a/sway/container.c b/sway/container.c
index 20b7905b..4883a648 100644
--- a/sway/container.c
+++ b/sway/container.c
@@ -134,32 +134,39 @@ swayc_t *new_output(wlc_handle handle) {
// Create workspace
char *ws_name = NULL;
+ swayc_t *ws = NULL;
+
if (name) {
for (i = 0; i < config->workspace_outputs->length; ++i) {
struct workspace_output *wso = config->workspace_outputs->items[i];
if (strcasecmp(wso->output, name) == 0) {
sway_log(L_DEBUG, "Matched workspace to output: %s for %s", wso->workspace, wso->output);
// Check if any other workspaces are using this name
- if (workspace_by_name(wso->workspace)) {
- sway_log(L_DEBUG, "But it's already taken");
- break;
+ if ((ws = workspace_by_name(wso->workspace))) {
+ // if yes, move those to this output, because they should be here
+ move_workspace_to(ws, output);
+ } else if (!ws_name) {
+ // set a workspace name in case we need to create a default one
+ ws_name = strdup(wso->workspace);
}
- sway_log(L_DEBUG, "So we're going to use it");
- ws_name = strdup(wso->workspace);
- break;
}
}
}
- if (!ws_name) {
- ws_name = workspace_next_name(output->name);
- }
- // create and initialize default workspace
- swayc_t *ws = new_workspace(output, ws_name);
- ws->is_focused = true;
+ if (output->children->length == 0) {
+ if (!ws_name) {
+ ws_name = workspace_next_name(output->name);
+ }
+ // create and initialize default workspace
+ sway_log(L_DEBUG, "Creating default workspace %s", ws_name);
+ ws = new_workspace(output, ws_name);
+ ws->is_focused = true;
+ } else {
+ sort_workspaces(output);
+ set_focused_container(output->children->items[0]);
+ }
free(ws_name);
-
return output;
}
diff --git a/sway/focus.c b/sway/focus.c
index 9db2aaa7..2219ab4a 100644
--- a/sway/focus.c
+++ b/sway/focus.c
@@ -110,7 +110,7 @@ bool set_focused_container(swayc_t *c) {
// Get workspace for c, get that workspaces current focused container.
swayc_t *workspace = swayc_active_workspace_for(c);
swayc_t *focused = get_focused_view(workspace);
- // if the workspace we are changing focus to has a fullscreen view return
+
if (swayc_is_fullscreen(focused) && focused != c) {
// if switching to a workspace with a fullscreen view,
// focus on the fullscreen view