diff options
Diffstat (limited to 'Utility/FSEvents.hs')
-rw-r--r-- | Utility/FSEvents.hs | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/Utility/FSEvents.hs b/Utility/FSEvents.hs index 8a8f890eb..8fd676d9e 100644 --- a/Utility/FSEvents.hs +++ b/Utility/FSEvents.hs @@ -18,6 +18,7 @@ watchDir :: FilePath -> (FilePath -> Bool) -> WatchHooks -> IO EventStream watchDir dir ignored hooks = do unlessM fileLevelEventsSupported $ error "Need at least OSX 10.7.0 for file-level FSEvents" + scan dir eventStreamCreate [dir] 1.0 True False True handle where handle evt @@ -52,9 +53,29 @@ watchDir dir ignored hooks = do ms <- getstatus $ eventPath evt runhook modifyHook ms where - getstatus = catchMaybeIO . getSymbolicLinkStatus hasflag f = eventFlags evt .&. f /= 0 runhook h s = maybe noop (\a -> a (eventPath evt) s) (h hooks) + + scan d = unless (ignoredPath ignored d) $ + mapM_ go =<< dirContentsRecursive d + where + go f + | ignoredPath ignored f = noop + | otherwise = do + ms <- getstatus f + case ms of + Nothing -> noop + Just s + | Files.isSymbolicLink s -> + runhook addSymlinkHook ms + | Files.isRegularFile s -> + runhook addHook ms + | otherwise -> + noop + where + runhook h s = maybe noop (\a -> a f s) (h hooks) + + getstatus = catchMaybeIO . getSymbolicLinkStatus {- Check each component of the path to see if it's ignored. -} ignoredPath :: (FilePath -> Bool) -> FilePath -> Bool |