parrotcode: Parrot Submission Instructions | |
Contents | Documentation |
docs/submissions.pod - Parrot Submission Instructions
How to submit bug reports, patches and new files to Parrot.
If you encounter an error while working with Parrot, and don't understand what is causing it, then submit a bug report using the parrotbug utility. The simplest way to use it is to run
% ./parrotbug
in the distribution's root directory, and follow the prompts.
However, if you do know how to fix the problem you encountered, then think about submitting a patch, or (see below) getting commit privileges.
Try to keep your patches specific to a single change, and ensure that your change does not break any tests. Do this by running make test
. If there is no test for the fixed bug, please provide one.
In the following examples, parrot contains the Parrot distribution, and workingdir contains parrot. The name workingdir is just a placeholder for whatever the distribution's parent directory is called on your machine.
workingdir
|
+--> parrot
|
+--> LICENSE
|
+--> src
|
+--> tools
|
+--> ...
svn
svn diff
. cd parrot
svn status
svn diff > my_contribution.patch
diff
diff
for each file. The diff
should be created in parrot. Please be sure to create a unified diff, with diff -u
. cd parrot
diff -u docs/submissions.pod docs/submissions.new > submissions.patch
-ub
.diff
diff
on the two directories to create your patch. The diff
should be created in workingdir. cd workingdir
diff -ur --exclude='.svn' parrot parrot.new > docs.patch
--exclude=.DS_Store
.CREDITS
Prefix it with a [PATCH]
identifier.
diffstat(1)
utility when run on your patch(s) may be included at the bottom of the message body.Double-check that you've actually done this, because it's easy to forget.
DO NOT paste the patch file content into the body of the message.
You may wish to apply a patch submitted by someone else before the patch is incorporated into SVN.
For single diff
patches or svn
patches, copy the patch file to parrot, and run:
cd parrot
patch -p0 < some.patch
For recursive diff
patches, copy the patch file to workingdir, and run:
cd workingdir
patch -p0 < some.patch
In order to be on the safe side run 'make test' before actually committing the changes.
Sometimes new files will be created in the configuration and build process of Parrot. These files should not show up when checking the distribution with
svn status
or
perl tools/dev/manicheck.pl
The list of these ignore files can be set up with:
svn propedit svn:ignore <PATH>
In order to keep the two different checks synchronized, the MANIFEST and MANIFEST.SKIP file should be regenerated with:
perl tools/dev/mk_manifest_and_skip.pl
If you have a new feature to add to Parrot, such as a new test.
.t
, some mailers may become confused and consider it an application/x-troff. One way around this (for *nix users) is to diff the file against /dev/null like this: cd parrot
diff -u /dev/null newfile.t > newfile.patch
Prefix it with a [NEW]
identifier.
diffstat(1)
utility when run on your patch(es).Double-check that you've actually done this, because it's easy to forget.
DO NOT paste the content of the new file or files into the body of the message.
RT creates a ticket for the submission, and you will receive an automatic reply with details of the ticket identifier. This identifier should be used in all further correspondence concerning the submission.
Everyone on the list sees the submission, and can comment on it. A developer with SVN commit authority will commit it to SVN once it is clear that it is the right thing to do.
Even developers with SVN commit authority stick to this scheme for larger or more complex changes, to allow time for peer review.
You can check the progress of your submission at the Parrot bugs page http://bugs6.perl.org/. If you have trouble logging in try username guest
with password guest
.
A Parrot Bug Summary page is also available from https://rt.perl.org/rt3/NoAuth/parrot/Overview.html
A list of all the unresolved patches is at http://www.parrotcode.org/openpatches.html
The sources for http://www.parrotcode.org are managed in a subversion repository. The repository can be fetched from https://svn.perl.org/perl.org/docs/live/parrotcode/. A read only copy can be retrieved with 'guest/guest'.
You will notice that some of the content is generated directly from the Parrot repository. So the usual rules for Parrot patches apply for this content.
For changes specific for parrotcode.org please send patches to webmaster at perl dot org, and cc parrot-porters at perl dot org.
If you are interested in getting commit privileges to Parrot, here is the procedure:
http://www.perlfoundation.org/contributor_license_agreement
parrot-porters
mailing list, or via IRC (#parrot on irc.perl.org). The existing commiters will discuss your request in the next couple of weeks.If approved, a metacommiter will update the permissions to allow you to commit to Parrot; see RESPONSIBLE_PARTIES
for the current list. Welcome aboard!
Thanks for your help!
Adapted by Michael Scott from a tutorial submitted by Aldo Calpini, with some additional remarks from Bruce Gray.
|