Lua, CR correcting to CRLF



我有一个lua文件。它读取 2 个文件,一个"脚本"文件,一个"源"文件。lua 文件解释脚本文件,并使用脚本文件中的一些指令更改源文件(在内存中(。然后将此修改后的源输出到输出文件中。这工作正常,直到某些东西成为 CR。修改后的源被修改为具有 CRLF 而不是 CR。这破坏了很多东西,我不知道如何解决这个问题。这里是 lua 文件。

progargs = {...}
if #progargs ~= 3 then
    print("Usage: patch <src> <script> <output>")
    return "u didnt do it right"
end

opcodes = {
    ["00"] = {
        function(args)
            local inp=outc:sub(pos,pos):byte()
            strt={}
            for j=1,#src do
                table.insert(strt,outc:sub(j,j))
            end
            strt[pos]=string.char(inp-args[1])
            outc=table.concat(strt,"")
        end,
        1
    },
    ["80"] = {
        function(args)
            local val = args[4] * 1 + args[3] * 256 + args[2] * 65536 + args[1] * 16777216
            pos = val+1
        end,
        4
    },   
    ["255"] = {
        function(args)            
            local inp=outc:sub(pos,pos):byte()
            strt={}
            for j=1,#src do
                table.insert(strt,outc:sub(j,j))
            end
            strt[pos]=string.char(inp+args[1])
            outc=table.concat(strt,"")
        end,
        1
    },   
}
srcf = io.open(progargs[1])
src = srcf:read("*a")
srcf:close()
scrf = io.open(progargs[2])
scr = scrf:read("*a")
scrf:close()
i=1
pos=1
outc=src
while i<scr:len() do
    local opc = scr:sub(i,i)
    if opcodes[opc] ~= nil then
        local argc = opcodes[opc][2]
        local func = opcodes[opc][1]
        local args = {}
        for j=1,argc do
            table.insert(args,scr:sub(i+j,i+j):byte())
        end
        func(args)
        i=i+argc+1
    else
        print("unknown opcode xd fuck u")
        i=i+1
    end
end
print("doned")
outf = io.open(progargs[3], "w")
outf:write(outc)
outf:close()

任何关于如何解决此问题的方法将不胜感激。

当使用二进制文件时,您必须在模式字符串中添加"b",否则您将在Windows上遇到问题。

简单模型函数 io.input 和 io.output 始终打开一个文件 在文本模式下(默认(。在Unix中,两者之间没有区别 二进制文件和文本文件。但在某些系统中,特别是Windows, 二进制文件必须使用特殊标志打开。处理这样的二进制文件 文件,则必须使用 io.open,模式字符串中带有字母"b"。

从 https://www.lua.org/pil/21.2.2.html

最新更新