summaryrefslogtreecommitdiff
path: root/trainlogic.lua
diff options
context:
space:
mode:
authororwell96 <mono96.mml@gmail.com>2016-05-29 22:02:51 +0200
committerorwell96 <mono96.mml@gmail.com>2016-05-29 22:02:51 +0200
commitc71b0209270daa2df717c449c67507d9db0dc0a9 (patch)
tree730a9c1d91c082ae45c3887d45e4910134d3a93a /trainlogic.lua
parent6e34cb19559ccc99ea11ccec6fc20172fdda25e2 (diff)
fixed lua errors and code mistakes
Diffstat (limited to 'trainlogic.lua')
-rw-r--r--trainlogic.lua11
1 files changed, 7 insertions, 4 deletions
diff --git a/trainlogic.lua b/trainlogic.lua
index 87c5d33..785f6f8 100644
--- a/trainlogic.lua
+++ b/trainlogic.lua
@@ -18,6 +18,7 @@ end
advtrains.trains={}
+advtrains.wagon_save={}
--load initially
advtrains.fpath=minetest.get_worldpath().."/advtrains"
@@ -169,7 +170,7 @@ function advtrains.train_step(id, train, dtime)
end
--check for any trainpart entities if they have been unloaded. do this only if both front and end positions are loaded, to ensure train entities will be placed inside loaded area, and only every second.
- train.check_trainpartload=train.check_trainpartload-dtime
+ train.check_trainpartload=(train.check_trainpartload or 0)-dtime
if train.check_trainpartload<=0 and posfront and posback and minetest.get_node_or_nil(posfront) and minetest.get_node_or_nil(posback) then
--it is better to iterate luaentites only once
local found_uids={}
@@ -177,7 +178,7 @@ function advtrains.train_step(id, train, dtime)
if wagon.is_wagon and wagon.initialized and wagon.train_id==id then
if found_uids[wagon.unique_id] then
--duplicate found, delete it
- wagon.object and wagon.object:remove()
+ if wagon.object then wagon.object:remove() end
else
found_uids[wagon.unique_id]=true
end
@@ -189,13 +190,15 @@ function advtrains.train_step(id, train, dtime)
found_uids[w_id]=nil
elseif advtrains.wagon_save[w_id] then
--spawn a new and initialize it with the properties from wagon_save
- local le=minetest.env:add_entity(posfront, "advtrains:"..sysname):get_luaentity()
+ local le=minetest.env:add_entity(posfront, advtrains.wagon_save[w_id].name):get_luaentity()
for k,v in pairs(advtrains.wagon_save[w_id]) do
le[k]=v
end
+ advtrains.wagon_save[w_id].name=nil
+ advtrains.wagon_save[w_id].object=nil
else
--what the hell...
- local le=minetest.env:add_entity(posfront, "advtrains:"..sysname):get_luaentity()
+ local le=minetest.env:add_entity(posfront, advtrains.wagon_save[w_id].name):get_luaentity()
le.unique_id=w_id
le.train_id=id
le.pos_in_trainparts=pit