X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=src%2Fwincontrol.c;h=d444623ec79cae2e86273201c044d8e9aeb90972;hb=e31f0c764131a28ac50c6f9c35e0a190f4bc95e4;hp=3d0307817397343b8a42fb008e4a9da29b98466e;hpb=ffacb8844b9d843fe82ba7f912706b2e96bc6856;p=plomrogue
diff --git a/src/wincontrol.c b/src/wincontrol.c
index 3d03078..d444623 100644
--- a/src/wincontrol.c
+++ b/src/wincontrol.c
@@ -504,13 +504,13 @@ extern void save_win_configs(struct World * world)
extern uint8_t toggle_window(struct WinMeta * win_meta, struct Win * win)
{
- if (0 != win->frame.curses_win)
+ if (0 == win->prev && win_meta->chain_start != win) /* Win outside chain. */
{
- return suspend_win(win_meta, win);
+ return append_win(win_meta, win);
}
else
{
- return append_win(win_meta, win);
+ return suspend_win(win_meta, win);
}
}
@@ -523,15 +523,20 @@ extern void toggle_winconfig(struct World * world, struct Win * win)
{
win->draw = draw_winconf_geometry;
wcp->view = 1;
+ wcp->center = win->center;
+ win->center.y = 0;
+ win->center.x = 0;
}
else if (1 == wcp->view)
{
win->draw = draw_winconf_keybindings;
wcp->view = 2;
+ win->center.x = 0;
}
else
{
win->draw = get_drawfunc_by_char(wcp->draw);
+ win->center = wcp->center;
wcp->view = 0;
}
}