X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=dgit.git;a=blobdiff_plain;f=NOTES.git-debrebase;h=ac5a72336b0dab1dce5040e7fa8192f00ac21690;hp=e0a67b5b3ea470d09614934c131e5fc7c8ddf675;hb=c53c58baf0425eaa76826725264dc909b46a4f7c;hpb=7c3763c866d9cca28d2f4d2368028d708694e3e9 diff --git a/NOTES.git-debrebase b/NOTES.git-debrebase index e0a67b5b..ac5a7233 100644 --- a/NOTES.git-debrebase +++ b/NOTES.git-debrebase @@ -1,5 +1,15 @@ +TODO + more tests, see "todo" in gdr-editw + reference docs + git-debrebase(5) data model + git-debrebase(1) command line + tutorial + dgit-maint-debrebase(7) + + clean up remains of NOTES and README + + arrange for dgit to automatically stitch on push -# # git-ffqrebase start [BASE] # # records previous HEAD so it can be overwritten # # records base for future git-ffqrebase @@ -8,9 +18,7 @@ # git-ffqrebase finish # git-ffqrebase status [BRANCH] # -# refs/ffqrebase-prev/BRANCH BRANCH may be refs/...; if not it means -# refs/ffqrebase-base/BRANCH refs/heads/BRANCH -# zero, one, or both of these may exist +# refs/ffq-prev/REF relates to refs/REF # # git-debrebase without start, if already started, is willing # to strip pseudomerges provided that they overwrite exactly @@ -44,6 +52,7 @@ overall format [git-debrebase: gbp2debrebase, drop patches] [git-debrebase breakwater: declare upstream] +[git-debrebase pseudomerge: stitch] m{^\[git-debrebase (?:\w*-)?upstream combine \.((?: $extra_orig_namepart_re)+)\]} @@ -174,6 +183,69 @@ so that the overall result will be series of pseudomerges. ======================================== +So, pm handling specifics: + +strategy is to avoid making needless pseudomerges +pseudomerges that exist will be preserved +(by being included in will-overwrite) + +This is good because the presence of a pseudomerge means we know we +want to keep it; and that allows explicit control over history detail +level. + +It does mean we must avoid making the pseudomerges unnecessarily. +They should be made just before (ideally, part of) dgit push. + +1. git-debrebase [-i etc.] + + should: + check for will-overwrite + if is already a will-overwrite, fine, do no more + if not: + + check our origin branch exists and we are ff from it + if not fail + + check our other might-be-pushed to branches + check we are ff from them + if not fail + + set will-overwrite to something which is ff from + all above branches + + we use our tip, as discussed above + (optionally, can use some other commit which is ff + from all of the above, eg one of them) + +N. git-debrebase [--noop-ok] record-ffq-prev + + does what is described above + +2. git-debrebase [--noop-ok] stitch + + makes pseudomerge with will-overwrite + deletes will-overwrite + + we will teach dgit to do + git-debrebase stitch + +3. git-debrebase push + + like git push only does stitch first + ??? command line parsing! + +4. git-debrebase release + + stiches, finalises changelog, signs tags, pushes everything + for the future, when there is some automatic builder + +will-overwrite for each ref + refs/heads/FOO +is + refs/ffq-prev/FOO + +======================================== + import from gbp [ all this is done now: