mirror of
https://github.com/python/cpython.git
synced 2025-08-29 05:05:03 +00:00

svn+ssh://pythondev@svn.python.org/python/trunk ........ r53954 | jeremy.hylton | 2007-02-26 10:41:18 -0800 (Mon, 26 Feb 2007) | 10 lines Do not copy free variables to locals in class namespaces. Fixes bug 1569356, but at the cost of a minor incompatibility in locals(). Add test that verifies that the class namespace is not polluted. Also clarify the behavior in the library docs. Along the way, cleaned up the dict_to_map and map_to_dict implementations and added some comments that explain what they do. ........ r53955 | jeremy.hylton | 2007-02-26 11:00:20 -0800 (Mon, 26 Feb 2007) | 2 lines Fix assertion. ........ r53969 | neal.norwitz | 2007-02-26 14:41:45 -0800 (Mon, 26 Feb 2007) | 3 lines When printing an unraisable error, don't print exceptions. before the name. This duplicates the behavior whening normally printing exceptions. ........ r53970 | andrew.kuchling | 2007-02-26 15:02:47 -0800 (Mon, 26 Feb 2007) | 1 line Markup fix ........ r53975 | neal.norwitz | 2007-02-26 15:48:27 -0800 (Mon, 26 Feb 2007) | 3 lines SF #1669182, 2.5 was already fixed. Just assert in 2.6 since string exceptions are gone. ........ r53976 | andrew.kuchling | 2007-02-26 15:54:17 -0800 (Mon, 26 Feb 2007) | 1 line Add some items ........ r53981 | jeremy.hylton | 2007-02-26 17:01:59 -0800 (Mon, 26 Feb 2007) | 4 lines Fix long-standing bug in name mangling for package imports Reported by Mike Verdone. ........ r53993 | jeremy.hylton | 2007-02-27 08:00:06 -0800 (Tue, 27 Feb 2007) | 2 lines tabify ........ r53994 | jeremy.hylton | 2007-02-27 08:13:23 -0800 (Tue, 27 Feb 2007) | 5 lines tabify Note that ast.c still has a mix of tabs and spaces, because it attempts to use four-space indents for more of the new code. ........ r53996 | jeremy.hylton | 2007-02-27 09:24:48 -0800 (Tue, 27 Feb 2007) | 2 lines whitespace normalization ........ r53997 | jeremy.hylton | 2007-02-27 10:29:45 -0800 (Tue, 27 Feb 2007) | 24 lines Add checking for a number of metaclass error conditions. We add some new rules that are required for preserving internal invariants of types. 1. If type (or a subclass of type) appears in bases, it must appear before any non-type bases. If a non-type base (like a regular new-style class) occurred first, it could trick type into allocating the new class an __dict__ which must be impossible. 2. There are several checks that are made of bases when creating a type. Those checks are now repeated when assigning to __bases__. We also add the restriction that assignment to __bases__ may not change the metaclass of the type. Add new tests for these cases and for a few other oddball errors that were no previously tested. Remove a crasher test that was fixed. Also some internal refactoring: Extract the code to find the most derived metaclass of a type and its bases. It is now needed in two places. Rewrite the TypeError checks in test_descr to use doctest. The tests now clearly show what exception they expect to see. ........ r53998 | jeremy.hylton | 2007-02-27 10:33:31 -0800 (Tue, 27 Feb 2007) | 2 lines Add news about changes to metaclasses and __bases__ error checking. ........ r54016 | armin.rigo | 2007-02-28 01:25:29 -0800 (Wed, 28 Feb 2007) | 3 lines Modify the segfaulting example to show why r53997 is not a solution to it. ........ r54022 | brett.cannon | 2007-02-28 10:15:00 -0800 (Wed, 28 Feb 2007) | 2 lines Add a test for instantiating SyntaxError with no arguments. ........ r54026 | raymond.hettinger | 2007-02-28 10:27:41 -0800 (Wed, 28 Feb 2007) | 1 line Docstring nit. ........ r54033 | raymond.hettinger | 2007-02-28 10:37:52 -0800 (Wed, 28 Feb 2007) | 1 line Prepare collections module for pure python code entries. ........ r54053 | raymond.hettinger | 2007-02-28 22:16:43 -0800 (Wed, 28 Feb 2007) | 1 line Add collections.NamedTuple ........ r54054 | neal.norwitz | 2007-02-28 23:04:41 -0800 (Wed, 28 Feb 2007) | 1 line Add Pat and Eric for work on PEP 3101 in the sandbox ........ r54061 | andrew.kuchling | 2007-03-01 06:36:12 -0800 (Thu, 01 Mar 2007) | 1 line Add NamedTuple ........ r54080 | georg.brandl | 2007-03-02 06:37:12 -0800 (Fri, 02 Mar 2007) | 2 lines Bug #1628895: some better tries to find HTML documentation in pydoc. ........ r54086 | raymond.hettinger | 2007-03-02 11:20:46 -0800 (Fri, 02 Mar 2007) | 1 line Fix embarrassing typo and fix constantification of None ........ r54088 | georg.brandl | 2007-03-02 12:30:14 -0800 (Fri, 02 Mar 2007) | 2 lines Bugs #1668032, #1668036, #1669304: clarify behavior of PyMem_Realloc and _Resize. ........ r54114 | georg.brandl | 2007-03-04 09:18:54 -0800 (Sun, 04 Mar 2007) | 2 lines Fix a bug in test_dict and test_userdict, found at the PyPy sprint. ........ r54124 | skip.montanaro | 2007-03-04 12:52:28 -0800 (Sun, 04 Mar 2007) | 2 lines Teach setup.py how to find Berkeley DB on Macs using MacPorts. ........ r54125 | skip.montanaro | 2007-03-04 12:54:12 -0800 (Sun, 04 Mar 2007) | 1 line note MacPorts/BerkDB change in setup.py ........ r54136 | neal.norwitz | 2007-03-04 23:52:01 -0800 (Sun, 04 Mar 2007) | 1 line Added Pete for 3101 too ........ r54138 | facundo.batista | 2007-03-05 08:31:54 -0800 (Mon, 05 Mar 2007) | 1 line Minor corrections to docs, and an explanation comentary ........ r54139 | georg.brandl | 2007-03-05 14:28:08 -0800 (Mon, 05 Mar 2007) | 3 lines Patch #1674228: when assigning a slice (old-style), check for the sq_ass_slice instead of the sq_slice slot. ........ r54149 | georg.brandl | 2007-03-06 01:33:01 -0800 (Tue, 06 Mar 2007) | 3 lines Nit: a struct field is set to GenericAlloc, not GenericAlloc(). ........ r54150 | georg.brandl | 2007-03-06 02:02:47 -0800 (Tue, 06 Mar 2007) | 3 lines Patch #1671450: add a section about subclassing builtin types to the "extending and embedding" tutorial. ........ r54152 | martin.v.loewis | 2007-03-06 02:41:24 -0800 (Tue, 06 Mar 2007) | 2 lines Patch #1121142: Implement ZipFile.open. ........ r54154 | georg.brandl | 2007-03-06 03:51:14 -0800 (Tue, 06 Mar 2007) | 2 lines A test case for the fix in #1674228. ........ r54156 | georg.brandl | 2007-03-06 03:52:24 -0800 (Tue, 06 Mar 2007) | 2 lines Patch #1672481: fix bug in idlelib.MultiCall. ........ r54159 | georg.brandl | 2007-03-06 04:17:50 -0800 (Tue, 06 Mar 2007) | 1 line Bug #1674503: close the file opened by execfile() in an error condition. ........ r54160 | georg.brandl | 2007-03-06 05:32:52 -0800 (Tue, 06 Mar 2007) | 3 lines Fix another reincarnation of bug #1576657 in defaultdict. ........ r54162 | georg.brandl | 2007-03-06 05:35:00 -0800 (Tue, 06 Mar 2007) | 2 lines A test case for the defaultdict KeyError bug. ........ r54164 | georg.brandl | 2007-03-06 05:37:45 -0800 (Tue, 06 Mar 2007) | 3 lines Patch #1663234: you can now run doctest on test files and modules using "python -m doctest [-v] filename ...". ........ r54165 | martin.v.loewis | 2007-03-06 06:43:00 -0800 (Tue, 06 Mar 2007) | 3 lines Patch #912410: Replace HTML entity references for attribute values in HTMLParser. ........ r54166 | skip.montanaro | 2007-03-06 07:41:38 -0800 (Tue, 06 Mar 2007) | 1 line patch 1673619 - identify extension modules which cannot be built ........ r54167 | guido.van.rossum | 2007-03-06 07:50:01 -0800 (Tue, 06 Mar 2007) | 5 lines Patch #1646728: datetime.fromtimestamp fails with negative fractional times. With unittest. Somebody please backport to 2.5. ........ r54169 | georg.brandl | 2007-03-06 09:49:14 -0800 (Tue, 06 Mar 2007) | 2 lines Fix cmp vs. key argument for list.sort. ........ r54170 | georg.brandl | 2007-03-06 10:21:32 -0800 (Tue, 06 Mar 2007) | 2 lines Small nit, found by Neal. ........ r54171 | georg.brandl | 2007-03-06 10:29:58 -0800 (Tue, 06 Mar 2007) | 3 lines Patch #1602128: clarify that richcmp methods can return NotImplemented and should return True or False otherwise. ........ r54173 | georg.brandl | 2007-03-06 10:41:12 -0800 (Tue, 06 Mar 2007) | 2 lines Patch #1638879: don't accept strings with embedded NUL bytes in long(). ........ r54175 | georg.brandl | 2007-03-06 10:47:31 -0800 (Tue, 06 Mar 2007) | 2 lines Patch #1673121: update README wrt. OSX default shell. ........ r54177 | georg.brandl | 2007-03-06 10:59:11 -0800 (Tue, 06 Mar 2007) | 3 lines Patch #1654417: make operator.{get,set,del}slice use the full range of Py_ssize_t. ........ r54180 | walter.doerwald | 2007-03-06 12:38:57 -0800 (Tue, 06 Mar 2007) | 4 lines Patch for bug #1633621: if curses.resizeterm() or curses.resize_term() is called, update _curses.LINES, _curses.COLS, curses.LINES and curses.COLS. ........ r54182 | walter.doerwald | 2007-03-06 13:15:24 -0800 (Tue, 06 Mar 2007) | 2 lines Document change to curses. ........ r54188 | georg.brandl | 2007-03-06 16:34:46 -0800 (Tue, 06 Mar 2007) | 5 lines Variant of patch #697613: don't exit the interpreter on a SystemExit exception if the -i command line option or PYTHONINSPECT environment variable is given, but break into the interactive interpreter just like on other exceptions or normal program exit. (backport) ........ r54189 | georg.brandl | 2007-03-06 16:40:28 -0800 (Tue, 06 Mar 2007) | 4 lines Patch #703779: unset __file__ in __main__ after running a file. This makes the filenames the warning module prints much more sensible when a PYTHONSTARTUP file is used. ........ r54192 | george.yoshida | 2007-03-06 20:21:18 -0800 (Tue, 06 Mar 2007) | 2 lines add versionadded info ........ r54195 | georg.brandl | 2007-03-06 23:39:06 -0800 (Tue, 06 Mar 2007) | 2 lines Patch #812285: allow multiple auth schemes in AbstractBasicAuthHandler. ........ r54197 | georg.brandl | 2007-03-07 00:31:51 -0800 (Wed, 07 Mar 2007) | 3 lines Patch #1001604: glob.glob() now returns unicode filenames if it was given a unicode argument and os.listdir() returns unicode filenames. ........ r54199 | georg.brandl | 2007-03-07 01:09:40 -0800 (Wed, 07 Mar 2007) | 3 lines Patches #1550273, #1550272: fix a few bugs in unittest and add a comprehensive test suite for the module. ........ r54201 | georg.brandl | 2007-03-07 01:21:06 -0800 (Wed, 07 Mar 2007) | 3 lines Patch #787789: allow to pass custom TestRunner instances to unittest's main() function. ........ r54202 | georg.brandl | 2007-03-07 01:34:45 -0800 (Wed, 07 Mar 2007) | 2 lines Patch #1669331: clarify shutil.copyfileobj() behavior wrt. file position. ........ r54204 | martin.v.loewis | 2007-03-07 03:04:33 -0800 (Wed, 07 Mar 2007) | 2 lines Bug #1115886: os.path.splitext('.cshrc') gives now ('.cshrc', ''). ........ r54206 | georg.brandl | 2007-03-07 03:37:42 -0800 (Wed, 07 Mar 2007) | 2 lines Patch #1675471: convert test_pty to unittest. ........ r54207 | georg.brandl | 2007-03-07 03:54:49 -0800 (Wed, 07 Mar 2007) | 4 lines Add some sanity checks to unittest.TestSuite's addTest(s) methods. Fixes #878275. ........ r54209 | guido.van.rossum | 2007-03-07 07:16:29 -0800 (Wed, 07 Mar 2007) | 3 lines Windows doesn't support negative timestamps. Skip the tests involving them if os.name == "nt". ........ r54219 | martin.v.loewis | 2007-03-08 05:42:43 -0800 (Thu, 08 Mar 2007) | 2 lines Add missing ) in parenthical remark. ........ r54220 | georg.brandl | 2007-03-08 09:49:06 -0800 (Thu, 08 Mar 2007) | 2 lines Fix #1676656: \em is different from \emph... ........ r54222 | georg.brandl | 2007-03-08 10:37:31 -0800 (Thu, 08 Mar 2007) | 2 lines Add a NEWS entry for rev. 54207,8. ........ r54225 | raymond.hettinger | 2007-03-08 11:24:27 -0800 (Thu, 08 Mar 2007) | 1 line SF 1676321: empty() returned wrong result ........ r54227 | collin.winter | 2007-03-08 11:58:14 -0800 (Thu, 08 Mar 2007) | 1 line Backported r54226 from p3yk: Move test_unittest, test_doctest and test_doctest2 higher up in the testing order. ........ r54230 | raymond.hettinger | 2007-03-08 13:33:47 -0800 (Thu, 08 Mar 2007) | 1 line SF #1637850: make_table in difflib did not work with unicode ........ r54232 | collin.winter | 2007-03-08 14:16:25 -0800 (Thu, 08 Mar 2007) | 1 line Patch #1668482: don't use '-' in mkstemp ........ r54233 | brett.cannon | 2007-03-08 15:58:11 -0800 (Thu, 08 Mar 2007) | 10 lines Introduce test.test_support.TransientResource. It's a context manager to surround calls to resources that may or may not be available. Specifying the expected exception and attributes to be raised if the resource is not available prevents overly broad catching of exceptions. This is meant to help suppress spurious failures by raising test.test_support.ResourceDenied if the exception matches. It would probably be good to go through the various network tests and surround the calls to catch connection timeouts (as done with test_socket_ssl in this commit). ........ r54234 | collin.winter | 2007-03-08 19:15:56 -0800 (Thu, 08 Mar 2007) | 1 line Patch #1481079: Support of HTTP_REFERER in CGIHTTPServer.py ........ r54235 | collin.winter | 2007-03-08 19:26:32 -0800 (Thu, 08 Mar 2007) | 1 line Add NEWS item for patch #1481079 (r54234). ........ r54237 | neal.norwitz | 2007-03-08 21:59:01 -0800 (Thu, 08 Mar 2007) | 1 line Fix SF #1676971, Complex OverflowError has a typo ........ r54239 | georg.brandl | 2007-03-09 04:58:41 -0800 (Fri, 09 Mar 2007) | 2 lines Typo. ........ r54240 | martin.v.loewis | 2007-03-09 07:35:55 -0800 (Fri, 09 Mar 2007) | 2 lines Patch #957003: Implement smtplib.LMTP. ........ r54243 | collin.winter | 2007-03-09 10:09:10 -0800 (Fri, 09 Mar 2007) | 2 lines Bug #1629566: clarify the docs on the return values of parsedate() and parsedate_tz() in email.utils and rfc822. ........ r54244 | thomas.heller | 2007-03-09 11:21:28 -0800 (Fri, 09 Mar 2007) | 3 lines Fix bug #1646630: ctypes.string_at(buf, 0) and ctypes.wstring_at(buf, 0) returned string up to the first NUL character. ........ r54245 | martin.v.loewis | 2007-03-09 11:36:01 -0800 (Fri, 09 Mar 2007) | 2 lines Add Ziga Seilnacht. ........ r54247 | collin.winter | 2007-03-09 12:33:07 -0800 (Fri, 09 Mar 2007) | 2 lines Patch #1491866: change the complex() constructor to allow parthensized forms. This means complex(repr(x)) now works instead of raising a ValueError. ........ r54248 | thomas.heller | 2007-03-09 12:39:22 -0800 (Fri, 09 Mar 2007) | 7 lines Bug #1651235: When a tuple was passed to a ctypes function call, Python would crash instead of raising an error. The crash was caused by a section of code that should have been removed long ago, at that time ctypes had other ways to pass parameters to function calls. ........ r54250 | collin.winter | 2007-03-09 15:30:39 -0800 (Fri, 09 Mar 2007) | 1 line Hashing simplification pointed out by Thomas Wouters. ........ r54252 | collin.winter | 2007-03-09 18:23:40 -0800 (Fri, 09 Mar 2007) | 5 lines * Unlink test files before and after each test; hopefully this will cut down on recent buildbot failures in test_islink. * Drop safe_remove() in favor of test_support.unlink(). * Fix the indentation of test_samefile so that it runs. ........ r54253 | collin.winter | 2007-03-09 18:51:26 -0800 (Fri, 09 Mar 2007) | 3 lines Bug #1531963: Make SocketServer.TCPServer's server_address always be equal to calling getsockname() on the server's socket. Will backport. ........ r54254 | neal.norwitz | 2007-03-09 19:19:18 -0800 (Fri, 09 Mar 2007) | 4 lines Simplify a little by handling the TCP case first. Update to use predominant style of spaces around = in args list and print to stderr if debugging. ........ r54256 | collin.winter | 2007-03-09 19:35:34 -0800 (Fri, 09 Mar 2007) | 1 line Add proper attribution for a bug fix. ........ r54257 | georg.brandl | 2007-03-09 23:38:14 -0800 (Fri, 09 Mar 2007) | 2 lines Typos. ........ r54260 | collin.winter | 2007-03-10 06:33:32 -0800 (Sat, 10 Mar 2007) | 1 line Convert an assert to a raise so it works even in the presence of -O. ........ r54262 | collin.winter | 2007-03-10 06:41:48 -0800 (Sat, 10 Mar 2007) | 2 lines Patch #1599845: Add an option to disable the implicit calls to server_bind() and server_activate() in the constructors for TCPServer, SimpleXMLRPCServer and DocXMLRPCServer. ........ r54268 | georg.brandl | 2007-03-11 00:28:46 -0800 (Sun, 11 Mar 2007) | 2 lines Add missing "return" statements in exception handler. ........ r54270 | ziga.seilnacht | 2007-03-11 08:54:54 -0700 (Sun, 11 Mar 2007) | 3 lines Patch #1675981: remove unreachable code from type.__new__() method. __dict__ and __weakref__ are removed from the slots tuple earlier in the code, in the loop that mangles slot names. Will backport. ........ r54271 | collin.winter | 2007-03-11 09:00:20 -0700 (Sun, 11 Mar 2007) | 3 lines Patch #1192590: Fix pdb's "ignore" and "condition" commands so they trap the IndexError caused by passing in an invalid breakpoint number. Will backport. ........ r54274 | vinay.sajip | 2007-03-11 11:32:07 -0700 (Sun, 11 Mar 2007) | 1 line Fix resource leak reported in SF #1516995. ........ r54278 | collin.winter | 2007-03-11 18:55:54 -0700 (Sun, 11 Mar 2007) | 4 lines Patch #1678662: ftp.python.org does not exist. So the testcode in urllib.py must use a more stable FTP. Will backport. ........ r54280 | barry.warsaw | 2007-03-11 20:20:01 -0700 (Sun, 11 Mar 2007) | 8 lines Tokio Kikuchi's fix for SF bug #1629369; folding whitespace allowed in the display name of an email address, e.g. Foo \tBar <foo@example.com> Test case added by Barry. ........ r54282 | skip.montanaro | 2007-03-11 20:30:50 -0700 (Sun, 11 Mar 2007) | 4 lines Sane humans would call these invalid tests, but Andrew McNamara pointed out that given the inputs in these tests Excel does indeed produce the output these tests expect. Document that for future confused folks. ........ r54283 | martin.v.loewis | 2007-03-12 03:50:39 -0700 (Mon, 12 Mar 2007) | 2 lines Bug #1675511: Use -Kpic instead of -xcode=pic32 on Solaris/x86. ........ r54285 | martin.v.loewis | 2007-03-12 04:01:10 -0700 (Mon, 12 Mar 2007) | 2 lines Patch #1677862: Require a space or tab after import in .pth files. ........ r54287 | georg.brandl | 2007-03-12 06:17:36 -0700 (Mon, 12 Mar 2007) | 8 lines Backport from Py3k branch: Patch #1591665: implement the __dir__() special function lookup in PyObject_Dir. Had to change a few bits of the patch because classobjs and __methods__ are still in Py2.6. ........ r54288 | georg.brandl | 2007-03-12 07:30:05 -0700 (Mon, 12 Mar 2007) | 3 lines Bug #1678647: write a newline after printing an exception in any case, even when converting the value to a string failed. ........ r54290 | collin.winter | 2007-03-12 08:57:19 -0700 (Mon, 12 Mar 2007) | 1 line Patch #1678088: convert test_operations to use unittest, fold the result into test_dict. ........ r54291 | collin.winter | 2007-03-12 09:11:39 -0700 (Mon, 12 Mar 2007) | 3 lines Bug #742342: make Python stop segfaulting on infinitely-recursive reload()s. Fixed by patch #922167. Will backport. ........ r54292 | georg.brandl | 2007-03-12 09:15:09 -0700 (Mon, 12 Mar 2007) | 2 lines Typo fix. ........ r54295 | collin.winter | 2007-03-12 10:24:07 -0700 (Mon, 12 Mar 2007) | 1 line Patch #1670993: Refactor test_threadedtempfile.py to use unittest. ........ r54296 | tim.peters | 2007-03-12 11:07:52 -0700 (Mon, 12 Mar 2007) | 2 lines Whitespace normalization. ........ r54297 | tim.peters | 2007-03-12 11:09:22 -0700 (Mon, 12 Mar 2007) | 2 lines Set missing svn:eol-style property on text files. ........ r54315 | brett.cannon | 2007-03-12 19:34:09 -0700 (Mon, 12 Mar 2007) | 8 lines Add test.test_support.transient_internet . Returns a context manager that nests test.test_support.TransientResource context managers that capture exceptions raised when the Internet connection is flaky. Initially using in test_socket_ssl but should probably be expanded to cover any test that should not raise the captured exceptions if the Internet connection works. ........ r54316 | brett.cannon | 2007-03-12 20:05:40 -0700 (Mon, 12 Mar 2007) | 2 lines Fix a typo where the variable name was not updated. ........ r54318 | neal.norwitz | 2007-03-12 21:59:58 -0700 (Mon, 12 Mar 2007) | 1 line Add Jerry Seutter for a bunch of his recent patches refactoring tests ........ r54319 | neal.norwitz | 2007-03-12 22:07:14 -0700 (Mon, 12 Mar 2007) | 7 lines Add some other acks for recent checkins: Brian Leair - 922167 Tomer Filiba - 1591665 Jeremy Jones - 1192590 ........ r54321 | neal.norwitz | 2007-03-12 22:31:38 -0700 (Mon, 12 Mar 2007) | 9 lines Fix some style nits: * lines too long * wrong indentation * space after a function name * wrong function name in error string * simplifying some logic Also add an error check to PyDict_SetItemString. ........ r54322 | georg.brandl | 2007-03-13 00:23:16 -0700 (Tue, 13 Mar 2007) | 2 lines Typo and grammar fixes. ........ r54323 | georg.brandl | 2007-03-13 00:50:57 -0700 (Tue, 13 Mar 2007) | 2 lines Patch #1679379: add documentation for fnmatch.translate(). ........ r54325 | georg.brandl | 2007-03-13 00:57:51 -0700 (Tue, 13 Mar 2007) | 2 lines Patch #1642844: comments to clarify the complexobject constructor. ........ r54326 | georg.brandl | 2007-03-13 01:14:27 -0700 (Tue, 13 Mar 2007) | 3 lines Patch #1668100: urllib2 now correctly raises URLError instead of OSError if accessing a local file via the file:// protocol fails. ........ r54327 | georg.brandl | 2007-03-13 02:32:11 -0700 (Tue, 13 Mar 2007) | 4 lines Patch #1635454: the csv.DictWriter class now includes the offending field names in its exception message if you try to write a record with a dictionary containing fields not in the CSV field names list. ........ r54328 | georg.brandl | 2007-03-13 02:41:31 -0700 (Tue, 13 Mar 2007) | 3 lines Patch #1555098: use str.join() instead of repeated string concatenation in robotparser. ........ r54329 | georg.brandl | 2007-03-13 03:06:48 -0700 (Tue, 13 Mar 2007) | 3 lines Patch #1542681: add entries for "with", "as" and "CONTEXTMANAGERS" to pydoc's help keywords. ........ r54331 | georg.brandl | 2007-03-13 03:19:22 -0700 (Tue, 13 Mar 2007) | 3 lines Patch #1569798: fix a bug in distutils when building Python from a directory within sys.exec_prefix. ........ r54333 | martin.v.loewis | 2007-03-13 03:24:00 -0700 (Tue, 13 Mar 2007) | 4 lines Patch #1449244: Support Unicode strings in email.message.Message.{set_charset,get_content_charset}. Will backport. ........ r54335 | lars.gustaebel | 2007-03-13 03:47:19 -0700 (Tue, 13 Mar 2007) | 34 lines This is the implementation of POSIX.1-2001 (pax) format read/write support. The TarInfo class now contains all necessary logic to process and create tar header data which has been moved there from the TarFile class. The fromtarfile() method was added. The new path and linkpath properties are aliases for the name and linkname attributes in correspondence to the pax naming scheme. The TarFile constructor and classmethods now accept a number of keyword arguments which could only be set as attributes before (e.g. dereference, ignore_zeros). The encoding and pax_headers arguments were added for pax support. There is a new tarinfo keyword argument that allows using subclassed TarInfo objects in TarFile. The boolean TarFile.posix attribute is deprecated, because now three tar formats are supported. Instead, the desired format for writing is specified using the constants USTAR_FORMAT, GNU_FORMAT and PAX_FORMAT as the format keyword argument. This change affects TarInfo.tobuf() as well. The test suite has been heavily reorganized and partially rewritten. A new testtar.tar was added that contains sample data in many formats from 4 different tar programs. Some bugs and quirks that also have been fixed: Directory names do no longer have a trailing slash in TarInfo.name or TarFile.getnames(). Adding the same file twice does not create a hardlink file member. The TarFile constructor does no longer need a name argument. The TarFile._mode attribute was renamed to mode and contains either 'r', 'w' or 'a'. ........ r54336 | georg.brandl | 2007-03-13 05:34:25 -0700 (Tue, 13 Mar 2007) | 3 lines Bug #1622896: fix a rare corner case where the bz2 module raised an error in spite of a succesful compression. ........ r54338 | lars.gustaebel | 2007-03-13 08:47:07 -0700 (Tue, 13 Mar 2007) | 3 lines Quick fix for tests that fail on systems with an encoding other than 'iso8859-1'. ........ r54339 | georg.brandl | 2007-03-13 10:43:32 -0700 (Tue, 13 Mar 2007) | 4 lines Patch #1603688: ConfigParser.SafeConfigParser now checks values that are set for invalid interpolation sequences that would lead to errors on reading back those values. ........ r54341 | georg.brandl | 2007-03-13 11:15:41 -0700 (Tue, 13 Mar 2007) | 3 lines Patch #1581073: add a flag to textwrap that prevents the dropping of whitespace while wrapping. ........ r54343 | georg.brandl | 2007-03-13 11:24:40 -0700 (Tue, 13 Mar 2007) | 2 lines Patch #1605192: list allowed states in error messages for imaplib. ........ r54344 | georg.brandl | 2007-03-13 11:31:49 -0700 (Tue, 13 Mar 2007) | 4 lines Patch #1537850: tempfile.NamedTemporaryFile now has a "delete" parameter which can be set to False to prevent the default delete-on-close behavior. ........ r54345 | collin.winter | 2007-03-13 11:53:04 -0700 (Tue, 13 Mar 2007) | 9 lines Add acks for recent patch checkins: Arvin Schnell - 1668482 S?\195?\169bastien Martini - 1481079 Heiko Wundram - 1491866 Damon Kohler - 1545011 Peter Parente - 1599845 Bjorn Lindqvist - 1678662 ........ r54346 | georg.brandl | 2007-03-13 12:00:36 -0700 (Tue, 13 Mar 2007) | 2 lines Acks for recent patches. ........ r54347 | georg.brandl | 2007-03-13 12:18:18 -0700 (Tue, 13 Mar 2007) | 3 lines Fix a tab. ........ r54348 | georg.brandl | 2007-03-13 12:32:21 -0700 (Tue, 13 Mar 2007) | 4 lines Patch #1533909: the timeit module now accepts callables in addition to strings for the code to time and the setup code. Also added two convenience functions for instantiating a Timer and calling its methods. ........ r54352 | georg.brandl | 2007-03-13 13:02:57 -0700 (Tue, 13 Mar 2007) | 3 lines Patch #1530482: add pydoc.render_doc() which returns the documentation for a thing instead of paging it to stdout, which pydoc.doc() does. ........ r54357 | thomas.heller | 2007-03-13 13:42:52 -0700 (Tue, 13 Mar 2007) | 1 line Patch #1649190: Adding support for _Bool to ctypes as c_bool, by David Remahl. ........ r54358 | georg.brandl | 2007-03-13 13:46:32 -0700 (Tue, 13 Mar 2007) | 2 lines Patch #1444529: the builtin compile() now accepts keyword arguments. (backport) ........ r54359 | thomas.heller | 2007-03-13 14:01:39 -0700 (Tue, 13 Mar 2007) | 1 line Add versionadded marker for ctypes.c_bool. ........ r54360 | georg.brandl | 2007-03-13 14:08:15 -0700 (Tue, 13 Mar 2007) | 3 lines Patch #1393667: pdb now has a "run" command which restarts the debugged Python program, optionally with different arguments. ........ r54361 | georg.brandl | 2007-03-13 14:32:01 -0700 (Tue, 13 Mar 2007) | 3 lines Deprecate commands.getstatus(). ........ r54362 | georg.brandl | 2007-03-13 14:32:56 -0700 (Tue, 13 Mar 2007) | 2 lines NEWS entry for getstatus() deprecation. ........ r54363 | georg.brandl | 2007-03-13 14:58:44 -0700 (Tue, 13 Mar 2007) | 4 lines Patch #1429539: pdb now correctly initializes the __main__ module for the debugged script, which means that imports from __main__ work correctly now. ........ r54364 | georg.brandl | 2007-03-13 15:07:36 -0700 (Tue, 13 Mar 2007) | 4 lines Patch #957650: "%var%" environment variable references are now properly expanded in ntpath.expandvars(), also "~user" home directory references are recognized and handled on Windows. ........ r54365 | georg.brandl | 2007-03-13 15:16:30 -0700 (Tue, 13 Mar 2007) | 2 lines Patch #1194449: correctly detect unbound methods in pydoc. ........ r54367 | georg.brandl | 2007-03-13 15:49:43 -0700 (Tue, 13 Mar 2007) | 5 lines Patch #1185447: binascii.b2a_qp() now correctly quotes binary characters with ASCII value less than 32. Also, it correctly quotes dots only if they occur on a single line, as opposed to the previous behavior of quoting dots if they are the second character of any line. ........ r54368 | collin.winter | 2007-03-13 16:02:15 -0700 (Tue, 13 Mar 2007) | 1 line Inline PyImport_GetModulesReloading(). ........ r54371 | barry.warsaw | 2007-03-13 21:59:50 -0700 (Tue, 13 Mar 2007) | 6 lines SF bug #1582282; decode_header() incorrectly splits not-conformant RFC 2047-like headers where there is no whitespace between encoded words. This fix changes the matching regexp to include a trailing lookahead assertion that the closing ?= must be followed by whitespace, newline, or end-of-string. This also changes the regexp to add the MULTILINE flag. ........ r54372 | gregory.p.smith | 2007-03-14 00:17:40 -0700 (Wed, 14 Mar 2007) | 2 lines correct order and names of the less often used keyword parameters. ........ r54373 | gregory.p.smith | 2007-03-14 00:19:50 -0700 (Wed, 14 Mar 2007) | 5 lines Its time to stop listing (Unix, Windows) when we really mean "everything but Mac OS 9" now that nobody is likely to use Python on Mac OS 9 and most of the (Mac) platform items are all OS X special API specific since OS X is unixy enough for these modules to be available out of the box. ........ r54376 | georg.brandl | 2007-03-14 01:27:52 -0700 (Wed, 14 Mar 2007) | 4 lines Bug #767111: fix long-standing bug in urllib which caused an AttributeError instead of an IOError when the server's response didn't contain a valid HTTP status line. ........ r54378 | ziga.seilnacht | 2007-03-14 05:24:09 -0700 (Wed, 14 Mar 2007) | 4 lines Patch #1680015: Don't modify __slots__ tuple if it contains an unicode name. Remove a reference leak that happened if the name could not be converted to string. Will backport. ........ r54386 | martin.v.loewis | 2007-03-14 13:02:31 -0700 (Wed, 14 Mar 2007) | 3 lines Patch #1559413: Fix test_cmd_line if sys.executable contains a space. Will backport. ........ r54389 | brett.cannon | 2007-03-14 14:40:13 -0700 (Wed, 14 Mar 2007) | 3 lines Note how test_socket_ssl has various exceptions that deal with a flaky Net connection are silenced. ........ r54390 | brett.cannon | 2007-03-14 14:44:15 -0700 (Wed, 14 Mar 2007) | 2 lines Raise ResourceDenied in test_urllib2net when the Net connection goes bad. ........ r54391 | neal.norwitz | 2007-03-14 21:41:20 -0700 (Wed, 14 Mar 2007) | 1 line Wrap a long line and fix a typo (is -> if) ........ r54392 | georg.brandl | 2007-03-15 00:38:14 -0700 (Thu, 15 Mar 2007) | 3 lines Patch #1680978: consistently use "alive" instead of "active" in the thread lib doc. ........ r54394 | georg.brandl | 2007-03-15 00:41:30 -0700 (Thu, 15 Mar 2007) | 3 lines Patch #1681153: the wave module now closes a file object it opened if initialization failed. ........ r54397 | ziga.seilnacht | 2007-03-15 04:44:55 -0700 (Thu, 15 Mar 2007) | 3 lines Patch #1462488: prevent a segfault in object_reduce_ex() by splitting the implementation for __reduce__ and __reduce_ex__ into two separate functions. Fixes bug #931877. Will backport. ........ r54404 | collin.winter | 2007-03-15 21:11:30 -0700 (Thu, 15 Mar 2007) | 3 lines Patch #1642547: Fix an error/crash when encountering syntax errors in complex if statements. Will backport. ........ r54406 | georg.brandl | 2007-03-16 00:55:09 -0700 (Fri, 16 Mar 2007) | 5 lines Bug #1681228: the webbrowser module now correctly uses the default GNOME or KDE browser, depending on whether there is a session of one of those present. Also, it tries the Windows default browser before trying Mozilla variants. (backport) ........ r54407 | georg.brandl | 2007-03-16 01:22:40 -0700 (Fri, 16 Mar 2007) | 4 lines Patch #1273829: os.walk() now has a "followlinks" parameter. If set to True (which is not the default), it visits symlinks pointing to directories. ........ r54408 | georg.brandl | 2007-03-16 01:24:21 -0700 (Fri, 16 Mar 2007) | 2 lines Add \versionadded tag. ........ r54409 | georg.brandl | 2007-03-16 01:33:47 -0700 (Fri, 16 Mar 2007) | 2 lines RFE #1670167: fix in isinstance() docs. ........ r54412 | ziga.seilnacht | 2007-03-16 04:59:38 -0700 (Fri, 16 Mar 2007) | 3 lines Patch #1623563: allow __class__ assignment for classes with __slots__. The old and the new class are still required to have the same slot names, but the order in which they are specified is not relevant. ........ r54413 | ziga.seilnacht | 2007-03-16 05:11:11 -0700 (Fri, 16 Mar 2007) | 2 lines Whitespace cleanup. Also remove the empty lines from the previous check in. ........ r54414 | jeremy.hylton | 2007-03-16 07:49:11 -0700 (Fri, 16 Mar 2007) | 2 lines Remove warning: funcion declaration isn't a prototype ........ r54415 | jeremy.hylton | 2007-03-16 08:59:47 -0700 (Fri, 16 Mar 2007) | 11 lines Clean up formatting of this file. The file should now follow PEP 7, except that it uses 4 space indents (in the style of Py3k). This particular code would be really hard to read with the regular tab idents. Other changes: - reflow long lines - change multi-line conditionals to have test at end of line ........ r54417 | collin.winter | 2007-03-16 14:13:35 -0700 (Fri, 16 Mar 2007) | 1 line Patch #1676994: Refactor test_popen2 to use unittest. ........ r54418 | collin.winter | 2007-03-16 14:15:35 -0700 (Fri, 16 Mar 2007) | 1 line Remove test/output/test_popen2 (missed in r54417). ........ r54419 | collin.winter | 2007-03-16 15:16:08 -0700 (Fri, 16 Mar 2007) | 1 line Patch 1339796: add a relpath() function to os.path. ........ r54421 | georg.brandl | 2007-03-17 09:08:45 -0700 (Sat, 17 Mar 2007) | 5 lines Patch #1675423: PyComplex_AsCComplex() now tries to convert an object to complex using its __complex__() method before falling back to the __float__() method. Therefore, the functions in the cmath module now can operate on objects that define a __complex__() method. (backport) ........ r54423 | gregory.p.smith | 2007-03-17 15:33:35 -0700 (Sat, 17 Mar 2007) | 2 lines move note to the correct section ........ r54426 | georg.brandl | 2007-03-18 01:25:00 -0700 (Sun, 18 Mar 2007) | 2 lines Patch #1682878: the new socket methods are recv_into and recvfrom_into, not *_buf. ........ r54432 | georg.brandl | 2007-03-18 11:28:25 -0700 (Sun, 18 Mar 2007) | 2 lines Patch #1678339: test case for bug in difflib. ........ r54439 | collin.winter | 2007-03-19 11:52:08 -0700 (Mon, 19 Mar 2007) | 1 line Patch #1630118: add a SpooledTemporaryFile class to tempfile. ........ r54441 | georg.brandl | 2007-03-19 12:02:48 -0700 (Mon, 19 Mar 2007) | 2 lines Patch #1683328: fixes and enhancements for "unparse" demo. ........ r54456 | neal.norwitz | 2007-03-19 22:07:28 -0700 (Mon, 19 Mar 2007) | 1 line Add some doc that was left out from some change to platform.py ........ r54457 | neal.norwitz | 2007-03-19 22:08:23 -0700 (Mon, 19 Mar 2007) | 1 line Add a comment about 3k migration ........ r54458 | neal.norwitz | 2007-03-19 22:21:21 -0700 (Mon, 19 Mar 2007) | 1 line Get rid of deprecation warning when testing commands.getstatus() ........ r54459 | neal.norwitz | 2007-03-19 22:23:09 -0700 (Mon, 19 Mar 2007) | 4 lines Try backing out 54407 to see if it corrects the problems on the Windows buildbots. This rev was backported, so we will need to keep both branches in sync, pending the outcome of the test after this checkin. ........ r54460 | neal.norwitz | 2007-03-19 23:13:25 -0700 (Mon, 19 Mar 2007) | 1 line Try to make this test more resistant to dropping from previous runs (ie, files that may exist but cause the test to fail). Should be backported (assuming it works :-) ........ r54461 | neal.norwitz | 2007-03-19 23:16:26 -0700 (Mon, 19 Mar 2007) | 1 line Try to make this test more resistant to dropping from previous runs (ie, files that may exist but cause the test to fail). Should be backported (assuming it works :-) ........ r54462 | neal.norwitz | 2007-03-19 23:53:17 -0700 (Mon, 19 Mar 2007) | 5 lines Try to be a little more resilient to errors. This might help the test pass, but my guess is that it won't. I'm guessing that some other test is leaving this file open which means it can't be removed under Windows AFAIK. ........ r54463 | neal.norwitz | 2007-03-20 01:14:57 -0700 (Tue, 20 Mar 2007) | 8 lines Try to get test_urllib to pass on Windows by closing the file. I'm guessing that's the problem. h.getfile() must be called *after* h.getreply() and the fp can be None. I'm not entirely convinced this is the best fix (or even correct). The buildbots will tell us if things improve or not. I don't know if this needs to be backported (assuming it actually works). ........ r54465 | raymond.hettinger | 2007-03-20 14:27:24 -0700 (Tue, 20 Mar 2007) | 1 line Extend work on rev 52962 and 53829 eliminating redundant PyObject_Hash() calls and fixing set/dict interoperability. ........ r54468 | georg.brandl | 2007-03-20 16:05:14 -0700 (Tue, 20 Mar 2007) | 2 lines Fix for glob.py if filesystem encoding is None. ........ r54479 | neal.norwitz | 2007-03-20 23:39:48 -0700 (Tue, 20 Mar 2007) | 1 line Remove unused file spotted by Paul Hankin ........ r54480 | georg.brandl | 2007-03-21 02:00:39 -0700 (Wed, 21 Mar 2007) | 3 lines Patch #1682205: a TypeError while unpacking an iterable is no longer masked by a generic one with the message "unpack non-sequence". ........ r54482 | georg.brandl | 2007-03-21 02:10:29 -0700 (Wed, 21 Mar 2007) | 2 lines New test for rev. 54407 which only uses directories under TESTFN. ........ r54483 | georg.brandl | 2007-03-21 02:16:53 -0700 (Wed, 21 Mar 2007) | 2 lines Patch #1684834: document some utility C API functions. ........ r54485 | georg.brandl | 2007-03-21 04:51:25 -0700 (Wed, 21 Mar 2007) | 2 lines Fix #1684254: split BROWSER contents with shlex to avoid displaying 'URL'. ........ r54487 | andrew.kuchling | 2007-03-21 07:32:43 -0700 (Wed, 21 Mar 2007) | 1 line Add comments on maintenance of this file ........ r54489 | andrew.kuchling | 2007-03-21 09:57:32 -0700 (Wed, 21 Mar 2007) | 1 line Fix sentence, and fix typo in example ........ r54490 | andrew.kuchling | 2007-03-21 09:59:20 -0700 (Wed, 21 Mar 2007) | 1 line Put code examples at left margin instead of indenting them ........ r54491 | facundo.batista | 2007-03-21 12:41:24 -0700 (Wed, 21 Mar 2007) | 1 line Minor clarification, saying that blocking means no timeout (from bug #882297) ........ r54492 | ziga.seilnacht | 2007-03-21 13:07:56 -0700 (Wed, 21 Mar 2007) | 2 lines Bug #1675967: re patterns pickled with older Python versions can now be unpickled. Will backport. ........ r54495 | raymond.hettinger | 2007-03-21 13:33:57 -0700 (Wed, 21 Mar 2007) | 1 line Add test and fix for fromkeys() optional argument. ........ r54524 | georg.brandl | 2007-03-22 01:05:45 -0700 (Thu, 22 Mar 2007) | 2 lines Bug #1685704: use -m switch in timeit docs. ........ r54533 | thomas.heller | 2007-03-22 12:44:31 -0700 (Thu, 22 Mar 2007) | 5 lines Back out "Patch #1643874: memory leak in ctypes fixed." The code in this patch leaves no way to give up the ownership of a BSTR instance. ........ r54538 | thomas.heller | 2007-03-22 13:34:37 -0700 (Thu, 22 Mar 2007) | 2 lines Explain the purpose of the b_needsfree flag (forward ported from release25-maint). ........ r54539 | guido.van.rossum | 2007-03-22 21:58:42 -0700 (Thu, 22 Mar 2007) | 12 lines - Bug #1683368: The object.__init__() and object.__new__() methods are now stricter in rejecting excess arguments. The only time when either allows excess arguments is when it is not overridden and the other one is. For backwards compatibility, when both are overridden, it is a deprecation warning (for now; maybe a Py3k warning later). When merging this into 3.0, the warnings should become errors. Note: without the change to string.py, lots of spurious warnings happen. What's going on there? ........ r54540 | neal.norwitz | 2007-03-22 22:17:23 -0700 (Thu, 22 Mar 2007) | 1 line Add Mark Dickinson for SF # 1675423. ........ r54541 | martin.v.loewis | 2007-03-23 03:35:49 -0700 (Fri, 23 Mar 2007) | 3 lines Patch #1686451: Fix return type for PySequence_{Count,Index,Fast_GET_SIZE}. Will backport. ........ r54543 | martin.v.loewis | 2007-03-23 06:27:15 -0700 (Fri, 23 Mar 2007) | 3 lines Bug #978833: Revert r50844, as it broke _socketobject.dup. Will backport. ........ r54545 | guido.van.rossum | 2007-03-23 11:53:03 -0700 (Fri, 23 Mar 2007) | 8 lines Add a type.__init__() method that enforces the same signature as type.__new__(), and then calls object.__init__(cls), just to be anal. This allows us to restore the code in string.py's _TemplateMetaclass that called super(...).__init__(name, bases, dct), which I commented out yesterday since it broke due to the stricter argument checking added to object.__init__(). ........ r54546 | facundo.batista | 2007-03-23 11:54:07 -0700 (Fri, 23 Mar 2007) | 4 lines Added a 'create_connect()' function to socket.py, which creates a connection with an optional timeout, and modified httplib.py to use this function in HTTPConnection. Applies patch 1676823. ........ r54547 | guido.van.rossum | 2007-03-23 12:39:01 -0700 (Fri, 23 Mar 2007) | 2 lines Add note about type.__init__(). ........ r54553 | thomas.heller | 2007-03-23 12:55:27 -0700 (Fri, 23 Mar 2007) | 5 lines Prevent creation (followed by a segfault) of array types when the size overflows the valid Py_ssize_t range. Check return values of PyMem_Malloc. Will backport to release25-maint. ........ r54555 | facundo.batista | 2007-03-23 13:23:08 -0700 (Fri, 23 Mar 2007) | 6 lines Surrounded with try/finally to socket's default timeout setting changes in the tests, so failing one test won't produce strange results in others. Also relaxed the timeout settings in the test (where actually the value didn't mean anything). ........ r54556 | collin.winter | 2007-03-23 15:24:39 -0700 (Fri, 23 Mar 2007) | 1 line Make test_relpath() pass on Windows. ........ r54559 | ziga.seilnacht | 2007-03-24 07:24:26 -0700 (Sat, 24 Mar 2007) | 6 lines Patch #1489771: update syntax rules in Python Reference Manual. Python 2.5 added support for explicit relative import statements and yield expressions, which were missing in the manual. Also fix grammar productions that used the names from the Grammar file, markup that broke the generated grammar.txt, and wrap some lines that broke the pdf output. Will backport. ........ r54565 | georg.brandl | 2007-03-24 15:20:34 -0700 (Sat, 24 Mar 2007) | 2 lines Remove typo accent. ........ r54566 | georg.brandl | 2007-03-24 15:27:56 -0700 (Sat, 24 Mar 2007) | 2 lines Revert accidental change. ........ r54567 | brett.cannon | 2007-03-24 18:32:36 -0700 (Sat, 24 Mar 2007) | 3 lines Change the docs to no longer claim that unittest is preferred over doctest for regression tests. ........ r54568 | facundo.batista | 2007-03-24 18:53:21 -0700 (Sat, 24 Mar 2007) | 4 lines Redone the tests, using the infrastructure already present for threading and socket serving. ........ r54570 | facundo.batista | 2007-03-24 20:20:05 -0700 (Sat, 24 Mar 2007) | 3 lines Closing the HTTP connection after each test, and listening more. ........ r54572 | georg.brandl | 2007-03-25 11:44:35 -0700 (Sun, 25 Mar 2007) | 2 lines Markup fix. ........ r54573 | georg.brandl | 2007-03-25 12:04:55 -0700 (Sun, 25 Mar 2007) | 2 lines Markup fix. ........ r54580 | facundo.batista | 2007-03-26 13:18:31 -0700 (Mon, 26 Mar 2007) | 5 lines Added an optional timeout to FTP class. Also I started a test_ftplib.py file to test the ftp lib (right now I included a basic test, the timeout one, and nothing else). ........ r54581 | georg.brandl | 2007-03-26 13:28:28 -0700 (Mon, 26 Mar 2007) | 2 lines Some nits. ........ r54582 | facundo.batista | 2007-03-26 13:56:09 -0700 (Mon, 26 Mar 2007) | 4 lines Forgot to add the file before the previous commit, here go the ftplib tests. ........ r54585 | facundo.batista | 2007-03-27 11:23:21 -0700 (Tue, 27 Mar 2007) | 5 lines Added an optional timeout to poplib.POP3. Also created a test_poplib.py file with a basic test and the timeout ones. Docs are also updated. ........ r54586 | facundo.batista | 2007-03-27 11:50:29 -0700 (Tue, 27 Mar 2007) | 3 lines The basic test cases of poplib.py. ........ r54594 | facundo.batista | 2007-03-27 20:45:20 -0700 (Tue, 27 Mar 2007) | 4 lines Bug 1688393. Adds a control of negative values in socket.recvfrom, which caused an ugly crash. ........ r54599 | facundo.batista | 2007-03-28 11:25:54 -0700 (Wed, 28 Mar 2007) | 5 lines Added timeout to smtplib (to SMTP and SMTP_SSL). Also created the test_smtplib.py file, with a basic test and the timeout ones. Docs are updated too. ........ r54603 | collin.winter | 2007-03-28 16:34:06 -0700 (Wed, 28 Mar 2007) | 3 lines Consolidate patches #1690164, 1683397, and 1690169, all of which refactor XML-related test suites. The patches are applied together because they use a common output/xmltests file. Thanks to Jerry Seutter for all three patches. ........ r54604 | collin.winter | 2007-03-28 19:28:16 -0700 (Wed, 28 Mar 2007) | 1 line Make test_zipfile clean up its temporary files properly. ........ r54605 | georg.brandl | 2007-03-29 00:41:32 -0700 (Thu, 29 Mar 2007) | 2 lines These are actually methods. ........ r54606 | georg.brandl | 2007-03-29 05:42:07 -0700 (Thu, 29 Mar 2007) | 4 lines In Windows' time.clock(), when QueryPerformanceFrequency() fails, the C lib's clock() is used, but it must be divided by CLOCKS_PER_SEC as for the POSIX implementation (thanks to #pypy). ........ r54608 | facundo.batista | 2007-03-29 11:22:35 -0700 (Thu, 29 Mar 2007) | 5 lines Added timout parameter to telnetlib.Telnet. Also created test_telnetlib.py with a basic test and timeout ones. Docs are also updated. ........ r54613 | facundo.batista | 2007-03-30 06:00:35 -0700 (Fri, 30 Mar 2007) | 4 lines Added the posibility to pass the timeout to FTP.connect, not only when instantiating the class. Docs and tests are updated. ........ r54614 | collin.winter | 2007-03-30 07:01:25 -0700 (Fri, 30 Mar 2007) | 1 line Bug #1688274: add documentation for C-level class objects. ........ r54615 | marc-andre.lemburg | 2007-03-30 08:01:42 -0700 (Fri, 30 Mar 2007) | 4 lines Bump the patch level version of distutils since there were a few bug fixes since the 2.5.0 release. ........ r54617 | georg.brandl | 2007-03-30 08:49:05 -0700 (Fri, 30 Mar 2007) | 2 lines Markup fix. ........ r54618 | georg.brandl | 2007-03-30 10:39:39 -0700 (Fri, 30 Mar 2007) | 2 lines Label name fix. ........ r54619 | georg.brandl | 2007-03-30 10:47:21 -0700 (Fri, 30 Mar 2007) | 2 lines Duplicate label fix. ........ r54620 | georg.brandl | 2007-03-30 10:48:39 -0700 (Fri, 30 Mar 2007) | 2 lines Markup fix. ........ r54623 | andrew.kuchling | 2007-03-30 11:00:15 -0700 (Fri, 30 Mar 2007) | 1 line Add item. (Oops, accidentally checked this in on my branch) ........ r54624 | georg.brandl | 2007-03-30 12:01:38 -0700 (Fri, 30 Mar 2007) | 2 lines Duplicate label fix. ........ r54625 | georg.brandl | 2007-03-30 12:14:02 -0700 (Fri, 30 Mar 2007) | 2 lines Markup fix. ........ r54629 | georg.brandl | 2007-03-31 03:17:31 -0700 (Sat, 31 Mar 2007) | 2 lines repair string literal. ........ r54630 | georg.brandl | 2007-03-31 04:54:58 -0700 (Sat, 31 Mar 2007) | 2 lines Markup fix. ........ r54631 | georg.brandl | 2007-03-31 04:58:36 -0700 (Sat, 31 Mar 2007) | 2 lines Duplicate label fix. ........ r54632 | georg.brandl | 2007-03-31 04:59:54 -0700 (Sat, 31 Mar 2007) | 2 lines Typo fix. ........ r54633 | neal.norwitz | 2007-03-31 11:54:18 -0700 (Sat, 31 Mar 2007) | 1 line Fix method names. Will backport. ........ r54634 | georg.brandl | 2007-03-31 11:56:11 -0700 (Sat, 31 Mar 2007) | 4 lines Bug #1655392: don't add -L/usr/lib/pythonX.Y/config to the LDFLAGS returned by python-config if Python was built with --enable-shared because that prevented the shared library from being used. ........ r54637 | collin.winter | 2007-03-31 12:31:34 -0700 (Sat, 31 Mar 2007) | 1 line Shut up an occaisonal buildbot error due to test files being left around. ........ r54644 | neal.norwitz | 2007-04-01 11:24:22 -0700 (Sun, 01 Apr 2007) | 11 lines SF #1685563, MSVCCompiler creates redundant and long PATH strings If MSVCCompiler.initialize() was called multiple times, the path would get duplicated. On Windows, this is a problem because the path is limited to 4k. There's no benefit in adding a path multiple times, so prevent that from occuring. We also normalize the path before checking for duplicates so things like /a and /a/ won't both be stored. Will backport. ........ r54646 | brett.cannon | 2007-04-01 11:47:27 -0700 (Sun, 01 Apr 2007) | 8 lines time.strptime's caching of its locale object was being recreated when the locale changed but not used during the function call it was recreated during. The test in this checkin is untested (OS X does not have the proper locale support for me to test), although the fix for the bug this deals with was tested by the OP (#1290505). Once the buildbots verify the test at least doesn't fail it becomes a backport candidate. ........ r54647 | brett.cannon | 2007-04-01 12:46:19 -0700 (Sun, 01 Apr 2007) | 3 lines Fix the test for recreating the locale cache object by not worrying about if one of the test locales cannot be set. ........ r54649 | georg.brandl | 2007-04-01 14:29:15 -0700 (Sun, 01 Apr 2007) | 2 lines Fix a lot of markup and meta-information glitches. ........ r54650 | georg.brandl | 2007-04-01 14:39:52 -0700 (Sun, 01 Apr 2007) | 2 lines Another fix. ........ r54651 | georg.brandl | 2007-04-01 15:39:10 -0700 (Sun, 01 Apr 2007) | 2 lines Lots of explicit class names for method and member descs. ........ r54652 | georg.brandl | 2007-04-01 15:40:12 -0700 (Sun, 01 Apr 2007) | 2 lines Explicit class names. ........ r54653 | georg.brandl | 2007-04-01 15:47:31 -0700 (Sun, 01 Apr 2007) | 2 lines Some semantic fixes. ........ r54654 | georg.brandl | 2007-04-01 16:29:10 -0700 (Sun, 01 Apr 2007) | 2 lines Remove bogus entry. ........ r54655 | georg.brandl | 2007-04-01 16:31:30 -0700 (Sun, 01 Apr 2007) | 2 lines Fix the class name of strings. ........ r54658 | raymond.hettinger | 2007-04-02 10:29:30 -0700 (Mon, 02 Apr 2007) | 1 line SF #1693079: Cannot save empty array in shelve ........ r54663 | raymond.hettinger | 2007-04-02 15:54:21 -0700 (Mon, 02 Apr 2007) | 3 lines Array module's buffer interface can now handle empty arrays. ........ r54664 | guido.van.rossum | 2007-04-02 16:55:37 -0700 (Mon, 02 Apr 2007) | 5 lines Fix warnings about object.__init__() signature. Two (test_array and test_descr) were bug IMO; the third (copy_reg) is a work-around which recognizes that object.__init__() doesn't do anything. ........ r54666 | raymond.hettinger | 2007-04-02 17:02:11 -0700 (Mon, 02 Apr 2007) | 1 line SF 1602378 Clarify docstrings for bisect ........ r54668 | raymond.hettinger | 2007-04-02 18:39:43 -0700 (Mon, 02 Apr 2007) | 3 lines SF #1382213: Tutorial section 9.5.1 ignores MRO for new-style classes ........ r54669 | matthias.klose | 2007-04-02 21:35:59 -0700 (Mon, 02 Apr 2007) | 4 lines - Fix an off-by-one bug in locale.strxfrm(). patch taken from http://bugs.debian.org/416934. ........ r54671 | georg.brandl | 2007-04-03 00:04:27 -0700 (Tue, 03 Apr 2007) | 9 lines Fix the strange case of \begin{methoddesc}[NNTP]{...} where \ifx#1\@undefined ended up comparing N and N, therefore executing the true part of the conditional, blowing up at \@undefined. ........ r54672 | facundo.batista | 2007-04-03 07:05:08 -0700 (Tue, 03 Apr 2007) | 4 lines Now using unittest for the tests infraestructure. Also split the tests in those who need the network, and that who doesn't. ........ r54673 | walter.doerwald | 2007-04-03 09:08:10 -0700 (Tue, 03 Apr 2007) | 4 lines Move the functionality for catching warnings in test_warnings.py into a separate class to that reusing the functionality in test_structmembers.py doesn't rerun the tests from test_warnings.py. ........ r54674 | walter.doerwald | 2007-04-03 09:16:24 -0700 (Tue, 03 Apr 2007) | 2 lines Document that CatchWarningTests is reused by test_structmembers.py. ........ r54675 | walter.doerwald | 2007-04-03 09:53:43 -0700 (Tue, 03 Apr 2007) | 4 lines Add tests for the filename. Test that the stacklevel is handled correctly. ........ r54676 | facundo.batista | 2007-04-03 10:29:48 -0700 (Tue, 03 Apr 2007) | 6 lines Added a SSL server to test_socket_ssl.py to be able to test locally. Now, it checks if have openssl available and run those specific tests (it starts openssl at the beggining of all the tests and then kills it at the end). ........ r54677 | walter.doerwald | 2007-04-03 11:33:29 -0700 (Tue, 03 Apr 2007) | 6 lines Implement a contextmanager test.test_support.catch_warning that can be used to catch the last warning issued by the warning framework. Change test_warnings.py and test_structmembers.py to use this new contextmanager. ........ r54678 | facundo.batista | 2007-04-03 14:15:34 -0700 (Tue, 03 Apr 2007) | 4 lines Changed the whole structure of startup and checking if the server is available. Hope to not get more false alarms. ........ r54681 | facundo.batista | 2007-04-04 07:10:40 -0700 (Wed, 04 Apr 2007) | 4 lines Fixed the way that the .pem files are looked for, and changed how to kill the process in win32 to use the _handle attribute. ........ r54682 | guido.van.rossum | 2007-04-04 10:43:02 -0700 (Wed, 04 Apr 2007) | 4 lines Fix a race condition in this test -- instead of assuming that it will take the test server thread at most 0.5 seconds to get ready, use an event variable. ........ r54683 | collin.winter | 2007-04-04 11:14:17 -0700 (Wed, 04 Apr 2007) | 1 line Clean up imports. ........ r54684 | collin.winter | 2007-04-04 11:16:24 -0700 (Wed, 04 Apr 2007) | 1 line Stop using test_support.verify(). ........ r54685 | martin.v.loewis | 2007-04-04 11:30:36 -0700 (Wed, 04 Apr 2007) | 2 lines Bug #1686475: Support stat'ing open files on Windows again. Will backport to 2.5. ........ r54687 | collin.winter | 2007-04-04 11:33:40 -0700 (Wed, 04 Apr 2007) | 1 line Make test_getopt use unittest. ........ r54688 | collin.winter | 2007-04-04 11:36:30 -0700 (Wed, 04 Apr 2007) | 1 line Make test_softspace use unittest. ........ r54689 | ziga.seilnacht | 2007-04-04 11:38:47 -0700 (Wed, 04 Apr 2007) | 2 lines Fix WalkTests.test_traversal() on Windows. The cleanup in MakedirTests.setUp() can now be removed. ........ r54695 | raymond.hettinger | 2007-04-05 11:00:03 -0700 (Thu, 05 Apr 2007) | 3 lines Bug #1563759: struct.unpack doens't support buffer protocol objects ........ r54697 | collin.winter | 2007-04-05 13:05:07 -0700 (Thu, 05 Apr 2007) | 1 line Convert test_long_future to use unittest. ........ r54698 | collin.winter | 2007-04-05 13:08:56 -0700 (Thu, 05 Apr 2007) | 1 line Convert test_normalization to use unittest. ........ r54699 | andrew.kuchling | 2007-04-05 18:11:58 -0700 (Thu, 05 Apr 2007) | 1 line Some grammar fixes ........ r54704 | collin.winter | 2007-04-06 12:27:40 -0700 (Fri, 06 Apr 2007) | 1 line Convert test_stringprep to use unittest. ........ r54705 | collin.winter | 2007-04-06 12:32:32 -0700 (Fri, 06 Apr 2007) | 1 line Import cleanup in test_crypt. ........ r54706 | collin.winter | 2007-04-06 13:00:05 -0700 (Fri, 06 Apr 2007) | 1 line Convert test_gc to use unittest. ........ r54707 | collin.winter | 2007-04-06 13:03:11 -0700 (Fri, 06 Apr 2007) | 1 line Convert test_module to use unittest. ........ r54711 | collin.winter | 2007-04-06 21:40:43 -0700 (Fri, 06 Apr 2007) | 1 line Convert test_fileinput to use unittest. ........ r54712 | brett.cannon | 2007-04-07 21:29:32 -0700 (Sat, 07 Apr 2007) | 5 lines Doc that file.next() has undefined behaviour when called on a file opened with 'w'. Closes bug #1569057. To be backported once 2.5 branch is unfrozen. ........ r54726 | vinay.sajip | 2007-04-09 09:16:10 -0700 (Mon, 09 Apr 2007) | 1 line Added optional timeout to SocketHandler.makeSocket (SF #1695948) ........ r54727 | ziga.seilnacht | 2007-04-09 12:10:29 -0700 (Mon, 09 Apr 2007) | 3 lines Patch #1695862: remove old test directory that causes test_urllib failures on Windows buildbots. The change is a one time fix and will be removed after a successful buildbot run. ........ r54729 | facundo.batista | 2007-04-09 20:00:37 -0700 (Mon, 09 Apr 2007) | 3 lines Minor fix to the tests pass ok even with -O. ........ r54730 | collin.winter | 2007-04-09 21:44:49 -0700 (Mon, 09 Apr 2007) | 1 line Typo fix. ........ r54732 | facundo.batista | 2007-04-10 05:58:45 -0700 (Tue, 10 Apr 2007) | 5 lines General clean-up. Lot of margin corrections, comments, some typos. Exceptions now are raised in the new style. And a mockup class is now also new style. Thanks Santiago Pereson. ........ r54741 | georg.brandl | 2007-04-10 14:39:38 -0700 (Tue, 10 Apr 2007) | 2 lines Repair a duplicate label and some obsolete uses of \setindexsubitem. ........ r54746 | andrew.kuchling | 2007-04-11 06:39:00 -0700 (Wed, 11 Apr 2007) | 1 line Add window.chgat() method, submitted via e-mail by Fabian Kreutz ........ r54747 | andrew.kuchling | 2007-04-11 06:42:25 -0700 (Wed, 11 Apr 2007) | 1 line Point readers at the patch submission instructions ........ r54748 | andrew.kuchling | 2007-04-11 06:47:13 -0700 (Wed, 11 Apr 2007) | 1 line Describe undocumented third argument to touchline() ........ r54757 | georg.brandl | 2007-04-11 10:16:24 -0700 (Wed, 11 Apr 2007) | 3 lines Add some missing NULL checks which trigger crashes on low-memory conditions. Found by Victor Stinner. Will backport when 2.5 branch is unfrozen. ........ r54760 | raymond.hettinger | 2007-04-11 11:40:58 -0700 (Wed, 11 Apr 2007) | 1 line SF 1191699: Make slices picklable ........ r54762 | georg.brandl | 2007-04-11 12:25:11 -0700 (Wed, 11 Apr 2007) | 2 lines Exceptions are no longer old-style instances. Fix accordingly. ........ r54763 | georg.brandl | 2007-04-11 16:28:44 -0700 (Wed, 11 Apr 2007) | 2 lines Repair missing spaces after \UNIX. ........ r54772 | raymond.hettinger | 2007-04-11 21:10:00 -0700 (Wed, 11 Apr 2007) | 1 line SF 1193128: Let str.translate(None) be an identity transformation ........ r54784 | georg.brandl | 2007-04-12 00:01:19 -0700 (Thu, 12 Apr 2007) | 2 lines Patch #1698951: clarify deprecation message in rexec and Bastion ........ r54785 | ziga.seilnacht | 2007-04-12 01:46:51 -0700 (Thu, 12 Apr 2007) | 2 lines Patch #1695862: remove the cleanup code, now that Windows buildbots are green again. ........ r54786 | walter.doerwald | 2007-04-12 03:35:00 -0700 (Thu, 12 Apr 2007) | 3 lines Fix utf-8-sig incremental decoder, which didn't recognise a BOM when the first chunk fed to the decoder started with a BOM, but was longer than 3 bytes. ........ r54807 | barry.warsaw | 2007-04-13 11:47:14 -0700 (Fri, 13 Apr 2007) | 8 lines Port r54805 from python25-maint branch: Add code to read from master_fd in the parent, breaking when we get an OSError (EIO can occur on Linux) or there's no more data to read. Without this, test_pty.py can hang on the waitpid() because the child is blocking on the stdout write. This will definitely happen on Mac OS X and could potentially happen on other platforms. See the comment for details. ........ r54812 | kristjan.jonsson | 2007-04-13 15:07:33 -0700 (Fri, 13 Apr 2007) | 1 line Fix a bug when using the __lltrace__ opcode tracer, and a problem sith signed chars in frameobject.c which can occur with opcodes > 127 ........ r54814 | kristjan.jonsson | 2007-04-13 15:20:13 -0700 (Fri, 13 Apr 2007) | 1 line Fix potential crash in path manipulation on windows ........ r54816 | trent.mick | 2007-04-13 16:22:05 -0700 (Fri, 13 Apr 2007) | 4 lines Add the necessary dependency for the Windows VC6 build to ensure 'pythoncore' is built before '_ctypes' is attempted. Will backport to 2.5 once it is unfrozen for 2.5.1. ........ r54825 | neal.norwitz | 2007-04-13 22:25:50 -0700 (Fri, 13 Apr 2007) | 3 lines When __slots__ are set to a unicode string, make it work the same as setting a plain string, ie don't expand to single letter identifiers. ........ r54841 | neal.norwitz | 2007-04-16 00:37:55 -0700 (Mon, 16 Apr 2007) | 1 line SF #1701207, Fix bogus assertion (and test it!) ........ r54844 | collin.winter | 2007-04-16 15:10:32 -0700 (Mon, 16 Apr 2007) | 1 line Check the availability of the urlfetch resource earlier than before. ........ r54849 | martin.v.loewis | 2007-04-16 22:02:01 -0700 (Mon, 16 Apr 2007) | 2 lines Add Travis Oliphant. ........ r54873 | brett.cannon | 2007-04-18 20:44:17 -0700 (Wed, 18 Apr 2007) | 2 lines Silence a compiler warning about incompatible pointer types. ........ r54874 | neal.norwitz | 2007-04-18 22:52:37 -0700 (Wed, 18 Apr 2007) | 2 lines SF #1703270, add missing declaration in readline.c to avoid compiler warning. ........ r54875 | armin.rigo | 2007-04-19 07:44:48 -0700 (Thu, 19 Apr 2007) | 8 lines Revert r53997 as per http://mail.python.org/pipermail/python-dev/2007-March/071796.html . I've kept a couple of still-valid extra tests in test_descr, but didn't bother to sort through the new comments and refactorings added in r53997 to see if some of them could be kept. If so, they could go in a follow-up check-in. ........ r54876 | armin.rigo | 2007-04-19 07:56:48 -0700 (Thu, 19 Apr 2007) | 2 lines Fix a usage of the dangerous pattern decref - modify field - incref. ........ r54884 | neal.norwitz | 2007-04-19 22:20:38 -0700 (Thu, 19 Apr 2007) | 9 lines Add an optional address to copy the failure mails to. Detect a conflict in the only file that should have outstanding changes when this script is run. This doesn't matter on the trunk, but does when run on a branch. Trunk always has the date set to today in boilerplate.tex. Each time a release is cut with a different date, a conflict occurs. (We could copy a known good version, but then we would lose changes to this file.) ........ r54918 | georg.brandl | 2007-04-21 13:35:38 -0700 (Sat, 21 Apr 2007) | 3 lines Bug #1704790: bind name "sys" locally in __del__ method so that it is not cleared before __del__ is run. ........ r54920 | facundo.batista | 2007-04-21 18:18:56 -0700 (Sat, 21 Apr 2007) | 5 lines Added tests for other methods of SSL object. Now we cover all the object methods. This is the final step to close the #451607 bug. ........ r54927 | facundo.batista | 2007-04-23 10:08:31 -0700 (Mon, 23 Apr 2007) | 5 lines As specified in RFC 2616, 2xx code indicates that the client's request was successfully received, understood, and accepted. Now in these cases no error is raised. Also fixed tests. ........ r54929 | collin.winter | 2007-04-23 20:43:46 -0700 (Mon, 23 Apr 2007) | 1 line Convert PyUnit -> unittest. ........ r54931 | collin.winter | 2007-04-23 21:09:52 -0700 (Mon, 23 Apr 2007) | 1 line Remove code that hasn't been called in years. ........ r54932 | neal.norwitz | 2007-04-23 21:53:12 -0700 (Mon, 23 Apr 2007) | 1 line Fix SF #1703110, Incorrect example for add_password() (use uri, not host) ........ r54934 | georg.brandl | 2007-04-24 03:36:42 -0700 (Tue, 24 Apr 2007) | 2 lines Some new year updates. ........ r54938 | facundo.batista | 2007-04-24 06:54:38 -0700 (Tue, 24 Apr 2007) | 4 lines Added a comment about last change in urllib2.py (all 2xx responses are ok now). ........ r54939 | georg.brandl | 2007-04-24 08:10:09 -0700 (Tue, 24 Apr 2007) | 2 lines Bug #1705717: error in sys.argv docs. ........ r54941 | georg.brandl | 2007-04-24 08:27:13 -0700 (Tue, 24 Apr 2007) | 4 lines Bug #1706381: Specifying the SWIG option "-c++" in the setup.py file (as opposed to the command line) will now write file names ending in ".cpp" too. ........ r54944 | raymond.hettinger | 2007-04-24 15:13:43 -0700 (Tue, 24 Apr 2007) | 1 line Fix markup ........ r54945 | kristjan.jonsson | 2007-04-24 17:10:50 -0700 (Tue, 24 Apr 2007) | 1 line Merge change 54909 from release25-maint: Fix several minor issues discovered using code analysis in VisualStudio 2005 Team Edition ........ r54947 | kristjan.jonsson | 2007-04-24 17:17:39 -0700 (Tue, 24 Apr 2007) | 1 line Make pythoncore compile cleanly with VisualStudio 2005. Used an explicit typecast to get a 64 bit integer, and undefined the Yield macro that conflicts with winbase.h ........ r54948 | kristjan.jonsson | 2007-04-24 17:19:26 -0700 (Tue, 24 Apr 2007) | 1 line Remove obsolete comment. Importing of .dll files has been discontinued, only .pyd files supported on windows now. ........ r54949 | georg.brandl | 2007-04-24 23:24:59 -0700 (Tue, 24 Apr 2007) | 2 lines Patch #1698768: updated the "using Python on the Mac" intro. ........ r54951 | georg.brandl | 2007-04-24 23:25:55 -0700 (Tue, 24 Apr 2007) | 2 lines Markup fix. ........ r54953 | neal.norwitz | 2007-04-24 23:30:05 -0700 (Tue, 24 Apr 2007) | 3 lines Whitespace normalization. Ugh, we really need to do this more often. You might want to review this change as it's my first time. Be gentle. :-) ........ r54956 | collin.winter | 2007-04-25 10:29:52 -0700 (Wed, 25 Apr 2007) | 1 line Standardize on test.test_support.run_unittest() (as opposed to a mix of run_unittest() and run_suite()). Also, add functionality to run_unittest() that admits usage of unittest.TestLoader.loadTestsFromModule(). ........ r54957 | collin.winter | 2007-04-25 10:37:35 -0700 (Wed, 25 Apr 2007) | 1 line Remove functionality from test_datetime.test_main() that does reference count checking; 'regrtest.py -R' is the way to do this kind of testing. ........ r54958 | collin.winter | 2007-04-25 10:57:53 -0700 (Wed, 25 Apr 2007) | 1 line Change test_support.have_unicode to use True/False instead of 1/0. ........ r54959 | tim.peters | 2007-04-25 11:47:18 -0700 (Wed, 25 Apr 2007) | 2 lines Whitespace normalization. ........ r54960 | tim.peters | 2007-04-25 11:48:35 -0700 (Wed, 25 Apr 2007) | 2 lines Set missing svn:eol-style property on text files. ........ r54961 | collin.winter | 2007-04-25 11:54:36 -0700 (Wed, 25 Apr 2007) | 1 line Import and raise statement cleanup. ........ r54969 | collin.winter | 2007-04-25 13:41:34 -0700 (Wed, 25 Apr 2007) | 1 line Convert test_ossaudiodev to use unittest. ........ r54974 | collin.winter | 2007-04-25 14:50:25 -0700 (Wed, 25 Apr 2007) | 1 line Fix an issue related to the unittest conversion. ........ r54979 | fred.drake | 2007-04-25 21:42:19 -0700 (Wed, 25 Apr 2007) | 1 line fix some markup errors ........ r54982 | kristjan.jonsson | 2007-04-26 02:15:08 -0700 (Thu, 26 Apr 2007) | 1 line Export function sanitize_the_mode from fileobject.c as _PyFile_SanitizeMode(). Use this function in posixmodule.c when implementing fdopen(). This fixes test_subprocess.py for a VisualStudio 2005 compile. ........ r54983 | kristjan.jonsson | 2007-04-26 06:44:16 -0700 (Thu, 26 Apr 2007) | 1 line The locale "En" appears not to be valid on windows underi VisualStudio.2005. Added "English" to the test_locale.py to make the testsuite pass for that build ........ r54984 | steve.holden | 2007-04-26 07:23:12 -0700 (Thu, 26 Apr 2007) | 1 line Minor wording change on slicing aide-memoire. ........ r54985 | kristjan.jonsson | 2007-04-26 08:24:54 -0700 (Thu, 26 Apr 2007) | 1 line Accomodate 64 bit time_t in the _bsddb module. ........
1276 lines
50 KiB
TeX
1276 lines
50 KiB
TeX
\chapter{Expressions\label{expressions}}
|
|
\index{expression}
|
|
|
|
This chapter explains the meaning of the elements of expressions in
|
|
Python.
|
|
|
|
\strong{Syntax Notes:} In this and the following chapters, extended
|
|
BNF\index{BNF} notation will be used to describe syntax, not lexical
|
|
analysis. When (one alternative of) a syntax rule has the form
|
|
|
|
\begin{productionlist}[*]
|
|
\production{name}{\token{othername}}
|
|
\end{productionlist}
|
|
|
|
and no semantics are given, the semantics of this form of \code{name}
|
|
are the same as for \code{othername}.
|
|
\index{syntax}
|
|
|
|
|
|
\section{Arithmetic conversions\label{conversions}}
|
|
\indexii{arithmetic}{conversion}
|
|
|
|
When a description of an arithmetic operator below uses the phrase
|
|
``the numeric arguments are converted to a common type,'' the
|
|
arguments are coerced using the coercion rules listed at
|
|
~\ref{coercion-rules}. If both arguments are standard numeric types,
|
|
the following coercions are applied:
|
|
|
|
\begin{itemize}
|
|
\item If either argument is a complex number, the other is converted
|
|
to complex;
|
|
\item otherwise, if either argument is a floating point number,
|
|
the other is converted to floating point;
|
|
\item otherwise, if either argument is a long integer,
|
|
the other is converted to long integer;
|
|
\item otherwise, both must be plain integers and no conversion
|
|
is necessary.
|
|
\end{itemize}
|
|
|
|
Some additional rules apply for certain operators (e.g., a string left
|
|
argument to the `\%' operator). Extensions can define their own
|
|
coercions.
|
|
|
|
|
|
\section{Atoms\label{atoms}}
|
|
\index{atom}
|
|
|
|
Atoms are the most basic elements of expressions. The simplest atoms
|
|
are identifiers or literals. Forms enclosed in
|
|
reverse quotes or in parentheses, brackets or braces are also
|
|
categorized syntactically as atoms. The syntax for atoms is:
|
|
|
|
\begin{productionlist}
|
|
\production{atom}
|
|
{\token{identifier} | \token{literal} | \token{enclosure}}
|
|
\production{enclosure}
|
|
{\token{parenth_form} | \token{list_display}}
|
|
\productioncont{| \token{generator_expression} | \token{dict_display}}
|
|
\productioncont{| \token{string_conversion} | \token{yield_atom}}
|
|
\end{productionlist}
|
|
|
|
|
|
\subsection{Identifiers (Names)\label{atom-identifiers}}
|
|
\index{name}
|
|
\index{identifier}
|
|
|
|
An identifier occurring as an atom is a name. See
|
|
section \ref{identifiers} for lexical definition and
|
|
section~\ref{naming} for documentation of naming and binding.
|
|
|
|
When the name is bound to an object, evaluation of the atom yields
|
|
that object. When a name is not bound, an attempt to evaluate it
|
|
raises a \exception{NameError} exception.
|
|
\exindex{NameError}
|
|
|
|
\strong{Private name mangling:}
|
|
\indexii{name}{mangling}%
|
|
\indexii{private}{names}%
|
|
When an identifier that textually occurs in a class definition begins
|
|
with two or more underscore characters and does not end in two or more
|
|
underscores, it is considered a \dfn{private name} of that class.
|
|
Private names are transformed to a longer form before code is
|
|
generated for them. The transformation inserts the class name in
|
|
front of the name, with leading underscores removed, and a single
|
|
underscore inserted in front of the class name. For example, the
|
|
identifier \code{__spam} occurring in a class named \code{Ham} will be
|
|
transformed to \code{_Ham__spam}. This transformation is independent
|
|
of the syntactical context in which the identifier is used. If the
|
|
transformed name is extremely long (longer than 255 characters),
|
|
implementation defined truncation may happen. If the class name
|
|
consists only of underscores, no transformation is done.
|
|
|
|
|
|
\subsection{Literals\label{atom-literals}}
|
|
\index{literal}
|
|
|
|
Python supports string literals and various numeric literals:
|
|
|
|
\begin{productionlist}
|
|
\production{literal}
|
|
{\token{stringliteral} | \token{integer} | \token{longinteger}}
|
|
\productioncont{| \token{floatnumber} | \token{imagnumber}}
|
|
\end{productionlist}
|
|
|
|
Evaluation of a literal yields an object of the given type (string,
|
|
integer, long integer, floating point number, complex number) with the
|
|
given value. The value may be approximated in the case of floating
|
|
point and imaginary (complex) literals. See section \ref{literals}
|
|
for details.
|
|
|
|
All literals correspond to immutable data types, and hence the
|
|
object's identity is less important than its value. Multiple
|
|
evaluations of literals with the same value (either the same
|
|
occurrence in the program text or a different occurrence) may obtain
|
|
the same object or a different object with the same value.
|
|
\indexiii{immutable}{data}{type}
|
|
\indexii{immutable}{object}
|
|
|
|
|
|
\subsection{Parenthesized forms\label{parenthesized}}
|
|
\index{parenthesized form}
|
|
|
|
A parenthesized form is an optional expression list enclosed in
|
|
parentheses:
|
|
|
|
\begin{productionlist}
|
|
\production{parenth_form}
|
|
{"(" [\token{expression_list}] ")"}
|
|
\end{productionlist}
|
|
|
|
A parenthesized expression list yields whatever that expression list
|
|
yields: if the list contains at least one comma, it yields a tuple;
|
|
otherwise, it yields the single expression that makes up the
|
|
expression list.
|
|
|
|
An empty pair of parentheses yields an empty tuple object. Since
|
|
tuples are immutable, the rules for literals apply (i.e., two
|
|
occurrences of the empty tuple may or may not yield the same object).
|
|
\indexii{empty}{tuple}
|
|
|
|
Note that tuples are not formed by the parentheses, but rather by use
|
|
of the comma operator. The exception is the empty tuple, for which
|
|
parentheses \emph{are} required --- allowing unparenthesized ``nothing''
|
|
in expressions would cause ambiguities and allow common typos to
|
|
pass uncaught.
|
|
\index{comma}
|
|
\indexii{tuple}{display}
|
|
|
|
|
|
\subsection{List displays\label{lists}}
|
|
\indexii{list}{display}
|
|
\indexii{list}{comprehensions}
|
|
|
|
A list display is a possibly empty series of expressions enclosed in
|
|
square brackets:
|
|
|
|
\begin{productionlist}
|
|
\production{list_display}
|
|
{"[" [\token{expression_list} | \token{list_comprehension}] "]"}
|
|
\production{list_comprehension}
|
|
{\token{expression} \token{list_for}}
|
|
\production{list_for}
|
|
{"for" \token{target_list} "in" \token{old_expression_list}
|
|
[\token{list_iter}]}
|
|
\production{old_expression_list}
|
|
{\token{old_expression}
|
|
[("," \token{old_expression})+ [","]]}
|
|
\production{list_iter}
|
|
{\token{list_for} | \token{list_if}}
|
|
\production{list_if}
|
|
{"if" \token{old_expression} [\token{list_iter}]}
|
|
\end{productionlist}
|
|
|
|
A list display yields a new list object. Its contents are specified
|
|
by providing either a list of expressions or a list comprehension.
|
|
\indexii{list}{comprehensions}
|
|
When a comma-separated list of expressions is supplied, its elements are
|
|
evaluated from left to right and placed into the list object in that
|
|
order. When a list comprehension is supplied, it consists of a
|
|
single expression followed by at least one \keyword{for} clause and zero or
|
|
more \keyword{for} or \keyword{if} clauses. In this
|
|
case, the elements of the new list are those that would be produced
|
|
by considering each of the \keyword{for} or \keyword{if} clauses a block,
|
|
nesting from
|
|
left to right, and evaluating the expression to produce a list element
|
|
each time the innermost block is reached\footnote{In Python 2.3, a
|
|
list comprehension "leaks" the control variables of each
|
|
\samp{for} it contains into the containing scope. However, this
|
|
behavior is deprecated, and relying on it will not work once this
|
|
bug is fixed in a future release}.
|
|
\obindex{list}
|
|
\indexii{empty}{list}
|
|
|
|
|
|
\subsection{Generator expressions\label{genexpr}}
|
|
\indexii{generator}{expression}
|
|
|
|
A generator expression is a compact generator notation in parentheses:
|
|
|
|
\begin{productionlist}
|
|
\production{generator_expression}
|
|
{"(" \token{expression} \token{genexpr_for} ")"}
|
|
\production{genexpr_for}
|
|
{"for" \token{target_list} "in" \token{or_test}
|
|
[\token{genexpr_iter}]}
|
|
\production{genexpr_iter}
|
|
{\token{genexpr_for} | \token{genexpr_if}}
|
|
\production{genexpr_if}
|
|
{"if" \token{old_expression} [\token{genexpr_iter}]}
|
|
\end{productionlist}
|
|
|
|
A generator expression yields a new generator object.
|
|
\obindex{generator}
|
|
It consists of a single expression followed by at least one
|
|
\keyword{for} clause and zero or more \keyword{for} or \keyword{if}
|
|
clauses. The iterating values of the new generator are those that
|
|
would be produced by considering each of the \keyword{for} or
|
|
\keyword{if} clauses a block, nesting from left to right, and
|
|
evaluating the expression to yield a value that is reached the
|
|
innermost block for each iteration.
|
|
|
|
Variables used in the generator expression are evaluated lazily
|
|
when the \method{__next__()} method is called for generator object
|
|
(in the same fashion as normal generators). However, the leftmost
|
|
\keyword{for} clause is immediately evaluated so that error produced
|
|
by it can be seen before any other possible error in the code that
|
|
handles the generator expression.
|
|
Subsequent \keyword{for} clauses cannot be evaluated immediately since
|
|
they may depend on the previous \keyword{for} loop.
|
|
For example: \samp{(x*y for x in range(10) for y in bar(x))}.
|
|
|
|
The parentheses can be omitted on calls with only one argument.
|
|
See section \ref{calls} for the detail.
|
|
|
|
|
|
\subsection{Dictionary displays\label{dict}}
|
|
\indexii{dictionary}{display}
|
|
|
|
A dictionary display is a possibly empty series of key/datum pairs
|
|
enclosed in curly braces:
|
|
\index{key}
|
|
\index{datum}
|
|
\index{key/datum pair}
|
|
|
|
\begin{productionlist}
|
|
\production{dict_display}
|
|
{"\{" [\token{key_datum_list}] "\}"}
|
|
\production{key_datum_list}
|
|
{\token{key_datum} ("," \token{key_datum})* [","]}
|
|
\production{key_datum}
|
|
{\token{expression} ":" \token{expression}}
|
|
\end{productionlist}
|
|
|
|
A dictionary display yields a new dictionary object.
|
|
\obindex{dictionary}
|
|
|
|
The key/datum pairs are evaluated from left to right to define the
|
|
entries of the dictionary: each key object is used as a key into the
|
|
dictionary to store the corresponding datum.
|
|
|
|
Restrictions on the types of the key values are listed earlier in
|
|
section \ref{types}. (To summarize, the key type should be hashable,
|
|
which excludes all mutable objects.) Clashes between duplicate keys
|
|
are not detected; the last datum (textually rightmost in the display)
|
|
stored for a given key value prevails.
|
|
\indexii{immutable}{object}
|
|
|
|
|
|
\subsection{Yield expressions\label{yieldexpr}}
|
|
\kwindex{yield}
|
|
\indexii{yield}{expression}
|
|
\indexii{generator}{function}
|
|
|
|
\begin{productionlist}
|
|
\production{yield_atom}
|
|
{"(" \token{yield_expression} ")"}
|
|
\production{yield_expression}
|
|
{"yield" [\token{expression_list}]}
|
|
\end{productionlist}
|
|
|
|
\versionadded{2.5}
|
|
|
|
The \keyword{yield} expression is only used when defining a generator
|
|
function, and can only be used in the body of a function definition.
|
|
Using a \keyword{yield} expression in a function definition is
|
|
sufficient to cause that definition to create a generator function
|
|
instead of a normal function.
|
|
|
|
When a generator function is called, it returns an iterator known as a
|
|
generator. That generator then controls the execution of a generator
|
|
function. The execution starts when one of the generator's methods is
|
|
called. At that time, the execution proceeds to the first
|
|
\keyword{yield} expression, where it is suspended again, returning the
|
|
value of \grammartoken{expression_list} to generator's caller. By
|
|
suspended we mean that all local state is retained, including the
|
|
current bindings of local variables, the instruction pointer, and the
|
|
internal evaluation stack. When the execution is resumed by calling
|
|
one of the generator's methods, the function can proceed exactly as
|
|
if the \keyword{yield} expression was just another external call.
|
|
The value of the \keyword{yield} expression after resuming depends on
|
|
the method which resumed the execution.
|
|
|
|
\index{coroutine}
|
|
|
|
All of this makes generator functions quite similar to coroutines; they
|
|
yield multiple times, they have more than one entry point and their
|
|
execution can be suspended. The only difference is that a generator
|
|
function cannot control where should the execution continue after it
|
|
yields; the control is always transfered to the generator's caller.
|
|
|
|
\obindex{generator}
|
|
|
|
The following generator's methods can be used to control the execution
|
|
of a generator function:
|
|
|
|
\exindex{StopIteration}
|
|
|
|
\begin{methoddesc}[generator]{next}{}
|
|
Starts the execution of a generator function or resumes it at the
|
|
last executed \keyword{yield} expression. When a generator function
|
|
is resumed with a \method{next()} method, the current \keyword{yield}
|
|
expression always evaluates to \constant{None}. The execution then
|
|
continues to the next \keyword{yield} expression, where the generator
|
|
is suspended again, and the value of the
|
|
\grammartoken{expression_list} is returned to \method{next()}'s
|
|
caller. If the generator exits without yielding another value, a
|
|
\exception{StopIteration} exception is raised.
|
|
\end{methoddesc}
|
|
|
|
\begin{methoddesc}[generator]{send}{value}
|
|
Resumes the execution and ``sends'' a value into the generator
|
|
function. The \code{value} argument becomes the result of the
|
|
current \keyword{yield} expression. The \method{send()} method
|
|
returns the next value yielded by the generator, or raises
|
|
\exception{StopIteration} if the generator exits without yielding
|
|
another value.
|
|
When \method{send()} is called to start the generator, it must be
|
|
called with \constant{None} as the argument, because there is no
|
|
\keyword{yield} expression that could receieve the value.
|
|
\end{methoddesc}
|
|
|
|
\begin{methoddesc}[generator]{throw}
|
|
{type\optional{, value\optional{, traceback}}}
|
|
Raises an exception of type \code{type} at the point where generator
|
|
was paused, and returns the next value yielded by the generator
|
|
function. If the generator exits without yielding another value, a
|
|
\exception{StopIteration} exception is raised. If the generator
|
|
function does not catch the passed-in exception, or raises a
|
|
different exception, then that exception propagates to the caller.
|
|
\end{methoddesc}
|
|
|
|
\exindex{GeneratorExit}
|
|
|
|
\begin{methoddesc}[generator]{close}{}
|
|
Raises a \exception{GeneratorExit} at the point where the generator
|
|
function was paused. If the generator function then raises
|
|
\exception{StopIteration} (by exiting normally, or due to already
|
|
being closed) or \exception{GeneratorExit} (by not catching the
|
|
exception), close returns to its caller. If the generator yields a
|
|
value, a \exception{RuntimeError} is raised. If the generator raises
|
|
any other exception, it is propagated to the caller. \method{close}
|
|
does nothing if the generator has already exited due to an exception
|
|
or normal exit.
|
|
\end{methoddesc}
|
|
|
|
Here is a simple example that demonstrates the behavior of generators
|
|
and generator functions:
|
|
|
|
\begin{verbatim}
|
|
>>> def echo(value=None):
|
|
... print "Execution starts when 'next()' is called for the first time."
|
|
... try:
|
|
... while True:
|
|
... try:
|
|
... value = (yield value)
|
|
... except GeneratorExit:
|
|
... # never catch GeneratorExit
|
|
... raise
|
|
... except Exception, e:
|
|
... value = e
|
|
... finally:
|
|
... print "Don't forget to clean up when 'close()' is called."
|
|
...
|
|
>>> generator = echo(1)
|
|
>>> print generator.next()
|
|
Execution starts when 'next()' is called for the first time.
|
|
1
|
|
>>> print generator.next()
|
|
None
|
|
>>> print generator.send(2)
|
|
2
|
|
>>> generator.throw(TypeError, "spam")
|
|
TypeError('spam',)
|
|
>>> generator.close()
|
|
Don't forget to clean up when 'close()' is called.
|
|
\end{verbatim}
|
|
|
|
\begin{seealso}
|
|
\seepep{0342}{Coroutines via Enhanced Generators}
|
|
{The proposal to enhance the API and syntax of generators,
|
|
making them usable as simple coroutines.}
|
|
\end{seealso}
|
|
|
|
|
|
\section{Primaries\label{primaries}}
|
|
\index{primary}
|
|
|
|
Primaries represent the most tightly bound operations of the language.
|
|
Their syntax is:
|
|
|
|
\begin{productionlist}
|
|
\production{primary}
|
|
{\token{atom} | \token{attributeref}
|
|
| \token{subscription} | \token{slicing} | \token{call}}
|
|
\end{productionlist}
|
|
|
|
|
|
\subsection{Attribute references\label{attribute-references}}
|
|
\indexii{attribute}{reference}
|
|
|
|
An attribute reference is a primary followed by a period and a name:
|
|
|
|
\begin{productionlist}
|
|
\production{attributeref}
|
|
{\token{primary} "." \token{identifier}}
|
|
\end{productionlist}
|
|
|
|
The primary must evaluate to an object of a type that supports
|
|
attribute references, e.g., a module, list, or an instance. This
|
|
object is then asked to produce the attribute whose name is the
|
|
identifier. If this attribute is not available, the exception
|
|
\exception{AttributeError}\exindex{AttributeError} is raised.
|
|
Otherwise, the type and value of the object produced is determined by
|
|
the object. Multiple evaluations of the same attribute reference may
|
|
yield different objects.
|
|
\obindex{module}
|
|
\obindex{list}
|
|
|
|
|
|
\subsection{Subscriptions\label{subscriptions}}
|
|
\index{subscription}
|
|
|
|
A subscription selects an item of a sequence (string, tuple or list)
|
|
or mapping (dictionary) object:
|
|
\obindex{sequence}
|
|
\obindex{mapping}
|
|
\obindex{string}
|
|
\obindex{tuple}
|
|
\obindex{list}
|
|
\obindex{dictionary}
|
|
\indexii{sequence}{item}
|
|
|
|
\begin{productionlist}
|
|
\production{subscription}
|
|
{\token{primary} "[" \token{expression_list} "]"}
|
|
\end{productionlist}
|
|
|
|
The primary must evaluate to an object of a sequence or mapping type.
|
|
|
|
If the primary is a mapping, the expression list must evaluate to an
|
|
object whose value is one of the keys of the mapping, and the
|
|
subscription selects the value in the mapping that corresponds to that
|
|
key. (The expression list is a tuple except if it has exactly one
|
|
item.)
|
|
|
|
If the primary is a sequence, the expression (list) must evaluate to a
|
|
plain integer. If this value is negative, the length of the sequence
|
|
is added to it (so that, e.g., \code{x[-1]} selects the last item of
|
|
\code{x}.) The resulting value must be a nonnegative integer less
|
|
than the number of items in the sequence, and the subscription selects
|
|
the item whose index is that value (counting from zero).
|
|
|
|
A string's items are characters. A character is not a separate data
|
|
type but a string of exactly one character.
|
|
\index{character}
|
|
\indexii{string}{item}
|
|
|
|
|
|
\subsection{Slicings\label{slicings}}
|
|
\index{slicing}
|
|
\index{slice}
|
|
|
|
A slicing selects a range of items in a sequence object (e.g., a
|
|
string, tuple or list). Slicings may be used as expressions or as
|
|
targets in assignment or \keyword{del} statements. The syntax for a
|
|
slicing:
|
|
\obindex{sequence}
|
|
\obindex{string}
|
|
\obindex{tuple}
|
|
\obindex{list}
|
|
|
|
\begin{productionlist}
|
|
\production{slicing}
|
|
{\token{simple_slicing} | \token{extended_slicing}}
|
|
\production{simple_slicing}
|
|
{\token{primary} "[" \token{short_slice} "]"}
|
|
\production{extended_slicing}
|
|
{\token{primary} "[" \token{slice_list} "]" }
|
|
\production{slice_list}
|
|
{\token{slice_item} ("," \token{slice_item})* [","]}
|
|
\production{slice_item}
|
|
{\token{expression} | \token{proper_slice} | \token{ellipsis}}
|
|
\production{proper_slice}
|
|
{\token{short_slice} | \token{long_slice}}
|
|
\production{short_slice}
|
|
{[\token{lower_bound}] ":" [\token{upper_bound}]}
|
|
\production{long_slice}
|
|
{\token{short_slice} ":" [\token{stride}]}
|
|
\production{lower_bound}
|
|
{\token{expression}}
|
|
\production{upper_bound}
|
|
{\token{expression}}
|
|
\production{stride}
|
|
{\token{expression}}
|
|
\production{ellipsis}
|
|
{"..."}
|
|
\end{productionlist}
|
|
|
|
There is ambiguity in the formal syntax here: anything that looks like
|
|
an expression list also looks like a slice list, so any subscription
|
|
can be interpreted as a slicing. Rather than further complicating the
|
|
syntax, this is disambiguated by defining that in this case the
|
|
interpretation as a subscription takes priority over the
|
|
interpretation as a slicing (this is the case if the slice list
|
|
contains no proper slice nor ellipses). Similarly, when the slice
|
|
list has exactly one short slice and no trailing comma, the
|
|
interpretation as a simple slicing takes priority over that as an
|
|
extended slicing.\indexii{extended}{slicing}
|
|
|
|
The semantics for a simple slicing are as follows. The primary must
|
|
evaluate to a sequence object. The lower and upper bound expressions,
|
|
if present, must evaluate to plain integers; defaults are zero and the
|
|
\code{sys.maxint}, respectively. If either bound is negative, the
|
|
sequence's length is added to it. The slicing now selects all items
|
|
with index \var{k} such that
|
|
\code{\var{i} <= \var{k} < \var{j}} where \var{i}
|
|
and \var{j} are the specified lower and upper bounds. This may be an
|
|
empty sequence. It is not an error if \var{i} or \var{j} lie outside the
|
|
range of valid indexes (such items don't exist so they aren't
|
|
selected).
|
|
|
|
The semantics for an extended slicing are as follows. The primary
|
|
must evaluate to a mapping object, and it is indexed with a key that
|
|
is constructed from the slice list, as follows. If the slice list
|
|
contains at least one comma, the key is a tuple containing the
|
|
conversion of the slice items; otherwise, the conversion of the lone
|
|
slice item is the key. The conversion of a slice item that is an
|
|
expression is that expression. The conversion of a
|
|
proper slice is a slice object (see section \ref{types}) whose
|
|
\member{start}, \member{stop} and \member{step} attributes are the
|
|
values of the expressions given as lower bound, upper bound and
|
|
stride, respectively, substituting \code{None} for missing
|
|
expressions.
|
|
\withsubitem{(slice object attribute)}{\ttindex{start}
|
|
\ttindex{stop}\ttindex{step}}
|
|
|
|
|
|
\subsection{Calls\label{calls}}
|
|
\index{call}
|
|
|
|
A call calls a callable object (e.g., a function) with a possibly empty
|
|
series of arguments:
|
|
\obindex{callable}
|
|
|
|
\begin{productionlist}
|
|
\production{call}
|
|
{\token{primary} "(" [\token{argument_list} [","]}
|
|
\productioncont{ | \token{expression} \token{genexpr_for}] ")"}
|
|
\production{argument_list}
|
|
{\token{positional_arguments} ["," \token{keyword_arguments}]}
|
|
\productioncont{ ["," "*" \token{expression}]}
|
|
\productioncont{ ["," "**" \token{expression}]}
|
|
\productioncont{| \token{keyword_arguments} ["," "*" \token{expression}]}
|
|
\productioncont{ ["," "**" \token{expression}]}
|
|
\productioncont{| "*" \token{expression} ["," "**" \token{expression}]}
|
|
\productioncont{| "**" \token{expression}}
|
|
\production{positional_arguments}
|
|
{\token{expression} ("," \token{expression})*}
|
|
\production{keyword_arguments}
|
|
{\token{keyword_item} ("," \token{keyword_item})*}
|
|
\production{keyword_item}
|
|
{\token{identifier} "=" \token{expression}}
|
|
\end{productionlist}
|
|
|
|
A trailing comma may be present after the positional and keyword
|
|
arguments but does not affect the semantics.
|
|
|
|
The primary must evaluate to a callable object (user-defined
|
|
functions, built-in functions, methods of built-in objects, class
|
|
objects, methods of class instances, and certain class instances
|
|
themselves are callable; extensions may define additional callable
|
|
object types). All argument expressions are evaluated before the call
|
|
is attempted. Please refer to section \ref{function} for the syntax
|
|
of formal parameter lists.
|
|
|
|
If keyword arguments are present, they are first converted to
|
|
positional arguments, as follows. First, a list of unfilled slots is
|
|
created for the formal parameters. If there are N positional
|
|
arguments, they are placed in the first N slots. Next, for each
|
|
keyword argument, the identifier is used to determine the
|
|
corresponding slot (if the identifier is the same as the first formal
|
|
parameter name, the first slot is used, and so on). If the slot is
|
|
already filled, a \exception{TypeError} exception is raised.
|
|
Otherwise, the value of the argument is placed in the slot, filling it
|
|
(even if the expression is \code{None}, it fills the slot). When all
|
|
arguments have been processed, the slots that are still unfilled are
|
|
filled with the corresponding default value from the function
|
|
definition. (Default values are calculated, once, when the function
|
|
is defined; thus, a mutable object such as a list or dictionary used
|
|
as default value will be shared by all calls that don't specify an
|
|
argument value for the corresponding slot; this should usually be
|
|
avoided.) If there are any unfilled slots for which no default value
|
|
is specified, a \exception{TypeError} exception is raised. Otherwise,
|
|
the list of filled slots is used as the argument list for the call.
|
|
|
|
If there are more positional arguments than there are formal parameter
|
|
slots, a \exception{TypeError} exception is raised, unless a formal
|
|
parameter using the syntax \samp{*identifier} is present; in this
|
|
case, that formal parameter receives a tuple containing the excess
|
|
positional arguments (or an empty tuple if there were no excess
|
|
positional arguments).
|
|
|
|
If any keyword argument does not correspond to a formal parameter
|
|
name, a \exception{TypeError} exception is raised, unless a formal
|
|
parameter using the syntax \samp{**identifier} is present; in this
|
|
case, that formal parameter receives a dictionary containing the
|
|
excess keyword arguments (using the keywords as keys and the argument
|
|
values as corresponding values), or a (new) empty dictionary if there
|
|
were no excess keyword arguments.
|
|
|
|
If the syntax \samp{*expression} appears in the function call,
|
|
\samp{expression} must evaluate to a sequence. Elements from this
|
|
sequence are treated as if they were additional positional arguments;
|
|
if there are postional arguments \var{x1},...,\var{xN} , and
|
|
\samp{expression} evaluates to a sequence \var{y1},...,\var{yM}, this
|
|
is equivalent to a call with M+N positional arguments
|
|
\var{x1},...,\var{xN},\var{y1},...,\var{yM}.
|
|
|
|
A consequence of this is that although the \samp{*expression} syntax
|
|
appears \emph{after} any keyword arguments, it is processed
|
|
\emph{before} the keyword arguments (and the
|
|
\samp{**expression} argument, if any -- see below). So:
|
|
|
|
\begin{verbatim}
|
|
>>> def f(a, b):
|
|
... print a, b
|
|
...
|
|
>>> f(b=1, *(2,))
|
|
2 1
|
|
>>> f(a=1, *(2,))
|
|
Traceback (most recent call last):
|
|
File "<stdin>", line 1, in ?
|
|
TypeError: f() got multiple values for keyword argument 'a'
|
|
>>> f(1, *(2,))
|
|
1 2
|
|
\end{verbatim}
|
|
|
|
It is unusual for both keyword arguments and the
|
|
\samp{*expression} syntax to be used in the same call, so in practice
|
|
this confusion does not arise.
|
|
|
|
If the syntax \samp{**expression} appears in the function call,
|
|
\samp{expression} must evaluate to a (subclass of) dictionary, the
|
|
contents of which are treated as additional keyword arguments. In the
|
|
case of a keyword appearing in both \samp{expression} and as an
|
|
explicit keyword argument, a \exception{TypeError} exception is
|
|
raised.
|
|
|
|
Formal parameters using the syntax \samp{*identifier} or
|
|
\samp{**identifier} cannot be used as positional argument slots or
|
|
as keyword argument names. Formal parameters using the syntax
|
|
\samp{(sublist)} cannot be used as keyword argument names; the
|
|
outermost sublist corresponds to a single unnamed argument slot, and
|
|
the argument value is assigned to the sublist using the usual tuple
|
|
assignment rules after all other parameter processing is done.
|
|
|
|
A call always returns some value, possibly \code{None}, unless it
|
|
raises an exception. How this value is computed depends on the type
|
|
of the callable object.
|
|
|
|
If it is---
|
|
|
|
\begin{description}
|
|
|
|
\item[a user-defined function:] The code block for the function is
|
|
executed, passing it the argument list. The first thing the code
|
|
block will do is bind the formal parameters to the arguments; this is
|
|
described in section \ref{function}. When the code block executes a
|
|
\keyword{return} statement, this specifies the return value of the
|
|
function call.
|
|
\indexii{function}{call}
|
|
\indexiii{user-defined}{function}{call}
|
|
\obindex{user-defined function}
|
|
\obindex{function}
|
|
|
|
\item[a built-in function or method:] The result is up to the
|
|
interpreter; see the \citetitle[../lib/built-in-funcs.html]{Python
|
|
Library Reference} for the descriptions of built-in functions and
|
|
methods.
|
|
\indexii{function}{call}
|
|
\indexii{built-in function}{call}
|
|
\indexii{method}{call}
|
|
\indexii{built-in method}{call}
|
|
\obindex{built-in method}
|
|
\obindex{built-in function}
|
|
\obindex{method}
|
|
\obindex{function}
|
|
|
|
\item[a class object:] A new instance of that class is returned.
|
|
\obindex{class}
|
|
\indexii{class object}{call}
|
|
|
|
\item[a class instance method:] The corresponding user-defined
|
|
function is called, with an argument list that is one longer than the
|
|
argument list of the call: the instance becomes the first argument.
|
|
\obindex{class instance}
|
|
\obindex{instance}
|
|
\indexii{class instance}{call}
|
|
|
|
\item[a class instance:] The class must define a \method{__call__()}
|
|
method; the effect is then the same as if that method was called.
|
|
\indexii{instance}{call}
|
|
\withsubitem{(object method)}{\ttindex{__call__()}}
|
|
|
|
\end{description}
|
|
|
|
|
|
\section{The power operator\label{power}}
|
|
|
|
The power operator binds more tightly than unary operators on its
|
|
left; it binds less tightly than unary operators on its right. The
|
|
syntax is:
|
|
|
|
\begin{productionlist}
|
|
\production{power}
|
|
{\token{primary} ["**" \token{u_expr}]}
|
|
\end{productionlist}
|
|
|
|
Thus, in an unparenthesized sequence of power and unary operators, the
|
|
operators are evaluated from right to left (this does not constrain
|
|
the evaluation order for the operands).
|
|
|
|
The power operator has the same semantics as the built-in
|
|
\function{pow()} function, when called with two arguments: it yields
|
|
its left argument raised to the power of its right argument. The
|
|
numeric arguments are first converted to a common type. The result
|
|
type is that of the arguments after coercion.
|
|
|
|
With mixed operand types, the coercion rules for binary arithmetic
|
|
operators apply. For int and long int operands, the result has the
|
|
same type as the operands (after coercion) unless the second argument
|
|
is negative; in that case, all arguments are converted to float and a
|
|
float result is delivered. For example, \code{10**2} returns \code{100},
|
|
but \code{10**-2} returns \code{0.01}. (This last feature was added in
|
|
Python 2.2. In Python 2.1 and before, if both arguments were of integer
|
|
types and the second argument was negative, an exception was raised).
|
|
|
|
Raising \code{0.0} to a negative power results in a
|
|
\exception{ZeroDivisionError}. Raising a negative number to a
|
|
fractional power results in a \exception{ValueError}.
|
|
|
|
|
|
\section{Unary arithmetic operations \label{unary}}
|
|
\indexiii{unary}{arithmetic}{operation}
|
|
\indexiii{unary}{bit-wise}{operation}
|
|
|
|
All unary arithmetic (and bit-wise) operations have the same priority:
|
|
|
|
\begin{productionlist}
|
|
\production{u_expr}
|
|
{\token{power} | "-" \token{u_expr}
|
|
| "+" \token{u_expr} | "{\~}" \token{u_expr}}
|
|
\end{productionlist}
|
|
|
|
The unary \code{-} (minus) operator yields the negation of its
|
|
numeric argument.
|
|
\index{negation}
|
|
\index{minus}
|
|
|
|
The unary \code{+} (plus) operator yields its numeric argument
|
|
unchanged.
|
|
\index{plus}
|
|
|
|
The unary \code{\~} (invert) operator yields the bit-wise inversion
|
|
of its plain or long integer argument. The bit-wise inversion of
|
|
\code{x} is defined as \code{-(x+1)}. It only applies to integral
|
|
numbers.
|
|
\index{inversion}
|
|
|
|
In all three cases, if the argument does not have the proper type,
|
|
a \exception{TypeError} exception is raised.
|
|
\exindex{TypeError}
|
|
|
|
|
|
\section{Binary arithmetic operations\label{binary}}
|
|
\indexiii{binary}{arithmetic}{operation}
|
|
|
|
The binary arithmetic operations have the conventional priority
|
|
levels. Note that some of these operations also apply to certain
|
|
non-numeric types. Apart from the power operator, there are only two
|
|
levels, one for multiplicative operators and one for additive
|
|
operators:
|
|
|
|
\begin{productionlist}
|
|
\production{m_expr}
|
|
{\token{u_expr} | \token{m_expr} "*" \token{u_expr}
|
|
| \token{m_expr} "//" \token{u_expr}
|
|
| \token{m_expr} "/" \token{u_expr}}
|
|
\productioncont{| \token{m_expr} "\%" \token{u_expr}}
|
|
\production{a_expr}
|
|
{\token{m_expr} | \token{a_expr} "+" \token{m_expr}
|
|
| \token{a_expr} "-" \token{m_expr}}
|
|
\end{productionlist}
|
|
|
|
The \code{*} (multiplication) operator yields the product of its
|
|
arguments. The arguments must either both be numbers, or one argument
|
|
must be an integer (plain or long) and the other must be a sequence.
|
|
In the former case, the numbers are converted to a common type and
|
|
then multiplied together. In the latter case, sequence repetition is
|
|
performed; a negative repetition factor yields an empty sequence.
|
|
\index{multiplication}
|
|
|
|
The \code{/} (division) and \code{//} (floor division) operators yield
|
|
the quotient of their arguments. The numeric arguments are first
|
|
converted to a common type. Plain or long integer division yields an
|
|
integer of the same type; the result is that of mathematical division
|
|
with the `floor' function applied to the result. Division by zero
|
|
raises the
|
|
\exception{ZeroDivisionError} exception.
|
|
\exindex{ZeroDivisionError}
|
|
\index{division}
|
|
|
|
The \code{\%} (modulo) operator yields the remainder from the
|
|
division of the first argument by the second. The numeric arguments
|
|
are first converted to a common type. A zero right argument raises
|
|
the \exception{ZeroDivisionError} exception. The arguments may be floating
|
|
point numbers, e.g., \code{3.14\%0.7} equals \code{0.34} (since
|
|
\code{3.14} equals \code{4*0.7 + 0.34}.) The modulo operator always
|
|
yields a result with the same sign as its second operand (or zero);
|
|
the absolute value of the result is strictly smaller than the absolute
|
|
value of the second operand\footnote{
|
|
While \code{abs(x\%y) < abs(y)} is true mathematically, for
|
|
floats it may not be true numerically due to roundoff. For
|
|
example, and assuming a platform on which a Python float is an
|
|
IEEE 754 double-precision number, in order that \code{-1e-100 \% 1e100}
|
|
have the same sign as \code{1e100}, the computed result is
|
|
\code{-1e-100 + 1e100}, which is numerically exactly equal
|
|
to \code{1e100}. Function \function{fmod()} in the \module{math}
|
|
module returns a result whose sign matches the sign of the
|
|
first argument instead, and so returns \code{-1e-100} in this case.
|
|
Which approach is more appropriate depends on the application.
|
|
}.
|
|
\index{modulo}
|
|
|
|
The integer division and modulo operators are connected by the
|
|
following identity: \code{x == (x/y)*y + (x\%y)}. Integer division and
|
|
modulo are also connected with the built-in function \function{divmod()}:
|
|
\code{divmod(x, y) == (x/y, x\%y)}. These identities don't hold for
|
|
floating point numbers; there similar identities hold
|
|
approximately where \code{x/y} is replaced by \code{floor(x/y)} or
|
|
\code{floor(x/y) - 1}\footnote{
|
|
If x is very close to an exact integer multiple of y, it's
|
|
possible for \code{floor(x/y)} to be one larger than
|
|
\code{(x-x\%y)/y} due to rounding. In such cases, Python returns
|
|
the latter result, in order to preserve that \code{divmod(x,y)[0]
|
|
* y + x \%{} y} be very close to \code{x}.
|
|
}.
|
|
|
|
In addition to performing the modulo operation on numbers, the \code{\%}
|
|
operator is also overloaded by string and unicode objects to perform
|
|
string formatting (also known as interpolation). The syntax for string
|
|
formatting is described in the
|
|
\citetitle[../lib/typesseq-strings.html]{Python Library Reference},
|
|
section ``Sequence Types''.
|
|
|
|
\deprecated{2.3}{The floor division operator, the modulo operator,
|
|
and the \function{divmod()} function are no longer defined for complex
|
|
numbers. Instead, convert to a floating point number using the
|
|
\function{abs()} function if appropriate.}
|
|
|
|
The \code{+} (addition) operator yields the sum of its arguments.
|
|
The arguments must either both be numbers or both sequences of the
|
|
same type. In the former case, the numbers are converted to a common
|
|
type and then added together. In the latter case, the sequences are
|
|
concatenated.
|
|
\index{addition}
|
|
|
|
The \code{-} (subtraction) operator yields the difference of its
|
|
arguments. The numeric arguments are first converted to a common
|
|
type.
|
|
\index{subtraction}
|
|
|
|
|
|
\section{Shifting operations\label{shifting}}
|
|
\indexii{shifting}{operation}
|
|
|
|
The shifting operations have lower priority than the arithmetic
|
|
operations:
|
|
|
|
\begin{productionlist}
|
|
\production{shift_expr}
|
|
{\token{a_expr}
|
|
| \token{shift_expr} ( "<<" | ">>" ) \token{a_expr}}
|
|
\end{productionlist}
|
|
|
|
These operators accept plain or long integers as arguments. The
|
|
arguments are converted to a common type. They shift the first
|
|
argument to the left or right by the number of bits given by the
|
|
second argument.
|
|
|
|
A right shift by \var{n} bits is defined as division by
|
|
\code{pow(2,\var{n})}. A left shift by \var{n} bits is defined as
|
|
multiplication with \code{pow(2,\var{n})}; for plain integers there is
|
|
no overflow check so in that case the operation drops bits and flips
|
|
the sign if the result is not less than \code{pow(2,31)} in absolute
|
|
value. Negative shift counts raise a \exception{ValueError}
|
|
exception.
|
|
\exindex{ValueError}
|
|
|
|
|
|
\section{Binary bit-wise operations\label{bitwise}}
|
|
\indexiii{binary}{bit-wise}{operation}
|
|
|
|
Each of the three bitwise operations has a different priority level:
|
|
|
|
\begin{productionlist}
|
|
\production{and_expr}
|
|
{\token{shift_expr} | \token{and_expr} "\&" \token{shift_expr}}
|
|
\production{xor_expr}
|
|
{\token{and_expr} | \token{xor_expr} "\textasciicircum" \token{and_expr}}
|
|
\production{or_expr}
|
|
{\token{xor_expr} | \token{or_expr} "|" \token{xor_expr}}
|
|
\end{productionlist}
|
|
|
|
The \code{\&} operator yields the bitwise AND of its arguments, which
|
|
must be plain or long integers. The arguments are converted to a
|
|
common type.
|
|
\indexii{bit-wise}{and}
|
|
|
|
The \code{\^} operator yields the bitwise XOR (exclusive OR) of its
|
|
arguments, which must be plain or long integers. The arguments are
|
|
converted to a common type.
|
|
\indexii{bit-wise}{xor}
|
|
\indexii{exclusive}{or}
|
|
|
|
The \code{|} operator yields the bitwise (inclusive) OR of its
|
|
arguments, which must be plain or long integers. The arguments are
|
|
converted to a common type.
|
|
\indexii{bit-wise}{or}
|
|
\indexii{inclusive}{or}
|
|
|
|
|
|
\section{Comparisons\label{comparisons}}
|
|
\index{comparison}
|
|
|
|
Unlike C, all comparison operations in Python have the same priority,
|
|
which is lower than that of any arithmetic, shifting or bitwise
|
|
operation. Also unlike C, expressions like \code{a < b < c} have the
|
|
interpretation that is conventional in mathematics:
|
|
\indexii{C}{language}
|
|
|
|
\begin{productionlist}
|
|
\production{comparison}
|
|
{\token{or_expr} ( \token{comp_operator} \token{or_expr} )*}
|
|
\production{comp_operator}
|
|
{"<" | ">" | "==" | ">=" | "<=" | "!="}
|
|
\productioncont{| "is" ["not"] | ["not"] "in"}
|
|
\end{productionlist}
|
|
|
|
Comparisons yield boolean values: \code{True} or \code{False}.
|
|
|
|
Comparisons can be chained arbitrarily, e.g., \code{x < y <= z} is
|
|
equivalent to \code{x < y and y <= z}, except that \code{y} is
|
|
evaluated only once (but in both cases \code{z} is not evaluated at all
|
|
when \code{x < y} is found to be false).
|
|
\indexii{chaining}{comparisons}
|
|
|
|
Formally, if \var{a}, \var{b}, \var{c}, \ldots, \var{y}, \var{z} are
|
|
expressions and \var{opa}, \var{opb}, \ldots, \var{opy} are comparison
|
|
operators, then \var{a opa b opb c} \ldots \var{y opy z} is equivalent
|
|
to \var{a opa b} \keyword{and} \var{b opb c} \keyword{and} \ldots
|
|
\var{y opy z}, except that each expression is evaluated at most once.
|
|
|
|
Note that \var{a opa b opb c} doesn't imply any kind of comparison
|
|
between \var{a} and \var{c}, so that, e.g., \code{x < y > z} is
|
|
perfectly legal (though perhaps not pretty).
|
|
|
|
The operators \code{<}, \code{>}, \code{==}, \code{>=}, \code{<=}, and
|
|
\code{!=} compare
|
|
the values of two objects. The objects need not have the same type.
|
|
If both are numbers, they are converted to a common type. Otherwise,
|
|
objects of different types \emph{always} compare unequal, and are
|
|
ordered consistently but arbitrarily. You can control comparison
|
|
behavior of objects of non-builtin types by defining a \code{__cmp__}
|
|
method or rich comparison methods like \code{__gt__}, described in
|
|
section~\ref{specialnames}.
|
|
|
|
(This unusual definition of comparison was used to simplify the
|
|
definition of operations like sorting and the \keyword{in} and
|
|
\keyword{not in} operators. In the future, the comparison rules for
|
|
objects of different types are likely to change.)
|
|
|
|
Comparison of objects of the same type depends on the type:
|
|
|
|
\begin{itemize}
|
|
|
|
\item
|
|
Numbers are compared arithmetically.
|
|
|
|
\item
|
|
Strings are compared lexicographically using the numeric equivalents
|
|
(the result of the built-in function \function{ord()}) of their
|
|
characters. Unicode and 8-bit strings are fully interoperable in this
|
|
behavior.
|
|
|
|
\item
|
|
Tuples and lists are compared lexicographically using comparison of
|
|
corresponding elements. This means that to compare equal, each
|
|
element must compare equal and the two sequences must be of the same
|
|
type and have the same length.
|
|
|
|
If not equal, the sequences are ordered the same as their first
|
|
differing elements. For example, \code{cmp([1,2,x], [1,2,y])} returns
|
|
the same as \code{cmp(x,y)}. If the corresponding element does not
|
|
exist, the shorter sequence is ordered first (for example,
|
|
\code{[1,2] < [1,2,3]}).
|
|
|
|
\item
|
|
Mappings (dictionaries) compare equal if and only if their sorted
|
|
(key, value) lists compare equal.\footnote{The implementation computes
|
|
this efficiently, without constructing lists or sorting.}
|
|
Outcomes other than equality are resolved consistently, but are not
|
|
otherwise defined.\footnote{Earlier versions of Python used
|
|
lexicographic comparison of the sorted (key, value) lists, but this
|
|
was very expensive for the common case of comparing for equality. An
|
|
even earlier version of Python compared dictionaries by identity only,
|
|
but this caused surprises because people expected to be able to test
|
|
a dictionary for emptiness by comparing it to \code{\{\}}.}
|
|
|
|
\item
|
|
Most other objects of builtin types compare unequal unless they are
|
|
the same object;
|
|
the choice whether one object is considered smaller or larger than
|
|
another one is made arbitrarily but consistently within one
|
|
execution of a program.
|
|
|
|
\end{itemize}
|
|
|
|
The operators \keyword{in} and \keyword{not in} test for set
|
|
membership. \code{\var{x} in \var{s}} evaluates to true if \var{x}
|
|
is a member of the set \var{s}, and false otherwise. \code{\var{x}
|
|
not in \var{s}} returns the negation of \code{\var{x} in \var{s}}.
|
|
The set membership test has traditionally been bound to sequences; an
|
|
object is a member of a set if the set is a sequence and contains an
|
|
element equal to that object. However, it is possible for an object
|
|
to support membership tests without being a sequence. In particular,
|
|
dictionaries support membership testing as a nicer way of spelling
|
|
\code{\var{key} in \var{dict}}; other mapping types may follow suit.
|
|
|
|
For the list and tuple types, \code{\var{x} in \var{y}} is true if and
|
|
only if there exists an index \var{i} such that
|
|
\code{\var{x} == \var{y}[\var{i}]} is true.
|
|
|
|
For the Unicode and string types, \code{\var{x} in \var{y}} is true if
|
|
and only if \var{x} is a substring of \var{y}. An equivalent test is
|
|
\code{y.find(x) != -1}. Note, \var{x} and \var{y} need not be the
|
|
same type; consequently, \code{u'ab' in 'abc'} will return \code{True}.
|
|
Empty strings are always considered to be a substring of any other string,
|
|
so \code{"" in "abc"} will return \code{True}.
|
|
\versionchanged[Previously, \var{x} was required to be a string of
|
|
length \code{1}]{2.3}
|
|
|
|
For user-defined classes which define the \method{__contains__()} method,
|
|
\code{\var{x} in \var{y}} is true if and only if
|
|
\code{\var{y}.__contains__(\var{x})} is true.
|
|
|
|
For user-defined classes which do not define \method{__contains__()} and
|
|
do define \method{__getitem__()}, \code{\var{x} in \var{y}} is true if
|
|
and only if there is a non-negative integer index \var{i} such that
|
|
\code{\var{x} == \var{y}[\var{i}]}, and all lower integer indices
|
|
do not raise \exception{IndexError} exception. (If any other exception
|
|
is raised, it is as if \keyword{in} raised that exception).
|
|
|
|
The operator \keyword{not in} is defined to have the inverse true value
|
|
of \keyword{in}.
|
|
\opindex{in}
|
|
\opindex{not in}
|
|
\indexii{membership}{test}
|
|
\obindex{sequence}
|
|
|
|
The operators \keyword{is} and \keyword{is not} test for object identity:
|
|
\code{\var{x} is \var{y}} is true if and only if \var{x} and \var{y}
|
|
are the same object. \code{\var{x} is not \var{y}} yields the inverse
|
|
truth value.
|
|
\opindex{is}
|
|
\opindex{is not}
|
|
\indexii{identity}{test}
|
|
|
|
|
|
\section{Boolean operations\label{Booleans}}
|
|
\indexii{Conditional}{expression}
|
|
\indexii{Boolean}{operation}
|
|
|
|
Boolean operations have the lowest priority of all Python operations:
|
|
|
|
\begin{productionlist}
|
|
\production{expression}
|
|
{\token{conditional_expression} | \token{lambda_form}}
|
|
\production{old_expression}
|
|
{\token{or_test} | \token{old_lambda_form}}
|
|
\production{conditional_expression}
|
|
{\token{or_test} ["if" \token{or_test} "else" \token{expression}]}
|
|
\production{or_test}
|
|
{\token{and_test} | \token{or_test} "or" \token{and_test}}
|
|
\production{and_test}
|
|
{\token{not_test} | \token{and_test} "and" \token{not_test}}
|
|
\production{not_test}
|
|
{\token{comparison} | "not" \token{not_test}}
|
|
\end{productionlist}
|
|
|
|
In the context of Boolean operations, and also when expressions are
|
|
used by control flow statements, the following values are interpreted
|
|
as false: \code{False}, \code{None}, numeric zero of all types, and empty
|
|
strings and containers (including strings, tuples, lists, dictionaries,
|
|
sets and frozensets). All other values are interpreted as true.
|
|
|
|
The operator \keyword{not} yields \code{True} if its argument is false,
|
|
\code{False} otherwise.
|
|
\opindex{not}
|
|
|
|
The expression \code{\var{x} if \var{C} else \var{y}} first evaluates
|
|
\var{C} (\emph{not} \var{x}); if \var{C} is true, \var{x} is evaluated and
|
|
its value is returned; otherwise, \var{y} is evaluated and its value is
|
|
returned. \versionadded{2.5}
|
|
|
|
The expression \code{\var{x} and \var{y}} first evaluates \var{x}; if
|
|
\var{x} is false, its value is returned; otherwise, \var{y} is
|
|
evaluated and the resulting value is returned.
|
|
\opindex{and}
|
|
|
|
The expression \code{\var{x} or \var{y}} first evaluates \var{x}; if
|
|
\var{x} is true, its value is returned; otherwise, \var{y} is
|
|
evaluated and the resulting value is returned.
|
|
\opindex{or}
|
|
|
|
(Note that neither \keyword{and} nor \keyword{or} restrict the value
|
|
and type they return to \code{False} and \code{True}, but rather return the
|
|
last evaluated argument.
|
|
This is sometimes useful, e.g., if \code{s} is a string that should be
|
|
replaced by a default value if it is empty, the expression
|
|
\code{s or 'foo'} yields the desired value. Because \keyword{not} has to
|
|
invent a value anyway, it does not bother to return a value of the
|
|
same type as its argument, so e.g., \code{not 'foo'} yields \code{False},
|
|
not \code{''}.)
|
|
|
|
\section{Lambdas\label{lambdas}}
|
|
\indexii{lambda}{expression}
|
|
\indexii{lambda}{form}
|
|
\indexii{anonymous}{function}
|
|
|
|
\begin{productionlist}
|
|
\production{lambda_form}
|
|
{"lambda" [\token{parameter_list}]: \token{expression}}
|
|
\production{old_lambda_form}
|
|
{"lambda" [\token{parameter_list}]: \token{old_expression}}
|
|
\end{productionlist}
|
|
|
|
Lambda forms (lambda expressions) have the same syntactic position as
|
|
expressions. They are a shorthand to create anonymous functions; the
|
|
expression \code{lambda \var{arguments}: \var{expression}}
|
|
yields a function object. The unnamed object behaves like a function
|
|
object defined with
|
|
|
|
\begin{verbatim}
|
|
def name(arguments):
|
|
return expression
|
|
\end{verbatim}
|
|
|
|
See section \ref{function} for the syntax of parameter lists. Note
|
|
that functions created with lambda forms cannot contain statements.
|
|
\label{lambda}
|
|
|
|
\section{Expression lists\label{exprlists}}
|
|
\indexii{expression}{list}
|
|
|
|
\begin{productionlist}
|
|
\production{expression_list}
|
|
{\token{expression} ( "," \token{expression} )* [","]}
|
|
\end{productionlist}
|
|
|
|
An expression list containing at least one comma yields a
|
|
tuple. The length of the tuple is the number of expressions in the
|
|
list. The expressions are evaluated from left to right.
|
|
\obindex{tuple}
|
|
|
|
The trailing comma is required only to create a single tuple (a.k.a. a
|
|
\emph{singleton}); it is optional in all other cases. A single
|
|
expression without a trailing comma doesn't create a
|
|
tuple, but rather yields the value of that expression.
|
|
(To create an empty tuple, use an empty pair of parentheses:
|
|
\code{()}.)
|
|
\indexii{trailing}{comma}
|
|
|
|
\section{Evaluation order\label{evalorder}}
|
|
\indexii{evaluation}{order}
|
|
|
|
Python evaluates expressions from left to right. Notice that while
|
|
evaluating an assignment, the right-hand side is evaluated before
|
|
the left-hand side.
|
|
|
|
In the following lines, expressions will be evaluated in the
|
|
arithmetic order of their suffixes:
|
|
|
|
\begin{verbatim}
|
|
expr1, expr2, expr3, expr4
|
|
(expr1, expr2, expr3, expr4)
|
|
{expr1: expr2, expr3: expr4}
|
|
expr1 + expr2 * (expr3 - expr4)
|
|
func(expr1, expr2, *expr3, **expr4)
|
|
expr3, expr4 = expr1, expr2
|
|
\end{verbatim}
|
|
|
|
\section{Summary\label{summary}}
|
|
|
|
The following table summarizes the operator
|
|
precedences\indexii{operator}{precedence} in Python, from lowest
|
|
precedence (least binding) to highest precedence (most binding).
|
|
Operators in the same box have the same precedence. Unless the syntax
|
|
is explicitly given, operators are binary. Operators in the same box
|
|
group left to right (except for comparisons, including tests, which all
|
|
have the same precedence and chain from left to right --- see section
|
|
\ref{comparisons} -- and exponentiation, which groups from right to left).
|
|
|
|
\begin{tableii}{c|l}{textrm}{Operator}{Description}
|
|
\lineii{\keyword{lambda}} {Lambda expression}
|
|
\hline
|
|
\lineii{\keyword{or}} {Boolean OR}
|
|
\hline
|
|
\lineii{\keyword{and}} {Boolean AND}
|
|
\hline
|
|
\lineii{\keyword{not} \var{x}} {Boolean NOT}
|
|
\hline
|
|
\lineii{\keyword{in}, \keyword{not} \keyword{in}}{Membership tests}
|
|
\lineii{\keyword{is}, \keyword{is not}}{Identity tests}
|
|
\lineii{\code{<}, \code{<=}, \code{>}, \code{>=},
|
|
\code{!=}, \code{==}}
|
|
{Comparisons}
|
|
\hline
|
|
\lineii{\code{|}} {Bitwise OR}
|
|
\hline
|
|
\lineii{\code{\^}} {Bitwise XOR}
|
|
\hline
|
|
\lineii{\code{\&}} {Bitwise AND}
|
|
\hline
|
|
\lineii{\code{<<}, \code{>>}} {Shifts}
|
|
\hline
|
|
\lineii{\code{+}, \code{-}}{Addition and subtraction}
|
|
\hline
|
|
\lineii{\code{*}, \code{/}, \code{\%}}
|
|
{Multiplication, division, remainder}
|
|
\hline
|
|
\lineii{\code{+\var{x}}, \code{-\var{x}}} {Positive, negative}
|
|
\lineii{\code{\~\var{x}}} {Bitwise not}
|
|
\hline
|
|
\lineii{\code{**}} {Exponentiation}
|
|
\hline
|
|
\lineii{\code{\var{x}.\var{attribute}}} {Attribute reference}
|
|
\lineii{\code{\var{x}[\var{index}]}} {Subscription}
|
|
\lineii{\code{\var{x}[\var{index}:\var{index}]}} {Slicing}
|
|
\lineii{\code{\var{f}(\var{arguments}...)}} {Function call}
|
|
\hline
|
|
\lineii{\code{(\var{expressions}\ldots)}} {Binding or tuple display}
|
|
\lineii{\code{[\var{expressions}\ldots]}} {List display}
|
|
\lineii{\code{\{\var{key}:\var{datum}\ldots\}}}{Dictionary display}
|
|
\lineii{\code{`\var{expressions}\ldots`}} {String conversion}
|
|
\end{tableii}
|