1
 
Scaling analysys of Merge
 
2
 
=========================
 
4
 
1. Fetch revisions O(a)
 
5
 
2. Common Ancestor [O(b)] **O(h)**
 
6
 
3. Calculate tree merge O(c) [+ O(b) + O(d)] **+ O(i)**
 
8
 
 - text merge O(e * e * f) + O(b)
 
10
 
4. Find filesystem conflicts O(c)
 
11
 
5. Resolve filesystem conflicts O(g)
 
12
 
6. Apply changes O(c) + O(log(d))
 
13
 
7. Set pending merges O(1)
 
14
 
8. Print conflicts O(g)
 
17
 
:a: revisions missing from repo:
 
18
 
:b: nodes in the revision graph:
 
19
 
:c: files that differ between base and other:
 
20
 
:d: number of files in the tree
 
21
 
:e: number of lines in the text
 
22
 
:f: number of files requiring text merge
 
23
 
:g: number of conflicts (g <= c)
 
24
 
:h: humber of uncommon ancestors
 
25
 
:i: number of revisions between base and other
 
29
 
- Access to revision graph proportional to number of revisions read
 
30
 
- Access to changed file metadata proportional to number of changes and number of intervening revisions.
 
31
 
- O(1) access to fulltexts
 
35
 
Multiparent deltas may offer some nice properties for performance of annotation based merging.