fix hang when built with unix-2.8

git-annex test hang when running git-annex add in an adjusted unlocked
branch. I couldn't seem to reproduce the hang outside the test suite.

Seems that the code added in 26a9ea12d1
was buggy, and as that commit was made without testing it, building with
unix-2.8 exposed the bug.

I don't fully understand the bug, which involves fdToHandle
and then closing the fd, vs closing the handle. May somehow involve
laziness or forcing around the S.hGet? Using hClose solved it
in any case.

(Also eliminated checkcontentfollowssymlinks to fix a build warning
when it's not used.)
This commit is contained in:
Joey Hess 2023-08-01 20:17:29 -04:00
parent 6da6449fff
commit 3a52b4c4c3
No known key found for this signature in database
GPG key ID: DB12DB0FF05F8F38

View file

@ -434,23 +434,22 @@ maxSymlinkSz = 8192
isPointerFile :: RawFilePath -> IO (Maybe Key) isPointerFile :: RawFilePath -> IO (Maybe Key)
isPointerFile f = catchDefaultIO Nothing $ isPointerFile f = catchDefaultIO Nothing $
#if defined(mingw32_HOST_OS) #if defined(mingw32_HOST_OS)
checkcontentfollowssymlinks -- no symlinks supported on windows withFile (fromRawFilePath f) ReadMode readhandle
#else #else
#if MIN_VERSION_unix(2,8,0) #if MIN_VERSION_unix(2,8,0)
bracket let open = do
(openFd (fromRawFilePath f) ReadOnly (defaultFileFlags { nofollow = True })) fd <- openFd (fromRawFilePath f) ReadOnly
closeFd (defaultFileFlags { nofollow = True })
(\fd -> readhandle =<< fdToHandle fd) fdToHandle fd
in bracket open hClose readhandle
#else #else
ifM (isSymbolicLink <$> R.getSymbolicLinkStatus f) ifM (isSymbolicLink <$> R.getSymbolicLinkStatus f)
( return Nothing ( return Nothing
, checkcontentfollowssymlinks , withFile (fromRawFilePath f) ReadMode readhandle
) )
#endif #endif
#endif #endif
where where
checkcontentfollowssymlinks =
withFile (fromRawFilePath f) ReadMode readhandle
readhandle h = parseLinkTargetOrPointer <$> S.hGet h maxPointerSz readhandle h = parseLinkTargetOrPointer <$> S.hGet h maxPointerSz
{- Checks a symlink target or pointer file first line to see if it {- Checks a symlink target or pointer file first line to see if it