mirror of
https://github.com/minetest-mods/digtron.git
synced 2025-01-05 10:17:28 +01:00
Add logging of various events.
This commit is contained in:
parent
253ff12815
commit
e9e8e202f9
@ -197,6 +197,7 @@ minetest.register_node("digtron:builder", {
|
|||||||
local build_facing = meta:get_int("build_facing")
|
local build_facing = meta:get_int("build_facing")
|
||||||
local facing = minetest.get_node(pos).param2
|
local facing = minetest.get_node(pos).param2
|
||||||
local buildpos = digtron.find_new_pos(pos, facing)
|
local buildpos = digtron.find_new_pos(pos, facing)
|
||||||
|
local oldnode = minetest.get_node(buildpos)
|
||||||
|
|
||||||
if (buildpos[controlling_coordinate] + meta:get_int("offset")) % meta:get_int("period") ~= 0 then
|
if (buildpos[controlling_coordinate] + meta:get_int("offset")) % meta:get_int("period") ~= 0 then
|
||||||
return nil
|
return nil
|
||||||
@ -210,6 +211,7 @@ minetest.register_node("digtron:builder", {
|
|||||||
if digtron.creative_mode then
|
if digtron.creative_mode then
|
||||||
local returned_stack, success = digtron.item_place_node(item_stack, player, buildpos, tonumber(build_facing))
|
local returned_stack, success = digtron.item_place_node(item_stack, player, buildpos, tonumber(build_facing))
|
||||||
if success == true then
|
if success == true then
|
||||||
|
minetest.log("action", string.format("%s uses Digtron to build %s at (%d, %d, %d), displacing %s", player:get_player_name(), item_stack:get_name(), buildpos.x, buildpos.y, buildpos.z, oldnode.name))
|
||||||
nodes_dug:set(buildpos.x, buildpos.y, buildpos.z, false)
|
nodes_dug:set(buildpos.x, buildpos.y, buildpos.z, false)
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
@ -223,6 +225,7 @@ minetest.register_node("digtron:builder", {
|
|||||||
end
|
end
|
||||||
local returned_stack, success = digtron.item_place_node(item_stack, player, buildpos, tonumber(build_facing))
|
local returned_stack, success = digtron.item_place_node(item_stack, player, buildpos, tonumber(build_facing))
|
||||||
if success == true then
|
if success == true then
|
||||||
|
minetest.log("action", string.format("%s uses Digtron to build %s at (%d, %d, %d), displacing %s", player:get_player_name(), item_stack:get_name(), buildpos.x, buildpos.y, buildpos.z, oldnode.name))
|
||||||
--flag this node as *not* to be dug.
|
--flag this node as *not* to be dug.
|
||||||
nodes_dug:set(buildpos.x, buildpos.y, buildpos.z, false)
|
nodes_dug:set(buildpos.x, buildpos.y, buildpos.z, false)
|
||||||
return true
|
return true
|
||||||
|
@ -190,7 +190,7 @@ local execute_cycle = function(pos, clicker)
|
|||||||
end
|
end
|
||||||
|
|
||||||
--move the array
|
--move the array
|
||||||
digtron.move_digtron(facing, layout.all, layout.extents, nodes_dug)
|
digtron.move_digtron(facing, layout.all, layout.extents, nodes_dug, clicker:get_player_name())
|
||||||
local oldpos = {x=pos.x, y=pos.y, z=pos.z}
|
local oldpos = {x=pos.x, y=pos.y, z=pos.z}
|
||||||
pos = digtron.find_new_pos(pos, facing)
|
pos = digtron.find_new_pos(pos, facing)
|
||||||
meta = minetest.get_meta(pos)
|
meta = minetest.get_meta(pos)
|
||||||
@ -246,6 +246,7 @@ local execute_cycle = function(pos, clicker)
|
|||||||
local node_to_dig, whether_to_dig = nodes_dug:pop()
|
local node_to_dig, whether_to_dig = nodes_dug:pop()
|
||||||
while node_to_dig ~= nil do
|
while node_to_dig ~= nil do
|
||||||
if whether_to_dig == true then
|
if whether_to_dig == true then
|
||||||
|
minetest.log("action", string.format("%s uses Digtron to dig %s at (%d, %d, %d)", clicker:get_player_name(), minetest.get_node(node_to_dig).name, node_to_dig.x, node_to_dig.y, node_to_dig.z))
|
||||||
minetest.remove_node(node_to_dig)
|
minetest.remove_node(node_to_dig)
|
||||||
end
|
end
|
||||||
-- all of the digtron's nodes wind up in nodes_dug, so this is an ideal place to stick
|
-- all of the digtron's nodes wind up in nodes_dug, so this is an ideal place to stick
|
||||||
|
8
util.lua
8
util.lua
@ -95,9 +95,11 @@ digtron.can_move_to = function(pos, protected_nodes, dug_nodes)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
digtron.move_node = function(pos, newpos)
|
digtron.move_node = function(pos, newpos, player_name)
|
||||||
-- Moves nodes, preserving digtron metadata and inventory
|
-- Moves nodes, preserving digtron metadata and inventory
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
|
local oldnode = minetest.get_node(newpos)
|
||||||
|
minetest.log("action", string.format("%s moves %s from (%d, %d, %d) to (%d, %d, %d), displacing %s", player_name, node.name, pos.x, pos.y, pos.z, newpos.x, newpos.y, newpos.z, oldnode.name))
|
||||||
minetest.add_node(newpos, { name=node.name, param1=node.param1, param2=node.param2 })
|
minetest.add_node(newpos, { name=node.name, param1=node.param1, param2=node.param2 })
|
||||||
|
|
||||||
local oldmeta = minetest.get_meta(pos)
|
local oldmeta = minetest.get_meta(pos)
|
||||||
@ -276,7 +278,7 @@ digtron.take_from_inventory = function(itemname, inventory_positions)
|
|||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
|
|
||||||
digtron.move_digtron = function(facing, digtrons, extents, nodes_dug)
|
digtron.move_digtron = function(facing, digtrons, extents, nodes_dug, player_name)
|
||||||
-- move everything. Note! order is important or they'll step on each other, that's why this has complicated loops and filtering.
|
-- move everything. Note! order is important or they'll step on each other, that's why this has complicated loops and filtering.
|
||||||
-- Nodes are moved in a "caterpillar" pattern - front plane first, then next plane back, then next plane back, etc.
|
-- Nodes are moved in a "caterpillar" pattern - front plane first, then next plane back, then next plane back, etc.
|
||||||
-- positions in the digtron list will be updated when this method executes. Note that the inventories list shares
|
-- positions in the digtron list will be updated when this method executes. Note that the inventories list shares
|
||||||
@ -334,7 +336,7 @@ digtron.move_digtron = function(facing, digtrons, extents, nodes_dug)
|
|||||||
for k, location in pairs(digtrons) do
|
for k, location in pairs(digtrons) do
|
||||||
if location[filter] == index then
|
if location[filter] == index then
|
||||||
local newpos = digtron.find_new_pos(location, facing)
|
local newpos = digtron.find_new_pos(location, facing)
|
||||||
digtron.move_node(location, newpos)
|
digtron.move_node(location, newpos, player_name)
|
||||||
--By updating the digtron position table in-place we also update all the special node tables as well
|
--By updating the digtron position table in-place we also update all the special node tables as well
|
||||||
digtrons[k].x= newpos.x
|
digtrons[k].x= newpos.x
|
||||||
digtrons[k].y= newpos.y
|
digtrons[k].y= newpos.y
|
||||||
|
Loading…
Reference in New Issue
Block a user