##// END OF EJS Templates
inotify: server: new data structure to keep track of changes....
inotify: server: new data structure to keep track of changes. == Rationale for the new structure == Current structure was a dictionary tree. One directory was tracked as a dictionary: - keys: file/subdir name - values: - for a file, the status (a/r/m/...) - for a subdir, the directory representing the subdir It allowed efficient lookups, no matter of the type of the terminal leaf: for part in path.split('/'): tree = tree[part] However, there is no way to represent a directory and a file with the same name because keys are conflicting in the dictionary. Concrete example: Initial state: root dir |- foo (file) |- bar (file) # data state is: {'foo': 'n', 'bar': 'n'} Remove foo: root dir |- bar (file) # Data becomes {'foo': 'r'} until next commit. Add foo, as a directory, and foo/barbar file: root dir |- bar (file) |-> foo (dir) |- barbar (file) # New state should be represented as: {'foo': {'barbar': 'a'}, 'bar': 'n'} however, the key "foo" is already used and represents the old file. The dirstate: D foo A foo/barbar cannot be represented, hence the need for a new structure. == The new structure == 'directory' class. Represents one directory level. * Notable attributes: Two dictionaries: - 'files' Maps filename -> status for the current dir. - 'dirs' Maps subdir's name -> directory object representing the subdir * methods - walk(), formerly server.walk - lookup(), old server.lookup - dir(), old server.dir This new class allows embedding all the tree walks/lookups in its own class, instead of having everything mixed together in server. Incidently, since files and directories are not stored in the same dictionaries, we are solving the previous key conflict problem. The small drawback is that lookup operation is a bit more complex: for a path a/b/c/d/e we have to check twice the leaf, if e is a directory or a file.

File last commit:

r8167:6c82beaa default
r9115:b55d4471 default
Show More
test-git-export
158 lines | 2.8 KiB | text/plain | TextLexer
Brendan Cully
Add diff --git option
r2907 #!/bin/sh
hg init a
cd a
echo start > start
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -Amstart
Brendan Cully
Add diff --git option
r2907 echo new > new
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -Amnew
Brendan Cully
Add diff --git option
r2907 echo '% new file'
Stephen Darnell
Add -D/--nodates options to hg diff/export that removes dates from diff headers...
r3199 hg diff --git -r 0
Brendan Cully
Add diff --git option
r2907
hg cp new copy
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -mcopy
Brendan Cully
Add diff --git option
r2907 echo '% copy'
Stephen Darnell
Add -D/--nodates options to hg diff/export that removes dates from diff headers...
r3199 hg diff --git -r 1:tip
Brendan Cully
Add diff --git option
r2907
hg mv copy rename
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -mrename
Brendan Cully
Add diff --git option
r2907 echo '% rename'
Stephen Darnell
Add -D/--nodates options to hg diff/export that removes dates from diff headers...
r3199 hg diff --git -r 2:tip
Brendan Cully
Add diff --git option
r2907
hg rm rename
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -mdelete
Brendan Cully
Add diff --git option
r2907 echo '% delete'
Stephen Darnell
Add -D/--nodates options to hg diff/export that removes dates from diff headers...
r3199 hg diff --git -r 3:tip
Brendan Cully
Add diff --git option
r2907
cat > src <<EOF
1
2
3
4
5
EOF
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -Amsrc
Brendan Cully
Add diff --git option
r2907 chmod +x src
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -munexec
Brendan Cully
Add diff --git option
r2907 echo '% chmod 644'
Stephen Darnell
Add -D/--nodates options to hg diff/export that removes dates from diff headers...
r3199 hg diff --git -r 5:tip
Brendan Cully
Add diff --git option
r2907
hg mv src dst
chmod -x dst
echo a >> dst
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -mrenamemod
Brendan Cully
Add diff --git option
r2907 echo '% rename+mod+chmod'
Stephen Darnell
Add -D/--nodates options to hg diff/export that removes dates from diff headers...
r3199 hg diff --git -r 6:tip
Benoit Boissinot
git --diff: fix traceback when getting mode change...
r3066
echo '% nonexistent in tip+chmod'
Stephen Darnell
Add -D/--nodates options to hg diff/export that removes dates from diff headers...
r3199 hg diff --git -r 5:6
Brendan Cully
Add test for git binary diff support
r3368
echo '% binary diff'
cp $TESTDIR/binfile.bin .
hg add binfile.bin
hg diff --git > b.diff
cat b.diff
echo '% import binary diff'
hg revert binfile.bin
rm binfile.bin
hg import -mfoo b.diff
cmp binfile.bin $TESTDIR/binfile.bin
Alexis S. L. Carvalho
diff: improve detection of renames when diffing across many revisions
r3693 echo
Alexis S. L. Carvalho
git patches: handle renames of binary files
r4092 echo '% rename binary file'
hg mv binfile.bin renamed.bin
hg diff --git
echo
Alexis S. L. Carvalho
diff: improve detection of renames when diffing across many revisions
r3693 echo '% diff across many revisions'
hg mv dst dst2
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -m 'mv dst dst2'
Alexis S. L. Carvalho
diff: improve detection of renames when diffing across many revisions
r3693
echo >> start
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -m 'change start'
Alexis S. L. Carvalho
diff: improve detection of renames when diffing across many revisions
r3693
hg revert -r -2 start
hg mv dst2 dst3
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -m 'mv dst2 dst3; revert start'
Alexis S. L. Carvalho
diff: improve detection of renames when diffing across many revisions
r3693
hg diff --git -r 9:11
Alexis S. L. Carvalho
Make hg diff --git -r revA:revB detect (inverted) copies if revA > revB
r5264 echo '% reversed'
hg diff --git -r 11:9
Alexis S. L. Carvalho
renamedbetween: only return (file, node) pairs that exist in the original rev
r3694
echo a >> foo
hg add foo
hg ci -m 'add foo'
echo b >> foo
hg ci -m 'change foo'
hg mv foo bar
hg ci -m 'mv foo bar'
echo c >> bar
hg ci -m 'change bar'
echo
echo '% file created before r1 and renamed before r2'
hg diff --git -r -3:-1
Alexis S. L. Carvalho
Make hg diff --git -r revA:revB detect (inverted) copies if revA > revB
r5264 echo '% reversed'
hg diff --git -r -1:-3
Alexis S. L. Carvalho
renamedbetween: only return (file, node) pairs that exist in the original rev
r3694 echo
echo '% file created in r1 and renamed before r2'
hg diff --git -r -4:-1
Alexis S. L. Carvalho
Make hg diff --git -r revA:revB detect (inverted) copies if revA > revB
r5264 echo '% reversed'
hg diff --git -r -1:-4
Alexis S. L. Carvalho
renamedbetween: only return (file, node) pairs that exist in the original rev
r3694 echo
echo '% file created after r1 and renamed before r2'
hg diff --git -r -5:-1
Alexis S. L. Carvalho
Make hg diff --git -r revA:revB detect (inverted) copies if revA > revB
r5264 echo '% reversed'
hg diff --git -r -1:-5
Alexis S. L. Carvalho
renamedbetween: only return (file, node) pairs that exist in the original rev
r3694
Alexis S. L. Carvalho
fix typo in mercurial/patch.py
r3695 echo
echo '% comparing with the working dir'
echo >> start
Martin Geisler
tests: removed redundant "-d '0 0'" from test scripts...
r8167 hg ci -m 'change start again'
Alexis S. L. Carvalho
fix typo in mercurial/patch.py
r3695
echo > created
hg add created
hg ci -m 'add created'
hg mv created created2
hg ci -m 'mv created created2'
hg mv created2 created3
echo "% there's a copy in the working dir..."
hg diff --git
echo
echo "% ...but there's another copy between the original rev and the wd"
hg diff --git -r -2
Alexis S. L. Carvalho
diff: better detection of renames when comparing with the working dir.
r3696 echo
echo "% ...but the source of the copy was created after the original rev"
hg diff --git -r -3
hg ci -m 'mv created2 created3'
echo > brand-new
hg add brand-new
hg ci -m 'add brand-new'
hg mv brand-new brand-new2
echo '% created in parent of wd; renamed in the wd'
hg diff --git
echo
echo '% created between r1 and parent of wd; renamed in the wd'
hg diff --git -r -2
Alexis S. L. Carvalho
Don't generate git patches that rename a file to multiple destinations...
r3702 hg ci -m 'mv brand-new brand-new2'
echo '% one file is copied to many destinations and removed'
hg cp brand-new2 brand-new3
hg mv brand-new2 brand-new3-2
hg ci -m 'multiple renames/copies'
hg diff --git -r -2 -r -1
Alexis S. L. Carvalho
Make hg diff --git -r revA:revB detect (inverted) copies if revA > revB
r5264 echo '% reversed'
hg diff --git -r -1 -r -2
Alexis S. L. Carvalho
Don't generate git patches that rename a file to multiple destinations...
r3702
Alexis S. L. Carvalho
git patches: correct handling of filenames with spaces...
r4679 echo '% there should be a trailing TAB if there are spaces in the file name'
echo foo > 'with spaces'
hg add 'with spaces'
hg diff --git
hg ci -m 'add filename with spaces'