diff options
author | orwell96 <orwell@bleipb.de> | 2017-12-18 23:44:01 +0100 |
---|---|---|
committer | orwell96 <orwell@bleipb.de> | 2017-12-18 23:44:01 +0100 |
commit | e3b70469687116437e90aedf0b0be61cf4a8dc3e (patch) | |
tree | bf631aff79a4c3710ef20a13ac11abec7c2ab756 | |
parent | 8a51a10a61626c2190b32f06a52dbe20cdf1d04c (diff) |
Remove path invalidation statement.
Caused problems on multiple detector rails in a row, because paths got cleared in-between a train step
Also optimize some code
-rw-r--r-- | advtrains/nodedb.lua | 3 | ||||
-rw-r--r-- | advtrains/trainlogic.lua | 2 | ||||
-rw-r--r-- | advtrains/wagons.lua | 7 |
3 files changed, 4 insertions, 8 deletions
diff --git a/advtrains/nodedb.lua b/advtrains/nodedb.lua index a4fbf0a..ab49192 100644 --- a/advtrains/nodedb.lua +++ b/advtrains/nodedb.lua @@ -135,9 +135,6 @@ end function ndb.swap_node(pos, node, no_inval) minetest.swap_node(pos, node) ndb.update(pos, node) - if not no_inval then - advtrains.invalidate_all_paths(pos) - end end function ndb.update(pos, pnode) diff --git a/advtrains/trainlogic.lua b/advtrains/trainlogic.lua index d98c9e8..a72d246 100644 --- a/advtrains/trainlogic.lua +++ b/advtrains/trainlogic.lua @@ -433,7 +433,7 @@ function advtrains.train_step_b(id, train, dtime) --hacky fix: if train_step_a returned in phase 2, end_index may not be set. --just return - if not train.end_index then + if not train.index or not train.end_index then return end diff --git a/advtrains/wagons.lua b/advtrains/wagons.lua index 415665e..b75ca50 100644 --- a/advtrains/wagons.lua +++ b/advtrains/wagons.lua @@ -301,10 +301,10 @@ function wagon:on_step(dtime) --check infotext
local outside=self:train().text_outside or ""
- local train = self:train()
+ local gp=self:train()
--show off-track information in outside text instead of notifying the whole server about this
- local front_off_track=train.max_index_on_track and train.index and train.index>train.max_index_on_track
- local back_off_track=train.min_index_on_track and train.end_index and train.end_index<train.min_index_on_track
+ local front_off_track=gp.max_index_on_track and gp.index and gp.index>gp.max_index_on_track
+ local back_off_track=gp.min_index_on_track and gp.end_index and gp.end_index<gp.min_index_on_track
if front_off_track or back_off_track then
outside = outside .."\n!!! Train off track !!!"
end
@@ -314,7 +314,6 @@ function wagon:on_step(dtime) self.infotext_cache=outside
end
- local gp=self:train()
local fct=self.wagon_flipped and -1 or 1
--set line number
if self.name == "advtrains:subway_wagon" and gp.line and gp.line~=self.line_cache then
|