mirror of
https://github.com/minetest-mods/moreores.git
synced 2024-12-22 22:02:28 +01:00
Rewrite the code.
This commit is contained in:
parent
0977bbc809
commit
038aefb114
266
init.lua
266
init.lua
@ -14,8 +14,8 @@ dofile(minetest.get_modpath("moreores").."/_config.txt")
|
|||||||
****
|
****
|
||||||
More Ores
|
More Ores
|
||||||
by Calinou
|
by Calinou
|
||||||
with the help of MarkTraceur, GloopMaster and Kotolegokot
|
with the help of Nore/Novatux
|
||||||
Licensed under GPLv3+ for code and CC BY-SA for textures, see: http://www.gnu.org/licenses/gpl-3.0.html
|
Licensed under the CC0
|
||||||
****
|
****
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
@ -23,34 +23,66 @@ Licensed under GPLv3+ for code and CC BY-SA for textures, see: http://www.gnu.or
|
|||||||
|
|
||||||
local default_stone_sounds = default.node_sound_stone_defaults()
|
local default_stone_sounds = default.node_sound_stone_defaults()
|
||||||
|
|
||||||
local stick = "default:stick"
|
local function hoe_on_use(itemstack, user, pointed_thing, uses)
|
||||||
local recipes = {
|
local pt = pointed_thing
|
||||||
sword = {{"m"}, {"m"}, {stick}},
|
-- check if pointing at a node
|
||||||
shovel = {{"m"}, {stick}, {stick}},
|
if not pt then
|
||||||
axe = {{"m", "m"}, {"m", stick}, {"" , stick}},
|
return
|
||||||
pick = {{"m", "m", "m"}, {"", stick, ""}, {"", stick, ""}}
|
end
|
||||||
}
|
if pt.type ~= "node" then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
local function get_tool_recipe(craftitem, toolname)
|
local under = minetest.get_node(pt.under)
|
||||||
local orig = recipes[toolname]
|
local p = {x=pt.under.x, y=pt.under.y+1, z=pt.under.z}
|
||||||
local complete = {}
|
local above = minetest.get_node(p)
|
||||||
for i, row in ipairs(orig) do
|
|
||||||
local thisrow = {}
|
-- return if any of the nodes is not registered
|
||||||
for j, col in ipairs(row) do
|
if not minetest.registered_nodes[under.name] then
|
||||||
if col == "m" then
|
return
|
||||||
table.insert(thisrow, craftitem)
|
|
||||||
else
|
|
||||||
table.insert(thisrow, col)
|
|
||||||
end
|
end
|
||||||
|
if not minetest.registered_nodes[above.name] then
|
||||||
|
return
|
||||||
end
|
end
|
||||||
table.insert(complete, thisrow)
|
|
||||||
|
-- check if the node above the pointed thing is air
|
||||||
|
if above.name ~= "air" then
|
||||||
|
return
|
||||||
end
|
end
|
||||||
return complete
|
|
||||||
|
-- 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
|
end
|
||||||
|
|
||||||
local function add_ore(modname, mineral_name, oredef)
|
local function get_recipe(c, name)
|
||||||
local firstlet = string.upper(string.sub(mineral_name, 1, 1))
|
if name == "sword":
|
||||||
local description = firstlet .. string.sub(mineral_name, 2)
|
return {{c},{c},{"default:stick"}}
|
||||||
|
if name == "shovel":
|
||||||
|
return {{c},{"default:stick"},{"default:stick"}}
|
||||||
|
if name == "axe":
|
||||||
|
return {{c,c},{c,"default:stick"},{"","default:stick"}}
|
||||||
|
if name == "pick":
|
||||||
|
return {{c,c,c},{"","default:stick",""},{"","default:stick",""}}
|
||||||
|
if name == "hoe":
|
||||||
|
return {{c,c},{"","default:stick"},{"","default:stick"}}
|
||||||
|
if name == "block":
|
||||||
|
return {{c,c,c},{c,c,c},{c,c,c}}
|
||||||
|
if name == "lockedchest":
|
||||||
|
return {{"default:wood","default:wood","default:wood"},{"default:wood",c,"default:wood"},{"default:wood","default:wood","default:wood"}}
|
||||||
|
end
|
||||||
|
|
||||||
|
local function add_ore(modname, description, mineral_name, oredef)
|
||||||
local img_base = modname .. "_" .. mineral_name
|
local img_base = modname .. "_" .. mineral_name
|
||||||
local toolimg_base = modname .. "_tool_"..mineral_name
|
local toolimg_base = modname .. "_tool_"..mineral_name
|
||||||
local tool_base = modname .. ":"
|
local tool_base = modname .. ":"
|
||||||
@ -61,13 +93,12 @@ local function add_ore(modname, mineral_name, oredef)
|
|||||||
local ingotcraft = ingot
|
local ingotcraft = ingot
|
||||||
|
|
||||||
if oredef.makes.ore then
|
if oredef.makes.ore then
|
||||||
local mineral_img_base = modname .. "_mineral_"..mineral_name
|
|
||||||
minetest.register_node(modname .. ":mineral_"..mineral_name, {
|
minetest.register_node(modname .. ":mineral_"..mineral_name, {
|
||||||
description = S("%s Ore"):format(S(description)),
|
description = S("%s Ore"):format(S(description)),
|
||||||
tiles = {"default_stone.png^"..mineral_img_base..".png"},
|
tiles = {"default_stone.png^"..modname.."_mineral_"..mineral_name..".png"},
|
||||||
groups = {cracky=3},
|
groups = {cracky=3},
|
||||||
sounds = default_stone_sounds,
|
sounds = default_stone_sounds,
|
||||||
drop = item_base .. "_lump 1"
|
drop = lumpitem
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -80,25 +111,24 @@ local function add_ore(modname, mineral_name, oredef)
|
|||||||
sounds = default_stone_sounds
|
sounds = default_stone_sounds
|
||||||
})
|
})
|
||||||
minetest.register_alias(mineral_name.."_block", blockitem)
|
minetest.register_alias(mineral_name.."_block", blockitem)
|
||||||
local ingotrow = {ingot, ingot, ingot}
|
if oredef.makes.ingot then
|
||||||
local nodeblockitem = "node " .. blockitem .. ""
|
|
||||||
minetest.register_craft( {
|
minetest.register_craft( {
|
||||||
output = nodeblockitem,
|
output = blockitem,
|
||||||
recipe = {ingotrow, ingotrow, ingotrow}
|
recipe = get_recipe(ingot, "block")
|
||||||
})
|
})
|
||||||
minetest.register_craft( {
|
minetest.register_craft( {
|
||||||
output = "craft " .. ingot .. " 9",
|
output = ingot .. " 9",
|
||||||
recipe = {
|
recipe = {
|
||||||
{ nodeblockitem }
|
{ blockitem }
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
if oredef.makes.lump then
|
if oredef.makes.lump then
|
||||||
minetest.register_craftitem(lumpitem, {
|
minetest.register_craftitem(lumpitem, {
|
||||||
description = S("%s Lump"):format(S(description)),
|
description = S("%s Lump"):format(S(description)),
|
||||||
inventory_image = img_base .. "_lump.png",
|
inventory_image = img_base .. "_lump.png",
|
||||||
on_place_on_ground = minetest.craftitem_place_item
|
|
||||||
})
|
})
|
||||||
minetest.register_alias(mineral_name .. "_lump", lumpitem)
|
minetest.register_alias(mineral_name .. "_lump", lumpitem)
|
||||||
if oredef.makes.ingot then
|
if oredef.makes.ingot then
|
||||||
@ -114,33 +144,31 @@ local function add_ore(modname, mineral_name, oredef)
|
|||||||
minetest.register_craftitem(ingot, {
|
minetest.register_craftitem(ingot, {
|
||||||
description = S("%s Ingot"):format(S(description)),
|
description = S("%s Ingot"):format(S(description)),
|
||||||
inventory_image = img_base .. "_ingot.png",
|
inventory_image = img_base .. "_ingot.png",
|
||||||
on_place_on_ground = minetest.craftitem_place_item
|
|
||||||
})
|
})
|
||||||
minetest.register_alias(mineral_name .. "_ingot", ingot)
|
minetest.register_alias(mineral_name .. "_ingot", ingot)
|
||||||
if oredef.makes.chest then
|
|
||||||
minetest.register_craft( {
|
|
||||||
output = "node default:chest_locked 1",
|
|
||||||
recipe = {
|
|
||||||
{ ingotcraft },
|
|
||||||
{ "node default:chest" }
|
|
||||||
}
|
|
||||||
})
|
|
||||||
wood = "node default:wood"
|
|
||||||
woodrow = {wood,wood,wood}
|
|
||||||
minetest.register_craft( {
|
|
||||||
output = "node default:chest_locked 1",
|
|
||||||
recipe = {
|
|
||||||
woodrow,
|
|
||||||
{wood, ingotcraft, wood},
|
|
||||||
woodrow
|
|
||||||
}
|
|
||||||
})
|
|
||||||
end
|
|
||||||
end
|
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.wherein = "default:stone"
|
||||||
|
|
||||||
|
minetest.register_ore(oredef)
|
||||||
|
|
||||||
for toolname, tooldef in pairs(oredef.tools) do
|
for toolname, tooldef in pairs(oredef.tools) do
|
||||||
local tflet = string.upper(string.sub(toolname, 0, 1))
|
|
||||||
local tool_description = tflet..string.sub(toolname, 2)
|
|
||||||
local tdef = {
|
local tdef = {
|
||||||
description = "",
|
description = "",
|
||||||
inventory_image = toolimg_base .. toolname .. ".png",
|
inventory_image = toolimg_base .. toolname .. ".png",
|
||||||
@ -167,13 +195,22 @@ local function add_ore(modname, mineral_name, oredef)
|
|||||||
tdef.description = S("%s Shovel"):format(S(description))
|
tdef.description = S("%s Shovel"):format(S(description))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if toolname == "hoe" then
|
||||||
|
tdef.description = S("%s Hoe"):format(S(description))
|
||||||
|
local uses = tdef.uses
|
||||||
|
tdef.uses = nil
|
||||||
|
tdef.on_use = function(itemstack, user, pointed_thing)
|
||||||
|
return hoe_on_use(itemstack, user, pointed_thing, uses)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local fulltoolname = tool_base .. toolname .. tool_post
|
local fulltoolname = tool_base .. toolname .. tool_post
|
||||||
minetest.register_tool(fulltoolname, tdef)
|
minetest.register_tool(fulltoolname, tdef)
|
||||||
minetest.register_alias(toolname .. tool_post, fulltoolname)
|
minetest.register_alias(toolname .. tool_post, fulltoolname)
|
||||||
if oredef.makes.ingot then
|
if oredef.makes.ingot then
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "craft " .. fulltoolname .. " 1",
|
output = fulltoolname,
|
||||||
recipe = get_tool_recipe(item_base .. "_ingot", toolname)
|
recipe = get_tool_recipe(ingot, toolname)
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -186,10 +223,19 @@ local modname = "moreores"
|
|||||||
local oredefs = {
|
local oredefs = {
|
||||||
silver = {
|
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,
|
||||||
|
height_min = moreores_silver_min_depth,
|
||||||
|
height_max = moreores_silver_max_depth
|
||||||
|
},
|
||||||
tools = {
|
tools = {
|
||||||
pick = {
|
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 = {
|
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}
|
||||||
},
|
},
|
||||||
@ -207,14 +253,29 @@ local oredefs = {
|
|||||||
},
|
},
|
||||||
tin = {
|
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,
|
||||||
|
height_min = moreores_tin_min_depth,
|
||||||
|
height_max = moreores_tin_max_depth
|
||||||
|
},
|
||||||
tools = {}
|
tools = {}
|
||||||
},
|
},
|
||||||
mithril = {
|
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,
|
||||||
|
height_min = moreores_mithril_min_depth,
|
||||||
|
height_max = moreores_mithril_max_depth
|
||||||
|
},
|
||||||
tools = {
|
tools = {
|
||||||
pick = {
|
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 = {
|
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}
|
||||||
},
|
},
|
||||||
@ -241,9 +302,9 @@ end
|
|||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "moreores:copper_rail 16",
|
output = "moreores:copper_rail 16",
|
||||||
recipe = {
|
recipe = {
|
||||||
{"moreores:copper_ingot", "", "moreores:copper_ingot"},
|
{"default:copper_ingot", "", "default:copper_ingot"},
|
||||||
{"moreores:copper_ingot", "default:stick", "moreores:copper_ingot"},
|
{"default:copper_ingot", "default:stick", "default:copper_ingot"},
|
||||||
{"moreores:copper_ingot", "", "moreores:copper_ingot"}
|
{"default:copper_ingot", "", "default:copper_ingot"}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -251,11 +312,11 @@ minetest.register_craft({
|
|||||||
|
|
||||||
minetest.register_craft( {
|
minetest.register_craft( {
|
||||||
type = "shapeless",
|
type = "shapeless",
|
||||||
output = "moreores:bronze_ingot 3",
|
output = "default:bronze_ingot 3",
|
||||||
recipe = {
|
recipe = {
|
||||||
"moreores:tin_ingot",
|
"moreores:tin_ingot",
|
||||||
"moreores:copper_ingot",
|
"default:copper_ingot",
|
||||||
"moreores:copper_ingot",
|
"default:copper_ingot",
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -278,87 +339,14 @@ minetest.register_node("moreores:copper_rail", {
|
|||||||
mesecons = {
|
mesecons = {
|
||||||
effector = {
|
effector = {
|
||||||
action_on = function(pos, node)
|
action_on = function(pos, node)
|
||||||
minetest.env:get_meta(pos):set_string("cart_acceleration", "0.5")
|
minetest.get_meta(pos):set_string("cart_acceleration", "0.5")
|
||||||
end,
|
end,
|
||||||
|
|
||||||
action_off = function(pos, node)
|
action_off = function(pos, node)
|
||||||
minetest.env:get_meta(pos):set_string("cart_acceleration", "0")
|
minetest.get_meta(pos):set_string("cart_acceleration", "0")
|
||||||
end,
|
end,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
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_ore({
|
|
||||||
ore_type = "scatter",
|
|
||||||
ore = "moreores:mineral_tin",
|
|
||||||
wherein = "default:stone",
|
|
||||||
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,
|
|
||||||
height_min = moreores_tin_min_depth,
|
|
||||||
height_max = moreores_tin_max_depth
|
|
||||||
})
|
|
||||||
minetest.register_ore({
|
|
||||||
ore_type = "scatter",
|
|
||||||
ore = "moreores:mineral_silver",
|
|
||||||
wherein = "default:stone",
|
|
||||||
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,
|
|
||||||
height_min = moreores_silver_min_depth,
|
|
||||||
height_max = moreores_silver_max_depth
|
|
||||||
})
|
|
||||||
minetest.register_ore({
|
|
||||||
ore_type = "scatter",
|
|
||||||
ore = "moreores:mineral_mithril",
|
|
||||||
wherein = "default:stone",
|
|
||||||
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,
|
|
||||||
height_min = moreores_mithril_min_depth,
|
|
||||||
height_max = moreores_mithril_max_depth
|
|
||||||
})
|
|
||||||
|
|
||||||
print(S("[moreores] loaded."))
|
print(S("[moreores] loaded."))
|
||||||
|
Loading…
Reference in New Issue
Block a user