1
0
Fork 0
mirror of https://github.com/notwa/mm synced 2024-11-05 02:49:02 -08:00
mm/Lua/boilerplate.lua
Connor Olding 307e3ac751 refactor "A" boilerplate
less memory. maybe faster?
2015-05-26 10:22:18 -07:00

130 lines
2.9 KiB
Lua
Executable file

-- boilerplate convenience functions
-- TODO: respect little endian consoles too
require "extra"
local mm = mainmemory
local m = memory
m.usememorydomain("ROM")
R1 = mm.readbyte
R2 = mm.read_u16_be
R3 = mm.read_u24_be
R4 = mm.read_u32_be
RF = function(addr) return mm.readfloat(addr, true) end
W1 = mm.writebyte
W2 = mm.write_u16_be
W3 = mm.write_u24_be
W4 = mm.write_u32_be
WF = function(addr, value) mm.writefloat(addr, value, true) end
X1 = m.readbyte
X2 = m.read_u16_be
X3 = m.read_u24_be
X4 = m.read_u32_be
XF = function(addr) return m.readfloat(addr, true) end
local H1 = function(self, value)
return value and W1(self.addr, value) or R1(self.addr)
end
local H2 = function(self, value)
return value and W2(self.addr, value) or R2(self.addr)
end
local H3 = function(self, value)
return value and W3(self.addr, value) or R3(self.addr)
end
local H4 = function(self, value)
return value and W4(self.addr, value) or R4(self.addr)
end
local HF = function(self, value)
return value and WF(self.addr, value) or RF(self.addr)
end
local mts = {
[1] = {__call = H1},
[2] = {__call = H2},
[3] = {__call = H3},
[4] = {__call = H4},
['f'] = {__call = HF},
}
function A(addr, atype)
local mt = mts[atype]
return setmetatable({
addr=addr,
type=atype,
}, mt)
end
Class = function(inherit)
local class = {}
local mt_obj = {__index = class}
local mt_class = {
__call = function(self, ...)
local obj = setmetatable({}, mt_obj)
obj:init(...)
return obj
end,
__index = inherit,
}
return setmetatable(class, mt_class)
end
function getindex(obj)
local gm = getmetatable(obj)
if not gm then return end
return gm.__index
end
function printf(fmt, ...)
print(fmt:format(...))
end
function is_ptr(ptr)
return bit.band(0xFF800000, ptr) == 0x80000000
end
function deref(ptr)
return is_ptr(ptr) and ptr - 0x80000000
end
function asciize(bytes)
local str = ""
local seq = false
for i, v in ipairs(bytes) do
local c = type(v) == 'number' and v or tonumber(v, 16)
if c == 9 or c == 10 or c == 13 or (c >= 32 and c < 127) then
str = str..string.char(c)
seq = false
elseif seq == false then
str = str..' '
seq = true
end
end
return str
end
function hex(i)
-- convenience function for use in console
printf("%08X", i)
end
--[[
-- now we can just write:
handle = A(0x123456, 1)
print(handle()) -- get 1 byte at address
handle(0xFF) -- set 1 byte at address
-- or just:
A(0x123456, 1)(0xFF) -- set address value
-- and taking advantage of A returning a table and not just a function:
A(handle.addr + 1, handle.type)(0x00) -- set the byte after our address
-- this doesn't limit us to just the type we initially specified. eg:
A(handle.addr, 2)(0x1234) -- set 2 bytes as opposed to our original 1
--]]
return A