<br><br><div><span class="gmail_quote">On 4/21/06, <b class="gmail_sendername">hyeshik.chang</b> <<a href="mailto:python-3000-checkins@python.org">python-3000-checkins@python.org</a>> wrote:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
Author: hyeshik.chang<br>Date: Fri Apr 21 18:21:44 2006<br>New Revision: 45619<br><br>Modified:<br> python/branches/p3yk/Modules/cjkcodecs/multibytecodec.c<br>Log:<br>Add empty __init__ methods for stateful multibytecodec instances.
<br>This resolves a problem found by Thomas Wouters:<br><a href="http://mail.python.org/pipermail/python-dev/2006-April/064051.html">http://mail.python.org/pipermail/python-dev/2006-April/064051.html</a></blockquote><div>
<br>Thanks, but please don't "backport" from the p3yk-branch to the trunk. It makes merging harder. Not an issue for this fix, because the trunk-merge happened to be up-to-date, but it can make future merges 'orribly damned hard. If a fix applies to both the trunk and one or more branches (that are actively merged), only stuff it in the trunk, then merge the trunk changes into the branch. (Or get someone else to do it.)
<br><br>And just so everyone knows: done right, merging isn't hard. It's not as easy as it could be, but 'svn merge' makes it a lot easier than it used to be in CVS. Here's how you do it:<br></div><br>The last merged revision is stored in the branch, in a property called 'last_merge'; 'svn propget last_merge .' will show it. Right now, it's in human-readable format, partly because a branch off of p3yk would get the last_merge property branched, too, and then you lose track of which branch was merged when. If anyone wants to automate the merging process (not something I'd bother with, myself, since it usually requires too much manual merging anyway), make sure to support grepping for the right revision :) Also, 'last_merge' is a completely arbitrary propname.
<br><br>In a checked out and pristine p3yk branch, run 'svn merge -r <lastmerge>:<now> ../path/to/trunk'. 'path to trunk' can be a URL just as easily as a local path. 'svn merge' applies all changes (diffs, but also renames, deletes, property changes, etc) to the local working copy.
<br><br>Resolve the conflicts, configure, compile, make, make test, fix any test failures. When you're about to commit, 'svn propedit last_merge .', fill in the <now> you used in the merge, and 'svn commit' the whole lot.
<br><br>The <now> you use can be any revision, it doesn't have to be now. Also, svn merge sometimes can't deal with the trunk changes; for instance, the trunk had re.py removed and then sre.py renamed to re.py, and svn merge couldn't handle that in one go. Fortunately, 'svn merge' only applies changes locally. Tossing it all out is a matter of 'svn revert -R' or just deleting the working copy.
<br><br>I think Neal wants to keep the p3yk branch pretty up to date with the trunk, likely merging every week, and I think that's a very good idea. It makes merging much less painful ;P<br><br></div>-- <br>Thomas Wouters <
<a href="mailto:thomas@python.org">thomas@python.org</a>><br><br>Hi! I'm a .signature virus! copy me into your .signature file to help me spread!