summaryrefslogtreecommitdiff
path: root/item_transport.lua
diff options
context:
space:
mode:
authorVanessaE <vanessaezekowitz@gmail.com>2013-01-19 08:44:26 -0800
committerVanessaE <vanessaezekowitz@gmail.com>2013-01-19 08:44:26 -0800
commitf8eb154f7ab446dc30080868b8c5971949cac4d0 (patch)
tree9fa421bf6727d7589e1d50512d5bafd9bed20d7e /item_transport.lua
parent6202e82163bad1bf0160505bc384396133d9611f (diff)
parenta77095ebe6e11ceab88d8b6c8a68a9b6c4440d3f (diff)
Merge pull request #8 from Novatux/master
Teleporter and accelerator tubes, crafting recipe for detector pipe, autocrafter
Diffstat (limited to 'item_transport.lua')
-rw-r--r--item_transport.lua54
1 files changed, 36 insertions, 18 deletions
diff --git a/item_transport.lua b/item_transport.lua
index db057aa..bed8f31 100644
--- a/item_transport.lua
+++ b/item_transport.lua
@@ -153,10 +153,13 @@ minetest.register_entity("pipeworks:tubed_item", {
end,
get_staticdata = function(self)
-
+ if self.start_pos==nil then return end
+ local velocity=self.object:getvelocity()
+ --self.object:setvelocity({x=0,y=0,z=0})
+ self.object:setpos(self.start_pos)
return minetest.serialize({
itemstring=self.itemstring,
- velocity=self.object:getvelocity(),
+ velocity=velocity,
start_pos=self.start_pos
})
end,
@@ -196,31 +199,35 @@ minetest.register_entity("pipeworks:tubed_item", {
local velocitycopy={x=velocity.x,y=velocity.y,z=velocity.z}
local moved=false
+ local speed=math.abs(velocity.x+velocity.y+velocity.z)
+ local vel={x=velocity.x/speed,y=velocity.y/speed,z=velocity.z/speed}
- if math.abs(velocity.x)==1 then
+ if math.abs(vel.x)==1 then
local next_node=math.abs(pos.x-self.start_pos.x)
if next_node >= 1 then
- self.start_pos.x=self.start_pos.x+velocity.x
+ self.start_pos.x=self.start_pos.x+vel.x
moved=true
end
- elseif math.abs(velocity.y)==1 then
+ elseif math.abs(vel.y)==1 then
local next_node=math.abs(pos.y-self.start_pos.y)
if next_node >= 1 then
- self.start_pos.y=self.start_pos.y+velocity.y
+ self.start_pos.y=self.start_pos.y+vel.y
moved=true
end
- elseif math.abs(velocity.z)==1 then
+ elseif math.abs(vel.z)==1 then
local next_node=math.abs(pos.z-self.start_pos.z)
if next_node >= 1 then
- self.start_pos.z=self.start_pos.z+velocity.z
+ self.start_pos.z=self.start_pos.z+vel.z
moved=true
end
end
+ local sposcopy={x=self.start_pos.x,y=self.start_pos.y,z=self.start_pos.z}
+
node = minetest.env:get_node(self.start_pos)
if moved and minetest.get_item_group(node.name,"tubedevice_receiver")==1 then
if minetest.registered_nodes[node.name].tube and minetest.registered_nodes[node.name].tube.insert_object then
- leftover = minetest.registered_nodes[node.name].tube.insert_object(self.start_pos,node,stack,velocity)
+ leftover = minetest.registered_nodes[node.name].tube.insert_object(self.start_pos,node,stack,vel)
else
leftover = stack
end
@@ -249,7 +256,8 @@ minetest.register_entity("pipeworks:tubed_item", {
end
end
- if velocity.x~=velocitycopy.x or velocity.y~=velocitycopy.y or velocity.z~=velocitycopy.z then
+ if velocity.x~=velocitycopy.x or velocity.y~=velocitycopy.y or velocity.z~=velocitycopy.z or
+ self.start_pos.x~=sposcopy.x or self.start_pos.y~=sposcopy.y or self.start_pos.z~=sposcopy.z then
self.object:setpos(self.start_pos)
self.object:setvelocity(velocity)
end
@@ -278,13 +286,23 @@ function go_next(pos,velocity,stack)
local len=1
local n
local can_go
+ local speed=math.abs(velocity.x+velocity.y+velocity.z)
+ local vel={x=velocity.x/speed,y=velocity.y/speed,z=velocity.z/speed,speed=speed}
+ if speed>=4.1 then
+ speed=4
+ elseif speed>=1.1 then
+ speed=speed-0.1
+ else
+ speed=1
+ end
+ vel.speed=speed
if minetest.registered_nodes[cnode.name].tube and minetest.registered_nodes[cnode.name].tube.can_go then
- can_go=minetest.registered_nodes[cnode.name].tube.can_go(pos,node,velocity,stack)
+ can_go=minetest.registered_nodes[cnode.name].tube.can_go(pos,node,vel,stack)
else
can_go=adjlist
end
for _,vect in ipairs(can_go) do
- if vect.x~=-velocity.x or vect.y~=-velocity.y or vect.z~=-velocity.z then
+ if vect.x~=-vel.x or vect.y~=-vel.y or vect.z~=-vel.z then
npos=addVect(pos,vect)
node=minetest.env:get_node(npos)
tube_receiver=minetest.get_item_group(node.name,"tubedevice_receiver")
@@ -334,9 +352,9 @@ function go_next(pos,velocity,stack)
end
until false
meta:set_int("tubedir",n)
- velocity.x=tubes[n].vect.x
- velocity.y=tubes[n].vect.y
- velocity.z=tubes[n].vect.z
+ velocity.x=tubes[n].vect.x*vel.speed
+ velocity.y=tubes[n].vect.y*vel.speed
+ velocity.z=tubes[n].vect.z*vel.speed
end
else
local i=1
@@ -352,9 +370,9 @@ function go_next(pos,velocity,stack)
break
end
until false
- velocity.x=chests[n].vect.x
- velocity.y=chests[n].vect.y
- velocity.z=chests[n].vect.z
+ velocity.x=chests[n].vect.x*speed
+ velocity.y=chests[n].vect.y*speed
+ velocity.z=chests[n].vect.z*speed
end
return 1
end \ No newline at end of file