summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--durt/nodes/(1704,17,4652).lua44
-rw-r--r--durt/nodes/(1710,17,4637).lua18
-rw-r--r--durt/nodes/(1740,17,4636).lua15
-rw-r--r--durt/nodes/(1742,17,4642).lua (renamed from durt/nodes/(1704,17,4658).lua)0
-rw-r--r--durt/nodes/(1742,17,4652).lua1
5 files changed, 77 insertions, 1 deletions
diff --git a/durt/nodes/(1704,17,4652).lua b/durt/nodes/(1704,17,4652).lua
new file mode 100644
index 0000000..ca0506c
--- /dev/null
+++ b/durt/nodes/(1704,17,4652).lua
@@ -0,0 +1,44 @@
+-- Automatic bouncer for headshunts, assuming longer headshunt than train length. Arrow points into headshunt
+local rev_rc = "MCR_HS_W"
+local rm_rc = true
+local autocouple = "MCR_HS_W_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
+ -- -- commented out as we want all trains to bounce here
+ -- 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
diff --git a/durt/nodes/(1710,17,4637).lua b/durt/nodes/(1710,17,4637).lua
index 7489acc..69bc3a1 100644
--- a/durt/nodes/(1710,17,4637).lua
+++ b/durt/nodes/(1710,17,4637).lua
@@ -1 +1,17 @@
--- \ No newline at end of file
+-- MCR Arrivals track
+local rc = "MCR_runaround"
+local list = {
+ rc,
+ "MCR_HS_W",
+ "MCR_HS_E",
+ "MCR_HS_E_AC"
+}
+if not F.has_rc(rc) then
+ split_off_locomotive("A0B0")
+ F.add_rc(list)
+ set_route(POS(1706,18,4638), "Headshunt")
+ atc_send("A1S3")
+ return
+end
+F.remove_rc(list)
+atc_send("A0S0WD5RS2") \ No newline at end of file
diff --git a/durt/nodes/(1740,17,4636).lua b/durt/nodes/(1740,17,4636).lua
new file mode 100644
index 0000000..9cfec9d
--- /dev/null
+++ b/durt/nodes/(1740,17,4636).lua
@@ -0,0 +1,15 @@
+if event.train then
+ if not atc_arrow then return end
+ local fc = split_at_fc("A0B0", 5)
+ local cmd = {
+ "MCR_HS_E",
+ "MCR_HS_E_AC",
+ "MCR_DIR_"..fc
+ }
+ if #section_occupancy("115343") == 1 then
+ table.insert(cmd, "MCR_LAST_SORT")
+ end
+ F.add_rc(cmd)
+ atc_send("A1S3")
+ return
+end \ No newline at end of file
diff --git a/durt/nodes/(1704,17,4658).lua b/durt/nodes/(1742,17,4642).lua
index 7489acc..7489acc 100644
--- a/durt/nodes/(1704,17,4658).lua
+++ b/durt/nodes/(1742,17,4642).lua
diff --git a/durt/nodes/(1742,17,4652).lua b/durt/nodes/(1742,17,4652).lua
new file mode 100644
index 0000000..7489acc
--- /dev/null
+++ b/durt/nodes/(1742,17,4652).lua
@@ -0,0 +1 @@
+-- \ No newline at end of file