歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> 改造Lua的debug.traceback() 讓其顯示棧上所有的局部變量

改造Lua的debug.traceback() 讓其顯示棧上所有的局部變量

日期:2017/3/1 10:31:03   编辑:Linux編程
  1. function tracebackex()
  2. local ret = ""
  3. local level = 2
  4. ret = ret .. "stack traceback:\n"
  5. while true do
  6. --get stack info
  7. local info = debug.getinfo(level, "Sln")
  8. if not info then break end
  9. if info.what == "C" then -- C function
  10. ret = ret .. tostring(level) .. "\tC function\n"
  11. else -- Lua function
  12. ret = ret .. string.format("\t[%s]:%d in function `%s`\n", info.short_src, info.currentline, info.name or "")
  13. end
  14. --get local vars
  15. local i = 1
  16. while true do
  17. local name, value = debug.getlocal(level, i)
  18. if not name then break end
  19. ret = ret .. "\t\t" .. name .. " =\t" .. tostringex(value, 3) .. "\n"
  20. i = i + 1
  21. end
  22. level = level + 1
  23. end
  24. return ret
  25. end
  26. function tostringex(v, len)
  27. if len == nil then len = 0 end
  28. local pre = string.rep('\t', len)
  29. local ret = ""
  30. if type(v) == "table" then
  31. if len > 5 then return "\t{ ... }" end
  32. local t = ""
  33. for k, v1 in pairs(v) do
  34. t = t .. "\n\t" .. pre .. tostring(k) .. ":"
  35. t = t .. tostringex(v1, len + 1)
  36. end
  37. if t == "" then
  38. ret = ret .. pre .. "{ }\t(" .. tostring(v) .. ")"
  39. else
  40. if len > 0 then
  41. ret = ret .. "\t(" .. tostring(v) .. ")\n"
  42. end
  43. ret = ret .. pre .. "{" .. t .. "\n" .. pre .. "}"
  44. end
  45. else
  46. ret = ret .. pre .. tostring(v) .. "\t(" .. type(v) .. ")"
  47. end
  48. return ret
  49. end
Copyright © Linux教程網 All Rights Reserved