Bugfix: Obey colspan/rowspan when checking if containers can be snapped to the right/bottom (Thanks Mirko)
This fixes ticket #54.
This commit is contained in:
parent
749faa3695
commit
ba070fcc6c
@ -363,8 +363,9 @@ static void snap_current_container(xcb_connection_t *conn, direction_t direction
|
||||
case D_RIGHT: {
|
||||
/* Check if the cell is used */
|
||||
int new_col = container->col + container->colspan;
|
||||
if (!cell_exists(new_col, container->row) ||
|
||||
CUR_TABLE[new_col][container->row]->currently_focused != NULL) {
|
||||
for (int i = 0; i < container->rowspan; i++)
|
||||
if (!cell_exists(new_col, container->row + i) ||
|
||||
CUR_TABLE[new_col][container->row + i]->currently_focused != NULL) {
|
||||
LOG("cannot snap to right - the cell is already used\n");
|
||||
return;
|
||||
}
|
||||
@ -395,8 +396,9 @@ static void snap_current_container(xcb_connection_t *conn, direction_t direction
|
||||
case D_DOWN: {
|
||||
LOG("snapping down\n");
|
||||
int new_row = container->row + container->rowspan;
|
||||
if (!cell_exists(container->col, new_row) ||
|
||||
CUR_TABLE[container->col][new_row]->currently_focused != NULL) {
|
||||
for (int i = 0; i < container->colspan; i++)
|
||||
if (!cell_exists(container->col + i, new_row) ||
|
||||
CUR_TABLE[container->col + i][new_row]->currently_focused != NULL) {
|
||||
LOG("cannot snap down - the cell is already used\n");
|
||||
return;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user