X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=dgit.git;a=blobdiff_plain;f=dgit.1;h=c2541f0eb8163a8c8ffafff0f288bf634c4628ff;hp=cc10695a636897e045ad2fc1cbd376187cca989d;hb=b0e8004aa91bc35ab21a195ed3696134b102427a;hpb=5076ec43032fe6a533718399006985d9b229b36a diff --git a/dgit.1 b/dgit.1 index cc10695a..c2541f0e 100644 --- a/dgit.1 +++ b/dgit.1 @@ -155,6 +155,9 @@ the built source package not being identical to the git tree. In more detail: dgit push checks that the current HEAD corresponds to the .dsc. It then pushes the HEAD to the suite's dgit-repos branch, +adjusts the .changes to include any .origs which the archive lacks +and exclude .origs which the archive has +(so -sa and -sd are not needed when building for dgit push), makes a signed git tag, edits the .dsc to contain the dgit metadata field, runs debsign to sign the upload (.dsc and .changes), pushes the signed tag, and finally uses dput to upload the .changes to the @@ -237,6 +240,33 @@ other kinds of more exotic history. If dgit can't find a suitable linearisation of your history, by default it will fail, but you can ask it to generate a single squashed patch instead. .TP +.BI "dgit import-dsc " ../path/to/.dsc branch +Import a Debian-format source package, +specified by its .dsc, +into git, +the way dgit fetch would do. + +This does about half the work of dgit fetch: +it will convert the .dsc into a new, orphan git branch. +Since dgit has no access to a corresponding source package archive +or knowledge of the history +it does not consider whether this version is newer +than any previous import +or corresponding git branches; +and it therefore does not +make a pseudomerge to bind the import +into any existing git history. + +If +.I branch +does not start with refs/, refs/heads/ is prepended. +The specified branch is unconditionally updated. + +If the specified .dsc contains a Dgit field, +dgit will simply make a branch of that commit. +If you cannot manage to find that commit anywhere, +consider --force-import-dsc-with-dgit-field. +.TP .B dgit version Prints version information and exits. .TP @@ -591,7 +621,11 @@ Specifies a single additional option to pass, eventually, to dpkg-genchanges. Options which are safe to pass include -.BR "-si -sa -sd -C" . +.BR -C +(and also +.BR "-si -sa -sd" +although these should never be necessary with Debian since dgit +automatically calculates whether .origs need to be uploaded.) For other options the caveat below applies. .TP @@ -730,6 +764,13 @@ These options are provided as an escape hatch, in case dgit is confused. (They might also be useful for testing error cases.) .TP +.B --import-dsc-with-dgit-field +Tell dgit import-dsc to treat a .dsc with a Dgit field +like one without it. +The result is a fresh import, +discarding the git history +that the person who pushed that .dsc was working with. +.TP .B --force-unrepresentable Carry on even if dgit thinks that your git tree contains changes @@ -737,6 +778,11 @@ dgit thinks that your git tree contains changes which dpkg-source is not able to represent. Your build or push will probably fail later. .TP +.B --force-changes-origs-exactly +Use the set of .origs specified in your .changes, exactly, +without regard to what is in the archive already. +The archive may well reject your upload. +.TP .B --force-unsupported-source-format Carry on despite dgit not understanding your source package format. dgit will probably mishandle it.