module Language.PureScript.Ide.Watcher where
import Control.Concurrent (threadDelay)
import Control.Concurrent.STM
import Control.Monad
import Control.Monad.Trans.Except
import Language.PureScript.Ide.Externs
import Language.PureScript.Ide.State
import Language.PureScript.Ide.Types
import Prelude
import System.FilePath
import System.FSNotify
reloadFile :: TVar PscIdeState -> Event -> IO ()
reloadFile _ Removed{} = pure ()
reloadFile stateVar ev = do
let fp = eventPath ev
ef' <- runExceptT (readExternFile fp)
case ef' of
Left _ -> pure ()
Right ef -> do
atomically (insertModuleSTM stateVar ef)
putStrLn ("Reloaded File at: " ++ fp)
watcher :: TVar PscIdeState -> FilePath -> IO ()
watcher stateVar fp =
withManagerConf (defaultConfig { confDebounce = NoDebounce }) $ \mgr -> do
_ <- watchTree mgr fp
(\ev -> takeFileName (eventPath ev) == "externs.json")
(reloadFile stateVar)
forever (threadDelay 100000)