summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJonathan Nieder <jrn@google.com>2020-10-28 11:27:41 -0700
committerJonathan Nieder <jrn@google.com>2020-11-03 20:27:19 +0000
commit6248e0fd1dcc5e0f76cb38056aa68af55fee5f3f (patch)
treefe84aa0b4f27c9ae05e66a9e3e2eb980d6afdf62
parent50a81de2bc9f2074d56c368f651cf9f50c8d8a87 (diff)
downloadgit-repo-6248e0fd1dcc5e0f76cb38056aa68af55fee5f3f.tar.gz
launcher: simplify .repo search ceiling check
In the .repo discovery loop while curdir != '/' and curdir != olddir: ... break if we found .repo ... olddir = curdir curdir = os.path.dirname(curdir) the "while" condition is meant to avoid searching forever if we do not find .repo before reaching the top-level directory of the filesystem. For that purpose, the first half of the condition is redundant; once we reach "/", the parent directory will be "/" again and the curdir != olddir check would suffice to terminate the search. Simplify by removing the redundant first half of the check. Noticed by code inspection. The first half of the check was retained when introducing the second half in df14a70c ("Make path references OS independent", 2011-01-09), in an excess of caution. This also improves consistency a little: if I start with curdir = '/home/me', then with the redundant check in place we search /home/me /home before hitting / and giving up. On Windows, if I start with 'c:/users/me', then we search c:/users/me c:/users c:/ before hitting a repetition and giving up. Fortunately it is not common for people to set up repo clients at the top level of filesystems, but consistently following the latter behavior should make debugging a little easier in case it comes up. Link: https://gerrit-review.googlesource.com/id/Ib9e830e3b9adfb1c4e56f3bcfba4746c401fb84f Reviewed-on: https://gerrit-review.googlesource.com/c/git-repo/+/286002 Reviewed-by: Mike Frysinger <vapier@google.com> Tested-by: Jonathan Nieder <jrn@google.com>
-rwxr-xr-xrepo4
1 files changed, 1 insertions, 3 deletions
diff --git a/repo b/repo
index cf1f78b4..b13e34c6 100755
--- a/repo
+++ b/repo
@@ -966,9 +966,7 @@ def _FindRepo():
966 repo = None 966 repo = None
967 967
968 olddir = None 968 olddir = None
969 while curdir != '/' \ 969 while curdir != olddir and not repo:
970 and curdir != olddir \
971 and not repo:
972 repo = os.path.join(curdir, repodir, REPO_MAIN) 970 repo = os.path.join(curdir, repodir, REPO_MAIN)
973 if not os.path.isfile(repo): 971 if not os.path.isfile(repo):
974 repo = None 972 repo = None