syndicate-rkt/syndicate
Tony Garnock-Jones 3ff50a6f65 broker: client; ping for keepalive; client example 2019-03-18 23:29:12 +00:00
..
broker broker: client; ping for keepalive; client example 2019-03-18 23:29:12 +00:00
drivers tcp-rejected; reassert-on 2019-03-18 23:27:59 +00:00
examples broker: client; ping for keepalive; client example 2019-03-18 23:29:12 +00:00
mc Initial broker implementation 2019-03-18 15:34:14 +00:00
test Supervision and reloading 2019-01-28 01:14:33 +00:00
.gitignore Tweak .gitignore 2018-04-29 14:54:22 +01:00
HOWITWORKS.md Note in HOWITWORKS about `opaque-placeholder`. 2018-11-20 13:22:44 +00:00
Makefile Improve (?) test ergonomics. 2018-11-02 12:15:21 +00:00
README.md Notes on install and test 2018-05-03 15:21:33 +01:00
assertions.rkt Factor out assertion structure definitions 2018-05-03 16:14:30 +01:00
bag.rkt for/bag and for/bag/count 2018-05-03 22:09:13 +01:00
broker.rkt broker: client; ping for keepalive; client example 2019-03-18 23:29:12 +00:00
dataspace.rkt Supervision and reloading 2019-01-28 01:14:33 +00:00
event-expander.rkt Progress on syntax veneer 2018-04-08 11:44:32 +01:00
ground.rkt Drain multiple external ground events at once. (Good or bad idea?) 2018-05-01 17:34:51 +01:00
info.rkt Refactor tests 2018-04-29 11:55:32 +01:00
lang.rkt In case there are no activation-forms, add a gratuitous `(void)` at the end. 2018-04-30 22:47:53 +01:00
main.rkt Factor out assertion structure definitions 2018-05-03 16:14:30 +01:00
pattern-expander.rkt pattern-expander.rkt 2018-05-04 23:15:09 +01:00
pattern.rkt Silly mistake 2018-11-02 15:09:20 +00:00
prototype.rkt Rearrange 2018-03-27 22:21:49 +13:00
reassert.rkt tcp-rejected; reassert-on 2019-03-18 23:27:59 +00:00
reflection.rkt Supervision and reloading 2019-01-28 01:14:33 +00:00
relay.rkt Initial broker implementation 2019-03-18 15:34:14 +00:00
reload.rkt Make reloaders in turn reloadable 2019-01-30 16:40:12 +00:00
skeleton.rkt First JavaScript steps, based on HOWITWORKS.md 2018-10-21 00:58:40 +01:00
supervise.rkt Supervision and reloading 2019-01-28 01:14:33 +00:00
syntax-classes.rkt Add timer/timestate support; this prompted a change to endpoint registration. 2018-04-29 22:27:55 +01:00
syntax.rkt User count; define/query-count 2019-01-29 20:47:06 +00:00
term.rkt Initial broker implementation 2019-03-18 15:34:14 +00:00
test-implementation.rkt Supervision and reloading 2019-01-28 01:14:33 +00:00

README.md

New "Imperative" Syndicate Implementation

This experimental reimplementation of Syndicate takes the language-level constructs of facets, endpoints, and fields to heart, and integrates knowledge of facets and endpoints into the dataspace implementation itself.

It gains a significant performance advantage by doing so.

Programs seem to be about 20x faster. Some are only 10x faster, some are 30x faster.

The prototype that embodies the new idea is in prototype.rkt.

All the drivers end up looking much nicer with this new implementation. The previously-separate GL-2D support is now integrated as just another driver (though the timing characteristics of the old implementation are not precisely preserved). The ground.rkt implementation is much cleaner.

Install the package by getting a Git checkout and running

raco pkg install --link -n imperative-syndicate `pwd`

The implementation test suite lives in test/. Run it with:

raco setup imperative-syndicate; raco test -p imperative-syndicate

Try out the "many Racket logos" animation example/demo:

racket examples/gl-2d-many.rkt

Hopefully you'll get a smooth 60fps, though I admit I'm running it on a fairly fast machine so you might need to drop the sprite-count in the code a bit to sustain 60fps.