mirror of
https://github.com/Adorable-Catgirl/Zorya-NEO.git
synced 2024-11-27 04:38:06 +11:00
vBIOS
This commit is contained in:
parent
7ea507d2fd
commit
77e542785e
@ -7,6 +7,9 @@
|
|||||||
{name="oefiv1", cat="util", path="mods/util_oefiv1.zy2m"},
|
{name="oefiv1", cat="util", path="mods/util_oefiv1.zy2m"},
|
||||||
{name="openos", cat="loader", path="mods/loader_openos.zy2m"},
|
{name="openos", cat="loader", path="mods/loader_openos.zy2m"},
|
||||||
{name="fuchas", cat="loader", path="mods/loader_fuchas.zy2m"},
|
{name="fuchas", cat="loader", path="mods/loader_fuchas.zy2m"},
|
||||||
|
{name="vbios", cat="vdev", path="mods/vdev_vbios.zy2m"},
|
||||||
|
{name="biosdev", cat="vdev", path="mods/vdev_biosdev.zy2m"},
|
||||||
|
{name="searchpaths", cat="util", path="mods/util_searchpaths.zy2m"},
|
||||||
--{name="tsuki", cat="loader", path="mods/loader_tsuki.zy2m"},
|
--{name="tsuki", cat="loader", path="mods/loader_tsuki.zy2m"},
|
||||||
--{name="romfs", cat="util", path="mods/util_romfs.zy2m"},
|
--{name="romfs", cat="util", path="mods/util_romfs.zy2m"},
|
||||||
{name="cpio", cat="util", path="lib/util_cpio.zy2l"},
|
{name="cpio", cat="util", path="lib/util_cpio.zy2l"},
|
||||||
@ -14,7 +17,7 @@
|
|||||||
--{name="loadfile", cat="loader", path="mods/loader_loadfile.zy2m"},
|
--{name="loadfile", cat="loader", path="mods/loader_loadfile.zy2m"},
|
||||||
{name="minitel", cat="net", path="lib/net_minitel.zy2l"},
|
{name="minitel", cat="net", path="lib/net_minitel.zy2l"},
|
||||||
--{name="vdev", cat="util", path="mods/util_vdev.zy2m"},
|
--{name="vdev", cat="util", path="mods/util_vdev.zy2m"},
|
||||||
{name="menu", cat="menu", path="mods/menu_classic.zy2m"},
|
{name="classic", cat="menu", path="mods/menu_classic.zy2m"},
|
||||||
--{name="vdevrt", cat="rtmod", path="mods/rtmod_vdevrt.zy2m"},
|
--{name="vdevrt", cat="rtmod", path="mods/rtmod_vdevrt.zy2m"},
|
||||||
--{name="tsukinet", cat="net", path="mods/net_tsukinet"},
|
--{name="tsukinet", cat="net", path="mods/net_tsukinet"},
|
||||||
--{name="biosemu", cat="loader", path="mods/loader_biosemu.zy2m", warning="warn_mod_biosemu"},
|
--{name="biosemu", cat="loader", path="mods/loader_biosemu.zy2m", warning="warn_mod_biosemu"},
|
||||||
|
@ -49,7 +49,7 @@ local function checkCache(packetID)
|
|||||||
end
|
end
|
||||||
|
|
||||||
--local realComputerPullSignal = computer.pullSignal
|
--local realComputerPullSignal = computer.pullSignal
|
||||||
thd.add(function()
|
thd.add("minitel_handler", function()
|
||||||
while true do
|
while true do
|
||||||
local eventTab = {computer.pullSignal(0)}
|
local eventTab = {computer.pullSignal(0)}
|
||||||
for k,v in pairs(net.hook) do
|
for k,v in pairs(net.hook) do
|
||||||
|
@ -21,6 +21,7 @@ end
|
|||||||
return function(addr, args)
|
return function(addr, args)
|
||||||
--oefi.getExtensions().ZyNeo_ExecOEFIApp(addr, ".efi/fuchas.efi2", ...)
|
--oefi.getExtensions().ZyNeo_ExecOEFIApp(addr, ".efi/fuchas.efi2", ...)
|
||||||
--We don't do that here.
|
--We don't do that here.
|
||||||
|
local fuch = {}
|
||||||
fuch.env = oefi.getExtensions().ZyNeo_GetOEFIEnv(addr)
|
fuch.env = oefi.getExtensions().ZyNeo_GetOEFIEnv(addr)
|
||||||
fuch.env.computer.supportsOEFI = function()
|
fuch.env.computer.supportsOEFI = function()
|
||||||
return true
|
return true
|
||||||
|
@ -12,6 +12,7 @@ return function(addr)
|
|||||||
end
|
end
|
||||||
function computer.setBootAddress()end
|
function computer.setBootAddress()end
|
||||||
--log(env, env.computer, env.computer.getBootAddress, env.computer.getBootAddress())
|
--log(env, env.computer, env.computer.getBootAddress, env.computer.getBootAddress())
|
||||||
|
local old_dl = utils.debug_log
|
||||||
load(utils.readfile(fs.address, fs.open("init.lua")), "=init.lua", "t")()
|
load(utils.readfile(fs.address, fs.open("init.lua")), "=init.lua", "t")()
|
||||||
krequire = kr
|
krequire = kr
|
||||||
end
|
end
|
@ -29,6 +29,13 @@ function menu.add(text, func)
|
|||||||
end
|
end
|
||||||
|
|
||||||
function menu.draw()
|
function menu.draw()
|
||||||
|
|
||||||
|
local w, h = gpu.getViewport()
|
||||||
|
local stime = computer.uptime()
|
||||||
|
local autosel = true
|
||||||
|
local ypos = 1
|
||||||
|
local sel = 1
|
||||||
|
local function redraw()
|
||||||
local w, h = gpu.getViewport()
|
local w, h = gpu.getViewport()
|
||||||
local cls = function()gpu.fill(1,1,w,h," ")end
|
local cls = function()gpu.fill(1,1,w,h," ")end
|
||||||
gpu.setBackground(bg)
|
gpu.setBackground(bg)
|
||||||
@ -49,11 +56,6 @@ function menu.draw()
|
|||||||
gpu.set(w, h-3, border_chars[6])
|
gpu.set(w, h-3, border_chars[6])
|
||||||
gpu.set(1, h-1, "Use ↑ and ↓ keys to select which entry is highlighted.")
|
gpu.set(1, h-1, "Use ↑ and ↓ keys to select which entry is highlighted.")
|
||||||
gpu.set(1, h, "Use ENTER to boot the selected entry.")
|
gpu.set(1, h, "Use ENTER to boot the selected entry.")
|
||||||
local stime = computer.uptime()
|
|
||||||
local autosel = true
|
|
||||||
local ypos = 1
|
|
||||||
local sel = 1
|
|
||||||
local function redraw()
|
|
||||||
gpu.setBackground(bg)
|
gpu.setBackground(bg)
|
||||||
gpu.setForeground(fg)
|
gpu.setForeground(fg)
|
||||||
gpu.fill(1, h-2, w, 1, " ")
|
gpu.fill(1, h-2, w, 1, " ")
|
||||||
|
35
mods/util_searchpaths/init.lua
Normal file
35
mods/util_searchpaths/init.lua
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
local zy = krequire("zorya")
|
||||||
|
local sys = krequire("sys")
|
||||||
|
local utils = krequire("utils")
|
||||||
|
|
||||||
|
local computer, component = computer, component
|
||||||
|
|
||||||
|
local sp = {}
|
||||||
|
|
||||||
|
function sp.add_mod_path(drive, path)
|
||||||
|
local px = component.proxy(drive)
|
||||||
|
zy.add_mod_search(function(mod)
|
||||||
|
if (px.exists(path.."/"..mod..".zy2m")) then
|
||||||
|
local h = px.open(path.."/"..mod..".zy2m", "r")
|
||||||
|
return utils.load_lua(utils.readfile(drive, h))
|
||||||
|
elseif (px.exists(path.."/"..mod.."/init.zy2m")) then
|
||||||
|
local h = px.open(path.."/"..mod.."/init.zy2m", "r")
|
||||||
|
return utils.load_lua(utils.readfile(drive, h))
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
function sp.add_lib_path(drive, path)
|
||||||
|
local px = component.proxy(drive)
|
||||||
|
sys.add_search(function(mod)
|
||||||
|
if (px.exists(path.."/"..mod..".zy2l")) then
|
||||||
|
local h = px.open(path.."/"..mod..".zy2l", "r")
|
||||||
|
return utils.load_lua(utils.readfile(drive, h))
|
||||||
|
elseif (px.exists(path.."/"..mod.."/init.zy2l")) then
|
||||||
|
local h = px.open(path.."/"..mod.."/init.zy2l", "r")
|
||||||
|
return utils.load_lua(utils.readfile(drive, h))
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
|
||||||
|
return sp
|
@ -1,6 +1,6 @@
|
|||||||
local zy = krequire("zorya")
|
local zy = krequire("zorya")
|
||||||
local vdev = krequire("util_vcomponent")
|
local vdev = krequire("util_vcomponent")
|
||||||
vdev.register("ZORYA_BIOS", "zybios", {
|
vdev.register("ZORYA_BIOS", "zybios",
|
||||||
{
|
{
|
||||||
get_threads_info = function()
|
get_threads_info = function()
|
||||||
local threads = {}
|
local threads = {}
|
||||||
@ -8,13 +8,13 @@ vdev.register("ZORYA_BIOS", "zybios", {
|
|||||||
local info = zy.lkthdi(i)
|
local info = zy.lkthdi(i)
|
||||||
threads[i] = {
|
threads[i] = {
|
||||||
name = info[1],
|
name = info[1],
|
||||||
deadline = info[6]
|
deadline = info[4]
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
return threads
|
return threads
|
||||||
end,
|
end,
|
||||||
get_version = function()
|
get_version = function()
|
||||||
return string.format("%f.%d", _ZVER, _ZPAT)
|
return string.format("%1.1f.%d", _ZVER, _ZPAT)
|
||||||
end,
|
end,
|
||||||
get_git_revision = function()
|
get_git_revision = function()
|
||||||
return _ZGIT
|
return _ZGIT
|
||||||
@ -25,6 +25,6 @@ vdev.register("ZORYA_BIOS", "zybios", {
|
|||||||
get_version = "get_version():string -- Returns the Zorya NEO version.",
|
get_version = "get_version():string -- Returns the Zorya NEO version.",
|
||||||
get_git_revision = "get_git_revision():string -- Returns the git revision of the build."
|
get_git_revision = "get_git_revision():string -- Returns the git revision of the build."
|
||||||
}
|
}
|
||||||
})
|
)
|
||||||
|
|
||||||
return true
|
return true
|
0
mods/vdev_vbios/crc32.lua
Normal file
0
mods/vdev_vbios/crc32.lua
Normal file
83
mods/vdev_vbios/init.lua
Normal file
83
mods/vdev_vbios/init.lua
Normal file
@ -0,0 +1,83 @@
|
|||||||
|
local vdev = krequire("util_vcomponent")
|
||||||
|
local utils = krequire("utils")
|
||||||
|
local thd = krequire("thd")
|
||||||
|
local comp = component
|
||||||
|
local eeprom = {}
|
||||||
|
local lua_code = [[
|
||||||
|
--#include "luabios.lua"
|
||||||
|
]]
|
||||||
|
local function generate_vbios(f_, path)
|
||||||
|
local fs = comp.proxy(f_)
|
||||||
|
if not fs.exists(path) then
|
||||||
|
fs.makeDirectory(path)
|
||||||
|
end
|
||||||
|
if not fs.exists(path.."/code.lua") then
|
||||||
|
local h = fs.open(path.."/code.lua", "wb")
|
||||||
|
fs.write(h, lua_code)
|
||||||
|
fs.close(h)
|
||||||
|
end
|
||||||
|
if not fs.exists(path.."/data.bin") then
|
||||||
|
local h = fs.open(path.."/data.bin", "wb")
|
||||||
|
fs.write(h, "")
|
||||||
|
fs.close(h)
|
||||||
|
end
|
||||||
|
if not fs.exists(path.."/label.txt") then
|
||||||
|
local h = fs.open(path.."/label.txt", "wb")
|
||||||
|
fs.write(h, "Lua BIOS")
|
||||||
|
fs.close(h)
|
||||||
|
end
|
||||||
|
local tbl = {
|
||||||
|
get = function()
|
||||||
|
local h = fs.open(path.."/code.lua", "rb")
|
||||||
|
return utils.readfile(f_, h)
|
||||||
|
end,
|
||||||
|
getData = function()
|
||||||
|
local h = fs.open(path.."/data.bin", "rb")
|
||||||
|
return utils.readfile(f_, h)
|
||||||
|
end,
|
||||||
|
getLabel = function()
|
||||||
|
local h = fs.open(path.."/label.txt", "rb")
|
||||||
|
return utils.readfile(f_, h)
|
||||||
|
end,
|
||||||
|
set = function(data)
|
||||||
|
local h = fs.open(path.."/code.lua", "wb")
|
||||||
|
fs.write(h, data)
|
||||||
|
fs.close(h)
|
||||||
|
end,
|
||||||
|
setData = function(data)
|
||||||
|
local h = fs.open(path.."/data.bin", "wb")
|
||||||
|
fs.write(h, data)
|
||||||
|
fs.close(h)
|
||||||
|
end,
|
||||||
|
setLabel = function(label)
|
||||||
|
local h = fs.open(path.."/label.txt", "wb")
|
||||||
|
fs.write(h, label:sub(1, 16))
|
||||||
|
fs.close(h)
|
||||||
|
end,
|
||||||
|
getDataSize = function()
|
||||||
|
|
||||||
|
return fs.spaceTotal()
|
||||||
|
end,
|
||||||
|
getSize = function()
|
||||||
|
|
||||||
|
return fs.spaceTotal()
|
||||||
|
end,
|
||||||
|
getChecksum = function()
|
||||||
|
|
||||||
|
return 0/0
|
||||||
|
end,
|
||||||
|
makeReadonly = function()
|
||||||
|
|
||||||
|
return
|
||||||
|
end
|
||||||
|
}
|
||||||
|
vdev.register("vdev-ZY_VBIOS", "eeprom", tbl)
|
||||||
|
local nice = function()
|
||||||
|
|
||||||
|
--#include "machine.lua"
|
||||||
|
|
||||||
|
end
|
||||||
|
return nice, tbl
|
||||||
|
end
|
||||||
|
|
||||||
|
return generate_vbios
|
64
mods/vdev_vbios/luabios.lua
Normal file
64
mods/vdev_vbios/luabios.lua
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
local init
|
||||||
|
do
|
||||||
|
local component_invoke = component.invoke
|
||||||
|
local function boot_invoke(address, method, ...)
|
||||||
|
local result = table.pack(pcall(component_invoke, address, method, ...))
|
||||||
|
if not result[1] then
|
||||||
|
return nil, result[2]
|
||||||
|
else
|
||||||
|
return table.unpack(result, 2, result.n)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- backwards compatibility, may remove later
|
||||||
|
local eeprom = component.list("eeprom")()
|
||||||
|
computer.getBootAddress = function()
|
||||||
|
return boot_invoke(eeprom, "getData")
|
||||||
|
end
|
||||||
|
computer.setBootAddress = function(address)
|
||||||
|
return boot_invoke(eeprom, "setData", address)
|
||||||
|
end
|
||||||
|
|
||||||
|
do
|
||||||
|
local screen = component.list("screen")()
|
||||||
|
local gpu = component.list("gpu")()
|
||||||
|
if gpu and screen then
|
||||||
|
boot_invoke(gpu, "bind", screen)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local function tryLoadFrom(address)
|
||||||
|
local handle, reason = boot_invoke(address, "open", "/init.lua")
|
||||||
|
if not handle then
|
||||||
|
return nil, reason
|
||||||
|
end
|
||||||
|
local buffer = ""
|
||||||
|
repeat
|
||||||
|
local data, reason = boot_invoke(address, "read", handle, math.huge)
|
||||||
|
if not data and reason then
|
||||||
|
return nil, reason
|
||||||
|
end
|
||||||
|
buffer = buffer .. (data or "")
|
||||||
|
until not data
|
||||||
|
boot_invoke(address, "close", handle)
|
||||||
|
return load(buffer, "=init")
|
||||||
|
end
|
||||||
|
local reason
|
||||||
|
if computer.getBootAddress() then
|
||||||
|
init, reason = tryLoadFrom(computer.getBootAddress())
|
||||||
|
end
|
||||||
|
if not init then
|
||||||
|
computer.setBootAddress()
|
||||||
|
for address in component.list("filesystem") do
|
||||||
|
init, reason = tryLoadFrom(address)
|
||||||
|
if init then
|
||||||
|
computer.setBootAddress(address)
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if not init then
|
||||||
|
error("no bootable medium found" .. (reason and (": " .. tostring(reason)) or ""), 0)
|
||||||
|
end
|
||||||
|
computer.beep(1000, 0.2)
|
||||||
|
end
|
||||||
|
init()
|
73
mods/vdev_vbios/machine.lua
Normal file
73
mods/vdev_vbios/machine.lua
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
-- This our custom machine.lua
|
||||||
|
local utils = krequire("utils")
|
||||||
|
local computer = computer
|
||||||
|
xpcall(function()
|
||||||
|
utils.debug_log("Copying env...")
|
||||||
|
local env = utils.deepcopy(_G)
|
||||||
|
utils.debug_log("Coppied env.")
|
||||||
|
env._G = env
|
||||||
|
env._ENV = env
|
||||||
|
env.krequire = nil
|
||||||
|
env._BIOS = nil
|
||||||
|
env._ZVSTR = nil
|
||||||
|
env._ZVER = nil
|
||||||
|
env._ZPAT = nil
|
||||||
|
env._ZGIT = nil
|
||||||
|
vdev.install(env)
|
||||||
|
local _oldlist = env.component.list
|
||||||
|
local thdid = string.format("%.4x", math.random(0, 2^16-1))
|
||||||
|
function env.component.list(...)
|
||||||
|
local ol = _oldlist(...)
|
||||||
|
local tcall = function()
|
||||||
|
local a, t = ol()
|
||||||
|
if (a ~= "vdev-ZY_VBIOS" and t == "eeprom") then
|
||||||
|
a, t = ol()
|
||||||
|
end
|
||||||
|
return a, t
|
||||||
|
end
|
||||||
|
for k, v in pairs(ol) do
|
||||||
|
if (k ~= "vdev-ZY_VBIOS" and v == "eeprom") then
|
||||||
|
ol[k] = nil
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return setmetatable({}, {__index=ol, __call=tcall})
|
||||||
|
end
|
||||||
|
function env.load(code, name, mode, e, ...)
|
||||||
|
local e = e or env
|
||||||
|
return load(code, name, mode, e, ...)
|
||||||
|
end
|
||||||
|
local ded = false
|
||||||
|
function env.computer.returnToBios()
|
||||||
|
local thds = thd.get_threads()
|
||||||
|
local vbname = "vbios$"..tbl.getLabel().."#"..thdid
|
||||||
|
for i=1, #thds do
|
||||||
|
if (thds[i][1] == vbname) then
|
||||||
|
thds[i][6] = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
ded = true
|
||||||
|
utils.debug_log("Returning to BIOS...")
|
||||||
|
end
|
||||||
|
utils.debug_log("Loading vBIOS...")
|
||||||
|
thd.add("vbios$"..tbl.getLabel().."#"..thdid, function()
|
||||||
|
xpcall(function()
|
||||||
|
utils.debug_log("Starting BIOS.")
|
||||||
|
assert(load(tbl.get(), "=vbios", "t", env))()
|
||||||
|
end, function(err)
|
||||||
|
utils.debug_log("ERROR", "vBIOS error!")
|
||||||
|
utils.debug_log(err, debug.traceback())
|
||||||
|
end)
|
||||||
|
utils.debug_log("Sending signal.")
|
||||||
|
computer.pushSignal("vbios_dead")
|
||||||
|
end)
|
||||||
|
while true do
|
||||||
|
if computer.pullSignal() == "vbios_dead" then
|
||||||
|
utils.debug_log("Got signal.")
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
utils.debug_log("Dead.")
|
||||||
|
end, function(err)
|
||||||
|
utils.debug_log("ERROR", "vBIOS error!")
|
||||||
|
utils.debug_log(err, debug.traceback())
|
||||||
|
end)
|
2
mods/vfs/init.lua
Normal file
2
mods/vfs/init.lua
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
local component, computer = component, computer
|
||||||
|
local vfs = {}
|
@ -22,14 +22,14 @@ status("\n\nBuilding modules.")
|
|||||||
if (os.execute("stat mods 1>/dev/null 2>&1")) then
|
if (os.execute("stat mods 1>/dev/null 2>&1")) then
|
||||||
for l in io.popen("ls mods"):lines() do
|
for l in io.popen("ls mods"):lines() do
|
||||||
status("MOD\t"..l)
|
status("MOD\t"..l)
|
||||||
os.execute("zsh -c 'cd mods/"..l.."; luacomp init.lua -mluamin | lua ../../utils/zlua.lua > ../../pkg/mods/"..l..".zy2m'")
|
os.execute("zsh -c 'cd mods/"..l.."; luacomp init.lua | lua ../../utils/zlua.lua > ../../pkg/mods/"..l..".zy2m'")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
status("Module build complete.\n\nBuilding libraries.")
|
status("Module build complete.\n\nBuilding libraries.")
|
||||||
if (os.execute("stat lib 1>/dev/null 2>&1")) then
|
if (os.execute("stat lib 1>/dev/null 2>&1")) then
|
||||||
for l in io.popen("ls lib"):lines() do
|
for l in io.popen("ls lib"):lines() do
|
||||||
status("LIB\t"..l)
|
status("LIB\t"..l)
|
||||||
os.execute("zsh -c 'cd lib/"..l.."; luacomp init.lua -mluamin | lua ../../utils/zlua.lua > ../../pkg/lib/"..l..".zy2l'")
|
os.execute("zsh -c 'cd lib/"..l.."; luacomp init.lua | lua ../../utils/zlua.lua > ../../pkg/lib/"..l..".zy2l'")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
status("Library build complete.\n\nBuilding installer...")
|
status("Library build complete.\n\nBuilding installer...")
|
||||||
|
@ -24,7 +24,14 @@ assert(bootfs.exists(".zy2/image.romfs"), "No boot image!")
|
|||||||
local romfs_file = assert(bootfs.open(".zy2/image.romfs", "rb"))
|
local romfs_file = assert(bootfs.open(".zy2/image.romfs", "rb"))
|
||||||
|
|
||||||
local romfs_dev = romfs.read(function(a)
|
local romfs_dev = romfs.read(function(a)
|
||||||
return bootfs.read(romfs_file, a)
|
local c = ""
|
||||||
|
local d
|
||||||
|
while a > 0 do
|
||||||
|
d = bootfs.read(romfs_file, a)
|
||||||
|
a = a - #d
|
||||||
|
c = c .. d
|
||||||
|
end
|
||||||
|
return c
|
||||||
end, function(a)
|
end, function(a)
|
||||||
return bootfs.seek(romfs_file, "cur", a)
|
return bootfs.seek(romfs_file, "cur", a)
|
||||||
end, function()
|
end, function()
|
||||||
|
@ -57,4 +57,5 @@ function utils.deepcopy(src, dest)
|
|||||||
end
|
end
|
||||||
return dest
|
return dest
|
||||||
end
|
end
|
||||||
|
|
||||||
builtins.utils = function() return utils end
|
builtins.utils = function() return utils end
|
@ -72,11 +72,11 @@ sys.add_lib("zorya", (function()
|
|||||||
end
|
end
|
||||||
|
|
||||||
function zy.lkthdn()
|
function zy.lkthdn()
|
||||||
return #thd.getthreads()
|
return #thd.get_threads()
|
||||||
end
|
end
|
||||||
|
|
||||||
function zy.lkthdi(i)
|
function zy.lkthdi(i)
|
||||||
return thd.getthreads()[i][1]
|
return thd.get_threads()[i]
|
||||||
end
|
end
|
||||||
return zy
|
return zy
|
||||||
end)())
|
end)())
|
||||||
@ -93,7 +93,7 @@ th_a(function()
|
|||||||
utils.debug_log(mod, ".zy2m")
|
utils.debug_log(mod, ".zy2m")
|
||||||
return load_lua(bfs.getfile(".zy2/mods/"..mod..".zy2m"), "=.zy2/mods/"..mod..".zy2m")()
|
return load_lua(bfs.getfile(".zy2/mods/"..mod..".zy2m"), "=.zy2/mods/"..mod..".zy2m")()
|
||||||
elseif (bfs.exists(".zy2/mods/"..mod.."/init.zy2m")) then
|
elseif (bfs.exists(".zy2/mods/"..mod.."/init.zy2m")) then
|
||||||
return load_lua(bfs.getfile(".zy2/mods/"..mod.."/init.zy2m"), "=.zy2/mods/"..mod.."/init.zy2m")()
|
return assert(load_lua(bfs.getfile(".zy2/mods/"..mod.."/init.zy2m"), "=.zy2/mods/"..mod.."/init.zy2m"))()
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
sys.add_search(function(mod)
|
sys.add_search(function(mod)
|
||||||
|
Loading…
Reference in New Issue
Block a user