X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=topbloke-formulae.git;a=blobdiff_plain;f=article.tex;h=85e09e1c470a695becbf92bfa58fcaad0dc000e8;hp=ad3a1bae8579d8cf92685644f392209ef1ec882e;hb=9a2630dee8213479147c4b6a60973c4533de4c32;hpb=ef10a30be6c13c72ef3b33730d5f968bdc794473 diff --git a/article.tex b/article.tex index ad3a1ba..85e09e1 100644 --- a/article.tex +++ b/article.tex @@ -293,6 +293,26 @@ by the LHS. And $A \le A''$. }\] xxx proof tbd +\[ \eqn{Ingredients Prevent Replay:}{ + \left[ + {C \hasparents \set A} \land + \\ + \left( + D \isin C \implies + D = C \lor + \Largeexists_{A \in \set A} D \isin A + \right) + \right] \implies \left[ + D \isin C \implies D \le C + \right] +}\] +\proof{ + Trivial for $D = C$. Consider some $D \neq C$, $D \isin C$. + By the preconditions, there is some $A$ s.t. $D \in \set A$ + and $D \isin A$. By No Replay for $A$, $D \le A$. And + $A \le C$ so $D \le C$. +} + \[ \eqn{Totally Foreign Contents:}{ \bigforall_{C \hasparents \set A} \left[ @@ -301,43 +321,16 @@ xxx proof tbd \right] \implies \left[ - D \isin C + D \le C \implies \patchof{D} = \bot \right] }\] -xxx proof tbd - -\subsection{No Replay for Merge Results} - -If we are constructing $C$, with, -\gathbegin - \mergeof{C}{L}{M}{R} -\gathnext - L \le C -\gathnext - R \le C -\end{gather} -No Replay is preserved. \proofstarts - -\subsubsection{For $D=C$:} $D \isin C, D \le C$. OK. - -\subsubsection{For $D \isin L \land D \isin R$:} -$D \isin C$. And $D \isin L \implies D \le L \implies D \le C$. OK. - -\subsubsection{For $D \neq C \land D \not\isin L \land D \not\isin R$:} -$D \not\isin C$. OK. - -\subsubsection{For $D \neq C \land (D \isin L \equiv D \not\isin R) - \land D \not\isin M$:} -$D \isin C$. Also $D \isin L \lor D \isin R$ so $D \le L \lor D \le -R$ so $D \le C$. OK. - -\subsubsection{For $D \neq C \land (D \isin L \equiv D \not\isin R) - \land D \isin M$:} -$D \not\isin C$. OK. - -$\qed$ +\proof{ +Consider some $D \le C$. If $D = C$, $\patchof{D} = \bot$ trivially. +If $D \neq C$ then $D \le A$ where $A \in \set A$. By Foreign +Contents of $A$, $\patchof{D} = \bot$. +} \section{Commit annotation} @@ -385,7 +378,8 @@ This also covers Topbloke-generated commits on plain git branches: Topbloke strips the metadata when exporting. \subsection{No Replay} -Trivial. + +Ingredients Prevent Replay applies. $\qed$ \subsection{Unique Base} If $A, C \in \py$ then by Calculation of Ends for @@ -461,10 +455,8 @@ $D \isin C \equiv D \isin A \equiv D \le A \equiv D \le C$. $\qed$ \subsection{Foreign Contents:} -Only relevant if $\patchof{C} = \bot$. Trivial by Foreign Contents of -$A$. $\qed$ - -xxx fixme not trivial use Totally Foreign Contents +Only relevant if $\patchof{C} = \bot$, and in that case Totally +Foreign Contents applies. $\qed$ \section{Create Base} @@ -472,7 +464,7 @@ Given $L$, create a Topbloke base branch initial commit $B$. \gathbegin B \hasparents \{ L \} \gathnext - \patchof{B} = \pa{B} + \patchof{B} = \pan{Q} \gathnext D \isin B \equiv D \isin L \lor D = B \end{gather} @@ -483,34 +475,85 @@ Given $L$, create a Topbloke base branch initial commit $B$. \patchof{L} = \pa{L} \lor \patchof{L} = \bot }\] \[ \eqn{ Non-recursion }{ - L \not\in \pa{B} + L \not\haspatch \pa{Q} }\] \subsection{No Replay} -If $\patchof{L} = \pa{L}$, trivial by Base Acyclic for $L$. - -If $\patchof{L} = \bot$, xxx - -Trivial from Base Acyclic for $L$. $\qed$ +Ingredients Prevent Replay applies. $\qed$ \subsection{Unique Base} -Not applicable. $\qed$ +Not applicable. \subsection{Tip Contents} -Not applicable. $\qed$ +Not applicable. \subsection{Base Acyclic} -xxx +Consider some $D \isin B$. If $D = B$, $D \in \pan{Q}$. +If $D \neq B$, $D \isin L$, and by Non-recursion +$D \not\in \pay{Q}$. $\qed$ + +\subsection{Coherence and Patch Inclusion} + +Consider some $D \in \p$. +$B \not\in \py$ so $D \neq B$. So $D \isin B \equiv D \isin L$. -xxx unfinished +Thus $L \haspatch \p \implies B \haspatch P$ +and $L \nothaspatch \p \implies B \nothaspatch P$. + +$\qed$. + +\subsection{Foreign Inclusion} + +Consider some $D$ s.t. $\patchof{D} = \bot$. $D \neq B$ +so $D \isin B \equiv D \isin L$. +By Foreign Inclusion of $D$ in $L$, $D \isin L \equiv D \le L$. +And by Exact Ancestors $D \le L \equiv D \le B$. +So $D \isin B \equiv D \le B$. $\qed$ + +\subsection{Foreign Contents} + +Not applicable. \section{Create Tip} -xxx tbd +Given a Topbloke base $B$, create a tip branch initial commit B. +\gathbegin + C \hasparents \{ B \} +\gathnext + \patchof{B} = \pay{Q} +\gathnext + D \isin C \equiv D \isin B \lor D = C +\end{gather} + +\subsection{Conditions} + +\[ \eqn{ Ingredients }{ + \patchof{B} = \pan{Q} +}\] + +\subsection{No Replay} + +Ingredients Prevent Replay applies. $\qed$ + +\subsection{Unique Base} + +Trivially, $\pendsof{C}{\pan{Q}} = \{B\}$ so $\baseof{C} = B$. + +\subsection{Tip Contents} + +Consider some arbitrary commit $D$. If $D = C$, trivially satisfied. + +If $D \neq C$, $D \isin C \equiv D \isin B$. +By Base Acyclic of $B$, $D \isin B \implies D \not\in \pay{Q}$. +So $D \isin C \equiv D \isin \baseof{B}$. + +$\qed$ + +xxx up to here \section{Anticommit} @@ -540,7 +583,7 @@ R^+ \in \pry \land R^- = \baseof{R^+} L \haspatch \pry }\] -\subsection{Ordering of ${L, R^+, R^-}$:} +\subsection{Ordering of Ingredients:} By Unique Tip, $R^+ \le L$. By definition of $\base$, $R^- \le R^+$ so $R^- \le L$. So $R^+ \le C$ and $R^- \le C$. @@ -551,7 +594,10 @@ is a descendant, not an ancestor, of the 2nd parent.) \subsection{No Replay} -No Replay for Merge Results applies. $\qed$ +By definition of $\merge$, +$D \isin C \implies D \isin L \lor D \isin R^- \lor D = C$. +So, by Ordering of Ingredients, +Ingredients Prevent Replay applies. $\qed$ \subsection{Desired Contents} @@ -635,9 +681,9 @@ Thus $D \isin C \equiv D \le C$. $\qed$ -\subsection{Foreign Contents:} +\subsection{Foreign Contents} -Not applicable. $\qed$ +Not applicable. \section{Merge} @@ -705,7 +751,10 @@ is therefore consistent with our scheme. \subsection{No Replay} -No Replay for Merge Results applies. $\qed$ +By definition of $\merge$, +$D \isin C \implies D \isin L \lor D \isin R \lor D = C$. +So, by Ingredients, +Ingredients Prevent Replay applies. $\qed$ \subsection{Unique Base} @@ -906,11 +955,10 @@ OK $\qed$ -\subsection{Foreign Contents:} - -xxx use Totally Foreign Contents +\subsection{Foreign Contents} -If $\patchof{C} = \bot$, by Foreign Merges -$\patchof{L} = \patchof{R} = \bot$. +Only relevant if $\patchof{L} = \bot$, in which case +$\patchof{C} = \bot$ and by Foreign Merges $\patchof{R} = \bot$, +so Totally Foreign Contents applies. $\qed$ \end{document}