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

Safe HaskellNone

Darcs.Patch.PatchInfoAnd

Synopsis

Documentation

data Hopefully a x y Source

Hopefully p C (x y) is Either String (p C (x y)) in a form adapted to darcs patches. The C (x y) represents the type witness for the patch that should be there. The Hopefully type just tells whether we expect the patch to be hashed or not, and SimpleHopefully does the real work of emulating Either. Hopefully sh represents an expected unhashed patch, and Hashed hash sh represents an expected hashed patch with its hash.

data PatchInfoAnd p a b Source

PatchInfoAnd p a b represents a hope we have to get a patch through its info. We're not sure we have the patch, but we know its info.

data WPatchInfo a b Source

WPatchInfo a b represents the info of a patch, marked with the patch's witnesses.

Instances

compareWPatchInfo :: WPatchInfo a b -> WPatchInfo c d -> EqCheck (a, b) (c, d)Source

piap :: PatchInfo -> Named p a b -> PatchInfoAnd p a bSource

piap i p creates a PatchInfoAnd containing p with info i.

n2pia :: Named p x y -> PatchInfoAnd p x ySource

n2pia creates a PatchInfoAnd representing a Named patch.

fmapPIAP :: (forall a b. p a b -> q a b) -> PatchInfoAnd p x y -> PatchInfoAnd q x ySource

fmapFL_PIAP :: (FL p x y -> FL q x y) -> PatchInfoAnd p x y -> PatchInfoAnd q x ySource

conscientiously :: (Doc -> Doc) -> PatchInfoAnd p a b -> Named p a bSource

conscientiously er hp tries to extract a patch from a PatchInfoAnd. If it fails, it applies the error handling function er to a description of the patch info component of hp.

hopefully :: PatchInfoAnd p a b -> Named p a bSource

hopefully hp tries to get a patch from a PatchInfoAnd value. If it fails, it outputs an error "failed to read patch: <description of the patch>". We get the description of the patch from the info part of hp

hopefullyM :: Monad m => PatchInfoAnd p a b -> m (Named p a b)Source

hopefullyM is a version of hopefully which calls fail in a monad instead of erroring.

createHashed :: String -> (String -> IO (Sealed (a x))) -> IO (Sealed (Hopefully a x))Source

actually :: a x y -> Hopefully a x ySource

patchDesc :: forall p x y. PatchInfoAnd p x y -> StringSource