92
Theorem4.2canbeeasilyextendedtoapplytoconflictedchangesetsbymodifyingcase
3ofthedefinition.TheextensionisrequiredtocoverthecasewhereDest(I
1 )andDest(I’
1 )
areequalinclause3.Inthissituationanmethodisneededtoorderpairsofchangeswhose
destinationsareequal.Typically,animplementationwillhaveachoiceoftotalorderingson
changes,whetherarbitraryones,perhapsbasedonthebinaryrepresentationofchanges,or
temporalones(ifaglobalclockisavailable).Manyapplicationswillalsowanttodetectsuch
situations,andsignalanerror,somethingwehavemodeledbydisallowingthem.
4.3.3 P-sequenceaddresses:A’(S)
ThesetA(S)definedbyasetofchangesSissignificantlylargerthanisneededtorepre-
sentthehistoryofaP-sequence.ForagivenmovewithIDM,forinstance,itincludesad-
dressesoftheform(M.p,i)wheretheaddresses(p,i)arenotinthesourcerangeofM.
These“junk”addressesarenotevenusefulinrepresentinguserintentions(unlikethecon-
tent-freeaddressesdiscussedinSection3.4.2).Thefollowingadditionalrestrictions,applied
toA(S),givetheactualaddressspaceA(S)foraminimallyconsistentchangesetS.
Definition4.9:ThesetA’(S) isdefinedasthosemembers,a e A(S),foranunconflicted
causalchangesetSsatisfyingthefollowingconditions:
1. aisoftheform(I,i),whereIistheIDofaninsertion.
2. Ifaisoftheform(I
1 …I
n ,i)andChange(I
1 ) = M[a
1 , a
2 , d]then
a
1 £
SA (I
2 …I
n , I) £
SA a
2 .
3. Ifaisoftheform(I
1 …I
n ,i)andChange(I
1 ) = C[a
1 , a
2 , d]then
a
1 £
SA (I
2 …I
n , I) £
SA a
2 .
4. aisnil.
ThisdefinitionensurestheA’(S) containstargetaddressesofmovesandcopiesonlyfor
thoseaddressesthatcouldpotentiallybeinthesourcerangeoftheoperationinquestion.
Allchangesetswithchangescontainnil,asalreadynoted,butitem4ensuresthatevenan
emptychangesetincludesit.
Theorem4.2canbeeasilyextendedtoapplytoconflictedchangesetsbymodifyingcase
3ofthedefinition.TheextensionisrequiredtocoverthecasewhereDest(I
1 )andDest(I’
1 )
areequalinclause3.Inthissituationanmethodisneededtoorderpairsofchangeswhose
destinationsareequal.Typically,animplementationwillhaveachoiceoftotalorderingson
changes,whetherarbitraryones,perhapsbasedonthebinaryrepresentationofchanges,or
temporalones(ifaglobalclockisavailable).Manyapplicationswillalsowanttodetectsuch
situations,andsignalanerror,somethingwehavemodeledbydisallowingthem.
4.3.3 P-sequenceaddresses:A’(S)
ThesetA(S)definedbyasetofchangesSissignificantlylargerthanisneededtorepre-
sentthehistoryofaP-sequence.ForagivenmovewithIDM,forinstance,itincludesad-
dressesoftheform(M.p,i)wheretheaddresses(p,i)arenotinthesourcerangeofM.
These“junk”addressesarenotevenusefulinrepresentinguserintentions(unlikethecon-
tent-freeaddressesdiscussedinSection3.4.2).Thefollowingadditionalrestrictions,applied
toA(S),givetheactualaddressspaceA(S)foraminimallyconsistentchangesetS.
Definition4.9:ThesetA’(S) isdefinedasthosemembers,a e A(S),foranunconflicted
causalchangesetSsatisfyingthefollowingconditions:
1. aisoftheform(I,i),whereIistheIDofaninsertion.
2. Ifaisoftheform(I
1 …I
n ,i)andChange(I
1 ) = M[a
1 , a
2 , d]then
a
1 £
SA (I
2 …I
n , I) £
SA a
2 .
3. Ifaisoftheform(I
1 …I
n ,i)andChange(I
1 ) = C[a
1 , a
2 , d]then
a
1 £
SA (I
2 …I
n , I) £
SA a
2 .
4. aisnil.
ThisdefinitionensurestheA’(S) containstargetaddressesofmovesandcopiesonlyfor
thoseaddressesthatcouldpotentiallybeinthesourcerangeoftheoperationinquestion.
Allchangesetswithchangescontainnil,asalreadynoted,butitem4ensuresthatevenan
emptychangesetincludesit.