1999-10-08 05:38:22 +08:00
|
|
|
This is the first file you should be reading after you get your CVS account.
|
|
|
|
We'll assume you're basically familiar with CVS, but feel free to post
|
2002-05-14 18:33:30 +08:00
|
|
|
your questions on the mailing list. Please have a look at
|
2002-05-14 02:09:56 +08:00
|
|
|
http://cvsbook.red-bean.com/ for more detailed information on CVS.
|
1999-10-08 05:38:22 +08:00
|
|
|
|
|
|
|
PHP is developed through the efforts of a large number of people.
|
|
|
|
Collaboration is a Good Thing(tm), and CVS lets us do this. Thus, following
|
|
|
|
some basic rules with regards to CVS usage will:
|
|
|
|
|
|
|
|
a. Make everybody happier, especially those responsible for maintaining
|
|
|
|
the CVS itself.
|
|
|
|
b. Keep the changes consistently well documented and easily trackable.
|
|
|
|
c. Prevent some of those 'Oops' moments.
|
|
|
|
d. Increase the general level of good will on planet Earth.
|
|
|
|
|
|
|
|
|
|
|
|
Having said that, here are the organizational rules:
|
|
|
|
|
|
|
|
1. Respect other people working on the project.
|
|
|
|
|
|
|
|
2. Discuss any significant changes on the list before committing.
|
|
|
|
|
2000-07-26 10:10:18 +08:00
|
|
|
3. Look at EXTENSIONS file to see who is the primary maintainer of
|
1999-10-08 05:38:22 +08:00
|
|
|
the code you want to contribute to.
|
|
|
|
|
|
|
|
4. If you "strongly disagree" about something another person did, don't
|
|
|
|
start fighting publicly - take it up in private email.
|
|
|
|
|
|
|
|
5. If you don't know how to do something, ask first!
|
|
|
|
|
|
|
|
6. Test your changes before committing them. We mean it. Really.
|
|
|
|
|
|
|
|
|
|
|
|
The next few rules are more of a technical nature.
|
|
|
|
|
2002-01-20 09:03:17 +08:00
|
|
|
1. DO NOT TOUCH ChangeLog! It is automagically updated from the commit
|
1999-10-08 05:38:22 +08:00
|
|
|
messages every day. Woe be to those who attempt to mess with it.
|
|
|
|
|
|
|
|
2. All news updates intended for public viewing, such as new features,
|
|
|
|
bug fixes, improvements, etc., should go into the NEWS file. Also see
|
|
|
|
the note below about automatically updating NEWS in your commit message.
|
|
|
|
|
|
|
|
3. Do not commit multiple file and dump all messages in one commit. If you
|
|
|
|
modified several unrelated files, commit each group separately and
|
|
|
|
provide a nice commit message for each one. See example below.
|
|
|
|
|
|
|
|
4. Do write your commit message in such a way that it makes sense even
|
|
|
|
without the corresponding diff. One should be able to look at it, and
|
|
|
|
immediately know what was modified. Definitely include the function name
|
|
|
|
in the message as shown below.
|
|
|
|
|
|
|
|
5. In your commit messages, keep each line shorter than 80 characters. And
|
1999-10-08 21:59:27 +08:00
|
|
|
try to align your lines vertically, if they wrap. It looks bad otherwise.
|
1999-10-08 05:38:22 +08:00
|
|
|
|
|
|
|
6. If you modified a function that is callable from PHP, prepend PHP to
|
|
|
|
the function name as shown below.
|
|
|
|
|
|
|
|
|
|
|
|
The format of the commit messages is pretty simple.
|
|
|
|
|
2002-10-31 22:55:51 +08:00
|
|
|
If a line begins with #, it is taken to be a comment and will not appear in
|
|
|
|
the ChangeLog. Everything else goes into the ChangeLog.
|
1999-10-08 21:59:27 +08:00
|
|
|
|
2002-10-31 22:55:51 +08:00
|
|
|
It is important to note that if your comment spans multiple lines, you have
|
|
|
|
to put # at the beginning of _every_ such line. Every entry in NEWS has to
|
|
|
|
have a name after it, so if you did it with someone's help, put both your
|
|
|
|
names there. Your name WILL NOT be automatically put at the end of the NEWS
|
|
|
|
entry - so, please provide it yourself.
|
1999-10-08 05:38:22 +08:00
|
|
|
|
|
|
|
Example. Say you modified two files, datetime.c and string.c. In datetime.c
|
|
|
|
you added a new format option for date() function, and in string.c you fixed
|
|
|
|
a memory leak in php_trim(). Don't commit both of these at once. Commit them
|
|
|
|
separately and try to make sure your commit messages look something like the
|
|
|
|
following.
|
|
|
|
|
|
|
|
For datetime.c:
|
|
|
|
|
|
|
|
(PHP date) Added new 'K' format modifier for printing out number of
|
1999-10-08 21:59:27 +08:00
|
|
|
days until New Year's Eve.
|
1999-10-08 05:38:22 +08:00
|
|
|
|
|
|
|
For string.c:
|
|
|
|
(php_trim) Fixed a memory leak resulting from improper use of zval_dtor().
|
|
|
|
# Man, that thing was leaking all over the place!
|
|
|
|
|
2002-10-31 22:55:51 +08:00
|
|
|
The lines above marked with # will be omitted from the ChangeLog.
|
|
|
|
Alternatively, you might want to add lines to the NEWS file directly.
|
1999-10-09 00:09:52 +08:00
|
|
|
|
2002-02-28 14:21:09 +08:00
|
|
|
If you fix some bugs, you should note the bug ID numbers in your
|
|
|
|
commit message. Bug ID should be prefixed by "#" for easier access to
|
|
|
|
bug report when developers are browsing CVS via. LXR or Bonsai.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
|
|
|
|
Fixed pgsql notice handler double free crash bug. Bug #14016
|
|
|
|
|
2002-10-31 22:55:51 +08:00
|
|
|
If you don't see your messages in ChangeLog right away, don't worry! These
|
|
|
|
files are updated once a day, so your stuff will not show up until somewhat
|
|
|
|
later. Please add an appropriate line in the NEWS file yourself.
|
1999-10-08 05:38:22 +08:00
|
|
|
|
1999-10-12 04:45:03 +08:00
|
|
|
You can use LXR (http://lxr.php.net/) and Bonsai (http://bonsai.php.net/)
|
|
|
|
to look at PHP CVS repository in various ways.
|
|
|
|
|
1999-10-09 02:05:59 +08:00
|
|
|
To receive daily updates to ChangeLog and NEWS, send an empty message to
|
|
|
|
php-cvs-daily-subscribe@lists.php.net.
|
|
|
|
|
1999-10-08 05:38:22 +08:00
|
|
|
Happy hacking,
|
|
|
|
|
|
|
|
PHP Team
|