[ARCHIVED] Warp - very fast & powerful networking library

Warp

Warp is a open-sourced networking library, Warp optimized efficient for any-scale task. It's very fast, small, powerful & strictly-typed library.

Roblox OSS Community | Documentation | Github | Wally | Roblox Creator
Download with .RBXM

Why Warp?


  • Simple (Warp has simply APIs & easy-to-use, no complex implementation stuff to do)
  • Typing (Warp is written with strictly-typed for better typing)
  • Rate Limit (Warp have better rateLimit system without sacrifice any performance with better configuration)
  • Performance (Warp have better performance optimized than FastNet2, up to 40%)
  • Flexibility (Warp is slightly flexible compared to other on firing a event with reliable or unreliable without require to creating another event)
  • Modern Dynamic SerDes (Warp use new serdes that use buffer over string.pack by default)

Performance Benchmark

Test Benchmark

(with Benchmarker Plugin)

(*Important Note: These benchmark are using the latest version and are using reliable event, the lower number is better, 250 iteration per attempt (total ~251 attempts per run), Specially for "BridgeNet2" here, it run separated because it always appearing bunch of errors and a bit lagging while on benchmark, which this affects to the benchmark results and "BridgeNet2" keep failing on this benchmark where it give result of 0 total packets received to bridge-event server listener.)



benchmark_warp.rbxl (114.3 KB)

Packet Sizes

Measuring Packet Sizes

(*Note: for packet size counter using Packet Profiler Plugin)

Warp (1.0.1):

FastNet2 (rc9 0.9.7):

BridgeNet2:

Red2:


104 Likes

Could you please provide examples and short usage guides on the main post? Also you make a lot of claims why to use this over FastNet2 and provide statistics without any evidence, it would be nice if those could be provided!

Also your documentation page is a work-in-progress entirely, you should consider providing usage here and finalize the documentation page as currently it is up to reading the source code to figure it how to use this as intended.

Reading the source code even further I realize there’s a few files that seemingly haven’t been tested, did you post this without proper testing? Why have you made your own Assert module instead of just using the built-in assert?

15 Likes

Can we get a comparison between this and BridgeNet2 or FastNet2?

11 Likes

custom assert have much better than assert(...) like performance

5 Likes

i have tested it while developing it and comparing Warp with FastNet2 rc9 0.9.7

2 Likes

Warp is just an upgrade to FastNet2, I don’t know why everyone brings that up when the OP made both of these networking libraries

also instead of replying twice, you can quote stuff in one post

8 Likes

I agree,as no evidence of these claims and features,I wouldnt use it without seeing the Test evidence and features that are being claimed are there,so for now I wont use it just till I see Evidence of these claims.

4 Likes

I will be doing the test and showing it the result with other libraries tmr.

3 Likes

interesting might aswell try it

4 Likes

hey, you should add 2 more functions ConnectEventClient and ConnectEventServer the server one connects any event that is created in a server script then you can listen to it the client connects any event that is created in the client then listen it, it would make the module easier to use.

1 Like

Are you gonna add support for Unreliable Remote Events?

2 Likes

image

1 Like

Oh dang! I haven’t read the documentation yet. Thanks for the notice.

1 Like

my question for this is what was the motive behind creating it? I see you already created two networking libraries. whats the point of making a third one? does this library depreciate the others?

1 Like

How would this be better than ByteNet or Zap? :zap:

5 Likes

make sure you have read the documentation site, on :Fires you have to add reliable argument before you given the data arguments like this :Fires(true, ...) if it true then it use reliable or else.

Warp | 1.0.1


  • Fix Missing argument type for rateLimit on .Server
  • Fix failed initialize player on Server (at some condition)

Get .RBXM from github
With Wally

also added some test benchmark result (also sorry for the minor typo on test benchmark result where supposed to be warp not wrap.

1 Like

I agree with this sentiment, why not just update one of the other ones to be more optimized instead of making a new one to deprecate an older one? It makes it harder for developers to quickly switch over to a better system since they’d have to fully change it in their workflow.

1 Like

update fixed the issues in my bot game , but still my render cant retrieve colours.
besides from the chat bit i think it got confused since there’s a server connected to it, client connected and another client. its created in one client script then accessed by the others server and client how do i control the flow of the event? shall i use the rateLimit?

also i put false in every fire bit in like 5 scripts before firing them (not using reliable events)