2018-09-08 18:29:27 +02:00
|
|
|
-- dependencies
|
2018-10-11 19:43:04 +02:00
|
|
|
local min = math.min
|
|
|
|
local max = math.max
|
|
|
|
local floor = math.floor
|
|
|
|
local abs = math.abs
|
2018-09-08 18:29:27 +02:00
|
|
|
|
|
|
|
-- this
|
|
|
|
local Debug = {}
|
|
|
|
|
|
|
|
-- private state
|
|
|
|
local debug = false
|
|
|
|
local cheats = false
|
|
|
|
|
|
|
|
function Debug.enable_debug()
|
|
|
|
debug = true
|
|
|
|
end
|
|
|
|
|
|
|
|
function Debug.disable_debug()
|
|
|
|
debug = false
|
|
|
|
end
|
|
|
|
|
|
|
|
function Debug.enable_cheats()
|
|
|
|
cheats = true
|
|
|
|
end
|
|
|
|
|
|
|
|
function Debug.disable_cheats()
|
|
|
|
cheats = true
|
|
|
|
end
|
|
|
|
|
2018-10-07 13:50:25 +02:00
|
|
|
global.message_count = 0
|
2018-09-11 22:15:02 +02:00
|
|
|
|
2018-09-08 18:29:27 +02:00
|
|
|
--[[--
|
|
|
|
Shows the given message if _DEBUG == true.
|
|
|
|
|
|
|
|
@param message string
|
|
|
|
]]
|
|
|
|
function Debug.print(message)
|
2018-09-20 17:34:17 +02:00
|
|
|
if type(message) ~= 'string' and type(message) ~= 'number' and type(message) ~= 'boolean' then message = type(message) end
|
2018-10-07 13:50:25 +02:00
|
|
|
global.message_count = global.message_count + 1
|
2018-09-08 18:29:27 +02:00
|
|
|
if (debug) then
|
2018-10-07 13:50:25 +02:00
|
|
|
game.print('[' .. global.message_count .. '] ' .. tostring(message))
|
|
|
|
log('[' .. global.message_count .. '] ' .. tostring(message))
|
2018-09-08 18:29:27 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-09-13 20:42:12 +02:00
|
|
|
--[[--
|
|
|
|
Shows the given message if _DEBUG == true for a given position.
|
|
|
|
|
|
|
|
@param x number
|
|
|
|
@param y number
|
|
|
|
@param message string
|
|
|
|
]]
|
2018-09-20 13:15:12 +02:00
|
|
|
function Debug.printPosition(position, message)
|
|
|
|
message = message or ''
|
2018-09-20 17:34:17 +02:00
|
|
|
if type(message) ~= 'string' and type(message) ~= 'number' and type(message) ~= 'boolean' then message = type(message) end
|
2018-10-07 13:50:25 +02:00
|
|
|
global.message_count = global.message_count + 1
|
2018-09-13 20:42:12 +02:00
|
|
|
if (debug) then
|
2018-10-07 13:50:25 +02:00
|
|
|
game.print('[' .. global.message_count .. '] {x=' .. position.x .. ', y=' .. position.y .. '} ' .. tostring(message))
|
2018-09-13 20:42:12 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-09-08 18:29:27 +02:00
|
|
|
--[[--
|
2018-11-10 14:37:24 +02:00
|
|
|
Executes the given callback if cheating is enabled.
|
2018-09-08 18:29:27 +02:00
|
|
|
|
|
|
|
@param callback function
|
|
|
|
]]
|
|
|
|
function Debug.cheat(callback)
|
|
|
|
if (cheats) then
|
|
|
|
callback()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-09-25 21:34:36 +02:00
|
|
|
--[[--
|
|
|
|
Prints a colored value on a location.
|
|
|
|
|
|
|
|
@param value between -1 and 1
|
|
|
|
@param surface LuaSurface
|
|
|
|
@param position Position {x, y}
|
|
|
|
]]
|
2018-10-16 13:40:32 +02:00
|
|
|
function Debug.print_grid_value(value, surface, position, scale, offset)
|
2018-11-10 14:37:24 +02:00
|
|
|
local is_string = type(value) == 'string'
|
|
|
|
local color = {r = 1, g = 1, b = 1}
|
|
|
|
text = value
|
2018-09-29 23:02:15 +02:00
|
|
|
|
2018-11-10 14:37:24 +02:00
|
|
|
if not is_string then
|
|
|
|
scale = scale or 1
|
|
|
|
offset = offset or 0
|
|
|
|
position = {x = position.x + offset, y = position.y + offset}
|
|
|
|
local r = max(1, value) / scale
|
|
|
|
local g = 1 - abs(value) / scale
|
|
|
|
local b = min(1, value) / scale
|
2018-09-29 23:02:15 +02:00
|
|
|
|
2018-11-10 14:37:24 +02:00
|
|
|
if (r > 0) then
|
|
|
|
r = 0
|
|
|
|
end
|
2018-10-15 13:50:41 +02:00
|
|
|
|
2018-11-10 14:37:24 +02:00
|
|
|
if (b < 0) then
|
|
|
|
b = 0
|
|
|
|
end
|
2018-09-29 23:02:15 +02:00
|
|
|
|
2018-11-10 14:37:24 +02:00
|
|
|
if (g < 0) then
|
|
|
|
g = 0
|
|
|
|
end
|
2018-09-29 23:02:15 +02:00
|
|
|
|
2018-11-10 14:37:24 +02:00
|
|
|
r = abs(r)
|
2018-09-25 21:34:36 +02:00
|
|
|
|
2018-11-10 14:37:24 +02:00
|
|
|
color = { r = r, g = g, b = b}
|
|
|
|
|
|
|
|
-- round at precision of 2
|
|
|
|
local text = floor(100 * value) * 0.01
|
|
|
|
|
|
|
|
if (0 == text) then
|
|
|
|
text = '0.00'
|
|
|
|
end
|
2018-09-26 22:15:39 +02:00
|
|
|
end
|
|
|
|
|
2018-09-25 21:34:36 +02:00
|
|
|
local text_entity = surface.find_entity('flying-text', position)
|
|
|
|
|
|
|
|
if text_entity then
|
|
|
|
text_entity.text = text
|
|
|
|
text_entity.color = color
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
surface.create_entity{
|
|
|
|
name = 'flying-text',
|
|
|
|
color = color,
|
|
|
|
text = text,
|
|
|
|
position = position
|
|
|
|
}.active = false
|
|
|
|
end
|
|
|
|
|
2018-09-08 18:29:27 +02:00
|
|
|
return Debug
|