feat(bar): let gtk-layer-shell manage exclusive zone

Previous attempts to use auto exclusive zone from gtk-layer-shell failed
because gls was expecting real booleans (`TRUE`/`FALSE`) as set_anchor
arguments. With that being fixed, gtk_layer_auto_exclusive_zone_enable
makes gls handle everything related to the bar resizing.

The only remaining purpose of onConfigureGLS is to log warnings and bar
size changes; gtk-layer-shell code path no longer needs saved width_ or
height_ values.
This commit is contained in:
Aleksei Bavshin 2020-10-20 23:18:58 -07:00
parent 9fa2cc45d2
commit 2b3d7be9cb
No known key found for this signature in database
GPG Key ID: 4F071603387A382A

View File

@ -2,10 +2,11 @@
#include <gtk-layer-shell.h> #include <gtk-layer-shell.h>
#endif #endif
#include <spdlog/spdlog.h>
#include "bar.hpp" #include "bar.hpp"
#include "client.hpp" #include "client.hpp"
#include "factory.hpp" #include "factory.hpp"
#include <spdlog/spdlog.h>
waybar::Bar::Bar(struct waybar_output* w_output, const Json::Value& w_config) waybar::Bar::Bar(struct waybar_output* w_output, const Json::Value& w_config)
: output(w_output), : output(w_output),
@ -134,33 +135,32 @@ void waybar::Bar::initGtkLayerShell() {
gtk_layer_set_monitor(gtk_window, output->monitor->gobj()); gtk_layer_set_monitor(gtk_window, output->monitor->gobj());
gtk_layer_set_namespace(gtk_window, "waybar"); gtk_layer_set_namespace(gtk_window, "waybar");
gtk_layer_set_anchor( gtk_layer_set_anchor(gtk_window,
gtk_window, GTK_LAYER_SHELL_EDGE_LEFT, anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_LEFT); GTK_LAYER_SHELL_EDGE_LEFT,
gtk_layer_set_anchor( (anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_LEFT) ? TRUE : FALSE);
gtk_window, GTK_LAYER_SHELL_EDGE_RIGHT, anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_RIGHT); gtk_layer_set_anchor(gtk_window,
gtk_layer_set_anchor( GTK_LAYER_SHELL_EDGE_RIGHT,
gtk_window, GTK_LAYER_SHELL_EDGE_TOP, anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP); (anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_RIGHT) ? TRUE : FALSE);
gtk_layer_set_anchor( gtk_layer_set_anchor(gtk_window,
gtk_window, GTK_LAYER_SHELL_EDGE_BOTTOM, anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM); GTK_LAYER_SHELL_EDGE_TOP,
(anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP) ? TRUE : FALSE);
gtk_layer_set_anchor(gtk_window,
GTK_LAYER_SHELL_EDGE_BOTTOM,
(anchor_ & ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM) ? TRUE : FALSE);
gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_LEFT, margins_.left); gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_LEFT, margins_.left);
gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_RIGHT, margins_.right); gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_RIGHT, margins_.right);
gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_TOP, margins_.top); gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_TOP, margins_.top);
gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_BOTTOM, margins_.bottom); gtk_layer_set_margin(gtk_window, GTK_LAYER_SHELL_EDGE_BOTTOM, margins_.bottom);
if (width_ > 1 && height_ > 1) {
/* configure events are not emitted if the bar is using initial size */
setExclusiveZone(width_, height_); setExclusiveZone(width_, height_);
} }
}
void waybar::Bar::onConfigureGLS(GdkEventConfigure* ev) { void waybar::Bar::onConfigureGLS(GdkEventConfigure* ev) {
/* /*
* GTK wants new size for the window. * GTK wants new size for the window.
* Actual resizing is done within the gtk-layer-shell code; the only remaining action is to apply * Actual resizing and management of the exclusve zone is handled within the gtk-layer-shell code.
* exclusive zone. * This event handler only updates stored size of the window and prints some warnings.
* gtk_layer_auto_exclusive_zone_enable() could handle even that, but at the cost of ignoring
* margins on unanchored edge.
* *
* Note: forced resizing to a window smaller than required by GTK would not work with * Note: forced resizing to a window smaller than required by GTK would not work with
* gtk-layer-shell. * gtk-layer-shell.
@ -170,14 +170,13 @@ void waybar::Bar::onConfigureGLS(GdkEventConfigure* ev) {
spdlog::warn(MIN_WIDTH_MSG, width_, ev->width); spdlog::warn(MIN_WIDTH_MSG, width_, ev->width);
} }
} else { } else {
if (!vertical && height_ > 1 && ev->height > static_cast<int>(height_)) { if (height_ > 1 && ev->height > static_cast<int>(height_)) {
spdlog::warn(MIN_HEIGHT_MSG, height_, ev->height); spdlog::warn(MIN_HEIGHT_MSG, height_, ev->height);
} }
} }
width_ = ev->width; width_ = ev->width;
height_ = ev->height; height_ = ev->height;
spdlog::info(BAR_SIZE_MSG, width_, height_, output->name); spdlog::info(BAR_SIZE_MSG, width_, height_, output->name);
setExclusiveZone(width_, height_);
} }
void waybar::Bar::onMapGLS(GdkEventAny* ev) { void waybar::Bar::onMapGLS(GdkEventAny* ev) {
@ -262,6 +261,18 @@ void waybar::Bar::onMap(GdkEventAny* ev) {
} }
void waybar::Bar::setExclusiveZone(uint32_t width, uint32_t height) { void waybar::Bar::setExclusiveZone(uint32_t width, uint32_t height) {
#ifdef HAVE_GTK_LAYER_SHELL
if (use_gls_) {
if (visible) {
spdlog::debug("Enable auto exclusive zone for output {}", output->name);
gtk_layer_auto_exclusive_zone_enable(window.gobj());
} else {
spdlog::debug("Disable exclusive zone for output {}", output->name);
gtk_layer_set_exclusive_zone(window.gobj(), 0);
}
} else
#endif
{
auto zone = 0; auto zone = 0;
if (visible) { if (visible) {
// exclusive zone already includes margin for anchored edge, // exclusive zone already includes margin for anchored edge,
@ -275,13 +286,6 @@ void waybar::Bar::setExclusiveZone(uint32_t width, uint32_t height) {
} }
} }
spdlog::debug("Set exclusive zone {} for output {}", zone, output->name); spdlog::debug("Set exclusive zone {} for output {}", zone, output->name);
#ifdef HAVE_GTK_LAYER_SHELL
if (use_gls_) {
gtk_layer_set_exclusive_zone(window.gobj(), zone);
} else
#endif
{
zwlr_layer_surface_v1_set_exclusive_zone(layer_surface_, zone); zwlr_layer_surface_v1_set_exclusive_zone(layer_surface_, zone);
} }
} }