Tag-based asynchronous messaging framework
Go to file
Tristan B. Kildaire c1712d8afe Updated API docs 2020-06-23 10:58:11 +02:00
source/tristanable Cleaned up comment. 2020-06-23 09:18:20 +02:00
.gitignore Initial commit 2020-06-19 19:36:57 +02:00
LICENSE Initial commit 2020-06-19 19:36:57 +02:00
README.md Updated API docs 2020-06-23 10:58:11 +02:00
dub.json Updated dub info 2020-06-21 17:39:50 +02:00
dub.selections.json Added module structure and stub modules. 2020-06-21 17:27:20 +02:00

README.md

tristanable

Tag-based asynchronous messaging framework

Usage

The entry point is via the Manager type, so first create an instance as follows (passing the endpoint Socket in as socket in this example):

Manager manager = new Manager(socket);

Now the event loop would have started, now we are ready to send out some tagged messages and blocking receive for them!

Let's send out two messages with tags 1 and 2:

manager.sendMessage(1, [1,2,3,4,5]);
manager.sendMessage(2, [6,7,8,9,0]);

Now we can start two seperate threads and wait on them both:

byte[] receivedData = manager.receiveMessage(1);
byte[] receivedData = manager.receiveMessage(2);

TODO

Format

[4 bytes (size-2, little endian)][8 bytes - tag][(2-size) bytes - data]

Acknowledgements

Thansk to Gabby Smuts for the name suggestion 😉