+import System.IO
+import Subversion.Repository
+import Text.HyperEstraier hiding (WriteLock)
+
+
+mkStorage :: FilePath -> Repository -> (Page -> IO Document) -> IO Storage
+mkStorage lsdir repos mkDraft
+ = do chan <- startIndexManager lsdir repos mkDraft
+ let sto = Storage {
+ stoRepository = repos
+ , stoIndexChan = chan
+ }
+ syncIndex sto
+ return sto
+
+
+getPage :: MonadIO m => Storage -> PageName -> Maybe RevNum -> m (Maybe Page)
+getPage = ((liftIO .) .) . getPage' . stoRepository
+