Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Support concurrent merge and split operations in Tree #753

Open
sejongk opened this issue Jan 8, 2024 · 0 comments
Open

Support concurrent merge and split operations in Tree #753

sejongk opened this issue Jan 8, 2024 · 0 comments
Labels
enhancement 🌟 New feature or request sdk ⚒️

Comments

@sejongk
Copy link
Contributor

sejongk commented Jan 8, 2024

What would you like to be added:
Through the PRs #659 and #705, Yorkie now supports merge and split operations in Tree.
However, concurrent edits for these operations are not implemented yet.
It is necessary to support concurrent merge and split operations as a next step.

Why is this needed:

Problem

The current implementation of Tree can't support concurrent edits for merge and split operations.

This is mainly because these operations inherently involves the movement of child nodes to another parent node.
In concurrent editing situations, it becomes challenging to determine the destination or source of the child nodes solely based on the from or to in the operation.

Let's examine this with the following example.

Initial

<r><p>a</p><p>b</p></r>

Before sync

User A: Merge(Edit(2,4)) -> <r><p>ab</p></r> 
User B: Delete(Edit(3,6)) -> <r><p>a</p></r>

After sync

Expected: <r><p>a</p></r> 
User A Actual: <r><p>ab</p></r>  <-- Text "b" stays alive
User B Actual: <r><p>a</p></r>
tree-concurrent-merge-delete

You can see more examples in the following PRs.

Solution

One possible solution for this issue is re-ordering concurrent operations, which means that the Tree CRDT doesn't depend solely on the commutative rule between operations anymore.
To be specific, when more than one operations are considered to be concurrent by means of TimeTicketContext (a.k.a. latestCreatedAtMapByActor), it can roll back the current state to the nearest snapshot, re-order the concurrent operations, and apply them successively.

The ordering between operations should be determined by whether it preserves users' intention well in concurrent edits.
For instance, we can use Delete(Merge) > Split > Insert as the ordering for operations.

This mechanism is closely related to Tree.Move, which is described in #634.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement 🌟 New feature or request sdk ⚒️
Projects
Status: Backlog
Status: Todo
Development

No branches or pull requests

1 participant