##// 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:

r8518:3f4f14ea default
r9115:b55d4471 default
Show More
test-revert.out
87 lines | 1.8 KiB | text/plain | TextLexer
Benoit Boissinot
fix handling of files of unsupported type in the walk code...
r1487 %% should show b unknown
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 ? b
Benoit Boissinot
fix handling of files of unsupported type in the walk code...
r1487 %% should show b unknown and c modified
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 M c
? b
Benoit Boissinot
fix handling of files of unsupported type in the walk code...
r1487 %% should show b added and c modified
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 M c
A b
Benoit Boissinot
fix handling of files of unsupported type in the walk code...
r1487 %% should show a removed, b added and c modified
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 M c
A b
R a
Vadim Gelfer
rewrite revert command. fix issues 93, 123, 147....
r2029 %% should show b added, copy saved, and c modified
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 M c
A b
Thomas Arendsen Hein
Minor fix for revert: No need to make a backup when forgetting added files....
r2043 %% should show b unknown, and c modified
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 M c
? b
Thomas Arendsen Hein
Minor fix for revert: No need to make a backup when forgetting added files....
r2043 %% should show unknown: b
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 ? b
Alexis S. L. Carvalho
revert: unify forget and remove lists...
r6109 %% should show b added
A b
Alexis S. L. Carvalho
status: put added files that have disappeared in the deleted list...
r6110 %% should show b deleted
! b
Alexis S. L. Carvalho
revert: unify forget and remove lists...
r6109 forgetting b
%% should not find b
b: No such file or directory
%% should show a c e
Benoit Boissinot
revert added and removed files to their normal state before reverting...
r1447 a
c
Vadim Gelfer
rewrite revert command. fix issues 93, 123, 147....
r2029 e
Thomas Arendsen Hein
Don't abort when backup files already exist. Don't allow alternative names....
r2036 %% should verbosely save backup to e.orig
saving current version of e as e.orig
Vadim Gelfer
rewrite revert command. fix issues 93, 123, 147....
r2029 reverting e
%% should say no changes needed
no changes needed to a
%% should say file not managed
file not managed: q
%% should say file not found
Matt Mackall
walk: remove more old badmatch logic
r6583 notfound: No such file in rev 095eacd0c0d7
Vadim Gelfer
small changes to revert command....
r2042 A z
? e.orig
Alexis S. L. Carvalho
revert: don't assume ignored files will be returned in the unknown list...
r6031 %% should add a, remove d, forget z
Vadim Gelfer
small changes to revert command....
r2042 adding a
Alexis S. L. Carvalho
revert: don't assume ignored files will be returned in the unknown list...
r6031 removing d
Vadim Gelfer
small changes to revert command....
r2042 forgetting z
Alexis S. L. Carvalho
revert: don't assume ignored files will be returned in the unknown list...
r6031 %% should forget a, undelete d
Vadim Gelfer
small changes to revert command....
r2042 forgetting a
Alexis S. L. Carvalho
revert: don't assume ignored files will be returned in the unknown list...
r6031 undeleting d
Vadim Gelfer
small changes to revert command....
r2042 %% should silently add a
A a
Alexis S. L. Carvalho
revert: don't assume ignored files will be returned in the unknown list...
r6031 R d
%% should silently keep d removed
R d
Benoit Boissinot
update --clean: do not unlink added files (issue575)
r8518 1 files updated, 0 files merged, 0 files removed, 0 files unresolved
Vadim Gelfer
make test-revert check executable bit.
r2157 reverting c
%% should print non-executable
non-executable
reverting c
%% should print executable
executable
Vadim Gelfer
revert: fix corner case found by faheem mitha....
r2272 %% issue 241
adding a
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
Vadim Gelfer
revert: require --all to revert all files.
r2982 % should fail - no arguments
Benoit Boissinot
Add a hint for revert --all when aborting
r3020 abort: no files or directories specified; use --all to revert the whole repo
Vadim Gelfer
revert: require --all to revert all files.
r2982 % should succeed
Vadim Gelfer
revert: better fix for not printing 'reverting' message
r2407 reverting a
Benoit Boissinot
fix incorrect warning when walking on a particular rev...
r3019 %% issue332
adding b/b
Dirkjan Ochtman
warn about new heads on commit (issue842)
r6336 created new head
Benoit Boissinot
fix incorrect warning when walking on a particular rev...
r3019 reverting b/b
Alexis S. L. Carvalho
Fix confusing message from hg revert (issue332)...
r4225 forgetting newdir/newfile
Alexis S. L. Carvalho
util._matcher: use "." as the root of empty {rel,}path patterns...
r4233 reverting b/b
Brendan Cully
When reverting a file which was renamed, also revert the old name
r5230 % reverting a rename target should revert the source
? newa
Alexis S. L. Carvalho
revert: don't assume ignored files will be returned in the unknown list...
r6031 %% 4 ignored files (we will add/commit everything)
I ignored
Alexis S. L. Carvalho
dirstate.status: avoid putting ignored files in the unknown list...
r6033 I ignoreddir/file
I ignoreddir/removed
Alexis S. L. Carvalho
revert: don't assume ignored files will be returned in the unknown list...
r6031 I removed
%% should revert ignored* and undelete *removed
reverting ignored
reverting ignoreddir/file
undeleting ignoreddir/removed
undeleting removed
%% should silently revert the named files