From 11de0b6d8727b0f5ee5570342ab047263945a568 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Thu, 15 Feb 2024 18:47:32 +0330 Subject: [PATCH 01/17] TNT for CTF draft --- mods/ctf/ctf_map/maps | 2 +- mods/ctf/ctf_tnt/init.lua | 597 ++++++++++++++++++ mods/ctf/ctf_tnt/license.txt | 100 +++ mods/ctf/ctf_tnt/locale/ctf_tnt.de.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.eo.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.es.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.fr.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.id.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.it.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.ja.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.jbo.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.ms.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.pl.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.pt_BR.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.ru.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.sk.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.sv.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.uk.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.zh_CN.tr | 4 + mods/ctf/ctf_tnt/locale/ctf_tnt.zh_TW.tr | 4 + mods/ctf/ctf_tnt/locale/template.txt | 4 + mods/ctf/ctf_tnt/mod.conf | 3 + mods/ctf/ctf_tnt/sounds/ctf_tnt_explode.ogg | Bin 0 -> 13580 bytes .../sounds/ctf_tnt_gunpowder_burning.ogg | Bin 0 -> 7443 bytes mods/ctf/ctf_tnt/sounds/ctf_tnt_ignite.ogg | Bin 0 -> 26196 bytes mods/ctf/ctf_tnt/textures/ctf_tnt_blast.png | Bin 0 -> 472 bytes mods/ctf/ctf_tnt/textures/ctf_tnt_boom.png | Bin 0 -> 178 bytes mods/ctf/ctf_tnt/textures/ctf_tnt_bottom.png | Bin 0 -> 99 bytes ...nt_gunpowder_burning_crossing_animated.png | Bin 0 -> 512 bytes ..._tnt_gunpowder_burning_curved_animated.png | Bin 0 -> 364 bytes ...nt_gunpowder_burning_straight_animated.png | Bin 0 -> 343 bytes ..._gunpowder_burning_t_junction_animated.png | Bin 0 -> 474 bytes .../textures/ctf_tnt_gunpowder_crossing.png | Bin 0 -> 234 bytes .../textures/ctf_tnt_gunpowder_curved.png | Bin 0 -> 227 bytes .../textures/ctf_tnt_gunpowder_inventory.png | Bin 0 -> 301 bytes .../textures/ctf_tnt_gunpowder_straight.png | Bin 0 -> 201 bytes .../textures/ctf_tnt_gunpowder_t_junction.png | Bin 0 -> 258 bytes mods/ctf/ctf_tnt/textures/ctf_tnt_side.png | Bin 0 -> 128 bytes mods/ctf/ctf_tnt/textures/ctf_tnt_smoke.png | Bin 0 -> 162 bytes .../ctf_tnt/textures/ctf_tnt_tnt_stick.png | Bin 0 -> 149 bytes mods/ctf/ctf_tnt/textures/ctf_tnt_top.png | Bin 0 -> 148 bytes .../ctf_tnt/textures/ctf_tnt_top_burning.png | Bin 0 -> 159 bytes .../textures/ctf_tnt_top_burning_animated.png | Bin 0 -> 238 bytes 43 files changed, 773 insertions(+), 1 deletion(-) create mode 100644 mods/ctf/ctf_tnt/init.lua create mode 100644 mods/ctf/ctf_tnt/license.txt create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.de.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.eo.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.es.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.fr.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.id.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.it.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.ja.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.jbo.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.ms.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.pl.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.pt_BR.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.ru.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.sk.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.sv.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.uk.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.zh_CN.tr create mode 100644 mods/ctf/ctf_tnt/locale/ctf_tnt.zh_TW.tr create mode 100644 mods/ctf/ctf_tnt/locale/template.txt create mode 100644 mods/ctf/ctf_tnt/mod.conf create mode 100644 mods/ctf/ctf_tnt/sounds/ctf_tnt_explode.ogg create mode 100644 mods/ctf/ctf_tnt/sounds/ctf_tnt_gunpowder_burning.ogg create mode 100644 mods/ctf/ctf_tnt/sounds/ctf_tnt_ignite.ogg create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_blast.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_boom.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_bottom.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_crossing_animated.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_curved_animated.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_straight_animated.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_t_junction_animated.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_crossing.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_curved.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_inventory.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_straight.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_t_junction.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_side.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_smoke.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_tnt_stick.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_top.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_top_burning.png create mode 100644 mods/ctf/ctf_tnt/textures/ctf_tnt_top_burning_animated.png diff --git a/mods/ctf/ctf_map/maps b/mods/ctf/ctf_map/maps index 36fcc962e..6fb732057 160000 --- a/mods/ctf/ctf_map/maps +++ b/mods/ctf/ctf_map/maps @@ -1 +1 @@ -Subproject commit 36fcc962e9515f9ea62ca73e69af4d047171eea1 +Subproject commit 6fb7320571a118720f2c69bc2230f33cf35cfc39 diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua new file mode 100644 index 000000000..1589a04af --- /dev/null +++ b/mods/ctf/ctf_tnt/init.lua @@ -0,0 +1,597 @@ +-- tnt/init.lua + +tnt = {} + +-- Load support for MT game translation. +local S = minetest.get_translator("ctf_tnt") + + +-- loss probabilities array (one in X will be lost) +local loss_prob = {} + +loss_prob["default:cobble"] = 3 +loss_prob["default:dirt"] = 4 + +local tnt_radius = tonumber(minetest.settings:get("tnt_radius") or 3) + +-- Fill a list with data for content IDs, after all nodes are registered +local cid_data = {} +minetest.register_on_mods_loaded(function() + for name, def in pairs(minetest.registered_nodes) do + cid_data[minetest.get_content_id(name)] = { + name = name, + drops = def.drops, + flammable = def.groups.flammable, + on_blast = def.on_blast, + } + end +end) + +local function rand_pos(center, pos, radius) + local def + local reg_nodes = minetest.registered_nodes + local i = 0 + repeat + -- Give up and use the center if this takes too long + if i > 4 then + pos.x, pos.z = center.x, center.z + break + end + pos.x = center.x + math.random(-radius, radius) + pos.z = center.z + math.random(-radius, radius) + def = reg_nodes[minetest.get_node(pos).name] + i = i + 1 + until def and not def.walkable +end + +local function eject_drops(drops, pos, radius) + local drop_pos = vector.new(pos) + for _, item in pairs(drops) do + local count = math.min(item:get_count(), item:get_stack_max()) + while count > 0 do + local take = math.max(1,math.min(radius * radius, + count, + item:get_stack_max())) + rand_pos(pos, drop_pos, radius) + local dropitem = ItemStack(item) + dropitem:set_count(take) + local obj = minetest.add_item(drop_pos, dropitem) + if obj then + obj:get_luaentity().collect = true + obj:set_acceleration({x = 0, y = -10, z = 0}) + obj:set_velocity({x = math.random(-3, 3), + y = math.random(0, 10), + z = math.random(-3, 3)}) + end + count = count - take + end + end +end + +local function add_drop(drops, item) + item = ItemStack(item) + local name = item:get_name() + if loss_prob[name] ~= nil and math.random(1, loss_prob[name]) == 1 then + return + end + + local drop = drops[name] + if drop == nil then + drops[name] = item + else + drop:set_count(drop:get_count() + item:get_count()) + end +end + +local basic_flame_on_construct -- cached value +local function destroy(drops, npos, cid, c_air, c_fire, + on_blast_queue, on_construct_queue, + ignore_protection, ignore_on_blast, owner) + if not ignore_protection and minetest.is_protected(npos, owner) then + return cid + end + + local node = minetest.get_node_or_nil(npos) + if node then + if node.name == "ctf_map:reinforced_cobble" then + return cid + end + if minetest.registered_nodes[node.name].groups.immortal then + return cid + end + end + + local def = cid_data[cid] + + if not def then + return c_air + elseif not ignore_on_blast and def.on_blast then + on_blast_queue[#on_blast_queue + 1] = { + pos = vector.new(npos), + on_blast = def.on_blast + } + return cid + elseif def.flammable then + on_construct_queue[#on_construct_queue + 1] = { + fn = basic_flame_on_construct, + pos = vector.new(npos) + } + return c_fire + else + local node_drops = minetest.get_node_drops(def.name, "") + for _, item in pairs(node_drops) do + add_drop(drops, item) + end + return c_air + end +end + +local function calc_velocity(pos1, pos2, old_vel, power) + -- Avoid errors caused by a vector of zero length + if vector.equals(pos1, pos2) then + return old_vel + end + + local vel = vector.direction(pos1, pos2) + vel = vector.normalize(vel) + vel = vector.multiply(vel, power) + + -- Divide by distance + local dist = vector.distance(pos1, pos2) + dist = math.max(dist, 1) + vel = vector.divide(vel, dist) + + -- Add old velocity + vel = vector.add(vel, old_vel) + + -- randomize it a bit + vel = vector.add(vel, { + x = math.random() - 0.5, + y = math.random() - 0.5, + z = math.random() - 0.5, + }) + + -- Limit to terminal velocity + dist = vector.length(vel) + if dist > 250 then + vel = vector.divide(vel, dist / 250) + end + return vel +end + +local function entity_physics(pos, radius, drops) + local objs = minetest.get_objects_inside_radius(pos, radius) + local meta = minetest.get_meta(pos) + local owner = meta:get_string("owner") + local owner_team = meta:get_string("owner_team") + for _, obj in pairs(objs) do + local obj_pos = obj:get_pos() + local dist = math.max(1, vector.distance(pos, obj_pos)) + + local damage = (4 / dist) * radius + if obj:is_player() then + local dir = vector.normalize(vector.subtract(obj_pos, pos)) + local moveoff = vector.multiply(dir, 2 / dist * radius) + obj:add_velocity(moveoff) + minetest.chat_send_all(tostring(owner_team)) + if ctf_teams.get(obj:get_player_name()) ~= owner_team then + local player_ref = minetest.get_player_by_name(owner) + if player_ref then + obj:punch(player_ref, 10, { + damage_groups = { + fleshy = damage, + tnt = 1, + } + }) + else + obj:set_hp(obj:get_hp() - damage) + end + end + else + local luaobj = obj:get_luaentity() + + -- object might have disappeared somehow + if luaobj then + local do_damage = true + local do_knockback = true + local entity_drops = {} + local objdef = minetest.registered_entities[luaobj.name] + + if objdef and objdef.on_blast then + do_damage, do_knockback, entity_drops = objdef.on_blast(luaobj, damage) + end + + if do_knockback then + local obj_vel = obj:get_velocity() + obj:set_velocity(calc_velocity(pos, obj_pos, + obj_vel, radius * 10)) + end + if do_damage then + if not obj:get_armor_groups().immortal then + obj:punch(obj, 1.0, { + full_punch_interval = 1.0, + damage_groups = {fleshy = damage}, + }, nil) + end + end + for _, item in pairs(entity_drops) do + add_drop(drops, item) + end + end + end + end +end + +local function add_effects(pos, radius, drops) + minetest.add_particle({ + pos = pos, + velocity = vector.new(), + acceleration = vector.new(), + expirationtime = 0.4, + size = radius * 10, + collisiondetection = false, + vertical = false, + texture = "ctf_tnt_boom.png", + glow = 15, + }) + minetest.add_particlespawner({ + amount = 64, + time = 0.5, + minpos = vector.subtract(pos, radius / 2), + maxpos = vector.add(pos, radius / 2), + minvel = {x = -10, y = -10, z = -10}, + maxvel = {x = 10, y = 10, z = 10}, + minacc = vector.new(), + maxacc = vector.new(), + minexptime = 1, + maxexptime = 2.5, + minsize = radius * 3, + maxsize = radius * 5, + texture = "ctf_tnt_smoke.png", + }) + + -- we just dropped some items. Look at the items entities and pick + -- one of them to use as texture + local texture = "ctf_tnt_blast.png" --fallback texture + local node + local most = 0 + for name, stack in pairs(drops) do + local count = stack:get_count() + if count > most then + most = count + local def = minetest.registered_nodes[name] + if def then + node = { name = name } + if def.tiles and type(def.tiles[1]) == "string" then + texture = def.tiles[1] + end + end + end + end + + minetest.add_particlespawner({ + amount = 64, + time = 0.1, + minpos = vector.subtract(pos, radius / 2), + maxpos = vector.add(pos, radius / 2), + minvel = {x = -3, y = 0, z = -3}, + maxvel = {x = 3, y = 5, z = 3}, + minacc = {x = 0, y = -10, z = 0}, + maxacc = {x = 0, y = -10, z = 0}, + minexptime = 0.8, + maxexptime = 2.0, + minsize = radius * 0.33, + maxsize = radius, + texture = texture, + -- ^ only as fallback for clients without support for `node` parameter + node = node, + collisiondetection = true, + }) +end + +function tnt.burn(pos, nodename) + local name = nodename or minetest.get_node(pos).name + local def = minetest.registered_nodes[name] + if not def then + return + elseif def.on_ignite then + def.on_ignite(pos) + elseif minetest.get_item_group(name, "tnt") > 0 then + minetest.swap_node(pos, {name = name .. "_burning"}) + minetest.sound_play("ctf_tnt_ignite", {pos = pos, gain = 1.0}, true) + minetest.get_node_timer(pos):start(1) + end +end + +local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owner, explode_center) + pos = vector.round(pos) + -- scan for adjacent TNT nodes first, and enlarge the explosion + local vm1 = VoxelManip() + local p1 = vector.subtract(pos, 2) + local p2 = vector.add(pos, 2) + local minp, maxp = vm1:read_from_map(p1, p2) + local a = VoxelArea:new({MinEdge = minp, MaxEdge = maxp}) + local data = vm1:get_data() + local count = 0 + local c_tnt + local c_tnt_burning = minetest.get_content_id("ctf_tnt:tnt_burning") + local c_tnt_boom = minetest.get_content_id("ctf_tnt:boom") + local c_air = minetest.CONTENT_AIR + local c_ignore = minetest.CONTENT_IGNORE + if enable_tnt then + c_tnt = minetest.get_content_id("ctf_tnt:tnt") + else + c_tnt = c_tnt_burning -- tnt is not registered if disabled + end + -- make sure we still have explosion even when centre node isnt tnt related + if explode_center then + count = 1 + end + + for z = pos.z - 2, pos.z + 2 do + for y = pos.y - 2, pos.y + 2 do + local vi = a:index(pos.x - 2, y, z) + for x = pos.x - 2, pos.x + 2 do + local cid = data[vi] + if cid == c_tnt or cid == c_tnt_boom or cid == c_tnt_burning then + count = count + 1 + data[vi] = c_air + end + vi = vi + 1 + end + end + end + + vm1:set_data(data) + vm1:write_to_map() + + -- recalculate new radius + radius = math.floor(radius * math.pow(count, 1/3)) + + -- perform the explosion + local vm = VoxelManip() + local pr = PseudoRandom(os.time()) + p1 = vector.subtract(pos, radius) + p2 = vector.add(pos, radius) + minp, maxp = vm:read_from_map(p1, p2) + a = VoxelArea:new({MinEdge = minp, MaxEdge = maxp}) + data = vm:get_data() + + local drops = {} + local on_blast_queue = {} + local on_construct_queue = {} + basic_flame_on_construct = minetest.registered_nodes["fire:basic_flame"].on_construct + + local c_fire = minetest.get_content_id("fire:basic_flame") + for z = -radius, radius do + for y = -radius, radius do + local vi = a:index(pos.x + (-radius), pos.y + y, pos.z + z) + local count = 0 + for x = -radius, radius do + local r = vector.length(vector.new(x, y, z)) + if (radius * radius) / (r * r) >= (pr:next(80, 125) / 100) then + local cid = data[vi] + local p = {x = pos.x + x, y = pos.y + y, z = pos.z + z} + if cid ~= c_air and cid ~= c_ignore then + local replace = destroy(drops, p, cid, c_air, c_fire, + on_blast_queue, on_construct_queue, + ignore_protection, ignore_on_blast, owner) + if replace ~= c_air then + count = count + 1 + end + data[vi] = replace + end + end + vi = vi + 1 + end + end + end + + vm:set_data(data) + vm:write_to_map() + vm:update_map() + vm:update_liquids() + + -- call check_single_for_falling for everything within 1.5x blast radius + for y = -radius * 1.5, radius * 1.5 do + for z = -radius * 1.5, radius * 1.5 do + for x = -radius * 1.5, radius * 1.5 do + local rad = {x = x, y = y, z = z} + local s = vector.add(pos, rad) + local r = vector.length(rad) + if r / radius < 1.4 then + minetest.check_single_for_falling(s) + end + end + end + end + + for _, queued_data in pairs(on_blast_queue) do + local dist = math.max(1, vector.distance(queued_data.pos, pos)) + local intensity = (radius * radius) / (dist * dist) + local node_drops = queued_data.on_blast(queued_data.pos, intensity) + if node_drops then + for _, item in pairs(node_drops) do + add_drop(drops, item) + end + end + end + + for _, queued_data in pairs(on_construct_queue) do + queued_data.fn(queued_data.pos) + end + + minetest.log("action", "TNT owned by " .. owner .. " detonated at " .. + minetest.pos_to_string(pos) .. " with radius " .. radius) + + return drops, radius +end + +function tnt.boom(pos, def) + def = def or {} + def.radius = def.radius or 1 + def.damage_radius = def.damage_radius or def.radius * 2 + local meta = minetest.get_meta(pos) + local owner = meta:get_string("owner") + local owner_team = meta:get_string("owner_team") + if not def.explode_center and def.ignore_protection ~= true then + minetest.set_node(pos, {name = "ctf_tnt:boom"}) + end + minetest.sound_play("ctf_tnt_explode", {pos = pos, gain = 2.5, + max_hear_distance = math.min(def.radius * 20, 128)}, true) + local drops, radius = tnt_explode(pos, def.radius, def.ignore_protection, + def.ignore_on_blast, owner, def.explode_center) + -- append entity drops + local damage_radius = (radius / math.max(1, def.radius)) * def.damage_radius + entity_physics(pos, damage_radius, drops) + if not def.disable_drops then + eject_drops(drops, pos, radius) + end + add_effects(pos, radius, drops) + minetest.log("action", "A TNT explosion occurred at " .. minetest.pos_to_string(pos) .. + " with radius " .. radius) +end + +minetest.register_node("ctf_tnt:boom", { + drawtype = "airlike", + inventory_image = "ctf_tnt_boom.png", + wield_image = "ctf_tnt_boom.png", + light_source = default.LIGHT_MAX, + walkable = false, + drop = "", + groups = {dig_immediate = 3, not_in_creative_inventory = 1}, + -- unaffected by explosions + on_blast = function() end, +}) + + +minetest.register_craftitem("ctf_tnt:tnt_stick", { + description = S("TNT Stick"), + inventory_image = "ctf_tnt_tnt_stick.png", + groups = {flammable = 5}, +}) + +if enable_tnt then + crafting.register_recipe({ + output = "ctf_tnt:tnt_stick 2", + items = { "default:papyrus", "ctf_ranged:ammo 2" }, + always_known = false, + }) + crafting.register_recipe({ + output = "ctf_tnt:tnt", + items = { "ctf_tnt:tnt_stick 8" }, + always_known = false, + }) +end + +function tnt.register_tnt(def) + local name + if not def.name:find(':') then + name = "tnt:" .. def.name + else + name = def.name + def.name = def.name:match(":([%w_]+)") + end + if not def.tiles then def.tiles = {} end + local tnt_top = def.tiles.top or def.name .. "_top.png" + local tnt_bottom = def.tiles.bottom or def.name .. "_bottom.png" + local tnt_side = def.tiles.side or def.name .. "_side.png" + local tnt_burning = def.tiles.burning or def.name .. "_top_burning_animated.png" + if not def.damage_radius then def.damage_radius = def.radius * 2 end + + minetest.register_node(":" .. name, { + description = def.description, + tiles = {tnt_top, tnt_bottom, tnt_side}, + is_ground_content = false, + groups = {dig_immediate = 2, mesecon = 2, tnt = 1, flammable = 5}, + sounds = default.node_sound_wood_defaults(), + after_place_node = function(pos, placer) + if placer:is_player() then + local meta = minetest.get_meta(pos) + local pname = placer:get_player_name() + meta:set_string("owner", pname) + meta:set_string("owner_team", ctf_teams.get(pname)) + end + end, + on_punch = function(pos, node, puncher) + minetest.swap_node(pos, {name = name .. "_burning"}) + minetest.registered_nodes[name .. "_burning"].on_construct(pos) + default.log_player_action(puncher, "ignites", node.name, "at", pos) + end, + on_blast = function(pos, intensity) + minetest.after(0.1, function() + tnt.boom(pos, def) + end) + end, + mesecons = {effector = + {action_on = + function(pos) + tnt.boom(pos, def) + end + } + }, + on_burn = function(pos) + minetest.swap_node(pos, {name = name .. "_burning"}) + minetest.registered_nodes[name .. "_burning"].on_construct(pos) + end, + on_ignite = function(pos, igniter) + minetest.swap_node(pos, {name = name .. "_burning"}) + minetest.registered_nodes[name .. "_burning"].on_construct(pos) + end, + on_place = function(itemstack, placer, pointed_thing) + -- first get enemy flags positions + if placer:is_player() then + if not ctf_modebase.match_started then + hud_event.new(user, { + quick = true, + text = "Can't use during build time", + color = "warning", + }) + return nil + end + local pteam = ctf_teams.get(placer:get_player_name()) + for flagteam, team in pairs(ctf_map.current_map.teams) do + if pteam ~= flagteam and vector.distance(pointed_thing.above, team.flag_pos) <= 25 then + return minetest.item_place(itemstack, placer, pointed_thing) + end + end + end + return nil + end, + }) + + minetest.register_node(":" .. name .. "_burning", { + tiles = { + { + name = tnt_burning, + animation = { + type = "vertical_frames", + aspect_w = 16, + aspect_h = 16, + length = 1, + } + }, + tnt_bottom, tnt_side + }, + light_source = 5, + drop = "", + sounds = default.node_sound_wood_defaults(), + groups = {falling_node = 1, not_in_creative_inventory = 1}, + on_timer = function(pos, elapsed) + tnt.boom(pos, def) + end, + -- unaffected by explosions + on_blast = function() end, + on_construct = function(pos) + minetest.sound_play("tnt_ignite", {pos = pos}, true) + minetest.get_node_timer(pos):start(4) + minetest.check_for_falling(pos) + end, + }) +end + +tnt.register_tnt({ + name = "ctf_tnt:tnt", + description = S("TNT"), + radius = tnt_radius, +}) diff --git a/mods/ctf/ctf_tnt/license.txt b/mods/ctf/ctf_tnt/license.txt new file mode 100644 index 000000000..e59ec6ef2 --- /dev/null +++ b/mods/ctf/ctf_tnt/license.txt @@ -0,0 +1,100 @@ +License of source code +---------------------- + +The MIT License (MIT) +Copyright (C) 2014-2016 PilzAdam +Copyright (C) 2014-2016 ShadowNinja +Copyright (C) 2016 sofar (sofar@foo-projects.org) +Copyright (C) 2014-2016 Various Minetest developers and contributors + +Permission is hereby granted, free of charge, to any person obtaining a copy of this +software and associated documentation files (the "Software"), to deal in the Software +without restriction, including without limitation the rights to use, copy, modify, merge, +publish, distribute, sublicense, and/or sell copies of the Software, and to permit +persons to whom the Software is furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all copies or +substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, +INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR +PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE +FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +DEALINGS IN THE SOFTWARE. + +For more details: +https://opensource.org/licenses/MIT + +=================================== + +Licenses of media +----------------- + +Attribution-ShareAlike 3.0 Unported (CC BY-SA 3.0) +Copyright (C) 2014-2016 BlockMen +Copyright (C) 2014-2016 ShadowNinja +Copyright (C) 2015-2016 Wuzzy +Copyright (C) 2016 sofar (sofar@foo-projects.org) +Copyright (C) 2018 paramat + +You are free to: +Share — copy and redistribute the material in any medium or format. +Adapt — remix, transform, and build upon the material for any purpose, even commercially. +The licensor cannot revoke these freedoms as long as you follow the license terms. + +Under the following terms: + +Attribution — You must give appropriate credit, provide a link to the license, and +indicate if changes were made. You may do so in any reasonable manner, but not in any way +that suggests the licensor endorses you or your use. + +ShareAlike — If you remix, transform, or build upon the material, you must distribute +your contributions under the same license as the original. + +No additional restrictions — You may not apply legal terms or technological measures that +legally restrict others from doing anything the license permits. + +Notices: + +You do not have to comply with the license for elements of the material in the public +domain or where your use is permitted by an applicable exception or limitation. +No warranties are given. The license may not give you all of the permissions necessary +for your intended use. For example, other rights such as publicity, privacy, or moral +rights may limit how you use the material. + +For more details: +http://creativecommons.org/licenses/by-sa/3.0/ + +==================================================== + +CC0 1.0 Universal (CC0 1.0) Public Domain Dedication +for audio files (found in sounds folder) +TumeniNodes +steveygos93 +theneedle.tv +frankelmedico + +No Copyright + +The person who associated a work with this deed has dedicated the work to the public domain +by waiving all of his or her rights to the work worldwide under copyright law, including all +related and neighboring rights, to the extent allowed by law. + +You can copy, modify, distribute and perform the work, even for commercial purposes, all +without asking permission. See Other Information below. + +In no way are the patent or trademark rights of any person affected by CC0, nor are the +rights that other persons may have in the work or in how the work is used, such as publicity +or privacy rights. + +Unless expressly stated otherwise, the person who associated a work with this deed makes no +warranties about the work, and disclaims liability for all uses of the work, to the fullest +extent permitted by applicable law. + +When using or citing the work, you should not imply endorsement by the author or the affirmer. + +This license is acceptable for Free Cultural Works. +For more Information: +https://creativecommons.org/publicdomain/zero/1.0/ + diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.de.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.de.tr new file mode 100644 index 000000000..09d2ac26b --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.de.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Schießpulver +TNT Stick=TNT-Stange +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.eo.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.eo.tr new file mode 100644 index 000000000..86240914b --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.eo.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Pulvo +TNT Stick=Dinamita Bastono +TNT=Dinamito diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.es.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.es.tr new file mode 100644 index 000000000..d9f3f205c --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.es.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Pólvora +TNT Stick=Cartucho de TNT +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.fr.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.fr.tr new file mode 100644 index 000000000..3fe48fb03 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.fr.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Poudre à canon +TNT Stick=Bâton de TNT +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.id.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.id.tr new file mode 100644 index 000000000..2652ae0c2 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.id.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Bubuk Mesiu +TNT Stick=Tongkat TNT +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.it.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.it.tr new file mode 100644 index 000000000..6437c0039 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.it.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Polvere da sparo +TNT Stick=Candelotto di TNT +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.ja.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.ja.tr new file mode 100644 index 000000000..d7af9f584 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.ja.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=火薬 +TNT Stick=ダイナマイト +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.jbo.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.jbo.tr new file mode 100644 index 000000000..b1b425ac8 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.jbo.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=lo tercelpu'o +TNT Stick=lo granrti'enti +TNT=lo bamrti'enti diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.ms.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.ms.tr new file mode 100644 index 000000000..c4c5fddc6 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.ms.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Serbuk Senjata Api +TNT Stick=Batang TNT +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.pl.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.pl.tr new file mode 100644 index 000000000..1ede267d3 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.pl.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Proch strzelniczy +TNT Stick=Dynamit +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.pt_BR.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.pt_BR.tr new file mode 100644 index 000000000..d4fc17425 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.pt_BR.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Pólvora +TNT Stick=Banana de Dinamite +TNT=Dinamite diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.ru.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.ru.tr new file mode 100644 index 000000000..a8cee43bb --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.ru.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Порох +TNT Stick=Тротиловая Палка +TNT=Тротил diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.sk.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.sk.tr new file mode 100644 index 000000000..639b8c878 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.sk.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Pušný prach +TNT Stick=Časť TNT +TNT=TNT diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.sv.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.sv.tr new file mode 100644 index 000000000..fd08913fa --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.sv.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Krut +TNT Stick=Dynamitpinne +TNT=Dynamit diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.uk.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.uk.tr new file mode 100644 index 000000000..684466d57 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.uk.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=Порох +TNT Stick=Тротилова Паличка +TNT=Тротил diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.zh_CN.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.zh_CN.tr new file mode 100644 index 000000000..4cb2e9492 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.zh_CN.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=火药粉 +TNT Stick=三硝基甲苯棒 +TNT=三硝基甲苯 diff --git a/mods/ctf/ctf_tnt/locale/ctf_tnt.zh_TW.tr b/mods/ctf/ctf_tnt/locale/ctf_tnt.zh_TW.tr new file mode 100644 index 000000000..c1b3caf33 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/ctf_tnt.zh_TW.tr @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder=火藥粉 +TNT Stick=炸藥棒 +TNT=炸藥包 diff --git a/mods/ctf/ctf_tnt/locale/template.txt b/mods/ctf/ctf_tnt/locale/template.txt new file mode 100644 index 000000000..62bcb1504 --- /dev/null +++ b/mods/ctf/ctf_tnt/locale/template.txt @@ -0,0 +1,4 @@ +# textdomain: tnt +Gun Powder= +TNT Stick= +TNT= diff --git a/mods/ctf/ctf_tnt/mod.conf b/mods/ctf/ctf_tnt/mod.conf new file mode 100644 index 000000000..7da9d6a7a --- /dev/null +++ b/mods/ctf/ctf_tnt/mod.conf @@ -0,0 +1,3 @@ +name = ctf_tnt +description = TNT mod for CTF +depends = default, fire, ctf_teams diff --git a/mods/ctf/ctf_tnt/sounds/ctf_tnt_explode.ogg b/mods/ctf/ctf_tnt/sounds/ctf_tnt_explode.ogg new file mode 100644 index 0000000000000000000000000000000000000000..e00a16c1a332404379bc5dfeb74007d6bd3d701d GIT binary patch literal 13580 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 V+38NfLd4EwiqSafi~lX&{{v}ltsVdX literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/sounds/ctf_tnt_ignite.ogg b/mods/ctf/ctf_tnt/sounds/ctf_tnt_ignite.ogg new file mode 100644 index 0000000000000000000000000000000000000000..1a7062e96dd71d51d8b6fe520cd831aa42c04c15 GIT binary patch literal 26196 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 DzB1aE literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_blast.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_blast.png new file mode 100644 index 0000000000000000000000000000000000000000..92be28ba7412357a7fc6f6abedd8852002e229c5 GIT binary patch literal 472 zcmV;}0Vn>6P)Nklrc49=z+iXsqk{G@M0|8u!PK z2jAV*0q`}q0YV)TTPzmNd7J9^-;}EW5fejIRrzwc^z8D&%d$L^&||lol_yE!>-9PS z7@|o`V^@0L_rCA40HH1t?3$R6`g43bGr`Q!XY5dyV(hXr%kw;#ULMHk%AS)H>kVq*z0|2$$8%>hK zFd%>d%CO>u9RT{UruQQNkc({OV*?Om!=M+6VUhuW{V)TufyM8IWu;CpO|0 z0fezc#iasKfh@^n9hsl9=T1bZ#j;5n=rph(qGH=DjI6P#{2@T42u)04`TtsTln8eK z^Nd9;+w`rHPo+Z6)JTG7z)&SZmJE>TTP43pj!6IV=Kur%mb6^`4EzH6r6PZoB})qc O0000x;TbZF!r8y>HgM! z^>o4ClYMGi1OuZPI9w+*7>To1sI3vZ_gnf%+s{C5rjmw*SJ^IA9O#gaJWy`_-kkBm U+X>QYKtmZkUHx3vIVCg!0PsFO;Q#;t literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_bottom.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_bottom.png new file mode 100644 index 0000000000000000000000000000000000000000..95f66cb90fa1a27b8a6417fe621b7938194c3a65 GIT binary patch literal 99 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!93?!50ihlx9oB=)|uDci*E-)~>VqkcY^lBDR vP}I}KF@!@lIp*Yn0|#z!s5?38a2;WYxX&Rd&U~pDsDQ!K)z4*}Q$iB}9RL{A literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_crossing_animated.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_crossing_animated.png new file mode 100644 index 0000000000000000000000000000000000000000..efab2a9e676f7e738110bb8076282c4c0c5cf937 GIT binary patch literal 512 zcmV+b0{{JqP)>2hd-HkJGpU>2`D(uGuWEf4-CV6>Hor}o#m-D|r-d&Mt zn!Gr8JINDW863o&bX~V9)phOF2^*_URK{`iqMRGTwwfAZD7d?w6h*PVT$aVdHocVx zb+ms>S$3<3b+t%NLv#ywB@Hih(>9WK|T}lNIjf}eFd>|T=bAZb4zQ4`~ z+y`Qa3mo`h7=~ci>3?*rjJ@&!W8bQPNhX>b#5}fZfES~QHI=y{CN8M&E#)*m5Cf@* z#m1>v*l{KDK{67R4=gl(5+5)kFYy5zC+|k)gRJR<6J{N-S$yCE2kU_k^mrFOsH$pb zAWHK*@7`f(>wEl&XJJAs|K$d^Y;~m7(r4AM=0mF@>GQ!Od~kU_;CQq7z=CsDd&3y` zPkeC4L1;dVGxB5igzF?72oDY~Iv-#lGe1LbSTYM0k4}JjjWL}n7!VU8P0000PsvA2awjcBdeeNL~%5>ZSBNCl8YEFOTrt zbsd@F2}bsPC)Pm_kZknIqtL$ZQ<|m%G|#ipecxY40x!$52+b?YGNFfI&`YB%OG4=5 zI0{fzReE6d!r(ZLuk(E;bzKY4wrwx4v5{$-04D3R=SadZv@=i?g?a8yp27zWx2O?uxDLY%S4LA z?#soVc<&7WmSr(IjORtrIq=@+A(VU2_q|;w>^Kh2i*4IXDy0;{Fbuc#ecz3-jA@!o zszwOGnx>)Rzb#)Utm`^+&Xo(z^UNpFIrmaRMu@W>&p3{nKoWu#hmdw*{EB%XPa~W8 z)C*}EHK0TuNCH#^(#x@(X&$83DKDz=AcjNpfa-&HJYa#sj(vkq21__MIGL^Pme*gO#&@-Vc8NUXbVvQC2M@*Pm+Zu~?pXi;002ovPDHLkV1nvAnpFS* literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_t_junction_animated.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_burning_t_junction_animated.png new file mode 100644 index 0000000000000000000000000000000000000000..5b567e3839620fa44813733c79ca88c5228a5680 GIT binary patch literal 474 zcmV<00VV#4P)#YkEBI;Pd6)3k!sRsbBw@kUVB^*J(_&g(mnWE}$p@tX_A>;U+D zKFRleO4D=;=CUm2*zgIw85;q{Z~i|Bf@3S%wp}-OT}N4#Z7DSZr5o?y*#!_MB}uZb zuh)zEz6S{z!IFf7I1IyDRO&)v0(B+w+B6OE*P4JMukHiqcHX5?2Yx&rA62L|-(3$R z!D&5^U=)?=bRj5TYvhoCyN*}Z18EWTU>rv>Hk60~S-a(|2l7;P`dD094+P11J;3dR zOGZ^l?7vebLJw3VPWR$v1Zq8y8DNro^dJnwYvu!0EcP>!(|o`y&j%notp}I~ilUIp ztk(lrWj!BQr}5JH0N1-p4?uF?d~iuSJG~b!(E|+HPVWV^8{aC?N)Ke?SjU2aPVWU- z%JRJ+JJR@G;0^OU@5PnS=Ek-L0Qckn%?D0;fYUG^KveJ71ND5s{vYl61L;CZB@}Yz Qq5uE@07*qoM6N<$f`;kOp8x;= literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_crossing.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_crossing.png new file mode 100644 index 0000000000000000000000000000000000000000..c0487a09a4b195fd26a179fb9f34b2862b2353db GIT binary patch literal 234 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`8$DedLo80u4RYiiPA0kNq;ZTXj2Wu0=A7ceai zIo->=p|mY(+cl@sgQh literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_curved.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_curved.png new file mode 100644 index 0000000000000000000000000000000000000000..8ed01db8adb0cbba55e72cb8c5627317b34e89c0 GIT binary patch literal 227 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`t2|vCLo9mV2HfRpR*=x`Sa+yS zM0u&nn?s+jeXrkYY?o

{?cN^W4?^AOED?l(%O&Ch_jOMW4m5-&~yvOIA70f literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_inventory.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_inventory.png new file mode 100644 index 0000000000000000000000000000000000000000..105a2d257414901455937a730d385b4c2ac9498e GIT binary patch literal 301 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbK}T7XZ8E06{PDPaZ$2?ljJ1`~CL zNEe1^SB7Xeh8Q=7Sa*gvAo5^{_h3lyWJvO6NcLt(^<_x&WytVj$na;#1fl?j>_8x5 z%nsx%3S%q^<1LS3Xi8$}$zqt8%Q7)n?*IS)Dc7&40j*&y3GxeOaCmkj4ah0=ba4!+ zxK(=QqF9rHfNNmD^QgpS9+_^B{@16TwqEEzZ+YVSM4sZF#db@#Y@6aU;nXIt1>6lH zx7i+u$eC}r_E)j)_shHf>wnx)TxPmVm6?xWA)81;)czlWXYPNOuKV|+(!%!DF`l_i lnN3a^J!P&5J7&m89G6#lz%4UF?XNV**PgC^F6*2UngEQ!VbA~o literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_straight.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_straight.png new file mode 100644 index 0000000000000000000000000000000000000000..427feb90bf60d21ae7f0844fa1ed3e82cdb41139 GIT binary patch literal 201 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`6FglULo7}&oqUmtML@uHB8O(D zkS71X|Ke|FRopDwKKEwyr$;g6X$fz-lX_n7)O8D8`&BANc*@PH&2^KnN%2h&`tadu zqvTF@bynMhZELnNoVU!>jLNQ8P4LoeaOS9Be*gE;oMy-OvbhWnUY&nB9IST(boFyt=akR{0FcK} AHUIzs literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_t_junction.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_gunpowder_t_junction.png new file mode 100644 index 0000000000000000000000000000000000000000..b30c2b468371024f0e447c7b6ac3dd57d89a89b8 GIT binary patch literal 258 zcmV+d0sa1oP)jIF3k?1XWd8 zBAR*Mw|(399bN(!pXZ6L>)c7e7z6ph+XV{=Se6A%(^$}TUC%%#;GFj%#+79WnmNxi z)^&wL`ZzwD38snLw#ibd;7+KY1W}tP`#((+c!CM&JoWo(K476+-Whf>tN;K207*qo IM6N<$f=m)?vH$=8 literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_side.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_side.png new file mode 100644 index 0000000000000000000000000000000000000000..d3034732e4be26d06e5f775ee4f88f77ed48612f GIT binary patch literal 128 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJe}GSjE0EsBz;JL^B%H{MZ=` X4>LJVxOGq&sE@(Z)z4*}Q$iB}^57uD literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_smoke.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_smoke.png new file mode 100644 index 0000000000000000000000000000000000000000..6788974a9db8abf94aeea5446b904630a5dddab4 GIT binary patch literal 162 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61|;P_|4#%`nVv3=Ar`0aPCUqYz<|S5_NJhW zqOwI(w#8Ii)>p?>wq5YPulm8^bLb-d!tXow>mHK`6!l-f>UEmZq^=p3Wp;^aPtU8* zpYbtltKQdD5nIwZy< r>QNfjz$GzJ>%f5|md$~TR~Z>v-m^*UJjzl5)XCuK>gTe~DWM4f67?qE literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_top.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_top.png new file mode 100644 index 0000000000000000000000000000000000000000..31b807cb6a8af7552054e756c51c2b9fa6f00ece GIT binary patch literal 148 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!93?!50ihlx9JOMr-u0VPh1H%OdhF1&>aW72H z0Qt_IE{-7_vaAOUc^e!USPtr*xbCsQjpb1succ^+MnkBx-kA&ARxEO!l)K!PuY_mM tddFuxe>L`X|5!80cwug!>r|DWjAtI|q_o$YOaU6l;OXk;vd$@?2>`HcEsX#G literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_top_burning.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_top_burning.png new file mode 100644 index 0000000000000000000000000000000000000000..fc0d4905f628b501963c2c6fc3e0df6b159639cb GIT binary patch literal 159 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!63?wyl`GbKJe}GSjE0EsBz;JgTe~DWM4f D`zSFl literal 0 HcmV?d00001 diff --git a/mods/ctf/ctf_tnt/textures/ctf_tnt_top_burning_animated.png b/mods/ctf/ctf_tnt/textures/ctf_tnt_top_burning_animated.png new file mode 100644 index 0000000000000000000000000000000000000000..18a270fb9a453bb62cd9d087169ddd71f6db30ab GIT binary patch literal 238 zcmeAS@N?(olHy`uVBq!ia0vp^0zmA*!3-o-7PBt_Qv3lvA+A7r7X!lu28MfQ7+x_j zq?TA60t(IYba4!+U_3kdBG(}U0hZ@^pZ?#^X)%lGvss}KCBfCGcRTU0gtB%|$C@?F zJNZ6Ud8F(MZxha9^VwrOqoW|*Lv8Y;#)P+m0$1dOBC4j?>HqUito`lCwvA^uf1lk7 zJAvu^XSV!gxKS%{O->-7`UkiC^V$>Ezdvvu_*8grxzopr0NK%5q5uE@ literal 0 HcmV?d00001 From 675c994b26bf18d7d8103273a247dae4556b44f3 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 18:15:37 +0330 Subject: [PATCH 02/17] add debug messages --- mods/ctf/ctf_tnt/init.lua | 39 +++++++++++++++++---------------------- 1 file changed, 17 insertions(+), 22 deletions(-) diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index 1589a04af..00c2c31d4 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -164,6 +164,8 @@ local function entity_physics(pos, radius, drops) local meta = minetest.get_meta(pos) local owner = meta:get_string("owner") local owner_team = meta:get_string("owner_team") + minetest.chat_send_all(owner_team) + minetest.chat_send_all("Hello") for _, obj in pairs(objs) do local obj_pos = obj:get_pos() local dist = math.max(1, vector.distance(pos, obj_pos)) @@ -173,7 +175,6 @@ local function entity_physics(pos, radius, drops) local dir = vector.normalize(vector.subtract(obj_pos, pos)) local moveoff = vector.multiply(dir, 2 / dist * radius) obj:add_velocity(moveoff) - minetest.chat_send_all(tostring(owner_team)) if ctf_teams.get(obj:get_player_name()) ~= owner_team then local player_ref = minetest.get_player_by_name(owner) if player_ref then @@ -471,18 +472,16 @@ minetest.register_craftitem("ctf_tnt:tnt_stick", { groups = {flammable = 5}, }) -if enable_tnt then - crafting.register_recipe({ - output = "ctf_tnt:tnt_stick 2", - items = { "default:papyrus", "ctf_ranged:ammo 2" }, - always_known = false, - }) - crafting.register_recipe({ - output = "ctf_tnt:tnt", - items = { "ctf_tnt:tnt_stick 8" }, - always_known = false, - }) -end +crafting.register_recipe({ + output = "ctf_tnt:tnt_stick 2", + items = { "default:papyrus", "ctf_ranged:ammo 2" }, + always_known = false, +}) +crafting.register_recipe({ + output = "ctf_tnt:tnt", + items = { "ctf_tnt:tnt_stick 8" }, + always_known = false, +}) function tnt.register_tnt(def) local name @@ -523,13 +522,6 @@ function tnt.register_tnt(def) tnt.boom(pos, def) end) end, - mesecons = {effector = - {action_on = - function(pos) - tnt.boom(pos, def) - end - } - }, on_burn = function(pos) minetest.swap_node(pos, {name = name .. "_burning"}) minetest.registered_nodes[name .. "_burning"].on_construct(pos) @@ -540,9 +532,11 @@ function tnt.register_tnt(def) end, on_place = function(itemstack, placer, pointed_thing) -- first get enemy flags positions + -- TNT can be placed only within a radius of + -- an enemy flag if placer:is_player() then if not ctf_modebase.match_started then - hud_event.new(user, { + hud_events.new(user, { quick = true, text = "Can't use during build time", color = "warning", @@ -551,7 +545,8 @@ function tnt.register_tnt(def) end local pteam = ctf_teams.get(placer:get_player_name()) for flagteam, team in pairs(ctf_map.current_map.teams) do - if pteam ~= flagteam and vector.distance(pointed_thing.above, team.flag_pos) <= 25 then + if pteam ~= flagteam and vector.distance(pointed_thing.above, team.flag_pos) <= 24 then + local meta = minetest.get_meta(pointed_thing.above) return minetest.item_place(itemstack, placer, pointed_thing) end end From 873e868868e2cad1b476c068ef8e3b11abccc589 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 18:32:28 +0330 Subject: [PATCH 03/17] update --- mods/ctf/ctf_tnt/README.txt | 11 +++++++++++ mods/ctf/ctf_tnt/init.lua | 28 +++++++++++++--------------- mods/ctf/ctf_tnt/mod.conf | 2 +- 3 files changed, 25 insertions(+), 16 deletions(-) create mode 100644 mods/ctf/ctf_tnt/README.txt diff --git a/mods/ctf/ctf_tnt/README.txt b/mods/ctf/ctf_tnt/README.txt new file mode 100644 index 000000000..7cb6d8cd7 --- /dev/null +++ b/mods/ctf/ctf_tnt/README.txt @@ -0,0 +1,11 @@ +This is a fork of original TNT game by MTG. The original code is under LGPLv2.1+ and so is this. + +The main differences between the original TNT mod and CTF's TNT mod are: + + - CTF TNT does not damage teammates of the placer + - CTF TNT can be placed only within a radius of enemy flag + - CTF TNT gives points for blocks removed + - CTF TNT does not remove unremovable blocks in CTF, such as map borders, flags and chests + + +Copyright (C) 2024 Farooq Karimi Zadeh and MTG contributors. Some rights are reserved under GNU Lesser General Public License as publish by FSF, version 2.1 or at your option and later version. diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index 00c2c31d4..49d7228b8 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -159,13 +159,9 @@ local function calc_velocity(pos1, pos2, old_vel, power) return vel end -local function entity_physics(pos, radius, drops) +local function entity_physics(pos, radius, drops, owner, owner_team) local objs = minetest.get_objects_inside_radius(pos, radius) local meta = minetest.get_meta(pos) - local owner = meta:get_string("owner") - local owner_team = meta:get_string("owner_team") - minetest.chat_send_all(owner_team) - minetest.chat_send_all("Hello") for _, obj in pairs(objs) do local obj_pos = obj:get_pos() local dist = math.max(1, vector.distance(pos, obj_pos)) @@ -305,6 +301,9 @@ function tnt.burn(pos, nodename) end local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owner, explode_center) + local meta = minetest.get_meta(pos) + local owner = meta:get_string("owner") + local owner_team = meta:get_string("owner_team") pos = vector.round(pos) -- scan for adjacent TNT nodes first, and enlarge the explosion local vm1 = VoxelManip() @@ -424,7 +423,9 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne minetest.log("action", "TNT owned by " .. owner .. " detonated at " .. minetest.pos_to_string(pos) .. " with radius " .. radius) - + if owner ~= "" then + ctf_modebase.recent_rankings.add(owner, { score=count }, true) + end return drops, radius end @@ -444,7 +445,7 @@ function tnt.boom(pos, def) def.ignore_on_blast, owner, def.explode_center) -- append entity drops local damage_radius = (radius / math.max(1, def.radius)) * def.damage_radius - entity_physics(pos, damage_radius, drops) + entity_physics(pos, damage_radius, drops, owner, owner_team) if not def.disable_drops then eject_drops(drops, pos, radius) end @@ -505,13 +506,7 @@ function tnt.register_tnt(def) groups = {dig_immediate = 2, mesecon = 2, tnt = 1, flammable = 5}, sounds = default.node_sound_wood_defaults(), after_place_node = function(pos, placer) - if placer:is_player() then - local meta = minetest.get_meta(pos) - local pname = placer:get_player_name() - meta:set_string("owner", pname) - meta:set_string("owner_team", ctf_teams.get(pname)) - end - end, + end, on_punch = function(pos, node, puncher) minetest.swap_node(pos, {name = name .. "_burning"}) minetest.registered_nodes[name .. "_burning"].on_construct(pos) @@ -534,7 +529,7 @@ function tnt.register_tnt(def) -- first get enemy flags positions -- TNT can be placed only within a radius of -- an enemy flag - if placer:is_player() then + if placer and placer:is_player() then if not ctf_modebase.match_started then hud_events.new(user, { quick = true, @@ -547,6 +542,9 @@ function tnt.register_tnt(def) for flagteam, team in pairs(ctf_map.current_map.teams) do if pteam ~= flagteam and vector.distance(pointed_thing.above, team.flag_pos) <= 24 then local meta = minetest.get_meta(pointed_thing.above) + local pname = placer:get_player_name() + meta:set_string("owner", pname) + meta:set_string("owner_team", ctf_teams.get(pname)) return minetest.item_place(itemstack, placer, pointed_thing) end end diff --git a/mods/ctf/ctf_tnt/mod.conf b/mods/ctf/ctf_tnt/mod.conf index 7da9d6a7a..2db71c760 100644 --- a/mods/ctf/ctf_tnt/mod.conf +++ b/mods/ctf/ctf_tnt/mod.conf @@ -1,3 +1,3 @@ name = ctf_tnt description = TNT mod for CTF -depends = default, fire, ctf_teams +depends = default, fire, ctf_teams, hud_events From 2aed3f144a265595da1db34e450cfa9f78085d04 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 18:58:03 +0330 Subject: [PATCH 04/17] give score to TNT placer after explode --- mods/ctf/ctf_tnt/init.lua | 25 +++++++++++++++---------- 1 file changed, 15 insertions(+), 10 deletions(-) diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index 49d7228b8..31d34a608 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -300,10 +300,7 @@ function tnt.burn(pos, nodename) end end -local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owner, explode_center) - local meta = minetest.get_meta(pos) - local owner = meta:get_string("owner") - local owner_team = meta:get_string("owner_team") +local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owner, owner_team, explode_center) pos = vector.round(pos) -- scan for adjacent TNT nodes first, and enlarge the explosion local vm1 = VoxelManip() @@ -363,6 +360,7 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne basic_flame_on_construct = minetest.registered_nodes["fire:basic_flame"].on_construct local c_fire = minetest.get_content_id("fire:basic_flame") + local removed_blocks = 0 for z = -radius, radius do for y = -radius, radius do local vi = a:index(pos.x + (-radius), pos.y + y, pos.z + z) @@ -378,6 +376,8 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne ignore_protection, ignore_on_blast, owner) if replace ~= c_air then count = count + 1 + else + removed_blocks = removed_blocks + 1 end data[vi] = replace end @@ -424,7 +424,8 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne minetest.log("action", "TNT owned by " .. owner .. " detonated at " .. minetest.pos_to_string(pos) .. " with radius " .. radius) if owner ~= "" then - ctf_modebase.recent_rankings.add(owner, { score=count }, true) + local current_mode = ctf_modebase:get_current_mode() + current_mode.recent_rankings.add(owner, { score=removed_blocks }, false) end return drops, radius end @@ -442,7 +443,7 @@ function tnt.boom(pos, def) minetest.sound_play("ctf_tnt_explode", {pos = pos, gain = 2.5, max_hear_distance = math.min(def.radius * 20, 128)}, true) local drops, radius = tnt_explode(pos, def.radius, def.ignore_protection, - def.ignore_on_blast, owner, def.explode_center) + def.ignore_on_blast, owner, owner_team, def.explode_center) -- append entity drops local damage_radius = (radius / math.max(1, def.radius)) * def.damage_radius entity_physics(pos, damage_radius, drops, owner, owner_team) @@ -525,6 +526,14 @@ function tnt.register_tnt(def) minetest.swap_node(pos, {name = name .. "_burning"}) minetest.registered_nodes[name .. "_burning"].on_construct(pos) end, + after_place_node = function(pos, placer, itemstack, pointed_thing) + if placer and placer:is_player() then + local meta = minetest.get_meta(pos) + local pname = placer:get_player_name() + meta:set_string("owner", pname) + meta:set_string("owner_team", ctf_teams.get(pname)) + end + end, on_place = function(itemstack, placer, pointed_thing) -- first get enemy flags positions -- TNT can be placed only within a radius of @@ -541,10 +550,6 @@ function tnt.register_tnt(def) local pteam = ctf_teams.get(placer:get_player_name()) for flagteam, team in pairs(ctf_map.current_map.teams) do if pteam ~= flagteam and vector.distance(pointed_thing.above, team.flag_pos) <= 24 then - local meta = minetest.get_meta(pointed_thing.above) - local pname = placer:get_player_name() - meta:set_string("owner", pname) - meta:set_string("owner_team", ctf_teams.get(pname)) return minetest.item_place(itemstack, placer, pointed_thing) end end From f3d8cc9cdbeba61e24c7e93b030b070e08cf1ab1 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 19:10:21 +0330 Subject: [PATCH 05/17] add tnt sticks and crafting --- mods/ctf/ctf_modebase/crafting.lua | 12 ++++++++++++ mods/ctf/ctf_modes/ctf_mode_classes/init.lua | 1 + mods/ctf/ctf_modes/ctf_mode_classic/init.lua | 1 + mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua | 1 + mods/ctf/ctf_tnt/init.lua | 11 ----------- 5 files changed, 15 insertions(+), 11 deletions(-) diff --git a/mods/ctf/ctf_modebase/crafting.lua b/mods/ctf/ctf_modebase/crafting.lua index 92483dc18..544af20b6 100644 --- a/mods/ctf/ctf_modebase/crafting.lua +++ b/mods/ctf/ctf_modebase/crafting.lua @@ -173,3 +173,15 @@ crafting.register_recipe({ items = { "default:cobble 6", "default:steel_ingot" }, always_known = false, }) + +crafting.register_recipe({ + output = "ctf_tnt:tnt_stick 2", + items = { "default:papyrus", "ctf_ranged:ammo 2" }, + always_known = true, +}) +crafting.register_recipe({ + output = "ctf_tnt:tnt", + items = { "ctf_tnt:tnt_stick 8" }, + always_known = true, +}) + diff --git a/mods/ctf/ctf_modes/ctf_mode_classes/init.lua b/mods/ctf/ctf_modes/ctf_mode_classes/init.lua index 0ddb58b26..f1413c2f2 100644 --- a/mods/ctf/ctf_modes/ctf_mode_classes/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_classes/init.lua @@ -64,6 +64,7 @@ ctf_modebase.register_mode("classes", { ["grenades:frag" ] = {rarity = 0.1, max_stacks = 1}, ["grenades:smoke"] = {rarity = 0.2, max_stacks = 2}, ["grenades:poison"] = {rarity = 0.1, max_stacks = 2}, + ["ctf_tnt:tnt_stick"] = {rarity=0.2, max_stacks=2}, }, crafts = { "ctf_ranged:ammo", "default:axe_mese", "default:axe_diamond", "default:shovel_mese", "default:shovel_diamond", diff --git a/mods/ctf/ctf_modes/ctf_mode_classic/init.lua b/mods/ctf/ctf_modes/ctf_mode_classic/init.lua index 419eeda6a..786128df7 100644 --- a/mods/ctf/ctf_modes/ctf_mode_classic/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_classic/init.lua @@ -30,6 +30,7 @@ ctf_modebase.register_mode("classic", { ["grenades:frag" ] = {rarity = 0.1, max_stacks = 1}, ["grenades:smoke"] = {rarity = 0.2, max_stacks = 2}, + ["ctf_tnt:tnt"] = {rarity=0.2, max_stacks=2}, }, crafts = {"ctf_ranged:ammo", "ctf_melee:sword_steel", "ctf_melee:sword_mese", "ctf_melee:sword_diamond"}, physics = {sneak_glitch = true, new_move = false}, diff --git a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua index f442697c2..1a57c5758 100644 --- a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua @@ -46,6 +46,7 @@ ctf_modebase.register_mode("nade_fight", { ["grenades:smoke"] = {rarity = 0.2, max_stacks = 3}, ["grenades:poison"] = {rarity = 0.1, max_stacks = 2}, + ["ctf_tnt:tnt"] = {rarity=0.2, max_stacks=2}, }, crafts = { "ctf_map:damage_cobble", diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index 31d34a608..6354789f3 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -474,17 +474,6 @@ minetest.register_craftitem("ctf_tnt:tnt_stick", { groups = {flammable = 5}, }) -crafting.register_recipe({ - output = "ctf_tnt:tnt_stick 2", - items = { "default:papyrus", "ctf_ranged:ammo 2" }, - always_known = false, -}) -crafting.register_recipe({ - output = "ctf_tnt:tnt", - items = { "ctf_tnt:tnt_stick 8" }, - always_known = false, -}) - function tnt.register_tnt(def) local name if not def.name:find(':') then From ffb93d48fd27fc37aed592de2ad851d6264345b7 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 19:18:46 +0330 Subject: [PATCH 06/17] small improvement --- mods/ctf/ctf_tnt/init.lua | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index 6354789f3..3592f8415 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -1,6 +1,6 @@ -- tnt/init.lua -tnt = {} +ctf_tnt = {} -- Load support for MT game translation. local S = minetest.get_translator("ctf_tnt") @@ -286,7 +286,7 @@ local function add_effects(pos, radius, drops) }) end -function tnt.burn(pos, nodename) +function ctf_tnt.burn(pos, nodename) local name = nodename or minetest.get_node(pos).name local def = minetest.registered_nodes[name] if not def then @@ -430,7 +430,7 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne return drops, radius end -function tnt.boom(pos, def) +function ctf_tnt.boom(pos, def) def = def or {} def.radius = def.radius or 1 def.damage_radius = def.damage_radius or def.radius * 2 @@ -474,7 +474,7 @@ minetest.register_craftitem("ctf_tnt:tnt_stick", { groups = {flammable = 5}, }) -function tnt.register_tnt(def) +function ctf_tnt.register_tnt(def) local name if not def.name:find(':') then name = "tnt:" .. def.name @@ -529,7 +529,7 @@ function tnt.register_tnt(def) -- an enemy flag if placer and placer:is_player() then if not ctf_modebase.match_started then - hud_events.new(user, { + hud_events.new(placer:get_player_name(), { quick = true, text = "Can't use during build time", color = "warning", @@ -543,6 +543,11 @@ function tnt.register_tnt(def) end end end + hud_events.new(placer:get_player_name(), { + quick = true, + text = "You can place TNT only near one enemy flag", + color = "warning", + }) return nil end, }) @@ -565,7 +570,7 @@ function tnt.register_tnt(def) sounds = default.node_sound_wood_defaults(), groups = {falling_node = 1, not_in_creative_inventory = 1}, on_timer = function(pos, elapsed) - tnt.boom(pos, def) + ctf_tnt.boom(pos, def) end, -- unaffected by explosions on_blast = function() end, @@ -577,7 +582,7 @@ function tnt.register_tnt(def) }) end -tnt.register_tnt({ +ctf_tnt.register_tnt({ name = "ctf_tnt:tnt", description = S("TNT"), radius = tnt_radius, From edcde7919bb53ba3a411502fdf95228ed2061d1b Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 19:21:41 +0330 Subject: [PATCH 07/17] improvements --- mods/ctf/ctf_tnt/init.lua | 20 +++++++------------- 1 file changed, 7 insertions(+), 13 deletions(-) diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index 3592f8415..f1b6ff2e4 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -90,7 +90,7 @@ local function destroy(drops, npos, cid, c_air, c_fire, if not ignore_protection and minetest.is_protected(npos, owner) then return cid end - + local node = minetest.get_node_or_nil(npos) if node then if node.name == "ctf_map:reinforced_cobble" then @@ -315,11 +315,7 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne local c_tnt_boom = minetest.get_content_id("ctf_tnt:boom") local c_air = minetest.CONTENT_AIR local c_ignore = minetest.CONTENT_IGNORE - if enable_tnt then - c_tnt = minetest.get_content_id("ctf_tnt:tnt") - else - c_tnt = c_tnt_burning -- tnt is not registered if disabled - end + c_tnt = minetest.get_content_id("ctf_tnt:tnt") -- make sure we still have explosion even when centre node isnt tnt related if explode_center then count = 1 @@ -364,7 +360,7 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne for z = -radius, radius do for y = -radius, radius do local vi = a:index(pos.x + (-radius), pos.y + y, pos.z + z) - local count = 0 + count = 0 for x = -radius, radius do local r = vector.length(vector.new(x, y, z)) if (radius * radius) / (r * r) >= (pr:next(80, 125) / 100) then @@ -495,8 +491,6 @@ function ctf_tnt.register_tnt(def) is_ground_content = false, groups = {dig_immediate = 2, mesecon = 2, tnt = 1, flammable = 5}, sounds = default.node_sound_wood_defaults(), - after_place_node = function(pos, placer) - end, on_punch = function(pos, node, puncher) minetest.swap_node(pos, {name = name .. "_burning"}) minetest.registered_nodes[name .. "_burning"].on_construct(pos) @@ -504,7 +498,7 @@ function ctf_tnt.register_tnt(def) end, on_blast = function(pos, intensity) minetest.after(0.1, function() - tnt.boom(pos, def) + ctf_tnt.boom(pos, def) end) end, on_burn = function(pos) @@ -515,7 +509,7 @@ function ctf_tnt.register_tnt(def) minetest.swap_node(pos, {name = name .. "_burning"}) minetest.registered_nodes[name .. "_burning"].on_construct(pos) end, - after_place_node = function(pos, placer, itemstack, pointed_thing) + after_place_node = function(pos, placer, itemstack, pointed_thing) if placer and placer:is_player() then local meta = minetest.get_meta(pos) local pname = placer:get_player_name() @@ -523,11 +517,11 @@ function ctf_tnt.register_tnt(def) meta:set_string("owner_team", ctf_teams.get(pname)) end end, - on_place = function(itemstack, placer, pointed_thing) + on_place = function(itemstack, placer, pointed_thing) -- first get enemy flags positions -- TNT can be placed only within a radius of -- an enemy flag - if placer and placer:is_player() then + if placer and placer:is_player() then if not ctf_modebase.match_started then hud_events.new(placer:get_player_name(), { quick = true, From 746d78d6ceff957287bb7e1b5f65327e49ccd26e Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 19:59:29 +0330 Subject: [PATCH 08/17] correct commit for maps submodule --- mods/ctf/ctf_map/maps | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mods/ctf/ctf_map/maps b/mods/ctf/ctf_map/maps index 6fb732057..631fc3f69 160000 --- a/mods/ctf/ctf_map/maps +++ b/mods/ctf/ctf_map/maps @@ -1 +1 @@ -Subproject commit 6fb7320571a118720f2c69bc2230f33cf35cfc39 +Subproject commit 631fc3f69950419afe9164aecef01881f36b19f3 From 19a29874429b85e229996f6159c7fb85df489042 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 5 May 2024 20:00:56 +0330 Subject: [PATCH 09/17] fix another luacheck lint --- mods/ctf/ctf_tnt/init.lua | 1 - 1 file changed, 1 deletion(-) diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index f1b6ff2e4..beb2c87ce 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -161,7 +161,6 @@ end local function entity_physics(pos, radius, drops, owner, owner_team) local objs = minetest.get_objects_inside_radius(pos, radius) - local meta = minetest.get_meta(pos) for _, obj in pairs(objs) do local obj_pos = obj:get_pos() local dist = math.max(1, vector.distance(pos, obj_pos)) From b0d5dc185393e6908a4766c8c8ecd0414213cbf1 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Mon, 27 May 2024 18:17:57 +0330 Subject: [PATCH 10/17] TNT gives no score and can be placed anywhere anytime except build time and own base --- mods/ctf/ctf_tnt/init.lua | 24 ++++++++++-------------- mods/ctf/ctf_tnt/mod.conf | 2 +- 2 files changed, 11 insertions(+), 15 deletions(-) diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index beb2c87ce..abc3af767 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -355,7 +355,6 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne basic_flame_on_construct = minetest.registered_nodes["fire:basic_flame"].on_construct local c_fire = minetest.get_content_id("fire:basic_flame") - local removed_blocks = 0 for z = -radius, radius do for y = -radius, radius do local vi = a:index(pos.x + (-radius), pos.y + y, pos.z + z) @@ -371,8 +370,6 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne ignore_protection, ignore_on_blast, owner) if replace ~= c_air then count = count + 1 - else - removed_blocks = removed_blocks + 1 end data[vi] = replace end @@ -418,10 +415,11 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne minetest.log("action", "TNT owned by " .. owner .. " detonated at " .. minetest.pos_to_string(pos) .. " with radius " .. radius) + --[[ if owner ~= "" then local current_mode = ctf_modebase:get_current_mode() current_mode.recent_rankings.add(owner, { score=removed_blocks }, false) - end + end--]] return drops, radius end @@ -530,18 +528,16 @@ function ctf_tnt.register_tnt(def) return nil end local pteam = ctf_teams.get(placer:get_player_name()) - for flagteam, team in pairs(ctf_map.current_map.teams) do - if pteam ~= flagteam and vector.distance(pointed_thing.above, team.flag_pos) <= 24 then - return minetest.item_place(itemstack, placer, pointed_thing) - end + if vector.distance(pointed_thing.above, ctf_map.current_map.teams[pteam].flag_pos) <= 15 then + hud_events.new(placer:get_player_name(), { + quick = true, + text = "You can't place TNT near your own flag", + color = "warning", + }) + return nil end end - hud_events.new(placer:get_player_name(), { - quick = true, - text = "You can place TNT only near one enemy flag", - color = "warning", - }) - return nil + return minetest.item_place(itemstack, placer, pointed_thing) end, }) diff --git a/mods/ctf/ctf_tnt/mod.conf b/mods/ctf/ctf_tnt/mod.conf index 2db71c760..657d713f6 100644 --- a/mods/ctf/ctf_tnt/mod.conf +++ b/mods/ctf/ctf_tnt/mod.conf @@ -1,3 +1,3 @@ name = ctf_tnt description = TNT mod for CTF -depends = default, fire, ctf_teams, hud_events +depends = default, fire, ctf_teams, hud_events, ctf_map From b8121b62b97a5f3421b71be96a31d4e437b1e79e Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Mon, 27 May 2024 18:19:15 +0330 Subject: [PATCH 11/17] no tnt stick spawn in classes mode --- mods/ctf/ctf_modes/ctf_mode_classes/init.lua | 1 - 1 file changed, 1 deletion(-) diff --git a/mods/ctf/ctf_modes/ctf_mode_classes/init.lua b/mods/ctf/ctf_modes/ctf_mode_classes/init.lua index abe9e353e..1d0185fa9 100644 --- a/mods/ctf/ctf_modes/ctf_mode_classes/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_classes/init.lua @@ -64,7 +64,6 @@ ctf_modebase.register_mode("classes", { ["grenades:frag" ] = {rarity = 0.1, max_stacks = 1}, ["grenades:smoke"] = {rarity = 0.2, max_stacks = 2}, ["grenades:poison"] = {rarity = 0.1, max_stacks = 2}, - ["ctf_tnt:tnt_stick"] = {rarity=0.2, max_stacks=2}, }, crafts = { "ctf_ranged:ammo", "default:axe_mese", "default:axe_diamond", "default:shovel_mese", "default:shovel_diamond", From 4e0da5580351ea30583e9a26e4e6373b982bf6c8 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Mon, 27 May 2024 18:20:13 +0330 Subject: [PATCH 12/17] no tnt spawn in classic mode --- mods/ctf/ctf_modes/ctf_mode_classic/init.lua | 1 - 1 file changed, 1 deletion(-) diff --git a/mods/ctf/ctf_modes/ctf_mode_classic/init.lua b/mods/ctf/ctf_modes/ctf_mode_classic/init.lua index 786128df7..419eeda6a 100644 --- a/mods/ctf/ctf_modes/ctf_mode_classic/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_classic/init.lua @@ -30,7 +30,6 @@ ctf_modebase.register_mode("classic", { ["grenades:frag" ] = {rarity = 0.1, max_stacks = 1}, ["grenades:smoke"] = {rarity = 0.2, max_stacks = 2}, - ["ctf_tnt:tnt"] = {rarity=0.2, max_stacks=2}, }, crafts = {"ctf_ranged:ammo", "ctf_melee:sword_steel", "ctf_melee:sword_mese", "ctf_melee:sword_diamond"}, physics = {sneak_glitch = true, new_move = false}, From b799b63fd42ca49c7724cfb435c6294569da6358 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Mon, 27 May 2024 18:22:59 +0330 Subject: [PATCH 13/17] slightly add the chance of finding tnt stick in nade fight --- mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua index 1a57c5758..65c4677f2 100644 --- a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua @@ -46,12 +46,13 @@ ctf_modebase.register_mode("nade_fight", { ["grenades:smoke"] = {rarity = 0.2, max_stacks = 3}, ["grenades:poison"] = {rarity = 0.1, max_stacks = 2}, - ["ctf_tnt:tnt"] = {rarity=0.2, max_stacks=2}, + ["ctf_tnt:tnt_stick"] = {rarity=0.25, max_stacks=3}, }, crafts = { "ctf_map:damage_cobble", "ctf_map:spike", "ctf_map:reinforced_cobble 2", + "ctf_tnt:tnt_stick", }, physics = {sneak_glitch = true, new_move = false}, blacklisted_nodes = {"default:apple"}, From cc304a48943eba000237434f9297545b88f39e01 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Mon, 27 May 2024 18:23:44 +0330 Subject: [PATCH 14/17] tnt recipes are not always known --- mods/ctf/ctf_modebase/crafting.lua | 2 -- 1 file changed, 2 deletions(-) diff --git a/mods/ctf/ctf_modebase/crafting.lua b/mods/ctf/ctf_modebase/crafting.lua index 544af20b6..28afe20a5 100644 --- a/mods/ctf/ctf_modebase/crafting.lua +++ b/mods/ctf/ctf_modebase/crafting.lua @@ -177,11 +177,9 @@ crafting.register_recipe({ crafting.register_recipe({ output = "ctf_tnt:tnt_stick 2", items = { "default:papyrus", "ctf_ranged:ammo 2" }, - always_known = true, }) crafting.register_recipe({ output = "ctf_tnt:tnt", items = { "ctf_tnt:tnt_stick 8" }, - always_known = true, }) From a6c9380b71d990b80cb839fe1b47d06833047787 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Mon, 27 May 2024 18:24:27 +0330 Subject: [PATCH 15/17] make tnt crafting available in nade fight --- mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua | 1 + 1 file changed, 1 insertion(+) diff --git a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua index 65c4677f2..b019072da 100644 --- a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua @@ -53,6 +53,7 @@ ctf_modebase.register_mode("nade_fight", { "ctf_map:spike", "ctf_map:reinforced_cobble 2", "ctf_tnt:tnt_stick", + "ctf_tnt:tnt", }, physics = {sneak_glitch = true, new_move = false}, blacklisted_nodes = {"default:apple"}, From 85d818bc85ff6dc78b69ba750c20f61c0d562f0d Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Mon, 27 May 2024 18:30:25 +0330 Subject: [PATCH 16/17] slightly adjust rarity of TNT sticks --- mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua index b019072da..7665054cc 100644 --- a/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua +++ b/mods/ctf/ctf_modes/ctf_mode_nade_fight/init.lua @@ -46,7 +46,7 @@ ctf_modebase.register_mode("nade_fight", { ["grenades:smoke"] = {rarity = 0.2, max_stacks = 3}, ["grenades:poison"] = {rarity = 0.1, max_stacks = 2}, - ["ctf_tnt:tnt_stick"] = {rarity=0.25, max_stacks=3}, + ["ctf_tnt:tnt_stick"] = {rarity=0.35, max_stacks=3}, }, crafts = { "ctf_map:damage_cobble", From 15f5efcc2ffda9362de966f47e206baeab66e396 Mon Sep 17 00:00:00 2001 From: Farooq Karimi Zadeh Date: Sun, 9 Jun 2024 22:22:52 +0330 Subject: [PATCH 17/17] revert changes: TNT gives score if enemy base destroyed --- mods/ctf/ctf_tnt/init.lua | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/mods/ctf/ctf_tnt/init.lua b/mods/ctf/ctf_tnt/init.lua index abc3af767..1e6849e5f 100644 --- a/mods/ctf/ctf_tnt/init.lua +++ b/mods/ctf/ctf_tnt/init.lua @@ -359,6 +359,7 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne for y = -radius, radius do local vi = a:index(pos.x + (-radius), pos.y + y, pos.z + z) count = 0 + local removed_blocks = 0 for x = -radius, radius do local r = vector.length(vector.new(x, y, z)) if (radius * radius) / (r * r) >= (pr:next(80, 125) / 100) then @@ -370,6 +371,12 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne ignore_protection, ignore_on_blast, owner) if replace ~= c_air then count = count + 1 + else + for flagteam, team in pairs(ctf_map.current_map.teams) do + if owner_team ~= flagteam and vector.distance(p, team.flag_pos) <= 15 then + removed_blocks = removed_blocks + 1 + end + end end data[vi] = replace end @@ -415,11 +422,10 @@ local function tnt_explode(pos, radius, ignore_protection, ignore_on_blast, owne minetest.log("action", "TNT owned by " .. owner .. " detonated at " .. minetest.pos_to_string(pos) .. " with radius " .. radius) - --[[ if owner ~= "" then local current_mode = ctf_modebase:get_current_mode() - current_mode.recent_rankings.add(owner, { score=removed_blocks }, false) - end--]] + current_mode.recent_rankings.add(owner, { score=removed_blocks / 5 }, false) + end return drops, radius end