diff options
author | orwell <orwell@bleipb.de> | 2025-06-10 20:43:17 +0200 |
---|---|---|
committer | orwell <orwell@bleipb.de> | 2025-06-10 20:43:17 +0200 |
commit | 56e00d697e38d87bdfecada36eae98199ae94fc1 (patch) | |
tree | aaa21ae2d1d3c9d752a9ac24de56c2347d9d64ee | |
parent | adc01a0bba29b40278e45c50caa954c435374f7b (diff) | |
download | advtrains-56e00d697e38d87bdfecada36eae98199ae94fc1.tar.gz advtrains-56e00d697e38d87bdfecada36eae98199ae94fc1.tar.bz2 advtrains-56e00d697e38d87bdfecada36eae98199ae94fc1.zip |
tcb_ts_ui: correctly state reason for invalid route, do not reopen signalling form when form was left to edit/add
-rwxr-xr-x | advtrains_interlocking/tcb_ts_ui.lua | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/advtrains_interlocking/tcb_ts_ui.lua b/advtrains_interlocking/tcb_ts_ui.lua index 0be943a..7cc25ed 100755 --- a/advtrains_interlocking/tcb_ts_ui.lua +++ b/advtrains_interlocking/tcb_ts_ui.lua @@ -786,8 +786,12 @@ function advtrains.interlocking.check_route_valid(route, sigd) local nvar = c_rseg.next if nvar then local re_tcbs = ildb.get_tcbs({p = nvar.p, s = (nvar.s==1) and 2 or 1}) - if not re_tcbs or not re_tcbs.ts_id or re_tcbs.ts_id~=c_ts_id then - return false, "TCB at "..minetest.pos_to_string(nvar.p).." has different section than previous TCB." + if not re_tcbs then + return false, "TCB at "..minetest.pos_to_string(nvar.p).." is missing" + elseif not re_tcbs.ts_id then + return false, "TCB at "..minetest.pos_to_string(nvar.p).." is not assigned to previous track section" + elseif re_tcbs.ts_id~=c_ts_id then + return false, "TCB at "..minetest.pos_to_string(nvar.p).." has different section than previous TCB" end end -- advance @@ -1024,11 +1028,13 @@ minetest.register_on_player_receive_fields(function(player, formname, fields) advtrains.interlocking.init_route_prog(pname, sigd) minetest.close_formspec(pname, formname) tcbs.ars_ignore_next = nil + p_open_sig_form[pname] = nil -- form is closed/left, do not reopen return end if fields.smartroute and hasprivs then advtrains.interlocking.smartroute.start(pname, sigd) tcbs.ars_ignore_next = nil + p_open_sig_form[pname] = nil -- form is closed/left, do not reopen return end if sel_rte and tcbs.routes[sel_rte] then @@ -1042,6 +1048,7 @@ minetest.register_on_player_receive_fields(function(player, formname, fields) end if fields.editroute and hasprivs then advtrains.interlocking.show_route_edit_form(pname, sigd, sel_rte) + p_open_sig_form[pname] = nil -- form is closed/left, do not reopen return end if fields.setarsdefault and hasprivs then |