mirror of
https://github.com/kepler155c/opus
synced 2025-01-19 03:42:51 +00:00
ui theme generator + better module handling
This commit is contained in:
parent
c8f200ebb6
commit
672cca3084
@ -100,4 +100,5 @@ function tab:eventHandler(event)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
return tab
|
--this needs rework - see 4.user.lua
|
||||||
|
--return tab
|
||||||
|
@ -34,25 +34,12 @@ local keys = _G.keys
|
|||||||
local mouse = _G.device.mouse
|
local mouse = _G.device.mouse
|
||||||
local os = _G.os
|
local os = _G.os
|
||||||
|
|
||||||
local drivers = { }
|
|
||||||
|
|
||||||
kernel.hook('peripheral', function(_, eventData)
|
kernel.hook('peripheral', function(_, eventData)
|
||||||
local side = eventData[1]
|
local side = eventData[1]
|
||||||
if side then
|
if side then
|
||||||
local dev = Peripheral.addDevice(device, side)
|
local dev = Peripheral.addDevice(device, side)
|
||||||
if dev then
|
if dev then
|
||||||
if drivers[dev.type] then
|
os.queueEvent('device_attach', dev.name)
|
||||||
local e = drivers[dev.type](dev)
|
|
||||||
if type(e) == 'table' then
|
|
||||||
for _, v in pairs(e) do
|
|
||||||
os.queueEvent('device_attach', v.name)
|
|
||||||
end
|
|
||||||
elseif e then
|
|
||||||
os.queueEvent('device_attach', e.name)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
os.queueEvent('device_attach', dev.name, dev)
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
@ -61,12 +48,7 @@ kernel.hook('peripheral_detach', function(_, eventData)
|
|||||||
local side = eventData[1]
|
local side = eventData[1]
|
||||||
if side then
|
if side then
|
||||||
for _, dev in pairs(Util.findAll(device, 'side', side)) do
|
for _, dev in pairs(Util.findAll(device, 'side', side)) do
|
||||||
os.queueEvent('device_detach', dev.name, dev)
|
os.queueEvent('device_detach', dev.name)
|
||||||
if dev._children then
|
|
||||||
for _,v in pairs(dev._children) do
|
|
||||||
os.queueEvent('peripheral_detach', v.name)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
device[dev.name] = nil
|
device[dev.name] = nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -124,59 +106,3 @@ end
|
|||||||
function keyboard.removeHotkey(code)
|
function keyboard.removeHotkey(code)
|
||||||
keyboard.hotkeys[code] = nil
|
keyboard.hotkeys[code] = nil
|
||||||
end
|
end
|
||||||
|
|
||||||
local function createDevice(name, devType, method, manipulator)
|
|
||||||
local dev = {
|
|
||||||
name = name,
|
|
||||||
side = name,
|
|
||||||
type = devType,
|
|
||||||
}
|
|
||||||
local methods = {
|
|
||||||
'drop', 'getDocs', 'getItem', 'getItemMeta', 'getTransferLocations',
|
|
||||||
'list', 'pullItems', 'pushItems', 'size', 'suck',
|
|
||||||
}
|
|
||||||
if manipulator[method] then
|
|
||||||
for _,k in pairs(methods) do
|
|
||||||
dev[k] = function(...)
|
|
||||||
return manipulator[method]()[k](...)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if not manipulator._children then
|
|
||||||
manipulator._children = { dev }
|
|
||||||
else
|
|
||||||
table.insert(manipulator._children, dev)
|
|
||||||
end
|
|
||||||
device[name] = dev
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
drivers['manipulator'] = function(dev)
|
|
||||||
if dev.getName then
|
|
||||||
pcall(function()
|
|
||||||
local name = dev.getName()
|
|
||||||
if name then
|
|
||||||
if dev.getInventory then
|
|
||||||
createDevice(name .. ':inventory', 'inventory', 'getInventory', dev)
|
|
||||||
end
|
|
||||||
if dev.getEquipment then
|
|
||||||
createDevice(name .. ':equipment', 'equipment', 'getEquipment', dev)
|
|
||||||
end
|
|
||||||
if dev.getEnder then
|
|
||||||
createDevice(name .. ':enderChest', 'enderChest', 'getEnder', dev)
|
|
||||||
end
|
|
||||||
|
|
||||||
return dev._children
|
|
||||||
end
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- initialize drivers
|
|
||||||
for _,v in pairs(device) do
|
|
||||||
if drivers[v.type] then
|
|
||||||
local s, m = pcall(drivers[v.type], v)
|
|
||||||
if not s and m then
|
|
||||||
_G.printError(m)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
@ -3,17 +3,17 @@ local Util = require('opus.util')
|
|||||||
local device = _G.device
|
local device = _G.device
|
||||||
local kernel = _G.kernel
|
local kernel = _G.kernel
|
||||||
local os = _G.os
|
local os = _G.os
|
||||||
local peripheral = _G.peripheral
|
|
||||||
|
|
||||||
local containers = {
|
local containers = {
|
||||||
manipulator = true,
|
manipulator = true,
|
||||||
neuralInterface = true,
|
neuralInterface = true,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local cache = { }
|
||||||
|
|
||||||
local function getModules(dev, side)
|
local function getModules(dev, side)
|
||||||
local list = { }
|
local list = { }
|
||||||
|
if dev and dev.listModules then
|
||||||
if dev then
|
|
||||||
for _, module in pairs(dev.listModules()) do
|
for _, module in pairs(dev.listModules()) do
|
||||||
list[module] = Util.shallowCopy(dev)
|
list[module] = Util.shallowCopy(dev)
|
||||||
list[module].name = module
|
list[module].name = module
|
||||||
@ -24,29 +24,86 @@ local function getModules(dev, side)
|
|||||||
return list
|
return list
|
||||||
end
|
end
|
||||||
|
|
||||||
for _,v in pairs(device) do
|
-- if a device has been reattached, reuse the existing
|
||||||
if containers[v.type] then
|
-- table so any references to the table are retained
|
||||||
local list = getModules(v, v.side)
|
local function addDevice(dev, args, doQueue)
|
||||||
for k, dev in pairs(list) do
|
local name = args.name
|
||||||
-- neural and attached modules have precedence over manipulator modules
|
|
||||||
if not device[k] or v.type ~= 'manipulator' then
|
if not cache[name] then
|
||||||
device[k] = dev
|
cache[name] = { }
|
||||||
end
|
end
|
||||||
|
device[name] = cache[name]
|
||||||
|
Util.merge(device[name], dev)
|
||||||
|
Util.merge(device[name], args)
|
||||||
|
|
||||||
|
if doQueue then
|
||||||
|
os.queueEvent('device_attach', name)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function addContainer(v, doQueue)
|
||||||
|
-- add devices like plethora:scanner
|
||||||
|
for name, dev in pairs(getModules(v, v.side)) do
|
||||||
|
-- neural and attached modules have precedence over manipulator modules
|
||||||
|
if not device[name] or v.type ~= 'manipulator' then
|
||||||
|
addDevice(dev, { name = dev.name, type = dev.name, side = dev.side }, doQueue)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if v.getName then
|
||||||
|
pcall(function()
|
||||||
|
local name = v.getName()
|
||||||
|
if name then
|
||||||
|
if v.getInventory then
|
||||||
|
addDevice(v.getInventory(), {
|
||||||
|
name = name .. ':inventory',
|
||||||
|
type = 'inventory',
|
||||||
|
side = v.side
|
||||||
|
}, doQueue)
|
||||||
|
end
|
||||||
|
if v.getEquipment then
|
||||||
|
addDevice(v.getEquipment(), {
|
||||||
|
name = name .. ':equipment',
|
||||||
|
type = 'equipment',
|
||||||
|
side = v.side
|
||||||
|
}, doQueue)
|
||||||
|
end
|
||||||
|
if v.getEnder then
|
||||||
|
addDevice(v.getEnder(), {
|
||||||
|
name = name .. ':enderChest',
|
||||||
|
type = 'enderChest',
|
||||||
|
side = v.side
|
||||||
|
}, doQueue)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
for k,v in pairs(device) do
|
||||||
|
if containers[v.type] then
|
||||||
|
cache[k] = v
|
||||||
|
addContainer(v)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
-- register modules as peripherals
|
-- register modules as peripherals
|
||||||
kernel.hook('device_attach', function(_, eventData)
|
kernel.hook('device_attach', function(_, eventData)
|
||||||
local dev = eventData[2]
|
local name = eventData[1]
|
||||||
|
local dev = device[name]
|
||||||
|
|
||||||
if dev and containers[dev.type] then
|
if dev and containers[dev.type] then
|
||||||
local list = getModules(peripheral.wrap(dev.side), dev.side)
|
-- so... basically, if you get a handle to device.neuralInterface
|
||||||
for k,v in pairs(list) do
|
-- (or manipulator) - that handle will still be valid after
|
||||||
if not device[k] or dev.type ~= 'manipulator' then
|
-- a module is removed
|
||||||
device[k] = v
|
if cache[name] then
|
||||||
os.queueEvent('device_attach', k, v)
|
device[name] = cache[name]
|
||||||
end
|
-- TODO: cannot simply merge - need to remove
|
||||||
|
-- all functions then merge
|
||||||
|
Util.merge(device[name], dev)
|
||||||
|
else
|
||||||
|
cache[name] = dev
|
||||||
end
|
end
|
||||||
|
addContainer(dev, true)
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
@ -23,5 +23,5 @@ end
|
|||||||
|
|
||||||
-- register oc devices as peripherals
|
-- register oc devices as peripherals
|
||||||
kernel.hook('device_attach', function(_, eventData)
|
kernel.hook('device_attach', function(_, eventData)
|
||||||
register(device[eventData[2]])
|
register(device[eventData[1]])
|
||||||
end)
|
end)
|
||||||
|
@ -12,6 +12,7 @@ local fs = _G.fs
|
|||||||
local os = _G.os
|
local os = _G.os
|
||||||
local peripheral = _G.peripheral
|
local peripheral = _G.peripheral
|
||||||
local term = _G.term
|
local term = _G.term
|
||||||
|
local textutils = _G.textutils
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
Using the shorthand window definition, elements are created from
|
Using the shorthand window definition, elements are created from
|
||||||
@ -217,6 +218,34 @@ function Manager:loadTheme(filename)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function Manager:generateTheme(filename)
|
||||||
|
local t = { }
|
||||||
|
for k,v in pairs(self) do
|
||||||
|
if type(v) == 'table' then
|
||||||
|
if v._preload then
|
||||||
|
v._preload()
|
||||||
|
v = self[k]
|
||||||
|
end
|
||||||
|
if v.defaults and v.defaults.UIElement ~= 'Device' then
|
||||||
|
for p,d in pairs(v.defaults) do
|
||||||
|
if p:find('olor') then
|
||||||
|
if not t[k] then
|
||||||
|
t[k] = { }
|
||||||
|
end
|
||||||
|
for c, n in pairs(colors) do
|
||||||
|
if n == d then
|
||||||
|
t[k][p] = 'colors.' .. c
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
Util.writeFile(filename, textutils.serialize(t):gsub('(")', ''))
|
||||||
|
end
|
||||||
|
|
||||||
function Manager:emitEvent(event)
|
function Manager:emitEvent(event)
|
||||||
local currentPage = self:getActivePage()
|
local currentPage = self:getActivePage()
|
||||||
if currentPage and currentPage.focused then
|
if currentPage and currentPage.focused then
|
||||||
|
@ -7,6 +7,7 @@ UI.Menu.defaults = {
|
|||||||
UIElement = 'Menu',
|
UIElement = 'Menu',
|
||||||
disableHeader = true,
|
disableHeader = true,
|
||||||
columns = { { heading = 'Prompt', key = 'prompt', width = 20 } },
|
columns = { { heading = 'Prompt', key = 'prompt', width = 20 } },
|
||||||
|
menuItems = { },
|
||||||
}
|
}
|
||||||
function UI.Menu:postInit()
|
function UI.Menu:postInit()
|
||||||
self.values = self.menuItems
|
self.values = self.menuItems
|
||||||
|
Loading…
Reference in New Issue
Block a user