Fix _ReferenceGitDir symlinking

This fixes these errors:

  ...
  File ".repo/repo/project.py", line 2371, in _ReferenceGitDir
    os.symlink(os.path.relpath(src, os.path.dirname(dst)), dst)
  OSError: [Errno 17] File exists

Which was happening for checkouts that were created before v1.12.8, when
project-objects was created. Nothing had yet been forcing these
checkouts to use project-objects, until the recent verification changes.

In this OSError case, we already created the symlink, so src == dst, and
the directory did not exist. This caused us to run os.makedirs the
os.symlink on the same file.

dst really should be the file in gitdir, not the target of that symlink
if it exists. So just use realpath for the dotgit portion of the path.

Change-Id: Iff5396a2093de91029c42cf38aa57131fd22981c
This commit is contained in:
Dan Willemsen 2015-07-30 20:43:33 -07:00
parent abaa7f312f
commit 2a3e15217a

View File

@ -2347,10 +2347,11 @@ class Project(object):
if copy_all: if copy_all:
to_copy = os.listdir(gitdir) to_copy = os.listdir(gitdir)
dotgit = os.path.realpath(dotgit)
for name in set(to_copy).union(to_symlink): for name in set(to_copy).union(to_symlink):
try: try:
src = os.path.realpath(os.path.join(gitdir, name)) src = os.path.realpath(os.path.join(gitdir, name))
dst = os.path.realpath(os.path.join(dotgit, name)) dst = os.path.join(dotgit, name)
if os.path.lexists(dst): if os.path.lexists(dst):
continue continue