diff options
author | Brian Ashworth <bosrsf04@gmail.com> | 2018-10-21 22:57:29 -0400 |
---|---|---|
committer | Brian Ashworth <bosrsf04@gmail.com> | 2018-10-21 22:57:29 -0400 |
commit | 80e8be71a34c44dec693c0b54f8b6b220920b290 (patch) | |
tree | 8696d1c2d30824b01e775c7f118a58eb92ec3ebb /sway/commands/reload.c | |
parent | a918844e52a94d949f7db6181263e0186c52eb29 (diff) |
cmd_reload: recalc font sizing + rebuild textures
When the config gets reloaded, the font height and baseline get reset to
0. If the config does not have a font command in it, the variables will
remain at 0 causing a transparent area where the title would be
rendered.
This makes it so the font height and baseline are recalculated. Additionally,
since the font height and baseline may have changed due to the reload, the
title and marks textures are rebuilt.
Diffstat (limited to 'sway/commands/reload.c')
-rw-r--r-- | sway/commands/reload.c | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/sway/commands/reload.c b/sway/commands/reload.c index 9e136d48..791081a8 100644 --- a/sway/commands/reload.c +++ b/sway/commands/reload.c @@ -5,9 +5,17 @@ #include "sway/ipc-server.h" #include "sway/server.h" #include "sway/tree/arrange.h" +#include "sway/tree/view.h" #include "list.h" #include "log.h" +static void rebuild_textures_iterator(struct sway_container *con, void *data) { + if (con->view) { + view_update_marks_textures(con->view); + } + container_update_title_textures(con); +} + static void do_reload(void *data) { // store bar ids to check against new bars for barconfig_update events list_t *bar_ids = create_list(); @@ -40,6 +48,9 @@ static void do_reload(void *data) { list_foreach(bar_ids, free); list_free(bar_ids); + config_update_font_height(true); + root_for_each_container(rebuild_textures_iterator, NULL); + arrange_root(); } |