Add "New From Route" function into route editing form

This patch allows creating new routes based on what was done on another route. This can be useful to fix minor mistakes on a route, or to create similar routes. Note that the route buffer created "steps back" one section, but with turnouts kept.

The new button is placed above the "Save ARS" button - I know it is ugly, so please suggest a better place for it.
This commit is contained in:
1F616EMO 2024-09-30 19:37:18 +08:00 committed by orwell
parent 8b9eb2a96d
commit d83d06ecdd
2 changed files with 32 additions and 10 deletions

View File

@ -214,19 +214,32 @@ end
local player_rte_prog = {}
function advtrains.interlocking.init_route_prog(pname, sigd)
function advtrains.interlocking.init_route_prog(pname, sigd, default_route)
if not minetest.check_player_privs(pname, "interlocking") then
minetest.chat_send_player(pname, "Insufficient privileges to use this!")
return
end
player_rte_prog[pname] = {
local rp = {
origin = sigd,
route = {
name = "PROG["..pname.."]",
},
tmp_lcks = {},
}
advtrains.interlocking.visualize_route(sigd, player_rte_prog[pname].route, "prog_"..pname, player_rte_prog[pname].tmp_lcks, pname)
if default_route then
rp.route = table.copy(default_route)
-- "Step back one section", but keeping turnouts
local last_route = rp.route[#rp.route]
if last_route then
rp.tmp_lcks = last_route.locks
rp.route[#rp.route] = nil
end
rp.route.name = "PROG["..pname.."]"
else
rp.route = {
name = "PROG["..pname.."]"
}
rp.tmp_lcks = {}
end
player_rte_prog[pname] = rp
advtrains.interlocking.visualize_route(sigd, rp.route, "prog_"..pname, rp.tmp_lcks, pname)
minetest.chat_send_player(pname, "Route programming mode active. Punch TCBs to add route segments, punch turnouts to lock them.")
end

View File

@ -24,7 +24,7 @@ function atil.show_route_edit_form(pname, sigd, routeid)
local route = tcbs.routes[routeid]
if not route then return end
local form = "size[9,10]label[0.5,0.2;Route overview]"
local form = "size[9,11]label[0.5,0.2;Route overview]"
form = form.."field[0.8,1.2;6.5,1;name;Route name;"..minetest.formspec_escape(route.name).."]"
form = form.."button[7.0,0.9;1.5,1;setname;Set]"
@ -86,10 +86,12 @@ function atil.show_route_edit_form(pname, sigd, routeid)
form = form.."button[4.5,6;2,1;aspect;Signal Aspect]"
form = form.."button[6.5,6;2,1;delete;Delete Route]"
form = form.."button[5.5,7;3,1;newfrom;New From Route]"
--atdebug(route.ars)
form = form.."style[ars;font=mono]"
form = form.."textarea[0.8,7.3;5,3;ars;ARS Rule List;"..atil.ars_to_text(route.ars).."]"
form = form.."button[5.5,7.23;3,1;savears;Save ARS List]"
form = form.."textarea[0.8,8.3;5,3;ars;ARS Rule List;"..atil.ars_to_text(route.ars).."]"
form = form.."button[5.5,8.23;3,1;savears;Save ARS List]"
minetest.show_formspec(pname, "at_il_routeedit_"..minetest.pos_to_string(sigd.p).."_"..sigd.s.."_"..routeid, form)
@ -140,6 +142,13 @@ minetest.register_on_player_receive_fields(function(player, formname, fields)
advtrains.interlocking.show_signalling_form(sigd, pname)
end
if fields.newfrom then
advtrains.interlocking.init_route_prog(pname, sigd, route)
minetest.close_formspec(pname, formname)
tcbs.ars_ignore_next = nil
return
end
if fields.ars and fields.savears then
route.ars = atil.text_to_ars(fields.ars)
--atdebug(route.ars)