mirror of
https://github.com/srid/ema.git
synced 2024-11-25 20:12:20 +03:00
Add mountFileSystemOnLVar
This commit is contained in:
parent
2f0bb39b6a
commit
5386bf7ca9
@ -4,6 +4,8 @@
|
||||
|
||||
- Remove Ex03_Documentation.hs (moved to separate repo, `ema-docs`)
|
||||
- Add `Ord` instance to `Slug`
|
||||
- Helpers.FileSystem
|
||||
- add `mountFileSystemOnLVar`
|
||||
- Helpers.Tailwind
|
||||
- add overflow-y-scroll to body
|
||||
- Add twind shim *before* application's head
|
||||
|
@ -1,6 +1,6 @@
|
||||
cabal-version: 2.4
|
||||
name: ema
|
||||
version: 0.1.0.0
|
||||
version: 0.2.0.0
|
||||
license: AGPL-3.0-only
|
||||
copyright: 2021 Sridhar Ratnakumar
|
||||
maintainer: srid@srid.ca
|
||||
|
@ -5,7 +5,10 @@
|
||||
--
|
||||
-- Use @new@ in conjunction with @observe@ in your @runEma@ function call.
|
||||
module Ema.Helper.FileSystem
|
||||
( filesMatching,
|
||||
( -- | This is typically what you want.
|
||||
mountFileSystemOnLVar,
|
||||
-- | Lower-level utilities
|
||||
filesMatching,
|
||||
onChange,
|
||||
FileAction (..),
|
||||
)
|
||||
@ -14,6 +17,9 @@ where
|
||||
import Control.Concurrent (threadDelay)
|
||||
import Control.Exception (finally)
|
||||
import Control.Monad.Logger
|
||||
import Data.Default
|
||||
import Data.LVar (LVar)
|
||||
import qualified Data.LVar as LVar
|
||||
import System.Directory (canonicalizePath)
|
||||
import System.FSNotify
|
||||
( ActionPredicate,
|
||||
@ -24,12 +30,38 @@ import System.FSNotify
|
||||
withManager,
|
||||
)
|
||||
import System.FilePath (makeRelative)
|
||||
import System.FilePattern (FilePattern)
|
||||
import System.FilePattern (FilePattern, (?==))
|
||||
import System.FilePattern.Directory (getDirectoryFiles)
|
||||
import UnliftIO (MonadUnliftIO, withRunInIO)
|
||||
|
||||
type FolderPath = FilePath
|
||||
|
||||
mountFileSystemOnLVar ::
|
||||
forall model m.
|
||||
( MonadIO m,
|
||||
MonadUnliftIO m,
|
||||
MonadLogger m,
|
||||
Default model
|
||||
) =>
|
||||
-- | The directory to mount.
|
||||
FilePath ->
|
||||
-- | Only include these files (exclude everything else)
|
||||
[FilePattern] ->
|
||||
-- | The `LVar` onto which to mount.
|
||||
LVar model ->
|
||||
-- | How to update the model given a file action.
|
||||
(FilePath -> FileAction -> m (model -> model)) ->
|
||||
m ()
|
||||
mountFileSystemOnLVar folder pats var toAction = do
|
||||
logInfoN $ "Mounting path " <> toText folder <> " (filter: " <> show pats <> ") onto LVar"
|
||||
LVar.set var =<< do
|
||||
fs <- filesMatching folder pats
|
||||
initialActions <- traverse (`toAction` Update) fs
|
||||
pure $ foldl' (flip ($)) def initialActions
|
||||
onChange folder $ \fp change ->
|
||||
when (any (?== fp) pats) $
|
||||
LVar.modify var =<< toAction fp change
|
||||
|
||||
log :: MonadLogger m => LogLevel -> Text -> m ()
|
||||
log = logWithoutLoc "Helper.FileSystem"
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user