Add Jeija's piston modification, which allows pistons to remember their orientation.

This commit is contained in:
Jeija 2012-01-27 15:50:55 -05:00 committed by Anthony Zhang
parent cc43dbfebe
commit f56e8dffae
2 changed files with 120 additions and 94 deletions

13
jeija/alias.lua Normal file

@ -0,0 +1,13 @@
-- This file registers aliases for the /give /giveme commands.
minetest.register_alias("jeija:meselamp", "jeija:meselamp_off")
minetest.register_alias("jeija:mesecon", "jeija:mesecon_off")
minetest.register_alias("jeija:object_detector", "jeija:object_detector_off")
minetest.register_alias("jeija:wireless_inverter", "jeija:wireless_inverter_on")
minetest.register_alias("jeija:wireless_receiver", "jeija:wireless_receiver_off")
minetest.register_alias("jeija:wireless_transmitter", "jeija:wireless_transmitter_off")
minetest.register_alias("jeija:switch", "jeija:switch_off")
minetest.register_alias("jeija:piston", "jeija:piston_normal")
minetest.register_alias("jeija:blinky_plant", "jeija:blinky_plant_off")
minetest.register_alias("jeija:mesecon_torch", "jeija:mesecon_torch_on")
minetest.register_alias("jeija:hydro_turbine", "jeija:hydro_turbine_off")

@ -62,12 +62,12 @@
-- SETTINGS -- SETTINGS
ENABLE_TEMPEREST=0 ENABLE_TEMPEREST=0
ENABLE_PISTON_ANIMATION=1 ENABLE_PISTON_ANIMATION=0
BLINKY_PLANT_INTERVAL=3 BLINKY_PLANT_INTERVAL=3
OLD_PISTON_DIRECTION=0
-- PUBLIC VARIABLES -- PUBLIC VARIABLES
mesecon={} -- contains all functions and all global variables mesecon={} -- contains all functions and all global variables
mesecon.modpath = minetest.get_modpath("jeija")
mesecon.actions_on={} -- Saves registered function callbacks for mesecon on mesecon.actions_on={} -- Saves registered function callbacks for mesecon on
mesecon.actions_off={} -- Saves registered function callbacks for mesecon off mesecon.actions_off={} -- Saves registered function callbacks for mesecon off
mesecon.pwr_srcs={} -- this is public for now mesecon.pwr_srcs={} -- this is public for now
@ -102,14 +102,14 @@ minetest.register_node("jeija:mesecon_on", {
type = "fixed", type = "fixed",
}, },
material = minetest.digprop_constanttime(0.1), material = minetest.digprop_constanttime(0.1),
dug_item = 'node "jeija:mesecon_off" 1', drop = '"jeija:mesecon_off" 1',
light_source = LIGHT_MAX-11, light_source = LIGHT_MAX-11,
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:mesecon_off" 16', output = '"jeija:mesecon_off" 16',
recipe = { recipe = {
{'node "default:mese"'}, {'"default:mese"'},
} }
}) })
@ -552,11 +552,11 @@ minetest.register_node("jeija:power_plant", {
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:power_plant" 1', output = '"jeija:power_plant" 1',
recipe = { recipe = {
{'node "jeija:mesecon_off"'}, {'"jeija:mesecon_off"'},
{'node "jeija:mesecon_off"'}, {'"jeija:mesecon_off"'},
{'node "default:junglegrass"'}, {'"default:junglegrass"'},
} }
}) })
@ -597,16 +597,16 @@ minetest.register_node("jeija:blinky_plant_on", {
paramtype = "light", paramtype = "light",
walkable = false, walkable = false,
material = minetest.digprop_leaveslike(0.2), material = minetest.digprop_leaveslike(0.2),
dug_item='node "jeija:blinky_plant_off" 1', drop='"jeija:blinky_plant_off" 1',
light_source = LIGHT_MAX-7, light_source = LIGHT_MAX-7,
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:blinky_plant_off" 1', output = '"jeija:blinky_plant_off" 1',
recipe = { recipe = {
{'','node "jeija:mesecon_off"',''}, {'','"jeija:mesecon_off"',''},
{'','node "jeija:mesecon_off"',''}, {'','"jeija:mesecon_off"',''},
{'node "default:junglegrass"','node "default:junglegrass"','node "default:junglegrass"'}, {'"default:junglegrass"','"default:junglegrass"','"default:junglegrass"'},
} }
}) })
@ -669,18 +669,18 @@ minetest.register_node("jeija:solar_panel", {
}) })
minetest.register_craft({ minetest.register_craft({
output = 'craft "jeija:silicon" 4', output = '"jeija:silicon" 4',
recipe = { recipe = {
{'node "default:sand"', 'node "default:sand"'}, {'"default:sand"', '"default:sand"'},
{'node "default:sand"', 'craft "default:steel_ingot"'}, {'"default:sand"', '"default:steel_ingot"'},
} }
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:solar_panel" 1', output = '"jeija:solar_panel" 1',
recipe = { recipe = {
{'craft "jeija:silicon"', 'craft "jeija:silicon"'}, {'"jeija:silicon"', '"jeija:silicon"'},
{'craft "jeija:silicon"', 'craft "jeija:silicon"'}, {'"jeija:silicon"', '"jeija:silicon"'},
} }
}) })
@ -708,14 +708,16 @@ minetest.register_node("jeija:meselamp_on", {
paramtype = "light", paramtype = "light",
sunlight_propagates = true, sunlight_propagates = true,
walkable = false, walkable = false,
wall_mounted = false, legacy_wallmounted = true,
paramtype2 = "wallmounted",
light_source = LIGHT_MAX, light_source = LIGHT_MAX,
selection_box = { selection_box = {
type = "wallmounted",
type = "fixed", type = "fixed",
fixed = {-0.38, -0.5, -0.1, 0.38, -0.2, 0.1}, fixed = {-0.38, -0.5, -0.1, 0.38, -0.2, 0.1},
}, },
material = minetest.digprop_constanttime(0.1), material = minetest.digprop_constanttime(0.1),
dug_item='node "jeija:meselamp_off" 1', drop='"jeija:meselamp_off" 1',
}) })
minetest.register_node("jeija:meselamp_off", { minetest.register_node("jeija:meselamp_off", {
@ -734,11 +736,11 @@ minetest.register_node("jeija:meselamp_off", {
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:meselamp_off" 1', output = '"jeija:meselamp_off" 1',
recipe = { recipe = {
{'', 'node "default:glass"', ''}, {'', '"default:glass"', ''},
{'node "jeija:mesecon_off"', 'craft "default:steel_ingot"', 'node "jeija:mesecon_off"'}, {'"jeija:mesecon_off"', '"default:steel_ingot"', '"jeija:mesecon_off"'},
{'', 'node "default:glass"', ''}, {'', '"default:glass"', ''},
} }
}) })
@ -746,69 +748,84 @@ minetest.register_craft({
--PISTONS --PISTONS
--registration normal one: --registration normal one:
minetest.register_node("jeija:piston_normal", { minetest.register_node("jeija:piston_normal", {
tile_images = {"jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_side.png", "jeija_piston_side.png", "jeija_piston_side.png", "jeija_piston_side.png"}, 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"},
inventory_image = minetest.inventorycube("jeija_piston_tb.png", "jeija_piston_side.png", "jeija_piston_side.png"),
material = minetest.digprop_stonelike(0.5), material = minetest.digprop_stonelike(0.5),
paramtype2="facedir",
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:piston_normal" 2', output = '"jeija:piston_normal" 2',
recipe = { recipe = {
{'node "default:wood"', 'node "default:wood"', 'node "default:wood"'}, {'"default:wood"', '"default:wood"', '"default:wood"'},
{'node "default:cobble"', 'craft "default:steel_ingot"', 'node "default:cobble"'}, {'"default:cobble"', '"default:steel_ingot"', '"default:cobble"'},
{'node "default:cobble"', 'node "jeija:mesecon_off"', 'node "default:cobble"'}, {'"default:cobble"', '"jeija:mesecon_off"', '"default:cobble"'},
} }
}) })
--registration sticky one: --registration sticky one:
minetest.register_node("jeija:piston_sticky", { minetest.register_node("jeija:piston_sticky", {
tile_images = {"jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_sticky_side.png", "jeija_piston_sticky_side.png", "jeija_piston_sticky_side.png", "jeija_piston_sticky_side.png"}, tile_images = {"jeija_piston_tb.png", "jeija_piston_tb.png", "jeija_piston_sticky_side.png", "jeija_piston_sticky_side.png", "jeija_piston_sticky_side.png", "jeija_piston_sticky_side.png"},
inventory_image = minetest.inventorycube("jeija_piston_tb.png", "jeija_piston_sticky_side.png", "jeija_piston_sticky_side.png"),
material = minetest.digprop_stonelike(0.5), material = minetest.digprop_stonelike(0.5),
paramtype2="facedir",
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:piston_sticky" 1', output = '"jeija:piston_sticky" 1',
recipe = { recipe = {
{'craft "jeija:glue"'}, {'"jeija:glue"'},
{'node "jeija:piston_normal"'}, {'"jeija:piston_normal"'},
} }
}) })
-- get push direction normal -- get push direction normal
function mesecon:piston_get_direction(pos) function mesecon:piston_get_direction(pos)
getactivated=0
local direction = {x=0, y=0, z=0} local direction = {x=0, y=0, z=0}
local lpos={x=pos.x, y=pos.y, z=pos.z} if OLD_PISTON_DIRECTION==1 then
local getactivated=0 getactivated=0
local rules=mesecon:get_rules("piston") 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) 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 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) 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 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 k=3, 5 do for n=6, 8 do
getactivated=getactivated+mesecon:is_power_on(pos, rules[k].x, rules[k].y, rules[k].z) 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 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
return direction return direction
end end
@ -986,10 +1003,10 @@ minetest.register_craftitem("jeija:glue", {
}) })
minetest.register_craft({ minetest.register_craft({
output = 'craft "jeija:glue" 2', output = '"jeija:glue" 2',
recipe = { recipe = {
{'node "default:junglegrass"', 'node "default:junglegrass"'}, {'"default:junglegrass"', '"default:junglegrass"'},
{'node "default:junglegrass"', 'node "default:junglegrass"'}, {'"default:junglegrass"', '"default:junglegrass"'},
} }
}) })
@ -998,14 +1015,12 @@ minetest.register_craft({
minetest.register_node("jeija:hydro_turbine_off", { minetest.register_node("jeija:hydro_turbine_off", {
tile_images = {"jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png"}, tile_images = {"jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png"},
inventory_image = minetest.inventorycube("jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png", "jeija_hydro_turbine_off.png"),
material = minetest.digprop_constanttime(0.5), material = minetest.digprop_constanttime(0.5),
}) })
minetest.register_node("jeija:hydro_turbine_on", { minetest.register_node("jeija:hydro_turbine_on", {
tile_images = {"jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png"}, tile_images = {"jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png"},
inventory_image = minetest.inventorycube("jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png", "jeija_hydro_turbine_on.png"), drop = '"jeija:hydro_turbine_off" 1',
dug_item = 'node "jeija:hydro_turbine_off" 1',
material = minetest.digprop_constanttime(0.5), material = minetest.digprop_constanttime(0.5),
}) })
@ -1044,11 +1059,11 @@ mesecon:add_receptor_node("jeija:hydro_turbine_on")
mesecon:add_receptor_node_off("jeija:hydro_turbine_off") mesecon:add_receptor_node_off("jeija:hydro_turbine_off")
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:hydro_turbine_off" 2', output = '"jeija:hydro_turbine_off" 2',
recipe = { recipe = {
{'','craft "default:stick"', ''}, {'','"default:stick"', ''},
{'craft "default:stick"', 'craft "default:steel_ingot"', 'craft "default:stick"'}, {'"default:stick"', '"default:steel_ingot"', '"default:stick"'},
{'','craft "default:stick"', ''}, {'','"default:stick"', ''},
} }
}) })
@ -1057,17 +1072,15 @@ minetest.register_craft({
minetest.register_node("jeija:mesecon_switch_off", { minetest.register_node("jeija:mesecon_switch_off", {
tile_images = {"jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_off.png"}, tile_images = {"jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_off.png"},
inventory_image = minetest.inventorycube("jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_off.png"), paramtype2="facedir",
paramtype = "facedir_simple",
material = minetest.digprop_constanttime(0.5), material = minetest.digprop_constanttime(0.5),
}) })
minetest.register_node("jeija:mesecon_switch_on", { minetest.register_node("jeija:mesecon_switch_on", {
tile_images = {"jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_on.png"}, tile_images = {"jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_on.png"},
inventory_image = minetest.inventorycube("jeija_mesecon_switch_side.png", "jeija_mesecon_switch_side.png", "jeija_mesecon_switch_on.png"), paramtype2="facedir",
paramtype = "facedir_simple",
material = minetest.digprop_constanttime(0.5), material = minetest.digprop_constanttime(0.5),
dug_item='node "jeija:mesecon_switch_off" 1', drop='"jeija:mesecon_switch_off" 1',
}) })
mesecon:add_receptor_node("jeija:mesecon_switch_on") mesecon:add_receptor_node("jeija:mesecon_switch_on")
@ -1095,10 +1108,10 @@ minetest.register_on_dignode(
) )
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:mesecon_switch_off" 2', output = '"jeija:mesecon_switch_off" 2',
recipe = { recipe = {
{'craft "default:steel_ingot"', 'node "default:cobble"', 'craft "default:steel_ingot"'}, {'"default:steel_ingot"', '"default:cobble"', '"default:steel_ingot"'},
{'node "jeija:mesecon_off"','', 'node "jeija:mesecon_off"'}, {'"jeija:mesecon_off"','', '"jeija:mesecon_off"'},
} }
}) })
@ -1121,11 +1134,11 @@ minetest.register_node("jeija:removestone", {
}) })
minetest.register_craft({ minetest.register_craft({
output = 'node "jeija:removestone" 4', output = '"jeija:removestone" 4',
recipe = { recipe = {
{'', 'node "default:cobble"',''}, {'', '"default:cobble"',''},
{'node "default:cobble"', 'node "jeija:mesecon_off"', 'node "default:cobble"'}, {'"default:cobble"', '"jeija:mesecon_off"', '"default:cobble"'},
{'', 'node "default:cobble"',''}, {'', '"default:cobble"',''},
} }
}) })
@ -1137,16 +1150,16 @@ end)
-- Include other files -- Include other files
dofile(mesecon.modpath.."/movestone.lua") dofile(minetest.get_modpath("jeija").."/movestone.lua")
dofile(mesecon.modpath.."/button.lua") dofile(minetest.get_modpath("jeija").."/button.lua")
dofile(mesecon.modpath.."/torches.lua") dofile(minetest.get_modpath("jeija").."/torches.lua")
dofile(mesecon.modpath.."/detector.lua") dofile(minetest.get_modpath("jeija").."/detector.lua")
dofile(mesecon.modpath.."/pressureplates.lua") dofile(minetest.get_modpath("jeija").."/pressureplates.lua")
dofile(mesecon.modpath.."/wireless.lua") dofile(minetest.get_modpath("jeija").."/wireless.lua")
dofile(mesecon.modpath.."/lightstone.lua") dofile(minetest.get_modpath("jeija").."/alias.lua")
--TEMPEREST's STUFF --TEMPEREST's STUFF
if ENABLE_TEMPEREST==1 then if ENABLE_TEMPEREST==1 then
dofile(mesecon.modpath.."/temperest.lua") dofile(minetest.get_modpath("jeija").."temperest.lua")
end end
--INIT --INIT