i3bar: Include sb_hoff_px only when needed

Fixes #3404.
This commit is contained in:
Orestis Floros 2018-09-15 13:27:18 +03:00
parent 18f705a978
commit 9936d049cf
No known key found for this signature in database
GPG Key ID: E9AD9F32E401E38F

View File

@ -501,7 +501,7 @@ void handle_button(xcb_button_press_event_t *event) {
* check if a status block has been clicked. */ * check if a status block has been clicked. */
int tray_width = get_tray_width(walk->trayclients); int tray_width = get_tray_width(walk->trayclients);
int block_x = 0, last_block_x; int block_x = 0, last_block_x;
int offset = walk->rect.w - walk->statusline_width - tray_width - logical_px(sb_hoff_px); int offset = walk->rect.w - walk->statusline_width - tray_width - logical_px((tray_width > 0) * sb_hoff_px);
int32_t statusline_x = x - offset; int32_t statusline_x = x - offset;
if (statusline_x >= 0 && statusline_x < walk->statusline_width) { if (statusline_x >= 0 && statusline_x < walk->statusline_width) {
@ -2005,7 +2005,8 @@ void draw_bars(bool unhide) {
DLOG("Printing statusline!\n"); DLOG("Printing statusline!\n");
int tray_width = get_tray_width(outputs_walk->trayclients); int tray_width = get_tray_width(outputs_walk->trayclients);
uint32_t max_statusline_width = outputs_walk->rect.w - workspace_width - tray_width - 2 * logical_px(sb_hoff_px); uint32_t hoff = logical_px(((workspace_width > 0) + (tray_width > 0)) * sb_hoff_px);
uint32_t max_statusline_width = outputs_walk->rect.w - workspace_width - tray_width - hoff;
uint32_t clip_left = 0; uint32_t clip_left = 0;
uint32_t statusline_width = full_statusline_width; uint32_t statusline_width = full_statusline_width;
bool use_short_text = false; bool use_short_text = false;
@ -2019,7 +2020,7 @@ void draw_bars(bool unhide) {
} }
int16_t visible_statusline_width = MIN(statusline_width, max_statusline_width); int16_t visible_statusline_width = MIN(statusline_width, max_statusline_width);
int x_dest = outputs_walk->rect.w - tray_width - logical_px(sb_hoff_px) - visible_statusline_width; int x_dest = outputs_walk->rect.w - tray_width - logical_px((tray_width > 0) * sb_hoff_px) - visible_statusline_width;
draw_statusline(outputs_walk, clip_left, use_focus_colors, use_short_text); draw_statusline(outputs_walk, clip_left, use_focus_colors, use_short_text);
draw_util_copy_surface(&outputs_walk->statusline_buffer, &outputs_walk->buffer, 0, 0, draw_util_copy_surface(&outputs_walk->statusline_buffer, &outputs_walk->buffer, 0, 0,