|
|
#!/bin/sh
|
|
|
|
|
|
hg init
|
|
|
mkdir d1 d1/d11 d2
|
|
|
echo d1/a > d1/a
|
|
|
echo d1/ba > d1/ba
|
|
|
echo d1/a1 > d1/d11/a1
|
|
|
echo d1/b > d1/b
|
|
|
echo d2/b > d2/b
|
|
|
hg add d1/a d1/b d1/ba d1/d11/a1 d2/b
|
|
|
hg commit -m "1" -d "1000000 0"
|
|
|
|
|
|
echo "# rename a single file"
|
|
|
hg rename d1/d11/a1 d2/c
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d2/c
|
|
|
|
|
|
echo "# rename --after a single file"
|
|
|
mv d1/d11/a1 d2/c
|
|
|
hg rename --after d1/d11/a1 d2/c
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d2/c
|
|
|
|
|
|
echo "# rename --after a single file to a nonexistant target filename"
|
|
|
hg rename --after d1/a dummy
|
|
|
|
|
|
echo "# move a single file to an existing directory"
|
|
|
hg rename d1/d11/a1 d2
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d2/a1
|
|
|
|
|
|
echo "# move --after a single file to an existing directory"
|
|
|
mv d1/d11/a1 d2
|
|
|
hg rename --after d1/d11/a1 d2
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d2/a1
|
|
|
|
|
|
echo "# rename a file using a relative path"
|
|
|
(cd d1/d11; hg rename ../../d2/b e)
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d1/d11/e
|
|
|
|
|
|
echo "# rename --after a file using a relative path"
|
|
|
(cd d1/d11; mv ../../d2/b e; hg rename --after ../../d2/b e)
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d1/d11/e
|
|
|
|
|
|
echo "# rename directory d1 as d3"
|
|
|
hg rename d1/ d3
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# rename --after directory d1 as d3"
|
|
|
mv d1 d3
|
|
|
hg rename --after d1 d3
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# move a directory using a relative path"
|
|
|
(cd d2; mkdir d3; hg rename ../d1/d11 d3)
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d2/d3
|
|
|
|
|
|
echo "# move --after a directory using a relative path"
|
|
|
(cd d2; mkdir d3; mv ../d1/d11 d3; hg rename --after ../d1/d11 d3)
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d2/d3
|
|
|
|
|
|
echo "# move directory d1/d11 to an existing directory d2 (removes empty d1)"
|
|
|
hg rename d1/d11/ d2
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d2/d11
|
|
|
|
|
|
echo "# move directories d1 and d2 to a new directory d3"
|
|
|
mkdir d3
|
|
|
hg rename d1 d2 d3
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# move --after directories d1 and d2 to a new directory d3"
|
|
|
mkdir d3
|
|
|
mv d1 d2 d3
|
|
|
hg rename --after d1 d2 d3
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# move everything under directory d1 to existing directory d2, do not"
|
|
|
echo "# overwrite existing files (d2/b)"
|
|
|
hg rename d1/* d2
|
|
|
hg status -C
|
|
|
diff d1/b d2/b
|
|
|
hg update -C
|
|
|
rm d2/a d2/ba d2/d11/a1
|
|
|
|
|
|
echo "# attempt to move one file into a non-existent directory"
|
|
|
hg rename d1/a dx/
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
|
|
|
echo "# attempt to move potentially more than one file into a non-existent"
|
|
|
echo "# directory"
|
|
|
hg rename 'glob:d1/**' dx
|
|
|
|
|
|
echo "# move every file under d1 to d2/d21 (glob)"
|
|
|
mkdir d2/d21
|
|
|
hg rename 'glob:d1/**' d2/d21
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d2/d21
|
|
|
|
|
|
echo "# move --after some files under d1 to d2/d21 (glob)"
|
|
|
mkdir d2/d21
|
|
|
mv d1/a d1/d11/a1 d2/d21
|
|
|
hg rename --after 'glob:d1/**' d2/d21
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d2/d21
|
|
|
|
|
|
echo "# move every file under d1 starting with an 'a' to d2/d21 (regexp)"
|
|
|
mkdir d2/d21
|
|
|
hg rename 're:d1/([^a][^/]*/)*a.*' d2/d21
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d2/d21
|
|
|
|
|
|
echo "# attempt to overwrite an existing file"
|
|
|
echo "ca" > d1/ca
|
|
|
hg rename d1/ba d1/ca
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
|
|
|
echo "# forced overwrite of an existing file"
|
|
|
echo "ca" > d1/ca
|
|
|
hg rename --force d1/ba d1/ca
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d1/ca
|
|
|
|
|
|
echo "# replace a symlink with a file"
|
|
|
ln -s ba d1/ca
|
|
|
hg rename --force d1/ba d1/ca
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d1/ca
|
|
|
|
|
|
echo "# do not copy more than one source file to the same destination file"
|
|
|
mkdir d3
|
|
|
hg rename d1/* d2/* d3
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# move a whole subtree with \"hg rename .\""
|
|
|
mkdir d3
|
|
|
(cd d1; hg rename . ../d3)
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# move a whole subtree with \"hg rename --after .\""
|
|
|
mkdir d3
|
|
|
mv d1/* d3
|
|
|
(cd d1; hg rename --after . ../d3)
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# move the parent tree with \"hg rename ..\""
|
|
|
(cd d1/d11; hg rename .. ../../d3)
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# skip removed files"
|
|
|
hg remove d1/b
|
|
|
hg rename d1 d3
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm -rf d3
|
|
|
|
|
|
echo "# transitive rename"
|
|
|
hg rename d1/b d1/bb
|
|
|
hg rename d1/bb d1/bc
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d1/bc
|
|
|
|
|
|
echo "# transitive rename --after"
|
|
|
hg rename d1/b d1/bb
|
|
|
mv d1/bb d1/bc
|
|
|
hg rename --after d1/bb d1/bc
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm d1/bc
|
|
|
|
|
|
echo "# idempotent renames (d1/b -> d1/bb followed by d1/bb -> d1/b)"
|
|
|
hg rename d1/b d1/bb
|
|
|
echo "some stuff added to d1/bb" >> d1/bb
|
|
|
hg rename d1/bb d1/b
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
|
|
|
echo '# overwriting with renames (issue1959)'
|
|
|
hg rename d1/a d1/c
|
|
|
hg rename d1/b d1/a
|
|
|
hg status -C
|
|
|
hg diff --git
|
|
|
hg update -C
|
|
|
|
|
|
echo "# check illegal path components"
|
|
|
|
|
|
hg rename d1/d11/a1 .hg/foo
|
|
|
hg status -C
|
|
|
hg rename d1/d11/a1 ../foo
|
|
|
hg status -C
|
|
|
|
|
|
mv d1/d11/a1 .hg/foo
|
|
|
hg rename --after d1/d11/a1 .hg/foo
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm .hg/foo
|
|
|
|
|
|
hg rename d1/d11/a1 .hg
|
|
|
hg status -C
|
|
|
hg rename d1/d11/a1 ..
|
|
|
hg status -C
|
|
|
|
|
|
mv d1/d11/a1 .hg
|
|
|
hg rename --after d1/d11/a1 .hg
|
|
|
hg status -C
|
|
|
hg update -C
|
|
|
rm .hg/a1
|
|
|
|
|
|
(cd d1/d11; hg rename ../../d2/b ../../.hg/foo)
|
|
|
hg status -C
|
|
|
(cd d1/d11; hg rename ../../d2/b ../../../foo)
|
|
|
hg status -C
|
|
|
|
|
|
|