summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--jeija/init.lua269
-rw-r--r--jeija/pistons.lua266
2 files changed, 267 insertions, 268 deletions
diff --git a/jeija/init.lua b/jeija/init.lua
index 1c97bf6..f766e1d 100644
--- a/jeija/init.lua
+++ b/jeija/init.lua
@@ -744,274 +744,6 @@ minetest.register_craft({
}
})
-
---PISTONS
---registration normal one:
-minetest.register_node("jeija:piston_normal", {
- tile_images = {"jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_side.png"},
- material = minetest.digprop_stonelike(0.5),
- paramtype2="facedir",
-})
-
-minetest.register_craft({
- output = '"jeija:piston_normal" 2',
- recipe = {
- {"default:wood", "default:wood", "default:wood"},
- {"default:cobble", "default:steel_ingot", "default:cobble"},
- {"default:cobble", "jeija:mesecon_off", "default:cobble"},
- }
-})
-
---registration sticky one:
-minetest.register_node("jeija:piston_sticky", {
- tile_images = {"jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_sticky_side.png"},
- material = minetest.digprop_stonelike(0.5),
- paramtype2="facedir",
-})
-
-minetest.register_craft({
- output = '"jeija:piston_sticky" 1',
- recipe = {
- {'"jeija:glue"'},
- {'"jeija:piston_normal"'},
- }
-})
-
--- get push direction normal
-function mesecon:piston_get_direction(pos)
- local direction = {x=0, y=0, z=0}
- if OLD_PISTON_DIRECTION==1 then
- getactivated=0
- local lpos={x=pos.x, y=pos.y, z=pos.z}
- local getactivated=0
- local rules=mesecon:get_rules("piston")
-
- getactivated=getactivated+mesecon:is_power_on(pos, rules[1].x, rules[1].y, rules[1].z)
- if getactivated>0 then direction.y=-1 return direction end
- getactivated=getactivated+mesecon:is_power_on(pos, rules[2].x, rules[2].y, rules[2].z)
- if getactivated>0 then direction.y=1 return direction end
- for k=3, 5 do
- getactivated=getactivated+mesecon:is_power_on(pos, rules[k].x, rules[k].y, rules[k].z)
- end
- if getactivated>0 then direction.z=1 return direction end
-
- for n=6, 8 do
- getactivated=getactivated+mesecon:is_power_on(pos, rules[n].x, rules[n].y, rules[n].z)
- end
-
- if getactivated>0 then direction.z=-1 return direction end
-
- for j=9, 11 do
- getactivated=getactivated+mesecon:is_power_on(pos, rules[j].x, rules[j].y, rules[j].z)
- end
-
- if getactivated>0 then direction.x=-1 return direction end
-
- for l=12, 14 do
- getactivated=getactivated+mesecon:is_power_on(pos, rules[l].x, rules[l].y, rules[l].z)
- end
- if getactivated>0 then direction.x=1 return direction end
- else
- local node=minetest.env:get_node(pos)
- if node.param2==3 then
- return {x=1, y=0, z=0}
- end
- if node.param2==2 then
- return {x=0, y=0, z=1}
- end
- if node.param2==1 then
- return {x=-1, y=0, z=0}
- end
- if node.param2==0 then
- return {x=0, y=0, z=-1}
- end
- end
- return direction
-end
-
--- get pull/push direction sticky
-function mesecon:sticky_piston_get_direction(pos)
- if OLD_PISTON_DIRECTION==1 then
- getactivated=0
- local direction = {x=0, y=0, z=0}
- local lpos={x=pos.x, y=pos.y, z=pos.z}
- local getactivated=0
- local rules=mesecon:get_rules("piston")
-
- getactivated=getactivated+mesecon:is_power_off(pos, rules[1].x, rules[1].y, rules[1].z)
- if getactivated>0 then direction.y=-1 return direction end
- getactivated=getactivated+mesecon:is_power_off(pos, rules[2].x, rules[2].y, rules[2].z)
- if getactivated>0 then direction.y=1 return direction end
-
- for k=3, 5 do
- getactivated=getactivated+mesecon:is_power_off(pos, rules[k].x, rules[k].y, rules[k].z)
- end
- if getactivated>0 then direction.z=1 return direction end
-
- for n=6, 8 do
- getactivated=getactivated+mesecon:is_power_off(pos, rules[n].x, rules[n].y, rules[n].z)
- end
-
- if getactivated>0 then direction.z=-1 return direction end
-
- for j=9, 11 do
- getactivated=getactivated+mesecon:is_power_off(pos, rules[j].x, rules[j].y, rules[j].z)
- end
-
- if getactivated>0 then direction.x=-1 return direction end
-
- for l=12, 14 do
- getactivated=getactivated+mesecon:is_power_off(pos, rules[l].x, rules[l].y, rules[l].z)
- end
- if getactivated>0 then direction.x=1 return direction end
- else
- local node=minetest.env:get_node(pos)
- if node.param2==3 then
- return {x=1, y=0, z=0}
- end
- if node.param2==2 then
- return {x=0, y=0, z=1}
- end
- if node.param2==1 then
- return {x=-1, y=0, z=0}
- end
- if node.param2==0 then
- return {x=0, y=0, z=-1}
- end
- end
- return direction
-end
-
--- Push action
-mesecon:register_on_signal_on(function (pos, node)
- if (node.name=="jeija:piston_normal" or node.name=="jeija:piston_sticky") then
- local direction=mesecon:piston_get_direction(pos)
-
- local checknode={}
- local checkpos={x=pos.x, y=pos.y, z=pos.z}
- repeat -- Check if it collides with a stopper
- checkpos={x=checkpos.x+direction.x, y=checkpos.y+direction.y, z=checkpos.z+direction.z}
- checknode=minetest.env:get_node(checkpos)
- if mesecon:is_mvps_stopper(checknode.name) then
- return
- end
- until checknode.name=="air"
- or checknode.name=="ignore"
- or checknode.name=="default:water"
- or checknode.name=="default:water_flowing"
-
- local obj={}
- if node.name=="jeija:piston_normal" then
- obj=minetest.env:add_entity(pos, "jeija:piston_pusher_normal")
- elseif node.name=="jeija:piston_sticky" then
- obj=minetest.env:add_entity(pos, "jeija:piston_pusher_sticky")
- end
-
- if ENABLE_PISTON_ANIMATION==1 then
- obj:setvelocity({x=direction.x*4, y=direction.y*4, z=direction.z*4})
- else
- obj:moveto({x=pos.x+direction.x, y=pos.y+direction.y, z=pos.z+direction.z}, false)
- end
-
- local np = {x=pos.x+direction.x, y=pos.y+direction.y, z=pos.z+direction.z}
- local coln = minetest.env:get_node(np)
-
- or checknode.name=="ignore"
- or checknode.name=="default:water"
- or checknode.name=="default:water_flowing"
-
- if coln.name ~= "air" and coln.name ~="water" then
- local thisp= {x=np.x, y=np.y, z=np.z}
- local thisnode=minetest.env:get_node(thisp)
- local nextnode={}
- minetest.env:remove_node(thisp)
- repeat
- thisp.x=thisp.x+direction.x
- thisp.y=thisp.y+direction.y
- thisp.z=thisp.z+direction.z
- nextnode=minetest.env:get_node(thisp)
- minetest.env:add_node(thisp, {name=thisnode.name})
- nodeupdate(thisp)
- thisnode=nextnode
- until thisnode.name=="air"
- or thisnode.name=="ignore"
- or thisnode.name=="default:water"
- or thisnode.name=="default:water_flowing"
- end
- end
-end)
-
---Pull action (sticky only)
-mesecon:register_on_signal_off(function (pos, node)
- if node.name=="jeija:piston_sticky" or node.name=="jeija:piston_normal" then
- local objs = minetest.env:get_objects_inside_radius(pos, 2)
- for k, obj in pairs(objs) do
- obj:remove()
- end
-
- if node.name=="jeija:piston_sticky" then
- local direction=mesecon:sticky_piston_get_direction(pos)
- local np = {x=pos.x+direction.x, y=pos.y+direction.y, z=pos.z+direction.z}
- local coln = minetest.env:get_node(np)
- if coln.name == "air" or coln.name =="water" then
- local thisp= {x=np.x+direction.x, y=np.y+direction.y, z=np.z+direction.z}
- local thisnode=minetest.env:get_node(thisp)
- if thisnode.name~="air" and thisnode.name~="water" and not mesecon:is_mvps_stopper(thisnode.name) then
- local newpos={}
- local oldpos={}
- minetest.env:add_node(np, {name=thisnode.name})
- minetest.env:remove_node(thisp)
- end
- end
- end
- end
-end)
-
---Piston Animation
-local PISTON_PUSHER_NORMAL={
- physical = false,
- visual = "sprite",
- textures = {"default_wood.png", "default_wood.png", "jeija_piston_pusher_normal.png", "jeija_piston_pusher_normal.png", "jeija_piston_pusher_normal.png", "jeija_piston_pusher_normal.png"},
- collisionbox = {-0.5,-0.5,-0.5, 0.5,0.5,0.5},
- visual = "cube",
- timer=0,
-}
-
-function PISTON_PUSHER_NORMAL:on_step(dtime)
- self.timer=self.timer+dtime
- if self.timer>=0.24 then
- self.object:setvelocity({x=0, y=0, z=0})
- end
-end
-
-local PISTON_PUSHER_STICKY={
- physical = false,
- visual = "sprite",
- textures = {"default_wood.png", "default_wood.png", "jeija_piston_pusher_sticky.png", "jeija_piston_pusher_sticky.png", "jeija_piston_pusher_sticky.png", "jeija_piston_pusher_sticky.png"},
- collisionbox = {-0.5,-0.5,-0.5, 0.5,0.5,0.5},
- visual = "cube",
- timer=0,
-}
-
-function PISTON_PUSHER_STICKY:on_step(dtime)
- self.timer=self.timer+dtime
- if self.timer>=0.24 then
- self.object:setvelocity({x=0, y=0, z=0})
- end
-end
-
-minetest.register_entity("jeija:piston_pusher_normal", PISTON_PUSHER_NORMAL)
-minetest.register_entity("jeija:piston_pusher_sticky", PISTON_PUSHER_STICKY)
-
-minetest.register_on_dignode(function(pos, node)
- if node.name=="jeija:piston_normal" or node.name=="jeija:piston_sticky" then
- local objs = minetest.env:get_objects_inside_radius(pos, 2)
- for k, obj in pairs(objs) do
- obj:remove()
- end
- end
-end)
-
--GLUE
minetest.register_craftitem("jeija:glue", {
image = "jeija_glue.png",
@@ -1126,6 +858,7 @@ dofile(minetest.get_modpath("jeija").."/pressureplates.lua")
dofile(minetest.get_modpath("jeija").."/wireless.lua")
dofile(minetest.get_modpath("jeija").."/alias.lua")
dofile(minetest.get_modpath("jeija").."/switch.lua")
+dofile(minetest.get_modpath("jeija").."/pistons.lua")
--TEMPEREST's STUFF
if ENABLE_TEMPEREST==1 then
dofile(minetest.get_modpath("jeija").."temperest.lua")
diff --git a/jeija/pistons.lua b/jeija/pistons.lua
new file mode 100644
index 0000000..f287503
--- /dev/null
+++ b/jeija/pistons.lua
@@ -0,0 +1,266 @@
+--PISTONS
+--registration normal one:
+minetest.register_node("jeija:piston_normal", {
+ tile_images = {"jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_side.png"},
+ material = minetest.digprop_stonelike(0.5),
+ paramtype2="facedir",
+})
+
+minetest.register_craft({
+ output = '"jeija:piston_normal" 2',
+ recipe = {
+ {"default:wood", "default:wood", "default:wood"},
+ {"default:cobble", "default:steel_ingot", "default:cobble"},
+ {"default:cobble", "jeija:mesecon_off", "default:cobble"},
+ }
+})
+
+--registration sticky one:
+minetest.register_node("jeija:piston_sticky", {
+ tile_images = {"jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_sticky_side.png"},
+ material = minetest.digprop_stonelike(0.5),
+ paramtype2="facedir",
+})
+
+minetest.register_craft({
+ output = '"jeija:piston_sticky" 1',
+ recipe = {
+ {'"jeija:glue"'},
+ {'"jeija:piston_normal"'},
+ }
+})
+
+-- get push direction normal
+function mesecon:piston_get_direction(pos)
+ local direction = {x=0, y=0, z=0}
+ if OLD_PISTON_DIRECTION==1 then
+ getactivated=0
+ local lpos={x=pos.x, y=pos.y, z=pos.z}
+ local getactivated=0
+ local rules=mesecon:get_rules("piston")
+
+ getactivated=getactivated+mesecon:is_power_on(pos, rules[1].x, rules[1].y, rules[1].z)
+ if getactivated>0 then direction.y=-1 return direction end
+ getactivated=getactivated+mesecon:is_power_on(pos, rules[2].x, rules[2].y, rules[2].z)
+ if getactivated>0 then direction.y=1 return direction end
+ for k=3, 5 do
+ getactivated=getactivated+mesecon:is_power_on(pos, rules[k].x, rules[k].y, rules[k].z)
+ end
+ if getactivated>0 then direction.z=1 return direction end
+
+ for n=6, 8 do
+ getactivated=getactivated+mesecon:is_power_on(pos, rules[n].x, rules[n].y, rules[n].z)
+ end
+
+ if getactivated>0 then direction.z=-1 return direction end
+
+ for j=9, 11 do
+ getactivated=getactivated+mesecon:is_power_on(pos, rules[j].x, rules[j].y, rules[j].z)
+ end
+
+ if getactivated>0 then direction.x=-1 return direction end
+
+ for l=12, 14 do
+ getactivated=getactivated+mesecon:is_power_on(pos, rules[l].x, rules[l].y, rules[l].z)
+ end
+ if getactivated>0 then direction.x=1 return direction end
+ else
+ local node=minetest.env:get_node(pos)
+ if node.param2==3 then
+ return {x=1, y=0, z=0}
+ end
+ if node.param2==2 then
+ return {x=0, y=0, z=1}
+ end
+ if node.param2==1 then
+ return {x=-1, y=0, z=0}
+ end
+ if node.param2==0 then
+ return {x=0, y=0, z=-1}
+ end
+ end
+ return direction
+end
+
+-- get pull/push direction sticky
+function mesecon:sticky_piston_get_direction(pos)
+ if OLD_PISTON_DIRECTION==1 then
+ getactivated=0
+ local direction = {x=0, y=0, z=0}
+ local lpos={x=pos.x, y=pos.y, z=pos.z}
+ local getactivated=0
+ local rules=mesecon:get_rules("piston")
+
+ getactivated=getactivated+mesecon:is_power_off(pos, rules[1].x, rules[1].y, rules[1].z)
+ if getactivated>0 then direction.y=-1 return direction end
+ getactivated=getactivated+mesecon:is_power_off(pos, rules[2].x, rules[2].y, rules[2].z)
+ if getactivated>0 then direction.y=1 return direction end
+
+ for k=3, 5 do
+ getactivated=getactivated+mesecon:is_power_off(pos, rules[k].x, rules[k].y, rules[k].z)
+ end
+ if getactivated>0 then direction.z=1 return direction end
+
+ for n=6, 8 do
+ getactivated=getactivated+mesecon:is_power_off(pos, rules[n].x, rules[n].y, rules[n].z)
+ end
+
+ if getactivated>0 then direction.z=-1 return direction end
+
+ for j=9, 11 do
+ getactivated=getactivated+mesecon:is_power_off(pos, rules[j].x, rules[j].y, rules[j].z)
+ end
+
+ if getactivated>0 then direction.x=-1 return direction end
+
+ for l=12, 14 do
+ getactivated=getactivated+mesecon:is_power_off(pos, rules[l].x, rules[l].y, rules[l].z)
+ end
+ if getactivated>0 then direction.x=1 return direction end
+ else
+ local node=minetest.env:get_node(pos)
+ if node.param2==3 then
+ return {x=1, y=0, z=0}
+ end
+ if node.param2==2 then
+ return {x=0, y=0, z=1}
+ end
+ if node.param2==1 then
+ return {x=-1, y=0, z=0}
+ end
+ if node.param2==0 then
+ return {x=0, y=0, z=-1}
+ end
+ end
+ return direction
+end
+
+-- Push action
+mesecon:register_on_signal_on(function (pos, node)
+ if (node.name=="jeija:piston_normal" or node.name=="jeija:piston_sticky") then
+ local direction=mesecon:piston_get_direction(pos)
+
+ local checknode={}
+ local checkpos={x=pos.x, y=pos.y, z=pos.z}
+ repeat -- Check if it collides with a stopper
+ checkpos={x=checkpos.x+direction.x, y=checkpos.y+direction.y, z=checkpos.z+direction.z}
+ checknode=minetest.env:get_node(checkpos)
+ if mesecon:is_mvps_stopper(checknode.name) then
+ return
+ end
+ until checknode.name=="air"
+ or checknode.name=="ignore"
+ or checknode.name=="default:water"
+ or checknode.name=="default:water_flowing"
+
+ local obj={}
+ if node.name=="jeija:piston_normal" then
+ obj=minetest.env:add_entity(pos, "jeija:piston_pusher_normal")
+ elseif node.name=="jeija:piston_sticky" then
+ obj=minetest.env:add_entity(pos, "jeija:piston_pusher_sticky")
+ end
+
+ if ENABLE_PISTON_ANIMATION==1 then
+ obj:setvelocity({x=direction.x*4, y=direction.y*4, z=direction.z*4})
+ else
+ obj:moveto({x=pos.x+direction.x, y=pos.y+direction.y, z=pos.z+direction.z}, false)
+ end
+
+ local np = {x=pos.x+direction.x, y=pos.y+direction.y, z=pos.z+direction.z}
+ local coln = minetest.env:get_node(np)
+
+ or checknode.name=="ignore"
+ or checknode.name=="default:water"
+ or checknode.name=="default:water_flowing"
+
+ if coln.name ~= "air" and coln.name ~="water" then
+ local thisp= {x=np.x, y=np.y, z=np.z}
+ local thisnode=minetest.env:get_node(thisp)
+ local nextnode={}
+ minetest.env:remove_node(thisp)
+ repeat
+ thisp.x=thisp.x+direction.x
+ thisp.y=thisp.y+direction.y
+ thisp.z=thisp.z+direction.z
+ nextnode=minetest.env:get_node(thisp)
+ minetest.env:add_node(thisp, {name=thisnode.name})
+ nodeupdate(thisp)
+ thisnode=nextnode
+ until thisnode.name=="air"
+ or thisnode.name=="ignore"
+ or thisnode.name=="default:water"
+ or thisnode.name=="default:water_flowing"
+ end
+ end
+end)
+
+--Pull action (sticky only)
+mesecon:register_on_signal_off(function (pos, node)
+ if node.name=="jeija:piston_sticky" or node.name=="jeija:piston_normal" then
+ local objs = minetest.env:get_objects_inside_radius(pos, 2)
+ for k, obj in pairs(objs) do
+ obj:remove()
+ end
+
+ if node.name=="jeija:piston_sticky" then
+ local direction=mesecon:sticky_piston_get_direction(pos)
+ local np = {x=pos.x+direction.x, y=pos.y+direction.y, z=pos.z+direction.z}
+ local coln = minetest.env:get_node(np)
+ if coln.name == "air" or coln.name =="water" then
+ local thisp= {x=np.x+direction.x, y=np.y+direction.y, z=np.z+direction.z}
+ local thisnode=minetest.env:get_node(thisp)
+ if thisnode.name~="air" and thisnode.name~="water" and not mesecon:is_mvps_stopper(thisnode.name) then
+ local newpos={}
+ local oldpos={}
+ minetest.env:add_node(np, {name=thisnode.name})
+ minetest.env:remove_node(thisp)
+ end
+ end
+ end
+ end
+end)
+
+--Piston Animation
+local PISTON_PUSHER_NORMAL={
+ physical = false,
+ visual = "sprite",
+ textures = {"default_wood.png", "default_wood.png", "jeija_piston_pusher_normal.png", "jeija_piston_pusher_normal.png", "jeija_piston_pusher_normal.png", "jeija_piston_pusher_normal.png"},
+ collisionbox = {-0.5,-0.5,-0.5, 0.5,0.5,0.5},
+ visual = "cube",
+ timer=0,
+}
+
+function PISTON_PUSHER_NORMAL:on_step(dtime)
+ self.timer=self.timer+dtime
+ if self.timer>=0.24 then
+ self.object:setvelocity({x=0, y=0, z=0})
+ end
+end
+
+local PISTON_PUSHER_STICKY={
+ physical = false,
+ visual = "sprite",
+ textures = {"default_wood.png", "default_wood.png", "jeija_piston_pusher_sticky.png", "jeija_piston_pusher_sticky.png", "jeija_piston_pusher_sticky.png", "jeija_piston_pusher_sticky.png"},
+ collisionbox = {-0.5,-0.5,-0.5, 0.5,0.5,0.5},
+ visual = "cube",
+ timer=0,
+}
+
+function PISTON_PUSHER_STICKY:on_step(dtime)
+ self.timer=self.timer+dtime
+ if self.timer>=0.24 then
+ self.object:setvelocity({x=0, y=0, z=0})
+ end
+end
+
+minetest.register_entity("jeija:piston_pusher_normal", PISTON_PUSHER_NORMAL)
+minetest.register_entity("jeija:piston_pusher_sticky", PISTON_PUSHER_STICKY)
+
+minetest.register_on_dignode(function(pos, node)
+ if node.name=="jeija:piston_normal" or node.name=="jeija:piston_sticky" then
+ local objs = minetest.env:get_objects_inside_radius(pos, 2)
+ for k, obj in pairs(objs) do
+ obj:remove()
+ end
+ end
+end)