X-Git-Url: http://git.cielonegro.org/gitweb.cgi?a=blobdiff_plain;f=Rakka%2FStorage%2FImpl.hs;h=2c36f516c2a012dfe64189ca3adaca0fa5da924c;hb=044a917ed3908780479b759ac772e1545616c7fc;hp=a6d00561498e2e7ca5b74ef2ab5a6ab87485b4b7;hpb=04f57f2ee2e6e696b4bf0bbd8cda51cdc3d7b4a4;p=Rakka.git diff --git a/Rakka/Storage/Impl.hs b/Rakka/Storage/Impl.hs index a6d0056..2c36f51 100644 --- a/Rakka/Storage/Impl.hs +++ b/Rakka/Storage/Impl.hs @@ -1,5 +1,7 @@ module Rakka.Storage.Impl ( getPage' + , putPage' + , deletePage' , startIndexManager ) where @@ -11,6 +13,7 @@ import Control.Monad import Data.Maybe import Data.Set (Set) import qualified Data.Set as S +import Network.HTTP.Lucu import Network.URI import Rakka.Page import Rakka.Storage.DefaultPage @@ -41,6 +44,14 @@ getPage' repos name rev p -> return p +putPage' :: Repository -> Page -> IO StatusCode +putPage' = putPageIntoRepository + + +deletePage' :: Repository -> PageName -> IO StatusCode +deletePage' = deletePageFromRepository + + findAllPages :: Repository -> RevNum -> IO (Set PageName) findAllPages _ 0 = findAllDefaultPages findAllPages repos rev = do reposPages <- findAllPagesInRevision repos rev @@ -51,7 +62,9 @@ findAllPages repos rev = do reposPages <- findAllPagesInRevision repos rev findChangedPages :: Repository -> RevNum -> RevNum -> IO (Set PageName) findChangedPages repos 0 newRev = findAllPages repos newRev findChangedPages repos oldRev newRev - = findAllPages repos newRev -- FIXME + = mapM (findChangedPagesAtRevision repos) [oldRev + 1 .. newRev] + >>= + return . S.unions getCurrentRevNum :: Repository -> IO RevNum