darcs-2.10.1: a distributed, interactive, smart revision control system

Safe HaskellNone
LanguageHaskell2010

Darcs.Patch.ApplyMonad

Synopsis

Documentation

class (Functor m, Monad m, Functor (ApplyMonadBase m), Monad (ApplyMonadBase m), ToTree state) => ApplyMonad m state where

Associated Types

type ApplyMonadBase m :: * -> *

Methods

nestedApply :: m x -> state (ApplyMonadBase m) -> m (x, state (ApplyMonadBase m))

liftApply :: (state (ApplyMonadBase m) -> ApplyMonadBase m x) -> state (ApplyMonadBase m) -> m (x, state (ApplyMonadBase m))

getApplyState :: m (state (ApplyMonadBase m))

putApplyState :: state m -> m ()

editFile :: (state ~ ObjectMap) => UUID -> (ByteString -> ByteString) -> m ()

editDirectory :: (state ~ ObjectMap) => UUID -> (DirContent -> DirContent) -> m ()

mDoesDirectoryExist :: (state ~ Tree) => FileName -> m Bool

mDoesFileExist :: (state ~ Tree) => FileName -> m Bool

mReadFilePS :: (state ~ Tree) => FileName -> m ByteString

mReadFilePSs :: (state ~ Tree) => FileName -> m [ByteString]

mCreateDirectory :: (state ~ Tree) => FileName -> m ()

mRemoveDirectory :: (state ~ Tree) => FileName -> m ()

mCreateFile :: (state ~ Tree) => FileName -> m ()

mRemoveFile :: (state ~ Tree) => FileName -> m ()

mRename :: (state ~ Tree) => FileName -> FileName -> m ()

mModifyFilePS :: (state ~ Tree) => FileName -> (ByteString -> m ByteString) -> m ()

mModifyFilePSs :: (state ~ Tree) => FileName -> ([ByteString] -> m [ByteString]) -> m ()

mChangePref :: (state ~ Tree) => String -> String -> String -> m ()

class (Functor m, Monad m, ApplyMonad (ApplyMonadOver m state) state) => ApplyMonadTrans m state where

Associated Types

type ApplyMonadOver m state :: * -> *

Methods

runApplyMonad :: ApplyMonadOver m state x -> state m -> m (x, state m)

Instances

withFileNames :: Maybe [OrigFileNameOf] -> [FileName] -> FilePathMonad a -> FilePathMonadState

withFileNames takes a maybe list of existing rename-pairs, a list of filenames and an action, and returns the resulting triple of affected files, updated filename list and new rename details. If the rename-pairs are not present, a new list is generated from the filesnames.

withFiles :: [(FileName, ByteString)] -> RestrictedApply a -> [(FileName, ByteString)]

class ToTree s where

Methods

toTree :: s m -> Tree m

Instances