From 16b6bdde0acb9258734a7ce30854b23a65bcd418 Mon Sep 17 00:00:00 2001 From: Lars Mueller Date: Tue, 6 Jun 2023 14:07:33 +0200 Subject: [PATCH] `default.set_inventory_action_loggers`: Hook (instead of replace) callbacks --- game_api.txt | 3 ++- mods/default/functions.lua | 7 +++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/game_api.txt b/game_api.txt index 8d3653d..a2e9c64 100644 --- a/game_api.txt +++ b/game_api.txt @@ -1142,8 +1142,9 @@ the log. `default.set_inventory_action_loggers(def, name)` - * sets the callbacks `on_metadata_inventory_move`, + * hooks the callbacks `on_metadata_inventory_move`, `on_metadata_inventory_put` and `on_metadata_inventory_take` that log corresponding actions + * after logging the action, the original callback (if any) is called * `def` See [Node definition] * `name` Description of the node in the log message diff --git a/mods/default/functions.lua b/mods/default/functions.lua index 0afd97e..3c31e97 100644 --- a/mods/default/functions.lua +++ b/mods/default/functions.lua @@ -744,16 +744,23 @@ function default.log_player_action(player, ...) minetest.log("action", msg) end +local nop = function() end function default.set_inventory_action_loggers(def, name) + local on_move = def.on_metadata_inventory_move or nop def.on_metadata_inventory_move = function(pos, from_list, from_index, to_list, to_index, count, player) default.log_player_action(player, "moves stuff in", name, "at", pos) + return on_move(pos, from_list, from_index, to_list, to_index, count, player) end + local on_put = def.on_metadata_inventory_put or nop def.on_metadata_inventory_put = function(pos, listname, index, stack, player) default.log_player_action(player, "moves", stack:get_name(), "to", name, "at", pos) + return on_put(pos, listname, index, stack, player) end + local on_take = def.on_metadata_inventory_take or nop def.on_metadata_inventory_take = function(pos, listname, index, stack, player) default.log_player_action(player, "takes", stack:get_name(), "from", name, "at", pos) + return on_take(pos, listname, index, stack, player) end end