我有一个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 = {
["\000"] = {
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
},
["\080"] = {
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()
任何有关如何解决此问题的方法都将受到赞赏。
答案 0 :(得分:6)
将io.open与二进制文件一起使用时,必须在模式字符串中添加“b”,否则会在Windows上遇到问题。
简单模型函数io.input和io.output始终打开一个文件 在文本模式下(默认)。在Unix中,没有区别 二进制文件和文本文件。但在某些系统中,特别是Windows, 必须使用特殊标志打开二进制文件。处理这样的二进制文件 文件,你必须使用io.open,模式字符串中带有字母“b”。