fold parseLinkTarget into parseLinkTargetOrPointer

Only one place remained that differentiated between them.

It is the case that a symlink target that happens to contain a newline
somehow will be treated as a link to a key truncated at the newline.
This is super unlikely to happen, and since a key cannot actually
contain a newline, it's as good a behavior as any. Anyway, this commit
does not change the behavior there, although arguably it should be
changed. Note that getAnnexLinkTarget does prevent a symlink target
containing a newline.

Sponsored-by: Dartmouth College's Datalad project
This commit is contained in:
Joey Hess 2022-02-23 12:24:09 -04:00
parent 38816a9ae9
commit 4cd9325c2c
No known key found for this signature in database
GPG key ID: DB12DB0FF05F8F38
2 changed files with 13 additions and 15 deletions

View file

@ -7,7 +7,7 @@
- -
- Pointer files are used instead of symlinks for unlocked files. - Pointer files are used instead of symlinks for unlocked files.
- -
- Copyright 2013-2021 Joey Hess <id@joeyh.name> - Copyright 2013-2022 Joey Hess <id@joeyh.name>
- -
- Licensed under the GNU AGPL version 3 or higher. - Licensed under the GNU AGPL version 3 or higher.
-} -}
@ -297,11 +297,21 @@ unableToRestage mf = unwords
{- Parses a symlink target or a pointer file to a Key. -} {- Parses a symlink target or a pointer file to a Key. -}
parseLinkTargetOrPointer :: S.ByteString -> Maybe Key parseLinkTargetOrPointer :: S.ByteString -> Maybe Key
parseLinkTargetOrPointer = parseLinkTarget . S8.takeWhile (not . lineend) parseLinkTargetOrPointer = go . S8.takeWhile (not . lineend)
where where
go l
| isLinkToAnnex l = fileKey $ snd $ S8.breakEnd pathsep l
| otherwise = Nothing
lineend '\n' = True lineend '\n' = True
lineend '\r' = True lineend '\r' = True
lineend _ = False lineend _ = False
pathsep '/' = True
#ifdef mingw32_HOST_OS
pathsep '\\' = True
#endif
pathsep _ = False
{- Avoid looking at more of the lazy ByteString than necessary since it {- Avoid looking at more of the lazy ByteString than necessary since it
- could be reading from a large file that is not a pointer file. -} - could be reading from a large file that is not a pointer file. -}
@ -310,18 +320,6 @@ parseLinkTargetOrPointerLazy b =
let b' = L.take (fromIntegral maxPointerSz) b let b' = L.take (fromIntegral maxPointerSz) b
in parseLinkTargetOrPointer (L.toStrict b') in parseLinkTargetOrPointer (L.toStrict b')
{- Parses a symlink target to a Key. -}
parseLinkTarget :: S.ByteString -> Maybe Key
parseLinkTarget l
| isLinkToAnnex l = fileKey $ snd $ S8.breakEnd pathsep l
| otherwise = Nothing
where
pathsep '/' = True
#ifdef mingw32_HOST_OS
pathsep '\\' = True
#endif
pathsep _ = False
formatPointer :: Key -> S.ByteString formatPointer :: Key -> S.ByteString
formatPointer k = prefix <> keyFile k <> nl formatPointer k = prefix <> keyFile k <> nl
where where

View file

@ -265,7 +265,7 @@ onAddFile' contentchanged addassociatedfile addlink samefilestatus symlinkssuppo
case linktarget of case linktarget of
Nothing -> a Nothing -> a
Just lt -> do Just lt -> do
case parseLinkTarget lt of case parseLinkTargetOrPointer lt of
Nothing -> noop Nothing -> noop
Just key -> liftAnnex $ Just key -> liftAnnex $
addassociatedfile key file addassociatedfile key file