mirror of
https://github.com/kepler155c/opus
synced 2025-01-14 17:35:42 +00:00
133 lines
2.9 KiB
Lua
133 lines
2.9 KiB
Lua
local class = require('class')
|
|
local Peripheral = require('peripheral')
|
|
|
|
local RefinedProvider = class()
|
|
|
|
function RefinedProvider:init(args)
|
|
|
|
local defaults = {
|
|
cache = { },
|
|
items = { },
|
|
name = 'refinedStorage',
|
|
}
|
|
Util.merge(self, defaults)
|
|
Util.merge(self, args)
|
|
|
|
local controller = Peripheral.getByType('refinedstorage:controller')
|
|
if controller then
|
|
Util.merge(self, controller)
|
|
end
|
|
end
|
|
|
|
function RefinedProvider:isValid()
|
|
return not not self.listAvailableItems
|
|
end
|
|
|
|
function RefinedProvider:isOnline()
|
|
return self.getNetworkEnergyStored() > 0
|
|
end
|
|
|
|
function RefinedProvider:getCachedItemDetails(item)
|
|
local key = table.concat({ item.name, item.damage, item.nbtHash }, ':')
|
|
|
|
local detail = self.cache[key]
|
|
if not detail then
|
|
detail = self.findItem(item)
|
|
if detail then
|
|
local meta
|
|
pcall(function() meta = detail.getMetadata() end)
|
|
if meta then
|
|
Util.merge(detail, meta)
|
|
if detail.maxDamage and detail.maxDamage > 0 and detail.damage > 0 then
|
|
detail.displayName = detail.displayName .. ' (damaged)'
|
|
end
|
|
detail.lname = detail.displayName:lower()
|
|
|
|
-- backwards capability
|
|
detail.dmg = detail.damage
|
|
detail.id = detail.name
|
|
detail.qty = detail.count
|
|
detail.display_name = detail.displayName
|
|
detail.nbtHash = item.nbtHash
|
|
|
|
self.cache[key] = detail
|
|
end
|
|
end
|
|
end
|
|
if detail then
|
|
return Util.shallowCopy(detail)
|
|
end
|
|
end
|
|
|
|
function RefinedProvider:listItems()
|
|
local items = { }
|
|
local list
|
|
|
|
pcall(function()
|
|
list = self.listAvailableItems()
|
|
end)
|
|
|
|
if list then
|
|
for _,v in pairs(list) do
|
|
local item = self:getCachedItemDetails(v)
|
|
if item then
|
|
item.count = v.count
|
|
item.qty = v.count
|
|
table.insert(items, item)
|
|
end
|
|
end
|
|
end
|
|
|
|
return items
|
|
end
|
|
|
|
function RefinedProvider:getItemInfo(fingerprint)
|
|
|
|
local key = table.concat({ fingerprint.name, fingerprint.damage, fingerprint.nbtHash }, ':')
|
|
|
|
local item = self.cache[key]
|
|
if not item then
|
|
return self:getCachedItemDetails(fingerprint)
|
|
end
|
|
|
|
local detail = self.findItem(item)
|
|
if detail then
|
|
item.count = detail.count
|
|
item.qty = detail.count
|
|
return item
|
|
end
|
|
end
|
|
|
|
function RefinedProvider:isCrafting(item)
|
|
for _,task in pairs(self.getCraftingTasks()) do
|
|
local output = task.getPattern().outputs[1]
|
|
if output.name == item.name and
|
|
output.damage == item.damage and
|
|
output.nbtHash == item.nbtHash then
|
|
return true
|
|
end
|
|
end
|
|
return false
|
|
end
|
|
|
|
function RefinedProvider:craft(id, dmg, qty)
|
|
return false
|
|
end
|
|
|
|
function RefinedProvider:craftItems(items)
|
|
return false
|
|
end
|
|
|
|
function RefinedProvider:provide(item, qty, slot)
|
|
end
|
|
|
|
function RefinedProvider:extract(slot, qty)
|
|
-- self.pushItems(self.direction, slot, qty)
|
|
end
|
|
|
|
function RefinedProvider:insert(slot, qty)
|
|
-- self.pullItems(self.direction, slot, qty)
|
|
end
|
|
|
|
return RefinedProvider
|