[Python-checkins] r67948 - in python/branches/py3k: Doc/Makefile Doc/README.txt Doc/c-api/arg.rst Doc/license.rst Doc/tools/sphinx-web.py Doc/tools/sphinxext/download.html Doc/tutorial/controlflow.rst Doc/using/unix.rst Lib/distutils/command/register.py Lib/distutils/config.py Lib/distutils/tests/test_config.py Lib/distutils/tests/test_register.py Lib/io.py Lib/lib2to3/main.py Lib/test/pickletester.py Lib/test/test_io.py Misc/developers.txt Modules/_testcapimodule.c Python/getargs.c

benjamin.peterson python-checkins at python.org
Sat Dec 27 17:00:55 CET 2008


Author: benjamin.peterson
Date: Sat Dec 27 17:00:54 2008
New Revision: 67948
Log:
Merged revisions 67889-67892,67895,67898,67904-67907,67912,67918,67920-67921,67923-67924,67926-67927,67930,67943 via svnmerge from 
svn+ssh://pythondev@svn.python.org/python/trunk
................
 r67889 | benjamin.peterson | 2008年12月20日 19:04:32 -0600 (2008年12月20日) | 1 line
 
 sphinx.web is long gone
................
 r67890 | benjamin.peterson | 2008年12月20日 19:12:26 -0600 (2008年12月20日) | 1 line
 
 update readme
................
 r67891 | benjamin.peterson | 2008年12月20日 19:14:47 -0600 (2008年12月20日) | 1 line
 
 there are way too many places which need to have the current version added
................
 r67892 | benjamin.peterson | 2008年12月20日 19:29:32 -0600 (2008年12月20日) | 9 lines
 
 Merged revisions 67809 via svnmerge from 
 svn+ssh://pythondev@svn.python.org/sandbox/trunk/2to3/lib2to3
 
 ........
 r67809 | benjamin.peterson | 2008年12月15日 21:54:45 -0600 (2008年12月15日) | 1 line
 
 fix logic error
 ........
................
 r67895 | neal.norwitz | 2008年12月21日 08:28:32 -0600 (2008年12月21日) | 2 lines
 
 Add Tarek for work on distutils.
................
 r67898 | benjamin.peterson | 2008年12月21日 15:00:53 -0600 (2008年12月21日) | 1 line
 
 compute DISTVERSION with patchlevel.py
................
 r67904 | benjamin.peterson | 2008年12月22日 14:44:58 -0600 (2008年12月22日) | 1 line
 
 less attitude
................
 r67905 | benjamin.peterson | 2008年12月22日 14:51:15 -0600 (2008年12月22日) | 1 line
 
 fix #4720: the format to PyArg_ParseTupleAndKeywords can now start with '|'
................
 r67906 | benjamin.peterson | 2008年12月22日 14:52:53 -0600 (2008年12月22日) | 1 line
 
 add NEWS note
................
 r67907 | benjamin.peterson | 2008年12月22日 16:12:19 -0600 (2008年12月22日) | 1 line
 
 silence compiler warning
................
 r67912 | georg.brandl | 2008年12月23日 06:37:21 -0600 (2008年12月23日) | 2 lines
 
 Fix missing "svn" command.
................
 r67918 | georg.brandl | 2008年12月23日 09:44:25 -0600 (2008年12月23日) | 2 lines
 
 Markup fix.
................
 r67920 | benjamin.peterson | 2008年12月23日 14:09:28 -0600 (2008年12月23日) | 1 line
 
 use a global variable, so the compiler doesn't optimize the assignment out
................
 r67921 | benjamin.peterson | 2008年12月23日 14:12:33 -0600 (2008年12月23日) | 1 line
 
 make global static
................
 r67923 | benjamin.peterson | 2008年12月24日 09:10:27 -0600 (2008年12月24日) | 1 line
 
 #4736 BufferRWPair.closed shouldn't try to call another property as a function
................
 r67924 | benjamin.peterson | 2008年12月24日 10:10:05 -0600 (2008年12月24日) | 1 line
 
 pretend exceptions don't exist a while longer
................
 r67926 | tarek.ziade | 2008年12月24日 13:10:05 -0600 (2008年12月24日) | 1 line
 
 fixed #4400 : distutils .pypirc default generated file was broken.
................
 r67927 | benjamin.peterson | 2008年12月26日 17:26:30 -0600 (2008年12月26日) | 1 line
 
 python version is included in file name now
................
 r67930 | hirokazu.yamamoto | 2008年12月26日 22:19:48 -0600 (2008年12月26日) | 2 lines
 
 Issue #4740: Use HIGHEST_PROTOCOL in pickle test.
 (There is no behavior difference in 2.x because HIGHEST_PROTOCOL == 2)
................
 r67943 | alexandre.vassalotti | 2008年12月27日 04:02:59 -0600 (2008年12月27日) | 2 lines
 
 Fix bogus unicode tests in pickletester.
................
Added:
 python/branches/py3k/Lib/distutils/tests/test_register.py
 - copied unchanged from r67930, /python/trunk/Lib/distutils/tests/test_register.py
Removed:
 python/branches/py3k/Doc/tools/sphinx-web.py
Modified:
 python/branches/py3k/ (props changed)
 python/branches/py3k/Doc/Makefile
 python/branches/py3k/Doc/README.txt
 python/branches/py3k/Doc/c-api/arg.rst
 python/branches/py3k/Doc/license.rst
 python/branches/py3k/Doc/tools/sphinxext/download.html
 python/branches/py3k/Doc/tutorial/controlflow.rst
 python/branches/py3k/Doc/using/unix.rst
 python/branches/py3k/Lib/distutils/command/register.py
 python/branches/py3k/Lib/distutils/config.py
 python/branches/py3k/Lib/distutils/tests/test_config.py
 python/branches/py3k/Lib/io.py
 python/branches/py3k/Lib/lib2to3/main.py
 python/branches/py3k/Lib/test/pickletester.py
 python/branches/py3k/Lib/test/test_io.py
 python/branches/py3k/Misc/developers.txt
 python/branches/py3k/Modules/_testcapimodule.c
 python/branches/py3k/Python/getargs.c
Modified: python/branches/py3k/Doc/Makefile
==============================================================================
--- python/branches/py3k/Doc/Makefile	(original)
+++ python/branches/py3k/Doc/Makefile	Sat Dec 27 17:00:54 2008
@@ -9,7 +9,7 @@
 SPHINXOPTS =
 PAPER =
 SOURCES =
-DISTVERSION =
+DISTVERSION = $(shell $(PYTHON) tools/sphinxext/patchlevel.py)
 
 ALLSPHINXOPTS = -b $(BUILDER) -d build/doctrees -D latex_paper_size=$(PAPER) \
 $(SPHINXOPTS) . build/$(BUILDER) $(SOURCES)
@@ -111,33 +111,33 @@
 
 	# archive the HTML
 	make html
-	cp -pPR build/html dist/python$(DISTVERSION)-docs-html
-	tar -C dist -cf dist/python$(DISTVERSION)-docs-html.tar python$(DISTVERSION)-docs-html
-	bzip2 -9 -k dist/python$(DISTVERSION)-docs-html.tar
-	(cd dist; zip -q -r -9 python$(DISTVERSION)-docs-html.zip python$(DISTVERSION)-docs-html)
-	rm -r dist/python$(DISTVERSION)-docs-html
-	rm dist/python$(DISTVERSION)-docs-html.tar
+	cp -pPR build/html dist/python-$(DISTVERSION)-docs-html
+	tar -C dist -cf dist/python-$(DISTVERSION)-docs-html.tar python-$(DISTVERSION)-docs-html
+	bzip2 -9 -k dist/python-$(DISTVERSION)-docs-html.tar
+	(cd dist; zip -q -r -9 python-$(DISTVERSION)-docs-html.zip python-$(DISTVERSION)-docs-html)
+	rm -r dist/python-$(DISTVERSION)-docs-html
+	rm dist/python-$(DISTVERSION)-docs-html.tar
 
 	# archive the text build
 	make text
-	cp -pPR build/text dist/python$(DISTVERSION)-docs-text
-	tar -C dist -cf dist/python$(DISTVERSION)-docs-text.tar python$(DISTVERSION)-docs-text
-	bzip2 -9 -k dist/python$(DISTVERSION)-docs-text.tar
-	(cd dist; zip -q -r -9 python$(DISTVERSION)-docs-text.zip python$(DISTVERSION)-docs-text)
-	rm -r dist/python$(DISTVERSION)-docs-text
-	rm dist/python$(DISTVERSION)-docs-text.tar
+	cp -pPR build/text dist/python-$(DISTVERSION)-docs-text
+	tar -C dist -cf dist/python-$(DISTVERSION)-docs-text.tar python-$(DISTVERSION)-docs-text
+	bzip2 -9 -k dist/python-$(DISTVERSION)-docs-text.tar
+	(cd dist; zip -q -r -9 python-$(DISTVERSION)-docs-text.zip python-$(DISTVERSION)-docs-text)
+	rm -r dist/python-$(DISTVERSION)-docs-text
+	rm dist/python-$(DISTVERSION)-docs-text.tar
 	
 	# archive the A4 latex
 	-rm -r build/latex
 	make latex PAPER=a4
 	(cd build/latex; make clean && make all-pdf && make FMT=pdf zip bz2)
-	cp build/latex/docs-pdf.zip dist/python$(DISTVERSION)-docs-pdf-a4.zip
-	cp build/latex/docs-pdf.tar.bz2 dist/python$(DISTVERSION)-docs-pdf-a4.tar.bz2
+	cp build/latex/docs-pdf.zip dist/python-$(DISTVERSION)-docs-pdf-a4.zip
+	cp build/latex/docs-pdf.tar.bz2 dist/python-$(DISTVERSION)-docs-pdf-a4.tar.bz2
 
 	# archive the letter latex
 	rm -r build/latex
 	make latex PAPER=letter
 	(cd build/latex; make clean && make all-pdf && make FMT=pdf zip bz2)
-	cp build/latex/docs-pdf.zip dist/python$(DISTVERSION)-docs-pdf-letter.zip
-	cp build/latex/docs-pdf.tar.bz2 dist/python$(DISTVERSION)-docs-pdf-letter.tar.bz2
+	cp build/latex/docs-pdf.zip dist/python-$(DISTVERSION)-docs-pdf-letter.zip
+	cp build/latex/docs-pdf.tar.bz2 dist/python-$(DISTVERSION)-docs-pdf-letter.tar.bz2
 
Modified: python/branches/py3k/Doc/README.txt
==============================================================================
--- python/branches/py3k/Doc/README.txt	(original)
+++ python/branches/py3k/Doc/README.txt	Sat Dec 27 17:00:54 2008
@@ -81,8 +81,7 @@
 
 svn co http://svn.python.org/projects/doctools/trunk/sphinx tools/sphinx
 
-Then, you need to install Docutils 0.4 (the SVN snapshot won't work), either
-by checking it out via ::
+Then, you need to install Docutils, either by checking it out via ::
 
 svn co http://svn.python.org/projects/external/docutils-0.4/docutils tools/docutils
 
@@ -99,19 +98,18 @@
 
 python tools/sphinx-build.py -b<builder> . build/<outputdirectory>
 
-where `<builder>` is one of html, web or htmlhelp (for explanations see the make
-targets above).
+where `<builder>` is one of html, text, latex, or htmlhelp (for explanations see
+the make targets above).
 
 
 Contributing
 ============
 
-For bugs in the content, the online version at http://docs.python.org/ has a
-"suggest change" facility that can be used to correct errors in the source text
-and submit them as a patch to the maintainers.
+Bugs in the content should be reported to the Python bug tracker at
+http://bugs.python.org.
 
-Bugs in the toolset should be reported in the Python bug tracker at
-http://bugs.python.org/.
+Bugs in the toolset should be reported in the Sphinx bug tracker at
+http://www.bitbucket.org/birkenfeld/sphinx/issues/.
 
 You can also send a mail to the Python Documentation Team at docs at python.org,
 and we will process your request as soon as possible.
Modified: python/branches/py3k/Doc/c-api/arg.rst
==============================================================================
--- python/branches/py3k/Doc/c-api/arg.rst	(original)
+++ python/branches/py3k/Doc/c-api/arg.rst	Sat Dec 27 17:00:54 2008
@@ -305,8 +305,8 @@
 
 ``;``
 The list of format units ends here; the string after the semicolon is used as
- the error message *instead* of the default error message. Clearly, ``:`` and
- ``;`` mutually exclude each other.
+ the error message *instead* of the default error message. ``:`` and ``;``
+ mutually exclude each other.
 
 Note that any Python object references which are provided to the caller are
 *borrowed* references; do not decrement their reference count!
Modified: python/branches/py3k/Doc/license.rst
==============================================================================
--- python/branches/py3k/Doc/license.rst	(original)
+++ python/branches/py3k/Doc/license.rst	Sat Dec 27 17:00:54 2008
@@ -31,6 +31,7 @@
 Source Definition). Historically, most, but not all, Python releases have also
 been GPL-compatible; the table below summarizes the various releases.
 
+<<<<<<< .working
 +----------------+--------------+------------+------------+-----------------+
 | Release | Derived from | Year | Owner | GPL compatible? |
 +================+==============+============+============+=================+
@@ -90,9 +91,12 @@
 +----------------+--------------+------------+------------+-----------------+
 | 2.6 | 2.5 | 2008 | PSF | yes |
 +----------------+--------------+------------+------------+-----------------+
+| 2.6.1 | 2.6 | 2008 | PSF | yes |
++----------------+--------------+------------+------------+-----------------+
 | 3.0 | 2.6 | 2008 | PSF | yes |
 +----------------+--------------+------------+------------+-----------------+
 
+
 .. note::
 
 GPL-compatible doesn't mean that we're distributing Python under the GPL. All
Deleted: python/branches/py3k/Doc/tools/sphinx-web.py
==============================================================================
--- python/branches/py3k/Doc/tools/sphinx-web.py	Sat Dec 27 17:00:54 2008
+++ (empty file)
@@ -1,14 +0,0 @@
-# -*- coding: utf-8 -*-
-"""
- Sphinx - Python documentation webserver
- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-
- :copyright: 2007 by Georg Brandl.
- :license: Python license.
-"""
-
-import sys
-
-if __name__ == '__main__':
- from sphinx.web import main
- sys.exit(main(sys.argv))
Modified: python/branches/py3k/Doc/tools/sphinxext/download.html
==============================================================================
--- python/branches/py3k/Doc/tools/sphinxext/download.html	(original)
+++ python/branches/py3k/Doc/tools/sphinxext/download.html	Sat Dec 27 17:00:54 2008
@@ -19,20 +19,20 @@
 <table class="docutils">
 <tr><th>Format</th><th>Packed as .zip</th><th>Packed as .tar.bz2</th></tr>
 <tr><td>PDF (US-Letter paper size)</td>
- <td><a href="{{ dlbase }}/python-docs-pdf-letter.zip">Download</a> (ca. 8 MB)</td>
- <td><a href="{{ dlbase }}/python-docs-pdf-letter.tar.bz2">Download</a> (ca. 8 MB)</td>
+ <td><a href="{{ dlbase }}/python-{{ release }}-docs-pdf-letter.zip">Download</a> (ca. 8 MB)</td>
+ <td><a href="{{ dlbase }}/python-{{ release }}-docs-pdf-letter.tar.bz2">Download</a> (ca. 8 MB)</td>
 </tr>
 <tr><td>PDF (A4 paper size)</td>
- <td><a href="{{ dlbase }}/python-docs-pdf-a4.zip">Download</a> (ca. 8 MB)</td>
- <td><a href="{{ dlbase }}/python-docs-pdf-a4.tar.bz2">Download</a> (ca. 8 MB)</td>
+ <td><a href="{{ dlbase }}/python-{{ release }}-docs-pdf-a4.zip">Download</a> (ca. 8 MB)</td>
+ <td><a href="{{ dlbase }}/python-{{ release }}-docs-pdf-a4.tar.bz2">Download</a> (ca. 8 MB)</td>
 </tr>
 <tr><td>HTML</td>
- <td><a href="{{ dlbase }}/python-docs-html.zip">Download</a> (ca. 6 MB)</td>
- <td><a href="{{ dlbase }}/python-docs-html.tar.bz2">Download</a> (ca. 4 MB)</td>
+ <td><a href="{{ dlbase }}/python-{{ release }}-docs-html.zip">Download</a> (ca. 6 MB)</td>
+ <td><a href="{{ dlbase }}/python-{{ release }}-docs-html.tar.bz2">Download</a> (ca. 4 MB)</td>
 </tr>
 <tr><td>Plain Text</td>
 <td><a href="{{ dlbase }}/python-docs-text.zip">Download</a> (ca. 2 MB)</td>
- <td><a href="{{ dlbase }}/python-docs-text.tar.bz2">Download</a> (ca. 1.5 MB)</td>
+ <td><a href="{{ dlbase }}/python-{{ release }}-docs-text.tar.bz2">Download</a> (ca. 1.5 MB)</td>
 </tr>
 </table>
 
Modified: python/branches/py3k/Doc/tutorial/controlflow.rst
==============================================================================
--- python/branches/py3k/Doc/tutorial/controlflow.rst	(original)
+++ python/branches/py3k/Doc/tutorial/controlflow.rst	Sat Dec 27 17:00:54 2008
@@ -200,42 +200,20 @@
 ... pass # Busy-wait for keyboard interrupt (Ctrl+C)
 ... 
 
-This is commonly used for creating minimal classes such as exceptions, or
-for ignoring unwanted exceptions::
+This is commonly used for creating minimal classes::
 
- >>> class ParserError(Exception):
+ >>> class MyEmptyClass:
 ... pass
- ... 
- >>> try:
- ... import audioop
- ... except ImportError:
- ... pass
- ... 
+ ...
 
 Another place :keyword:`pass` can be used is as a place-holder for a function or
-conditional body when you are working on new code, allowing you to keep
-thinking at a more abstract level. However, as :keyword:`pass` is silently
-ignored, a better choice may be to raise a :exc:`NotImplementedError`
-exception::
+conditional body when you are working on new code, allowing you to keep thinking
+at a more abstract level. The :keyword:`pass` is silently ignored::
 
 >>> def initlog(*args):
- ... raise NotImplementedError # Open logfile if not already open
- ... if not logfp:
- ... raise NotImplementedError # Set up dummy log back-end
- ... raise NotImplementedError('Call log initialization handler')
+ ... pass # Remember to implement this!
 ... 
 
-If :keyword:`pass` were used here and you later ran tests, they may fail
-without indicating why. Using :exc:`NotImplementedError` causes this code
-to raise an exception, telling you exactly where the incomplete code 
-is. Note the two calling styles of the exceptions above.
-The first style, with no message but with an accompanying comment, 
-lets you easily leave the comment when you remove the exception,
-which ideally would be a good description for
-the block of code the exception is a placeholder for. However, the 
-third example, providing a message for the exception, will produce 
-a more useful traceback.
-
 .. _tut-functions:
 
 Defining Functions
Modified: python/branches/py3k/Doc/using/unix.rst
==============================================================================
--- python/branches/py3k/Doc/using/unix.rst	(original)
+++ python/branches/py3k/Doc/using/unix.rst	Sat Dec 27 17:00:54 2008
@@ -140,8 +140,8 @@
 Vim and Emacs are excellent editors which support Python very well. For more
 information on how to code in python in these editors, look at:
 
-http://www.vim.org/scripts/script.php?script_id=790
-http://sourceforge.net/projects/python-mode
+* http://www.vim.org/scripts/script.php?script_id=790
+* http://sourceforge.net/projects/python-mode
 
 Geany is an excellent IDE with support for a lot of languages. For more
 information, read: http://geany.uvena.de/
Modified: python/branches/py3k/Lib/distutils/command/register.py
==============================================================================
--- python/branches/py3k/Lib/distutils/command/register.py	(original)
+++ python/branches/py3k/Lib/distutils/command/register.py	Sat Dec 27 17:00:54 2008
@@ -143,13 +143,14 @@
 # get the user's login info
 choices = '1 2 3 4'.split()
 while choice not in choices:
- print('''We need to know who you are, so please choose either:
+ self.announce('''\
+We need to know who you are, so please choose either:
 1. use your existing login,
 2. register as a new user,
 3. have the server generate a new password for you (and email it to you), or
 4. quit
-Your selection [default 1]: ''', end=' ')
- choice = input()
+Your selection [default 1]: ''', log.INFO)
+ choice = raw_input()
 if not choice:
 choice = '1'
 elif choice not in choices:
@@ -169,12 +170,16 @@
 # send the info to the server and report the result
 code, result = self.post_to_server(self.build_post_data('submit'),
 auth)
- print('Server response (%s): %s'%(code, result))
+ self.announce('Server response (%s): %s' % (code, result),
+ log.INFO)
 
 # possibly save the login
 if not self.has_config and code == 200:
- print('I can store your PyPI login so future submissions will be faster.')
- print('(the login will be stored in %s)' % self._get_rc_file())
+ self.announce(('I can store your PyPI login so future '
+ 'submissions will be faster.'), log.INFO)
+ self.announce('(the login will be stored in %s)' % \
+ self._get_rc_file(), log.INFO)
+
 choice = 'X'
 while choice.lower() not in 'yn':
 choice = input('Save your login (y/N)?')
Modified: python/branches/py3k/Lib/distutils/config.py
==============================================================================
--- python/branches/py3k/Lib/distutils/config.py	(original)
+++ python/branches/py3k/Lib/distutils/config.py	Sat Dec 27 17:00:54 2008
@@ -10,8 +10,8 @@
 from distutils.cmd import Command
 
 DEFAULT_PYPIRC = """\
-[pypirc]
-servers =
+[distutils]
+index-servers =
 pypi
 
 [pypi]
Modified: python/branches/py3k/Lib/distutils/tests/test_config.py
==============================================================================
--- python/branches/py3k/Lib/distutils/tests/test_config.py	(original)
+++ python/branches/py3k/Lib/distutils/tests/test_config.py	Sat Dec 27 17:00:54 2008
@@ -5,6 +5,8 @@
 
 from distutils.core import PyPIRCCommand
 from distutils.core import Distribution
+from distutils.log import set_threshold
+from distutils.log import WARN
 
 from distutils.tests import support
 
@@ -32,6 +34,17 @@
 password:secret
 """
 
+WANTED = """\
+[distutils]
+index-servers =
+ pypi
+
+[pypi]
+username:tarek
+password:xxx
+"""
+
+
 class PyPIRCCommandTestCase(support.TempdirManager, unittest.TestCase):
 
 def setUp(self):
@@ -53,6 +66,7 @@
 finalize_options = initialize_options
 
 self._cmd = command
+ self.old_threshold = set_threshold(WARN)
 
 def tearDown(self):
 """Removes the patch."""
@@ -62,6 +76,7 @@
 os.environ['HOME'] = self._old_home
 if os.path.exists(self.rc):
 os.remove(self.rc)
+ set_threshold(self.old_threshold)
 
 def test_server_registration(self):
 # This test makes sure PyPIRCCommand knows how to:
@@ -96,6 +111,20 @@
 ('server', 'server-login'), ('username', 'tarek')]
 self.assertEquals(config, waited)
 
+ def test_server_empty_registration(self):
+
+ cmd = self._cmd(self.dist)
+ rc = cmd._get_rc_file()
+ self.assert_(not os.path.exists(rc))
+
+ cmd._store_pypirc('tarek', 'xxx')
+
+ self.assert_(os.path.exists(rc))
+ content = open(rc).read()
+
+ self.assertEquals(content, WANTED)
+
+
 def test_suite():
 return unittest.makeSuite(PyPIRCCommandTestCase)
 
Modified: python/branches/py3k/Lib/io.py
==============================================================================
--- python/branches/py3k/Lib/io.py	(original)
+++ python/branches/py3k/Lib/io.py	Sat Dec 27 17:00:54 2008
@@ -1157,7 +1157,7 @@
 
 @property
 def closed(self):
- return self.writer.closed()
+ return self.writer.closed
 
 
 class BufferedRandom(BufferedWriter, BufferedReader):
Modified: python/branches/py3k/Lib/lib2to3/main.py
==============================================================================
--- python/branches/py3k/Lib/lib2to3/main.py	(original)
+++ python/branches/py3k/Lib/lib2to3/main.py	Sat Dec 27 17:00:54 2008
@@ -40,7 +40,8 @@
 # Actually write the new file
 super(StdoutRefactoringTool, self).write_file(new_text,
 filename, old_text)
- shutil.copymode(filename, backup)
+ if not self.nobackups:
+ shutil.copymode(filename, backup)
 
 def print_output(self, lines):
 for line in lines:
Modified: python/branches/py3k/Lib/test/pickletester.py
==============================================================================
--- python/branches/py3k/Lib/test/pickletester.py	(original)
+++ python/branches/py3k/Lib/test/pickletester.py	Sat Dec 27 17:00:54 2008
@@ -484,8 +484,8 @@
 self.assertRaises(ValueError, self.loads, buf)
 
 def test_unicode(self):
- endcases = ['', '<\\u>', '<\\\u1234>', '<\n>', '<\\>',
- '<\\\U00012345>']
+ endcases = [u'', u'<\\u>', u'<\\\u1234>', u'<\n>',
+ u'<\\>', u'<\\\U00012345>']
 for proto in protocols:
 for u in endcases:
 p = self.dumps(u, proto)
Modified: python/branches/py3k/Lib/test/test_io.py
==============================================================================
--- python/branches/py3k/Lib/test/test_io.py	(original)
+++ python/branches/py3k/Lib/test/test_io.py	Sat Dec 27 17:00:54 2008
@@ -553,8 +553,9 @@
 r = MockRawIO(())
 w = MockRawIO()
 pair = io.BufferedRWPair(r, w)
+ self.assertFalse(pair.closed)
 
- # XXX need implementation
+ # XXX More Tests
 
 
 class BufferedRandomTest(unittest.TestCase):
Modified: python/branches/py3k/Misc/developers.txt
==============================================================================
--- python/branches/py3k/Misc/developers.txt	(original)
+++ python/branches/py3k/Misc/developers.txt	Sat Dec 27 17:00:54 2008
@@ -17,6 +17,9 @@
 Permissions History
 -------------------
 
+- Tarek Ziadé as given SVN access on Decmeber 21 2008 by NCN,
+ for maintenance of distutils.
+
 - Hirokazu Yamamoto was given SVN access on August 12 2008 by MvL,
 for contributions to the Windows build.
 
Modified: python/branches/py3k/Modules/_testcapimodule.c
==============================================================================
--- python/branches/py3k/Modules/_testcapimodule.c	(original)
+++ python/branches/py3k/Modules/_testcapimodule.c	Sat Dec 27 17:00:54 2008
@@ -508,6 +508,8 @@
 Py_RETURN_NONE;
 }
 
+static volatile int x;
+
 /* Test the u and u# codes for PyArg_ParseTuple. May leak memory in case
 of an error.
 */
@@ -522,7 +524,6 @@
 	/* issue4122: Undefined reference to _Py_ascii_whitespace on Windows */
 	/* Just use the macro and check that it compiles */
 	x = Py_UNICODE_ISSPACE(25);
-	x = x;
 
 tuple = PyTuple_New(1);
 if (tuple == NULL)
@@ -608,6 +609,32 @@
 }
 
 static PyObject *
+test_empty_argparse(PyObject *self)
+{
+	/* Test that formats can begin with '|'. See issue #4720. */
+	PyObject *tuple, *dict = NULL;
+	static char *kwlist[] = {NULL};
+	int result;
+	tuple = PyTuple_New(0);
+	if (!tuple)
+		return NULL;
+	if ((result = PyArg_ParseTuple(tuple, "|:test_empty_argparse")) < 0)
+		goto done;
+	dict = PyDict_New();
+	if (!dict)
+		goto done;
+	result = PyArg_ParseTupleAndKeywords(tuple, dict, "|:test_empty_argparse", kwlist);
+ done:
+	Py_DECREF(tuple);
+	Py_XDECREF(dict);
+	if (result < 0)
+		return NULL;
+	else {
+		Py_RETURN_NONE;
+	}
+}
+
+static PyObject *
 codec_incrementalencoder(PyObject *self, PyObject *args)
 {
 	const char *encoding, *errors = NULL;
@@ -1012,6 +1039,7 @@
 	{"test_long_api",	(PyCFunction)test_long_api,	 METH_NOARGS},
 	{"test_long_numbits",	(PyCFunction)test_long_numbits,	 METH_NOARGS},
 	{"test_k_code",		(PyCFunction)test_k_code,	 METH_NOARGS},
+	{"test_empty_argparse", (PyCFunction)test_empty_argparse,METH_NOARGS},
 	{"test_null_strings",	(PyCFunction)test_null_strings,	 METH_NOARGS},
 	{"test_string_from_format", (PyCFunction)test_string_from_format, METH_NOARGS},
 	{"test_with_docstring", (PyCFunction)test_with_docstring, METH_NOARGS,
Modified: python/branches/py3k/Python/getargs.c
==============================================================================
--- python/branches/py3k/Python/getargs.c	(original)
+++ python/branches/py3k/Python/getargs.c	Sat Dec 27 17:00:54 2008
@@ -1649,7 +1649,7 @@
 		}
 	}
 
-	if (!IS_END_OF_FORMAT(*format)) {
+	if (!IS_END_OF_FORMAT(*format) && *format != '|') {
 		PyErr_Format(PyExc_RuntimeError,
 			"more argument specifiers than keyword list entries "
 			"(remaining format:'%s')", format);


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /