美文网首页cocos2dcocos2d-Lua
cocos 模仿dump写了一个写错误日志的函数

cocos 模仿dump写了一个写错误日志的函数

作者: 人气小哥 | 来源:发表于2017-06-05 21:58 被阅读12次

--require("src.app.utils.FileUtil") 可能会需要包含这个文件
ErrorPath = "error.log"     --记录错误日志路径 默认与exe 同级目录
--写错误日志 表
function dumpError(value, desciption, nesting)

    io.writefile(ErrorPath, "===================================\n", "a")
    local osData = os.date("%Y年%m月%d日_%H时%M分%S秒",os.time())
    io.writefile(ErrorPath, osData .. "\n", "a")

    if type(nesting) ~= "number" then nesting = 3 end

    local lookupTable = {}
    local result = {}

    local function _v(v)
        if type(v) == "string" then
            v = "\"" .. v .. "\""
        end
        return tostring(v)
    end

    local traceback = string.split(debug.traceback("", 2), "\n")
    print("dump from: " .. string.trim(traceback[3]))

    local function _dump(value, desciption, indent, nest, keylen)
        desciption = desciption or "<var>"
        spc = ""
        if type(keylen) == "number" then
            spc = string.rep(" ", keylen - string.len(_v(desciption)))
        end
        if type(value) ~= "table" then
            result[#result +1 ] = string.format("%s%s%s = %s", indent, _v(desciption), spc, _v(value))
        elseif lookupTable[value] then
            result[#result +1 ] = string.format("%s%s%s = *REF*", indent, desciption, spc)
        else
            lookupTable[value] = true
            if nest > nesting then
                result[#result +1 ] = string.format("%s%s = *MAX NESTING*", indent, desciption)
            else
                result[#result +1 ] = string.format("%s%s = {", indent, _v(desciption))
                local indent2 = indent.."    "
                local keys = {}
                local keylen = 0
                local values = {}
                for k, v in pairs(value) do
                    keys[#keys + 1] = k
                    local vk = _v(k)
                    local vkl = string.len(vk)
                    if vkl > keylen then keylen = vkl end
                    values[k] = v
                end
                table.sort(keys, function(a, b)
                    if type(a) == "number" and type(b) == "number" then
                        return a < b
                    else
                        return tostring(a) < tostring(b)
                    end
                end)
                for i, k in ipairs(keys) do
                    _dump(values[k], k, indent2, nest + 1, keylen)
                end
                result[#result +1] = string.format("%s}", indent)
            end
        end
    end
    _dump(value, desciption, "- ", 1)

    for i, line in ipairs(result) do
        --print(line)
        io.writefile(ErrorPath, line .. "\n", "a")
    end

    io.writefile(ErrorPath, "\n", "a")
end

--写错误日志
function g_writeErrorLog(data, desciption, isClearWrite)

    if not desciption then
        desciption = "var"
    end

    if isClearWrite then            --是否清空历史log
        io.writefile(ErrorPath, "", "w")
    end

    if type(data) ~= "table" then
        io.writefile(ErrorPath, "===================================\n", "a")
        local osData = os.date("%Y年%m月%d日_%H时%M分%S秒",os.time())
        io.writefile(ErrorPath, osData .. "\n", "a")
    end

    local str = ""
    local function arrayToString(array)
        str = str .. "{\n"
        for k, v in pairs(array) do
            if type(v) == "number" then
                str = str .. k .. "=" .. v .. ",\n"
            elseif type(v) == "string" then
                str = str .. k .. "=" .. "\"" .. v .. "\"" .. ",\n"
            elseif type(v) == "table" then
                arrayToString(v)
            end
        end
        str = str .. "},\n"
        return str
    end

    if type(data) == "number" then

        str = desciption .. " = " .. data .. "\n"
        io.writefile(ErrorPath, str, "a")

    elseif type(data) == "string" then

        str = desciption .. " = " .. "\"" .. data .. "\"" .. "\n"
        io.writefile(ErrorPath, str, "a")

    elseif type(data) == "table" then

        dumpError(data, desciption, 10)

    end

end

相关文章

  • cocos 模仿dump写了一个写错误日志的函数

  • cocos2d-lua 3.10 开启debug.log写日志

    之前一直想找cocos 打印写log文件日志因为之前一直都是控制台输出后来自己也写了一个写log文件日志公司项目里...

  • OOM问题排查方法

    根据日志确定发生OOM的原因和区域,以下几个内存区域都可能发生OOM,先找到打印出的OOM错误日志和dump文件(...

  • FFmpeg方法

    av_dump_format() 此函数的作用:av_dump_format()是一个手工调试的函数,能使我们看到...

  • RN 错误大全

    这个错误的原因是render函数出错,具体就是在render函数里面写了注释,所以千万不要在render函数里写注...

  • Lua语法 dump()函数

    cocos2d-x 3.4版本lua新增了方法dump(),dump()为输出堆栈方法,可以方便的打印表table...

  • 服务器JVM等查看

    常用 JVM性能调优监控工具JDK内置工具使用JAVA线程dump分析JVM致命错误日志1 . CPU的监控 cs...

  • Discuz 常用方法

    Discuz 常用函数 打印 打印变量函数 日志 写日志 DB对象函数 SQL 语句 format 的支持 ins...

  • Python学习:带参数的装饰器

    问题 前面写了一个统计函数执行时间的装饰器,默认使用print函数打印执行日志。日志打印,不能假设一定会用prin...

  • golang处理error

    底层函数只需要返回错误,不要对错误进行处理。错误统一放到主函数进行处理,比如记录日志/发送邮件等。

网友评论

    本文标题:cocos 模仿dump写了一个写错误日志的函数

    本文链接:https://www.haomeiwen.com/subject/dcpwfxtx.html