2009-12-22 17:40:06 -05:00
|
|
|
/*
|
|
|
|
* vim:ts=8:expandtab
|
|
|
|
*
|
|
|
|
* i3 - an improved dynamic tiling window manager
|
|
|
|
*
|
|
|
|
* © 2009 Michael Stapelberg and contributors
|
|
|
|
*
|
|
|
|
* See file LICENSE for license information.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "data.h"
|
|
|
|
#include "log.h"
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Returns the mode of the given container (or MODE_DEFAULT if a NULL pointer
|
|
|
|
* was passed in order to save a few explicit checks in other places). If
|
|
|
|
* for_frame was set to true, the special case of having exactly one client
|
|
|
|
* in a container is handled so that MODE_DEFAULT is returned. For some parts
|
|
|
|
* of the rendering, this is interesting, other parts need the real mode.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
int container_mode(Container *con, bool for_frame) {
|
2009-12-22 17:43:05 -05:00
|
|
|
int num_clients = 0;
|
|
|
|
Client *client;
|
2009-12-22 17:40:06 -05:00
|
|
|
|
2009-12-22 17:43:05 -05:00
|
|
|
if (con == NULL || con->mode == MODE_DEFAULT)
|
|
|
|
return MODE_DEFAULT;
|
2009-12-22 17:40:06 -05:00
|
|
|
|
|
|
|
if (!for_frame)
|
|
|
|
return con->mode;
|
|
|
|
|
2009-12-22 17:43:05 -05:00
|
|
|
CIRCLEQ_FOREACH(client, &(con->clients), clients)
|
|
|
|
num_clients++;
|
2009-12-22 17:40:06 -05:00
|
|
|
|
2009-12-22 17:43:05 -05:00
|
|
|
/* If the container contains only one client, mode is irrelevant */
|
|
|
|
if (num_clients == 1) {
|
|
|
|
DLOG("mode to default\n");
|
|
|
|
return MODE_DEFAULT;
|
|
|
|
}
|
2009-12-22 17:40:06 -05:00
|
|
|
|
2009-12-22 17:43:05 -05:00
|
|
|
return con->mode;
|
2009-12-22 17:40:06 -05:00
|
|
|
}
|