aboutsummaryrefslogtreecommitdiff
path: root/sway/scratchpad.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2018-07-28 09:30:12 -0400
committerGitHub <noreply@github.com>2018-07-28 09:30:12 -0400
commit53069f1403587d230e8f2c6adb61daa7c5e022b7 (patch)
tree67b966d2736ba19540b0102381710f9fb5316e61 /sway/scratchpad.c
parente4b54ac16e52cea9fe7f8385e87033764d36522f (diff)
parent0337609667ad1d01e0e0dc19231373df3fbf7c87 (diff)
downloadsway-53069f1403587d230e8f2c6adb61daa7c5e022b7.tar.xz
Merge pull request #2360 from RyanDwyer/floating-containers
Allow containers to float
Diffstat (limited to 'sway/scratchpad.c')
-rw-r--r--sway/scratchpad.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/sway/scratchpad.c b/sway/scratchpad.c
index 64636c77..b7d6fd99 100644
--- a/sway/scratchpad.c
+++ b/sway/scratchpad.c
@@ -72,11 +72,7 @@ static void scratchpad_show(struct sway_container *con) {
if (!wlr_box_contains_point(&workspace_box, center_lx, center_ly)) {
// Maybe resize it
if (con->width > ws->width || con->height > ws->height) {
- // TODO: Do this properly once we can float C_CONTAINERs
- if (con->type == C_VIEW) {
- view_init_floating(con->sway_view);
- arrange_windows(con);
- }
+ container_init_floating(con);
}
// Center it
@@ -85,7 +81,8 @@ static void scratchpad_show(struct sway_container *con) {
container_floating_move_to(con, new_lx, new_ly);
}
- seat_set_focus(seat, con);
+ arrange_windows(ws);
+ seat_set_focus(seat, seat_get_focus_inactive(seat, con));
container_set_dirty(con->parent);
}
@@ -113,6 +110,15 @@ void scratchpad_toggle_auto(void) {
struct sway_container *ws = focus->type == C_WORKSPACE ?
focus : container_parent(focus, C_WORKSPACE);
+ // If the focus is in a floating split container,
+ // operate on the split container instead of the child.
+ if (container_is_floating_or_child(focus)) {
+ while (focus->parent->layout != L_FLOATING) {
+ focus = focus->parent;
+ }
+ }
+
+
// Check if the currently focused window is a scratchpad window and should
// be hidden again.
if (focus->scratchpad) {