Version 0.10.0-alpha.2
The changes in this version are important enough to receive an alpha version and its own release.
This version fixes three critical issues in YetAnotherNet, one preventing packets from being queried in some cases, and two others which caused unexpected frame delays due to flaws in the design of the scheduling code. In order to fix these issues, breaking changes have been make to the Hooks API and the Bridge API, a detailed migration guide can be found below.
It is important to note that the Hooks API should be stable, but the Bridge API may at any point change and should be considered unstable. The breaking changes made in this version were necessary in order to address a flaw in the API design.
Migration Guide
Hooks API
If you previously used the YetAnotherNet.createHook()
function, it still behaves the same except it now returns two new functions instead of one: beginFrame
and endFrame
.
These functions will respectively call scheduling code that is meant for the beginning and end of a frame, instead of one function that would call it at the same time.
The following is an example of how to use the updated Hooks API:
local RunService = game:GetService("RunService")
local YetAnotherNet = require("@packages/YetAnotherNet")
local routes = require("@shared/routes")
local myRoute = routes.myRoute
local beginFrame, endFrame = YetAnotherNet.createHook({ Route })
RunService.Heartbeat:Connect(function()
beginFrame()
myRoute:send(...)
for i, player, data in myRoute:query() do
-- Do something
end
endFrame()
end)
Note
The behavior of YetAnotherNet.start()
has changed, the API itself has not. This function will now run the respective scheduling code at the beginning AND the end of a frame instead of just at the end of a frame.
Bridge API
The Bridge:step()
method has been removed and replaced with new Bridge:beginFrame()
and Bridge:endFrame()
methods which will run the respective scheduling code at the beginning AND the end of a frame instead of just at the end of a frame.
Warning
The Bridge API is unstable and may change in future versions, it is not guaranteed that any of the API for the Bridge will remain constant.
Installing the New Version
Wally
Add YetAnotherNet to your project with Wally by adding the following to your wally.toml
file:
[dependencies]
YetAnotherNet = "yetanotherclown/[email protected]"
Note
Wally does not export types automatically, if you wish to use Strict Typing with YetAnotherNet, install Wally Package Types with Foreman.
NPM for Roblox Typescript
You can find YetAnotherNet on NPM, or install it with the command line:
npm i @rbxts/[email protected]
Change Log
Tip
See the CHANGELOG.md for future and past changes.
Changed
Bridge:step()
has been replaced byBridge:beginFrame
andBridge:endFrame
which separates the logic behind the Incoming and Outgoing queuesYetAnotherNet.createHook()
now returns two functions, abeginFrame
and aendFrame
function which separates scheduling logic
Fixed
- A critical bug that resulted in the unexpected termination of query iterators