module Hakyll.Core.Provider
(
Internal.Provider
, newProvider
, Internal.resourceList
, Internal.resourceExists
, Internal.resourceFilePath
, Internal.resourceModified
, Internal.resourceModificationTime
, Internal.resourceString
, Internal.resourceLBS
, Internal.resourceMetadata
, Internal.resourceBody
) where
import Control.Monad (forM)
import qualified Hakyll.Core.Provider.Internal as Internal
import qualified Hakyll.Core.Provider.MetadataCache as Internal
import Hakyll.Core.Store (Store)
import Hakyll.Core.Identifier (Identifier)
newProvider :: Store
-> (FilePath -> IO Bool)
-> FilePath
-> IO (Internal.Provider, [Identifier])
newProvider :: Store
-> (FilePath -> IO Bool) -> FilePath -> IO (Provider, [Identifier])
newProvider Store
store FilePath -> IO Bool
ignore FilePath
directory = do
p <- Store -> (FilePath -> IO Bool) -> FilePath -> IO Provider
Internal.newProvider Store
store FilePath -> IO Bool
ignore FilePath
directory
let modified =
(Identifier -> Bool) -> [Identifier] -> [Identifier]
forall a. (a -> Bool) -> [a] -> [a]
filter
(Provider -> Identifier -> Bool
Internal.resourceModified Provider
p)
(Provider -> [Identifier]
Internal.resourceList Provider
p)
modifiedMetadata <- fmap concat $ forM modified $ \Identifier
identifier -> do
mbCachedMetadata <- Provider -> Identifier -> IO (Maybe Metadata)
Internal.resourceLookupMetadataCache Provider
p Identifier
identifier
case mbCachedMetadata of
Maybe Metadata
Nothing -> [Identifier] -> IO [Identifier]
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure []
Just Metadata
oldMeta -> do
Provider -> Identifier -> IO ()
Internal.resourceInvalidateMetadataCache Provider
p Identifier
identifier
newMeta <- Provider -> Identifier -> IO Metadata
Internal.resourceMetadata Provider
p Identifier
identifier
pure $ if oldMeta == newMeta then [] else [identifier]
return (p, modifiedMetadata)