aboutsummaryrefslogtreecommitdiff
path: root/advtrains/advtrains
diff options
context:
space:
mode:
Diffstat (limited to 'advtrains/advtrains')
-rw-r--r--advtrains/advtrains/damage.lua4
-rw-r--r--advtrains/advtrains/wagons.lua10
2 files changed, 12 insertions, 2 deletions
diff --git a/advtrains/advtrains/damage.lua b/advtrains/advtrains/damage.lua
index b39fe67..e05d00d 100644
--- a/advtrains/advtrains/damage.lua
+++ b/advtrains/advtrains/damage.lua
@@ -15,7 +15,9 @@ minetest.register_globalstep(function(dtime)
if le and le.is_wagon and le.initialized and le:train() then
if (not advtrains.player_to_train_mapping[player:get_player_name()] or le.train_id~=advtrains.player_to_train_mapping[player:get_player_name()]) and math.abs(le:train().velocity)>2 then
--player:punch(object, 1000, {damage={fleshy=3*math.abs(le:train().velocity)}})
- player:set_hp(player:get_hp()-math.abs(le:train().velocity)-3)
+ player:set_hp(player:get_hp()-math.abs(le:train().velocity)-3)
+ elseif (not advtrains.player_to_train_mapping[player:get_player_name()] or le.train_id~=advtrains.player_to_train_mapping[player:get_player_name()]) and le:train().door_open~=0 then
+ le:on_rightclick(player)
end
end
end
diff --git a/advtrains/advtrains/wagons.lua b/advtrains/advtrains/wagons.lua
index 9d63ab5..163dc73 100644
--- a/advtrains/advtrains/wagons.lua
+++ b/advtrains/advtrains/wagons.lua
@@ -257,6 +257,14 @@ function wagon:on_step(dtime)
advtrains.update_driver_hud(driver:get_player_name(), self:train(), self.wagon_flipped)
end
end
+ else
+ local pass = self.seatp[seatno] and minetest.get_player_by_name(self.seatp[seatno])
+ if pass and self:train().door_open~=0 then
+ local pc=pass:get_player_control()
+ if pc.up or pc.down then
+ self:get_off(seatno)
+ end
+ end
end
end
@@ -744,7 +752,7 @@ function advtrains.register_wagon(sysname, prototype, desc, inv_img)
return
end
-
+
local node=minetest.get_node_or_nil(pointed_thing.under)
if not node then atprint("[advtrains]Ignore at placer position") return itemstack end
local nodename=node.name