mirror of
https://github.com/XeonSquared/OC-Copper.git
synced 2024-11-23 09:58:06 +11:00
Make relib relatively backend-independent, increase the max timers to 0x400.
relib now relies on an additional parameter which should be require("culib"), but could instead be a Copper-like library.
This commit is contained in:
parent
4a4cd485b1
commit
8e8b3f650d
@ -19,6 +19,7 @@ if package.loaded["occure"] then
|
|||||||
error("Already installed")
|
error("Already installed")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local culib = require("culib")
|
||||||
local node = require("relib")(host, function (tgt, data)
|
local node = require("relib")(host, function (tgt, data)
|
||||||
for _, v in ipairs(modems) do
|
for _, v in ipairs(modems) do
|
||||||
if tgt then
|
if tgt then
|
||||||
@ -29,15 +30,16 @@ local node = require("relib")(host, function (tgt, data)
|
|||||||
end
|
end
|
||||||
end, function (...)
|
end, function (...)
|
||||||
computer.pushSignal("copper_packet", ...)
|
computer.pushSignal("copper_packet", ...)
|
||||||
end, computer.uptime)
|
end, computer.uptime, culib)
|
||||||
|
|
||||||
package.loaded["occure"] = node
|
|
||||||
|
|
||||||
for v, _ in component.list("modem") do
|
for v, _ in component.list("modem") do
|
||||||
local m = component.proxy(v)
|
local m = component.proxy(v)
|
||||||
table.insert(modems, m)
|
table.insert(modems, m)
|
||||||
m.open(4957)
|
m.open(4957)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
package.loaded["occure"] = node
|
||||||
|
|
||||||
event.listen("modem_message", function (et, adto, adfrom, port, dist, magic, data)
|
event.listen("modem_message", function (et, adto, adfrom, port, dist, magic, data)
|
||||||
if et ~= "modem_message" then return end
|
if et ~= "modem_message" then return end
|
||||||
if port == 4957 then
|
if port == 4957 then
|
||||||
|
38
relib.lua
38
relib.lua
@ -4,16 +4,34 @@
|
|||||||
-- Copper Reliability Layer
|
-- Copper Reliability Layer
|
||||||
-- Notably, this should be instantiated rather than the normal Copper instance.
|
-- Notably, this should be instantiated rather than the normal Copper instance.
|
||||||
|
|
||||||
local culib = require("culib")
|
-- The Copper node constructor (which could be replaced with something else,
|
||||||
|
-- should you decide to run the Reliability layer over another transport)
|
||||||
|
-- is passed as function (hostname, transmit, onReceive, time),
|
||||||
|
-- where hostname is the hostname given,
|
||||||
|
-- transmit is the (target/nil (for broadcast), data) function as given,
|
||||||
|
-- onReceive is the (nfrom. nto, ndata) function
|
||||||
|
-- internal to the Reliability Layer to translate packets for onRReceive
|
||||||
|
-- and acknowledge packets that need to be acknowledged,
|
||||||
|
-- and time is the function-that-returns-current-time-in-seconds
|
||||||
|
-- function as given.
|
||||||
|
|
||||||
|
-- The resulting Copper-like node should have the following fields:
|
||||||
|
-- node.hostname: Editable hostname.
|
||||||
|
-- node.refresh(): Do various timed cleanup tasks.
|
||||||
|
-- node.input(...): relib.input is set to this for convenience.
|
||||||
|
-- Ought to be function (opaqueFrom, data).
|
||||||
|
-- node.output(nFrom, nTo, data): The normal Copper send function.
|
||||||
|
|
||||||
-- onRReceive is now: (from, to, port, data, unreliablePacket)
|
-- onRReceive is now: (from, to, port, data, unreliablePacket)
|
||||||
-- where to can be anything for unreliable packets, but otherwise is the current hostname.
|
-- where to can be anything for unreliable packets,
|
||||||
return function (hostname, transmit, onRReceive, time)
|
-- but otherwise is the current hostname.
|
||||||
|
return function (hostname, transmit, onRReceive, time, culib)
|
||||||
-- node.hostname should be used for hostname generally.
|
-- node.hostname should be used for hostname generally.
|
||||||
local node
|
local node
|
||||||
|
|
||||||
-- The maximum amount of timers (used to cap memory usage)
|
-- The maximum amount of timers (used to cap memory usage).
|
||||||
local tuningMaxTimers = 0x200
|
-- Assuming 16 bytes per key, this should be 64k.
|
||||||
|
local tuningMaxTimers = 0x400
|
||||||
local tuningClearAntiduplicate = 60
|
local tuningClearAntiduplicate = 60
|
||||||
local tuningAttempts = 12
|
local tuningAttempts = 12
|
||||||
local tuningAttemptTime = 2.5
|
local tuningAttemptTime = 2.5
|
||||||
@ -78,15 +96,19 @@ return function (hostname, transmit, onRReceive, time)
|
|||||||
if nto ~= node.hostname then return end
|
if nto ~= node.hostname then return end
|
||||||
node.output(nto, nfrom, data:sub(1, 6) .. "\x02")
|
node.output(nto, nfrom, data:sub(1, 6) .. "\x02")
|
||||||
end
|
end
|
||||||
|
-- Ignore ACKs for our packets that aren't going our way.
|
||||||
|
-- (Just a fringe case of packet ID reuse)
|
||||||
|
if nto ~= node.hostname then
|
||||||
|
return
|
||||||
|
end
|
||||||
if (tp == 0x02) and needsAck[nfrom .. globalId] then
|
if (tp == 0x02) and needsAck[nfrom .. globalId] then
|
||||||
needsAck[nfrom .. globalId][1](nfrom)
|
needsAck[nfrom .. globalId][1](nfrom)
|
||||||
killTimer(needsAck[nfrom .. globalId][2])
|
killTimer(needsAck[nfrom .. globalId][2])
|
||||||
needsAck[nfrom .. globalId] = nil
|
needsAck[nfrom .. globalId] = nil
|
||||||
end
|
end
|
||||||
if nto ~= node.hostname then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Instantiate the node or lookalike.
|
||||||
node = culib(hostname, transmit, onReceive, time)
|
node = culib(hostname, transmit, onReceive, time)
|
||||||
|
|
||||||
local relib = {}
|
local relib = {}
|
||||||
|
Loading…
Reference in New Issue
Block a user