mirror of
https://github.com/20kdc/OC-KittenOS.git
synced 2024-11-23 19:08:05 +11:00
86 lines
2.0 KiB
Lua
86 lines
2.0 KiB
Lua
|
-- This is released into the public domain.
|
||
|
-- No warranty is provided, implied or otherwise.
|
||
|
|
||
|
-- BDIVIDE (r5 edition) and PREPROC (r9 edition)
|
||
|
-- decompression engine for installer
|
||
|
|
||
|
-- cb: sector accumulator
|
||
|
-- ct: preproc accumulator
|
||
|
-- cc: bdivide accumulator
|
||
|
-- cw: bdivide window
|
||
|
|
||
|
-- cp: function to submit to preproc
|
||
|
-- cd: function to submit to bdivide
|
||
|
|
||
|
cb,ct,cc,cw="","","",("\x00"):rep(2^16)
|
||
|
-- High-level breakdown:
|
||
|
-- CP is unescaper & TAR-sector-breakup.
|
||
|
-- It'll only begin to input if at least 3 bytes are available,
|
||
|
-- so you'll want to throw in 2 extra zeroes at the end of stream as done here.
|
||
|
-- It uses Ct (input buffer) and Cp (output buffer).
|
||
|
-- Ignore its second argument, as that's a lie, it's just there for a local.
|
||
|
-- CD is the actual decompressor. It has the same quirk as CP, wanting two more bytes.
|
||
|
-- It stores to Cc (compressed), and Cw (window).
|
||
|
-- It outputs that which goes to the window to CP also.
|
||
|
-- And it also uses a fake local.
|
||
|
|
||
|
-- SEE compress.lua FOR THIS FUNCTION
|
||
|
function p(x, y)
|
||
|
if x == 126 then
|
||
|
if y >= 32 then
|
||
|
return ({
|
||
|
-- Before adding to this, check how installer size is changed.
|
||
|
"\x7E", "\x7F"
|
||
|
})[y - 31], 3
|
||
|
end
|
||
|
return string.char(y), 3
|
||
|
elseif x == 127 then
|
||
|
return string.char(128 + y), 3
|
||
|
elseif x >= 32 then
|
||
|
return string.char(x), 2
|
||
|
elseif x == 31 then
|
||
|
return "\n", 2
|
||
|
elseif x == 30 then
|
||
|
return "\x00", 2
|
||
|
end
|
||
|
return string.char(("enart"):byte(x % 5 + 1), ("ndtelh"):byte(math.floor(x / 5) + 1)), 2
|
||
|
end
|
||
|
|
||
|
function cp(d, b, a)
|
||
|
ct = ct .. d
|
||
|
while #ct > 1 do
|
||
|
b, a = p(ct:byte(), ct:byte(2))
|
||
|
cb = cb .. b
|
||
|
ct = ct:sub(a)
|
||
|
if #cb > 511 then
|
||
|
M(cb:sub(1, 512))
|
||
|
cb = cb:sub(513)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
function cd(d, b, p)
|
||
|
cc = cc .. d
|
||
|
while #cc > 2 do
|
||
|
b = cc:byte()
|
||
|
if b < 128 then
|
||
|
b, cc = cc:sub(1, 1), cc:sub(2)
|
||
|
else
|
||
|
p = cc:byte(2) * 256 + cc:byte(3) + 1
|
||
|
b, cc = cw:sub(p, p + b - 125), cc:sub(4)
|
||
|
end
|
||
|
cp(b)
|
||
|
cw = (cw .. b):sub(-65536)
|
||
|
end
|
||
|
end
|
||
|
|
||
|
-- quick & dirty integration with the existing stuff
|
||
|
function L(d)
|
||
|
if not d then
|
||
|
cd("\x00\x00")cp("\x00\x00")
|
||
|
else
|
||
|
cd(d)
|
||
|
end
|
||
|
end
|
||
|
|