Compare commits
1 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
3af4a5b513 |
187
init.lua
Normal file → Executable file
187
init.lua
Normal file → Executable file
@ -1,132 +1,103 @@
|
|||||||
minetest.register_node("sponge:sponge", {
|
minetest.register_node("sponge:sponge", {
|
||||||
description = "Sponge",
|
description = "Sponge Dry",
|
||||||
drawtype = "normal",
|
drawtype = "normal",
|
||||||
tiles = {"sponge.png"},
|
tiles = {"sponge_sponge.png"},
|
||||||
paramtype = 'light',
|
paramtype = 'light',
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = true,
|
walkable = true,
|
||||||
pointable = true,
|
pointable = true,
|
||||||
diggable = true,
|
diggable = true,
|
||||||
buildable_to = false,
|
buildable_to = false,
|
||||||
groups = {snappy=2, flammable=1},
|
stack_max = 99,
|
||||||
})
|
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=3,flammable=3},
|
||||||
|
after_place_node = function(pos, placer, itemstack, pointed_thing)
|
||||||
minetest.register_node("sponge:iron_sponge", {
|
local pn = placer:get_player_name()
|
||||||
description = "Iron Sponge",
|
if pointed_thing.type ~= "node" then
|
||||||
drawtype = "normal",
|
return
|
||||||
tiles = {"iron_sponge.png"},
|
end
|
||||||
paramtype = 'light',
|
if minetest.is_protected(pointed_thing.above, pn) then
|
||||||
sunlight_propagates = true,
|
return
|
||||||
walkable = true,
|
end
|
||||||
pointable = true,
|
local change = false
|
||||||
diggable = true,
|
local on_water = false
|
||||||
buildable_to = false,
|
local p, n
|
||||||
groups = {cracky=2},
|
-- verifier si il est dans l'eau ou a cotée
|
||||||
})
|
if string.find(minetest.get_node(pointed_thing.above).name, "water_source")
|
||||||
|
or string.find(minetest.get_node(pointed_thing.above).name, "water_flowing") then
|
||||||
|
on_water = true
|
||||||
minetest.register_node("sponge:fake_air", {
|
|
||||||
description = "Fake Air",
|
|
||||||
drawtype = "airlike",
|
|
||||||
paramtype = 'light',
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
pointable = false,
|
|
||||||
diggable = false,
|
|
||||||
buildable_to = true,
|
|
||||||
groups = {not_in_creative_inventory=1},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_abm({
|
|
||||||
nodenames = {"default:water_source", "default:water_flowing"},
|
|
||||||
neighbors = {"sponge:sponge", "sponge:iron_sponge"},
|
|
||||||
interval = 1.0,
|
|
||||||
chance = 1,
|
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
|
||||||
minetest.env:add_node(pos, {name="sponge:fake_air"})
|
|
||||||
end
|
end
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_abm(
|
|
||||||
{nodenames = {"sponge:sponge"},
|
|
||||||
interval = 1.0,
|
|
||||||
chance = 1,
|
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
|
||||||
for i=-1,1 do
|
for i=-1,1 do
|
||||||
for j=-1,1 do
|
p = {x=pos.x+i, y=pos.y, z=pos.z}
|
||||||
for k=-1,1 do
|
n = minetest.get_node(p)
|
||||||
|
-- On verifie si il y a de l'eau
|
||||||
|
if (n.name=="default:water_flowing") or (n.name == "default:water_source")
|
||||||
|
or (n.name == "default:river_water_flowing") or (n.name == "default:river_water_source") then
|
||||||
|
on_water = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
for i=-1,1 do
|
||||||
|
p = {x=pos.x, y=pos.y+i, z=pos.z}
|
||||||
|
n = minetest.get_node(p)
|
||||||
|
-- On verifie si il y a de l'eau
|
||||||
|
if (n.name=="default:water_flowing") or (n.name == "default:water_source")
|
||||||
|
or (n.name == "default:river_water_flowing") or (n.name == "default:river_water_source") then
|
||||||
|
on_water = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
for i=-1,1 do
|
||||||
|
p = {x=pos.x, y=pos.y, z=pos.z+i}
|
||||||
|
n = minetest.get_node(p)
|
||||||
|
-- On verifie si il y a de l'eau
|
||||||
|
if (n.name=="default:water_flowing") or (n.name == "default:water_source")
|
||||||
|
or (n.name == "default:river_water_flowing") or (n.name == "default:river_water_source") then
|
||||||
|
on_water = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if on_water == true then
|
||||||
|
for i=-3,3 do
|
||||||
|
for j=-3,3 do
|
||||||
|
for k=-3,3 do
|
||||||
p = {x=pos.x+i, y=pos.y+j, z=pos.z+k}
|
p = {x=pos.x+i, y=pos.y+j, z=pos.z+k}
|
||||||
n = minetest.env:get_node(p)
|
n = minetest.get_node(p)
|
||||||
if (n.name=="default:water_flowing")
|
-- On Supprime l'eau
|
||||||
or (n.name == "default:water_source") then
|
if (n.name=="default:water_flowing") or (n.name == "default:water_source")
|
||||||
minetest.env:add_node(p, {name="sponge:fake_air"})
|
or (n.name == "default:river_water_flowing") or (n.name == "default:river_water_source") then
|
||||||
|
minetest.add_node(p, {name="air"})
|
||||||
|
change = true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
if change then
|
||||||
|
minetest.add_node(pos, {name = "sponge:sponge_wet"})
|
||||||
|
end
|
||||||
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_abm(
|
minetest.register_node("sponge:sponge_wet", {
|
||||||
{nodenames = {"sponge:iron_sponge"},
|
description = "Wet Sponge",
|
||||||
interval = 1.0,
|
drawtype = "normal",
|
||||||
chance = 1,
|
tiles = {"sponge_sponge_wet.png"},
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
paramtype = 'light',
|
||||||
for i=-2,2 do
|
walkable = true,
|
||||||
for j=-2,2 do
|
pointable = true,
|
||||||
for k=-2,2 do
|
diggable = true,
|
||||||
p = {x=pos.x+i, y=pos.y+j, z=pos.z+k}
|
buildable_to = false,
|
||||||
n = minetest.env:get_node(p)
|
stack_max = 99,
|
||||||
if (n.name=="default:water_flowing")
|
groups = {snappy=2,choppy=2,oddly_breakable_by_hand=3},
|
||||||
or (n.name == "default:water_source")
|
|
||||||
or (n.name == "default:lava_source")
|
|
||||||
or (n.name == "default:lava_flowing") then
|
|
||||||
minetest.env:add_node(p, {name="sponge:fake_air"})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_abm(
|
-- Sponge wet back to Sponge Dry if coocked in a furnace
|
||||||
{nodenames = {"sponge:fake_air"},
|
minetest.register_craft({
|
||||||
interval = 1.0,
|
type = "cooking", output = "sponge:sponge", recipe = "sponge:sponge_wet",
|
||||||
chance = 1,
|
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
|
||||||
spongecount=0
|
|
||||||
for i=-2,2 do
|
|
||||||
for j=-2,2 do
|
|
||||||
for k=-2,2 do
|
|
||||||
p = {x=pos.x+i, y=pos.y+j, z=pos.z+k}
|
|
||||||
n = minetest.env:get_node(p)
|
|
||||||
if (n.name=="sponge:iron_sponge") or (n.name == "sponge:sponge") then
|
|
||||||
spongecount=spongecount+1
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if (spongecount==0) then
|
|
||||||
minetest.env:add_node(pos, {name="air"})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "sponge:sponge",
|
output = "sponge:sponge",
|
||||||
recipe = {
|
recipe = {
|
||||||
{'default:leaves', 'default:leaves', 'default:leaves'},
|
{"", "dye:black", ""},
|
||||||
{'default:leaves', 'default:mese', 'default:leaves'},
|
{"dye:yellow", "wool:white", "dye:yellow"},
|
||||||
{'default:leaves', 'default:leaves', 'default:leaves'},
|
{"", "farming:wheat", ""},
|
||||||
}
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = "sponge:iron_sponge",
|
|
||||||
recipe = {
|
|
||||||
{'default:steel_ingot', 'default:steel_ingot', 'default:steel_ingot'},
|
|
||||||
{'default:steel_ingot', 'sponge:sponge', 'default:steel_ingot'},
|
|
||||||
{'default:steel_ingot', 'default:steel_ingot', 'default:steel_ingot'},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
|
103
oldinit.lua
103
oldinit.lua
@ -1,103 +0,0 @@
|
|||||||
minetest.register_node("sponge:sponge", {
|
|
||||||
description = "Sponge",
|
|
||||||
drawtype = "normal",
|
|
||||||
tiles = {"sponge.png"},
|
|
||||||
paramtype = 'light',
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = true,
|
|
||||||
pointable = true,
|
|
||||||
diggable = true,
|
|
||||||
buildable_to = false,
|
|
||||||
groups = {snappy=2, flammable=1},
|
|
||||||
after_destruct = function(pos)
|
|
||||||
for i=-1,1 do
|
|
||||||
for j=-1,1 do
|
|
||||||
for k=-1,1 do
|
|
||||||
p = {x=pos.x+i, y=pos.y+j, z=pos.z+k}
|
|
||||||
n = minetest.env:get_node(p)
|
|
||||||
if (n.name=="sponge:fake_air") then
|
|
||||||
minetest.env:add_node(p, {name="air"})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("sponge:iron_sponge", {
|
|
||||||
description = "Iron Sponge",
|
|
||||||
drawtype = "normal",
|
|
||||||
tiles = {"iron_sponge.png"},
|
|
||||||
paramtype = 'light',
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = true,
|
|
||||||
pointable = true,
|
|
||||||
diggable = true,
|
|
||||||
buildable_to = false,
|
|
||||||
groups = {cracky=2},
|
|
||||||
after_destruct = function(pos)
|
|
||||||
for i=-1,1 do
|
|
||||||
for j=-1,1 do
|
|
||||||
for k=-1,1 do
|
|
||||||
p = {x=pos.x+i, y=pos.y+j, z=pos.z+k}
|
|
||||||
n = minetest.env:get_node(p)
|
|
||||||
if (n.name=="sponge:fake_air") then
|
|
||||||
minetest.env:add_node(p, {name="air"})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
|
|
||||||
minetest.register_node("sponge:fake_air", {
|
|
||||||
description = "Fake Air",
|
|
||||||
drawtype = "airlike",
|
|
||||||
paramtype = 'light',
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
pointable = false,
|
|
||||||
diggable = false,
|
|
||||||
buildable_to = true,
|
|
||||||
groups = {not_in_creative_inventory=1},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_abm({
|
|
||||||
nodenames = {"default:water_source", "default:water_flowing"},
|
|
||||||
neighbors = {"sponge:sponge", "sponge:iron_sponge"},
|
|
||||||
interval = 1.0,
|
|
||||||
chance = 1,
|
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
|
||||||
minetest.env:add_node(pos, {name="sponge:fake_air"})
|
|
||||||
end
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_abm({
|
|
||||||
nodenames = {"default:lava_source", "default:lava_flowing"},
|
|
||||||
neighbors = {"sponge:iron_sponge"},
|
|
||||||
interval = 1.0,
|
|
||||||
chance = 1,
|
|
||||||
action = function(pos, node, active_object_count, active_object_count_wider)
|
|
||||||
minetest.env:add_node(pos, {name="sponge:fake_air"})
|
|
||||||
end
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = "sponge:sponge",
|
|
||||||
recipe = {
|
|
||||||
{'default:leaves', 'default:leaves', 'default:leaves'},
|
|
||||||
{'default:leaves', 'default:mese', 'default:leaves'},
|
|
||||||
{'default:leaves', 'default:leaves', 'default:leaves'},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_craft({
|
|
||||||
output = "sponge:iron_sponge",
|
|
||||||
recipe = {
|
|
||||||
{'default:steel_ingot', 'default:steel_ingot', 'default:steel_ingot'},
|
|
||||||
{'default:steel_ingot', 'sponge:sponge', 'default:steel_ingot'},
|
|
||||||
{'default:steel_ingot', 'default:steel_ingot', 'default:steel_ingot'},
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
Binary file not shown.
Before Width: | Height: | Size: 942 B |
Binary file not shown.
Before Width: | Height: | Size: 942 B |
BIN
textures/sponge_sponge.png
Executable file
BIN
textures/sponge_sponge.png
Executable file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
BIN
textures/sponge_sponge_wet.png
Normal file
BIN
textures/sponge_sponge_wet.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
Loading…
Reference in New Issue
Block a user