Skip to content

GSet

Defined in: src/crdt/GSet.ts:39

Conflict-free Replicated Data Type — a value that converges under replication without coordination. Every implementation is a state-based CvRDT: replicas exchange full state, and merge forms a join-semilattice.

Three properties every implementation must satisfy — tests/unit/crdt verifies them by hand-rolled property tests against generated samples:

  • Idempotent: merge(a, a) === a
  • Commutative: merge(a, b) === merge(b, a)
  • Associative: merge(merge(a, b), c) === merge(a, merge(b, c))

Together these mean: gossip can deliver state updates in any order, deduplicate, retransmit, and the world converges as long as every replica eventually sees every state.

Why state-based and not delta-state. Delta-CRDTs ship only the incremental change rather than the full state — much cheaper on the wire, but the implementation has more moving parts and you need delta acknowledgement protocols. State-based is the simplest thing that converges; we ship it first and revisit if payload size hurts.

E

The concrete CRDT type. F-bounded so subclass merge keeps the right return type without casting at every call site.

get size(): number

Defined in: src/crdt/GSet.ts:69

number

add(element): GSet<E>

Defined in: src/crdt/GSet.ts:52

E

GSet<E>


equals(other): boolean

Defined in: src/crdt/GSet.ts:106

GSet<E>

boolean


has(element): boolean

Defined in: src/crdt/GSet.ts:60

E

boolean


merge(other): GSet<E>

Defined in: src/crdt/GSet.ts:71

Join two replicas. Must be a join-semilattice operation: total, idempotent, commutative, associative.

GSet<E>

GSet<E>

Crdt.merge


toJSON(): GSetJson

Defined in: src/crdt/GSet.ts:88

Wire shape: array of JSON-stringified elements. Custom identity is NOT serialised — fromJSON callers must pass the matching identity option to reconstruct a set with the same dedup rule. For default identity the JSON-string IS the identity key, so a round-trip produces the same internal state.

GSetJson

Crdt.toJSON


value(): readonly E[]

Defined in: src/crdt/GSet.ts:65

Snapshot of every element currently in the set.

readonly E[]


static empty<E>(opts?): GSet<E>

Defined in: src/crdt/GSet.ts:48

E

GSetOptions<E> = {}

GSet<E>


static fromJSON<E>(json, opts?): GSet<E>

Defined in: src/crdt/GSet.ts:95

E

GSetJson

GSetOptions<E> = {}

GSet<E>