summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2013-10-05 15:36:09 -0400
committerGravatar Joey Hess <joey@kitenet.net>2013-10-05 15:36:09 -0400
commit9206bdbdf5bbc71ff6dd2c00314902dda1e48c14 (patch)
tree4582eb7f591b6051c664278c1c8097d032c73b7a
parent44bb0f6a9bdabd45edca7ffb6b7c53d93b639923 (diff)
add dirContentsRecursiveSkipping
-rw-r--r--Utility/Directory.hs18
1 files changed, 11 insertions, 7 deletions
diff --git a/Utility/Directory.hs b/Utility/Directory.hs
index 13e6168cb..42de1e8dd 100644
--- a/Utility/Directory.hs
+++ b/Utility/Directory.hs
@@ -38,15 +38,19 @@ dirContents d = map (d </>) . filter (not . dirCruft) <$> getDirectoryContents d
- and lazily. If the directory does not exist, no exception is thrown,
- instead, [] is returned. -}
dirContentsRecursive :: FilePath -> IO [FilePath]
-dirContentsRecursive topdir = dirContentsRecursive' [topdir]
+dirContentsRecursive topdir = dirContentsRecursiveSkipping (const False) topdir
-dirContentsRecursive' :: [FilePath] -> IO [FilePath]
-dirContentsRecursive' [] = return []
-dirContentsRecursive' (dir:dirs) = unsafeInterleaveIO $ do
- (files, dirs') <- collect [] [] =<< catchDefaultIO [] (dirContents dir)
- files' <- dirContentsRecursive' (dirs' ++ dirs)
- return (files ++ files')
+dirContentsRecursiveSkipping :: (FilePath -> Bool) -> FilePath -> IO [FilePath]
+dirContentsRecursiveSkipping skipdir topdir = go [topdir]
where
+ go [] = return []
+ go (dir:dirs)
+ | skipdir dir = go dirs
+ | otherwise = unsafeInterleaveIO $ do
+ (files, dirs') <- collect [] []
+ =<< catchDefaultIO [] (dirContents dir)
+ files' <- go (dirs' ++ dirs)
+ return (files ++ files')
collect files dirs' [] = return (reverse files, reverse dirs')
collect files dirs' (entry:entries)
| dirCruft entry = collect files dirs' entries