tests: Fix the `screen` template rendering with multiple screens.

It only worked for a single screen. It still isn't perfect, but
much better than it was.
This commit is contained in:
Emmanuel Lepage Vallee 2021-07-06 00:53:21 -07:00
parent dd6163ffe6
commit b2368c54a8
16 changed files with 66 additions and 66 deletions

View File

@ -39,7 +39,7 @@ local clients = {
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
draw_client_snap = true, --FIXME draw_client_snap = true, --FIXME

View File

@ -35,7 +35,7 @@ local clients = {
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
draw_gaps = true, draw_gaps = true,

View File

@ -35,7 +35,7 @@ local clients = {
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
draw_gaps = true, draw_gaps = true,

View File

@ -36,7 +36,7 @@ local clients = {
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
draw_gaps = true, draw_gaps = true,

View File

@ -36,7 +36,7 @@ local clients = {
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
draw_gaps = true, draw_gaps = true,

View File

@ -29,8 +29,8 @@ end --DOC_HIDE
} }
return { --DOC_HIDE return { --DOC_HIDE
factor = 2 , --DOC_HIDE factor = 2 , --DOC_HIDE
show_boxes = false, --DOC_HIDE show_boxes = false , --DOC_HIDE
highlight_geometry = true , --DOC_HIDE highlight_geometry = true , --DOC_HIDE
draw_wibar = wibar, --DOC_HIDE draw_wibars = {wibar}, --DOC_HIDE
} --DOC_HIDE } --DOC_HIDE

View File

@ -45,9 +45,9 @@ for _,c in ipairs(clients) do
end end
return { return {
factor = 2 , factor = 2,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
} }

View File

@ -47,7 +47,7 @@ end
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
} }

View File

@ -48,7 +48,7 @@ end
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
draw_mwfact = true, draw_mwfact = true,

View File

@ -51,7 +51,7 @@ end
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
draw_mwfact = true, draw_mwfact = true,

View File

@ -32,8 +32,8 @@ end --DOC_HIDE
} --DOC_HIDE } --DOC_HIDE
return { --DOC_HIDE return { --DOC_HIDE
factor = 2 , --DOC_HIDE factor = 2 , --DOC_HIDE
show_boxes = false, --DOC_HIDE show_boxes = false , --DOC_HIDE
highlight_padding_area = true , --DOC_HIDE highlight_padding_area = true , --DOC_HIDE
draw_wibar = wibar, --DOC_HIDE draw_wibars = {wibar}, --DOC_HIDE
} --DOC_HIDE } --DOC_HIDE

View File

@ -51,9 +51,9 @@ local clients = { --DOC_HIDE
} --DOC_HIDE } --DOC_HIDE
return { --DOC_HIDE return { --DOC_HIDE
factor = 2 , --DOC_HIDE factor = 2, --DOC_HIDE
show_boxes = true, --DOC_HIDE show_boxes = true, --DOC_HIDE
draw_wibar = wibar, --DOC_HIDE draw_wibars = {wibar}, --DOC_HIDE
draw_clients = clients, --DOC_HIDE draw_clients = clients, --DOC_HIDE
display_screen_info = false, --DOC_HIDE display_screen_info = false, --DOC_HIDE
draw_struts = true, --DOC_HIDE draw_struts = true, --DOC_HIDE

View File

@ -160,11 +160,12 @@ local function draw_client(_, c, name, offset, label, alpha)
end end
local function compute_ruler(_, rect, name) local function compute_ruler(s, rect, name)
table.insert(hrulers, { hrulers[s], vrulers[s] = hrulers[s] or {}, vrulers[s] or {}
table.insert(hrulers[s], {
label = name, x = rect.x, width = rect.width label = name, x = rect.x, width = rect.width
}) })
table.insert(vrulers, { table.insert(vrulers[s], {
label = name, y = rect.y, height = rect.height label = name, y = rect.y, height = rect.height
}) })
end end
@ -309,8 +310,8 @@ end
local function draw_rulers(s) local function draw_rulers(s)
-- The table has a maximum of 4 entries, the sort algorithm is irrelevant. -- The table has a maximum of 4 entries, the sort algorithm is irrelevant.
while not bubble_sort(hrulers, "x", "width" ) do end while not bubble_sort(hrulers[s], "x", "width" ) do end
while not bubble_sort(vrulers, "y", "height") do end while not bubble_sort(vrulers[s], "y", "height") do end
cr:set_line_width(1) cr:set_line_width(1)
cr:set_dash(nil) cr:set_dash(nil)
@ -320,7 +321,7 @@ local function draw_rulers(s)
dx = get_text_height() + 10 dx = get_text_height() + 10
for k, ruler in ipairs(vrulers) do for k, ruler in ipairs(vrulers[s]) do
draw_vruler(s, dx, sx, ruler, k) draw_vruler(s, dx, sx, ruler, k)
end end
@ -406,10 +407,6 @@ local function evaluate_translation(draw_gaps, draw_struts, draw_mwfact, draw_cl
end end
end end
local function translate()
cr:translate(tr_x, tr_y * 0.66)
end
local function draw_gaps(s) local function draw_gaps(s)
cr:translate(-tr_x, -tr_y) cr:translate(-tr_x, -tr_y)
@ -473,7 +470,7 @@ local function draw_struts(s)
if left > 0 then if left > 0 then
draw_hruler( draw_hruler(
s, s,
0, s.geometry.y*0.66,
get_text_height(), get_text_height(),
{x = s.geometry.x+tr_x*2, width = left, color = colors.gaps.."66", align = true}, {x = s.geometry.x+tr_x*2, width = left, color = colors.gaps.."66", align = true},
1 1
@ -484,7 +481,7 @@ local function draw_struts(s)
draw_vruler( draw_vruler(
s, s,
get_text_height()*1.5, get_text_height()*1.5,
0, s.geometry.x*0.66,
{y=s.geometry.y+tr_y*(1/factor), height = top, color = colors.gaps.."66", align = true}, {y=s.geometry.y+tr_y*(1/factor), height = top, color = colors.gaps.."66", align = true},
1 1
) )
@ -493,7 +490,7 @@ local function draw_struts(s)
if right > 0 then if right > 0 then
draw_hruler( draw_hruler(
s, s,
0, s.geometry.y*0.66,
get_text_height(), get_text_height(),
{x = s.geometry.x, width = left, color = colors.gaps.."66", align = true}, {x = s.geometry.x, width = left, color = colors.gaps.."66", align = true},
1 1
@ -504,7 +501,7 @@ local function draw_struts(s)
draw_vruler( draw_vruler(
s, s,
get_text_height()*1.5, get_text_height()*1.5,
0, s.geometry.x*0.66,
{ {
y = s.geometry.y+tr_y*(1/factor)+s.geometry.height - bottom, y = s.geometry.y+tr_y*(1/factor)+s.geometry.height - bottom,
height = bottom, height = bottom,
@ -667,8 +664,8 @@ local function draw_info(s)
end end
-- Compute the rulers size. -- Compute the rulers size.
for _=1, screen.count() do for k=1, screen.count() do
local s = screen[1] local s = screen[k]
-- The padding. -- The padding.
compute_ruler(s, s.tiling_area, "tiling_area") compute_ruler(s, s.tiling_area, "tiling_area")
@ -699,16 +696,15 @@ sew, seh = sew + 5*get_text_height(), seh + 5*get_text_height()
img = cairo.SvgSurface.create(image_path..".svg", sew, seh) img = cairo.SvgSurface.create(image_path..".svg", sew, seh)
cr = cairo.Context(img) cr = cairo.Context(img)
cr:set_line_width(1.5)
cr:set_dash({10,4},1)
-- Instead of adding origin offset everywhere, translate the viewport. -- Instead of adding origin offset everywhere, translate the viewport.
translate() cr:translate(tr_x, tr_y * 0.66)
-- Draw the various areas. -- Draw the various areas.
for k=1, screen.count() do for k=1, screen.count() do
local s = screen[1] local s = screen[k]
cr:set_line_width(1.5)
cr:set_dash({10,4},1)
-- The outer geometry. -- The outer geometry.
draw_area(s, s.geometry, "geometry", (k-1)*10, args.highlight_geometry) draw_area(s, s.geometry, "geometry", (k-1)*10, args.highlight_geometry)
@ -727,8 +723,10 @@ for k=1, screen.count() do
draw_rulers(s) draw_rulers(s)
-- Draw the wibar. -- Draw the wibar.
if args.draw_wibar then for _, wibar in ipairs(args.draw_wibars or {}) do
draw_struct(s, args.draw_wibar, 'wibar', (k-1)*10, 'Wibar') if wibar.screen == s then
draw_struct(s, wibar, 'wibar', (k-1)*10, 'Wibar')
end
end end
local skip_gaps = s.selected_tag local skip_gaps = s.selected_tag
@ -740,28 +738,30 @@ for k=1, screen.count() do
-- Draw clients. -- Draw clients.
if args.draw_clients then if args.draw_clients then
for label,c in pairs(args.draw_clients) do for label,c in pairs(args.draw_clients) do
local gap = c:tags()[1].gap if c.screen == s then
if args.draw_gaps and gap > 0 and (not c.floating) and not skip_gaps then local gap = c:tags()[1].gap
local proxy = { if args.draw_gaps and gap > 0 and (not c.floating) and not skip_gaps then
x = c.x - gap, local proxy = {
y = c.y - gap, x = c.x - gap,
width = c.width + 2*gap, y = c.y - gap,
height = c.height + 2*gap, width = c.width + 2*gap,
} height = c.height + 2*gap,
}
draw_client(s, proxy, 'gaps', (k-1)*10, nil, "11") draw_client(s, proxy, 'gaps', (k-1)*10, nil, "11")
elseif args.draw_client_snap and c.floating then elseif args.draw_client_snap and c.floating then
local proxy = { local proxy = {
x = c.x - sd, x = c.x - sd,
y = c.y - sd, y = c.y - sd,
width = c.width + 2*sd, width = c.width + 2*sd,
height = c.height + 2*sd, height = c.height + 2*sd,
} }
draw_client(s, proxy, 'gaps', (k-1)*10, nil, "11") draw_client(s, proxy, 'gaps', (k-1)*10, nil, "11")
end
draw_client(s, c, 'tiling_client', (k-1)*10, label)
end end
draw_client(s, c, 'tiling_client', (k-1)*10, label)
end end
end end

View File

@ -47,7 +47,7 @@ end
return { return {
factor = 2 , factor = 2 ,
show_boxes = true, show_boxes = true,
draw_wibar = wibar, draw_wibars = {wibar},
draw_clients = clients, draw_clients = clients,
display_screen_info = false, display_screen_info = false,
} }

View File

@ -27,5 +27,5 @@ return {
factor = 2 , factor = 2 ,
show_boxes = false, show_boxes = false,
highlight_tiling_area = true , highlight_tiling_area = true ,
draw_wibar = wibar, draw_wibars = {wibar},
} }

View File

@ -35,8 +35,8 @@ end --DOC_HIDE
} }
return { --DOC_HIDE return { --DOC_HIDE
factor = 2 , --DOC_HIDE factor = 2, --DOC_HIDE
show_boxes = false, --DOC_HIDE show_boxes = false, --DOC_HIDE
highlight_workarea = true , --DOC_HIDE highlight_workarea = true , --DOC_HIDE
draw_wibar = wibar, --DOC_HIDE draw_wibars = {wibar}, --DOC_HIDE
} --DOC_HIDE } --DOC_HIDE