diff options
author | emersion <contact@emersion.fr> | 2018-04-10 18:38:43 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-04-10 18:38:43 -0400 |
commit | 84243a708e1f2bb6db6b04550b798dea5a5049d6 (patch) | |
tree | 8850a8528f1e241a9a0ea3247c43840e371e29cf | |
parent | 96118be241b5a2f0f629a1f1859f1ec4ed39734c (diff) | |
parent | 7dfc0409ebd14f256294118ded769cf4df56e758 (diff) |
Merge pull request #1792 from RyanDwyer/fix-swaybar-status-blocks
Fix swaybar not showing all status blocks
-rw-r--r-- | swaybar/render.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/swaybar/render.c b/swaybar/render.c index 28296f31..3fd8da0b 100644 --- a/swaybar/render.c +++ b/swaybar/render.c @@ -154,15 +154,15 @@ static uint32_t render_status_block(cairo_t *cairo, block_width += block->border_right + margin; } - int sep_width; + int sep_width, sep_height; if (!edge) { if (config->sep_symbol) { - int _height; - get_text_size(cairo, config->font, &sep_width, &_height, + get_text_size(cairo, config->font, &sep_width, &sep_height, output->scale, false, "%s", config->sep_symbol); - uint32_t _ideal_height = _height + ws_vertical_padding * 2; - if ((uint32_t)_height < _ideal_height / output->scale) { - return _height / output->scale; + uint32_t _ideal_surface_height = ws_vertical_padding * 2 + + sep_height; + if (_ideal_surface_height > surface_height) { + return _ideal_surface_height; } if (sep_width > block->separator_block_width) { block->separator_block_width = sep_width + margin * 2; @@ -240,7 +240,7 @@ static uint32_t render_status_block(cairo_t *cairo, } if (config->sep_symbol) { offset = pos + (block->separator_block_width - sep_width) / 2; - cairo_move_to(cairo, offset, margin); + cairo_move_to(cairo, offset, height / 2.0 - sep_height / 2.0); pango_printf(cairo, config->font, output->scale, false, "%s", config->sep_symbol); } else { |