我有一个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()
Run Code Online (Sandbox Code Playgroud)
任何关于如何解决这个问题的方法都将受到赞赏.
小智 6
将io.open与二进制文件一起使用时,必须在模式字符串中添加"b",否则在Windows上会遇到问题.
简单模型函数io.input和io.output始终以文本模式打开文件(默认值).在Unix中,二进制文件和文本文件之间没有区别.但在某些系统中,特别是Windows,必须使用特殊标志打开二进制文件.要处理这样的二进制文件,必须使用io.open,模式字符串中带有字母"b".
来自https://www.lua.org/pil/21.2.2.html