diff options
author | Drew DeVault <[email protected]> | 2018-07-15 05:01:25 -0700 |
---|---|---|
committer | GitHub <[email protected]> | 2018-07-15 05:01:25 -0700 |
commit | 53e3f35ba348d6285478ceb4a93b020e138c95c7 (patch) | |
tree | 091c6133f3bd33b64b1853c7984eaa3921b9facf /sway/tree/container.c | |
parent | 806c06fdfbbf1734f2df74b85d861bf0bc13f48e (diff) | |
parent | 6b2dc7e63b3a602b29c47e3b70bc7890c063dcf4 (diff) |
Merge pull request #2272 from RyanDwyer/simplify-transactions
Simplify transactions by using a dirty flag on containers
Diffstat (limited to 'sway/tree/container.c')
-rw-r--r-- | sway/tree/container.c | 24 |
1 files changed, 11 insertions, 13 deletions
diff --git a/sway/tree/container.c b/sway/tree/container.c index 58852717..35f67cce 100644 --- a/sway/tree/container.c +++ b/sway/tree/container.c @@ -159,14 +159,6 @@ void container_free(struct sway_container *cont) { wlr_texture_destroy(cont->title_focused_inactive); wlr_texture_destroy(cont->title_unfocused); wlr_texture_destroy(cont->title_urgent); - - for (int i = 0; i < server.destroying_containers->length; ++i) { - if (server.destroying_containers->items[i] == cont) { - list_del(server.destroying_containers, i); - break; - } - } - list_free(cont->instructions); list_free(cont->children); list_free(cont->current.children); @@ -325,7 +317,7 @@ static struct sway_container *container_destroy_noreaping( } con->destroying = true; - list_add(server.destroying_containers, con); + container_set_dirty(con); if (!con->parent) { return NULL; @@ -1069,9 +1061,15 @@ void container_floating_move_to(struct sway_container *con, if (old_workspace != new_workspace) { container_remove_child(con); container_add_child(new_workspace->sway_workspace->floating, con); - struct sway_transaction *transaction = transaction_create(); - arrange_windows(old_workspace, transaction); - arrange_windows(new_workspace, transaction); - transaction_commit(transaction); + arrange_windows(old_workspace); + arrange_windows(new_workspace); + } +} + +void container_set_dirty(struct sway_container *container) { + if (container->dirty) { + return; } + container->dirty = true; + list_add(server.dirty_containers, container); } |