Add a allow_protected definition parameter

This commit is contained in:
upsilon 2017-03-05 15:30:02 +01:00
parent 33bc0b5f69
commit 4fe2a0c88c
No known key found for this signature in database
GPG Key ID: A80DAE1F266E1C3C
3 changed files with 12 additions and 1 deletions

View File

@ -21,6 +21,7 @@ throwing.horizontal_acceleration_factor = -3
throwing.vertical_acceleration = -10 throwing.vertical_acceleration = -10
throwing.allow_arrow_placing = false throwing.allow_arrow_placing = false
throwing.arrow_teleport_in_protected = true
``` ```
## API ## API
@ -53,6 +54,7 @@ Definition: definition table, containing:
* craft_quantity (optional, defaulting to 1 if itemcraft is non-nil, pointless otherwise): quantity of arrows in the craft output. * craft_quantity (optional, defaulting to 1 if itemcraft is non-nil, pointless otherwise): quantity of arrows in the craft output.
* tiles (essential): tiles of the arrow. * tiles (essential): tiles of the arrow.
* target (optional, defaulting to throwing.target_both): what the arrow is able to hit (throwing.target_node, throwing.target_object, throwing.target_both). * target (optional, defaulting to throwing.target_both): what the arrow is able to hit (throwing.target_node, throwing.target_object, throwing.target_both).
* allow_protected (optional, defaulting to false): whether the arrow can be throw in a protected area
* on_hit_sound (optional): sound played when the arrow hits a node or an object. * on_hit_sound (optional): sound played when the arrow hits a node or an object.
* on_hit(pos, last_pos, node, object, hitter, data, self) (must exist, will crash if nil): callback function: * on_hit(pos, last_pos, node, object, hitter, data, self) (must exist, will crash if nil): callback function:
- pos: the position of the hit node or object. - pos: the position of the hit node or object.

View File

@ -88,7 +88,7 @@ local function arrow_step(self, dtime)
return return
end end
if node and minetest.is_protected(pos, self.player) then -- Forbid hitting nodes in protected areas if node and minetest.is_protected(pos, self.player) and not self.allow_protected then -- Forbid hitting nodes in protected areas
minetest.record_protection_violation(pos, self.player) minetest.record_protection_violation(pos, self.player)
logging("hitted a node into a protected area") logging("hitted a node into a protected area")
return return
@ -241,6 +241,7 @@ function throwing.register_arrow(name, def)
on_hit_sound = def.on_hit_sound, on_hit_sound = def.on_hit_sound,
on_throw_sound = def.on_throw_sound, on_throw_sound = def.on_throw_sound,
on_throw = def.on_throw, on_throw = def.on_throw,
allow_protected = def.allow_protected,
target = def.target, target = def.target,
on_hit_fails = def.on_hit_fails, on_hit_fails = def.on_hit_fails,
node = throwing.modname..":"..name, node = throwing.modname..":"..name,

View File

@ -45,6 +45,7 @@ if get_setting("arrow") then
description = "Arrow", description = "Arrow",
tiles = {"throwing_arrow.png", "throwing_arrow.png", "throwing_arrow_back.png", "throwing_arrow_front.png", "throwing_arrow_2.png", "throwing_arrow.png"}, tiles = {"throwing_arrow.png", "throwing_arrow.png", "throwing_arrow_back.png", "throwing_arrow_front.png", "throwing_arrow_2.png", "throwing_arrow.png"},
target = throwing.target_both, target = throwing.target_both,
allow_protected = true,
on_hit_sound = "throwing_arrow", on_hit_sound = "throwing_arrow",
on_hit = function(pos, _, node, object, hitter) on_hit = function(pos, _, node, object, hitter)
if object then if object then
@ -68,6 +69,7 @@ if get_setting("golden_arrow") then
description = "Golden Arrow", description = "Golden Arrow",
tiles = {"throwing_arrow_gold.png", "throwing_arrow_gold.png", "throwing_arrow_gold_back.png", "throwing_arrow_gold_front.png", "throwing_arrow_gold_2.png", "throwing_arrow_gold.png"}, tiles = {"throwing_arrow_gold.png", "throwing_arrow_gold.png", "throwing_arrow_gold_back.png", "throwing_arrow_gold_front.png", "throwing_arrow_gold_2.png", "throwing_arrow_gold.png"},
target = throwing.target_object, target = throwing.target_object,
allow_protected = true,
on_hit_sound = "throwing_arrow", on_hit_sound = "throwing_arrow",
on_hit = function(pos, _, _, object, hitter) on_hit = function(pos, _, _, object, hitter)
object:punch(hitter, 1, { object:punch(hitter, 1, {
@ -108,6 +110,7 @@ if get_setting("teleport_arrow") then
itemcraft = "default:diamond", itemcraft = "default:diamond",
description = "Teleport Arrow", description = "Teleport Arrow",
tiles = {"throwing_arrow_teleport.png", "throwing_arrow_teleport.png", "throwing_arrow_teleport_back.png", "throwing_arrow_teleport_front.png", "throwing_arrow_teleport_2.png", "throwing_arrow_teleport.png"}, tiles = {"throwing_arrow_teleport.png", "throwing_arrow_teleport.png", "throwing_arrow_teleport_back.png", "throwing_arrow_teleport_front.png", "throwing_arrow_teleport_2.png", "throwing_arrow_teleport.png"},
allow_protected = true,
on_hit_sound = "throwing_teleport_arrow", on_hit_sound = "throwing_teleport_arrow",
on_hit = function(_, last_pos, _, _, hitter) on_hit = function(_, last_pos, _, _, hitter)
if minetest.get_node(last_pos).name ~= "air" then if minetest.get_node(last_pos).name ~= "air" then
@ -115,6 +118,10 @@ if get_setting("teleport_arrow") then
return return
end end
if minetest.setting_getbool("throwing.allow_teleport_in_protected") == false then
return false
end
hitter:moveto(last_pos) hitter:moveto(last_pos)
end end
}) })
@ -170,6 +177,7 @@ if get_setting("drop_arrow") then
description = "Drop Arrow", description = "Drop Arrow",
tiles = {"throwing_arrow_drop.png", "throwing_arrow_drop.png", "throwing_arrow_drop_back.png", "throwing_arrow_drop_front.png", "throwing_arrow_drop_2.png", "throwing_arrow_drop.png"}, tiles = {"throwing_arrow_drop.png", "throwing_arrow_drop.png", "throwing_arrow_drop_back.png", "throwing_arrow_drop_front.png", "throwing_arrow_drop_2.png", "throwing_arrow_drop.png"},
on_hit_sound = "throwing_build_arrow", on_hit_sound = "throwing_build_arrow",
allow_protected = true,
on_throw = function(_, thrower, next_index, data) on_throw = function(_, thrower, next_index, data)
data.itemstack = thrower:get_inventory():get_stack("main", next_index) data.itemstack = thrower:get_inventory():get_stack("main", next_index)
data.index = next_index data.index = next_index