金庆的专栏

  C++博客 :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  423 随笔 :: 0 文章 :: 454 评论 :: 0 Trackbacks
Lua热更新时正确设置文件名

(金庆的专栏 2016.12)

Lua热更新模块见:
https://github.com/jinq0123/hotfix

其中使用 load(chunk) 来加载更新后的内容,发现 traceback 打印缺少文件名,
这对于调试纠错有不小的影响。


test.lua

local M = {}

function M.test()
  assert(false, "test assert 5")
end

return M


如下测试:

D:\Jinq\temp\lua>d:\Jinq\tools\lua-5.3.2_Win64_bin\lua53
Lua 5.3.2  Copyright (C) 1994-2015 Lua.org, PUC-Rio
> hf = require("hotfix")
> t = require("test")
> t.test()
.\test.lua:4: test assert
stack traceback:
        [C]: in function 'assert'
        .\test.lua:4: in function 'test.test'
        (...tail calls...)
        [C]: in ?
> hf.hotfix_module("test")
table: 000000000078a6d0
> t.test()
[string "local M = {}..."]:4: test assert 2
stack traceback:
        [C]: in function 'assert'
        [string "local M = {}..."]:4: in function 'test.test'
        (...tail calls...)
        [C]: in ?
>

       
文件名信息被文件内容字符串给代替了。

改成:load(chunk, file_path), 结果是这样的:

> t.test()
[string ".\test.lua"]:4: test assert 3
stack traceback:
        [C]: in function 'assert'
        [string ".\test.lua"]:4: in function 'test.test'
        (...tail calls...)
        [C]: in ?
>

查看源码,发现需要用"@"前缀来表示这是个文件名,于是改成:

    load(chunk, '@'..file_path)
    
终于正常了。

posted on 2016-12-18 16:32 金庆 阅读(354) 评论(0)  编辑 收藏 引用 所属分类: 9. 其它

只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理