Moreores: updated and tweaked. Removed new recipes for locked chests
|
@ -20,3 +20,5 @@ More Ores: http://minetest.net/forum/viewtopic.php?id=549
|
|||
Map Tools: http://minetest.net/forum/viewtopic.php?id=1882
|
||||
Doors+: http://minetest.net/forum/viewtopic.php?id=2059
|
||||
Stairs+: http://minetest.net/forum/viewtopic.php?id=2092
|
||||
|
||||
Pitriss note: version 05.July 2014 - 779baaf3de105a609213c87ce3399371e651204c - removed new recipes for locked chests
|
|
@ -1 +1,2 @@
|
|||
default
|
||||
default
|
||||
mg?
|
||||
|
|
|
@ -8,7 +8,8 @@ if (minetest.get_modpath("intllib")) then
|
|||
S = function ( s ) return s end
|
||||
end
|
||||
|
||||
dofile(minetest.get_modpath("moreores").."/_config.txt")
|
||||
moreores_modpath = minetest.get_modpath("moreores")
|
||||
dofile(moreores_modpath .. "/_config.txt")
|
||||
|
||||
--[[
|
||||
****
|
||||
|
@ -32,60 +33,46 @@ local function hoe_on_use(itemstack, user, pointed_thing, uses)
|
|||
if pt.type ~= "node" then
|
||||
return
|
||||
end
|
||||
|
||||
|
||||
local under = minetest.get_node(pt.under)
|
||||
local p = {x=pt.under.x, y=pt.under.y+1, z=pt.under.z}
|
||||
local above = minetest.get_node(p)
|
||||
|
||||
-- return if any of the nodes is not registered
|
||||
if not minetest.registered_nodes[under.name] then
|
||||
return
|
||||
end
|
||||
if not minetest.registered_nodes[above.name] then
|
||||
return
|
||||
end
|
||||
|
||||
-- check if the node above the pointed thing is air
|
||||
if above.name ~= "air" then
|
||||
return
|
||||
end
|
||||
|
||||
-- check if pointing at dirt
|
||||
if minetest.get_item_group(under.name, "soil") ~= 1 then
|
||||
return
|
||||
end
|
||||
|
||||
-- turn the node into soil, wear out item and play sound
|
||||
minetest.set_node(pt.under, {name="farming:soil"})
|
||||
minetest.sound_play("default_dig_crumbly", {
|
||||
pos = pt.under,
|
||||
gain = 0.5,
|
||||
})
|
||||
--itemstack:add_wear(65535/(uses-1))
|
||||
local pos = {x = pt.under.x, y = pt.under.y + 1, z = pt.under.z}
|
||||
local above = minetest.get_node(pos)
|
||||
|
||||
-- Return if any of the nodes is not registered:
|
||||
if not minetest.registered_nodes[under.name] then return end
|
||||
if not minetest.registered_nodes[above.name] then return end
|
||||
|
||||
-- Check if the node above the pointed thing is air:
|
||||
if above.name ~= "air" then return end
|
||||
|
||||
-- Check if pointing at dirt:
|
||||
if minetest.get_item_group(under.name, "soil") ~= 1 then return end
|
||||
|
||||
-- Turn the node into soil, wear out item and play sound:
|
||||
minetest.set_node(pt.under, {name ="farming:soil"})
|
||||
minetest.sound_play("default_dig_crumbly", {pos = pt.under, gain = 0.5})
|
||||
itemstack:add_wear(65535 / (uses - 1))
|
||||
return itemstack
|
||||
end
|
||||
|
||||
local function get_recipe(c, name)
|
||||
if name == "sword" then
|
||||
return {{c},{c},{"default:stick"}}
|
||||
return {{c}, {c}, {"group:stick"}}
|
||||
end
|
||||
if name == "shovel" then
|
||||
return {{c},{"default:stick"},{"default:stick"}}
|
||||
return {{c}, {"group:stick"}, {"group:stick"}}
|
||||
end
|
||||
if name == "axe" then
|
||||
return {{c,c},{c,"default:stick"},{"","default:stick"}}
|
||||
return {{c, c}, {c, "group:stick"}, {"", "group:stick"}}
|
||||
end
|
||||
if name == "pick" then
|
||||
return {{c,c,c},{"","default:stick",""},{"","default:stick",""}}
|
||||
return {{c, c, c}, {"", "group:stick", ""}, {"", "group:stick", ""}}
|
||||
end
|
||||
if name == "hoe" then
|
||||
return {{c,c},{"","default:stick"},{"","default:stick"}}
|
||||
return {{c, c}, {"", "group:stick"}, {"", "group:stick"}}
|
||||
end
|
||||
if name == "block" then
|
||||
return {{c,c,c},{c,c,c},{c,c,c}}
|
||||
end
|
||||
if name == "lockedchest" then
|
||||
return {{"default:wood","default:wood","default:wood"},{"default:wood",c,"default:wood"},{"default:wood","default:wood","default:wood"}}
|
||||
return {{c, c, c}, {c, c, c}, {c, c, c}}
|
||||
end
|
||||
end
|
||||
|
||||
|
@ -103,7 +90,7 @@ local function add_ore(modname, description, mineral_name, oredef)
|
|||
minetest.register_node(modname .. ":mineral_"..mineral_name, {
|
||||
description = S("%s Ore"):format(S(description)),
|
||||
tiles = {"default_stone.png^"..modname.."_mineral_"..mineral_name..".png"},
|
||||
groups = {cracky=3},
|
||||
groups = {cracky = 3},
|
||||
sounds = default_stone_sounds,
|
||||
drop = lumpitem
|
||||
})
|
||||
|
@ -114,7 +101,7 @@ local function add_ore(modname, description, mineral_name, oredef)
|
|||
minetest.register_node(blockitem, {
|
||||
description = S("%s Block"):format(S(description)),
|
||||
tiles = { img_base .. "_block.png" },
|
||||
groups = {snappy=1,bendy=2,cracky=1,melty=2,level=2},
|
||||
groups = {snappy = 1,bendy = 2, cracky = 1,melty = 2,level= 2},
|
||||
sounds = default_stone_sounds
|
||||
})
|
||||
minetest.register_alias(mineral_name.."_block", blockitem)
|
||||
|
@ -154,58 +141,51 @@ local function add_ore(modname, description, mineral_name, oredef)
|
|||
})
|
||||
minetest.register_alias(mineral_name .. "_ingot", ingot)
|
||||
end
|
||||
|
||||
if oredef.makes.chest then
|
||||
minetest.register_craft( {
|
||||
output = "default:chest_locked 1",
|
||||
recipe = {
|
||||
{ ingot },
|
||||
{ "default:chest" }
|
||||
}
|
||||
})
|
||||
minetest.register_craft( {
|
||||
output = "default:chest_locked 1",
|
||||
recipe = get_recipe(ingot, "lockedchest")
|
||||
})
|
||||
end
|
||||
|
||||
|
||||
oredef.oredef.ore_type = "scatter"
|
||||
oredef.oredef.ore = modname..":mineral_"..mineral_name
|
||||
oredef.oredef.ore = modname .. ":mineral_" .. mineral_name
|
||||
oredef.oredef.wherein = "default:stone"
|
||||
|
||||
|
||||
minetest.register_ore(oredef.oredef)
|
||||
|
||||
for toolname, tdef in pairs(oredef.tools) do
|
||||
for toolname, tooldef in pairs(oredef.tools) do
|
||||
local tdef = {
|
||||
description = "",
|
||||
inventory_image = toolimg_base .. toolname .. ".png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps=tdef
|
||||
max_drop_level = 3,
|
||||
groupcaps = tooldef
|
||||
}
|
||||
}
|
||||
|
||||
if toolname == "sword" then
|
||||
tdef.full_punch_interval = oredef.punchint
|
||||
tdef.tool_capabilities.full_punch_interval = oredef.full_punch_interval
|
||||
tdef.tool_capabilities.damage_groups = oredef.damage_groups
|
||||
tdef.description = S("%s Sword"):format(S(description))
|
||||
end
|
||||
|
||||
if toolname == "pick" then
|
||||
tdef.tool_capabilities.full_punch_interval = oredef.full_punch_interval
|
||||
tdef.tool_capabilities.damage_groups = oredef.damage_groups
|
||||
tdef.description = S("%s Pickaxe"):format(S(description))
|
||||
end
|
||||
|
||||
|
||||
if toolname == "axe" then
|
||||
tdef.tool_capabilities.full_punch_interval = oredef.full_punch_interval
|
||||
tdef.tool_capabilities.damage_groups = oredef.damage_groups
|
||||
tdef.description = S("%s Axe"):format(S(description))
|
||||
end
|
||||
|
||||
if toolname == "shovel" then
|
||||
tdef.full_punch_interval = oredef.full_punch_interval
|
||||
tdef.tool_capabilities.damage_groups = oredef.damage_groups
|
||||
tdef.description = S("%s Shovel"):format(S(description))
|
||||
end
|
||||
|
||||
|
||||
if toolname == "hoe" then
|
||||
tdef.description = S("%s Hoe"):format(S(description))
|
||||
local uses = tdef.uses
|
||||
tdef.uses = nil
|
||||
local uses = tooldef.uses
|
||||
tooldef.uses = nil
|
||||
tdef.on_use = function(itemstack, user, pointed_thing)
|
||||
return hoe_on_use(itemstack, user, pointed_thing, uses)
|
||||
end
|
||||
|
@ -223,14 +203,13 @@ local function add_ore(modname, description, mineral_name, oredef)
|
|||
end
|
||||
end
|
||||
|
||||
-- Add everything (compact(ish)!)
|
||||
|
||||
-- Add everything:
|
||||
local modname = "moreores"
|
||||
|
||||
local oredefs = {
|
||||
silver = {
|
||||
desc = "Silver",
|
||||
makes = {ore=true, block=true, lump=true, ingot=true, chest=true},
|
||||
makes = {ore = true, block = true, lump = true, ingot = true, chest = true},
|
||||
oredef = {clust_scarcity = moreores_silver_chunk_size * moreores_silver_chunk_size * moreores_silver_chunk_size,
|
||||
clust_num_ores = moreores_silver_ore_per_chunk,
|
||||
clust_size = moreores_silver_chunk_size,
|
||||
|
@ -239,29 +218,30 @@ local oredefs = {
|
|||
},
|
||||
tools = {
|
||||
pick = {
|
||||
cracky={times={[1]=2.60, [2]=1.00, [3]=0.60}, uses=100, maxlevel=1}
|
||||
cracky = {times = {[1] = 2.60, [2] = 1.00, [3] = 0.60}, uses = 100, maxlevel= 1}
|
||||
},
|
||||
hoe = {
|
||||
uses = 300
|
||||
},
|
||||
shovel = {
|
||||
crumbly={times={[1]=1.10, [2]=0.40, [3]=0.25}, uses=100, maxlevel=1}
|
||||
crumbly = {times = {[1] = 1.10, [2] = 0.40, [3] = 0.25}, uses = 100, maxlevel= 1}
|
||||
},
|
||||
axe = {
|
||||
choppy={times={[1]=2.50, [2]=0.80, [3]=0.50}, uses=100, maxlevel=1},
|
||||
fleshy={times={[2]=1.10, [3]=0.60}, uses=100, maxlevel=1}
|
||||
choppy = {times = {[1] = 2.50, [2] = 0.80, [3] = 0.50}, uses = 100, maxlevel= 1},
|
||||
fleshy = {times = {[2] = 1.10, [3] = 0.60}, uses = 100, maxlevel= 1}
|
||||
},
|
||||
sword = {
|
||||
fleshy={times={[2]=0.70, [3]=0.30}, uses=100, maxlevel=1},
|
||||
snappy={times={[2]=0.70, [3]=0.30}, uses=100, maxlevel=1},
|
||||
choppy={times={[3]=0.80}, uses=100, maxlevel=0}
|
||||
fleshy = {times = {[2] = 0.70, [3] = 0.30}, uses = 100, maxlevel= 1},
|
||||
snappy = {times = {[2] = 0.70, [3] = 0.30}, uses = 100, maxlevel= 1},
|
||||
choppy = {times = {[3] = 0.80}, uses = 100, maxlevel= 0}
|
||||
}
|
||||
},
|
||||
punchint = 1.0
|
||||
full_punch_interval = 1.0,
|
||||
damage_groups = {fleshy = 6},
|
||||
},
|
||||
tin = {
|
||||
desc = "Tin",
|
||||
makes = {ore=true, block=true, lump=true, ingot=true, chest=false},
|
||||
makes = {ore = true, block = true, lump = true, ingot = true, chest = false},
|
||||
oredef = {clust_scarcity = moreores_tin_chunk_size * moreores_tin_chunk_size * moreores_tin_chunk_size,
|
||||
clust_num_ores = moreores_tin_ore_per_chunk,
|
||||
clust_size = moreores_tin_chunk_size,
|
||||
|
@ -272,7 +252,7 @@ local oredefs = {
|
|||
},
|
||||
mithril = {
|
||||
desc = "Mithril",
|
||||
makes = {ore=true, block=true, lump=true, ingot=true, chest=false},
|
||||
makes = {ore = true, block = true, lump = true, ingot = true, chest = false},
|
||||
oredef = {clust_scarcity = moreores_mithril_chunk_size * moreores_mithril_chunk_size * moreores_mithril_chunk_size,
|
||||
clust_num_ores = moreores_mithril_ore_per_chunk,
|
||||
clust_size = moreores_mithril_chunk_size,
|
||||
|
@ -281,25 +261,26 @@ local oredefs = {
|
|||
},
|
||||
tools = {
|
||||
pick = {
|
||||
cracky={times={[1]=2.25, [2]=0.55, [3]=0.35}, uses=200, maxlevel=1}
|
||||
cracky = {times = {[1] = 2.25, [2] = 0.55, [3] = 0.35}, uses = 200, maxlevel= 1}
|
||||
},
|
||||
hoe = {
|
||||
uses = 1000
|
||||
},
|
||||
shovel = {
|
||||
crumbly={times={[1]=0.70, [2]=0.35, [3]=0.20}, uses=200, maxlevel=1}
|
||||
crumbly = {times = {[1] = 0.70, [2] = 0.35, [3] = 0.20}, uses = 200, maxlevel= 1}
|
||||
},
|
||||
axe = {
|
||||
choppy={times={[1]=1.75, [2]=0.45, [3]=0.45}, uses=200, maxlevel=1},
|
||||
fleshy={times={[2]=0.95, [3]=0.30}, uses=200, maxlevel=1}
|
||||
choppy = {times = {[1] = 1.75, [2] = 0.45, [3] = 0.45}, uses = 200, maxlevel= 1},
|
||||
fleshy = {times = {[2] = 0.95, [3] = 0.30}, uses = 200, maxlevel= 1}
|
||||
},
|
||||
sword = {
|
||||
fleshy={times={[2]=0.65, [3]=0.25}, uses=200, maxlevel=1},
|
||||
snappy={times={[2]=0.70, [3]=0.25}, uses=200, maxlevel=1},
|
||||
choppy={times={[3]=0.65}, uses=200, maxlevel=0}
|
||||
fleshy = {times = {[2] = 0.65, [3] = 0.25}, uses = 200, maxlevel= 1},
|
||||
snappy = {times = {[2] = 0.70, [3] = 0.25}, uses = 200, maxlevel= 1},
|
||||
choppy = {times = {[3] = 0.65}, uses = 200, maxlevel= 0}
|
||||
}
|
||||
},
|
||||
punchint = 0.45
|
||||
full_punch_interval = 0.45,
|
||||
damage_groups = {fleshy = 9},
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -313,13 +294,12 @@ minetest.register_craft({
|
|||
output = "moreores:copper_rail 16",
|
||||
recipe = {
|
||||
{"default:copper_ingot", "", "default:copper_ingot"},
|
||||
{"default:copper_ingot", "default:stick", "default:copper_ingot"},
|
||||
{"default:copper_ingot", "group:stick", "default:copper_ingot"},
|
||||
{"default:copper_ingot", "", "default:copper_ingot"}
|
||||
}
|
||||
})
|
||||
|
||||
-- Bronze has some special cases, because it is made from copper and tin
|
||||
|
||||
-- Bronze has some special cases, because it is made from copper and tin:
|
||||
minetest.register_craft( {
|
||||
type = "shapeless",
|
||||
output = "default:bronze_ingot 3",
|
||||
|
@ -330,8 +310,7 @@ minetest.register_craft( {
|
|||
}
|
||||
})
|
||||
|
||||
-- Unique node
|
||||
|
||||
-- Unique node:
|
||||
minetest.register_node("moreores:copper_rail", {
|
||||
description = S("Copper Rail"),
|
||||
drawtype = "raillike",
|
||||
|
@ -345,7 +324,7 @@ minetest.register_node("moreores:copper_rail", {
|
|||
type = "fixed",
|
||||
fixed = {-1/2, -1/2, -1/2, 1/2, -1/2+1/16, 1/2},
|
||||
},
|
||||
groups = {bendy=2,snappy=1,dig_immediate=2,rail=1,connect_to_raillike=1},
|
||||
groups = {bendy = 2,snappy = 1,dig_immediate = 2,rail= 1, connect_to_raillike = 1},
|
||||
mesecons = {
|
||||
effector = {
|
||||
action_on = function(pos, node)
|
||||
|
@ -359,4 +338,11 @@ minetest.register_node("moreores:copper_rail", {
|
|||
},
|
||||
})
|
||||
|
||||
print(S("[moreores] loaded."))
|
||||
-- mg support:
|
||||
if minetest.get_modpath("mg") then
|
||||
dofile(moreores_modpath.."/mg.lua")
|
||||
end
|
||||
|
||||
if minetest.setting_getbool("log_mods") then
|
||||
print(S("[moreores] loaded."))
|
||||
end
|
||||
|
|
|
@ -0,0 +1,22 @@
|
|||
# Translation by Xanthin
|
||||
|
||||
[moreores] loaded. = [moreores] geladen.
|
||||
|
||||
%s Ore = %serz
|
||||
%s Lump = %sklumpen
|
||||
%s Ingot = %sbarren
|
||||
%s Block = %sblock
|
||||
%s Pickaxe = %sspitzhacke
|
||||
%s Shovel = %sschaufel
|
||||
%s Axe = %saxt
|
||||
%s Sword = %sschwert
|
||||
%s Hoe = %shacke
|
||||
|
||||
Copper = Kupfer
|
||||
Tin = Zinn
|
||||
Bronze = Bronze
|
||||
Silver = Silber
|
||||
Gold = Gold
|
||||
Mithril = Mithril
|
||||
|
||||
Copper Rail = Kupferschiene
|
|
@ -0,0 +1,46 @@
|
|||
mg.register_ore({
|
||||
name = "moreores:mineral_tin",
|
||||
wherein = "default:stone",
|
||||
seeddiff = 8,
|
||||
maxvdistance = 10.5,
|
||||
maxheight = 8,
|
||||
seglenghtn = 15,
|
||||
seglenghtdev = 6,
|
||||
segincln = 0,
|
||||
segincldev = 0.6,
|
||||
turnangle = 57,
|
||||
forkturnangle = 57,
|
||||
numperblock = 2
|
||||
})
|
||||
|
||||
mg.register_ore({
|
||||
name = "moreores:mineral_silver",
|
||||
wherein = "default:stone",
|
||||
seeddiff = 9,
|
||||
maxvdistance = 10.5,
|
||||
maxheight = -2,
|
||||
seglenghtn = 15,
|
||||
seglenghtdev = 6,
|
||||
sizen = 60,
|
||||
sizedev = 30,
|
||||
segincln = 0,
|
||||
segincldev = 0.6,
|
||||
turnangle = 57,
|
||||
forkturnangle = 57,
|
||||
numperblock = 2
|
||||
})
|
||||
|
||||
mg.register_ore({
|
||||
name = "moreores:mineral_mithril",
|
||||
wherein = "default:stone",
|
||||
seeddiff = 10,
|
||||
maxvdistance = 10.5,
|
||||
maxheight = -512,
|
||||
seglenghtn = 2,
|
||||
seglenghtdev = 4,
|
||||
sizen = 12,
|
||||
sizedev = 5,
|
||||
segincln = 0,
|
||||
segincldev = 0.6,
|
||||
turnangle = 57,
|
||||
})
|
|
@ -1,745 +0,0 @@
|
|||
--[[
|
||||
****
|
||||
More Ores
|
||||
by Calinou
|
||||
Old and "inefficient" version; use if the new version does not work for some reason. Outdated.
|
||||
Licensed under the zlib/libpng license, see LICENSE.txt for info.
|
||||
****
|
||||
--]]
|
||||
|
||||
-- Blocks
|
||||
|
||||
minetest.register_node( "moreores:mineral_gold", {
|
||||
description = "Gold Ore",
|
||||
tile_images = { "default_stone.png^moreores_mineral_gold.png" },
|
||||
is_ground_content = true,
|
||||
groups = {cracky=3},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
drop = 'craft "moreores:gold_lump" 1',
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:gold_block", {
|
||||
description = "Gold Block",
|
||||
tile_images = { "moreores_gold_block.png" },
|
||||
is_ground_content = true,
|
||||
groups = {snappy=1,bendy=2,cracky=1,melty=2,level=2},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:mineral_silver", {
|
||||
description = "Silver Ore",
|
||||
tile_images = { "default_stone.png^moreores_mineral_silver.png" },
|
||||
is_ground_content = true,
|
||||
groups = {cracky=3},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
drop = 'craft "moreores:silver_lump" 1',
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:silver_block", {
|
||||
description = "Silver Block",
|
||||
tile_images = { "moreores_silver_block.png" },
|
||||
is_ground_content = true,
|
||||
groups = {snappy=1,bendy=2,cracky=1,melty=2,level=2},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:mineral_copper", {
|
||||
description = "Copper Ore",
|
||||
tile_images = { "default_stone.png^moreores_mineral_copper.png" },
|
||||
is_ground_content = true,
|
||||
groups = {cracky=3},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
drop = 'craft "moreores:copper_lump" 1',
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:mineral_tin", {
|
||||
description = "Tin Ore",
|
||||
tile_images = { "default_stone.png^moreores_mineral_tin.png" },
|
||||
is_ground_content = true,
|
||||
groups = {cracky=3},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
drop = 'craft "moreores:tin_lump" 1',
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:bronze_block", {
|
||||
description = "Bronze Block",
|
||||
tile_images = { "moreores_bronze_block.png" },
|
||||
is_ground_content = true,
|
||||
groups = {snappy=1,bendy=2,cracky=1,melty=2,level=2},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:mineral_mithril", {
|
||||
description = "Mithril Ore",
|
||||
tile_images = { "default_stone.png^moreores_mineral_mithril.png" },
|
||||
is_ground_content = true,
|
||||
groups = {cracky=3},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
drop = 'craft "moreores:mithril_lump" 1',
|
||||
})
|
||||
|
||||
minetest.register_node( "moreores:mithril_block", {
|
||||
description = "Mithril Block",
|
||||
tile_images = { "moreores_mithril_block.png" },
|
||||
is_ground_content = true,
|
||||
groups = {snappy=1,bendy=2,cracky=1,melty=2,level=2},
|
||||
sounds = default.node_sound_stone_defaults(),
|
||||
})
|
||||
|
||||
minetest.register_node("moreores:copper_rail", {
|
||||
description = "Copper Rail",
|
||||
drawtype = "raillike",
|
||||
tile_images = {"moreores_copper_rail.png", "moreores_copper_rail_curved.png", "moreores_copper_rail_t_junction.png", "moreores_copper_rail_crossing.png"},
|
||||
inventory_image = "moreores_copper_rail.png",
|
||||
wield_image = "moreores_copper_rail.png",
|
||||
paramtype = "light",
|
||||
is_ground_content = true,
|
||||
walkable = false,
|
||||
selection_box = {
|
||||
type = "fixed",
|
||||
--fixed = <default>
|
||||
},
|
||||
groups = {bendy=2,snappy=1,dig_immediate=2},
|
||||
})
|
||||
|
||||
-- Items
|
||||
|
||||
minetest.register_craftitem( "moreores:gold_lump", {
|
||||
description = "Gold Lump",
|
||||
inventory_image = "moreores_gold_lump.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:gold_ingot", {
|
||||
description = "Gold Ingot",
|
||||
inventory_image = "moreores_gold_ingot.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:silver_lump", {
|
||||
description = "Silver Lump",
|
||||
inventory_image = "moreores_silver_lump.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:silver_ingot", {
|
||||
description = "Silver Ingot",
|
||||
inventory_image = "moreores_silver_ingot.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:copper_lump", {
|
||||
description = "Copper Lump",
|
||||
inventory_image = "moreores_copper_lump.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:copper_ingot", {
|
||||
description = "Copper Ingot",
|
||||
inventory_image = "moreores_copper_ingot.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:tin_lump", {
|
||||
description = "Tin Lump",
|
||||
inventory_image = "moreores_tin_lump.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:tin_ingot", {
|
||||
description = "Tin Ingot",
|
||||
inventory_image = "moreores_tin_ingot.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:bronze_ingot", {
|
||||
description = "Bronze Ingot",
|
||||
inventory_image = "moreores_bronze_ingot.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:mithril_lump", {
|
||||
description = "Mithril Lump",
|
||||
inventory_image = "moreores_mithril_lump.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
on_use = minetest.item_eat(2),
|
||||
})
|
||||
|
||||
minetest.register_craftitem( "moreores:mithril_ingot", {
|
||||
description = "Mithril Ingot",
|
||||
inventory_image = "moreores_mithril_ingot.png",
|
||||
on_place_on_ground = minetest.craftitem_place_item,
|
||||
})
|
||||
|
||||
-- Tools
|
||||
|
||||
minetest.register_tool("moreores:pick_bronze", {
|
||||
description = "Bronze Pickaxe",
|
||||
inventory_image = "moreores_tool_bronzepick.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
cracky={times={[1]=3.00, [2]=1.20, [3]=0.80}, uses=160, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:shovel_bronze", {
|
||||
description = "Bronze Shovel",
|
||||
inventory_image = "moreores_tool_bronzeshovel.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
crumbly={times={[1]=1.50, [2]=0.50, [3]=0.30}, uses=160, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:axe_bronze", {
|
||||
description = "Bronze Axe",
|
||||
inventory_image = "moreores_tool_bronzeaxe.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
choppy={times={[1]=3.00, [2]=1.00, [3]=0.60}, uses=160, maxlevel=1},
|
||||
fleshy={times={[2]=1.30, [3]=0.70}, uses=160, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:sword_bronze", {
|
||||
description = "Bronze Sword",
|
||||
inventory_image = "moreores_tool_bronzesword.png",
|
||||
tool_capabilities = {
|
||||
full_punch_interval = 1.0,
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
fleshy={times={[2]=0.80, [3]=0.40}, uses=160, maxlevel=1},
|
||||
snappy={times={[2]=0.80, [3]=0.40}, uses=160, maxlevel=1},
|
||||
choppy={times={[3]=0.90}, uses=160, maxlevel=0}
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:pick_silver", {
|
||||
description = "Silver Pickaxe",
|
||||
inventory_image = "moreores_tool_silverpick.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
cracky={times={[1]=2.60, [2]=1.00, [3]=0.60}, uses=100, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:shovel_silver", {
|
||||
description = "Silver Shovel",
|
||||
inventory_image = "moreores_tool_silvershovel.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
crumbly={times={[1]=1.10, [2]=0.40, [3]=0.25}, uses=100, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:axe_silver", {
|
||||
description = "Silver Axe",
|
||||
inventory_image = "moreores_tool_silveraxe.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
choppy={times={[1]=2.50, [2]=0.80, [3]=0.50}, uses=100, maxlevel=1},
|
||||
fleshy={times={[2]=1.10, [3]=0.60}, uses=100, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:sword_silver", {
|
||||
description = "Silver Sword",
|
||||
inventory_image = "moreores_tool_silversword.png",
|
||||
tool_capabilities = {
|
||||
full_punch_interval = 1.0,
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
fleshy={times={[2]=0.70, [3]=0.30}, uses=100, maxlevel=1},
|
||||
snappy={times={[2]=0.70, [3]=0.30}, uses=100, maxlevel=1},
|
||||
choppy={times={[3]=0.80}, uses=100, maxlevel=0}
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:pick_gold", {
|
||||
description = "Golden Pickaxe",
|
||||
inventory_image = "moreores_tool_goldpick.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
cracky={times={[1]=2.00, [2]=0.50, [3]=0.30}, uses=70, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:shovel_gold", {
|
||||
description = "Golden Shovel",
|
||||
inventory_image = "moreores_tool_goldshovel.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
crumbly={times={[1]=0.60, [2]=0.25, [3]=0.15}, uses=70, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:axe_gold", {
|
||||
description = "Golden Axe",
|
||||
inventory_image = "moreores_tool_goldaxe.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
choppy={times={[1]=1.70, [2]=0.40, [3]=0.35}, uses=70, maxlevel=1},
|
||||
fleshy={times={[2]=0.90, [3]=0.30}, uses=70, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:sword_gold", {
|
||||
description = "Golden Sword",
|
||||
inventory_image = "moreores_tool_goldsword.png",
|
||||
tool_capabilities = {
|
||||
full_punch_interval = 0.85,
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
fleshy={times={[2]=0.60, [3]=0.20}, uses=70, maxlevel=1},
|
||||
snappy={times={[2]=0.60, [3]=0.20}, uses=70, maxlevel=1},
|
||||
choppy={times={[3]=0.65}, uses=70, maxlevel=0}
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:pick_mithril", {
|
||||
description = "Mithril Pickaxe",
|
||||
inventory_image = "moreores_tool_mithrilpick.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
cracky={times={[1]=2.25, [2]=0.55, [3]=0.35}, uses=200, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:shovel_mithril", {
|
||||
description = "Mithril Shovel",
|
||||
inventory_image = "moreores_tool_mithrilshovel.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
crumbly={times={[1]=0.70, [2]=0.35, [3]=0.20}, uses=200, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:axe_mithril", {
|
||||
description = "Mithril Axe",
|
||||
inventory_image = "moreores_tool_mithrilaxe.png",
|
||||
tool_capabilities = {
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
choppy={times={[1]=1.75, [2]=0.45, [3]=0.45}, uses=200, maxlevel=1},
|
||||
fleshy={times={[2]=0.95, [3]=0.30}, uses=200, maxlevel=1}
|
||||
}
|
||||
},
|
||||
})
|
||||
|
||||
minetest.register_tool("moreores:sword_mithril", {
|
||||
description = "Mithril Sword",
|
||||
inventory_image = "moreores_tool_mithrilsword.png",
|
||||
tool_capabilities = {
|
||||
full_punch_interval = 0.45,
|
||||
max_drop_level=3,
|
||||
groupcaps={
|
||||
fleshy={times={[2]=0.65, [3]=0.25}, uses=200, maxlevel=1},
|
||||
snappy={times={[2]=0.70, [3]=0.25}, uses=200, maxlevel=1},
|
||||
choppy={times={[3]=0.65}, uses=200, maxlevel=0}
|
||||
}
|
||||
}
|
||||
})
|
||||
|
||||
-- Crafting
|
||||
|
||||
minetest.register_craft({
|
||||
output = 'moreores:copper_rail 15',
|
||||
recipe = {
|
||||
{'moreores:copper_ingot', '', 'moreores:copper_ingot'},
|
||||
{'moreores:copper_ingot', 'default:stick', 'moreores:copper_ingot'},
|
||||
{'moreores:copper_ingot', '', 'moreores:copper_ingot'},
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:pick_bronze" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:shovel_bronze" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:bronze_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:axe_bronze" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"', '' },
|
||||
{ 'craft "moreores:bronze_ingot"', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:sword_bronze" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:bronze_ingot"', '' },
|
||||
{ '', 'craft "moreores:bronze_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:pick_silver" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:shovel_silver" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:silver_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:axe_silver" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"', '' },
|
||||
{ 'craft "moreores:silver_ingot"', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:sword_silver" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:silver_ingot"', '' },
|
||||
{ '', 'craft "moreores:silver_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:pick_gold" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:shovel_gold" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:gold_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:axe_gold" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"', '' },
|
||||
{ 'craft "moreores:gold_ingot"', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:sword_gold" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:gold_ingot"', '' },
|
||||
{ '', 'craft "moreores:gold_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:pick_mithril" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:shovel_mithril" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:mithril_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:axe_mithril" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"', '' },
|
||||
{ 'craft "moreores:mithril_ingot"', 'craft "Stick"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:sword_mithril" 1',
|
||||
recipe = {
|
||||
{ '', 'craft "moreores:mithril_ingot"', '' },
|
||||
{ '', 'craft "moreores:mithril_ingot"', '' },
|
||||
{ '', 'craft "Stick"', '' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:bronze_ingot"',
|
||||
recipe = {
|
||||
{ 'craft "moreores:tin_ingot"'},
|
||||
{ 'craft "moreores:copper_ingot"'},
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:bronze_ingot"',
|
||||
recipe = {
|
||||
{ 'craft "moreores:copper_ingot"'},
|
||||
{ 'craft "moreores:tin_ingot"'},
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "moreores:gold_block" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"' },
|
||||
{ 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"' },
|
||||
{ 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"', 'craft "moreores:gold_ingot"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:gold_ingot" 9',
|
||||
recipe = {
|
||||
{ 'node "moreores:gold_block"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "moreores:silver_block" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"' },
|
||||
{ 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"' },
|
||||
{ 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"', 'craft "moreores:silver_ingot"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:silver_ingot" 9',
|
||||
recipe = {
|
||||
{ 'node "moreores:silver_block"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "moreores:bronze_block" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"' },
|
||||
{ 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"' },
|
||||
{ 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"', 'craft "moreores:bronze_ingot"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:bronze_ingot" 9',
|
||||
recipe = {
|
||||
{ 'node "moreores:bronze_block"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "moreores:mithril_block" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"' },
|
||||
{ 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"' },
|
||||
{ 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"', 'craft "moreores:mithril_ingot"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'craft "moreores:mithril_ingot" 9',
|
||||
recipe = {
|
||||
{ 'node "moreores:mithril_block"' },
|
||||
}
|
||||
})
|
||||
|
||||
-- Smelting
|
||||
|
||||
minetest.register_craft({
|
||||
type = "cooking",
|
||||
output = "moreores:gold_ingot",
|
||||
recipe = "moreores:gold_lump",
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
type = "cooking",
|
||||
output = "moreores:silver_ingot",
|
||||
recipe = "moreores:silver_lump",
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
type = "cooking",
|
||||
output = "moreores:tin_ingot",
|
||||
recipe = "moreores:tin_lump",
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
type = "cooking",
|
||||
output = "moreores:copper_ingot",
|
||||
recipe = "moreores:copper_lump",
|
||||
})
|
||||
|
||||
minetest.register_craft({
|
||||
type = "cooking",
|
||||
output = "moreores:mithril_ingot",
|
||||
recipe = "moreores:mithril_lump",
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "default:chest_locked" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:bronze_ingot"' },
|
||||
{ 'node "default:chest"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "default:chest_locked" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:silver_ingot"' },
|
||||
{ 'node "default:chest"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "default:chest_locked" 1',
|
||||
recipe = {
|
||||
{ 'craft "moreores:gold_ingot"' },
|
||||
{ 'node "default:chest"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "default:chest_locked" 1',
|
||||
recipe = {
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'craft "moreores:bronze_ingot"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "default:chest_locked" 1',
|
||||
recipe = {
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'craft "moreores:bronze_ingot"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "default:chest_locked" 1',
|
||||
recipe = {
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'craft "moreores:silver_ingot"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
}
|
||||
})
|
||||
|
||||
minetest.register_craft( {
|
||||
output = 'node "default:chest_locked" 1',
|
||||
recipe = {
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'craft "moreores:gold_ingot"', 'node "default:wood"' },
|
||||
{ 'node "default:wood"', 'node "default:wood"', 'node "default:wood"' },
|
||||
}
|
||||
})
|
||||
|
||||
-- Ore generation
|
||||
|
||||
local function generate_ore(name, wherein, minp, maxp, seed, chunks_per_volume, ore_per_chunk, height_min, height_max)
|
||||
if maxp.y < height_min or minp.y > height_max then
|
||||
return
|
||||
end
|
||||
local y_min = math.max(minp.y, height_min)
|
||||
local y_max = math.min(maxp.y, height_max)
|
||||
local volume = (maxp.x-minp.x+1)*(y_max-y_min+1)*(maxp.z-minp.z+1)
|
||||
local pr = PseudoRandom(seed)
|
||||
local num_chunks = math.floor(chunks_per_volume * volume)
|
||||
local chunk_size = 3
|
||||
if ore_per_chunk <= 4 then
|
||||
chunk_size = 2
|
||||
end
|
||||
local inverse_chance = math.floor(chunk_size*chunk_size*chunk_size / ore_per_chunk)
|
||||
--print("generate_ore num_chunks: "..dump(num_chunks))
|
||||
for i=1,num_chunks do
|
||||
if (y_max-chunk_size+1 <= y_min) then return end
|
||||
local y0 = pr:next(y_min, y_max-chunk_size+1)
|
||||
if y0 >= height_min and y0 <= height_max then
|
||||
local x0 = pr:next(minp.x, maxp.x-chunk_size+1)
|
||||
local z0 = pr:next(minp.z, maxp.z-chunk_size+1)
|
||||
local p0 = {x=x0, y=y0, z=z0}
|
||||
for x1=0,chunk_size-1 do
|
||||
for y1=0,chunk_size-1 do
|
||||
for z1=0,chunk_size-1 do
|
||||
if pr:next(1,inverse_chance) == 1 then
|
||||
local x2 = x0+x1
|
||||
local y2 = y0+y1
|
||||
local z2 = z0+z1
|
||||
local p2 = {x=x2, y=y2, z=z2}
|
||||
if minetest.env:get_node(p2).name == wherein then
|
||||
minetest.env:set_node(p2, {name=name})
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
--print("generate_ore done")
|
||||
end
|
||||
|
||||
minetest.register_on_generated(function(minp, maxp, seed)
|
||||
generate_ore("moreores:mineral_copper", "default:stone", minp, maxp, seed+16, 1/11/11/11, 8, -31000, 64)
|
||||
generate_ore("moreores:mineral_tin", "default:stone", minp, maxp, seed+17, 1/8/8/8, 2, -31000, 8)
|
||||
generate_ore("moreores:mineral_silver", "default:stone", minp, maxp, seed+18, 1/10/10/10, 5, -31000, 2)
|
||||
generate_ore("moreores:mineral_gold", "default:stone", minp, maxp, seed+19, 1/12/12/12, 5, -31000, -64)
|
||||
generate_ore("moreores:mineral_mithril", "default:stone", minp, maxp, seed+20, 1/6/6/6, 1, -31000, -512)
|
||||
end)
|
Before Width: | Height: | Size: 277 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 341 B After Width: | Height: | Size: 214 B |
Before Width: | Height: | Size: 249 B After Width: | Height: | Size: 128 B |
Before Width: | Height: | Size: 362 B After Width: | Height: | Size: 214 B |
Before Width: | Height: | Size: 382 B After Width: | Height: | Size: 225 B |
Before Width: | Height: | Size: 546 B After Width: | Height: | Size: 437 B |
Before Width: | Height: | Size: 581 B After Width: | Height: | Size: 389 B |
Before Width: | Height: | Size: 576 B After Width: | Height: | Size: 374 B |
Before Width: | Height: | Size: 577 B After Width: | Height: | Size: 374 B |
Before Width: | Height: | Size: 277 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 358 B After Width: | Height: | Size: 214 B |
Before Width: | Height: | Size: 364 B After Width: | Height: | Size: 221 B |
Before Width: | Height: | Size: 258 B After Width: | Height: | Size: 153 B |
Before Width: | Height: | Size: 222 B After Width: | Height: | Size: 153 B |
Before Width: | Height: | Size: 238 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 259 B After Width: | Height: | Size: 153 B |
Before Width: | Height: | Size: 254 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 614 B After Width: | Height: | Size: 372 B |
Before Width: | Height: | Size: 346 B After Width: | Height: | Size: 214 B |
Before Width: | Height: | Size: 365 B After Width: | Height: | Size: 221 B |
Before Width: | Height: | Size: 270 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 350 B After Width: | Height: | Size: 214 B |
Before Width: | Height: | Size: 356 B After Width: | Height: | Size: 221 B |
Before Width: | Height: | Size: 269 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 361 B After Width: | Height: | Size: 214 B |
Before Width: | Height: | Size: 361 B After Width: | Height: | Size: 225 B |
Before Width: | Height: | Size: 224 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 286 B After Width: | Height: | Size: 160 B |
Before Width: | Height: | Size: 253 B After Width: | Height: | Size: 148 B |
Before Width: | Height: | Size: 274 B After Width: | Height: | Size: 172 B |
Before Width: | Height: | Size: 225 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 294 B After Width: | Height: | Size: 171 B |
Before Width: | Height: | Size: 256 B After Width: | Height: | Size: 148 B |
Before Width: | Height: | Size: 275 B After Width: | Height: | Size: 172 B |
Before Width: | Height: | Size: 211 B After Width: | Height: | Size: 140 B |
Before Width: | Height: | Size: 337 B After Width: | Height: | Size: 203 B |
Before Width: | Height: | Size: 279 B After Width: | Height: | Size: 165 B |
Before Width: | Height: | Size: 242 B After Width: | Height: | Size: 148 B |
Before Width: | Height: | Size: 296 B After Width: | Height: | Size: 172 B |
Before Width: | Height: | Size: 218 B After Width: | Height: | Size: 142 B |
Before Width: | Height: | Size: 337 B After Width: | Height: | Size: 202 B |
Before Width: | Height: | Size: 290 B After Width: | Height: | Size: 166 B |
Before Width: | Height: | Size: 254 B After Width: | Height: | Size: 148 B |
Before Width: | Height: | Size: 299 B After Width: | Height: | Size: 172 B |