diff options
author | autocommitter <autocommitter@linux-forks.de> | 2024-12-02 00:00:02 +0100 |
---|---|---|
committer | autocommitter <autocommitter@linux-forks.de> | 2024-12-02 00:00:02 +0100 |
commit | 3f53635671b20b87df236790281f647bbd959108 (patch) | |
tree | e93c718cffebd4c760ccfd85f3d247e336bab2a3 /durt/nodes | |
parent | d8689cfa2dce341c032caa9a5882946d8470ed23 (diff) | |
download | luaatc_envs-3f53635671b20b87df236790281f647bbd959108.tar.gz luaatc_envs-3f53635671b20b87df236790281f647bbd959108.tar.bz2 luaatc_envs-3f53635671b20b87df236790281f647bbd959108.zip |
State at 2024-12-02
Diffstat (limited to 'durt/nodes')
-rw-r--r-- | durt/nodes/(1704,17,4658).lua (renamed from durt/nodes/(1718,17,4636).lua) | 0 | ||||
-rw-r--r-- | durt/nodes/(1710,17,4637).lua (renamed from durt/nodes/(1740,17,4636).lua) | 0 | ||||
-rw-r--r-- | durt/nodes/(1759,17,4623).lua | 45 |
3 files changed, 44 insertions, 1 deletions
diff --git a/durt/nodes/(1718,17,4636).lua b/durt/nodes/(1704,17,4658).lua index 7489acc..7489acc 100644 --- a/durt/nodes/(1718,17,4636).lua +++ b/durt/nodes/(1704,17,4658).lua diff --git a/durt/nodes/(1740,17,4636).lua b/durt/nodes/(1710,17,4637).lua index 7489acc..7489acc 100644 --- a/durt/nodes/(1740,17,4636).lua +++ b/durt/nodes/(1710,17,4637).lua diff --git a/durt/nodes/(1759,17,4623).lua b/durt/nodes/(1759,17,4623).lua index 7489acc..c8a4bbd 100644 --- a/durt/nodes/(1759,17,4623).lua +++ b/durt/nodes/(1759,17,4623).lua @@ -1 +1,44 @@ ---
\ No newline at end of file +-- Automatic bouncer for headshunts, assuming longer headshunt than train length. Arrow points into headshunt +local rev_rc = "MCR_HS_E" +local rm_rc = true +local autocouple = "MCR_HS_E_AC" +local rm_cpl_rc = true + +__approach_callback_mode = 1 + +if event.approach and not event.has_entered then + atc_set_lzb_tsr(3) + atc_set_ars_disable(true) + return +end + +if event.train then + if not atc_arrow then --train has bounced + if F.has_rc(autocouple) then + atc_send("CplS0WD2S1") + if rm_cpl_rc then F.remove_rc({autocouple}) end + end + return + end + + if not F.has_rc(rev_rc) then --not our train. disregard + atc_set_ars_disable(false) + return + end + if rm_rc then F.remove_rc({rev_rc}) end + schedule_in(";01",atc_id) + return +end + +if event.schedule then + if not atc_id then --bounce the train that just passed + atc_send_to_train(event.msg,"B0WRD1A1S3") + else + if atc_id == event.msg then --train hasn't fully passed yet, wait a bit longer + schedule_in(";01",atc_id) + else -- somehow another train crossed the controller before the first one returned. Unlikely but possible + atc_send_to_train(event.msg,"BBOL") + atc_send("BBOL") + end + end +end
\ No newline at end of file |