mirror of
https://github.com/minetest-mods/throwing.git
synced 2025-01-25 01:20:21 +01:00
Tell the allow_shot
function if it is its last run
This commit is contained in:
parent
164bf6b5fc
commit
e9acbfa6d1
@ -39,9 +39,12 @@ Definition: definition table, containing:
|
|||||||
* texture (essential): texture of the bow, shown in inventory.
|
* texture (essential): texture of the bow, shown in inventory.
|
||||||
* groups (optional): groups of the item.
|
* groups (optional): groups of the item.
|
||||||
* uses: number of uses of the bow (default is 50).
|
* uses: number of uses of the bow (default is 50).
|
||||||
* allow_shot (optional): function(player, itemstack, index):
|
* allow_shot (optional): function(player, itemstack, index, last_run):
|
||||||
- player: the player using the bow
|
- player: the player using the bow
|
||||||
- itemstack: the itemstack of the bow
|
- itemstack: the itemstack of the bow
|
||||||
|
- index: index of the arrow in the inventory
|
||||||
|
- last_run: whether this is the last time this function is called before actually calling `spawn_arrow_entity`.
|
||||||
|
Currently, `allow_shot` is actually run twice (once before the delay, and once after).
|
||||||
- should return true if the shot can be made, and false otherwise
|
- should return true if the shot can be made, and false otherwise
|
||||||
- the default function checks that the arrow to be thrown is a registered arrow
|
- the default function checks that the arrow to be thrown is a registered arrow
|
||||||
- it can return a second return value, which is the new itemstack
|
- it can return a second return value, which is the new itemstack
|
||||||
|
4
init.lua
4
init.lua
@ -338,7 +338,7 @@ function throwing.register_bow(name, def)
|
|||||||
|
|
||||||
local bow_index = user:get_wield_index()
|
local bow_index = user:get_wield_index()
|
||||||
local arrow_index = (def.throw_itself and bow_index) or bow_index+1
|
local arrow_index = (def.throw_itself and bow_index) or bow_index+1
|
||||||
local res, new_stack = def.allow_shot(user, user:get_inventory():get_stack("main", arrow_index), arrow_index)
|
local res, new_stack = def.allow_shot(user, user:get_inventory():get_stack("main", arrow_index), arrow_index, false)
|
||||||
if not res then
|
if not res then
|
||||||
return (def.throw_itself and new_stack) or itemstack
|
return (def.throw_itself and new_stack) or itemstack
|
||||||
end
|
end
|
||||||
@ -352,7 +352,7 @@ function throwing.register_bow(name, def)
|
|||||||
minetest.after(def.delay or 0, function()
|
minetest.after(def.delay or 0, function()
|
||||||
-- Re-check that the arrow can be thrown. Overwrite the new_stack
|
-- Re-check that the arrow can be thrown. Overwrite the new_stack
|
||||||
local old_new_stack = new_stack
|
local old_new_stack = new_stack
|
||||||
res, new_stack = def.allow_shot(user, user:get_inventory():get_stack("main", arrow_index), arrow_index)
|
res, new_stack = def.allow_shot(user, user:get_inventory():get_stack("main", arrow_index), arrow_index, true)
|
||||||
if not new_stack then
|
if not new_stack then
|
||||||
new_stack = old_new_stack
|
new_stack = old_new_stack
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user