-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
packages/core
- branch documentation (#437)
* WIP: branches doc * amend algorithm * move branches.md, add svg files * remove borders * more notes
- Loading branch information
Showing
8 changed files
with
66 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
# Branches | ||
|
||
In Canvas, the message log is an acyclic directed graph. Messages can have multiple "parents". This results in messages being partially ordered, i.e. some messages are children/ancestors of each other and some occur concurrently. To keep track of this branching behaviour, Canvas peers assign a "branch number" to each incoming message. Note that this property is local to each peer - on different peers, the same message may have a different branch number. | ||
|
||
This document will explain how branch numbers are determined and then explain how they are used within Canvas. Attention will be given to the data model and algorithms used. | ||
|
||
## Relevant tables: | ||
|
||
- `$messages` - this table stores the id, signature, message contents (the `message` column), hash, branch and clock information about each message that the peer sees. | ||
- `$effects` - in the case where a message is an action, it may make changes to the data in ModelDB. We call these changes "effects". This table stores the key (which consists of the model name and the key to be updated) and value that were set, as well as the branch number and clock of the message that produced the effect. | ||
- `$branch_merges` - this table stores the points where branches split off from and/or join each other. TODO: we aren't actually using this - delete? | ||
|
||
## How branch numbers are calculated | ||
|
||
When Canvas receives a new message (either by syncing with another peer or generating a message locally, e.g. when the user performs an action or creates a session), it is assigned a "branch number". These are positive integers, starting at zero. | ||
|
||
The algorithm is as follows: | ||
|
||
1. If the message has no parents, then allocate a new branch number and return it. | ||
2. If the parent with the highest branch value is the latest message on its branch (i.e. the peer has not seen any of its "children" yet), then return this parent's branch number. | ||
3. Otherwise, allocate a new branch number. | ||
|
||
To allocate a new branch number, choose the current maximum branch number across all messages and add `1`. | ||
|
||
### Example | ||
|
||
1. Add a message A. This message has no parents, so allocate a new branch `0`. | ||
|
||
data:image/s3,"s3://crabby-images/0baf5/0baf586f5fcd0f77dbf3c495e6dc2089313baa5e" alt="" | ||
|
||
2. Add a message B with one parent A. This message has one parent who has no other children, so give it branch `0`. | ||
|
||
data:image/s3,"s3://crabby-images/9d1e4/9d1e425ec2bbbcbf6edcb0f3f4d51dca69b9d1e4" alt="" | ||
|
||
3. Add a message C with parent B. This message also has one parent (B) who has no other children, so give it branch `0`. | ||
|
||
data:image/s3,"s3://crabby-images/6743a/6743aa100d6722218d9d8ba6472f7fc5b18422a3" alt="" | ||
|
||
4. Add a message D with parent A. A already has a child (B) so allocate a new branch `1`. | ||
|
||
data:image/s3,"s3://crabby-images/e80a7/e80a77ff1566101582ce2b81cfe3d914dfa6ab9e" alt="" | ||
|
||
5. Add a message E with parents B and D. D has a higher branch number (`1`) than B (`0`). D does not have any other children, so E's branch number is `1`. | ||
|
||
data:image/s3,"s3://crabby-images/77bee/77bee0e0a78d6247957ed720f97e1ccbe2d91ac1" alt="" | ||
|
||
6. Add a message F with one parent E. E does not have any other children, so F's branch number is `1`. | ||
|
||
data:image/s3,"s3://crabby-images/2ff2a/2ff2af2868760441ef089840f60f679a886db4f7" alt="" | ||
|
||
7. Add a message G with parents C and E. Out of the two parents, E has the highest branch number. E already has a child, so allocate a new branch `2`. | ||
|
||
data:image/s3,"s3://crabby-images/50d5a/50d5ad74d2abba484b497614d50b4106a07774bb" alt="" | ||
|
||
## How branch numbers are used | ||
|
||
Currently, Canvas does not internally use branch numbers. In the past we have experimented with using the branch number to optimise parts of the Canvas algorithm, see https://github.com/canvasxyz/canvas/pull/304. | ||
|
||
Branch numbers can be used to help generate graph layouts for displaying Canvas message logs. On a given peer, each pair of `(clock, branch)` has at most one message associated with it. |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.