Coalescing ring buffer in Rust


I am trying to rewrite the java version of Coalescing ring buffer in Rust. Original implementation can be found at

My version in rust which does not work yet can be found at

The idea is that a producer and a consumer thread will have a shared instance of this collection. The producer will continuously push(offer) objects on to collection and consumer will poll from the collection. Latest objects with same key will overwrite any unconsumed objects with the same key.

I am not able to decide what kind of data structure to use for the values. Any help is appreciated.



There is polyfractal’s Turbine which is also buggy as of now because while I managed to make it compile I didn’t find the time to shake the bugs out yet.