Mercurial > hg
diff rust/hg-core/src/dirstate_tree/on_disk.rs @ 48250:1730b2fceaa1
dirstate-v2: adds a flag to mark a file as modified
Right now, a files with a file system state that requires a lookup (same size,
different mtime) will requires a lookup. If the result of that lookup is a
modified files, it will remains ambiguous, requiring a lookup on the next status
run too.
To fix this, we introduce a dedicated flag in the new format. Such flag will
allow to record such file as "known modified" avoiding an extra lookup later.
As None of the associate code currently exist in the status code, we do the
minimal implementation: if we read a dirstate entry with this flag set, we make
it as "ambiguous" so that the next status code has to look it up. The same as it
would have to without this flag existing anyway.
Differential Revision: https://phab.mercurial-scm.org/D11681
author | Simon Sapin <simon.sapin@octobus.net> |
---|---|
date | Fri, 15 Oct 2021 16:12:00 +0200 |
parents | f7fd629ffb98 |
children | dfc5a505ddc5 |
line wrap: on
line diff
--- a/rust/hg-core/src/dirstate_tree/on_disk.rs Tue Oct 19 10:52:13 2021 +0100 +++ b/rust/hg-core/src/dirstate_tree/on_disk.rs Fri Oct 15 16:12:00 2021 +0200 @@ -110,6 +110,7 @@ const HAS_DIRECTORY_MTIME = 1 << 5; const MODE_EXEC_PERM = 1 << 6; const MODE_IS_SYMLINK = 1 << 7; + const EXPECTED_STATE_IS_MODIFIED = 1 << 8; } } @@ -351,12 +352,16 @@ let wdir_tracked = self.flags().contains(Flags::WDIR_TRACKED); let p1_tracked = self.flags().contains(Flags::P1_TRACKED); let p2_info = self.flags().contains(Flags::P2_INFO); - let mode_size = if self.flags().contains(Flags::HAS_MODE_AND_SIZE) { + let mode_size = if self.flags().contains(Flags::HAS_MODE_AND_SIZE) + && !self.flags().contains(Flags::EXPECTED_STATE_IS_MODIFIED) + { Some((self.synthesize_unix_mode(), self.size.into())) } else { None }; - let mtime = if self.flags().contains(Flags::HAS_FILE_MTIME) { + let mtime = if self.flags().contains(Flags::HAS_FILE_MTIME) + && !self.flags().contains(Flags::EXPECTED_STATE_IS_MODIFIED) + { Some(self.mtime.truncated_seconds.into()) } else { None