Make lua selection line create a new selection

... instead of modifying the one given as a parameter.

Also add some tests for it.
This commit is contained in:
Pasi Kallinen
2020-02-22 14:23:33 +02:00
parent 00a32c6039
commit 44f7d44e94
3 changed files with 34 additions and 12 deletions

View File

@@ -29,26 +29,23 @@ if math.random(0,99) < 75 then
local tidx = math.random(1, #terrains);
local choice = math.random(0, 4);
if choice == 0 then
-- one horizontal line
des.terrain(selection.line(10,8, 65,8), terrains[tidx]);
elseif choice == 1 then
local sel = selection.new();
sel:line(15,4, 15, 13);
sel:line(59,4, 59, 13);
-- two vertical lines
local sel = selection.line(15,4, 15, 13) | selection.line(59,4, 59, 13);
des.terrain(sel, terrains[tidx]);
elseif choice == 2 then
local sel = selection.new();
sel:line(10,8, 38, 8);
sel:line(37,8, 65, 8);
sel:line(37,3, 37, 8);
sel:line(37,8, 37,14);
-- plus sign
local sel = selection.line(10,8, 64, 8) | selection.line(37,3, 37, 14);
des.terrain(sel, terrains[tidx]);
elseif choice == 3 then
-- brackets: [ ]
des.terrain(selection.rect(4,4, 70,13), terrains[tidx]);
local sel = selection.new();
sel:line(25,4, 50,4);
sel:line(25,13, 50,13);
local sel = selection.line(25,4, 50,4) | selection.line(25,13, 50,13);
des.terrain(sel, '.');
else
-- nothing
end
end

View File

@@ -334,6 +334,10 @@ lua_State *L;
return 2;
}
/* internal function to get a selection and 4 integer values from lua stack.
removes the integers from the stack.
returns TRUE if params are good.
*/
/* function(selection, x1,y1, x2,y2) */
/* selection:function(x1,y1, x2,y2) */
static boolean
@@ -362,6 +366,7 @@ schar *x1, *y1, *x2, *y2;
*y1 = (schar) luaL_checkinteger(L, 3);
*x2 = (schar) luaL_checkinteger(L, 4);
*y2 = (schar) luaL_checkinteger(L, 5);
lua_pop(L, 4);
return TRUE;
}
return FALSE;
@@ -387,8 +392,10 @@ lua_State *L;
get_location_coord(&x1, &y1, ANY_LOC, g.coder ? g.coder->croom : NULL, SP_COORD_PACK(x1,y1));
get_location_coord(&x2, &y2, ANY_LOC, g.coder ? g.coder->croom : NULL, SP_COORD_PACK(x2,y2));
selection_do_line(x1,y1,x2,y2, sel);
lua_settop(L, 1);
(void) l_selection_clone(L);
sel = l_selection_check(L, 1);
selection_do_line(x1,y1,x2,y2, sel);
return 1;
}

View File

@@ -227,9 +227,27 @@ function test_sel_filter_percent()
-- TODO: Need a predictable rn2 to test for percentage(50)
end -- test_sel_filter_percent
function test_sel_line()
local __func__ = "test_sel_line";
local sela = selection.new();
local sela_clone = sela:clone();
local selb = sela:line(1,1, 5,5);
sel_are_equal(sela, sela_clone, __func__);
sel_has_n_points(selb, 5, __func__);
for x = 1, 5 do
sel_pt_ne(selb, x,x, 1, __func__);
end
local selc = selb:line(10,1, 10,5);
sel_has_n_points(selc, 10, __func__);
end -- test_sel_line
test_selection_params();
test_sel_negate();
test_sel_logical_and();
test_sel_logical_or();
test_sel_logical_xor();
test_sel_filter_percent();
test_sel_line();