summaryrefslogtreecommitdiff
path: root/durt
diff options
context:
space:
mode:
Diffstat (limited to 'durt')
-rw-r--r--durt/nodes/(-1511,11,-2590).lua67
1 files changed, 67 insertions, 0 deletions
diff --git a/durt/nodes/(-1511,11,-2590).lua b/durt/nodes/(-1511,11,-2590).lua
new file mode 100644
index 0000000..9c41623
--- /dev/null
+++ b/durt/nodes/(-1511,11,-2590).lua
@@ -0,0 +1,67 @@
+__approach_callback_mode = 1
+
+if event.approach and not event.has_entered then
+ atc_set_ars_disable(true)
+ atc_set_lzb_tsr(1)
+end
+
+if event.train and atc_arrow then
+ if S.yards.S27.shunt_type == true then
+
+ --split and run around properly. player is present to supervise autocouple
+ local info = {
+ ['rc'] = get_rc() or " ",
+ ['ln'] = get_line() or " ",
+ ['it'] = atc_get_text_inside() or " ",
+ ['ot'] = atc_get_text_outside() or " "
+ }
+ print("Local Info:")
+ print(info)
+ print("===========")
+ if info.rc ~= "S27_HEADSHUNT S27_AROUND" then
+ S.yards.S27['info'] = info
+ print("info.rc false --> S.yards.S27: ")
+ print(S.yards.S27)
+ print("===========")
+ split_at_index(2,"BBWR")
+ set_rc("S27_HEADSHUNT S27_AROUND")
+ set_autocouple()
+ else
+ info = S.yards.S27['info']
+ print("info.rc true --> S.yards.S27: ")
+ print(S.yards.S27)
+ print("===========")
+ set_rc(info.rc)
+ set_line(info.ln)
+ atc_set_text_inside(info.it)
+ atc_set_text_outside(info.ot)
+
+ atc_send("BBWD3RD1SM")
+ end
+ atc_set_ars_disable(false)
+ return
+ elseif S.yards.S27.shunt_type == false then
+ --reverse around loop. player not present to supervise autocouple operation
+ local rc = get_rc() or ""
+
+ local action = 0
+ local rc_list = {}
+ for token in rc:gmatch("[^%s]+") do
+ if token=="S27_LOOP" then
+ action = 1
+ else
+ table.insert(rc_list,token)
+ end
+ end
+
+ if action == 0 then
+ rc = rc.." S27_LOOP"
+ else
+ rc = table.concat(rc_list," ").." S27_EXIT"
+ end
+ set_rc(rc)
+ atc_set_ars_disable(false)
+ atc_send("B0WRD1S3")
+ return
+ end
+end \ No newline at end of file