diff options
Diffstat (limited to 'durt/nodes')
-rw-r--r-- | durt/nodes/(-1373,10,-2507).lua | 6 | ||||
-rw-r--r-- | durt/nodes/(-1433,11,-2563).lua | 25 | ||||
-rw-r--r-- | durt/nodes/(-1442,11,-2568).lua | 17 | ||||
-rw-r--r-- | durt/nodes/(-1444,11,-2546).lua | 24 | ||||
-rw-r--r-- | durt/nodes/(-1446,11,-2568).lua | 7 | ||||
-rw-r--r-- | durt/nodes/(-1457,11,-2573).lua | 35 | ||||
-rw-r--r-- | durt/nodes/(-1468,11,-2561).lua | 5 | ||||
-rw-r--r-- | durt/nodes/(-1515,7,-2621).lua | 5 | ||||
-rw-r--r-- | durt/nodes/(-1515,7,-2625).lua | 22 | ||||
-rw-r--r-- | durt/nodes/(-2120,21,869).lua | 5 | ||||
-rw-r--r-- | durt/nodes/(-2141,21,865).lua | 3 | ||||
-rw-r--r-- | durt/nodes/(-4129,13,-5726).lua | 1 | ||||
-rw-r--r-- | durt/nodes/(-4224,18,-5973).lua | 11 | ||||
-rw-r--r-- | durt/nodes/(-4224,18,-5985).lua | 41 | ||||
-rw-r--r-- | durt/nodes/(-4227,18,-5926).lua | 41 | ||||
-rw-r--r-- | durt/nodes/(-4227,18,-5936).lua | 7 | ||||
-rw-r--r-- | durt/nodes/(1906,7,9136).lua | 2 | ||||
-rw-r--r-- | durt/nodes/(1907,0,9142).lua | 5 | ||||
-rw-r--r-- | durt/nodes/(1907,8,9129).lua | 3 | ||||
-rw-r--r-- | durt/nodes/(1949,7,9112).lua | 2 |
20 files changed, 257 insertions, 10 deletions
diff --git a/durt/nodes/(-1373,10,-2507).lua b/durt/nodes/(-1373,10,-2507).lua index 7489acc..450ca4a 100644 --- a/durt/nodes/(-1373,10,-2507).lua +++ b/durt/nodes/(-1373,10,-2507).lua @@ -1 +1,5 @@ ---
\ No newline at end of file +if atc_arrow and F.has_rc("S27_EXP_EXIT") then + F.remove_rc("S27_EXP_EXIT") + atc_send("D10SM") + return +end
\ No newline at end of file diff --git a/durt/nodes/(-1433,11,-2563).lua b/durt/nodes/(-1433,11,-2563).lua new file mode 100644 index 0000000..7ac821e --- /dev/null +++ b/durt/nodes/(-1433,11,-2563).lua @@ -0,0 +1,25 @@ +__approach_callback_mode = 1 + +if event.approach and not event.has_entered then + atc_set_ars_disable(true) + atc_set_lzb_tsr(1) + return +end + +if event.train and atc_arrow then + if not F.has_rc("S27_EXP_WAIT") then + atc_set_ars_disable(false) + return + end + atc_send("S0") + return +end + +if event.ext_int and atc_id then + F.remove_rc("S27_REV_West S27_EXP_WAIT") + F.add_rc("S27_REV_East S27_EXP_DEPART") + atc_send("S3") + atc_set_ars_disable(false) + set_autocouple() + return +end
\ No newline at end of file diff --git a/durt/nodes/(-1442,11,-2568).lua b/durt/nodes/(-1442,11,-2568).lua new file mode 100644 index 0000000..6888f6b --- /dev/null +++ b/durt/nodes/(-1442,11,-2568).lua @@ -0,0 +1,17 @@ +local ind = POS(-1444,10,-2546) +if event.train and atc_arrow then + if not F.has_rc("S27_SHUNTER") then + step_fc() + split_off_locomotive("BBA0") + F.add_rc("S27_REV_West S27_EXP_WAIT S27_EXP_COLLECT") + F.indicator(ind,true) + return + end + unset_autocouple() + atc_send("A0BB") + if train_length() > 2 then -- if length > 2 it would try to discouple the nose + split_at_index(train_length()-1,"BBWRD2S3A1") + return + end + atc_send("BBWRD2S3A1") +end
\ No newline at end of file diff --git a/durt/nodes/(-1444,11,-2546).lua b/durt/nodes/(-1444,11,-2546).lua new file mode 100644 index 0000000..235e7d3 --- /dev/null +++ b/durt/nodes/(-1444,11,-2546).lua @@ -0,0 +1,24 @@ +local ind = POS(-1444,10,-2546) +local function send_train() + set_rc("S27_SHUNTER S27_REV_East S27") + atc_send("S0WRD2A1S4") + F.indicator(ind,false) +end +if event.ext_int then + if F.indicator(ind) then return end + if atc_id then + send_train() + return + else + F.indicator(ind,true) + return + end +end +if event.train then + if F.indicator(ind) then + send_train() + return + end + atc_send("B0") + return +end
\ No newline at end of file diff --git a/durt/nodes/(-1446,11,-2568).lua b/durt/nodes/(-1446,11,-2568).lua new file mode 100644 index 0000000..bca38cc --- /dev/null +++ b/durt/nodes/(-1446,11,-2568).lua @@ -0,0 +1,7 @@ +if event.train and atc_arrow then + if not F.has_rc("S27_SHUNTER") then return end + atc_reset() + atc_set_ars_disable(true) + atc_send("BB") + split_at_index(train_length(),"S0WRD1S3A1") +end
\ No newline at end of file diff --git a/durt/nodes/(-1457,11,-2573).lua b/durt/nodes/(-1457,11,-2573).lua index 7489acc..8f984b2 100644 --- a/durt/nodes/(-1457,11,-2573).lua +++ b/durt/nodes/(-1457,11,-2573).lua @@ -1 +1,34 @@ ---
\ No newline at end of file +local rev_rc = "S27_REV_West" +local rm_rc = false + + +__approach_callback_mode = 1 + +if event.approach and not event.has_entered then + atc_set_lzb_tsr(1) + atc_set_ars_disable(true) + return +end + +if event.train and atc_arrow then + if not F.has_rc(rev_rc) then + 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 diff --git a/durt/nodes/(-1468,11,-2561).lua b/durt/nodes/(-1468,11,-2561).lua new file mode 100644 index 0000000..df410b9 --- /dev/null +++ b/durt/nodes/(-1468,11,-2561).lua @@ -0,0 +1,5 @@ +if event.train and atc_arrow then + F.remove_rc({"S27_slag_shed"}) + F.add_rc({"S27_main_yard"}) + atc_send("A0S0WRD50S3A1") +end diff --git a/durt/nodes/(-1515,7,-2621).lua b/durt/nodes/(-1515,7,-2621).lua new file mode 100644 index 0000000..0abb68d --- /dev/null +++ b/durt/nodes/(-1515,7,-2621).lua @@ -0,0 +1,5 @@ +if event.train and atc_arrow then + F.remove_rc({"S27_main_yard"}) + F.add_rc({"S27_slag_shed"}) + atc_send("A0S0WRD100S3A1") +end diff --git a/durt/nodes/(-1515,7,-2625).lua b/durt/nodes/(-1515,7,-2625).lua index c12db21..2fd2155 100644 --- a/durt/nodes/(-1515,7,-2625).lua +++ b/durt/nodes/(-1515,7,-2625).lua @@ -1,17 +1,29 @@ +local notification_id = "S27" local ind = POS(-1513,8,-2613) +local print_notification = true local function send_train() - set_rc("FREIGHT S23 TanhX_NBS23toE3 BYARD BY_COLLECT_S27 MGGRatHYARD S27 S27_UNLOAD S27_Overburden BY_RTS S27_EXIT") + set_rc("FREIGHT S23 ARCAUTO ARC_RTS ARC_COLLECT_S27 ARC_AUTO_S23S TanhX_SBS23toE3 MGGRatHYARD S27 S27_UNLOAD S27_Overburden S27_EXIT") atc_send("S0WRD2A1S4") - set_route(POS(-1504,8,-2622),"Through to Lead") F.indicator(ind,false) end -if event.ext_int and atc_id then - send_train() +if event.ext_int then + if event.message == "notify" then + if print_notification then print(rwt.to_string(rwt.now()) .. " "..notification_id.." RX Notification") end + if F.indicator(ind) then return end + if atc_id then + send_train() + return + else + F.indicator(ind,true) + return + end + end end - if event.train then if F.indicator(ind) then send_train() + return end + atc_send("B0") return end
\ No newline at end of file diff --git a/durt/nodes/(-2120,21,869).lua b/durt/nodes/(-2120,21,869).lua new file mode 100644 index 0000000..b9831ee --- /dev/null +++ b/durt/nodes/(-2120,21,869).lua @@ -0,0 +1,5 @@ +-- +if event.train and atc_arrow and get_line() == "S20" then + local current_text = atc_get_text_outside() or "" + atc_set_text_outside("Service Ends At Arcadius\n No Access to Trap City\n \n"..current_text) +end
\ No newline at end of file diff --git a/durt/nodes/(-2141,21,865).lua b/durt/nodes/(-2141,21,865).lua new file mode 100644 index 0000000..2750c52 --- /dev/null +++ b/durt/nodes/(-2141,21,865).lua @@ -0,0 +1,3 @@ +if event.train and atc_arrow and get_line() == "S20" then + atc_set_text_outside("S20 - Euler Street <-> Trap City") +end
\ No newline at end of file diff --git a/durt/nodes/(-4129,13,-5726).lua b/durt/nodes/(-4129,13,-5726).lua index d5aa4b1..2f179db 100644 --- a/durt/nodes/(-4129,13,-5726).lua +++ b/durt/nodes/(-4129,13,-5726).lua @@ -13,7 +13,6 @@ if event.train then atc_send("CplD1S2") return end - atc_send("B4") end end diff --git a/durt/nodes/(-4224,18,-5973).lua b/durt/nodes/(-4224,18,-5973).lua new file mode 100644 index 0000000..8f6490a --- /dev/null +++ b/durt/nodes/(-4224,18,-5973).lua @@ -0,0 +1,11 @@ +if not F.has_rc("CORN_SHUNT") then return end +if not F.has_rc("CORN_rejoin") then + F.add_rc("CORN_rejoin") + split_off_locomotive("S0A0") + F.add_rc("CORN_HS_S CORN_AROUND CORN_HS_N") + return +else + F.remove_rc("CORN_rejoin") + F.add_rc("CORN_HS_S") + unset_autocouple() +end
\ No newline at end of file diff --git a/durt/nodes/(-4224,18,-5985).lua b/durt/nodes/(-4224,18,-5985).lua new file mode 100644 index 0000000..aacd93f --- /dev/null +++ b/durt/nodes/(-4224,18,-5985).lua @@ -0,0 +1,41 @@ +local rev_rc = "CORN_HS_S" +local rm_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 atc_arrow then + if not F.has_rc(rev_rc) then + atc_set_ars_disable(false) + return + end + if rm_rc then F.remove_rc(rev_rc) end + schedule_in(";01",atc_id) + return + else + if not F.has_rc("CORN_rejoin") then + F.add_rc("CORN_EXIT") + end + return + end +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 diff --git a/durt/nodes/(-4227,18,-5926).lua b/durt/nodes/(-4227,18,-5926).lua new file mode 100644 index 0000000..b640ec9 --- /dev/null +++ b/durt/nodes/(-4227,18,-5926).lua @@ -0,0 +1,41 @@ +local rev_rc = "CORN_HS_N" +local rm_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 atc_arrow then + if not F.has_rc(rev_rc) then + atc_set_ars_disable(false) + return + end + if rm_rc then F.remove_rc(rev_rc) end + schedule_in(";01",atc_id) + return + else + if F.has_rc("CORN_rejoin") then + set_autocouple() + end + return + end +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 diff --git a/durt/nodes/(-4227,18,-5936).lua b/durt/nodes/(-4227,18,-5936).lua new file mode 100644 index 0000000..b11f8a1 --- /dev/null +++ b/durt/nodes/(-4227,18,-5936).lua @@ -0,0 +1,7 @@ +if not F.has_rc("CORN_SHUNT") then return end +if not atc_arrow then return end +if F.has_rc("CORN_EXIT") then + F.remove_rc("CORN_EXIT CORN_AROUND") + atc_send("D10SM") + return +end
\ No newline at end of file diff --git a/durt/nodes/(1906,7,9136).lua b/durt/nodes/(1906,7,9136).lua index 03ae1a0..f83e4fc 100644 --- a/durt/nodes/(1906,7,9136).lua +++ b/durt/nodes/(1906,7,9136).lua @@ -16,7 +16,7 @@ if event.approach and not event.has_entered then end if event.train and atc_arrow then - digiline_send("mine_counter_lcd",S.yards.WOA.mine_counter) + digiline_send("mine_counter_lcd",S.yards.WOA.mine_count) if F.has_rc("WOA_mine_around") then if F.has_rc("WOA_around_active") then F.remove_rc(around_rc_list) diff --git a/durt/nodes/(1907,0,9142).lua b/durt/nodes/(1907,0,9142).lua new file mode 100644 index 0000000..0a2edad --- /dev/null +++ b/durt/nodes/(1907,0,9142).lua @@ -0,0 +1,5 @@ +if event.channel=="auth" then + S.yards.WOA.mine_count = 0 + print("WOA Mine: reset counter") + digiline_send("train_ctl","send") +end
\ No newline at end of file diff --git a/durt/nodes/(1907,8,9129).lua b/durt/nodes/(1907,8,9129).lua new file mode 100644 index 0000000..b18ad84 --- /dev/null +++ b/durt/nodes/(1907,8,9129).lua @@ -0,0 +1,3 @@ +if event.punch then + digiline_send("mine_counter_lcd",tostring(S.yards.WOA.mine_count)) +end
\ No newline at end of file diff --git a/durt/nodes/(1949,7,9112).lua b/durt/nodes/(1949,7,9112).lua index 8fd61c9..164a253 100644 --- a/durt/nodes/(1949,7,9112).lua +++ b/durt/nodes/(1949,7,9112).lua @@ -14,7 +14,7 @@ if event.train and atc_arrow then end if (event.ext_int and event.message == "notify") or (event.schedule and event.message == "send") or (event.channel=="train_ctl" and event.msg=="send") then - print("WOA RX Notification") + print(rwt.to_string(rwt.now()) .. " WOA RX Notification") if not atc_id then F.indicator(ind,true) return |