From e315dd323532b07e77c9e9975bbc7dafff3bd2cf Mon Sep 17 00:00:00 2001 From: Calinou Date: Thu, 11 Jul 2013 20:32:45 +0200 Subject: [PATCH] More Ores --- LICENSE.txt | 17 + README.md | 2 - README.txt | 22 + _config.txt | 35 + depends.txt | 1 + init.lua | 364 +++++++++ locale/es.txt | 21 + locale/fr.txt | 21 + old_init.lua | 745 +++++++++++++++++++ textures/moreores_bronze_block.png | Bin 0 -> 277 bytes textures/moreores_bronze_ingot.png | Bin 0 -> 341 bytes textures/moreores_copper_block.png | Bin 0 -> 249 bytes textures/moreores_copper_ingot.png | Bin 0 -> 362 bytes textures/moreores_copper_lump.png | Bin 0 -> 382 bytes textures/moreores_copper_rail.png | Bin 0 -> 546 bytes textures/moreores_copper_rail_crossing.png | Bin 0 -> 581 bytes textures/moreores_copper_rail_curved.png | Bin 0 -> 576 bytes textures/moreores_copper_rail_t_junction.png | Bin 0 -> 577 bytes textures/moreores_gold_block.png | Bin 0 -> 277 bytes textures/moreores_gold_ingot.png | Bin 0 -> 358 bytes textures/moreores_gold_lump.png | Bin 0 -> 364 bytes textures/moreores_mineral_copper.png | Bin 0 -> 258 bytes textures/moreores_mineral_gold.png | Bin 0 -> 222 bytes textures/moreores_mineral_mithril.png | Bin 0 -> 238 bytes textures/moreores_mineral_silver.png | Bin 0 -> 259 bytes textures/moreores_mineral_tin.png | Bin 0 -> 254 bytes textures/moreores_mithril_block.png | Bin 0 -> 614 bytes textures/moreores_mithril_ingot.png | Bin 0 -> 346 bytes textures/moreores_mithril_lump.png | Bin 0 -> 365 bytes textures/moreores_silver_block.png | Bin 0 -> 270 bytes textures/moreores_silver_ingot.png | Bin 0 -> 350 bytes textures/moreores_silver_lump.png | Bin 0 -> 356 bytes textures/moreores_tin_block.png | Bin 0 -> 269 bytes textures/moreores_tin_ingot.png | Bin 0 -> 361 bytes textures/moreores_tin_lump.png | Bin 0 -> 361 bytes textures/moreores_tool_bronzeaxe.png | Bin 0 -> 224 bytes textures/moreores_tool_bronzepick.png | Bin 0 -> 286 bytes textures/moreores_tool_bronzeshovel.png | Bin 0 -> 253 bytes textures/moreores_tool_bronzesword.png | Bin 0 -> 274 bytes textures/moreores_tool_goldaxe.png | Bin 0 -> 225 bytes textures/moreores_tool_goldpick.png | Bin 0 -> 294 bytes textures/moreores_tool_goldshovel.png | Bin 0 -> 256 bytes textures/moreores_tool_goldsword.png | Bin 0 -> 275 bytes textures/moreores_tool_mithrilaxe.png | Bin 0 -> 211 bytes textures/moreores_tool_mithrilpick.png | Bin 0 -> 279 bytes textures/moreores_tool_mithrilshovel.png | Bin 0 -> 242 bytes textures/moreores_tool_mithrilsword.png | Bin 0 -> 296 bytes textures/moreores_tool_silveraxe.png | Bin 0 -> 218 bytes textures/moreores_tool_silverpick.png | Bin 0 -> 290 bytes textures/moreores_tool_silvershovel.png | Bin 0 -> 254 bytes textures/moreores_tool_silversword.png | Bin 0 -> 299 bytes 51 files changed, 1226 insertions(+), 2 deletions(-) create mode 100644 LICENSE.txt delete mode 100644 README.md create mode 100644 README.txt create mode 100644 _config.txt create mode 100644 depends.txt create mode 100644 init.lua create mode 100644 locale/es.txt create mode 100644 locale/fr.txt create mode 100644 old_init.lua create mode 100644 textures/moreores_bronze_block.png create mode 100644 textures/moreores_bronze_ingot.png create mode 100644 textures/moreores_copper_block.png create mode 100644 textures/moreores_copper_ingot.png create mode 100644 textures/moreores_copper_lump.png create mode 100644 textures/moreores_copper_rail.png create mode 100644 textures/moreores_copper_rail_crossing.png create mode 100644 textures/moreores_copper_rail_curved.png create mode 100644 textures/moreores_copper_rail_t_junction.png create mode 100644 textures/moreores_gold_block.png create mode 100644 textures/moreores_gold_ingot.png create mode 100644 textures/moreores_gold_lump.png create mode 100644 textures/moreores_mineral_copper.png create mode 100644 textures/moreores_mineral_gold.png create mode 100644 textures/moreores_mineral_mithril.png create mode 100644 textures/moreores_mineral_silver.png create mode 100644 textures/moreores_mineral_tin.png create mode 100644 textures/moreores_mithril_block.png create mode 100644 textures/moreores_mithril_ingot.png create mode 100644 textures/moreores_mithril_lump.png create mode 100644 textures/moreores_silver_block.png create mode 100644 textures/moreores_silver_ingot.png create mode 100644 textures/moreores_silver_lump.png create mode 100644 textures/moreores_tin_block.png create mode 100644 textures/moreores_tin_ingot.png create mode 100644 textures/moreores_tin_lump.png create mode 100644 textures/moreores_tool_bronzeaxe.png create mode 100644 textures/moreores_tool_bronzepick.png create mode 100644 textures/moreores_tool_bronzeshovel.png create mode 100644 textures/moreores_tool_bronzesword.png create mode 100644 textures/moreores_tool_goldaxe.png create mode 100644 textures/moreores_tool_goldpick.png create mode 100644 textures/moreores_tool_goldshovel.png create mode 100644 textures/moreores_tool_goldsword.png create mode 100644 textures/moreores_tool_mithrilaxe.png create mode 100644 textures/moreores_tool_mithrilpick.png create mode 100644 textures/moreores_tool_mithrilshovel.png create mode 100644 textures/moreores_tool_mithrilsword.png create mode 100644 textures/moreores_tool_silveraxe.png create mode 100644 textures/moreores_tool_silverpick.png create mode 100644 textures/moreores_tool_silvershovel.png create mode 100644 textures/moreores_tool_silversword.png diff --git a/LICENSE.txt b/LICENSE.txt new file mode 100644 index 0000000..2499ee9 --- /dev/null +++ b/LICENSE.txt @@ -0,0 +1,17 @@ ++---- GNU GPL v3 ----+ + +More Ores -- a Minetest mod that adds ores. +Copyright (C) 2013 Calinou + +This program is free software: you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation, either version 3 of the License, or +(at your option) any later version. + +This program is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with this program. If not, see . diff --git a/README.md b/README.md deleted file mode 100644 index ff4c483..0000000 --- a/README.md +++ /dev/null @@ -1,2 +0,0 @@ -moreores -======== diff --git a/README.txt b/README.txt new file mode 100644 index 0000000..4c15581 --- /dev/null +++ b/README.txt @@ -0,0 +1,22 @@ +Calinou's Minetest Mods +===================== + +Calinou's Mods for Minetest [http://minetest.net], a free and opensource Minecraft-like game. + +This Git repository is mostly made for servers; it allows easy updating. + +To install, just clone this repository somewhere, then copy the "calinou_mods" folder in the "mods/minetest" folder of Minetest's installation folder. + + + +Misc stuff +===================== + +All these mods' source codes, except More Ores are under the zlib/libpng license. More Ores is under the GNU GPLv3; the mods' textures are under the CC BY-SA 3.0 Unported. + +Mods' forum threads: +More Blocks: http://minetest.net/forum/viewtopic.php?id=509 +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 diff --git a/_config.txt b/_config.txt new file mode 100644 index 0000000..68c6658 --- /dev/null +++ b/_config.txt @@ -0,0 +1,35 @@ +------------------------------------------------------------------------------ +------------------------------ CONFIGURATION --------------------------------- +------------------------------------------------------------------------------ + +------------------------------------------------------------------------------ +-------- Change settings by changing the values after the "=". --------------- +------------------------------------------------------------------------------ + +-- Chunk sizes for ore generation (bigger = ore deposits are more scattered around) +moreores_copper_chunk_size = 8 +moreores_tin_chunk_size = 7 +moreores_silver_chunk_size = 11 +moreores_gold_chunk_size = 14 +moreores_mithril_chunk_size = 11 + +-- Amount of ore per chunk (higher = bigger ore deposits) +moreores_copper_ore_per_chunk = 8 +moreores_tin_ore_per_chunk = 3 +moreores_silver_ore_per_chunk = 4 +moreores_gold_ore_per_chunk = 4 +moreores_mithril_ore_per_chunk = 1 + +-- Minimal depths of ore generation (Y coordinate, 0 being sea level by default) +moreores_copper_min_depth = -31000 +moreores_tin_min_depth = -31000 +moreores_silver_min_depth = -31000 +moreores_gold_min_depth = -31000 +moreores_mithril_min_depth = -31000 + +-- Maximal depths of ore generation (Y coordinate, 0 being sea level by default) +moreores_copper_max_depth = 64 +moreores_tin_max_depth = 8 +moreores_silver_max_depth = -2 +moreores_gold_max_depth = -64 +moreores_mithril_max_depth = -512 diff --git a/depends.txt b/depends.txt new file mode 100644 index 0000000..331d858 --- /dev/null +++ b/depends.txt @@ -0,0 +1 @@ +default \ No newline at end of file diff --git a/init.lua b/init.lua new file mode 100644 index 0000000..86f66eb --- /dev/null +++ b/init.lua @@ -0,0 +1,364 @@ +-- Load translation library if intllib is installed + +local S +if (minetest.get_modpath("intllib")) then + dofile(minetest.get_modpath("intllib").."/intllib.lua") + S = intllib.Getter(minetest.get_current_modname()) + else + S = function ( s ) return s end +end + +dofile(minetest.get_modpath("moreores").."/_config.txt") + +print(S("[moreores] loaded.")) + +--[[ +**** +More Ores +by Calinou +with the help of MarkTraceur, GloopMaster and Kotolegokot +Licensed under GPLv3+ for code and CC BY-SA for textures, see: http://www.gnu.org/licenses/gpl-3.0.html +**** +--]] + +-- Utility functions + +local default_stone_sounds = default.node_sound_stone_defaults() + +local stick = "default:stick" +local recipes = { + sword = {{"m"}, {"m"}, {stick}}, + shovel = {{"m"}, {stick}, {stick}}, + axe = {{"m", "m"}, {"m", stick}, {"" , stick}}, + pick = {{"m", "m", "m"}, {"", stick, ""}, {"", stick, ""}} +} + +local function get_tool_recipe(craftitem, toolname) + local orig = recipes[toolname] + local complete = {} + for i, row in ipairs(orig) do + local thisrow = {} + for j, col in ipairs(row) do + if col == "m" then + table.insert(thisrow, craftitem) + else + table.insert(thisrow, col) + end + end + table.insert(complete, thisrow) + end + return complete +end + +local function add_ore(modname, mineral_name, oredef) + local firstlet = string.upper(string.sub(mineral_name, 1, 1)) + local description = firstlet .. string.sub(mineral_name, 2) + local img_base = modname .. "_" .. mineral_name + local toolimg_base = modname .. "_tool_"..mineral_name + local tool_base = modname .. ":" + local tool_post = "_" .. mineral_name + local item_base = tool_base .. mineral_name + local ingot = item_base .. "_ingot" + local lumpitem = item_base .. "_lump" + local ingotcraft = ingot + + if oredef.makes.ore then + local mineral_img_base = modname .. "_mineral_"..mineral_name + minetest.register_node(modname .. ":mineral_"..mineral_name, { + description = S("%s Ore"):format(S(description)), + tiles = {"default_stone.png^"..mineral_img_base..".png"}, + groups = {cracky=3}, + sounds = default_stone_sounds, + drop = item_base .. "_lump 1" + }) + end + + if oredef.makes.block then + local blockitem = item_base .. "_block" + 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}, + sounds = default_stone_sounds + }) + minetest.register_alias(mineral_name.."_block", blockitem) + local ingotrow = {ingot, ingot, ingot} + local nodeblockitem = "node " .. blockitem .. "" + minetest.register_craft( { + output = nodeblockitem, + recipe = {ingotrow, ingotrow, ingotrow} + }) + minetest.register_craft( { + output = "craft " .. ingot .. " 9", + recipe = { + { nodeblockitem } + } + }) + end + + if oredef.makes.lump then + minetest.register_craftitem(lumpitem, { + description = S("%s Lump"):format(S(description)), + inventory_image = img_base .. "_lump.png", + on_place_on_ground = minetest.craftitem_place_item + }) + minetest.register_alias(mineral_name .. "_lump", lumpitem) + if oredef.makes.ingot then + minetest.register_craft({ + type = "cooking", + output = ingot, + recipe = lumpitem + }) + end + end + + if oredef.makes.ingot then + minetest.register_craftitem(ingot, { + description = S("%s Ingot"):format(S(description)), + inventory_image = img_base .. "_ingot.png", + on_place_on_ground = minetest.craftitem_place_item + }) + 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 + + 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 = { + description = "", + inventory_image = toolimg_base .. toolname .. ".png", + tool_capabilities = { + max_drop_level=3, + groupcaps=tooldef + } + } + + if toolname == "sword" then + tdef.full_punch_interval = oredef.punchint + tdef.description = S("%s Sword"):format(S(description)) + end + + if toolname == "pick" then + tdef.description = S("%s Pickaxe"):format(S(description)) + end + + if toolname == "axe" then + tdef.description = S("%s Axe"):format(S(description)) + end + + if toolname == "shovel" then + tdef.description = S("%s Shovel"):format(S(description)) + end + + local fulltoolname = tool_base .. toolname .. tool_post + minetest.register_tool(fulltoolname, tdef) + minetest.register_alias(toolname .. tool_post, fulltoolname) + if oredef.makes.ingot then + minetest.register_craft({ + output = "craft " .. fulltoolname .. " 1", + recipe = get_tool_recipe(item_base .. "_ingot", toolname) + }) + end + end +end + +-- Add everything (compact(ish)!) + +local modname = "moreores" + +local oredefs = { + silver = { + makes = {ore=true, block=true, lump=true, ingot=true, chest=true}, + tools = { + pick = { + cracky={times={[1]=2.60, [2]=1.00, [3]=0.60}, uses=100, maxlevel=1} + }, + shovel = { + 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} + }, + 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} + } + }, + punchint = 1.0 + }, + tin = { + makes = {ore=true, block=true, lump=true, ingot=true, chest=false}, + tools = {} + }, + mithril = { + makes = {ore=true, block=true, lump=true, ingot=true, chest=false}, + tools = { + pick = { + cracky={times={[1]=2.25, [2]=0.55, [3]=0.35}, uses=200, maxlevel=1} + }, + shovel = { + 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} + }, + 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} + } + }, + punchint = 0.45 + } +} + +for orename,def in pairs(oredefs) do + add_ore(modname, orename, def) +end + +-- Copper rail (special node) + +minetest.register_craft({ + output = "moreores:copper_rail 16", + recipe = { + {"moreores:copper_ingot", "", "moreores:copper_ingot"}, + {"moreores:copper_ingot", "default:stick", "moreores:copper_ingot"}, + {"moreores:copper_ingot", "", "moreores:copper_ingot"} + } +}) + +-- Bronze has some special cases, because it is made from copper and tin + +minetest.register_craft( { + type = "shapeless", + output = "moreores:bronze_ingot 3", + recipe = { + "moreores:tin_ingot", + "moreores:copper_ingot", + "moreores:copper_ingot", + } +}) + +-- Unique node + +minetest.register_node("moreores:copper_rail", { + description = S("Copper Rail"), + drawtype = "raillike", + tiles = {"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", + sunlight_propagates = true, + walkable = false, + selection_box = { + 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}, + mesecons = { + effector = { + action_on = function(pos, node) + minetest.env:get_meta(pos):set_string("cart_acceleration", "0.5") + end, + + action_off = function(pos, node) + minetest.env:get_meta(pos):set_string("cart_acceleration", "0") + 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 + }) diff --git a/locale/es.txt b/locale/es.txt new file mode 100644 index 0000000..1344a5a --- /dev/null +++ b/locale/es.txt @@ -0,0 +1,21 @@ +# Translation by kaeza + +[moreores] loaded. = [moreores] cargado. + +%s Ore = Mineral de %s +%s Lump = Pepita de %s +%s Ingot = Lingote de %s +%s Block = Bloque de %s +%s Pickaxe = Pico de %s +%s Shovel = Pala de %s +%s Axe = Hacha de %s +%s Sword = Espada de %s + +Copper = cobre +Tin = estaño +Bronze = bronce +Silver = plata +Gold = oro +Mithril = mitrilo + +Copper Rail = Riel de Cobre diff --git a/locale/fr.txt b/locale/fr.txt new file mode 100644 index 0000000..65687fa --- /dev/null +++ b/locale/fr.txt @@ -0,0 +1,21 @@ +# Translation by Calinou + +[moreores] loaded. = [moreores] a été chargé. + +%s Ore = Minerai en %s +%s Lump = Roche en %s +%s Ingot = Lingot en %s +%s Block = Bloc en %s +%s Pickaxe = Pioche en %s +%s Shovel = Pelle en %s +%s Axe = Hache en %s +%s Sword = Épée en %s + +Copper = cuivre +Tin = étain +Bronze = bronze +Silver = argent +Gold = or +Mithril = mithril + +Copper Rail = Rail en cuivre diff --git a/old_init.lua b/old_init.lua new file mode 100644 index 0000000..03be6bc --- /dev/null +++ b/old_init.lua @@ -0,0 +1,745 @@ +--[[ +**** +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 = + }, + 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) \ No newline at end of file diff --git a/textures/moreores_bronze_block.png b/textures/moreores_bronze_block.png new file mode 100644 index 0000000000000000000000000000000000000000..de6a34a2903f8e083b9b6f8dcef810eadd8ba5fb GIT binary patch literal 277 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=DinK$vl=HlH+5kiEpy*OmP)lZXft7a#MslR%+Go-U3d7N?g68S))g;3?5fk$cb^ z{)6++O8GbUmacyh*11wB^2C)BM<-ZxsY}-!|9R%^?>*)_1QuRpI{o}|S+Ycm8ztTP8_{U-hqZ9X?Yy_q)q2_AhHz@4sw1?`N%H>Sbv+zw?W(CRK$8& zOtbAxv%O=jJk*}=Yu)TDuh!vw;;_b17It<)s~tBRSeqwg=(};sv}fmB{!`iTE1K{5 zywAV+p3B{+_k7S5)4O!-x?Md_R(f{%3-hzB=yt!#IpKilwbic{U(IJ-IjeB{PDYiR zla^0?_CqN3>auCa*e0ZS|M7TyL*Ur{T!xxG1)o2hxf#gcwphyJi}t@iZ~3P@D~R?H zxiedI-T9S&ia3SlK5&;}IBvGpfbD(W=3Pu5mYq2HknO`i*4O#M-nx@kZT!fknjw85 j?adT(*R)tqe9e@UtDeE2c$S6t zz%ohOhM688^|#$fR9YesE4*v;3ufQyOZQZ9DUtc;tfo^^8A0*)niFb@tO+@475u)#^*J`bt}47EaL; zDm3_K;rV3Evl;pQbIRYj*x8vfOm;b!b*{j~ZKcS}Gdv8R7}otfc=<2y@!nv*Ra@>_VY^Nd@j-1Ckss299D`j&N#yp@;B6_??$d^>f&WBP5$NW zZ{Kc^v0t-yPqd)HM{%Z$`HoUEX6CKdT(9?P(%%#26&oAlQB>(^b literal 0 HcmV?d00001 diff --git a/textures/moreores_copper_lump.png b/textures/moreores_copper_lump.png new file mode 100644 index 0000000000000000000000000000000000000000..de03dcdff91846bf927eab72255dd385f012876a GIT binary patch literal 382 zcmV-^0fGLBP);(EaKForbU(gVEyvS!ql5{D7*I00^lV#e)06>tciGBcF;_e1uds zQAmX-%El|WO^-FX?r}Dqq94AY^yKF&9PO;zC56L;TvirSdcx(+owM{G>~5_Yz>4eC cdGSA~Pkk_aY_C{n4*&oF07*qoM6N<$f@DykeEPx#24YJ`L;(K){{a7>y{D4^000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2iyf4 z3?d+N7PgiE00E*&L_t(I%gvKNPZU8I#(y(Ax5si(qd+XAu%R=GhkqjB6A-?Hv9Pcp z5GkOe(Lx&&G{MAJ7&{URP5b~F8~)`ANQh_-1G&XJIRdxd?%m9e#lRXW613nc=Xvtv zeSeu34pf?(v17yimSZ$F+;2;BGg(dne0)5VJv@7G%@zVhhmxcgd|%RNYP7NJ>?Kqy zF86xkhQ0e_K`4OtpUd3ub4FO*rMlPVd?AOF(AE}{f|PKspnx0zOKaOlM?2{Xl7Ex} zcr$r3Yn&Y~TCGzq^#piA5Y`jU28y_422kd>+)&P^{p#T5?07*qoM6N<$f|oSq@Bjb+ literal 0 HcmV?d00001 diff --git a/textures/moreores_copper_rail_crossing.png b/textures/moreores_copper_rail_crossing.png new file mode 100644 index 0000000000000000000000000000000000000000..b23058c63f763e50f101be231a9604a06e7a3e2e GIT binary patch literal 581 zcmV-L0=oT)P)Px#24YJ`L;(K){{a7>y{D4^000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2iyf4 z3?eJ!#BUw|00G5GL_t(I%cYXvOH*+e#y{WfESn6BE;1|VrYj*@siS`(y9qD4jEKM> z3N$1gLJ$a{V|6itKqN}-*H|m)zZj7vMU&F(?0gkNBVuf4p1obnz8m9Mg74i6A0D3f zc^}xCxpYbfdZWUBW}r7JbLo`f0)EiVzC$t_?=jG|vj=519`hAfjcO04Cb@X&@;@Ck zGioQccQlO|Tsd<Qbp+QJi>fl<8FFH!WPGlwv(Ix4zvUC zA@9_`aQm69{yIox9o5AxPx#24YJ`L;(K){{a7>y{D4^000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2iyf4 z3?cBL_t(I%e|7{OH*MO$3L%IXD7zMCYrQ#LLr5Oq4opnPY6ONXk@6v zi$F*ir9!Y9h182I+EuJEgy_OSf#ClTlITs{B}x#%GMhU)?QCaH7vs#Wju&>(_wIdo zzn|y(yzc}5Q%|DjWNB(Z>TBvKfQg$O61_LYKLIu~2?0o_l1BslX;i*lxhuQt5;%$qH>pUd+y)+erj%}hd^&e=Va?QcJMKHl2^`Mz&avMYxtaP;imj{2G{ zkjww#)x&-{h^;7>r+TV_XlWCAoH4$1rUwQekxALqn3-V5gjH@pD|) z*!rv*M{wdR-!6XL!;gH4>%Ae&qK)qJ5Se|is^fG?(P(BQI_ACyPv7pSx;2%O4VqW6 z9KRxaMwySFY(}DEq+ic-vAf-UksQ5P`EmeLh^I*bK>&Krv@txtrhWtR46kN_)^TD0 O00001r;P)Px#24YJ`L;(K){{a7>y{D4^000SaNLh0L01FcU01FcV0GgZ_00007bV*G`2iyf4 z3?dX#qCz7800F^CL_t(I%axM7Yg1tu#eZ+^OA@0FDs~ZcPz05l_*p@xjNJs6K*1P- zgE|-y7bTN}mTDA>bci8~I5b*8@DFfv5RHREoo=hB&}v(Hb3f91ABUQ2+TOPIjOTrx z!#U4;;4hkuVJY=zgmqBr&q%W|9L{NgXSe!7V&v)(iR&1a>!W}`KpTqoLO@){82_?3 zTDf#sN{>G(4e;juHx6bN1;)*3wx%@GvmRSEX>8Xgl{9d?fR^i%Qab_2W-rprBC0z= zy;i02`h$wH-mzV;RhRI3z06UI`9hKOxhrZ_ft$H~a$wIkdXJwE7dy_DA39RN^Sp3* zwMZSrqR4^V4eGTjJ9=yyiblSxp{{t*N@46 z2`tY&^xRZd%fb9H$4Kd@L<*D#_OF@q&Zw!ZmWS1{SG;Ke$8kgA^vNWd-V+i?z=gqg zp_6+rOm*$-Zh-{d-?^fRD)EcWNrT_>ZO){3VY@!bghB51+a*277mCq6xIZ=#iYkz{ z4{@y+E%(WcwZNy(KKVkC`qR5q#wOL8Retp9>pwAt7%>HG2jI}&9$=C`e>%gk*jg$l P00000NkvXXu0mjfTSo!y literal 0 HcmV?d00001 diff --git a/textures/moreores_gold_block.png b/textures/moreores_gold_block.png new file mode 100644 index 0000000000000000000000000000000000000000..84dec2855f442b1db4b95cac8341521b9bdbd657 GIT binary patch literal 277 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=DinK$vl=HlH+5kiEpy*OmP)lZXf-pOUkpFi>cbr;B5V#p&cfpBDVKXJ&19dj9%s zp7{A|mAwr2XQ>`Oe*0~K-S!XxW??heKdYun%-XrMDZu1#Y=d6IS=T#3jux?<51Eqo zHeY7Q@jITbA*?!!Q>ww&xQfAe;-mPyl?rY4@%ch#3^&Dq>^<>DP}?ZNn=@bvtG`1(vZfaBm7#x^|QI Q8PK&1p00i_>zopr0Dw4T)&Kwi literal 0 HcmV?d00001 diff --git a/textures/moreores_gold_ingot.png b/textures/moreores_gold_ingot.png new file mode 100644 index 0000000000000000000000000000000000000000..fa1de151d45463fa2d4cfb966486ba48fb5c817f GIT binary patch literal 358 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)BfFp+`&6du$v~mco-U3d7N?(HT$pz#K;+oR|E$x} z8XIQJnBkgJTmVU+;HU>k-J24u?cPm17He_#ibrn#3jksF}Lslbq4S;|XsV16Cio?UyE~?;Nk%cjI-~({*))4BPe{{4cie z&tmKUe>_>v|2ri2i#LU}c=h$Qr-GO3{OP~NC??YQ=R_b|1JL^np00i_>zopr00LH( AHUIzs literal 0 HcmV?d00001 diff --git a/textures/moreores_gold_lump.png b/textures/moreores_gold_lump.png new file mode 100644 index 0000000000000000000000000000000000000000..432ba8bc8e4ff8b536986146fcc9467feb213333 GIT binary patch literal 364 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)BfFpi`<3HoL7>%MU-N+5 zM2AHlzJ~=DJh!;hIFGB3K~{ZXgC4JlNuUaQkI$dYyFcC6Yn{saC?d>jMqb+e-}AN@ ze|UcSb#+Cx&DM@spPdOs-`?c1a>)DXG^l?wDCKFm#(MmDcVFC>nUhmG&p0j7ny~6X z#E$)TTbdct!`f1_IPObdIx``y?c_y2cB3f&emlFBTHX(~zd7)KrNP_{@eMa^mT9aN zX5Z(q>YB<{)gGyN%TnzXx}+J7{bpLZ)_cmWNzc+Ai@D8i(=ME~y>`x)zh9OvTEl*= zqP+Bh-OJKz3%-;WMIJtz`;PbC!KX)WFrC}u6>I)~@-L=fgTe~ HDWM4f{m+*h literal 0 HcmV?d00001 diff --git a/textures/moreores_mineral_copper.png b/textures/moreores_mineral_copper.png new file mode 100644 index 0000000000000000000000000000000000000000..43cdb115efd6910670df65bccc00b038ff7d125c GIT binary patch literal 258 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)qo^>G@C0j7OQ2A{r;B5V#p&dP1!gyH$$hCWTX?yC zm*goYkH_u)@e+HquNxW}7#QTd=lcKu$^85W3z7X*Hv0(2PzgQu&X%Q~loCIIO1VtxPs literal 0 HcmV?d00001 diff --git a/textures/moreores_mineral_gold.png b/textures/moreores_mineral_gold.png new file mode 100644 index 0000000000000000000000000000000000000000..e110b437d9f207d17e9e332d0fc3e60efc5a0edb GIT binary patch literal 222 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)qo^>GXl29(9-vURr;B5V#p&dP1!h0$_CNf;yO!ra zd;7xs@6G@GFXmeK@qKWIV+3#WO{dc5mu++;CaUhgpMPN0#D4av|6g*qh!r`#NO#~{ zVZU7B!Hj)%hef%88XuH!D%&|HCN{~i&ENOngLUX$$LSju&05H?l{3{~(!4+`ptTI1 Lu6{1-oD!MQL70(Y)*K0-AbW|YuPgfE*gVp8|#QJY5_^EKVmU zEU>ze_w)RMyPxLgwHXOrIdSCFfr6bfi~P2Kwm-c8zQE4araddz6mBz2m1$w{j!5{< zWR;NQ`c%1G0H={lGf-%Pr;B5V#p&dP1!fi{|DOCW{k{GF z^4SY@T1@JGf9ySY?!ugjjg5^DuU!57fBv4Tg9m^>;K_@VCqRsjH9yX_mupOF=1<_} zUK8iQ9wQ^8@h9KD?!exzhu4F{&;PIg{*rml`^1+Xw?8Btc~QL70(Y)*K0-AbW|YuPgg)9!?=%E;k;QE}&4Ir;B5V#p&dP z1!gzOzhC%YTh9M?`Rs)~Eha@9HW){ooNa7mU|=9qUGeFEzrDSr1Q5)b@>U{{$6*_z zn&l6MZ5s}}Vl6pv@KE0&cRqHW{c_b6LPr%M7%uS`Bo*6L>Acxp{lb3TjKm}22{#Ts qI6i;=mEN>2VIk#}FB@L16lJLT=4$w{OlcR;B@CXfelF{r5}E+*=~tux literal 0 HcmV?d00001 diff --git a/textures/moreores_mithril_block.png b/textures/moreores_mithril_block.png new file mode 100644 index 0000000000000000000000000000000000000000..295af91d87f5edd2e29949162578a7d3e618810a GIT binary patch literal 614 zcmV-s0-61ZP)PrG5QSg;^z?Xa zCnP2giU?bdz>WiO8t%vef)FQ&vLHW>?Zk|yr@O0IjKZ#@lInd=_0i|g-*bKiKqT%p z##ODyS`%|)HURv8)imz_D3M%Ueam^PdNPhrFzwyyBd4?>k}0ui-sij*nbrDN^<*L;5_j+WJE9Q6l2sSu_-s}Hn2kh4Br#s}{jJD+ zDg%JIQSE9?T1wxxABYHGA_?J?h=$>@>plUf^#~Yq)3)njcwiQ7niI3pY*g(^c_9iD zM&I9xM6(jYDPR*ek!mS}$gI}mFg&#F+TDo=ScFhhdYr;bIRLD>$oZ84q;&6|W4uUd zQ_2g#fSHYLyYBltfJ^B`W~!ZP$AHCn$=sR^A)LDVI6k?%NOboYS7yUoNdRDx8Ih#4 z5t%V7U?H3lNzQvB5}6&3_kaNy$7kk7-7A2}lbrX=ZLLQlX_|AhLL_guc`}MsJNLTX z-b|jAa!~C`IZU6)dE0d#hvCoTQ`!Jnt-b)(H0SOPSd1&P!mO$%?jGaiB;`2n zRAjc>{RH6dwf00jy`q#pgk?$_kvI(@EJIlS0~<6hGwe(@UjP6A07*qoM6N<$f}xEN A1^@s6 literal 0 HcmV?d00001 diff --git a/textures/moreores_mithril_ingot.png b/textures/moreores_mithril_ingot.png new file mode 100644 index 0000000000000000000000000000000000000000..9f0e1ba53d92b497db7d3c1c118e063cf5d3f146 GIT binary patch literal 346 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)BfFqHdynKZC7{rAPZ!4!i_=dh8gdV3j2llbLXlzTXXN1 zKYi=f!2{PKpDXd($T2hIZC8(9D<;uKM5yajMO}?9%r*`L^8a zQh$-j!O8}{Pb}<$&KdMbdFe80Fuf_W`@D0>)mN7?rtEWRcRrA0SlfN*gUjZfLhF84 zIW0HtylXC08P_nyn1N?8TSJg{Ou0^yx5?Rs>q2(P3+vr^-(_I4Kl}P?HMV8{oK${^ lq%`g{1WI22J?sAo=9NB;j20!^?*hHd;OXk;vd$@?2>|H6g!2FZ literal 0 HcmV?d00001 diff --git a/textures/moreores_mithril_lump.png b/textures/moreores_mithril_lump.png new file mode 100644 index 0000000000000000000000000000000000000000..9b527b4312c52fcbbe255cd247092113f7ed90a1 GIT binary patch literal 365 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)BfFr2K~7bsAW-O+r;B5V#p%0~Z2g!VMUK}qZ@#IU zVasUxkmZ|LOoR4~Dh_S`hoUFVdQ&MBb@0J>UhTmS$7 literal 0 HcmV?d00001 diff --git a/textures/moreores_silver_ingot.png b/textures/moreores_silver_ingot.png new file mode 100644 index 0000000000000000000000000000000000000000..d07fdaad8dedbc339a6189a5d6572fcb7905d371 GIT binary patch literal 350 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)BfFry`u6f;uYf|YJzX3_EKWb2Xqa`_K%~vSk@Mn< zz~U3EmzY^MJzj^5uxlN2g4N6qTOv9F4_co7^ZW0=#bT}(ohQC%{`*jI;?`+4 z=OcBeE4|A9%hc|2E$Ull*A$`TGtXrj_TII~I9p?;-1j(s(XMrsH{Uj`$drofcNb(~ zU&~mrJC3nw#VW0DnOqH1gcy=}&fm_puw~NdVp@9TyK|hL#q*5YW>4^5y sf^)2nk<*$VWSDtA3V*%zdHoY+jo{X|?0-x*1HH}Q>FVdQ&MBb@00Og-M*si- literal 0 HcmV?d00001 diff --git a/textures/moreores_silver_lump.png b/textures/moreores_silver_lump.png new file mode 100644 index 0000000000000000000000000000000000000000..5093d9f07ec283724f8d0c091cfa9f2b0df82c3a GIT binary patch literal 356 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`Y)RhkE)4%caKYZ?lYt_f1s;*b z3=G`DAk4@xYmNj^kiEpy*OmP)BfFry@!GXQ(}6-CJzX3_EKc8@v@z?jfk2!6b+M06 z!nsTMzOe2}IUQtW;w-1=9lvnG$_dvE52gsLm{zEAv&-t_mE73N8~;v!T=M<@_r=yf zK6@k-?wT^`Usb9i%K?Gq20|;&rT^L| z|EX2r#yaK$mhQ3Fr=(iyUNGThsGRqBj`Y2`#S+QSWL=ItlX$GQYSp3Y|DVO=w%>j@ zdC3%I^?TLxzW+}7#`o^}Yk{@yN*`MP_bP0l+XkK^C^-Yf1IQ%_c zeD1p}AN#-hX7|a{{7~W1OvOnd_SEfPd46vzVP;5p{0?>Uf1Ng zy3YH&@g|3Mga_w=s@<#`7MYx$;VQ@=d!Ic){J4+0aP=no-U3d7N_q{+Us}NK%{m5goM=7 zn@e4_s@wVA$Xb;=mps)Ia&4bat5S{mn@pZw{(ZuBy6X4M zH#?tYycJmTGi0?LK-){(IWrFRRuSo>Od5hzopr E0BZ7@`2YX_ literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_bronzeaxe.png b/textures/moreores_tool_bronzeaxe.png new file mode 100644 index 0000000000000000000000000000000000000000..b6a4175ccb886ef1c993adb393b60bdd87ee6dd4 GIT binary patch literal 224 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85p>QL70(Y)*K0-AbW|YuPgg)9!?=v{i7G7jsk@eJY5_^EKVmU zNPKzVx%^Un%_pB0lmEXyNUT@vX)!s>FuOsg+2^ON+alfsAlMOpvMb5h%=tr=4y@m%I7lA_aJY5_^EKVmU zED$g_B=KH7^N;&9fit@gdQ4(8_^>JTg*`J6NUxU&Y~{*vGB{ywJ>_m?lb$53#w zq#Bzs%S}uFyOsGLfRdD)zDR^(<6qsFB(2Mz#z Y$r-*xV(TJdpi3D%UHx3vIVCg!0LO}Eod5s; literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_bronzeshovel.png b/textures/moreores_tool_bronzeshovel.png new file mode 100644 index 0000000000000000000000000000000000000000..8e71203fd41794b0813dc9af1a75a9adb07a0323 GIT binary patch literal 253 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgg)9!?=ngC{u>Hb9|TPZ!4!i_^&o z3j_>=Ru?qNAFh|MP84>MSKc_wmd8@!hU*l`x_vuO9{>V{i$9ttHUdGX%-ItS3m6Ta zD`lsN2ddp`h=`v0|HLeiT9)GVLb7E%8@FlwpF73kzp;UV!JheR{?1>b;dIT%NaCtZ jiU~+8V9CtJMn;A>F7pNcK5{ughcI}$`njxgN@xNA$>>x| literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_bronzesword.png b/textures/moreores_tool_bronzesword.png new file mode 100644 index 0000000000000000000000000000000000000000..366b648aaf9792f946613bbbca739d546a7533fe GIT binary patch literal 274 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgg)9!?<+otI^$MnIuSo-U3d7N?UF z76=$jTBR7*`p~{-?+3olUynm2{?*S({r2D0_IUjaN1r7b^Fq>&efaxQ_0r$Y9OF%I zn*)mXa52XSMw%U8ZSbewKJvG{>$z(piGTmsZ8EEzB`F~x!S%=FpS5P;p;)JB&my8l zFY#U!No>tNCboiw`F)Vx;d)=eYyX$18C3+myL;+D!QZp_ZfsS|3`eXg@6-meUjw?1 N!PC{xWt~$(69D99X0!kR literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_goldaxe.png b/textures/moreores_tool_goldaxe.png new file mode 100644 index 0000000000000000000000000000000000000000..41d4896e6e4da5c98be18387aca3572e00dd0d86 GIT binary patch literal 225 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85p>QL70(Y)*K0-AbW|YuPgg)9!?HHQJX_WEkL0}PZ!4!i_^&o z5?>xXW{_IaxI$giXbh2pe;#n_O&ICIBD6d8R`mRHtftE3N My85}Sb4q9e0EzxlcmMzZ literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_goldpick.png b/textures/moreores_tool_goldpick.png new file mode 100644 index 0000000000000000000000000000000000000000..1a65e8e2561b5200be5ae5134ba0be1fbfaa2ab9 GIT binary patch literal 294 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgg)9!?HH^OuW^6M#a?JY5_^EKVmU zED$g_Br#u~^{@N12UnwydrV?9`0#1Lr+PLZ&~vO^#B*5l|9rdD8|Ck<7cV*N zyhMWg$9adI%X6n#{7>c%A>Uu2%FF}rXn|0L7k6l1mp e9>&bf%nbL8LeFp4o)rOfF@vY8pUXO@geCy;9A}9D literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_goldshovel.png b/textures/moreores_tool_goldshovel.png new file mode 100644 index 0000000000000000000000000000000000000000..fc72a1e24a411968a1e587ef12c1e29efaec1d47 GIT binary patch literal 256 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgg)9!?G+UHi8)ZvurHJY5_^EKVmU zED$gdT3rxkdbnP~dhOJT+JdwG<=lV&7n#2KfBCM{|M~C4nxv1p^rYppE3(yTinsNj z|2E+{Yl^g_goMP8r7;o}Tfz;6o;F29PyKJ;`(jon)5dLD|L0Dz_-|}rU{JGD>f8J! r2b{0@7)e~UNihM51uU7_*vQE6{5^B(>;XrAG5(I!2L@$l>2-JajoH=RAP zjo;~Pp&Ue-X>*;Fhodr>{%55%Z!5F>f2?}x zu)(#kr~4-hJ+Egw`sDwUY&G_ttYyp7yciiSzcIM!uG_a8Xgq_btDnm{r-UW|EsIHv literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_mithrilpick.png b/textures/moreores_tool_mithrilpick.png new file mode 100644 index 0000000000000000000000000000000000000000..6efb469f674e6d52c9b9896f25770da17889e6f1 GIT binary patch literal 279 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgfF>+S%Xxmkt4&YY5!7mWY(~c=9%cjQ z2{8v;trJY5_^EKVmU zED$gdS{r2b!+y@+5?$p?HV^jy=>iv$6B2||6MlS^QYzazZ(<`5bn2Y-XxPAL@LVZ7 zO<46_Lqzn{{~EJyxJXKzOBa+c+qg~Z|J*4Sifs~pzx{(m7G|i4_GHN!&61RmkkGhv d=D-04hNf9Y;>LeJ{Ri64;OXk;vd$@?2>}1YPnZAz literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_mithrilsword.png b/textures/moreores_tool_mithrilsword.png new file mode 100644 index 0000000000000000000000000000000000000000..b9396d95fc637410339dc7c8f70fb75a5868a8f6 GIT binary patch literal 296 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgf;Xk z0X44x<2FXtI;sEqv6Uwjbaizopr0IDx*CjbBd literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_silveraxe.png b/textures/moreores_tool_silveraxe.png new file mode 100644 index 0000000000000000000000000000000000000000..e49fc75e66afd84f9be948911daa364477515b5d GIT binary patch literal 218 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85p>QL70(Y)*K0-AbW|YuPgg)9!?=f-jcibRDnWKo-U3d7N?UF zB)&X&)9d~J<4I$|OMia-jo#B{Aasd`c~R3Lo?}u~JubT$Vh#1CKls|zzEt_~TKDe{ z|11_iKS8cz<2J4TbEjDR_m8rCZ+~;v$*z5YXTMzW(PUsaI@9Kc!J8+ufwnMsy85}S Ib4q9e0Jv69jQ{`u literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_silverpick.png b/textures/moreores_tool_silverpick.png new file mode 100644 index 0000000000000000000000000000000000000000..d58e78352e047212a91ff005d76cb55f2a158ad3 GIT binary patch literal 290 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgg)9!?=f3#B|MkZFrNT^vI!PA4ZU z5HL6-@jO5FZ@*6Bie+a#CNUap_Ud zGH+SHxN)1-e@O`m38CL&Nv18GGa9OXebJor_upf75lc0vZT7XlrX=3q`@Y9-*|mt| zo=%Cg28J^fPpnH&3NyZ_a4qcV{>ehm>zxdlKeGw%G+WHB7HIa^OI{^=*@-kBhly!y bY-|i?G$Jft6-?d_bS;CYtDnm{r-UW|C-!CS literal 0 HcmV?d00001 diff --git a/textures/moreores_tool_silvershovel.png b/textures/moreores_tool_silvershovel.png new file mode 100644 index 0000000000000000000000000000000000000000..614c0a9db101c6a25ea4139940d4f75923f8a973 GIT binary patch literal 254 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`jKx9jP7LeL$-D$|*pj^6T^Rm@ z;DWu&Cj&(|3p^r=85sDEfH31!Z9ZwBAbW|YuPgg)9!?=9r7wyb_5+3LJY5_^EKVmU zED$gdTD_sn?Rve$Zp+0z6IGbA(o6nszh<5~L1!lw6CmGj$K&UC!_EU47Hp6WjQm z&L-~kEO0%NmF6hE;-q$JLPCNA=Z4DDV#4yNvy|5S*T1{ZZ{B=K2?+_VKPLaIH4Fdk zFZpftb5?S0Xopz~>(Q6taz-BB-o`q1HSH4{8ygp<27Rwzv^e|XHPip5t`Ywy&pPqI ov+{IbF3z$%-^qtEcptBh~UHx3vIVCg!07@itUH||9 literal 0 HcmV?d00001