From d4cb8dc8b303892e2414f03a7d35a54c9f2f7902 Mon Sep 17 00:00:00 2001 From: Uli Schlachter Date: Wed, 3 Jul 2019 22:55:38 +0200 Subject: [PATCH] wibox.hierarchy:draw: Clear paths after .draw (#2805) Cairo's save/restore methods handle all properties except for the current path. The path is just left as-is. A widget's draw method could create some path without consuming it. This path would then interfere with random things later which did not expect a path to already exist. This commits adds calls to cairo_new_path() in the relevant positions to clean things up. This not only applies to a widget's draw method, but also {before,after}_draw_{child,children}. However, these methods could (for whatever reason) create paths that are to be consumed in one of the other methods. To keep this working, the path is only cleared after all of these methods ran. I do not expect this commit to break anything, because a widget cannot really assume much about what widget is drawn after it. Especially so, because partial redraws could mean that some later widget is skipped and not redrawn. This should fix the issue reported at https://github.com/awesomeWM/awesome/pull/2804. Signed-off-by: Uli Schlachter --- lib/wibox/hierarchy.lua | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/lib/wibox/hierarchy.lua b/lib/wibox/hierarchy.lua index 7dbeb73a..d0e07d63 100644 --- a/lib/wibox/hierarchy.lua +++ b/lib/wibox/hierarchy.lua @@ -350,6 +350,8 @@ function hierarchy:draw(context, cr) cr:clip() call(widget.draw) cr:restore() + -- Clear any path that the widget might have left + cr:new_path() -- Draw its children (We already clipped to the draw extents above) call(widget.before_draw_children) @@ -359,6 +361,8 @@ function hierarchy:draw(context, cr) call(widget.after_draw_child, i, wi:get_widget()) end call(widget.after_draw_children) + -- Clear any path that the widget might have left + cr:new_path() -- Apply opacity if opacity ~= 1 then