Show More
@@ -450,14 +450,6 static PyObject *dirstate_item_from_v2_m | |||
|
450 | 450 | dirstate_flag_has_meaningful_data | |
|
451 | 451 | dirstate_flag_has_mtime); |
|
452 | 452 | } |
|
453 | if (t->flags & dirstate_flag_mtime_second_ambiguous) { | |
|
454 | /* The current code is not able to do the more subtle comparison | |
|
455 | * that the MTIME_SECOND_AMBIGUOUS requires. So we ignore the | |
|
456 | * mtime */ | |
|
457 | t->flags &= ~(dirstate_flag_mtime_second_ambiguous | | |
|
458 | dirstate_flag_has_meaningful_data | | |
|
459 | dirstate_flag_has_mtime); | |
|
460 | } | |
|
461 | 453 | t->mode = 0; |
|
462 | 454 | if (t->flags & dirstate_flag_has_meaningful_data) { |
|
463 | 455 | if (t->flags & dirstate_flag_mode_exec_perm) { |
@@ -149,10 +149,6 class DirstateItem(object): | |||
|
149 | 149 | """Build a new DirstateItem object from V2 data""" |
|
150 | 150 | has_mode_size = bool(flags & DIRSTATE_V2_HAS_MODE_AND_SIZE) |
|
151 | 151 | has_meaningful_mtime = bool(flags & DIRSTATE_V2_HAS_MTIME) |
|
152 | if flags & DIRSTATE_V2_MTIME_SECOND_AMBIGUOUS: | |
|
153 | # The current code is not able to do the more subtle comparison that the | |
|
154 | # MTIME_SECOND_AMBIGUOUS requires. So we ignore the mtime | |
|
155 | has_meaningful_mtime = False | |
|
156 | 152 | mode = None |
|
157 | 153 | |
|
158 | 154 | if flags & +DIRSTATE_V2_EXPECTED_STATE_IS_MODIFIED: |
@@ -179,13 +175,15 class DirstateItem(object): | |||
|
179 | 175 | mode |= stat.S_IFLNK |
|
180 | 176 | else: |
|
181 | 177 | mode |= stat.S_IFREG |
|
178 | ||
|
179 | second_ambiguous = flags & DIRSTATE_V2_MTIME_SECOND_AMBIGUOUS | |
|
182 | 180 | return cls( |
|
183 | 181 | wc_tracked=bool(flags & DIRSTATE_V2_WDIR_TRACKED), |
|
184 | 182 | p1_tracked=bool(flags & DIRSTATE_V2_P1_TRACKED), |
|
185 | 183 | p2_info=bool(flags & DIRSTATE_V2_P2_INFO), |
|
186 | 184 | has_meaningful_data=has_mode_size, |
|
187 | 185 | has_meaningful_mtime=has_meaningful_mtime, |
|
188 |
parentfiledata=(mode, size, (mtime_s, mtime_ns, |
|
|
186 | parentfiledata=(mode, size, (mtime_s, mtime_ns, second_ambiguous)), | |
|
189 | 187 | fallback_exec=fallback_exec, |
|
190 | 188 | fallback_symlink=fallback_symlink, |
|
191 | 189 | ) |
@@ -371,11 +371,12 impl Node { | |||
|
371 | 371 | let mtime = if self.flags().contains(Flags::HAS_MTIME) |
|
372 | 372 | && !self.flags().contains(Flags::DIRECTORY) |
|
373 | 373 | && !self.flags().contains(Flags::EXPECTED_STATE_IS_MODIFIED) |
|
374 | // The current code is not able to do the more subtle comparison that the | |
|
375 | // MTIME_SECOND_AMBIGUOUS requires. So we ignore the mtime | |
|
376 | && !self.flags().contains(Flags::MTIME_SECOND_AMBIGUOUS) | |
|
377 | 374 | { |
|
378 |
|
|
|
375 | let mut m: TruncatedTimestamp = self.mtime.try_into()?; | |
|
376 | if self.flags().contains(Flags::MTIME_SECOND_AMBIGUOUS) { | |
|
377 | m.second_ambiguous = true; | |
|
378 | } | |
|
379 | Some(m) | |
|
379 | 380 | } else { |
|
380 | 381 | None |
|
381 | 382 | }; |
General Comments 0
You need to be logged in to leave comments.
Login now