mirror of
https://github.com/Refactorio/RedMew.git
synced 2025-01-18 03:21:47 +02:00
50 lines
1.1 KiB
Lua
50 lines
1.1 KiB
Lua
-- dependencies
|
|
local format = string.format
|
|
local serialize = serpent.line
|
|
|
|
-- this
|
|
local Debug = {}
|
|
|
|
global.debug_message_count = 0
|
|
|
|
---@return number next index
|
|
local function increment()
|
|
local next = global.debug_message_count + 1
|
|
global.debug_message_count = next
|
|
|
|
return next
|
|
end
|
|
|
|
---Shows the given message if debug is enabled. Uses serpent to print non scalars.
|
|
---@param message table
|
|
function Debug.print(message)
|
|
if not _DEBUG then
|
|
return
|
|
end
|
|
|
|
if type(message) ~= 'string' and type(message) ~= 'number' and type(message) ~= 'boolean' then
|
|
message = serialize(message)
|
|
end
|
|
|
|
message = format('[%d] %s', increment(), tostring(message))
|
|
game.print(message)
|
|
log(message)
|
|
end
|
|
|
|
---Shows the given message if debug is on.
|
|
---@param position Position
|
|
---@param message string
|
|
function Debug.print_position(position, message)
|
|
Debug.print(format('%s %s', serialize(position), message))
|
|
end
|
|
|
|
---Executes the given callback if cheating is enabled.
|
|
---@param callback function
|
|
function Debug.cheat(callback)
|
|
if _CHEATS then
|
|
callback()
|
|
end
|
|
end
|
|
|
|
return Debug
|