allow add or del events to be ignored

This commit is contained in:
Joey Hess 2012-04-12 17:28:40 -04:00
parent be4edbaaf1
commit 6464a576cd

View file

@ -11,7 +11,7 @@ import System.Posix.Signals
demo :: IO () demo :: IO ()
demo = withINotify $ \i -> do demo = withINotify $ \i -> do
watchDir i (const True) add del "/home/joey/tmp/me" watchDir i (const True) (Just add) (Just del) "/home/joey/tmp/me"
putStrLn "started" putStrLn "started"
waitForTermination waitForTermination
where where
@ -48,31 +48,41 @@ demo = withINotify $ \i -> do
- /proc/sys/fs/inotify/max_user_watches (default 8192). - /proc/sys/fs/inotify/max_user_watches (default 8192).
- So This will fail if there are too many subdirectories. - So This will fail if there are too many subdirectories.
-} -}
watchDir :: INotify -> (FilePath -> Bool) -> (FilePath -> IO ()) -> (FilePath -> IO ()) -> FilePath -> IO () watchDir :: INotify -> (FilePath -> Bool) -> Maybe (FilePath -> IO ()) -> Maybe (FilePath -> IO ()) -> FilePath -> IO ()
watchDir i test add del dir = watchDir' False i test add del dir watchDir i test add del dir = watchDir' False i test add del dir
watchDir' :: Bool -> INotify -> (FilePath -> Bool) -> (FilePath -> IO ()) -> (FilePath -> IO ()) -> FilePath -> IO () watchDir' :: Bool -> INotify -> (FilePath -> Bool) -> Maybe (FilePath -> IO ()) -> Maybe (FilePath -> IO ()) -> FilePath -> IO ()
watchDir' scan i test add del dir = do watchDir' scan i test add del dir = do
if test dir if test dir
then do then do
_ <- addWatch i [MoveIn, MoveOut, Create, Delete, CloseWrite] dir go _ <- addWatch i watchevents dir go
_ <- mapM walk =<< dirContents dir _ <- mapM walk =<< dirContents dir
return () return ()
else return () else return ()
where where
watchevents
| isJust add && isJust del =
[Create, MoveIn, MoveOut, Delete, CloseWrite]
| isJust add = [Create, MoveIn, CloseWrite]
| isJust del = [Create, MoveOut, Delete]
| otherwise = [Create]
recurse = watchDir' scan i test add del recurse = watchDir' scan i test add del
walk f = ifM (catchBoolIO $ Files.isDirectory <$> getFileStatus f) walk f = ifM (catchBoolIO $ Files.isDirectory <$> getFileStatus f)
( recurse f ( recurse f
, if scan then add f else return () , if scan && isJust add then fromJust add f else return ()
) )
a <@> f = a $ dir </> f
go (Created { isDirectory = False }) = return () go (Created { isDirectory = False }) = return ()
go (Created { filePath = subdir }) = recurse <@> subdir go (Created { filePath = subdir }) = Just recurse <@> subdir
go (Closed { maybeFilePath = Just f }) = add <@> f go (Closed { maybeFilePath = Just f }) = add <@> f
go (MovedIn { isDirectory = False, filePath = f }) = add <@> f go (MovedIn { isDirectory = False, filePath = f }) = add <@> f
go (MovedOut { isDirectory = False, filePath = f }) = del <@> f go (MovedOut { isDirectory = False, filePath = f }) = del <@> f
go (Deleted { isDirectory = False, filePath = f }) = del <@> f go (Deleted { isDirectory = False, filePath = f }) = del <@> f
go _ = return () go _ = return ()
Just a <@> f = a $ dir </> f
Nothing <@> _ = return ()
{- Pauses the main thread, letting children run until program termination. -} {- Pauses the main thread, letting children run until program termination. -}
waitForTermination :: IO () waitForTermination :: IO ()
waitForTermination = do waitForTermination = do