LIB: add symlink helpers

This commit is contained in:
Julian Ospald 2015-12-24 17:45:04 +01:00
parent f64f2a975c
commit 5c8907143a
No known key found for this signature in database
GPG Key ID: 220CD1C5BDEED020

View File

@ -667,11 +667,34 @@ removeNonexistent = filter isOkConstructor
isOkError = not . isDoesNotExistErrorType . ioeGetErrorType . err isOkError = not . isDoesNotExistErrorType . ioeGetErrorType . err
---- SYMLINK HELPERS: ----
-- |Follows a chain of symlinks until it finds a non-symlink. Note that
-- this can be caught in an infinite loop if the symlinks haven't been
-- constructed properly. This module however ensures that this cannot
-- happen.
followSymlink :: File FileInfo -> File FileInfo
followSymlink (SymLink _ _ (_ :/ b@(SymLink {}))) = followSymlink b
followSymlink af = af
-- |Checks if a symlink is broken by examining the constructor of the
-- symlink destination. This also follows the symlink chain.
--
-- When called on a non-symlink, returns False.
isBrokenSymlink :: File FileInfo -> Bool
isBrokenSymlink af@(SymLink {})
= case followSymlink af of
(Failed {}) -> True
_ -> False
isBrokenSymlink _ = False
---- OTHER: ---- ---- OTHER: ----
fullPath :: AnchoredFile a -> FilePath fullPath :: AnchoredFile a -> FilePath
fullPath (bp :/ f) = bp </> name f fullPath (bp :/ f) = bp </> name f