v1.12.0 - Added drivers.
This commit is contained in:
@@ -1,7 +1,7 @@
|
||||
local loadfile = ...
|
||||
local filesystem = loadfile("/halyde/lib/filesystem.lua")(loadfile)
|
||||
|
||||
_G._OSVERSION = "Halyde 1.11.1"
|
||||
_G._OSVERSION = "Halyde 1.12.0"
|
||||
_G._OSLOGO = ""
|
||||
local handle, tmpdata = filesystem.open("/halyde/config/oslogo.ans", "r"), nil
|
||||
repeat
|
||||
@@ -47,6 +47,8 @@ local function preload(module)
|
||||
_G[module] = nil
|
||||
end
|
||||
|
||||
import("/halyde/core/drvload.lua")
|
||||
|
||||
preload("component")
|
||||
preload("computer")
|
||||
|
||||
@@ -87,12 +89,12 @@ gpu.setResolution(gpu.maxResolution())
|
||||
--handle:close()
|
||||
|
||||
local fs = import("filesystem")
|
||||
if not fs.exists("/halyde/config/shell.json") then
|
||||
if not fs.exists("/halyde/config/shell.json") then -- Auto-generate configs
|
||||
fs.copy("/halyde/config/generate/shell.json", "/halyde/config/shell.json")
|
||||
end
|
||||
if not fs.exists("/halyde/config/startupapps.json") then
|
||||
fs.copy("/halyde/config/generate/startupapps.json", "/halyde/config/startupapps.json")
|
||||
end
|
||||
fs = nil
|
||||
|
||||
|
||||
import("/halyde/core/cormgr.lua")
|
||||
|
||||
@@ -0,0 +1,46 @@
|
||||
local fs = import("filesystem")
|
||||
|
||||
local driverPath = "/halyde/drivers"
|
||||
|
||||
local drivers = fs.list(driverPath)
|
||||
local driverTypes = {}
|
||||
|
||||
local function loadDriver(drvName)
|
||||
local driverData = import(fs.concat(driverPath, drvName))
|
||||
table.remove(drivers, table.find(drivers, drvName))
|
||||
if driverData.dependencies then
|
||||
for _, dependency in pairs(driverData.dependencies) do
|
||||
if table.find(drivers, dependency) then
|
||||
loadDriver(dependency)
|
||||
elseif table.find(drivers, dependency .. ".lua") then
|
||||
loadDriver(dependency .. ".lua")
|
||||
else
|
||||
for typeLookupDrvName, typeLookupDrvType in pairs(driverTypes) do
|
||||
if typeLookupDrvType == dependency then
|
||||
loadDriver(typeLookupDrvName)
|
||||
-- Don't break, because there can be multiple drivers of the correct type
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
--print(drvName)
|
||||
if driverData.onStartup then -- I have no idea why would this not exist, but it's a failsafe
|
||||
driverData.onStartup()
|
||||
end
|
||||
-- More functions to be implemented in the future
|
||||
end
|
||||
|
||||
for _, drvName in pairs(drivers) do -- Get all the driver types
|
||||
local driverData = import(fs.concat(driverPath, drvName))
|
||||
if driverData.type then
|
||||
--print(driverData.type)
|
||||
driverTypes[drvName] = driverData.type -- Not the other way around because there can be multiple drivers of the same type, but there can't be multiple entries with the same key
|
||||
end
|
||||
end
|
||||
|
||||
for _, drvName in pairs(drivers) do -- Load the drivers
|
||||
if drvName:sub(-1, -1) ~= "/" then -- Check if it's not a directory. Otherwise it might be driver config
|
||||
loadDriver(drvName)
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user