Safe Haskell | None |
---|---|
Language | Haskell2010 |
Synopsis
- data RepoPatchV2 prim wX wY where
- Duplicate :: Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wX wX
- Etacilpud :: Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wX wX
- Normal :: prim wX wY -> RepoPatchV2 prim wX wY
- Conflictor :: [Non (RepoPatchV2 prim) wX] -> FL prim wX wY -> Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wY wX
- InvConflictor :: [Non (RepoPatchV2 prim) wX] -> FL prim wX wY -> Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wX wY
- isConsistent :: PrimPatch prim => RepoPatchV2 prim wX wY -> Maybe Doc
- isForward :: PrimPatch prim => RepoPatchV2 prim wS wY -> Maybe Doc
- isDuplicate :: RepoPatchV2 prim wS wY -> Bool
- mergeUnravelled :: PrimPatch prim => [Sealed (FL prim wX)] -> Maybe (FlippedSeal (RepoPatchV2 prim) wX)
Documentation
data RepoPatchV2 prim wX wY where Source #
RepoPatchV2
is used to represents prim patches that are duplicates of, or
conflict with, another prim patch in the repository.
Normal prim
: A primitive patch
Duplicate x
: This patch has no effect since x
is already present in the
repository.
Etacilpud x: invert (Duplicate x)
Conflictor ix xx x
:
ix
is the set of patches:
* that conflict with x
and also conflict with another patch in the
repository.
* that conflict with a patch that conflict with x
xx
is the sequence of patches that conflict *only* with x
x
is the original, conflicting patch.
ix
and x
are stored as Non
objects, which include any necessary
context to uniquely define the patch that is referred to.
The intuition is that a Conflictor should have the effect of inverting any
patches that x
conflicts with, that haven't already been undone by another
Conflictor in the repository.
Therefore, the effect of a Conflictor is invert xx
.
InvConflictor ix xx x
: like invert (Conflictor ix xx x)
Duplicate :: Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wX wX | |
Etacilpud :: Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wX wX | |
Normal :: prim wX wY -> RepoPatchV2 prim wX wY | |
Conflictor :: [Non (RepoPatchV2 prim) wX] -> FL prim wX wY -> Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wY wX | |
InvConflictor :: [Non (RepoPatchV2 prim) wX] -> FL prim wX wY -> Non (RepoPatchV2 prim) wX -> RepoPatchV2 prim wX wY |
Instances
isConsistent :: PrimPatch prim => RepoPatchV2 prim wX wY -> Maybe Doc Source #
This is used for unit-testing and for internal sanity checks
isForward :: PrimPatch prim => RepoPatchV2 prim wS wY -> Maybe Doc Source #
isForward
p
is True
if p
is either an InvConflictor
or
Etacilpud
.
isDuplicate :: RepoPatchV2 prim wS wY -> Bool Source #
isDuplicate
p
is True
if p
is either a Duplicate
or Etacilpud
patch.
mergeUnravelled :: PrimPatch prim => [Sealed (FL prim wX)] -> Maybe (FlippedSeal (RepoPatchV2 prim) wX) Source #
mergeUnravelled
is used when converting from Darcs V1 patches (Mergers)
to Darcs V2 patches (Conflictors).