From 5b7c1a8d4ca8bb0cd61a91e77e64f53de6ac7aa9 Mon Sep 17 00:00:00 2001 From: the-real-herowl Date: Sun, 29 Sep 2024 21:01:45 +0200 Subject: [PATCH] Reworked hammer crushing - crushing is now done by digging with a hammer - cobble is now crushable --- mods/ENTITIES/mcl_item_entity/init.lua | 6 +++ mods/ITEMS/mcl_core/nodes_base.lua | 1 + mods/ITEMS/mcl_core/nodes_glass.lua | 2 +- mods/ITEMS/vl_weaponry/init.lua | 71 +++++--------------------- 4 files changed, 21 insertions(+), 59 deletions(-) diff --git a/mods/ENTITIES/mcl_item_entity/init.lua b/mods/ENTITIES/mcl_item_entity/init.lua index 82c08e7f6..24161925b 100644 --- a/mods/ENTITIES/mcl_item_entity/init.lua +++ b/mods/ENTITIES/mcl_item_entity/init.lua @@ -318,6 +318,12 @@ function minetest.handle_node_drops(pos, drops, digger) end end + -- Special node drops (crushing) when digging with a hammer + local hammer = tooldef.groups.hammer + if hammer and hammer > 0 and nodedef._vl_crushing_drop then + drops = nodedef._vl_crushing_drop + end + if tool and nodedef._mcl_fortune_drop and enchantments.fortune then local fortune_level = enchantments.fortune local fortune_drop = nodedef._mcl_fortune_drop diff --git a/mods/ITEMS/mcl_core/nodes_base.lua b/mods/ITEMS/mcl_core/nodes_base.lua index 595019741..c3e45a366 100644 --- a/mods/ITEMS/mcl_core/nodes_base.lua +++ b/mods/ITEMS/mcl_core/nodes_base.lua @@ -772,6 +772,7 @@ minetest.register_node("mcl_core:cobble", { sounds = mcl_sounds.node_sound_stone_defaults(), _mcl_blast_resistance = 6, _mcl_hardness = 2, + _vl_crushing_drop = { "mcl_core:gravel" } }) minetest.register_node("mcl_core:mossycobble", { diff --git a/mods/ITEMS/mcl_core/nodes_glass.lua b/mods/ITEMS/mcl_core/nodes_glass.lua index 89eda2a1d..8b3aea689 100644 --- a/mods/ITEMS/mcl_core/nodes_glass.lua +++ b/mods/ITEMS/mcl_core/nodes_glass.lua @@ -12,7 +12,7 @@ minetest.register_node("mcl_core:glass", { paramtype2 = "glasslikeliquidlevel", sunlight_propagates = true, stack_max = 64, - groups = {handy=1, glass=1, building_block=1, material_glass=1, crushable=1}, + groups = {handy=1, glass=1, building_block=1, material_glass=1}, sounds = mcl_sounds.node_sound_glass_defaults(), drop = "", _mcl_blast_resistance = 0.3, diff --git a/mods/ITEMS/vl_weaponry/init.lua b/mods/ITEMS/vl_weaponry/init.lua index dfeb10d13..fc882a6d7 100644 --- a/mods/ITEMS/vl_weaponry/init.lua +++ b/mods/ITEMS/vl_weaponry/init.lua @@ -5,7 +5,7 @@ local S = minetest.get_translator(modname) local hammer_tt = S("Can crush blocks") .. "\n" .. S("Increased knockback") local hammer_longdesc = S("Hammers are great in melee combat, as they deal high damage with increased knockback and can endure countless battles. Hammers can also be used to crush things.") -local hammer_use = S("To crush a block, hold the hammer in your hand, then use (rightclick) the block. This only works with some blocks.") +local hammer_use = S("To crush a block, dig the block with the hammer. This only works with some blocks.") local spear_tt = S("Reaches farther") .. "\n" .. S("Can be thrown") local spear_longdesc = S("Spears are great in melee combat, as they have an increased reach. They can also be thrown.") @@ -13,51 +13,6 @@ local spear_use = S("To throw a spear, hold it in your hand, then hold use (righ local wield_scale = mcl_vars.tool_wield_scale -local function crush(pos) - if pos == nil then - return false - end - local node = minetest.get_node(pos) - local name = node.name - if minetest.get_item_group(name, "crushable") == 2 then - node.name = minetest.registered_nodes[name]._mcl_crushed_into - if node.name then - minetest.set_node(pos, node) - minetest.sound_play("default_dig_cracky", { pos = pos, gain = 0.5 }, true) - return true - end - elseif minetest.get_item_group(name, "crushable") == 1 then - minetest.set_node(pos, {name="air"}) - minetest.sound_play(mcl_sounds.node_sound_glass_defaults().dug, { pos = pos, gain = 0.5 }, true) - return true - end - return false -end - -local hammer_on_place = function(wear_divisor) - return function(itemstack, user, pointed_thing) - -- Call on_rightclick if the pointed node defines it - local node = minetest.get_node(pointed_thing.under) - if user and not user:get_player_control().sneak then - if minetest.registered_nodes[node.name] and minetest.registered_nodes[node.name].on_rightclick then - return minetest.registered_nodes[node.name].on_rightclick(pointed_thing.under, node, user, itemstack) or itemstack - end - end - - if minetest.is_protected(pointed_thing.under, user:get_player_name()) then - minetest.record_protection_violation(pointed_thing.under, user:get_player_name()) - return itemstack - end - - if crush(pointed_thing.under) then - if not minetest.is_creative_enabled(user:get_player_name()) then - itemstack:add_wear(65535/wear_divisor) - end - return itemstack - end - end -end - local GRAVITY = 9.81 local YAW_OFFSET = -math.pi/2 local function dir_to_pitch(dir) @@ -554,7 +509,6 @@ minetest.register_tool("vl_weaponry:hammer_wood", { _doc_items_hidden = false, inventory_image = "vl_tool_woodhammer.png", wield_scale = wield_scale, - on_place = hammer_on_place(uses.wood), groups = { weapon=1, hammer=1, dig_speed_class=2, enchantability=15 }, tool_capabilities = { full_punch_interval = 1.2, @@ -566,7 +520,8 @@ minetest.register_tool("vl_weaponry:hammer_wood", { _repair_material = "group:wood", _mcl_toollike_wield = true, _mcl_diggroups = { - pickaxey = { speed = 2, level = 1, uses = 60 } + pickaxey = { speed = 1, level = 1, uses = 60 }, + shovely = { speed = 1, level = 2, uses = 60 } }, }) minetest.register_tool("vl_weaponry:hammer_stone", { @@ -576,7 +531,6 @@ minetest.register_tool("vl_weaponry:hammer_stone", { _doc_items_usagehelp = hammer_use, inventory_image = "vl_tool_stonehammer.png", wield_scale = wield_scale, - on_place = hammer_on_place(uses.stone), groups = { weapon=1, hammer=1, dig_speed_class=2, enchantability=5 }, tool_capabilities = { full_punch_interval = 1.3, @@ -588,7 +542,8 @@ minetest.register_tool("vl_weaponry:hammer_stone", { _repair_material = "group:cobble", _mcl_toollike_wield = true, _mcl_diggroups = { - pickaxey = { speed = 2, level = 1, uses = 132 } + pickaxey = { speed = 2, level = 3, uses = 132 }, + shovely = { speed = 2, level = 3, uses = 132 } }, }) minetest.register_tool("vl_weaponry:hammer_iron", { @@ -598,7 +553,6 @@ minetest.register_tool("vl_weaponry:hammer_iron", { _doc_items_usagehelp = hammer_use, inventory_image = "vl_tool_steelhammer.png", wield_scale = wield_scale, - on_place = hammer_on_place(uses.iron), groups = { weapon=1, hammer=1, dig_speed_class=2, enchantability=14 }, tool_capabilities = { full_punch_interval = 1.2, @@ -610,7 +564,8 @@ minetest.register_tool("vl_weaponry:hammer_iron", { _repair_material = "mcl_core:iron_ingot", _mcl_toollike_wield = true, _mcl_diggroups = { - pickaxey = { speed = 2, level = 1, uses = 251 } + pickaxey = { speed = 3, level = 4, uses = 251 }, + shovely = { speed = 3, level = 4, uses = 251 } }, }) minetest.register_tool("vl_weaponry:hammer_gold", { @@ -620,7 +575,6 @@ minetest.register_tool("vl_weaponry:hammer_gold", { _doc_items_usagehelp = hammer_use, inventory_image = "vl_tool_goldhammer.png", wield_scale = wield_scale, - on_place = hammer_on_place(uses.gold), groups = { weapon=1, hammer=1, dig_speed_class=2, enchantability=22 }, tool_capabilities = { full_punch_interval = 1.0, @@ -632,7 +586,8 @@ minetest.register_tool("vl_weaponry:hammer_gold", { _repair_material = "mcl_core:gold_ingot", _mcl_toollike_wield = true, _mcl_diggroups = { - pickaxey = { speed = 2, level = 1, uses = 33 } + pickaxey = { speed = 8, level = 4, uses = 33 }, + shovely = { speed = 8, level = 4, uses = 33 } }, }) minetest.register_tool("vl_weaponry:hammer_diamond", { @@ -642,7 +597,6 @@ minetest.register_tool("vl_weaponry:hammer_diamond", { _doc_items_usagehelp = hammer_use, inventory_image = "vl_tool_diamondhammer.png", wield_scale = wield_scale, - on_place = hammer_on_place(uses.diamond), groups = { weapon=1, hammer=1, dig_speed_class=2, enchantability=10 }, tool_capabilities = { full_punch_interval = 1.0, @@ -654,7 +608,8 @@ minetest.register_tool("vl_weaponry:hammer_diamond", { _repair_material = "mcl_core:diamond", _mcl_toollike_wield = true, _mcl_diggroups = { - pickaxey = { speed = 2, level = 1, uses = 1562 } + pickaxey = { speed = 4, level = 5, uses = 1562 }, + pickaxey = { speed = 4, level = 5, uses = 1562 } }, _mcl_upgradable = true, _mcl_upgrade_item = "vl_weaponry:hammer_netherite" @@ -666,7 +621,6 @@ minetest.register_tool("vl_weaponry:hammer_netherite", { _doc_items_usagehelp = hammer_use, inventory_image = "vl_tool_netheritehammer.png", wield_scale = wield_scale, - on_place = hammer_on_place(uses.netherite), groups = { weapon=1, hammer=1, dig_speed_class=2, enchantability=10, fire_immune=1 }, tool_capabilities = { full_punch_interval = 1.0, @@ -678,7 +632,8 @@ minetest.register_tool("vl_weaponry:hammer_netherite", { _repair_material = "mcl_nether:netherite_ingot", _mcl_toollike_wield = true, _mcl_diggroups = { - pickaxey = { speed = 2, level = 1, uses = 2031 } + pickaxey = { speed = 6, level = 6, uses = 2031 }, + shovely = { speed = 6, level = 6, uses = 2031 } }, })