.\" Automatically generated by Pod::Man 4.07 (Pod::Simple 3.32) .\" .\" Standard preamble: .\" ======================================================================== .de Sp \" Vertical space (when we can't use .PP) .if t .sp .5v .if n .sp .. .de Vb \" Begin verbatim text .ft CW .nf .ne \\$1 .. .de Ve \" End verbatim text .ft R .fi .. .\" Set up some character translations and predefined strings. \*(-- will .\" give an unbreakable dash, \*(PI will give pi, \*(L" will give a left .\" double quote, and \*(R" will give a right double quote. \*(C+ will .\" give a nicer C++. Capital omega is used to do unbreakable dashes and .\" therefore won't be available. \*(C` and \*(C' expand to `' in nroff, .\" nothing in troff, for use with C<>. .tr \(*W- .ds C+ C\v'-.1v'\h'-1p'\s-2+\h'-1p'+\s0\v'.1v'\h'-1p' .ie n \{\ . ds -- \(*W- . ds PI pi . if (\n(.H=4u)&(1m=24u) .ds -- \(*W\h'-12u'\(*W\h'-12u'-\" diablo 10 pitch . if (\n(.H=4u)&(1m=20u) .ds -- \(*W\h'-12u'\(*W\h'-8u'-\" diablo 12 pitch . ds L" "" . ds R" "" . ds C` "" . ds C' "" 'br\} .el\{\ . ds -- \|\(em\| . ds PI \(*p . ds L" `` . ds R" '' . ds C` . ds C' 'br\} .\" .\" Escape single quotes in literal strings from groff's Unicode transform. .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" .\" If the F register is >0, we'll generate index entries on stderr for .\" titles (.TH), headers (.SH), subsections (.SS), items (.Ip), and index .\" entries marked with X<> in POD. Of course, you'll have to process the .\" output yourself in some meaningful fashion. .\" .\" Avoid warning from groff about undefined register 'F'. .de IX .. .if !\nF .nr F 0 .if \nF>0 \{\ . de IX . tm Index:\\$1\t\\n%\t"\\$2" .. . if !\nF==2 \{\ . nr % 0 . nr F 2 . \} .\} .\" .\" Accent mark definitions (@(#)ms.acc 1.5 88/02/08 SMI; from UCB 4.2). .\" Fear. Run. Save yourself. No user-serviceable parts. . \" fudge factors for nroff and troff .if n \{\ . ds #H 0 . ds #V .8m . ds #F .3m . ds #[ \f1 . ds #] \fP .\} .if t \{\ . ds #H ((1u-(\\\\n(.fu%2u))*.13m) . ds #V .6m . ds #F 0 . ds #[ \& . ds #] \& .\} . \" simple accents for nroff and troff .if n \{\ . ds ' \& . ds ` \& . ds ^ \& . ds , \& . ds ~ ~ . ds / .\} .if t \{\ . ds ' \\k:\h'-(\\n(.wu*8/10-\*(#H)'\'\h"|\\n:u" . ds ` \\k:\h'-(\\n(.wu*8/10-\*(#H)'\`\h'|\\n:u' . ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'^\h'|\\n:u' . ds , \\k:\h'-(\\n(.wu*8/10)',\h'|\\n:u' . ds ~ \\k:\h'-(\\n(.wu-\*(#H-.1m)'~\h'|\\n:u' . ds / \\k:\h'-(\\n(.wu*8/10-\*(#H)'\z\(sl\h'|\\n:u' .\} . \" troff and (daisy-wheel) nroff accents .ds : \\k:\h'-(\\n(.wu*8/10-\*(#H+.1m+\*(#F)'\v'-\*(#V'\z.\h'.2m+\*(#F'.\h'|\\n:u'\v'\*(#V' .ds 8 \h'\*(#H'\(*b\h'-\*(#H' .ds o \\k:\h'-(\\n(.wu+\w'\(de'u-\*(#H)/2u'\v'-.3n'\*(#[\z\(de\v'.3n'\h'|\\n:u'\*(#] .ds d- \h'\*(#H'\(pd\h'-\w'~'u'\v'-.25m'\f2\(hy\fP\v'.25m'\h'-\*(#H' .ds D- D\\k:\h'-\w'D'u'\v'-.11m'\z\(hy\v'.11m'\h'|\\n:u' .ds th \*(#[\v'.3m'\s+1I\s-1\v'-.3m'\h'-(\w'I'u*2/3)'\s-1o\s+1\*(#] .ds Th \*(#[\s+2I\s-2\h'-\w'I'u*3/5'\v'-.3m'o\v'.3m'\*(#] .ds ae a\h'-(\w'a'u*4/10)'e .ds Ae A\h'-(\w'A'u*4/10)'E . \" corrections for vroff .if v .ds ~ \\k:\h'-(\\n(.wu*9/10-\*(#H)'\s-2\u~\d\s+2\h'|\\n:u' .if v .ds ^ \\k:\h'-(\\n(.wu*10/11-\*(#H)'\v'-.4m'^\v'.4m'\h'|\\n:u' . \" for low resolution devices (crt and lpr) .if \n(.H>23 .if \n(.V>19 \ \{\ . ds : e . ds 8 ss . ds o a . ds d- d\h'-1'\(ga . ds D- D\h'-1'\(hy . ds th \o'bp' . ds Th \o'LP' . ds ae ae . ds Ae AE .\} .rm #[ #] #H #V #F C .\" ======================================================================== .\" .IX Title "git-debrebase 5" .TH git-debrebase 5 "Debian Project" "perl v5.24.1" "git-debrebase" .\" For nroff, turn off justification. Always turn off hyphenation; it makes .\" way too many mistakes in technical documents. .if n .ad l .nh .SH "NAME" git\-debrebase \- git data model for Debian packaging .SH "INTRODUCTION" .IX Header "INTRODUCTION" git-debrebase is a tool for representing in git, and manpulating, Debian packages based on upstream source code. .PP The Debian packaging has a fast forwarding history. The delta queue (changes to upstream files) is represented as a series of individual git commits, which can worked on with rebase, and also shared. .SS "\s-1DISCUSSION\s0" .IX Subsection "DISCUSSION" git-debrebase is designed to work well with dgit. git-debrebase can also be used in workflows without source packages, for example to work on Debian-format packages outside or alongside Debian. .PP git-debrebase itself is not very suitable for use by Debian derivatives, to work on packages inherited from Debian, because it assumes that you want to throw away any packaging provided by your upstream. However, use of git-debrebase in Debian does not make anything harder for derivatives, and it can make some things easier. .PP When using gitk on branches managed by git-debrebase, \&\fBgitk \-\-date\-order\fR, \fBgitk \-\-first\-parent\fR and \fBgitk \*(-- :.\fR (or \fBgitk .\fR) produce more useful output than the default. .SH "TERMINOLOGY" .IX Header "TERMINOLOGY" .IP "Pseudomerge" 4 .IX Item "Pseudomerge" A merge which does not actually merge the trees; instead, it is constructed by taking the tree from one of the parents (ignoring the contents of the other parents). These are used to make a rewritten history fast forward from a previous tip, so that it can be pushed and pulled normally. Manual construction of pseudomerges can be done with \&\f(CW\*(C`git merge \-s ours\*(C'\fR but is not normally needed when using git-debrebase. .IP "Packaging files" 4 .IX Item "Packaging files" Files in the source tree within \fBdebian/\fR, excluding anything in \fBdebian/patches/\fR. .IP "Upstream" 4 .IX Item "Upstream" The version of the package without Debian's packaging. Typically provided by the actual upstream project, and sometimes tracked by Debian contributors in a branch \f(CW\*(C`upstream\*(C'\fR. .Sp Upstream contains upstream files, but some upstreams also contain packaging files in \fBdebian/\fR. Any such non-upstream files found in upstream are thrown away by git-debrebase each time a new upstream version is incorporated. .IP "Upstream files" 4 .IX Item "Upstream files" Files in the source tree outside \fBdebian/\fR. These may include unmodified source from upstream, but also files which have been modified or created for Debian. .IP "Delta queue" 4 .IX Item "Delta queue" Debian's changes to upstream files: a series of git commits. .IP "Quilt patches" 4 .IX Item "Quilt patches" Files in \fBdebian/patches/\fR generated for the benefit of dpkg-source's 3.0 (quilt) .dsc source package format. Not used, often deleted, and regenerated when needed (such as when uploading to Debian), by git-debrebase. .IP "Interchange branch; breakwater; stitched; laundered" 4 .IX Item "Interchange branch; breakwater; stitched; laundered" See \*(L"\s-1BRANCHES AND BRANCH STATES \- OVERVIEW\*(R"\s0. .IP "Anchor; Packaging" 4 .IX Item "Anchor; Packaging" See \*(L"\s-1BRANCH CONTENTS \- DETAILED SPECIFICATION\*(R"\s0. .IP "ffq-prev; debrebase-last" 4 .IX Item "ffq-prev; debrebase-last" See \*(L"\s-1STITCHING,\s0 PSEUDO-MERGES, \s-1FFQ RECORD\*(R"\s0. .SH "DIAGRAM" .IX Header "DIAGRAM" .Vb 10 \& \-\-\-\-\-\-/\-\-A!\-\-\-\-/\-\-B3!\-\-%\-\-/\-\-> interchange view \& / / / with debian/ directory \& % % % entire delta queue applied \& / / / 3.0 (quilt) has debian/patches \& / / 3* "master" on Debian git servers \& / / / \& 2* 2* 2 \& / / / \& 1 1 1 breakwater branch, merging baseline \& / / / unmodified upstream code \& \-\-\-@\-\-\-\-\-@\-\-A\-\-\-\-@\-\-B\-\-C plus debian/ (but no debian/patches) \& / / / no ref refers to this: we \& \-\-#\-\-\-\-\-#\-\-\-\-\-\-\-#\-\-\-\-\-> upstream reconstruct its identity by \& inspecting interchange branch \& Key: \& \& 1,2,3 commits touching upstream files only \& A,B,C commits touching debian/ only \& B3 mixed commit (eg made by an NMUer) \& # upstream releases \& \& \-@\- anchor merge, takes contents of debian/ from the \& / previous \`breakwater\*(Aq commit and rest from upstream \& \& \-/\- pseudomerge; contents are identical to \& / parent lower on diagram. \& \& % dgit\- or git\-debrebase\- generated commit of debian/patches. \& \`3.0 (quilt)\*(Aq only; generally dropped by git\-debrebase. \& \& * Maintainer\*(Aqs HEAD was here while they were editing, \& before they said they were done, at which point their \& tools made \-/\- (and maybe %) to convert to \& the fast\-forwarding interchange branch. \& \& ! NMUer\*(Aqs HEAD was here when they said \`dgit push\*(Aq. \& Rebase branch launderer turns each ! into an \& equivalent *. .Ve .SH "BRANCHES AND BRANCH STATES \- OVERVIEW" .IX Header "BRANCHES AND BRANCH STATES - OVERVIEW" git-debrebase has one primary branch, the \fBinterchange branch\fR. This branch is found on Debian contributors' workstations (typically, a maintainer would call it \fBmaster\fR), in the Debian dgit git server as the suite branch (\fBdgit/dgit/sid\fR) and on other git servers which support Debian work (eg \fBmaster\fR on salsa). .PP The interchange branch is fast-forwarding (by virtue of pseudomerges, where necessary). .PP It is possible to have multiple different interchange branches for the same package, stored as different local and remote git branches. However, divergence should be avoided where possible \- see \*(L"\s-1OTHER MERGES\*(R"\s0. .PP A suitable interchange branch can be used directly with dgit. In this case each dgit archive suite branch is a separate interchange branch. .PP Within the ancestry of the interchange branch, there is another important, implicit branch, the \&\fBbreakwater\fR. The breakwater contains unmodified upstream source, but with Debian's packaging superimposed (replacing any \f(CW\*(C`debian/\*(C'\fR directory that may be in the upstream commits). The breakwater does not contain any representation of the delta queue (not even debian/patches). The part of the breakwater processed by git-debrebase is the part since the most recent \fBanchor\fR, which is usually a special merge generated by git-debrebase. .PP When working, locally, the user's branch can be in a rebasing state, known as \fBunstitched\fR. While a branch is unstitched, it is not in interchange format. The previous interchange branch tip is recorded, so that the previous history and the user's work can later be stitched into the fast-forwarding interchange form. .PP An unstitched branch may be in \&\fBlaundered\fR state, which means it has a more particular special form convenient for manipulating the delta queue. .SH "BRANCH CONTENTS \- DETAILED SPECIFICATION" .IX Header "BRANCH CONTENTS - DETAILED SPECIFICATION" It is most convenient to describe the \&\fBbreakwater\fR branch first. A breakwater is \fBfast-forwarding\fR, but is not usually named by a ref. It contains \fBin this order\fR (ancestors first): .IP "Anchor" 4 .IX Item "Anchor" An \fBanchor\fR commit, which is usually a special two-parent merge: .Sp The first parent contains the most recent version, at that point, of the Debian packaging (in debian/); it also often contains upstream files, but they are to be ignored. Often the first parent is a previous breakwater tip. .Sp The second parent is an upstream source commit. It may sometimes contain a debian/ subdirectory, but if so that is to be ignored. The second parent's upstream files are identical to the anchor's. Anchor merges always contain \&\f(CW\*(C`[git\-debrebase anchor: ...]\*(C'\fR as a line in the commit message. .Sp Alternatively, an anchor may be a single-parent commit which introduces the \f(CW\*(C`debian/\*(C'\fR directory and makes no other changes: ie, the start of Debian packaging. .IP "Packaging" 4 .IX Item "Packaging" Zero or more single-parent commits containing only packaging changes. (And no quilt patch changes.) .PP The \&\fBlaundered\fR branch state is \fBrebasing\fR. A laundered branch is based on a breakwater but also contains, additionally, \&\fBafter\fR the breakwater, a representation of the delta queue: .IP "Delta queue commits" 4 .IX Item "Delta queue commits" Zero or more single-parent commits containing only changes to upstream files. .PP The merely \&\fBunstitched\fR (ie, unstitched but unlaundered) branch state is also \fBrebasing\fR. It has the same contents as the laundered state, except that it may contain, additionally, \&\fBin any order but after the breakwater\fR: .IP "Linear commits to the source" 4 .IX Item "Linear commits to the source" Further commit(s) containing changes to to upstream files and/or to packaging, possibly mixed within a single commit. (But not quilt patch changes.) .IP "Quilt patch addition for `3.0 (quilt)'" 4 .IX Item "Quilt patch addition for `3.0 (quilt)'" Commit(s) which add patches to \fBdebian/patches/\fR, and add those patches to the end of \fBseries\fR. .Sp These are only necessary when working with packages in \f(CW\*(C`.dsc 3.0 (quilt)\*(C'\fR format. For git-debrebase they are purely an output; they are deleted when branches are laundered. git-debrebase takes care to make a proper patch series out of the delta queue, so that any resulting source packages are nice. .PP Finally, an \&\fBinterchange\fR branch is \fBfast forwarding\fR. It has the same contents as an unlaundered branch state, but may (and usually will) additionally contain (in some order, possibly intermixed with the extra commits which may be found on an unstitched unlaundered branch): .IP "Pseudomerge to make fast forward" 4 .IX Item "Pseudomerge to make fast forward" A pseudomerge making the branch fast forward from previous history. The contributing parent is itself in interchange format. Normally the overwritten parent is a previous tip of an interchange branch, but this is not necessary as the overwritten parent is not examined. .Sp If the two parents have identical trees, the one with the later commit date (or, if the commit dates are the same, the first parent) is treated as the contributing parent. .IP "dgit dsc import pseudomerge" 4 .IX Item "dgit dsc import pseudomerge" Debian .dsc source package import(s) made by dgit (during dgit fetch of a package most recently uploaded to Debian without dgit, or during dgit import-dsc). .Sp git-debrebase requires that each such import is in the fast-forwarding format produced by dgit: a two-parent pseudomerge, whose contributing parent is in the non-fast-forwarding dgit dsc import format (not described further here), and whose overwritten parent is the previous interchange tip (eg, the previous tip of the dgit suite branch). .SH "STITCHING, PSEUDO-MERGES, FFQ RECORD" .IX Header "STITCHING, PSEUDO-MERGES, FFQ RECORD" Whenever the branch \f(CW\*(C`refs/B\*(C'\fR is unstitched, the previous head is recorded in the git ref \f(CW\*(C`refs/ffq\-prev/B\*(C'\fR. .PP Unstiched branches are not fast forward from the published interchange branches [1]. So before a branch can be pushed, the right pseudomerge must be reestablished. This is the stitch operation, which consumes the ffq-prev ref. .PP When the user has an unstitched branch, they may rewrite it freely, from the breakwater tip onwards. Such a git rebase is the default operation for git-debrebase. Rebases should not go back before the breakwater tip, and certainly not before the most recent anchor. .PP Unstitched branches must not be pushed to interchange branch refs (by the use of \f(CW\*(C`git push \-f\*(C'\fR or equivalent). It is \s-1OK\s0 to share an unstitched branch in similar circumstances and with similar warnings to sharing any other rebasing git branch. .PP [1] Strictly, for a package which has never had a Debian delta queue, the interchange and breakwater branches may be identical, in which case the unstitched branch is fast forward from the interchange branch and no pseudomerge is needed. .PP When ffq-prev is not present, \&\f(CW\*(C`refs/debrebase\-last/B\*(C'\fR records some ancestor of refs/B, (usually, the result of last stitch). This is used for status printing and some error error checks \- especially for printing guesses about what a problem is. To determine whether a branch is being maintained in git-debrebase form it is necessary to walk its history. .SH "OTHER MERGES" .IX Header "OTHER MERGES" Note that the representation described here does not permit general merges on any of the relevant branches. For this reason the tools will try to help the user avoid divergence of the interchange branch. .PP See \fIdgit\-maint\-rebase\fR\|(7) for a discussion of what kinds of behaviours should be be avoided because they might generate such merges. .PP Automatic resolution of divergent interchange branches (or laundering of merges on the interchange branch) is thought to be possible, but there is no tooling for this yet: .PP Nonlinear (merging) history in the interchange branch is awkward because it (obviously) does not preserve the linearity of the delta queue. Easy merging of divergent delta queues is a research problem. .PP Nonlinear (merging) history in the breakwater branch is in principle tolerable, but each of the parents would have to be, in turn, a breakwater, and difficult questions arise if they don't have the same anchor. .PP We use the commit message annotation to distinguish the special anchor merges from other general merges, so we can at least detect unsupported merges. .SH "LEGAL OPERATIONS" .IX Header "LEGAL OPERATIONS" The following basic operations follow from this model (refer to the diagram above): .IP "Append linear commits" 4 .IX Item "Append linear commits" No matter the branch state, it is always fine to simply git commit (or cherry-pick etc.) commits containing upstream file changes, packaging changes, or both. .Sp (This may make the branch unlaundered.) .IP "Launder branch" 4 .IX Item "Launder branch" Record the previous head in ffq-prev, if we were stitched before (and delete debrebase-last). .Sp Reorganise the current branch so that the packaging changes come first, followed by the delta queue, turning \f(CW\*(C`\-@\-A\-1\-2\-B3\*(C'\fR into \f(CW\*(C`...@\-A\-B\-1\-2\-3\*(C'\fR. .Sp Drop pseudomerges and any quilt patch additions. .IP "Interactive rebase" 4 .IX Item "Interactive rebase" With a laundered branch, one can do an interactive git rebase of the delta queue. .IP "New upstream rebase" 4 .IX Item "New upstream rebase" Start rebasing onto a new upstream version, turning \f(CW\*(C`...#..@\-A\-B\-1\-2\-3\*(C'\fR into \f(CW\*(C`(...#..@\-A\-B\-, ...#\*(Aq\-)@\*(Aq\-1\-2\*(C'\fR. .Sp This has to be a wrapper around git-rebase, which prepares @' and then tries to rebase 1 2 onto @'. If the user asks for an interactive rebase, @' doesn't appear in the commit list, since @' is the newbase of the rebase (see \fIgit\-rebase\fR\|(1)). .Sp Note that the construction of @' cannot fail because @' simply copies debian/ from B and and everything else from #'. (Rebasing A and B is undesirable. We want the debian/ files to be non-rebasing so that git log shows the packaging history.) .IP "Stitch" 4 .IX Item "Stitch" Make a pseudomerge, whose contributing parent is the unstitched branch and whose overwritten parent is ffq-prev, consuming ffq-prev in the process (and writing debrebase-last instead). Ideally the contributing parent would be a laundered branch, or perhaps a laundered branch with a quilt patch addition commit. .IP "Commit quilt patches" 4 .IX Item "Commit quilt patches" To generate a tree which can be represented as a 3.0 (quilt) .dsc source package, the delta queue must be reified inside the git tree in \fBdebian/patches/\fR. These patch files can be stripped out and/or regenerated as needed. .SH "ILLEGAL OPERATIONS" .IX Header "ILLEGAL OPERATIONS" Some git operations are not permitted in this data model. Performing them will break git-debrebase. .IP "General merges" 4 .IX Item "General merges" See \*(L"\s-1OTHER MERGES\*(R"\s0, above. .IP "git-rebase starting too soon, or without base argument" 4 .IX Item "git-rebase starting too soon, or without base argument" git-rebase must not be invoked in such a way that the chosen base is before the anchor, or before the last pseudomerge. This is because git-rebase mangles merges. git rebase \-\-preserve\-merges is also dangerous. .Sp git-rebase without a base argument will often start too early. .Sp For these reasons, it is better to use git-debrebase and let it choose the base for your rebase. If you do realise you have made this mistake, it is best to use the reflog to recover to a suitable good previous state. .IP "Editing debian/patches" 4 .IX Item "Editing debian/patches" debian/patches is an output from git-debrebase, not an input. If you edit patches git-debrebase will complain and refuse to work. If you add patches your work is likely to be discarded. .Sp Instead of editing patches, use git-debrebase to edit the corresponding commits. .IP "Renaming (etc.) branch while unstitched" 4 .IX Item "Renaming (etc.) branch while unstitched" The previous \s-1HEAD,\s0 which will be pseudomerged over by operations like git-debrebase stitch, is recorded in a ref name dervied from your branch name. .Sp If you rename unstitched branches, this information can get out of step. .Sp Conversely, creating a new branch from an unstitched branch is good for making a branch to play about in, but the result cannot be stitched. .SH "COMMIT MESSAGE ANNOTATIONS" .IX Header "COMMIT MESSAGE ANNOTATIONS" git-debrebase makes annotations in the messages of commits it generates. .PP The general form is .PP .Vb 1 \& [git\-debrebase COMMIT\-TYPE [ ARGS...]: PROSE, MORE PROSE] .Ve .PP git-debrebase treats anything after the colon as a comment, paying no attention to \s-1PROSE.\s0 .PP The full set of annotations is: [git\-debrebase split: mixed commit, debian part] [git\-debrebase split: mixed commit, upstream\-part] [git\-debrebase onvert dgit import: debian changes] [git\-debrebase anchor: convert dgit import, upstream changes] .PP .Vb 4 \& [git\-debrebase upstream\-combine . PIECE[ PIECE...]: new upstream] \& [git\-debrebase anchor: new upstream NEW\-UPSTREAM\-VERSION, merge] \& [git\-debrebase changelog: new upstream NEW\-UPSTREAM\-VERSION] \& [git\-debrebase make\-patches: export and commit patches] \& \& [git\-debrebase convert\-from\-gbp: drop patches] \& [git\-debrebase anchor: declare upstream] \& [git\-debrebase pseudomerge: stitch] \& \& [git\-debrebase merged\-breakwater: constructed from vanilla merge] \& \& [git\-debrebase convert\-to\-gbp: commit patches] \& [git\-debrebase convert\-from\-dgit\-view upstream\-import\-convert: VERSION] \& [git\-debrebase convert\-from\-dgit\-view drop\-patches] .Ve .PP Only anchor merges have the \f(CW\*(C`[git\-debrebase anchor: ...]\*(C'\fR tag. Single-parent anchors are not generated by git-debrebase, and when made manually should not contain any \f(CW\*(C`[git\-debrebase ...]\*(C'\fR annotation. .PP The \f(CW\*(C`split mixed commit\*(C'\fR and \f(CW\*(C`convert dgit import\*(C'\fR tags are added to the pre-existing commit message, when git-debrebase rewrites the commit. .SH "APPENDIX \- DGIT IMPORT HANDLING" .IX Header "APPENDIX - DGIT IMPORT HANDLING" The dgit .dsc import format is not documented or specified (so some of the following terms are not defined anywhere). The dgit import format it is defined by the implementation in dgit, of which git-debrebase has special knowledge. .PP Consider a non-dgit \s-1NMU\s0 followed by a dgit \s-1NMU:\s0 .PP .Vb 10 \& interchange \-\-/\-\-B3!\-\-%\-\-//\-\-\-\-D*\-\-> \& / / \& % 4 \& / 3 \& / 2 \& / 1 \& 2 &_ \& / /| \e \& 1 0 00 =XBC% \& / \& / \& \-\-@\-\-A breakwater \& / \& \-\-#\-\-\-\-\-\-\-\-> upstream \& \& \& Supplementary key: \& \& =XBC% dgit tarball import of .debian.tar.gz containing \& Debian packaging including changes B C and quilt patches \& 0 dgit tarball import of upstream tarball \& 00 dgit tarball import of supplementary upstream piece \& &_ dgit import nearly\-breakwater\-anchor \& // dgit fetch / import\-dsc pseudomerge to make fast forward \& \& &\*(Aq git\-debrebase converted import (upstream files only) \& C\*(Aq git\-debrebase converted packaging change import \& \& * ** before and after HEAD .Ve .PP We want to transform this into: .IP "I. No new upstream version" 4 .IX Item "I. No new upstream version" .Vb 10 \& (0 + 00 eq #) \& \-\-/\-\-B3!\-\-%\-\-//\-\-\-\-\-D*\-\-\-\-\-\-\-\-\-\-\-\-\-/\-\-> \& / / / \& % 4 4** \& / 3 3 \& / 2 2 \& / 1 1 \& 2 &_ / \& / /| \e / \& 1 0 00 =XBC% / \& / / \& / / \& \-\-@\-\-A\-\-\-\-\-B\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-C\*(Aq\-\-\-D \& / \& \-\-#\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-> .Ve .IP "\s-1II.\s0 New upstream" 4 .IX Item "II. New upstream" .Vb 1 \& (0 + 00 neq #) \& \& \-\-/\-\-B3!\-\-%\-\-//\-\-\-\-\-D*\-\-\-\-\-\-\-\-\-\-\-\-\-/\-\-> \& / / / \& % 4 4** \& / 3 3 \& / 2 2 \& / 1 1 \& 2 &_ / \& / /| \e / \& 1 0 00 =XBC% / \& / / \& / / \& \-\-@\-\-A\-\-\-\-\-B\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-@\-\-\-C\*(Aq\-\-\-D \& / / \& \-\-#\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\-\- \- \- / \- \- \-\-\-\-\-\-\-\-\-> \& / \& &\*(Aq \& /| \& 0 00 .Ve .SH "SEE ALSO" .IX Header "SEE ALSO" \&\fIgit\-debrebase\fR\|(1), \&\fIdgit\-maint\-rebase\fR\|(7), \&\fIdgit\fR\|(1)