Show More
@@ -691,17 +691,22 b' def _makematcher(repo, revs, pats, opts)' | |||||
691 | slowpath = match.anypats() or (not match.always() and opts.get(b'removed')) |
|
691 | slowpath = match.anypats() or (not match.always() and opts.get(b'removed')) | |
692 | if not slowpath: |
|
692 | if not slowpath: | |
693 | follow = opts.get(b'follow') or opts.get(b'follow_first') |
|
693 | follow = opts.get(b'follow') or opts.get(b'follow_first') | |
694 | startctxs = [] |
|
|||
695 | if follow and opts.get(b'rev'): |
|
694 | if follow and opts.get(b'rev'): | |
696 | startctxs = [repo[r] for r in revs] |
|
695 | startctxs = [repo[r] for r in revs] | |
697 | for f in match.files(): |
|
696 | for f in match.files(): | |
698 | if follow and startctxs: |
|
|||
699 | # No idea if the path was a directory at that revision, so |
|
697 | # No idea if the path was a directory at that revision, so | |
700 | # take the slow path. |
|
698 | # take the slow path. | |
701 | if any(f not in c for c in startctxs): |
|
699 | if any(f not in c for c in startctxs): | |
702 | slowpath = True |
|
700 | slowpath = True | |
703 | continue |
|
701 | continue | |
704 | elif follow and f not in wctx: |
|
702 | filelog = repo.file(f) | |
|
703 | if not filelog: | |||
|
704 | raise error.Abort( | |||
|
705 | _(b'cannot follow nonexistent file: "%s"') % f | |||
|
706 | ) | |||
|
707 | elif follow: | |||
|
708 | for f in match.files(): | |||
|
709 | if f not in wctx: | |||
705 | # If the file exists, it may be a directory, so let it |
|
710 | # If the file exists, it may be a directory, so let it | |
706 | # take the slow path. |
|
711 | # take the slow path. | |
707 | if os.path.exists(repo.wjoin(f)): |
|
712 | if os.path.exists(repo.wjoin(f)): | |
@@ -717,12 +722,15 b' def _makematcher(repo, revs, pats, opts)' | |||||
717 | ) |
|
722 | ) | |
718 | filelog = repo.file(f) |
|
723 | filelog = repo.file(f) | |
719 | if not filelog: |
|
724 | if not filelog: | |
720 | # A zero count may be a directory or deleted file, so |
|
|||
721 | # try to find matching entries on the slow path. |
|
|||
722 | if follow: |
|
|||
723 | raise error.Abort( |
|
725 | raise error.Abort( | |
724 | _(b'cannot follow nonexistent file: "%s"') % f |
|
726 | _(b'cannot follow nonexistent file: "%s"') % f | |
725 | ) |
|
727 | ) | |
|
728 | else: | |||
|
729 | for f in match.files(): | |||
|
730 | filelog = repo.file(f) | |||
|
731 | if not filelog: | |||
|
732 | # A zero count may be a directory or deleted file, so | |||
|
733 | # try to find matching entries on the slow path. | |||
726 | slowpath = True |
|
734 | slowpath = True | |
727 |
|
735 | |||
728 | # We decided to fall back to the slowpath because at least one |
|
736 | # We decided to fall back to the slowpath because at least one |
@@ -2308,6 +2308,20 b' follow files from wdir' | |||||
2308 | $ hg log -T '== {rev} ==\n' -fr'wdir()' --git --stat notfound |
|
2308 | $ hg log -T '== {rev} ==\n' -fr'wdir()' --git --stat notfound | |
2309 | notfound: $ENOENT$ |
|
2309 | notfound: $ENOENT$ | |
2310 |
|
2310 | |||
|
2311 | follow added/removed files from wdir parent | |||
|
2312 | ||||
|
2313 | $ hg log -T '{rev}\n' -f d1/f2 | |||
|
2314 | abort: cannot follow nonexistent file: "d1/f2" | |||
|
2315 | [255] | |||
|
2316 | ||||
|
2317 | $ hg log -T '{rev}\n' -f f1-copy | |||
|
2318 | abort: cannot follow nonexistent file: "f1-copy" | |||
|
2319 | [255] | |||
|
2320 | ||||
|
2321 | $ hg log -T '{rev}\n' -f .d6/f1 | |||
|
2322 | abort: cannot follow file not in parent revision: ".d6/f1" | |||
|
2323 | [255] | |||
|
2324 | ||||
2311 | $ hg revert -aqC |
|
2325 | $ hg revert -aqC | |
2312 |
|
2326 | |||
2313 | Check that adding an arbitrary name shows up in log automatically |
|
2327 | Check that adding an arbitrary name shows up in log automatically |
General Comments 0
You need to be logged in to leave comments.
Login now