test-merge-changedelete.t
1108 lines
| 39.0 KiB
| text/troff
|
Tads3Lexer
/ tests / test-merge-changedelete.t
Pulkit Goyal
|
r46191 | #testcases newfilenode old | ||
#if newfilenode | ||||
Enable the config option | ||||
------------------------ | ||||
$ cat >> $HGRCPATH <<EOF | ||||
> [experimental] | ||||
> merge-track-salvaged = True | ||||
> EOF | ||||
#endif | ||||
Siddharth Agarwal
|
r27137 | Tests for change/delete conflicts, including: | ||
Siddharth Agarwal
|
r26947 | b5605d88dc27: Make ui.prompt repeat on "unrecognized response" again | ||
(issue897) | ||||
840e2b315c1f: Fix misleading error and prompts during update/merge | ||||
(issue556) | ||||
Make sure HGMERGE doesn't interfere with the test | ||||
$ unset HGMERGE | ||||
$ status() { | ||||
> echo "--- status ---" | ||||
Siddharth Agarwal
|
r27125 | > hg st -A file1 file2 file3 | ||
Siddharth Agarwal
|
r27126 | > echo "--- resolve --list ---" | ||
> hg resolve --list file1 file2 file3 | ||||
Siddharth Agarwal
|
r27136 | > echo "--- debugmergestate ---" | ||
> hg debugmergestate | ||||
Siddharth Agarwal
|
r27125 | > for file in file1 file2 file3; do | ||
Siddharth Agarwal
|
r26947 | > if [ -f $file ]; then | ||
> echo "--- $file ---" | ||||
> cat $file | ||||
> else | ||||
> echo "*** $file does not exist" | ||||
> fi | ||||
> done | ||||
> } | ||||
Siddharth Agarwal
|
r27137 | $ hg init repo | ||
$ cd repo | ||||
Siddharth Agarwal
|
r26947 | |||
$ echo 1 > file1 | ||||
$ echo 2 > file2 | ||||
Siddharth Agarwal
|
r27125 | $ echo 3 > file3 | ||
$ hg ci -Am 'added files' | ||||
Siddharth Agarwal
|
r26947 | adding file1 | ||
adding file2 | ||||
Siddharth Agarwal
|
r27125 | adding file3 | ||
Siddharth Agarwal
|
r26947 | |||
$ hg rm file1 | ||||
$ echo changed >> file2 | ||||
Siddharth Agarwal
|
r27125 | $ echo changed1 >> file3 | ||
$ hg ci -m 'removed file1, changed file2, changed file3' | ||||
Siddharth Agarwal
|
r26947 | |||
$ hg co 0 | ||||
Siddharth Agarwal
|
r27125 | 3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Siddharth Agarwal
|
r26947 | |||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
Siddharth Agarwal
|
r27125 | $ echo changed2 >> file3 | ||
$ hg ci -m 'changed file1, removed file2, changed file3' | ||||
Siddharth Agarwal
|
r26947 | created new head | ||
Non-interactive merge: | ||||
$ hg merge -y | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Siddharth Agarwal
|
r27125 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27599 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27125 | [1] | ||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
M file2 | ||||
Siddharth Agarwal
|
r27125 | M file3 | ||
Siddharth Agarwal
|
r26947 | C file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27126 | U file3 | ||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "u") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27136 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
Simon Farnsworth
|
r30062 | <<<<<<< working copy: 13910f48cf7b - test: changed file1, removed file2, chan... | ||
Siddharth Agarwal
|
r27125 | changed2 | ||
======= | ||||
changed1 | ||||
Kostia Balytskyi
|
r30460 | >>>>>>> merge rev: 10f9a0a634e8 - test: removed file1, changed file2, chan... | ||
Siddharth Agarwal
|
r26947 | |||
Interactive merge: | ||||
$ hg co -C | ||||
Siddharth Agarwal
|
r27125 | 1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r26947 | |||
$ hg merge --config ui.interactive=true <<EOF | ||||
> c | ||||
> d | ||||
> EOF | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? c | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? d | ||||
Siddharth Agarwal
|
r27125 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27137 | 0 files updated, 2 files merged, 0 files removed, 1 files unresolved | ||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27125 | [1] | ||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
file2: * (glob) | ||||
Siddharth Agarwal
|
r27125 | M file3 | ||
Siddharth Agarwal
|
r26947 | C file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27137 | R file1 | ||
R file2 | ||||
Siddharth Agarwal
|
r27126 | U file3 | ||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "r") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "r") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27136 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
*** file2 does not exist | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
Simon Farnsworth
|
r30062 | <<<<<<< working copy: 13910f48cf7b - test: changed file1, removed file2, chan... | ||
Siddharth Agarwal
|
r27125 | changed2 | ||
======= | ||||
changed1 | ||||
Kostia Balytskyi
|
r30460 | >>>>>>> merge rev: 10f9a0a634e8 - test: removed file1, changed file2, chan... | ||
Siddharth Agarwal
|
r26947 | |||
Interactive merge with bad input: | ||||
$ hg co -C | ||||
Siddharth Agarwal
|
r27125 | 1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r26947 | |||
$ hg merge --config ui.interactive=true <<EOF | ||||
> foo | ||||
> bar | ||||
> d | ||||
> baz | ||||
> c | ||||
> EOF | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? foo | ||||
Siddharth Agarwal
|
r26947 | unrecognized response | ||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? bar | ||||
Siddharth Agarwal
|
r26947 | unrecognized response | ||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? d | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? baz | ||||
Siddharth Agarwal
|
r26947 | unrecognized response | ||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? c | ||||
Siddharth Agarwal
|
r27125 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27137 | 0 files updated, 1 files merged, 1 files removed, 1 files unresolved | ||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27125 | [1] | ||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
M file2 | ||||
Siddharth Agarwal
|
r27125 | M file3 | ||
Siddharth Agarwal
|
r26947 | R file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27137 | R file1 | ||
R file2 | ||||
Siddharth Agarwal
|
r27126 | U file3 | ||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "r") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "r") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27136 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r26947 | *** file1 does not exist | ||
--- file2 --- | ||||
2 | ||||
changed | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
Simon Farnsworth
|
r30062 | <<<<<<< working copy: 13910f48cf7b - test: changed file1, removed file2, chan... | ||
Siddharth Agarwal
|
r27125 | changed2 | ||
======= | ||||
changed1 | ||||
Kostia Balytskyi
|
r30460 | >>>>>>> merge rev: 10f9a0a634e8 - test: removed file1, changed file2, chan... | ||
Siddharth Agarwal
|
r26947 | |||
Interactive merge with not enough input: | ||||
$ hg co -C | ||||
Siddharth Agarwal
|
r27125 | 2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r26947 | |||
$ hg merge --config ui.interactive=true <<EOF | ||||
> d | ||||
> EOF | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? d | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
0 files updated, 0 files merged, 1 files removed, 2 files unresolved | ||||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27137 | [1] | ||
Siddharth Agarwal
|
r26947 | |||
$ status | ||||
--- status --- | ||||
Siddharth Agarwal
|
r27137 | M file2 | ||
M file3 | ||||
R file1 | ||||
--- resolve --list --- | ||||
R file1 | ||||
U file2 | ||||
U file3 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "r") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "u") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | *** file1 does not exist | ||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
Simon Farnsworth
|
r30062 | <<<<<<< working copy: 13910f48cf7b - test: changed file1, removed file2, chan... | ||
Siddharth Agarwal
|
r27137 | changed2 | ||
======= | ||||
changed1 | ||||
Kostia Balytskyi
|
r30460 | >>>>>>> merge rev: 10f9a0a634e8 - test: removed file1, changed file2, chan... | ||
Siddharth Agarwal
|
r27137 | |||
Choose local versions of files | ||||
$ hg co -C | ||||
2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :local | ||||
0 files updated, 3 files merged, 0 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ status 2>&1 | tee $TESTTMP/local.status | ||||
--- status --- | ||||
Siddharth Agarwal
|
r26947 | file2: * (glob) | ||
Siddharth Agarwal
|
r27137 | M file3 | ||
Siddharth Agarwal
|
r26947 | C file1 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27137 | R file1 | ||
R file2 | ||||
R file3 | ||||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "r") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "r") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "r") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
*** file2 does not exist | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
changed2 | ||||
Siddharth Agarwal
|
r26947 | |||
Siddharth Agarwal
|
r27137 | Choose other versions of files | ||
$ hg co -C | ||||
1 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :other | ||||
0 files updated, 2 files merged, 1 files removed, 0 files unresolved | ||||
(branch merge, don't forget to commit) | ||||
$ status 2>&1 | tee $TESTTMP/other.status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
R file1 | ||||
--- resolve --list --- | ||||
R file1 | ||||
R file2 | ||||
R file3 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "r") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "r") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "r") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | *** file1 does not exist | ||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Fail | ||||
$ hg co -C | ||||
2 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :fail | ||||
0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27137 | [1] | ||
$ status 2>&1 | tee $TESTTMP/fail.status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
U file3 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "u") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed2 | ||||
Force prompts with no input (should be similar to :fail) | ||||
$ hg co -C | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --config ui.interactive=True --tool :prompt | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
file 'file3' needs to be resolved. | ||||
You can keep (l)ocal [working copy], take (o)ther [merge rev], or leave (u)nresolved. | ||||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27137 | [1] | ||
$ status 2>&1 | tee $TESTTMP/prompt.status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
U file3 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "u") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed2 | ||||
Danek Duvall
|
r27557 | $ cmp $TESTTMP/fail.status $TESTTMP/prompt.status || diff -U8 $TESTTMP/fail.status $TESTTMP/prompt.status | ||
Siddharth Agarwal
|
r27137 | |||
Force prompts | ||||
$ hg co -C | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :prompt | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? u | ||||
file 'file3' needs to be resolved. | ||||
You can keep (l)ocal [working copy], take (o)ther [merge rev], or leave (u)nresolved. | ||||
What do you want to do? u | ||||
Siddharth Agarwal
|
r27599 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27164 | [1] | ||
Siddharth Agarwal
|
r27137 | $ status | ||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27164 | U file3 | ||
Siddharth Agarwal
|
r27137 | --- debugmergestate --- | ||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "u") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed2 | ||||
Choose to merge all files | ||||
$ hg co -C | ||||
1 files updated, 0 files merged, 1 files removed, 0 files unresolved | ||||
Pulkit Goyal
|
r32698 | updated to "13910f48cf7b: changed file1, removed file2, changed file3" | ||
Pierre-Yves David
|
r28029 | 1 other heads for branch "default" | ||
Siddharth Agarwal
|
r27137 | |||
$ hg merge --tool :merge3 | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Siddharth Agarwal
|
r27137 | merging file3 | ||
warning: conflicts while merging file3! (edit, then use 'hg resolve --mark') | ||||
Siddharth Agarwal
|
r27599 | 0 files updated, 0 files merged, 0 files removed, 3 files unresolved | ||
Pulkit Goyal
|
r35722 | use 'hg resolve' to retry unresolved file merges or 'hg merge --abort' to abandon | ||
Siddharth Agarwal
|
r27137 | [1] | ||
$ status | ||||
--- status --- | ||||
M file2 | ||||
M file3 | ||||
C file1 | ||||
--- resolve --list --- | ||||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27137 | U file3 | ||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): 13910f48cf7bdb2a0ba6e24b4900e4fdd5739dd4 | ||
other (merge rev): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file2 (state "u") | ||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Pulkit Goyal
|
r46158 | extra: merge-removal-candidate = yes | ||
Martin von Zweigbergk
|
r44880 | file: file3 (state "u") | ||
local path: file3 (hash d5b0a58bc47161b1b8a831084b366f757c4f0b11, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file3 (node 2661d26c649684b482d10f91960cc3db683c38b4) | ||
other path: file3 (node a2644c43e210356772c7772a8674544a62e06beb) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
Simon Farnsworth
|
r30062 | <<<<<<< working copy: 13910f48cf7b - test: changed file1, removed file2, chan... | ||
Siddharth Agarwal
|
r27137 | changed2 | ||
||||||| base | ||||
======= | ||||
changed1 | ||||
Kostia Balytskyi
|
r30460 | >>>>>>> merge rev: 10f9a0a634e8 - test: removed file1, changed file2, chan... | ||
Siddharth Agarwal
|
r27137 | |||
Exercise transitions between local, other, fail and prompt, and make sure the | ||||
dirstate stays consistent. (Compare with each other and to the above | ||||
invocations.) | ||||
$ testtransitions() { | ||||
> # this traversal order covers every transition | ||||
> tools="local other prompt local fail other local prompt other fail prompt fail local" | ||||
> lasttool="merge3" | ||||
> for tool in $tools; do | ||||
> echo "=== :$lasttool -> :$tool ===" | ||||
> ref="$TESTTMP/$tool.status" | ||||
> hg resolve --unmark --all | ||||
> hg resolve --tool ":$tool" --all --config ui.interactive=True | ||||
> status > "$TESTTMP/compare.status" 2>&1 | ||||
> echo '--- diff of status ---' | ||||
Danek Duvall
|
r27557 | > if cmp "$TESTTMP/$tool.status" "$TESTTMP/compare.status" || diff -U8 "$TESTTMP/$tool.status" "$TESTTMP/compare.status"; then | ||
Siddharth Agarwal
|
r27137 | > echo '(status identical)' | ||
> fi | ||||
> lasttool="$tool" | ||||
> echo | ||||
> done | ||||
> } | ||||
$ testtransitions | ||||
=== :merge3 -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :prompt === | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
file 'file3' needs to be resolved. | ||||
You can keep (l)ocal [working copy], take (o)ther [merge rev], or leave (u)nresolved. | ||||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :prompt === | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
file 'file3' needs to be resolved. | ||||
You can keep (l)ocal [working copy], take (o)ther [merge rev], or leave (u)nresolved. | ||||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :prompt === | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [merge rev] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [merge rev]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
file 'file3' needs to be resolved. | ||||
You can keep (l)ocal [working copy], take (o)ther [merge rev], or leave (u)nresolved. | ||||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
Siddharth Agarwal
|
r26947 | Non-interactive linear update | ||
$ hg co -C 0 | ||||
Siddharth Agarwal
|
r27125 | 3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||
Siddharth Agarwal
|
r26947 | $ echo changed >> file1 | ||
$ hg rm file2 | ||||
$ hg update 1 -y | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [destination] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [destination]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Siddharth Agarwal
|
r27599 | 1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
Siddharth Agarwal
|
r26947 | $ status | ||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
Siddharth Agarwal
|
r27125 | C file3 | ||
Siddharth Agarwal
|
r27126 | --- resolve --list --- | ||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27136 | --- debugmergestate --- | ||
Martin von Zweigbergk
|
r44880 | local (working copy): ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
other (destination): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
file: file2 (state "u") | ||||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Choose local versions of files | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :local | ||||
1 files updated, 2 files merged, 0 files removed, 0 files unresolved | ||||
$ status 2>&1 | tee $TESTTMP/local.status | ||||
--- status --- | ||||
file2: * (glob) | ||||
A file1 | ||||
C file3 | ||||
--- resolve --list --- | ||||
R file1 | ||||
R file2 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
other (destination): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "r") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
file: file2 (state "r") | ||||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
*** file2 does not exist | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Choose other versions of files | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :other | ||||
1 files updated, 1 files merged, 1 files removed, 0 files unresolved | ||||
$ status 2>&1 | tee $TESTTMP/other.status | ||||
--- status --- | ||||
file1: * (glob) | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
R file1 | ||||
R file2 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
other (destination): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "r") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
file: file2 (state "r") | ||||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | *** file1 does not exist | ||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Fail | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :fail | ||||
1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
$ status 2>&1 | tee $TESTTMP/fail.status | ||||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
other (destination): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
file: file2 (state "u") | ||||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r26947 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
Siddharth Agarwal
|
r27125 | --- file3 --- | ||
3 | ||||
changed1 | ||||
Siddharth Agarwal
|
r27137 | |||
Force prompts with no input | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --config ui.interactive=True --tool :prompt | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [destination] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [destination]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | 1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
$ status 2>&1 | tee $TESTTMP/prompt.status | ||||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
U file1 | ||||
U file2 | ||||
--- debugmergestate --- | ||||
Martin von Zweigbergk
|
r44880 | local (working copy): ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
other (destination): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
file: file2 (state "u") | ||||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Danek Duvall
|
r27557 | $ cmp $TESTTMP/fail.status $TESTTMP/prompt.status || diff -U8 $TESTTMP/fail.status $TESTTMP/prompt.status | ||
Siddharth Agarwal
|
r27137 | |||
Choose to merge all files | ||||
$ hg co -C 0 | ||||
3 files updated, 0 files merged, 0 files removed, 0 files unresolved | ||||
$ echo changed >> file1 | ||||
$ hg rm file2 | ||||
$ hg update 1 --tool :merge3 | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [destination] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [destination]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? u | ||||
Siddharth Agarwal
|
r27599 | 1 files updated, 0 files merged, 0 files removed, 2 files unresolved | ||
use 'hg resolve' to retry unresolved file merges | ||||
[1] | ||||
Siddharth Agarwal
|
r27137 | $ status | ||
--- status --- | ||||
A file1 | ||||
C file2 | ||||
C file3 | ||||
--- resolve --list --- | ||||
Siddharth Agarwal
|
r27599 | U file1 | ||
U file2 | ||||
Siddharth Agarwal
|
r27137 | --- debugmergestate --- | ||
Martin von Zweigbergk
|
r44880 | local (working copy): ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
other (destination): 10f9a0a634e82080907e62f075ab119cbc565ea6 | ||||
file: file1 (state "u") | ||||
local path: file1 (hash 60b27f004e454aca81b0480209cce5081ec52390, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file1 (node b8e02f6433738021a065f94175c7cd23db5f05be) | ||
Martin von Zweigbergk
|
r44880 | other path: file1 (node 0000000000000000000000000000000000000000) | ||
extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||||
file: file2 (state "u") | ||||
local path: file2 (hash 0000000000000000000000000000000000000000, flags "") | ||||
Siddharth Agarwal
|
r27137 | ancestor path: file2 (node 5d9299349fc01ddd25d0070d149b124d8f10411e) | ||
other path: file2 (node e7c1328648519852e723de86c0c0525acd779257) | ||||
Martin von Zweigbergk
|
r44880 | extra: ancestorlinknode = ab57bf49aa276a22d35a473592d4c34b5abc3eff | ||
Siddharth Agarwal
|
r27137 | --- file1 --- | ||
1 | ||||
changed | ||||
--- file2 --- | ||||
2 | ||||
changed | ||||
--- file3 --- | ||||
3 | ||||
changed1 | ||||
Test transitions between different merge tools | ||||
$ testtransitions | ||||
=== :merge3 -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :prompt === | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [destination] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [destination]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :local -> :prompt === | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [destination] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [destination]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :other === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :other -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :prompt === | ||||
Pulkit Goyal
|
r39321 | file 'file1' was deleted in other [destination] but was modified in local [working copy]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, (d)elete, or leave (u)nresolved. | ||
What do you want to do? | ||||
Pulkit Goyal
|
r39321 | file 'file2' was deleted in local [working copy] but was modified in other [destination]. | ||
Kyle Lippincott
|
r42765 | You can use (c)hanged version, leave (d)eleted, or leave (u)nresolved. | ||
What do you want to do? | ||||
Siddharth Agarwal
|
r27137 | --- diff of status --- | ||
(status identical) | ||||
=== :prompt -> :fail === | ||||
--- diff of status --- | ||||
(status identical) | ||||
=== :fail -> :local === | ||||
(no more unresolved files) | ||||
--- diff of status --- | ||||
(status identical) | ||||