Fork of lines.love with some tweaks specific to mobile devices
function log(stack_frame_index, obj)
  local info = debug.getinfo(stack_frame_index, 'Sl')
  local msg
  if type(obj) == 'string' then
    msg = obj
  else
    msg = json.encode(obj)
  end
  love.filesystem.append('log', info.short_src..':'..info.currentline..': '..msg..'\n')
end

-- for section delimiters we'll use specific Unicode box characters
function log_start(name, stack_frame_index)
  if stack_frame_index == nil then
    stack_frame_index = 3
  end
  -- I'd like to use the unicode character \u{250c} here, but it doesn't work
  -- in OpenBSD.
  log(stack_frame_index, '[ u250c ' .. name)
end
function log_end(name, stack_frame_index)
  if stack_frame_index == nil then
    stack_frame_index = 3
  end
  -- I'd like to use the unicode character \u{2518} here, but it doesn't work
  -- in OpenBSD.
  log(stack_frame_index, '] u2518 ' .. name)
end

function log_new(name, stack_frame_index)
  if stack_frame_index == nil then
    stack_frame_index = 4
  end
  log_end(name, stack_frame_index)
  log_start(name, stack_frame_index)
end

-- rendering graphical objects within sections/boxes
log_render = {}

-- vim:noexpandtab