From 5f17f1aa83a7f42a31b90857bd43cf04deaf6c74 Mon Sep 17 00:00:00 2001 From: Emmanuel Lepage Vallee Date: Sat, 30 Apr 2016 02:35:14 -0400 Subject: [PATCH] resize_to_mouse: Support size_hints --- lib/awful/placement.lua | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/lib/awful/placement.lua b/lib/awful/placement.lua index a46996c8..4de4631e 100644 --- a/lib/awful/placement.lua +++ b/lib/awful/placement.lua @@ -146,16 +146,16 @@ local reverse_align_map = {} -- Some parameters to correctly compute the final size local resize_to_point_map = { -- Corners - top_left = {p1= nil , p2={1,1}, x_only=false, y_only=false}, - top_right = {p1={0,1} , p2= nil , x_only=false, y_only=false}, - bottom_left = {p1= nil , p2={1,0}, x_only=false, y_only=false}, - bottom_right = {p1={0,0} , p2= nil , x_only=false, y_only=false}, + top_left = {p1= nil , p2={1,1}, x_only=false, y_only=false, align="bottom_right"}, + top_right = {p1={0,1} , p2= nil , x_only=false, y_only=false, align="bottom_left" }, + bottom_left = {p1= nil , p2={1,0}, x_only=false, y_only=false, align="top_right" }, + bottom_right = {p1={0,0} , p2= nil , x_only=false, y_only=false, align="top_left" }, -- Sides - left = {p1= nil , p2={1,1}, x_only=true , y_only=false}, - right = {p1={0,0} , p2= nil , x_only=true , y_only=false}, - top = {p1= nil , p2={1,1}, x_only=false, y_only=true }, - bottom = {p1={0,0} , p2= nil , x_only=false, y_only=true }, + left = {p1= nil , p2={1,1}, x_only=true , y_only=false, align="top_right" }, + right = {p1={0,0} , p2= nil , x_only=true , y_only=false, align="top_left" }, + top = {p1= nil , p2={1,1}, x_only=false, y_only=true , align="bottom_left" }, + bottom = {p1={0,0} , p2= nil , x_only=false, y_only=true , align="top_left" }, } --- Add a context to the arguments. @@ -706,6 +706,17 @@ function placement.resize_to_mouse(d, args) ngeo[a] = ngeo[a] - 2*bw end + -- Now, correct the geometry by the given size_hints offset + if d.apply_size_hints then + local w, h = d:apply_size_hints( + ngeo.width, + ngeo.height + ) + local offset = align_map[pts.align](w, h, ngeo.width, ngeo.height) + ngeo.x = ngeo.x - offset.x + ngeo.y = ngeo.y - offset.y + end + geometry_common(d, args, ngeo) end