sort MANIFEST
[p5sagit/p5-mst-13.2.git] / pod / perlrepository.pod
index 80e2bf8..970d77c 100644 (file)
@@ -5,8 +5,8 @@ perlrepository - Using the Perl source repository
 =head1 SYNOPSIS
 
 All of Perl's source code is kept centrally in a Git repository. The
-repository contains many Perl revisions from Perl 1 onwards and all
-the revisions from Perforce, the version control system we were using
+repository contains many Perl revisions from Perl 1 onwards and all the
+revisions from Perforce, the version control system we were using
 previously. This repository is accessible in different ways.
 
 The full repository takes up about 80MB of disk space. A check out of
@@ -32,7 +32,7 @@ the repository using the Git protocol (which uses port 9418):
 
   git clone git://perl5.git.perl.org/perl.git perl-git
 
-This clones the repository and makes a local copy in the 'perl-git'
+This clones the repository and makes a local copy in the F<perl-git>
 directory.
 
 If your local network does not allow you to use port 9418, then you can
@@ -40,13 +40,13 @@ fetch a copy of the repository over HTTP (this is slower):
 
   git clone http://perl5.git.perl.org/perl.git perl-http
 
-This clones the repository and makes a local copy in the 'perl-http'
+This clones the repository and makes a local copy in the F<perl-http>
 directory.
 
 =head2 WRITE ACCESS TO THE REPOSITORY
 
-If you are a committer, then you can fetch a copy of the repository that
-you can push back on with:
+If you are a committer, then you can fetch a copy of the repository
+that you can push back on with:
 
   git clone ssh://perl5.git.perl.org/gitroot/perl.git perl-ssh
 
@@ -54,8 +54,8 @@ This clones the repository and makes a local copy in the 'perl-ssh'
 directory.
 
 If you clone using git, which is faster than ssh, then you will need to
-modify your config in order to enable pushing. Edit F<.git/config> where
-you will see something like:
+modify your config in order to enable pushing. Edit F<.git/config>
+where you will see something like:
 
   [remote "origin"]
   url = git://perl5.git.perl.org/perl.git
@@ -65,37 +65,42 @@ change that to something like this:
   [remote "origin"]
   url = ssh://perl5.git.perl.org/gitroot/perl.git
 
-NOTE: there are symlinks set up so that the /gitroot is actually optional.
+NOTE: there are symlinks set up so that the /gitroot is actually
+optional.
 
 You can also set up your user name and e-mail address. For example
 
   % git config user.name "Leon Brocard"
   % git config user.email acme@astray.com
 
-It is also possible to keep C<origin> as a git remote, and add a new remote for ssh access:
+It is also possible to keep C<origin> as a git remote, and add a new
+remote for ssh access:
 
   % git remote add camel user@camel:/gitroot/perl.git
 
-This allows you to update your local repository by pulling from C<origin>, which is faster and doesn't require you to authentify, and to push your changes back with the C<camel> remote:
+This allows you to update your local repository by pulling from
+C<origin>, which is faster and doesn't require you to authenticate, and
+to push your changes back with the C<camel> remote:
 
   % git fetch camel
   % git push camel
 
-The C<fetch> command just updates the C<camel> refs, as the objects themselves should have been fetched when pulling from C<origin>.
+The C<fetch> command just updates the C<camel> refs, as the objects
+themselves should have been fetched when pulling from C<origin>.
 
 =head1 OVERVIEW OF THE REPOSITORY
 
-Once you have changed into the repository directory, you can inspect it.
-
+Once you have changed into the repository directory, you can inspect
+it.
 
 After a clone the repository will contain a single local branch, which
-will be the current branch as well, as indicated by the asterix.
+will be the current branch as well, as indicated by the asterisk.
 
   % git branch
   * blead
 
-Using the -a switch to branch will also show the remote tracking branches in the
-repository:
+Using the -a switch to C<branch> will also show the remote tracking
+branches in the repository:
 
   % git branch -a
   * blead
@@ -103,47 +108,52 @@ repository:
     origin/blead
   ...
 
-The branches that begin with "origin" correspond to the "git remote" that
-you cloned from (which is named "origin"). Each branch on the remote will
-be exactly tracked by theses branches. You should NEVER do work on these
-remote tracking branches. You only ever do work in a local branch. Local
-branches can be configured to automerge (on pull) from a designated remote
-tracking branch. This is the case with the default branch C<blead> which
-will be configured to merge from the remote tracking branch
-C<origin/blead>.
+The branches that begin with "origin" correspond to the "git remote"
+that you cloned from (which is named "origin"). Each branch on the
+remote will be exactly tracked by theses branches. You should NEVER do
+work on these remote tracking branches. You only ever do work in a
+local branch. Local branches can be configured to automerge (on pull)
+from a designated remote tracking branch. This is the case with the
+default branch C<blead> which will be configured to merge from the
+remote tracking branch C<origin/blead>.
 
 You can see recent commits:
 
   % git log
 
-And pull new changes from the repository, and update your local repository
-(must be clean first)
+And pull new changes from the repository, and update your local
+repository (must be clean first)
 
   % git pull
 
-Assuming we are on the branch C<blead> immediately after a pull, this command
-would be more or less equivalent to:
+Assuming we are on the branch C<blead> immediately after a pull, this
+command would be more or less equivalent to:
 
   % git fetch
   % git merge origin/blead
 
-In fact if you want to update your local repository without touching your working
-directory you do:
+In fact if you want to update your local repository without touching
+your working directory you do:
 
   % git fetch
 
-And if you want to update your remote-tracking branches for all defined remotes
-simultaneously you can do
+And if you want to update your remote-tracking branches for all defined
+remotes simultaneously you can do
 
   % git remote update
 
-Neither of these last two commands will update your working directory, however
-both will update the remote-tracking branches in your repository.
+Neither of these last two commands will update your working directory,
+however both will update the remote-tracking branches in your
+repository.
 
 To switch to another branch:
 
   % git checkout origin/maint-5.8-dor
 
+To make a local branch of a remote branch:
+
+  % git checkout -b maint-5.10 origin/maint-5.10
+
 To switch back to blead:
 
   % git checkout blead
@@ -154,11 +164,11 @@ The most common git command you will use will probably be
 
   % git status
 
-This command will produce as output a description of the current state of the
-repository, including modified files and unignored untracked files, and in addition
-it will show things like what files have been staged for the next commit,
-and usually some useful information about how to change things. For instance the
-following:
+This command will produce as output a description of the current state
+of the repository, including modified files and unignored untracked
+files, and in addition it will show things like what files have been
+staged for the next commit, and usually some useful information about
+how to change things. For instance the following:
 
   $ git status
   # On branch blead
@@ -179,13 +189,14 @@ following:
   #
   #       deliberate.untracked
 
-This shows that there were changes to this document staged for commit, and
-that there were further changes in the working directory not yet staged. It
-also shows that there was an untracked file in the working directory, and as
-you can see shows how to change all of this. It also shows that there
-is one commit on the  working branch C<blead> which has not been pushed to the
-C<origin> remote yet. B<NOTE>: that this output is also what you see as a
-template if you do not provide a message to C<git commit>.
+This shows that there were changes to this document staged for commit,
+and that there were further changes in the working directory not yet
+staged. It also shows that there was an untracked file in the working
+directory, and as you can see shows how to change all of this. It also
+shows that there is one commit on the  working branch C<blead> which
+has not been pushed to the C<origin> remote yet. B<NOTE>: that this
+output is also what you see as a template if you do not provide a
+message to C<git commit>.
 
 Assuming we commit all the mentioned changes above:
 
@@ -206,8 +217,9 @@ We can re-run git status and see something like this:
   nothing added to commit but untracked files present (use "git add" to track)
 
 
-When in doubt, before you do anything else, check your status and read it
-carefully, many questions are answered directly by the git status output.
+When in doubt, before you do anything else, check your status and read
+it carefully, many questions are answered directly by the git status
+output.
 
 =head1 SUBMITTING A PATCH
 
@@ -220,15 +232,19 @@ Then change into the directory:
 
   % cd perl-git
 
-Alternatively, if you already have a Perl repository, you should
-ensure that you're on the I<blead> branch, and your repository
-is up to date:
+Alternatively, if you already have a Perl repository, you should ensure
+that you're on the I<blead> branch, and your repository is up to date:
 
   % git checkout blead
   % git pull
 
-Now that we have everything up to date, we need to create a temporary new
-branch for these changes and switch into it:
+(It's preferable to patch against the latest blead version, since patches
+are usually integrated from blead to the maintainance branches. This
+does not apply, obviously, in the rare case where your patch is specific
+to a maintaince release.)
+
+Now that we have everything up to date, we need to create a temporary
+new branch for these changes and switch into it:
 
   % git checkout -b orange
 
@@ -245,7 +261,7 @@ to Orange Brocard, we should change his name in the AUTHORS file:
 You can see what files are changed:
 
   % git status
-  # On branch blead
+  # On branch orange
   # Changes to be committed:
   #   (use "git reset HEAD <file>..." to unstage)
   #
@@ -294,6 +310,115 @@ If you want to delete your temporary branch, you may do so with:
   % git branch -D orange
   Deleted branch orange.
 
+=head2 A note on derived files
+
+Be aware that many files in the distribution are derivative--avoid
+patching them, because git won't see the changes to them, and the
+build process will overwrite them.
+Patch the originals instead.  Most utilities (like perldoc) are in
+this category, i.e. patch utils/perldoc.PL rather than utils/perldoc.
+Similarly, don't create patches for files under $src_root/ext from
+their copies found in $install_root/lib.  If you are unsure about the
+proper location of a file that may have gotten copied while building
+the source distribution, consult the C<MANIFEST>.
+
+=head2 A note on binary files
+
+Since the patch(1) utility cannot deal with binary files, it's important
+that you either avoid the use of binary files in your patch, generate the
+files dynamically, or that you encode any binary files using the
+F<uupacktool.pl> utility.
+
+Assuming you needed to include a gzip-encoded file for a module's test
+suite, you might do this as follows using the F<uupacktool.pl> utility:
+
+    $ perl uupacktool.pl -v -p -D lib/Some/Module/t/src/t.gz
+    Writing lib/Some/Module/t/src/t.gz into lib/Some/Module/t/src/t.gz.packed
+
+This will replace the C<t.gz> file with an encoded counterpart. During
+C<make test>, before any tests are run, perl's Makefile will restore all
+the C<.packed> files mentioned in the MANIFEST to their original name.
+This means that the test suite does not need to be aware of this packing
+scheme and will not need to be altered.
+
+=head2 Getting your patch accepted
+
+The first thing you should include with your patch is a description of the
+problem that the patch corrects.  If it is a code patch (rather than a
+documentation patch) you should also include a small test case that
+illustrates the bug (a patch to an existing test file is preferred).
+
+If you are submitting a code patch there are several other things that
+you need to do.
+
+=over 4
+
+=item Comments, Comments, Comments
+
+Be sure to adequately comment your code.  While commenting every
+line is unnecessary, anything that takes advantage of side effects of
+operators, that creates changes that will be felt outside of the
+function being patched, or that others may find confusing should
+be documented.  If you are going to err, it is better to err on the
+side of adding too many comments than too few.
+
+=item Style
+
+In general, please follow the particular style of the code you are patching.
+
+In particular, follow these general guidelines for patching Perl sources:
+
+    8-wide tabs (no exceptions!)
+    4-wide indents for code, 2-wide indents for nested CPP #defines
+    try hard not to exceed 79-columns
+    ANSI C prototypes
+    uncuddled elses and "K&R" style for indenting control constructs
+    no C++ style (//) comments
+    mark places that need to be revisited with XXX (and revisit often!)
+    opening brace lines up with "if" when conditional spans multiple
+        lines; should be at end-of-line otherwise
+    in function definitions, name starts in column 0 (return value is on
+        previous line)
+    single space after keywords that are followed by parens, no space
+        between function name and following paren
+    avoid assignments in conditionals, but if they're unavoidable, use
+        extra paren, e.g. "if (a && (b = c)) ..."
+    "return foo;" rather than "return(foo);"
+    "if (!foo) ..." rather than "if (foo == FALSE) ..." etc.
+
+=item Testsuite
+
+When submitting a patch you should make every effort to also include
+an addition to perl's regression tests to properly exercise your
+patch.  Your testsuite additions should generally follow these
+guidelines (courtesy of Gurusamy Sarathy <gsar@activestate.com>):
+
+    Know what you're testing.  Read the docs, and the source.
+    Tend to fail, not succeed.
+    Interpret results strictly.
+    Use unrelated features (this will flush out bizarre interactions).
+    Use non-standard idioms (otherwise you are not testing TIMTOWTDI).
+    Avoid using hardcoded test numbers whenever possible (the
+      EXPECTED/GOT found in t/op/tie.t is much more maintainable,
+      and gives better failure reports).
+    Give meaningful error messages when a test fails.
+    Avoid using qx// and system() unless you are testing for them.  If you
+      do use them, make sure that you cover _all_ perl platforms.
+    Unlink any temporary files you create.
+    Promote unforeseen warnings to errors with $SIG{__WARN__}.
+    Be sure to use the libraries and modules shipped with the version
+      being tested, not those that were already installed.
+    Add comments to the code explaining what you are testing for.
+    Make updating the '1..42' string unnecessary.  Or make sure that
+      you update it.
+    Test _all_ behaviors of a given operator, library, or function:
+      - All optional arguments
+      - Return values in various contexts (boolean, scalar, list, lvalue)
+      - Use both global and lexical variables
+      - Don't forget the exceptional, pathological cases.
+
+=back
+
 =head1 ACCEPTING A PATCH
 
 If you have received a patch file generated using the above section,
@@ -304,12 +429,14 @@ switch into it:
 
   % git checkout -b experimental
 
-Patches that were formatted by C<git format-patch> are applied with C<git am>:
+Patches that were formatted by C<git format-patch> are applied with
+C<git am>:
 
   % git am 0001-Rename-Leon-Brocard-to-Orange-Brocard.patch
   Applying Rename Leon Brocard to Orange Brocard
 
-If just a raw diff is provided, it is also possible use this two-step process:
+If just a raw diff is provided, it is also possible use this two-step
+process:
 
   % git apply bugfix.diff
   % git commit -am "Some fixing" --author="That Guy <that.guy@internets.com>"
@@ -357,7 +484,8 @@ If you want to delete your temporary branch, you may do so with:
 
 =head1 CLEANING A WORKING DIRECTORY
 
-The command C<git clean> can with varying arguments be used as a replacement for make-clean.
+The command C<git clean> can with varying arguments be used as a
+replacement for make-clean.
 
 To reset your working directory to a pristine condition you can do:
 
@@ -367,14 +495,23 @@ However, be aware this will delete ALL untracked content. You can use
 
   git clean -Xf
 
-to remove all ignored untracked files, such as build and test byproduct, but leave any 
-manually created files alone.
+to remove all ignored untracked files, such as build and test
+byproduct, but leave any  manually created files alone.
+
+If you only want to cancel some uncommitted edits, you can use
+C<git checkout> and give it a list of files to be reverted.
+
+If you want to cancel one or several commits, you can use C<git reset>.
 
 =head1 BISECTING
 
-C<git> provides a built-in way to determine, with a binary search in the history, which commit should be blamed for introducing a given bug.
+C<git> provides a built-in way to determine, with a binary search in
+the history, which commit should be blamed for introducing a given bug.
 
-Suppose that we have a script F<~/testcase.pl> that exits with C<0> when some behaviour is correct, and with C<1> when it's faulty. We need an helper script that automates building C<perl> and running the testcase:
+Suppose that we have a script F<~/testcase.pl> that exits with C<0>
+when some behaviour is correct, and with C<1> when it's faulty. We need
+an helper script that automates building C<perl> and running the
+testcase:
 
   % cat ~/run
   #!/bin/sh
@@ -384,19 +521,23 @@ Suppose that we have a script F<~/testcase.pl> that exits with C<0> when some be
   make || exit 125
   ./perl -Ilib ~/testcase.pl
 
-This script may return C<125> to indicate that the corresponding commit should be skipped. Otherwise, it returns the status of F<~/testcase.pl>.
+This script may return C<125> to indicate that the corresponding commit
+should be skipped. Otherwise, it returns the status of
+F<~/testcase.pl>.
 
 We first enter in bisect mode with:
 
   % git bisect start
 
-For example, if the bug is present on C<HEAD> but wasn't in 5.10.0, C<git> will learn about this when you enter:
+For example, if the bug is present on C<HEAD> but wasn't in 5.10.0,
+C<git> will learn about this when you enter:
 
   % git bisect bad
   % git bisect good perl-5.10.0
   Bisecting: 853 revisions left to test after this
 
-This results in checking out the median commit between C<HEAD> and C<perl-5.10.0>. We can then run the bisecting process with:
+This results in checking out the median commit between C<HEAD> and
+C<perl-5.10.0>. We can then run the bisecting process with:
 
   % git bisect run ~/run
 
@@ -412,8 +553,36 @@ When the first bad commit is isolated, C<git bisect> will tell you so:
 
   bisect run success
 
-You can peek into the bisecting process with C<git bisect log> and C<git bisect visualize>. C<git bisect reset> will get you out of bisect mode.
+You can peek into the bisecting process with C<git bisect log> and
+C<git bisect visualize>. C<git bisect reset> will get you out of bisect
+mode.
+
+Please note that the first C<good> state must be an ancestor of the
+first C<bad> state. If you want to search for the commit that I<solved>
+some bug, you have to negate your test case (i.e. exit with C<1> if OK
+and C<0> if not) and still mark the lower bound as C<good> and the
+upper as C<bad>. The "first bad commit" has then to be understood as
+the "first commit where the bug is solved".
+
+C<git help bisect> has much more information on how you can tweak your
+binary searches.
+
+=head1 COMITTING TO MAINTENANCE VERSIONS
+
+To commit to a maintenance version of perl, you need to create a local
+tracking branch:
+
+  % git checkout --track -b maint-5.005 origin/maint-5.005
+
+This creates a local branch named C<maint-5.005>, which tracks the remote
+branch C<origin/maint-5.005>. Then you can pull, commit, merge and push as
+before.
+
+You can also cherry-pick commits from blead and another branch, by
+using the C<git cherry-pick> command. It is recommended to use the B<-x>
+option to C<git cherry-pick> in order to record the SHA1 of the original
+commit in the new commit message.
 
-Please note that the first C<good> state must be an ancestor of the first C<bad> state. If you want to search for the commit that I<solved> some bug, you have to negate your test case (i.e. exit with C<1> if OK and C<0> if not) and still mark the lower bound as C<good> and the upper as C<bad>. The "first bad commit" has then to be understood as the "first commit where the bug is solved".
+=head1 SEE ALSO
 
-C<git help bisect> has much more information on how you can tweak your binary searches.
+The git documentation, accessible via C<git help command>.