mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 03:25:20 +00:00
docs: Improve patch submission guidelines
We should really advise (new) developers to send rebased patches that apply cleanly and use git-send-email rather than all other obscure ways.
This commit is contained in:
parent
1d9d5103b4
commit
a8d63a485e
39
HACKING
39
HACKING
@ -21,9 +21,46 @@ or:
|
|||||||
|
|
||||||
git diff > libvirt-myfeature.patch
|
git diff > libvirt-myfeature.patch
|
||||||
|
|
||||||
|
However, the usual workflow of libvirt developer is:
|
||||||
|
|
||||||
|
git checkout master
|
||||||
|
git pull
|
||||||
|
git checkout -t origin -b workbranch
|
||||||
|
Hack, committing any changes along the way
|
||||||
|
|
||||||
|
Then, when you want to post your patches:
|
||||||
|
|
||||||
|
git pull --rebase
|
||||||
|
(fix any conflicts)
|
||||||
|
git send-email --cover-letter --no-chain-reply-to --annotate --to=libvir-list@redhat.com master
|
||||||
|
|
||||||
|
For a single patch you can omit "--cover-letter", but series of a two or more
|
||||||
|
patches needs a cover letter. If you get tired of typing
|
||||||
|
"--to=libvir-list@redhat.com" designation you can set it in git config:
|
||||||
|
|
||||||
|
git config sendemail.to libvir-list@redhat.com
|
||||||
|
|
||||||
|
Please follow this as close as you can, especially the rebase and git
|
||||||
|
send-email part, as it makes life easier for other developers to review your
|
||||||
|
patch set. One should avoid sending patches as attachments, but rather send
|
||||||
|
them in email body along with commit message. If a developer is sending
|
||||||
|
another version of the patch (e.g. to address review comments), he is advised
|
||||||
|
to note differences to previous versions after the "---" line in the patch so
|
||||||
|
that it helps reviewers but doesn't become part of git history. Moreover, such
|
||||||
|
patch needs to be prefixed correctly with "--subject-prefix=PATCHv2" appended
|
||||||
|
to "git send-email" (substitute "v2" with the correct version if needed
|
||||||
|
though).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
(3) Split large changes into a series of smaller patches, self-contained if
|
(3) Split large changes into a series of smaller patches, self-contained if
|
||||||
possible, with an explanation of each patch and an explanation of how the
|
possible, with an explanation of each patch and an explanation of how the
|
||||||
sequence of patches fits together.
|
sequence of patches fits together. Moreover, please keep in mind that it's
|
||||||
|
required to be able to compile cleanly after each patch. A feature does not
|
||||||
|
have to work until the end of a series, as long as intermediate patches don't
|
||||||
|
cause test-suite failures.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
(4) Make sure your patches apply against libvirt GIT. Developers only follow GIT
|
(4) Make sure your patches apply against libvirt GIT. Developers only follow GIT
|
||||||
and don't care much about released versions.
|
and don't care much about released versions.
|
||||||
|
@ -20,10 +20,49 @@
|
|||||||
<pre>
|
<pre>
|
||||||
git diff > libvirt-myfeature.patch
|
git diff > libvirt-myfeature.patch
|
||||||
</pre>
|
</pre>
|
||||||
|
<p>However, the usual workflow of libvirt developer is:</p>
|
||||||
|
<pre>
|
||||||
|
git checkout master
|
||||||
|
git pull
|
||||||
|
git checkout -t origin -b workbranch
|
||||||
|
Hack, committing any changes along the way
|
||||||
|
</pre>
|
||||||
|
<p>Then, when you want to post your patches:</p>
|
||||||
|
<pre>
|
||||||
|
git pull --rebase
|
||||||
|
(fix any conflicts)
|
||||||
|
git send-email --cover-letter --no-chain-reply-to --annotate --to=libvir-list@redhat.com master
|
||||||
|
</pre>
|
||||||
|
<p>For a single patch you can omit <code>--cover-letter</code>, but
|
||||||
|
series of a two or more patches needs a cover letter. If you get tired
|
||||||
|
of typing <code>--to=libvir-list@redhat.com</code> designation you can
|
||||||
|
set it in git config:</p>
|
||||||
|
<pre>
|
||||||
|
git config sendemail.to libvir-list@redhat.com
|
||||||
|
</pre>
|
||||||
|
<p>Please follow this as close as you can, especially the rebase and
|
||||||
|
git send-email part, as it makes life easier for other developers to
|
||||||
|
review your patch set. One should avoid sending patches as attachments,
|
||||||
|
but rather send them in email body along with commit message. If a
|
||||||
|
developer is sending another version of the patch (e.g. to address
|
||||||
|
review comments), he is advised to note differences to previous
|
||||||
|
versions after the <code>---</code> line in the patch so that it helps
|
||||||
|
reviewers but doesn't become part of git history. Moreover, such patch
|
||||||
|
needs to be prefixed correctly with
|
||||||
|
<code>--subject-prefix=PATCHv2</code> appended to <code>git
|
||||||
|
send-email</code> (substitute <code>v2</code> with the correct
|
||||||
|
version if needed though).</p>
|
||||||
</li>
|
</li>
|
||||||
<li>Split large changes into a series of smaller patches, self-contained
|
|
||||||
if possible, with an explanation of each patch and an explanation of how
|
<li><p>Split large changes into a series of smaller patches,
|
||||||
the sequence of patches fits together.</li>
|
self-contained if possible, with an explanation of each patch and an
|
||||||
|
explanation of how the sequence of patches fits together. Moreover,
|
||||||
|
please keep in mind that it's required to be able to compile cleanly
|
||||||
|
after each patch. A feature does not have to work until the end of a
|
||||||
|
series, as long as intermediate patches don't cause test-suite
|
||||||
|
failures.</p>
|
||||||
|
</li>
|
||||||
|
|
||||||
<li>Make sure your patches apply against libvirt GIT. Developers
|
<li>Make sure your patches apply against libvirt GIT. Developers
|
||||||
only follow GIT and don't care much about released versions.</li>
|
only follow GIT and don't care much about released versions.</li>
|
||||||
<li><p>Run the automated tests on your code before submitting any changes.
|
<li><p>Run the automated tests on your code before submitting any changes.
|
||||||
|
Loading…
Reference in New Issue
Block a user