crdt-playground
crdt-playground copied to clipboard
This repository is a companion to the article "Data Laced with History: Causal Trees & Operational CRDTs", where I examine the fascinating new class of "operational" CRDTs in detail. Not a framework; for educational use only. Please don't use this in production unless you know what you're doing!
A generic implementation of Victor Grishchenko's Causal Tree CRDT, written in Swift. State-based (CvRDT) implementation. Features many tweaks, including a site identifier map, atom references, and priority atoms. Uses Lamport timestamps instead of "awareness".
Two pieces of companion software are included. The first is a macOS app that simulates device sync over a hypothetical network with any arbitrary topology and any number of partitions. The app is designed for testing the resiliency of a CRDT under difficult network conditions and includes editing support for text and vector graphics. The second is a very basic, CT-based text editor for iOS that works equally well online and offline, syncs documents over CloudKit, and supports real-time collaboration over CloudKit Sharing. No extra servers required! (Such is the glory of CRDTs.)
Performance is good: everything should be O(nlogn) or faster.
data:image/s3,"s3://crabby-images/a95ee/a95ee9ed928f560a53cadb40a8d691bbe48cd461" alt=""
data:image/s3,"s3://crabby-images/3f7ce/3f7ceaa3f0835f44d722651bc9f6ca6da1c08436" alt=""
data:image/s3,"s3://crabby-images/83c4c/83c4c5017360c37602eb5ce33b9648c6b15aee8d" alt=""
data:image/s3,"s3://crabby-images/f14c6/f14c63c92b684f10c5151794b237abf5a42db0ad" alt=""
data:image/s3,"s3://crabby-images/c8114/c81145a49370de97d40b5be5116ab81023d64326" alt=""