mirror of
https://github.com/python/cpython.git
synced 2025-11-10 02:21:40 +00:00
Merged revisions 51434-53004 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r51434 | neal.norwitz | 2006-08-21 20:20:10 +0200 (Mon, 21 Aug 2006) | 1 line Fix a couple of ssize-t issues reported by Alexander Belopolsky on python-dev ........ r51439 | neal.norwitz | 2006-08-21 21:47:08 +0200 (Mon, 21 Aug 2006) | 6 lines Patch #1542451: disallow continue anywhere under a finally I'm undecided if this should be backported to 2.5 or 2.5.1. Armin suggested to wait (I'm of the same opinion). Thomas W thinks it's fine to go in 2.5. ........ r51443 | neal.norwitz | 2006-08-21 22:16:24 +0200 (Mon, 21 Aug 2006) | 4 lines Handle a few more error conditions. Klocwork 301 and 302. Will backport. ........ r51450 | neal.norwitz | 2006-08-22 00:21:19 +0200 (Tue, 22 Aug 2006) | 5 lines Patch #1541585: fix buffer overrun when performing repr() on a unicode string in a build with wide unicode (UCS-4) support. This code could be improved, so add an XXX comment. ........ r51456 | neal.norwitz | 2006-08-22 01:44:48 +0200 (Tue, 22 Aug 2006) | 1 line Try to get the windows bots working again with the new peephole.c ........ r51461 | anthony.baxter | 2006-08-22 09:36:59 +0200 (Tue, 22 Aug 2006) | 1 line patch for documentation for recent uuid changes (from ping) ........ r51473 | neal.norwitz | 2006-08-22 15:56:56 +0200 (Tue, 22 Aug 2006) | 1 line Alexander Belopolsky pointed out that pos is a size_t ........ r51489 | jeremy.hylton | 2006-08-22 22:46:00 +0200 (Tue, 22 Aug 2006) | 2 lines Expose column offset information in parse trees. ........ r51497 | andrew.kuchling | 2006-08-23 01:13:43 +0200 (Wed, 23 Aug 2006) | 1 line Move functional howto into trunk ........ r51515 | jeremy.hylton | 2006-08-23 20:37:43 +0200 (Wed, 23 Aug 2006) | 2 lines Baby steps towards better tests for tokenize ........ r51525 | alex.martelli | 2006-08-23 22:42:02 +0200 (Wed, 23 Aug 2006) | 6 lines x**2 should about equal x*x (including for a float x such that the result is inf) but didn't; added a test to test_float to verify that, and ignored the ERANGE value for errno in the pow operation to make the new test pass (with help from Marilyn Davis at the Google Python Sprint -- thanks!). ........ r51526 | jeremy.hylton | 2006-08-23 23:14:03 +0200 (Wed, 23 Aug 2006) | 20 lines Bug fixes large and small for tokenize. Small: Always generate a NL or NEWLINE token following a COMMENT token. The old code did not generate an NL token if the comment was on a line by itself. Large: The output of untokenize() will now match the input exactly if it is passed the full token sequence. The old, crufty output is still generated if a limited input sequence is provided, where limited means that it does not include position information for tokens. Remaining bug: There is no CONTINUATION token (\) so there is no way for untokenize() to handle such code. Also, expanded the number of doctests in hopes of eventually removing the old-style tests that compare against a golden file. Bug fix candidate for Python 2.5.1. (Sigh.) ........ r51527 | jeremy.hylton | 2006-08-23 23:26:46 +0200 (Wed, 23 Aug 2006) | 5 lines Replace dead code with an assert. Now that COMMENT tokens are reliably followed by NL or NEWLINE, there is never a need to add extra newlines in untokenize. ........ r51530 | alex.martelli | 2006-08-24 00:17:59 +0200 (Thu, 24 Aug 2006) | 7 lines Reverting the patch that tried to fix the issue whereby x**2 raises OverflowError while x*x succeeds and produces infinity; apparently these inconsistencies cannot be fixed across ``all'' platforms and there's a widespread feeling that therefore ``every'' platform should keep suffering forevermore. Ah well. ........ r51565 | thomas.wouters | 2006-08-24 20:40:20 +0200 (Thu, 24 Aug 2006) | 6 lines Fix SF bug #1545837: array.array borks on deepcopy. array.__deepcopy__() needs to take an argument, even if it doesn't actually use it. Will backport to 2.5 and 2.4 (if applicable.) ........ r51580 | martin.v.loewis | 2006-08-25 02:03:34 +0200 (Fri, 25 Aug 2006) | 3 lines Patch #1545507: Exclude ctypes package in Win64 MSI file. Will backport to 2.5. ........ r51589 | neal.norwitz | 2006-08-25 03:52:49 +0200 (Fri, 25 Aug 2006) | 1 line importing types is not necessary if we use isinstance ........ r51604 | thomas.heller | 2006-08-25 09:27:33 +0200 (Fri, 25 Aug 2006) | 3 lines Port _ctypes.pyd to win64 on AMD64. ........ r51605 | thomas.heller | 2006-08-25 09:34:51 +0200 (Fri, 25 Aug 2006) | 3 lines Add missing file for _ctypes.pyd port to win64 on AMD64. ........ r51606 | thomas.heller | 2006-08-25 11:26:33 +0200 (Fri, 25 Aug 2006) | 6 lines Build _ctypes.pyd for win AMD64 into the MSVC project file. Since MSVC doesn't know about .asm files, a helper batch file is needed to find ml64.exe in predefined locations. The helper script hardcodes the path to the MS Platform SDK. ........ r51608 | armin.rigo | 2006-08-25 14:44:28 +0200 (Fri, 25 Aug 2006) | 4 lines The regular expression engine in '_sre' can segfault when interpreting bogus bytecode. It is unclear whether this is a real bug or a "won't fix" case like bogus_code_obj.py. ........ r51617 | tim.peters | 2006-08-26 00:05:39 +0200 (Sat, 26 Aug 2006) | 2 lines Whitespace normalization. ........ r51618 | tim.peters | 2006-08-26 00:06:44 +0200 (Sat, 26 Aug 2006) | 2 lines Add missing svn:eol-style property to text files. ........ r51619 | tim.peters | 2006-08-26 00:26:21 +0200 (Sat, 26 Aug 2006) | 3 lines A new test here relied on preserving invisible trailing whitespace in expected output. Stop that. ........ r51624 | jack.diederich | 2006-08-26 20:42:06 +0200 (Sat, 26 Aug 2006) | 4 lines - Move functions common to all path modules into genericpath.py and have the OS speicifc path modules import them. - Have os2emxpath import common functions fron ntpath instead of using copies ........ r51642 | neal.norwitz | 2006-08-29 07:40:58 +0200 (Tue, 29 Aug 2006) | 1 line Fix a couple of typos. ........ r51647 | marc-andre.lemburg | 2006-08-29 12:34:12 +0200 (Tue, 29 Aug 2006) | 5 lines Fix a buglet in the error reporting (SF bug report #1546372). This should probably go into Python 2.5 or 2.5.1 as well. ........ r51663 | armin.rigo | 2006-08-31 10:51:06 +0200 (Thu, 31 Aug 2006) | 3 lines Doc fix: hashlib objects don't always return a digest of 16 bytes. Backport candidate for 2.5. ........ r51664 | nick.coghlan | 2006-08-31 14:00:43 +0200 (Thu, 31 Aug 2006) | 1 line Fix the wrongheaded implementation of context management in the decimal module and add unit tests. (python-dev discussion is ongoing regarding what we do about Python 2.5) ........ r51665 | nick.coghlan | 2006-08-31 14:51:25 +0200 (Thu, 31 Aug 2006) | 1 line Remove the old decimal context management tests from test_contextlib (guess who didn't run the test suite before committing...) ........ r51669 | brett.cannon | 2006-08-31 20:54:26 +0200 (Thu, 31 Aug 2006) | 4 lines Make sure memory is properly cleaned up in file_init. Backport candidate. ........ r51671 | brett.cannon | 2006-08-31 23:47:52 +0200 (Thu, 31 Aug 2006) | 2 lines Fix comment about indentation level in C files. ........ r51674 | brett.cannon | 2006-09-01 00:42:37 +0200 (Fri, 01 Sep 2006) | 3 lines Have pre-existing C files use 8 spaces indents (to match old PEP 7 style), but have all new files use 4 spaces (to match current PEP 7 style). ........ r51676 | fred.drake | 2006-09-01 05:57:19 +0200 (Fri, 01 Sep 2006) | 3 lines - SF patch #1550263: Enhance and correct unittest docs - various minor cleanups for improved consistency ........ r51677 | georg.brandl | 2006-09-02 00:30:52 +0200 (Sat, 02 Sep 2006) | 2 lines evalfile() should be execfile(). ........ r51681 | neal.norwitz | 2006-09-02 04:43:17 +0200 (Sat, 02 Sep 2006) | 1 line SF #1547931, fix typo (missing and). Will backport to 2.5 ........ r51683 | neal.norwitz | 2006-09-02 04:50:35 +0200 (Sat, 02 Sep 2006) | 1 line Bug #1548092: fix curses.tparm seg fault on invalid input. Needs backport to 2.5.1 and earlier. ........ r51684 | neal.norwitz | 2006-09-02 04:58:13 +0200 (Sat, 02 Sep 2006) | 4 lines Bug #1550714: fix SystemError from itertools.tee on negative value for n. Needs backport to 2.5.1 and earlier. ........ r51685 | nick.coghlan | 2006-09-02 05:54:17 +0200 (Sat, 02 Sep 2006) | 1 line Make decimal.ContextManager a private implementation detail of decimal.localcontext() ........ r51686 | nick.coghlan | 2006-09-02 06:04:18 +0200 (Sat, 02 Sep 2006) | 1 line Further corrections to the decimal module context management documentation ........ r51688 | raymond.hettinger | 2006-09-02 19:07:23 +0200 (Sat, 02 Sep 2006) | 1 line Fix documentation nits for decimal context managers. ........ r51690 | neal.norwitz | 2006-09-02 20:51:34 +0200 (Sat, 02 Sep 2006) | 1 line Add missing word in comment ........ r51691 | neal.norwitz | 2006-09-02 21:40:19 +0200 (Sat, 02 Sep 2006) | 7 lines Hmm, this test has failed at least twice recently on the OpenBSD and Debian sparc buildbots. Since this goes through a lot of tests and hits the disk a lot it could be slow (especially if NFS is involved). I'm not sure if that's the problem, but printing periodic msgs shouldn't hurt. The code was stolen from test_compiler. ........ r51693 | nick.coghlan | 2006-09-03 03:02:00 +0200 (Sun, 03 Sep 2006) | 1 line Fix final documentation nits before backporting decimal module fixes to 2.5 ........ r51694 | nick.coghlan | 2006-09-03 03:06:07 +0200 (Sun, 03 Sep 2006) | 1 line Typo fix for decimal docs ........ r51697 | nick.coghlan | 2006-09-03 03:20:46 +0200 (Sun, 03 Sep 2006) | 1 line NEWS entry on trunk for decimal module changes ........ r51704 | raymond.hettinger | 2006-09-04 17:32:48 +0200 (Mon, 04 Sep 2006) | 1 line Fix endcase for str.rpartition() ........ r51716 | tim.peters | 2006-09-05 04:18:09 +0200 (Tue, 05 Sep 2006) | 12 lines "Conceptual" merge of rev 51711 from the 2.5 branch. i_divmod(): As discussed on Python-Dev, changed the overflow checking to live happily with recent gcc optimizations that assume signed integer arithmetic never overflows. This differs from the corresponding change on the 2.5 and 2.4 branches, using a less obscure approach, but one that /may/ tickle platform idiocies in their definitions of LONG_MIN. The 2.4 + 2.5 change avoided introducing a dependence on LONG_MIN, at the cost of substantially goofier code. ........ r51717 | tim.peters | 2006-09-05 04:21:19 +0200 (Tue, 05 Sep 2006) | 2 lines Whitespace normalization. ........ r51719 | tim.peters | 2006-09-05 04:22:17 +0200 (Tue, 05 Sep 2006) | 2 lines Add missing svn:eol-style property to text files. ........ r51720 | neal.norwitz | 2006-09-05 04:24:03 +0200 (Tue, 05 Sep 2006) | 2 lines Fix SF bug #1546288, crash in dict_equal. ........ r51721 | neal.norwitz | 2006-09-05 04:25:41 +0200 (Tue, 05 Sep 2006) | 1 line Fix SF #1552093, eval docstring typo (3 ps in mapping) ........ r51724 | neal.norwitz | 2006-09-05 04:35:08 +0200 (Tue, 05 Sep 2006) | 1 line This was found by Guido AFAIK on p3yk (sic) branch. ........ r51725 | neal.norwitz | 2006-09-05 04:36:20 +0200 (Tue, 05 Sep 2006) | 1 line Add a NEWS entry for str.rpartition() change ........ r51728 | neal.norwitz | 2006-09-05 04:57:01 +0200 (Tue, 05 Sep 2006) | 1 line Patch #1540470, for OpenBSD 4.0. Backport candidate for 2.[34]. ........ r51729 | neal.norwitz | 2006-09-05 05:53:08 +0200 (Tue, 05 Sep 2006) | 12 lines Bug #1520864 (again): unpacking singleton tuples in list comprehensions and generator expressions (x for x, in ... ) works again. Sigh, I only fixed for loops the first time, not list comps and genexprs too. I couldn't find any more unpacking cases where there is a similar bug lurking. This code should be refactored to eliminate the duplication. I'm sure the listcomp/genexpr code can be refactored. I'm not sure if the for loop can re-use any of the same code though. Will backport to 2.5 (the only place it matters). ........ r51731 | neal.norwitz | 2006-09-05 05:58:26 +0200 (Tue, 05 Sep 2006) | 1 line Add a comment about some refactoring. (There's probably more that should be done.) I will reformat this file in the next checkin due to the inconsistent tabs/spaces. ........ r51732 | neal.norwitz | 2006-09-05 06:00:12 +0200 (Tue, 05 Sep 2006) | 1 line M-x untabify ........ r51737 | hyeshik.chang | 2006-09-05 14:07:09 +0200 (Tue, 05 Sep 2006) | 7 lines Fix a few bugs on cjkcodecs found by Oren Tirosh: - gbk and gb18030 codec now handle U+30FB KATAKANA MIDDLE DOT correctly. - iso2022_jp_2 codec now encodes into G0 for KS X 1001, GB2312 codepoints to conform the standard. - iso2022_jp_3 and iso2022_jp_2004 codec can encode JIS X 2013:2 codepoints now. ........ r51738 | hyeshik.chang | 2006-09-05 14:14:57 +0200 (Tue, 05 Sep 2006) | 2 lines Fix a typo: 2013 -> 0213 ........ r51740 | georg.brandl | 2006-09-05 14:44:58 +0200 (Tue, 05 Sep 2006) | 3 lines Bug #1552618: change docs of dict.has_key() to reflect recommendation to use "in". ........ r51742 | andrew.kuchling | 2006-09-05 15:02:40 +0200 (Tue, 05 Sep 2006) | 1 line Rearrange example a bit, and show rpartition() when separator is not found ........ r51744 | andrew.kuchling | 2006-09-05 15:15:41 +0200 (Tue, 05 Sep 2006) | 1 line [Bug #1525469] SimpleXMLRPCServer still uses the sys.exc_{value,type} module-level globals instead of calling sys.exc_info(). Reported by Russell Warren ........ r51745 | andrew.kuchling | 2006-09-05 15:19:18 +0200 (Tue, 05 Sep 2006) | 3 lines [Bug #1526834] Fix crash in pdb when you do 'b f('; the function name was placed into a regex pattern and the unbalanced paren caused re.compile() to report an error ........ r51751 | kristjan.jonsson | 2006-09-05 19:58:12 +0200 (Tue, 05 Sep 2006) | 6 lines Update the PCBuild8 solution. Facilitate cross-compilation by having binaries in separate Win32 and x64 directories. Rationalized configs by making proper use of platforms/configurations. Remove pythoncore_pgo project. Add new PGIRelease and PGORelease configurations to perform Profile Guided Optimisation. Removed I64 support, but this can be easily added by copying the x64 platform settings. ........ r51758 | gustavo.niemeyer | 2006-09-06 03:58:52 +0200 (Wed, 06 Sep 2006) | 3 lines Fixing #1531862: Do not close standard file descriptors in the subprocess module. ........ r51760 | neal.norwitz | 2006-09-06 05:58:34 +0200 (Wed, 06 Sep 2006) | 1 line Revert 51758 because it broke all the buildbots ........ r51762 | georg.brandl | 2006-09-06 08:03:59 +0200 (Wed, 06 Sep 2006) | 3 lines Bug #1551427: fix a wrong NULL pointer check in the win32 version of os.urandom(). ........ r51765 | georg.brandl | 2006-09-06 08:09:31 +0200 (Wed, 06 Sep 2006) | 3 lines Bug #1550983: emit better error messages for erroneous relative imports (if not in package and if beyond toplevel package). ........ r51767 | neal.norwitz | 2006-09-06 08:28:06 +0200 (Wed, 06 Sep 2006) | 1 line with and as are now keywords. There are some generated files I can't recreate. ........ r51770 | georg.brandl | 2006-09-06 08:50:05 +0200 (Wed, 06 Sep 2006) | 5 lines Bug #1542051: Exceptions now correctly call PyObject_GC_UnTrack. Also make sure that every exception class has __module__ set to 'exceptions'. ........ r51785 | georg.brandl | 2006-09-06 22:05:58 +0200 (Wed, 06 Sep 2006) | 2 lines Fix missing import of the types module in logging.config. ........ r51789 | marc-andre.lemburg | 2006-09-06 22:40:22 +0200 (Wed, 06 Sep 2006) | 3 lines Add news item for bug fix of SF bug report #1546372. ........ r51797 | gustavo.niemeyer | 2006-09-07 02:48:33 +0200 (Thu, 07 Sep 2006) | 3 lines Fixed subprocess bug #1531862 again, after removing tests offending buildbot ........ r51798 | raymond.hettinger | 2006-09-07 04:42:48 +0200 (Thu, 07 Sep 2006) | 1 line Fix refcounts and add error checks. ........ r51803 | nick.coghlan | 2006-09-07 12:50:34 +0200 (Thu, 07 Sep 2006) | 1 line Fix the speed regression in inspect.py by adding another cache to speed up getmodule(). Patch #1553314 ........ r51805 | ronald.oussoren | 2006-09-07 14:03:10 +0200 (Thu, 07 Sep 2006) | 2 lines Fix a glaring error and update some version numbers. ........ r51814 | andrew.kuchling | 2006-09-07 15:56:23 +0200 (Thu, 07 Sep 2006) | 1 line Typo fix ........ r51815 | andrew.kuchling | 2006-09-07 15:59:38 +0200 (Thu, 07 Sep 2006) | 8 lines [Bug #1552726] Avoid repeatedly polling in interactive mode -- only put a timeout on the select() if an input hook has been defined. Patch by Richard Boulton. This select() code is only executed with readline 2.1, or if READLINE_CALLBACKS is defined. Backport candidate for 2.5, 2.4, probably earlier versions too. ........ r51816 | armin.rigo | 2006-09-07 17:06:00 +0200 (Thu, 07 Sep 2006) | 2 lines Add a warning notice on top of the generated grammar.txt. ........ r51819 | thomas.heller | 2006-09-07 20:56:28 +0200 (Thu, 07 Sep 2006) | 5 lines Anonymous structure fields that have a bit-width specified did not work, and they gave a strange error message from PyArg_ParseTuple: function takes exactly 2 arguments (3 given). With tests. ........ r51820 | thomas.heller | 2006-09-07 21:09:54 +0200 (Thu, 07 Sep 2006) | 4 lines The cast function did not accept c_char_p or c_wchar_p instances as first argument, and failed with a 'bad argument to internal function' error message. ........ r51827 | nick.coghlan | 2006-09-08 12:04:38 +0200 (Fri, 08 Sep 2006) | 1 line Add missing NEWS entry for rev 51803 ........ r51828 | andrew.kuchling | 2006-09-08 15:25:23 +0200 (Fri, 08 Sep 2006) | 1 line Add missing word ........ r51829 | andrew.kuchling | 2006-09-08 15:35:49 +0200 (Fri, 08 Sep 2006) | 1 line Explain SQLite a bit more clearly ........ r51830 | andrew.kuchling | 2006-09-08 15:36:36 +0200 (Fri, 08 Sep 2006) | 1 line Explain SQLite a bit more clearly ........ r51832 | andrew.kuchling | 2006-09-08 16:02:45 +0200 (Fri, 08 Sep 2006) | 1 line Use native SQLite types ........ r51833 | andrew.kuchling | 2006-09-08 16:03:01 +0200 (Fri, 08 Sep 2006) | 1 line Use native SQLite types ........ r51835 | andrew.kuchling | 2006-09-08 16:05:10 +0200 (Fri, 08 Sep 2006) | 1 line Fix typo in example ........ r51837 | brett.cannon | 2006-09-09 09:11:46 +0200 (Sat, 09 Sep 2006) | 6 lines Remove the __unicode__ method from exceptions. Allows unicode() to be called on exception classes. Would require introducing a tp_unicode slot to make it work otherwise. Fixes bug #1551432 and will be backported. ........ r51854 | neal.norwitz | 2006-09-11 06:24:09 +0200 (Mon, 11 Sep 2006) | 8 lines Forward port of 51850 from release25-maint branch. As mentioned on python-dev, reverting patch #1504333 because it introduced an infinite loop in rev 47154. This patch also adds a test to prevent the regression. ........ r51855 | neal.norwitz | 2006-09-11 06:28:16 +0200 (Mon, 11 Sep 2006) | 5 lines Properly handle a NULL returned from PyArena_New(). (Also fix some whitespace) Klocwork #364. ........ r51856 | neal.norwitz | 2006-09-11 06:32:57 +0200 (Mon, 11 Sep 2006) | 1 line Add a "crasher" taken from the sgml bug report referenced in the comment ........ r51858 | georg.brandl | 2006-09-11 11:38:35 +0200 (Mon, 11 Sep 2006) | 12 lines Forward-port of rev. 51857: Building with HP's cc on HP-UX turned up a couple of problems. _PyGILState_NoteThreadState was declared as static inconsistently. Make it static as it's not necessary outside of this module. Some tests failed because errno was reset to 0. (I think the tests that failed were at least: test_fcntl and test_mailbox). Ensure that errno doesn't change after a call to Py_END_ALLOW_THREADS. This only affected debug builds. ........ r51865 | martin.v.loewis | 2006-09-12 21:49:20 +0200 (Tue, 12 Sep 2006) | 2 lines Forward-port 51862: Add sgml_input.html. ........ r51866 | andrew.kuchling | 2006-09-12 22:50:23 +0200 (Tue, 12 Sep 2006) | 1 line Markup typo fix ........ r51867 | andrew.kuchling | 2006-09-12 23:09:02 +0200 (Tue, 12 Sep 2006) | 1 line Some editing, markup fixes ........ r51868 | andrew.kuchling | 2006-09-12 23:21:51 +0200 (Tue, 12 Sep 2006) | 1 line More wordsmithing ........ r51877 | andrew.kuchling | 2006-09-14 13:22:18 +0200 (Thu, 14 Sep 2006) | 1 line Make --help mention that -v can be supplied multiple times ........ r51878 | andrew.kuchling | 2006-09-14 13:28:50 +0200 (Thu, 14 Sep 2006) | 1 line Rewrite help message to remove some of the parentheticals. (There were a lot of them.) ........ r51883 | ka-ping.yee | 2006-09-15 02:34:19 +0200 (Fri, 15 Sep 2006) | 2 lines Fix grammar errors and improve clarity. ........ r51885 | georg.brandl | 2006-09-15 07:22:24 +0200 (Fri, 15 Sep 2006) | 3 lines Correct elementtree module index entry. ........ r51889 | fred.drake | 2006-09-15 17:18:04 +0200 (Fri, 15 Sep 2006) | 4 lines - fix module name in links in formatted documentation - minor markup cleanup (forward-ported from release25-maint revision 51888) ........ r51891 | fred.drake | 2006-09-15 18:11:27 +0200 (Fri, 15 Sep 2006) | 3 lines revise explanation of returns_unicode to reflect bool values and to include the default value (merged from release25-maint revision 51890) ........ r51897 | martin.v.loewis | 2006-09-16 19:36:37 +0200 (Sat, 16 Sep 2006) | 2 lines Patch #1557515: Add RLIMIT_SBSIZE. ........ r51903 | ronald.oussoren | 2006-09-17 20:42:53 +0200 (Sun, 17 Sep 2006) | 2 lines Port of revision 51902 in release25-maint to the trunk ........ r51904 | ronald.oussoren | 2006-09-17 21:23:27 +0200 (Sun, 17 Sep 2006) | 3 lines Tweak Mac/Makefile in to ensure that pythonw gets rebuild when the major version of python changes (2.5 -> 2.6). Bug #1552935. ........ r51913 | guido.van.rossum | 2006-09-18 23:36:16 +0200 (Mon, 18 Sep 2006) | 2 lines Make this thing executable. ........ r51920 | gregory.p.smith | 2006-09-19 19:35:04 +0200 (Tue, 19 Sep 2006) | 5 lines Fixes a bug with bsddb.DB.stat where the flags and txn keyword arguments are transposed. (reported by Louis Zechtzer) ..already committed to release24-maint ..needs committing to release25-maint ........ r51926 | brett.cannon | 2006-09-20 20:34:28 +0200 (Wed, 20 Sep 2006) | 3 lines Accidentally didn't commit Misc/NEWS entry on when __unicode__() was removed from exceptions. ........ r51927 | brett.cannon | 2006-09-20 20:43:13 +0200 (Wed, 20 Sep 2006) | 6 lines Allow exceptions to be directly sliced again (e.g., ``BaseException(1,2,3)[0:2]``). Discovered in Python 2.5.0 by Thomas Heller and reported to python-dev. This should be backported to 2.5 . ........ r51928 | brett.cannon | 2006-09-20 21:28:35 +0200 (Wed, 20 Sep 2006) | 2 lines Make python.vim output more deterministic. ........ r51949 | walter.doerwald | 2006-09-21 17:09:55 +0200 (Thu, 21 Sep 2006) | 2 lines Fix typo. ........ r51950 | jack.diederich | 2006-09-21 19:50:26 +0200 (Thu, 21 Sep 2006) | 5 lines * regression bug, count_next was coercing a Py_ssize_t to an unsigned Py_size_t which breaks negative counts * added test for negative numbers will backport to 2.5.1 ........ r51953 | jack.diederich | 2006-09-21 22:34:49 +0200 (Thu, 21 Sep 2006) | 1 line added itertools.count(-n) fix ........ r51971 | neal.norwitz | 2006-09-22 10:16:26 +0200 (Fri, 22 Sep 2006) | 10 lines Fix %zd string formatting on Mac OS X so it prints negative numbers. In addition to testing positive numbers, verify negative numbers work in configure. In order to avoid compiler warnings on OS X 10.4, also change the order of the check for the format character to use (PY_FORMAT_SIZE_T) in the sprintf format for Py_ssize_t. This patch changes PY_FORMAT_SIZE_T from "" to "l" if it wasn't defined at configure time. Need to verify the buildbot results. Backport candidate (if everyone thinks this patch can't be improved). ........ r51972 | neal.norwitz | 2006-09-22 10:18:10 +0200 (Fri, 22 Sep 2006) | 7 lines Bug #1557232: fix seg fault with def f((((x)))) and def f(((x),)). These tests should be improved. Hopefully this fixes variations when flipping back and forth between fpdef and fplist. Backport candidate. ........ r51975 | neal.norwitz | 2006-09-22 10:47:23 +0200 (Fri, 22 Sep 2006) | 4 lines Mostly revert this file to the same version as before. Only force setting of PY_FORMAT_SIZE_T to "l" for Mac OSX. I don't know a better define to use. This should get rid of the warnings on other platforms and Mac too. ........ r51986 | fred.drake | 2006-09-23 02:26:31 +0200 (Sat, 23 Sep 2006) | 1 line add boilerplate "What's New" document so the docs will build ........ r51987 | neal.norwitz | 2006-09-23 06:11:38 +0200 (Sat, 23 Sep 2006) | 1 line Remove extra semi-colons reported by Johnny Lee on python-dev. Backport if anyone cares. ........ r51989 | neal.norwitz | 2006-09-23 20:11:58 +0200 (Sat, 23 Sep 2006) | 1 line SF Bug #1563963, add missing word and cleanup first sentance ........ r51990 | brett.cannon | 2006-09-23 21:53:20 +0200 (Sat, 23 Sep 2006) | 3 lines Make output on test_strptime() be more verbose in face of failure. This is in hopes that more information will help debug the failing test on HPPA Ubuntu. ........ r51991 | georg.brandl | 2006-09-24 12:36:01 +0200 (Sun, 24 Sep 2006) | 2 lines Fix webbrowser.BackgroundBrowser on Windows. ........ r51993 | georg.brandl | 2006-09-24 14:35:36 +0200 (Sun, 24 Sep 2006) | 4 lines Fix a bug in the parser's future statement handling that led to "with" not being recognized as a keyword after, e.g., this statement: from __future__ import division, with_statement ........ r51995 | georg.brandl | 2006-09-24 14:50:24 +0200 (Sun, 24 Sep 2006) | 4 lines Fix a bug in traceback.format_exception_only() that led to an error being raised when print_exc() was called without an exception set. In version 2.4, this printed "None", restored that behavior. ........ r52000 | armin.rigo | 2006-09-25 17:16:26 +0200 (Mon, 25 Sep 2006) | 2 lines Another crasher. ........ r52011 | brett.cannon | 2006-09-27 01:38:24 +0200 (Wed, 27 Sep 2006) | 2 lines Make the error message for when the time data and format do not match clearer. ........ r52014 | andrew.kuchling | 2006-09-27 18:37:30 +0200 (Wed, 27 Sep 2006) | 1 line Add news item for rev. 51815 ........ r52018 | andrew.kuchling | 2006-09-27 21:23:05 +0200 (Wed, 27 Sep 2006) | 1 line Make examples do error checking on Py_InitModule ........ r52032 | brett.cannon | 2006-09-29 00:10:14 +0200 (Fri, 29 Sep 2006) | 2 lines Very minor grammatical fix in a comment. ........ r52048 | george.yoshida | 2006-09-30 07:14:02 +0200 (Sat, 30 Sep 2006) | 4 lines SF bug #1567976 : fix typo Will backport to 2.5. ........ r52051 | gregory.p.smith | 2006-09-30 08:08:20 +0200 (Sat, 30 Sep 2006) | 2 lines wording change ........ r52053 | georg.brandl | 2006-09-30 09:24:48 +0200 (Sat, 30 Sep 2006) | 2 lines Bug #1567375: a minor logical glitch in example description. ........ r52056 | georg.brandl | 2006-09-30 09:31:57 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1565661: in webbrowser, split() the command for the default GNOME browser in case it is a command with args. ........ r52058 | georg.brandl | 2006-09-30 10:43:30 +0200 (Sat, 30 Sep 2006) | 4 lines Patch #1567691: super() and new.instancemethod() now don't accept keyword arguments any more (previously they accepted them, but didn't use them). ........ r52061 | georg.brandl | 2006-09-30 11:03:42 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1566800: make sure that EnvironmentError can be called with any number of arguments, as was the case in Python 2.4. ........ r52063 | georg.brandl | 2006-09-30 11:06:45 +0200 (Sat, 30 Sep 2006) | 2 lines Bug #1566663: remove obsolete example from datetime docs. ........ r52065 | georg.brandl | 2006-09-30 11:13:21 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1566602: correct failure of posixpath unittest when $HOME ends with a slash. ........ r52068 | georg.brandl | 2006-09-30 12:58:01 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1457823: cgi.(Sv)FormContentDict's constructor now takes keep_blank_values and strict_parsing keyword arguments. ........ r52069 | georg.brandl | 2006-09-30 13:06:47 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1560617: in pyclbr, return full module name not only for classes, but also for functions. ........ r52072 | georg.brandl | 2006-09-30 13:17:34 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1556784: allow format strings longer than 127 characters in datetime's strftime function. ........ r52075 | georg.brandl | 2006-09-30 13:22:28 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1446043: correctly raise a LookupError if an encoding name given to encodings.search_function() contains a dot. ........ r52078 | georg.brandl | 2006-09-30 14:02:57 +0200 (Sat, 30 Sep 2006) | 3 lines Bug #1546052: clarify that PyString_FromString(AndSize) copies the string pointed to by its parameter. ........ r52080 | georg.brandl | 2006-09-30 14:16:03 +0200 (Sat, 30 Sep 2006) | 3 lines Convert test_import to unittest. ........ r52083 | kurt.kaiser | 2006-10-01 23:16:45 +0200 (Sun, 01 Oct 2006) | 5 lines Some syntax errors were being caught by tokenize during the tabnanny check, resulting in obscure error messages. Do the syntax check first. Bug 1562716, 1562719 ........ r52084 | kurt.kaiser | 2006-10-01 23:54:37 +0200 (Sun, 01 Oct 2006) | 3 lines Add comment explaining that error msgs may be due to user code when running w/o subprocess. ........ r52086 | martin.v.loewis | 2006-10-02 16:55:51 +0200 (Mon, 02 Oct 2006) | 3 lines Fix test for uintptr_t. Fixes #1568842. Will backport. ........ r52089 | martin.v.loewis | 2006-10-02 17:20:37 +0200 (Mon, 02 Oct 2006) | 3 lines Guard uintptr_t test with HAVE_STDINT_H, test for stdint.h. Will backport. ........ r52100 | vinay.sajip | 2006-10-03 20:02:37 +0200 (Tue, 03 Oct 2006) | 1 line Documentation omitted the additional parameter to LogRecord.__init__ which was added in 2.5. (See SF #1569622). ........ r52101 | vinay.sajip | 2006-10-03 20:20:26 +0200 (Tue, 03 Oct 2006) | 1 line Documentation clarified to mention optional parameters. ........ r52102 | vinay.sajip | 2006-10-03 20:21:56 +0200 (Tue, 03 Oct 2006) | 1 line Modified LogRecord.__init__ to make the func parameter optional. (See SF #1569622). ........ r52121 | brett.cannon | 2006-10-03 23:58:55 +0200 (Tue, 03 Oct 2006) | 2 lines Fix minor typo in a comment. ........ r52123 | brett.cannon | 2006-10-04 01:23:14 +0200 (Wed, 04 Oct 2006) | 2 lines Convert test_imp over to unittest. ........ r52128 | barry.warsaw | 2006-10-04 04:06:36 +0200 (Wed, 04 Oct 2006) | 3 lines decode_rfc2231(): As Christian Robottom Reis points out, it makes no sense to test for parts > 3 when we use .split(..., 2). ........ r52129 | jeremy.hylton | 2006-10-04 04:24:52 +0200 (Wed, 04 Oct 2006) | 9 lines Fix for SF bug 1569998: break permitted inside try. The compiler was checking that there was something on the fblock stack, but not that there was a loop on the stack. Fixed that and added a test for the specific syntax error. Bug fix candidate. ........ r52130 | martin.v.loewis | 2006-10-04 07:47:34 +0200 (Wed, 04 Oct 2006) | 4 lines Fix integer negation and absolute value to not rely on undefined behaviour of the C compiler anymore. Will backport to 2.5 and 2.4. ........ r52135 | martin.v.loewis | 2006-10-04 11:21:20 +0200 (Wed, 04 Oct 2006) | 1 line Forward port r52134: Add uuids for 2.4.4. ........ r52137 | armin.rigo | 2006-10-04 12:23:57 +0200 (Wed, 04 Oct 2006) | 3 lines Compilation problem caused by conflicting typedefs for uint32_t (unsigned long vs. unsigned int). ........ r52139 | armin.rigo | 2006-10-04 14:17:45 +0200 (Wed, 04 Oct 2006) | 23 lines Forward-port of r52136,52138: a review of overflow-detecting code. * unified the way intobject, longobject and mystrtoul handle values around -sys.maxint-1. * in general, trying to entierely avoid overflows in any computation involving signed ints or longs is extremely involved. Fixed a few simple cases where a compiler might be too clever (but that's all guesswork). * more overflow checks against bad data in marshal.c. * 2.5 specific: fixed a number of places that were still confusing int and Py_ssize_t. Some of them could potentially have caused "real-world" breakage. * list.pop(x): fixing overflow issues on x was messy. I just reverted to PyArg_ParseTuple("n"), which does the right thing. (An obscure test was trying to give a Decimal to list.pop()... doesn't make sense any more IMHO) * trying to write a few tests... ........ r52147 | andrew.kuchling | 2006-10-04 15:42:43 +0200 (Wed, 04 Oct 2006) | 6 lines Cause a PyObject_Malloc() failure to trigger a MemoryError, and then add 'if (PyErr_Occurred())' checks to various places so that NULL is returned properly. 2.4 backport candidate. ........ r52148 | martin.v.loewis | 2006-10-04 17:25:28 +0200 (Wed, 04 Oct 2006) | 1 line Add MSVC8 project files to create wininst-8.exe. ........ r52196 | brett.cannon | 2006-10-06 00:02:31 +0200 (Fri, 06 Oct 2006) | 7 lines Clarify what "re-initialization" means for init_builtin() and init_dynamic(). Also remove warning about re-initialization as possibly raising an execption as both call _PyImport_FindExtension() which pulls any module that was already imported from the Python process' extension cache and just copies the __dict__ into the module stored in sys.modules. ........ r52200 | fred.drake | 2006-10-06 02:03:45 +0200 (Fri, 06 Oct 2006) | 3 lines - update links - remove Sleepycat name now that they have been bought ........ r52204 | andrew.kuchling | 2006-10-06 12:41:01 +0200 (Fri, 06 Oct 2006) | 1 line Case fix ........ r52208 | georg.brandl | 2006-10-06 14:46:08 +0200 (Fri, 06 Oct 2006) | 3 lines Fix name. ........ r52211 | andrew.kuchling | 2006-10-06 15:18:26 +0200 (Fri, 06 Oct 2006) | 1 line [Bug #1545341] Allow 'classifier' parameter to be a tuple as well as a list. Will backport. ........ r52212 | armin.rigo | 2006-10-06 18:33:22 +0200 (Fri, 06 Oct 2006) | 4 lines A very minor bug fix: this code looks like it is designed to accept any hue value and do the modulo itself, except it doesn't quite do it in all cases. At least, the "cannot get here" comment was wrong. ........ r52213 | andrew.kuchling | 2006-10-06 20:51:55 +0200 (Fri, 06 Oct 2006) | 1 line Comment grammar ........ r52218 | skip.montanaro | 2006-10-07 13:05:02 +0200 (Sat, 07 Oct 2006) | 6 lines Note that the excel_tab class is registered as the "excel-tab" dialect. Fixes 1572471. Make a similar change for the excel class and clean up references to the Dialects and Formatting Parameters section in a few places. ........ r52221 | georg.brandl | 2006-10-08 09:11:54 +0200 (Sun, 08 Oct 2006) | 3 lines Add missing NEWS entry for rev. 52129. ........ r52223 | hyeshik.chang | 2006-10-08 15:48:34 +0200 (Sun, 08 Oct 2006) | 3 lines Bug #1572832: fix a bug in ISO-2022 codecs which may cause segfault when encoding non-BMP unicode characters. (Submitted by Ray Chason) ........ r52227 | ronald.oussoren | 2006-10-08 19:37:58 +0200 (Sun, 08 Oct 2006) | 4 lines Add version number to the link to the python documentation in /Developer/Documentation/Python, better for users that install multiple versions of python. ........ r52229 | ronald.oussoren | 2006-10-08 19:40:02 +0200 (Sun, 08 Oct 2006) | 2 lines Fix for bug #1570284 ........ r52233 | ronald.oussoren | 2006-10-08 19:49:52 +0200 (Sun, 08 Oct 2006) | 6 lines MacOSX: distutils changes the values of BASECFLAGS and LDFLAGS when using a universal build of python on OSX 10.3 to ensure that those flags can be used to compile code (the universal build uses compiler flags that aren't supported on 10.3). This patches gives the same treatment to CFLAGS, PY_CFLAGS and BLDSHARED. ........ r52236 | ronald.oussoren | 2006-10-08 19:51:46 +0200 (Sun, 08 Oct 2006) | 5 lines MacOSX: The universal build requires that users have the MacOSX10.4u SDK installed to build extensions. This patch makes distutils emit a warning when the compiler should use an SDK but that SDK is not installed, hopefully reducing some confusion. ........ r52238 | ronald.oussoren | 2006-10-08 20:18:26 +0200 (Sun, 08 Oct 2006) | 3 lines MacOSX: add more logic to recognize the correct startup file to patch to the shell profile patching post-install script. ........ r52242 | andrew.kuchling | 2006-10-09 19:10:12 +0200 (Mon, 09 Oct 2006) | 1 line Add news item for rev. 52211 change ........ r52245 | andrew.kuchling | 2006-10-09 20:05:19 +0200 (Mon, 09 Oct 2006) | 1 line Fix wording in comment ........ r52251 | georg.brandl | 2006-10-09 21:03:06 +0200 (Mon, 09 Oct 2006) | 2 lines Patch #1572724: fix typo ('=' instead of '==') in _msi.c. ........ r52255 | barry.warsaw | 2006-10-09 21:43:24 +0200 (Mon, 09 Oct 2006) | 2 lines List gc.get_count() in the module docstring. ........ r52257 | martin.v.loewis | 2006-10-09 22:44:25 +0200 (Mon, 09 Oct 2006) | 1 line Bug #1565150: Fix subsecond processing for os.utime on Windows. ........ r52268 | ronald.oussoren | 2006-10-10 09:55:06 +0200 (Tue, 10 Oct 2006) | 2 lines MacOSX: fix permission problem in the generated installer ........ r52293 | georg.brandl | 2006-10-12 09:38:04 +0200 (Thu, 12 Oct 2006) | 2 lines Bug #1575746: fix typo in property() docs. ........ r52295 | georg.brandl | 2006-10-12 09:57:21 +0200 (Thu, 12 Oct 2006) | 3 lines Bug #813342: Start the IDLE subprocess with -Qnew if the parent is started with that option. ........ r52297 | georg.brandl | 2006-10-12 10:22:53 +0200 (Thu, 12 Oct 2006) | 2 lines Bug #1565919: document set types in the Language Reference. ........ r52299 | georg.brandl | 2006-10-12 11:20:33 +0200 (Thu, 12 Oct 2006) | 3 lines Bug #1550524: better heuristics to find correct class definition in inspect.findsource(). ........ r52301 | georg.brandl | 2006-10-12 11:47:12 +0200 (Thu, 12 Oct 2006) | 4 lines Bug #1548891: The cStringIO.StringIO() constructor now encodes unicode arguments with the system default encoding just like the write() method does, instead of converting it to a raw buffer. ........ r52303 | georg.brandl | 2006-10-12 13:14:40 +0200 (Thu, 12 Oct 2006) | 2 lines Bug #1546628: add a note about urlparse.urljoin() and absolute paths. ........ r52305 | georg.brandl | 2006-10-12 13:27:59 +0200 (Thu, 12 Oct 2006) | 3 lines Bug #1545497: when given an explicit base, int() did ignore NULs embedded in the string to convert. ........ r52307 | georg.brandl | 2006-10-12 13:41:11 +0200 (Thu, 12 Oct 2006) | 3 lines Add a note to fpectl docs that it's not built by default (bug #1556261). ........ r52309 | georg.brandl | 2006-10-12 13:46:57 +0200 (Thu, 12 Oct 2006) | 3 lines Bug #1560114: the Mac filesystem does have accurate information about the case of filenames. ........ r52311 | georg.brandl | 2006-10-12 13:59:27 +0200 (Thu, 12 Oct 2006) | 2 lines Small grammar fix, thanks Sjoerd. ........ r52313 | georg.brandl | 2006-10-12 14:03:07 +0200 (Thu, 12 Oct 2006) | 2 lines Fix tarfile depending on buggy int('1\0', base) behavior. ........ r52315 | georg.brandl | 2006-10-12 14:33:07 +0200 (Thu, 12 Oct 2006) | 2 lines Bug #1283491: follow docstring convention wrt. keyword-able args in sum(). ........ r52316 | georg.brandl | 2006-10-12 15:08:16 +0200 (Thu, 12 Oct 2006) | 3 lines Bug #1560179: speed up posixpath.(dir|base)name ........ r52327 | brett.cannon | 2006-10-14 08:36:45 +0200 (Sat, 14 Oct 2006) | 3 lines Clean up the language of a sentence relating to the connect() function and user-defined datatypes. ........ r52332 | neal.norwitz | 2006-10-14 23:33:38 +0200 (Sat, 14 Oct 2006) | 3 lines Update the peephole optimizer to remove more dead code (jumps after returns) and inline jumps to returns. ........ r52333 | martin.v.loewis | 2006-10-15 09:54:40 +0200 (Sun, 15 Oct 2006) | 4 lines Patch #1576954: Update VC6 build directory; remove redundant files in VC7. Will backport to 2.5. ........ r52335 | martin.v.loewis | 2006-10-15 10:43:33 +0200 (Sun, 15 Oct 2006) | 1 line Patch #1576166: Support os.utime for directories on Windows NT+. ........ r52336 | martin.v.loewis | 2006-10-15 10:51:22 +0200 (Sun, 15 Oct 2006) | 2 lines Patch #1577551: Add ctypes and ET build support for VC6. Will backport to 2.5. ........ r52338 | martin.v.loewis | 2006-10-15 11:35:51 +0200 (Sun, 15 Oct 2006) | 1 line Loosen the test for equal time stamps. ........ r52339 | martin.v.loewis | 2006-10-15 11:43:39 +0200 (Sun, 15 Oct 2006) | 2 lines Bug #1567666: Emulate GetFileAttributesExA for Win95. Will backport to 2.5. ........ r52341 | martin.v.loewis | 2006-10-15 13:02:07 +0200 (Sun, 15 Oct 2006) | 2 lines Round to int, because some systems support sub-second time stamps in stat, but not in utime. Also be consistent with modifying only mtime, not atime. ........ r52342 | martin.v.loewis | 2006-10-15 13:57:40 +0200 (Sun, 15 Oct 2006) | 2 lines Set the eol-style for project files to "CRLF". ........ r52343 | martin.v.loewis | 2006-10-15 13:59:56 +0200 (Sun, 15 Oct 2006) | 3 lines Drop binary property on dsp files, set eol-style to CRLF instead. ........ r52344 | martin.v.loewis | 2006-10-15 14:01:43 +0200 (Sun, 15 Oct 2006) | 2 lines Remove binary property, set eol-style to CRLF instead. ........ r52346 | martin.v.loewis | 2006-10-15 16:30:38 +0200 (Sun, 15 Oct 2006) | 2 lines Mention the bdist_msi module. Will backport to 2.5. ........ r52354 | brett.cannon | 2006-10-16 05:09:52 +0200 (Mon, 16 Oct 2006) | 3 lines Fix turtle so that you can launch the demo2 function on its own instead of only when the module is launched as a script. ........ r52356 | martin.v.loewis | 2006-10-17 17:18:06 +0200 (Tue, 17 Oct 2006) | 2 lines Patch #1457736: Update VC6 to use current PCbuild settings. Will backport to 2.5. ........ r52360 | martin.v.loewis | 2006-10-17 20:09:55 +0200 (Tue, 17 Oct 2006) | 2 lines Remove obsolete file. Will backport. ........ r52363 | martin.v.loewis | 2006-10-17 20:59:23 +0200 (Tue, 17 Oct 2006) | 4 lines Forward-port r52358: - Bug #1578513: Cross compilation was broken by a change to configure. Repair so that it's back to how it was in 2.4.3. ........ r52365 | thomas.heller | 2006-10-17 21:30:48 +0200 (Tue, 17 Oct 2006) | 6 lines ctypes callback functions only support 'fundamental' result types. Check this and raise an error when something else is used - before this change ctypes would hang or crash when such a callback was called. This is a partial fix for #1574584. Will backport to release25-maint. ........ r52377 | tim.peters | 2006-10-18 07:06:06 +0200 (Wed, 18 Oct 2006) | 2 lines newIobject(): repaired incorrect cast to quiet MSVC warning. ........ r52378 | tim.peters | 2006-10-18 07:09:12 +0200 (Wed, 18 Oct 2006) | 2 lines Whitespace normalization. ........ r52379 | tim.peters | 2006-10-18 07:10:28 +0200 (Wed, 18 Oct 2006) | 2 lines Add missing svn:eol-style to text files. ........ r52387 | martin.v.loewis | 2006-10-19 12:58:46 +0200 (Thu, 19 Oct 2006) | 3 lines Add check for the PyArg_ParseTuple format, and declare it if it is supported. ........ r52388 | martin.v.loewis | 2006-10-19 13:00:37 +0200 (Thu, 19 Oct 2006) | 3 lines Fix various minor errors in passing arguments to PyArg_ParseTuple. ........ r52389 | martin.v.loewis | 2006-10-19 18:01:37 +0200 (Thu, 19 Oct 2006) | 2 lines Restore CFLAGS after checking for __attribute__ ........ r52390 | andrew.kuchling | 2006-10-19 23:55:55 +0200 (Thu, 19 Oct 2006) | 1 line [Bug #1576348] Fix typo in example ........ r52414 | walter.doerwald | 2006-10-22 10:59:41 +0200 (Sun, 22 Oct 2006) | 2 lines Port test___future__ to unittest. ........ r52415 | ronald.oussoren | 2006-10-22 12:45:18 +0200 (Sun, 22 Oct 2006) | 3 lines Patch #1580674: with this patch os.readlink uses the filesystem encoding to decode unicode objects and returns an unicode object when the argument is one. ........ r52416 | martin.v.loewis | 2006-10-22 12:46:18 +0200 (Sun, 22 Oct 2006) | 3 lines Patch #1580872: Remove duplicate declaration of PyCallable_Check. Will backport to 2.5. ........ r52418 | martin.v.loewis | 2006-10-22 12:55:15 +0200 (Sun, 22 Oct 2006) | 4 lines - Patch #1560695: Add .note.GNU-stack to ctypes' sysv.S so that ctypes isn't considered as requiring executable stacks. Will backport to 2.5. ........ r52420 | martin.v.loewis | 2006-10-22 15:45:13 +0200 (Sun, 22 Oct 2006) | 3 lines Remove passwd.adjunct.byname from list of maps for test_nis. Will backport to 2.5. ........ r52431 | georg.brandl | 2006-10-24 18:54:16 +0200 (Tue, 24 Oct 2006) | 2 lines Patch [ 1583506 ] tarfile.py: 100-char filenames are truncated ........ r52446 | andrew.kuchling | 2006-10-26 21:10:46 +0200 (Thu, 26 Oct 2006) | 1 line [Bug #1579796] Wrong syntax for PyDateTime_IMPORT in documentation. Reported by David Faure. ........ r52449 | andrew.kuchling | 2006-10-26 21:16:46 +0200 (Thu, 26 Oct 2006) | 1 line Typo fix ........ r52452 | martin.v.loewis | 2006-10-27 08:16:31 +0200 (Fri, 27 Oct 2006) | 3 lines Patch #1549049: Rewrite type conversion in structmember. Fixes #1545696 and #1566140. Will backport to 2.5. ........ r52454 | martin.v.loewis | 2006-10-27 08:42:27 +0200 (Fri, 27 Oct 2006) | 2 lines Check for values.h. Will backport. ........ r52456 | martin.v.loewis | 2006-10-27 09:06:52 +0200 (Fri, 27 Oct 2006) | 2 lines Get DBL_MAX from float.h not values.h. Will backport. ........ r52458 | martin.v.loewis | 2006-10-27 09:13:28 +0200 (Fri, 27 Oct 2006) | 2 lines Patch #1567274: Support SMTP over TLS. ........ r52459 | andrew.kuchling | 2006-10-27 13:33:29 +0200 (Fri, 27 Oct 2006) | 1 line Set svn:keywords property ........ r52460 | andrew.kuchling | 2006-10-27 13:36:41 +0200 (Fri, 27 Oct 2006) | 1 line Add item ........ r52461 | andrew.kuchling | 2006-10-27 13:37:01 +0200 (Fri, 27 Oct 2006) | 1 line Some wording changes and markup fixes ........ r52462 | andrew.kuchling | 2006-10-27 14:18:38 +0200 (Fri, 27 Oct 2006) | 1 line [Bug #1585690] Note that line_num was added in Python 2.5 ........ r52464 | andrew.kuchling | 2006-10-27 14:50:38 +0200 (Fri, 27 Oct 2006) | 1 line [Bug #1583946] Reword description of server and issuer ........ r52466 | andrew.kuchling | 2006-10-27 15:06:25 +0200 (Fri, 27 Oct 2006) | 1 line [Bug #1562583] Mention the set_reuse_addr() method ........ r52469 | andrew.kuchling | 2006-10-27 15:22:46 +0200 (Fri, 27 Oct 2006) | 4 lines [Bug #1542016] Report PCALL_POP value. This makes the return value of sys.callstats() match its docstring. Backport candidate. Though it's an API change, this is a pretty obscure portion of the API. ........ r52473 | andrew.kuchling | 2006-10-27 16:53:41 +0200 (Fri, 27 Oct 2006) | 1 line Point users to the subprocess module in the docs for os.system, os.spawn*, os.popen2, and the popen2 and commands modules ........ r52476 | andrew.kuchling | 2006-10-27 18:39:10 +0200 (Fri, 27 Oct 2006) | 1 line [Bug #1576241] Let functools.wraps work with built-in functions ........ r52478 | andrew.kuchling | 2006-10-27 18:55:34 +0200 (Fri, 27 Oct 2006) | 1 line [Bug #1575506] The _singlefileMailbox class was using the wrong file object in its flush() method, causing an error ........ r52480 | andrew.kuchling | 2006-10-27 19:06:16 +0200 (Fri, 27 Oct 2006) | 1 line Clarify docstring ........ r52481 | andrew.kuchling | 2006-10-27 19:11:23 +0200 (Fri, 27 Oct 2006) | 5 lines [Patch #1574068 by Scott Dial] urllib and urllib2 were using base64.encodestring() for encoding authentication data. encodestring() can include newlines for very long input, which produced broken HTTP headers. ........ r52483 | andrew.kuchling | 2006-10-27 20:13:46 +0200 (Fri, 27 Oct 2006) | 1 line Check db_setup_debug for a few print statements; change sqlite_setup_debug to False ........ r52484 | andrew.kuchling | 2006-10-27 20:15:02 +0200 (Fri, 27 Oct 2006) | 1 line [Patch #1503717] Tiny patch from Chris AtLee to stop a lengthy line from being printed ........ r52485 | thomas.heller | 2006-10-27 20:31:36 +0200 (Fri, 27 Oct 2006) | 5 lines WindowsError.str should display the windows error code, not the posix error code; with test. Fixes #1576174. Will backport to release25-maint. ........ r52487 | thomas.heller | 2006-10-27 21:05:53 +0200 (Fri, 27 Oct 2006) | 4 lines Modulefinder now handles absolute and relative imports, including tests. Will backport to release25-maint. ........ r52488 | georg.brandl | 2006-10-27 22:39:43 +0200 (Fri, 27 Oct 2006) | 2 lines Patch #1552024: add decorator support to unparse.py demo script. ........ r52492 | walter.doerwald | 2006-10-28 12:47:12 +0200 (Sat, 28 Oct 2006) | 2 lines Port test_bufio to unittest. ........ r52493 | georg.brandl | 2006-10-28 15:10:17 +0200 (Sat, 28 Oct 2006) | 6 lines Convert test_global, test_scope and test_grammar to unittest. I tried to enclose all tests which must be run at the toplevel (instead of inside a method) in exec statements. ........ r52494 | georg.brandl | 2006-10-28 15:11:41 +0200 (Sat, 28 Oct 2006) | 3 lines Update outstanding bugs test file. ........ r52495 | georg.brandl | 2006-10-28 15:51:49 +0200 (Sat, 28 Oct 2006) | 3 lines Convert test_math to unittest. ........ r52496 | georg.brandl | 2006-10-28 15:56:58 +0200 (Sat, 28 Oct 2006) | 3 lines Convert test_opcodes to unittest. ........ r52497 | georg.brandl | 2006-10-28 18:04:04 +0200 (Sat, 28 Oct 2006) | 2 lines Fix nth() itertool recipe. ........ r52500 | georg.brandl | 2006-10-28 22:25:09 +0200 (Sat, 28 Oct 2006) | 2 lines make test_grammar pass with python -O ........ r52501 | neal.norwitz | 2006-10-28 23:15:30 +0200 (Sat, 28 Oct 2006) | 6 lines Add some asserts. In sysmodule, I think these were to try to silence some warnings from Klokwork. They verify the assumptions of the format of svn version output. The assert in the thread module helped debug a problem on HP-UX. ........ r52502 | neal.norwitz | 2006-10-28 23:16:54 +0200 (Sat, 28 Oct 2006) | 5 lines Fix warnings with HP's C compiler. It doesn't recognize that infinite loops are, um, infinite. These conditions should not be able to happen. Will backport. ........ r52503 | neal.norwitz | 2006-10-28 23:17:51 +0200 (Sat, 28 Oct 2006) | 5 lines Fix crash in test on HP-UX. Apparently, it's not possible to delete a lock if it's held (even by the current thread). Will backport. ........ r52504 | neal.norwitz | 2006-10-28 23:19:07 +0200 (Sat, 28 Oct 2006) | 6 lines Fix bug #1565514, SystemError not raised on too many nested blocks. It seems like this should be a different error than SystemError, but I don't have any great ideas and SystemError was raised in 2.4 and earlier. Will backport. ........ r52505 | neal.norwitz | 2006-10-28 23:20:12 +0200 (Sat, 28 Oct 2006) | 4 lines Prevent crash if alloc of garbage fails. Found by Typo.pl. Will backport. ........ r52506 | neal.norwitz | 2006-10-28 23:21:00 +0200 (Sat, 28 Oct 2006) | 4 lines Don't inline Py_ADDRESS_IN_RANGE with gcc 4+ either. Will backport. ........ r52513 | neal.norwitz | 2006-10-28 23:56:49 +0200 (Sat, 28 Oct 2006) | 2 lines Fix test_modulefinder so it doesn't fail when run after test_distutils. ........ r52514 | neal.norwitz | 2006-10-29 00:12:26 +0200 (Sun, 29 Oct 2006) | 4 lines From SF 1557890, fix problem of using wrong type in example. Will backport. ........ r52517 | georg.brandl | 2006-10-29 09:39:22 +0100 (Sun, 29 Oct 2006) | 4 lines Fix codecs.EncodedFile which did not use file_encoding in 2.5.0, and fix all codecs file wrappers to work correctly with the "with" statement (bug #1586513). ........ r52519 | georg.brandl | 2006-10-29 09:47:08 +0100 (Sun, 29 Oct 2006) | 3 lines Clean up a leftover from old listcomp generation code. ........ r52520 | georg.brandl | 2006-10-29 09:53:06 +0100 (Sun, 29 Oct 2006) | 4 lines Bug #1586448: the compiler module now emits the same bytecode for list comprehensions as the builtin compiler, using the LIST_APPEND opcode. ........ r52521 | georg.brandl | 2006-10-29 10:01:01 +0100 (Sun, 29 Oct 2006) | 3 lines Remove trailing comma. ........ r52522 | georg.brandl | 2006-10-29 10:05:04 +0100 (Sun, 29 Oct 2006) | 3 lines Bug #1357915: allow all sequence types for shell arguments in subprocess. ........ r52524 | georg.brandl | 2006-10-29 10:16:12 +0100 (Sun, 29 Oct 2006) | 3 lines Patch #1583880: fix tarfile's problems with long names and posix/ GNU modes. ........ r52526 | georg.brandl | 2006-10-29 10:18:00 +0100 (Sun, 29 Oct 2006) | 3 lines Test assert if __debug__ is true. ........ r52527 | georg.brandl | 2006-10-29 10:32:16 +0100 (Sun, 29 Oct 2006) | 2 lines Fix the new EncodedFile test to work with big endian platforms. ........ r52529 | georg.brandl | 2006-10-29 15:39:09 +0100 (Sun, 29 Oct 2006) | 2 lines Bug #1586613: fix zlib and bz2 codecs' incremental en/decoders. ........ r52532 | georg.brandl | 2006-10-29 19:01:08 +0100 (Sun, 29 Oct 2006) | 2 lines Bug #1586773: extend hashlib docstring. ........ r52534 | neal.norwitz | 2006-10-29 19:30:10 +0100 (Sun, 29 Oct 2006) | 4 lines Update comments, remove commented out code. Move assembler structure next to assembler code to make it easier to move it to a separate file. ........ r52535 | georg.brandl | 2006-10-29 19:31:42 +0100 (Sun, 29 Oct 2006) | 3 lines Bug #1576657: when setting a KeyError for a tuple key, make sure that the tuple isn't used as the "exception arguments tuple". ........ r52537 | georg.brandl | 2006-10-29 20:13:40 +0100 (Sun, 29 Oct 2006) | 3 lines Convert test_mmap to unittest. ........ r52538 | georg.brandl | 2006-10-29 20:20:45 +0100 (Sun, 29 Oct 2006) | 3 lines Convert test_poll to unittest. ........ r52539 | georg.brandl | 2006-10-29 20:24:43 +0100 (Sun, 29 Oct 2006) | 3 lines Convert test_nis to unittest. ........ r52540 | georg.brandl | 2006-10-29 20:35:03 +0100 (Sun, 29 Oct 2006) | 3 lines Convert test_types to unittest. ........ r52541 | georg.brandl | 2006-10-29 20:51:16 +0100 (Sun, 29 Oct 2006) | 3 lines Convert test_cookie to unittest. ........ r52542 | georg.brandl | 2006-10-29 21:09:12 +0100 (Sun, 29 Oct 2006) | 3 lines Convert test_cgi to unittest. ........ r52543 | georg.brandl | 2006-10-29 21:24:01 +0100 (Sun, 29 Oct 2006) | 3 lines Completely convert test_httplib to unittest. ........ r52544 | georg.brandl | 2006-10-29 21:28:26 +0100 (Sun, 29 Oct 2006) | 2 lines Convert test_MimeWriter to unittest. ........ r52545 | georg.brandl | 2006-10-29 21:31:17 +0100 (Sun, 29 Oct 2006) | 3 lines Convert test_openpty to unittest. ........ r52546 | georg.brandl | 2006-10-29 21:35:12 +0100 (Sun, 29 Oct 2006) | 3 lines Remove leftover test output file. ........ r52547 | georg.brandl | 2006-10-29 22:54:18 +0100 (Sun, 29 Oct 2006) | 3 lines Move the check for openpty to the beginning. ........ r52548 | walter.doerwald | 2006-10-29 23:06:28 +0100 (Sun, 29 Oct 2006) | 2 lines Add tests for basic argument errors. ........ r52549 | walter.doerwald | 2006-10-30 00:02:27 +0100 (Mon, 30 Oct 2006) | 3 lines Add tests for incremental codecs with an errors argument. ........ r52550 | neal.norwitz | 2006-10-30 00:39:03 +0100 (Mon, 30 Oct 2006) | 1 line Fix refleak ........ r52552 | neal.norwitz | 2006-10-30 00:58:36 +0100 (Mon, 30 Oct 2006) | 1 line I'm assuming this is correct, it fixes the tests so they pass again ........ r52555 | vinay.sajip | 2006-10-31 18:32:37 +0100 (Tue, 31 Oct 2006) | 1 line Change to improve speed of _fixupChildren ........ r52556 | vinay.sajip | 2006-10-31 18:34:31 +0100 (Tue, 31 Oct 2006) | 1 line Added relativeCreated to Formatter doc (has been in the system for a long time - was unaccountably left out of the docs and not noticed until now). ........ r52588 | thomas.heller | 2006-11-02 20:48:24 +0100 (Thu, 02 Nov 2006) | 5 lines Replace the XXX marker in the 'Arrays and pointers' reference manual section with a link to the tutorial sections. Will backport to release25-maint. ........ r52592 | thomas.heller | 2006-11-02 21:22:29 +0100 (Thu, 02 Nov 2006) | 6 lines Fix a code example by adding a missing import. Fixes #1557890. Will backport to release25-maint. ........ r52598 | tim.peters | 2006-11-03 03:32:46 +0100 (Fri, 03 Nov 2006) | 2 lines Whitespace normalization. ........ r52619 | martin.v.loewis | 2006-11-04 19:14:06 +0100 (Sat, 04 Nov 2006) | 4 lines - Patch #1060577: Extract list of RPM files from spec file in bdist_rpm Will backport to 2.5. ........ r52621 | neal.norwitz | 2006-11-04 20:25:22 +0100 (Sat, 04 Nov 2006) | 4 lines Bug #1588287: fix invalid assertion for `1,2` in debug builds. Will backport ........ r52630 | andrew.kuchling | 2006-11-05 22:04:37 +0100 (Sun, 05 Nov 2006) | 1 line Update link ........ r52631 | skip.montanaro | 2006-11-06 15:34:52 +0100 (Mon, 06 Nov 2006) | 1 line note that user can control directory location even if default dir is used ........ r52644 | ronald.oussoren | 2006-11-07 16:53:38 +0100 (Tue, 07 Nov 2006) | 2 lines Fix a number of typos in strings and comments (sf#1589070) ........ r52647 | ronald.oussoren | 2006-11-07 17:00:34 +0100 (Tue, 07 Nov 2006) | 2 lines Whitespace changes to make the source more compliant with PEP8 (SF#1589070) ........ r52651 | thomas.heller | 2006-11-07 19:01:18 +0100 (Tue, 07 Nov 2006) | 3 lines Fix markup. Will backport to release25-maint. ........ r52653 | thomas.heller | 2006-11-07 19:20:47 +0100 (Tue, 07 Nov 2006) | 3 lines Fix grammatical error as well. Will backport to release25-maint. ........ r52657 | andrew.kuchling | 2006-11-07 21:39:16 +0100 (Tue, 07 Nov 2006) | 1 line Add missing word ........ r52662 | martin.v.loewis | 2006-11-08 07:46:37 +0100 (Wed, 08 Nov 2006) | 4 lines Correctly forward exception in instance_contains(). Fixes #1591996. Patch contributed by Neal Norwitz. Will backport. ........ r52664 | martin.v.loewis | 2006-11-08 07:48:36 +0100 (Wed, 08 Nov 2006) | 2 lines News entry for 52662. ........ r52665 | martin.v.loewis | 2006-11-08 08:35:55 +0100 (Wed, 08 Nov 2006) | 2 lines Patch #1351744: Add askyesnocancel helper for tkMessageBox. ........ r52666 | georg.brandl | 2006-11-08 08:45:59 +0100 (Wed, 08 Nov 2006) | 2 lines Patch #1592072: fix docs for return value of PyErr_CheckSignals. ........ r52668 | georg.brandl | 2006-11-08 11:04:29 +0100 (Wed, 08 Nov 2006) | 3 lines Bug #1592533: rename variable in heapq doc example, to avoid shadowing "sorted". ........ r52671 | andrew.kuchling | 2006-11-08 14:35:34 +0100 (Wed, 08 Nov 2006) | 1 line Add section on the functional module ........ r52672 | andrew.kuchling | 2006-11-08 15:14:30 +0100 (Wed, 08 Nov 2006) | 1 line Add section on operator module; make a few edits ........ r52673 | andrew.kuchling | 2006-11-08 15:24:03 +0100 (Wed, 08 Nov 2006) | 1 line Add table of contents; this required fixing a few headings. Some more smalle edits. ........ r52674 | andrew.kuchling | 2006-11-08 15:30:14 +0100 (Wed, 08 Nov 2006) | 1 line More edits ........ r52686 | martin.v.loewis | 2006-11-09 12:06:03 +0100 (Thu, 09 Nov 2006) | 3 lines Patch #838546: Make terminal become controlling in pty.fork(). Will backport to 2.5. ........ r52688 | martin.v.loewis | 2006-11-09 12:27:32 +0100 (Thu, 09 Nov 2006) | 2 lines Patch #1592250: Add elidge argument to Tkinter.Text.search. ........ r52690 | andrew.kuchling | 2006-11-09 14:27:07 +0100 (Thu, 09 Nov 2006) | 7 lines [Bug #1569790] mailbox.Maildir.get_folder() loses factory information Both the Maildir and MH classes had this bug; the patch fixes both classes and adds a test. Will backport to 25-maint. ........ r52692 | andrew.kuchling | 2006-11-09 14:51:14 +0100 (Thu, 09 Nov 2006) | 1 line [Patch #1514544 by David Watson] use fsync() to ensure data is really on disk ........ r52695 | walter.doerwald | 2006-11-09 17:23:26 +0100 (Thu, 09 Nov 2006) | 2 lines Replace C++ comment with C comment (fixes SF bug #1593525). ........ r52712 | andrew.kuchling | 2006-11-09 22:16:46 +0100 (Thu, 09 Nov 2006) | 11 lines [Patch #1514543] mailbox (Maildir): avoid losing messages on name clash Two changes: Where possible, use link()/remove() to move files into a directory; this makes it easier to avoid overwriting an existing file. Use _create_carefully() to create files in tmp/, which uses O_EXCL. Backport candidate. ........ r52716 | phillip.eby | 2006-11-10 01:33:36 +0100 (Fri, 10 Nov 2006) | 4 lines Fix SF#1566719: not creating site-packages (or other target directory) when installing .egg-info for a project that contains no modules or packages, while using --root (as in bdist_rpm). ........ r52719 | andrew.kuchling | 2006-11-10 14:14:01 +0100 (Fri, 10 Nov 2006) | 1 line Reword entry ........ r52725 | andrew.kuchling | 2006-11-10 15:39:01 +0100 (Fri, 10 Nov 2006) | 1 line [Feature request #1542920] Link to wsgi.org ........ r52731 | georg.brandl | 2006-11-11 19:29:11 +0100 (Sat, 11 Nov 2006) | 2 lines Bug #1594742: wrong word in stringobject doc. ........ r52733 | georg.brandl | 2006-11-11 19:32:47 +0100 (Sat, 11 Nov 2006) | 2 lines Bug #1594758: wording improvement for dict.update() docs. ........ r52736 | martin.v.loewis | 2006-11-12 11:32:47 +0100 (Sun, 12 Nov 2006) | 3 lines Patch #1065257: Support passing open files as body in HTTPConnection.request(). ........ r52737 | martin.v.loewis | 2006-11-12 11:41:39 +0100 (Sun, 12 Nov 2006) | 2 lines Patch #1355023: support whence argument for GzipFile.seek. ........ r52738 | martin.v.loewis | 2006-11-12 19:24:26 +0100 (Sun, 12 Nov 2006) | 2 lines Bug #1067760: Deprecate passing floats to file.seek. ........ r52739 | martin.v.loewis | 2006-11-12 19:48:13 +0100 (Sun, 12 Nov 2006) | 3 lines Patch #1359217: Ignore 2xx response before 150 response. Will backport to 2.5. ........ r52741 | martin.v.loewis | 2006-11-12 19:56:03 +0100 (Sun, 12 Nov 2006) | 4 lines Patch #1360200: Use unmangled_version RPM spec field to deal with file name mangling. Will backport to 2.5. ........ r52753 | walter.doerwald | 2006-11-15 17:23:46 +0100 (Wed, 15 Nov 2006) | 2 lines Fix typo. ........ r52754 | georg.brandl | 2006-11-15 18:42:03 +0100 (Wed, 15 Nov 2006) | 2 lines Bug #1594809: add a note to README regarding PYTHONPATH and make install. ........ r52762 | georg.brandl | 2006-11-16 16:05:14 +0100 (Thu, 16 Nov 2006) | 2 lines Bug #1597576: mention that the new base64 api has been introduced in py2.4. ........ r52764 | georg.brandl | 2006-11-16 17:50:59 +0100 (Thu, 16 Nov 2006) | 3 lines Bug #1597824: return the registered function from atexit.register() to facilitate usage as a decorator. ........ r52765 | georg.brandl | 2006-11-16 18:08:45 +0100 (Thu, 16 Nov 2006) | 4 lines Bug #1588217: don't parse "= " as a soft line break in binascii's a2b_qp() function, instead leave it in the string as quopri.decode() does. ........ r52776 | andrew.kuchling | 2006-11-17 14:30:25 +0100 (Fri, 17 Nov 2006) | 17 lines Remove file-locking in MH.pack() method. This change looks massive but it's mostly a re-indenting after removing some try...finally blocks. Also adds a test case that does a pack() while the mailbox is locked; this test would have turned up bugs in the original code on some platforms. In both nmh and GNU Mailutils' implementation of MH-format mailboxes, no locking is done of individual message files when renaming them. The original mailbox.py code did do locking, which meant that message files had to be opened. This code was buggy on certain platforms (found through reading the code); there were code paths that closed the file object and then called _unlock_file() on it. Will backport to 25-maint once I see how the buildbots react to this patch. ........ r52780 | martin.v.loewis | 2006-11-18 19:00:23 +0100 (Sat, 18 Nov 2006) | 5 lines Patch #1538878: Don't make tkSimpleDialog dialogs transient if the parent window is withdrawn. This mirrors what dialog.tcl does. Will backport to 2.5. ........ r52782 | martin.v.loewis | 2006-11-18 19:05:35 +0100 (Sat, 18 Nov 2006) | 4 lines Patch #1594554: Always close a tkSimpleDialog on ok(), even if an exception occurs. Will backport to 2.5. ........ r52784 | martin.v.loewis | 2006-11-18 19:42:11 +0100 (Sat, 18 Nov 2006) | 3 lines Patch #1472877: Fix Tix subwidget name resolution. Will backport to 2.5. ........ r52786 | andrew.kuchling | 2006-11-18 23:17:33 +0100 (Sat, 18 Nov 2006) | 1 line Expand checking in test_sha ........ r52787 | georg.brandl | 2006-11-19 09:48:30 +0100 (Sun, 19 Nov 2006) | 3 lines Patch [ 1586791 ] better error msgs for some TypeErrors ........ r52788 | martin.v.loewis | 2006-11-19 11:41:41 +0100 (Sun, 19 Nov 2006) | 4 lines Make cStringIO.truncate raise IOError for negative arguments (even for -1). Fixes the last bit of #1359365. ........ r52789 | andrew.kuchling | 2006-11-19 19:40:01 +0100 (Sun, 19 Nov 2006) | 1 line Add a test case of data w/ bytes > 127 ........ r52790 | martin.v.loewis | 2006-11-19 19:51:54 +0100 (Sun, 19 Nov 2006) | 3 lines Patch #1070046: Marshal new-style objects like InstanceType in xmlrpclib. ........ r52792 | neal.norwitz | 2006-11-19 22:26:53 +0100 (Sun, 19 Nov 2006) | 4 lines Speed up function calls into the math module by using METH_O. There should be no functional changes. However, the error msgs are slightly different. Also verified that the module dict is not NULL on init. ........ r52794 | george.yoshida | 2006-11-20 03:24:48 +0100 (Mon, 20 Nov 2006) | 2 lines markup fix ........ r52795 | georg.brandl | 2006-11-20 08:12:58 +0100 (Mon, 20 Nov 2006) | 3 lines Further markup fix. ........ r52800 | andrew.kuchling | 2006-11-20 14:39:37 +0100 (Mon, 20 Nov 2006) | 2 lines Jython compatibility fix: if uu.decode() opened its output file, be sure to close it. ........ r52811 | neal.norwitz | 2006-11-21 06:26:22 +0100 (Tue, 21 Nov 2006) | 9 lines Bug #1599782: Fix segfault on bsddb.db.DB().type(). The problem is that _DB_get_type() can't be called without the GIL because it calls a bunch of PyErr_* APIs when an error occurs. There were no other cases in this file that it was called without the GIL. Removing the BEGIN/END THREAD around _DB_get_type() made everything work. Will backport. ........ r52814 | neal.norwitz | 2006-11-21 06:51:51 +0100 (Tue, 21 Nov 2006) | 1 line Oops, convert tabs to spaces ........ r52815 | neal.norwitz | 2006-11-21 07:23:44 +0100 (Tue, 21 Nov 2006) | 1 line Fix SF #1599879, socket.gethostname should ref getfqdn directly. ........ r52817 | martin.v.loewis | 2006-11-21 19:20:25 +0100 (Tue, 21 Nov 2006) | 4 lines Conditionalize definition of _CRT_SECURE_NO_DEPRECATE and _CRT_NONSTDC_NO_DEPRECATE. Will backport. ........ r52821 | martin.v.loewis | 2006-11-22 09:50:02 +0100 (Wed, 22 Nov 2006) | 4 lines Patch #1362975: Rework CodeContext indentation algorithm to avoid hard-coding pixel widths. Also make the text's scrollbar a child of the text frame, not the top widget. ........ r52826 | walter.doerwald | 2006-11-23 06:03:56 +0100 (Thu, 23 Nov 2006) | 3 lines Change decode() so that it works with a buffer (i.e. unicode(..., 'utf-8-sig')) SF bug #1601501. ........ r52833 | georg.brandl | 2006-11-23 10:55:07 +0100 (Thu, 23 Nov 2006) | 2 lines Bug #1601630: little improvement to getopt docs ........ r52835 | michael.hudson | 2006-11-23 14:54:04 +0100 (Thu, 23 Nov 2006) | 3 lines a test for an error condition not covered by existing tests (noticed this when writing the equivalent code for pypy) ........ r52839 | raymond.hettinger | 2006-11-23 22:06:03 +0100 (Thu, 23 Nov 2006) | 1 line Fix and/add typo ........ r52840 | raymond.hettinger | 2006-11-23 22:35:19 +0100 (Thu, 23 Nov 2006) | 1 line ... and the number of the counting shall be three. ........ r52841 | thomas.heller | 2006-11-24 19:45:39 +0100 (Fri, 24 Nov 2006) | 1 line Fix bug #1598620: A ctypes structure cannot contain itself. ........ r52843 | martin.v.loewis | 2006-11-25 16:39:19 +0100 (Sat, 25 Nov 2006) | 3 lines Disable _XOPEN_SOURCE on NetBSD 1.x. Will backport to 2.5 ........ r52845 | georg.brandl | 2006-11-26 20:27:47 +0100 (Sun, 26 Nov 2006) | 2 lines Bug #1603321: make pstats.Stats accept Unicode file paths. ........ r52850 | georg.brandl | 2006-11-27 19:46:21 +0100 (Mon, 27 Nov 2006) | 2 lines Bug #1603789: grammatical error in Tkinter docs. ........ r52855 | thomas.heller | 2006-11-28 21:21:54 +0100 (Tue, 28 Nov 2006) | 7 lines Fix #1563807: _ctypes built on AIX fails with ld ffi error. The contents of ffi_darwin.c must be compiled unless __APPLE__ is defined and __ppc__ is not. Will backport. ........ r52862 | armin.rigo | 2006-11-29 22:59:22 +0100 (Wed, 29 Nov 2006) | 3 lines Forgot a case where the locals can now be a general mapping instead of just a dictionary. (backporting...) ........ r52872 | guido.van.rossum | 2006-11-30 20:23:13 +0100 (Thu, 30 Nov 2006) | 2 lines Update version. ........ r52890 | walter.doerwald | 2006-12-01 17:59:47 +0100 (Fri, 01 Dec 2006) | 3 lines Move xdrlib tests from the module into a separate test script, port the tests to unittest and add a few new tests. ........ r52900 | raymond.hettinger | 2006-12-02 03:00:39 +0100 (Sat, 02 Dec 2006) | 1 line Add name to credits (for untokenize). ........ r52905 | martin.v.loewis | 2006-12-03 10:54:46 +0100 (Sun, 03 Dec 2006) | 2 lines Move IDLE news into NEWS.txt. ........ r52906 | martin.v.loewis | 2006-12-03 12:23:45 +0100 (Sun, 03 Dec 2006) | 4 lines Patch #1544279: Improve thread-safety of the socket module by moving the sock_addr_t storage out of the socket object. Will backport to 2.5. ........ r52908 | martin.v.loewis | 2006-12-03 13:01:53 +0100 (Sun, 03 Dec 2006) | 3 lines Patch #1371075: Make ConfigParser accept optional dict type for ordering, sorting, etc. ........ r52910 | matthias.klose | 2006-12-03 18:16:41 +0100 (Sun, 03 Dec 2006) | 2 lines - Fix build failure on kfreebsd and on the hurd. ........ r52915 | george.yoshida | 2006-12-04 12:41:54 +0100 (Mon, 04 Dec 2006) | 2 lines fix a versionchanged tag ........ r52917 | george.yoshida | 2006-12-05 06:39:50 +0100 (Tue, 05 Dec 2006) | 3 lines Fix pickle doc typo Patch #1608758 ........ r52938 | georg.brandl | 2006-12-06 23:21:18 +0100 (Wed, 06 Dec 2006) | 2 lines Patch #1610437: fix a tarfile bug with long filename headers. ........ r52945 | brett.cannon | 2006-12-07 00:38:48 +0100 (Thu, 07 Dec 2006) | 3 lines Fix a bad assumption that all objects assigned to '__loader__' on a module will have a '_files' attribute. ........ r52951 | georg.brandl | 2006-12-07 10:30:06 +0100 (Thu, 07 Dec 2006) | 3 lines RFE #1592899: mention string.maketrans() in docs for str.translate, remove reference to the old regex module in the former's doc. ........ r52962 | raymond.hettinger | 2006-12-08 04:17:18 +0100 (Fri, 08 Dec 2006) | 1 line Eliminate two redundant calls to PyObject_Hash(). ........ r52963 | raymond.hettinger | 2006-12-08 05:24:33 +0100 (Fri, 08 Dec 2006) | 3 lines Port Armin's fix for a dict resize vulnerability (svn revision 46589, sf bug 1456209). ........ r52964 | raymond.hettinger | 2006-12-08 05:57:50 +0100 (Fri, 08 Dec 2006) | 4 lines Port Georg's dictobject.c fix keys that were tuples got unpacked on the way to setting a KeyError (svn revision 52535, sf bug 1576657). ........ r52966 | raymond.hettinger | 2006-12-08 18:35:25 +0100 (Fri, 08 Dec 2006) | 2 lines Add test for SF bug 1576657 ........ r52970 | georg.brandl | 2006-12-08 21:46:11 +0100 (Fri, 08 Dec 2006) | 3 lines #1577756: svnversion doesn't react to LANG=C, use LC_ALL=C to force English output. ........ r52972 | georg.brandl | 2006-12-09 10:08:29 +0100 (Sat, 09 Dec 2006) | 3 lines Patch #1608267: fix a race condition in os.makedirs() is the directory to be created is already there. ........ r52975 | matthias.klose | 2006-12-09 13:15:27 +0100 (Sat, 09 Dec 2006) | 2 lines - Fix the build of the library reference in info format. ........ r52994 | neal.norwitz | 2006-12-11 02:01:06 +0100 (Mon, 11 Dec 2006) | 1 line Fix a typo ........ r52996 | georg.brandl | 2006-12-11 08:56:33 +0100 (Mon, 11 Dec 2006) | 2 lines Move errno imports back to individual functions. ........ r52998 | vinay.sajip | 2006-12-11 15:07:16 +0100 (Mon, 11 Dec 2006) | 1 line Patch by Jeremy Katz (SF #1609407) ........ r53000 | vinay.sajip | 2006-12-11 15:26:23 +0100 (Mon, 11 Dec 2006) | 1 line Patch by "cuppatea" (SF #1503765) ........
1278 lines
58 KiB
TeX
1278 lines
58 KiB
TeX
\section{Built-in Functions \label{built-in-funcs}}
|
|
|
|
The Python interpreter has a number of functions built into it that
|
|
are always available. They are listed here in alphabetical order.
|
|
|
|
|
|
\setindexsubitem{(built-in function)}
|
|
|
|
\begin{funcdesc}{__import__}{name\optional{, globals\optional{, locals\optional{, fromlist\optional{, level}}}}}
|
|
This function is invoked by the \keyword{import}\stindex{import}
|
|
statement. It mainly exists so that you can replace it with another
|
|
function that has a compatible interface, in order to change the
|
|
semantics of the \keyword{import} statement. For examples of why
|
|
and how you would do this, see the standard library modules
|
|
\module{ihooks}\refstmodindex{ihooks} and
|
|
\refmodule{rexec}\refstmodindex{rexec}. See also the built-in
|
|
module \refmodule{imp}\refbimodindex{imp}, which defines some useful
|
|
operations out of which you can build your own
|
|
\function{__import__()} function.
|
|
|
|
For example, the statement \samp{import spam} results in the
|
|
following call: \code{__import__('spam',} \code{globals(),}
|
|
\code{locals(), [], -1)}; the statement \samp{from spam.ham import eggs}
|
|
results in \samp{__import__('spam.ham', globals(), locals(),
|
|
['eggs'], -1)}. Note that even though \code{locals()} and
|
|
\code{['eggs']} are passed in as arguments, the
|
|
\function{__import__()} function does not set the local variable
|
|
named \code{eggs}; this is done by subsequent code that is generated
|
|
for the import statement. (In fact, the standard implementation
|
|
does not use its \var{locals} argument at all, and uses its
|
|
\var{globals} only to determine the package context of the
|
|
\keyword{import} statement.)
|
|
|
|
When the \var{name} variable is of the form \code{package.module},
|
|
normally, the top-level package (the name up till the first dot) is
|
|
returned, \emph{not} the module named by \var{name}. However, when
|
|
a non-empty \var{fromlist} argument is given, the module named by
|
|
\var{name} is returned. This is done for compatibility with the
|
|
bytecode generated for the different kinds of import statement; when
|
|
using \samp{import spam.ham.eggs}, the top-level package \module{spam}
|
|
must be placed in the importing namespace, but when using \samp{from
|
|
spam.ham import eggs}, the \code{spam.ham} subpackage must be used
|
|
to find the \code{eggs} variable. As a workaround for this
|
|
behavior, use \function{getattr()} to extract the desired
|
|
components. For example, you could define the following helper:
|
|
|
|
\begin{verbatim}
|
|
def my_import(name):
|
|
mod = __import__(name)
|
|
components = name.split('.')
|
|
for comp in components[1:]:
|
|
mod = getattr(mod, comp)
|
|
return mod
|
|
\end{verbatim}
|
|
|
|
\var{level} specifies whether to use absolute or relative imports.
|
|
The default is \code{-1} which indicates both absolute and relative
|
|
imports will be attempted. \code{0} means only perform absolute imports.
|
|
Positive values for \var{level} indicate the number of parent directories
|
|
to search relative to the directory of the module calling
|
|
\function{__import__}.
|
|
\versionchanged[The level parameter was added]{2.5}
|
|
\versionchanged[Keyword support for parameters was added]{2.5}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{abs}{x}
|
|
Return the absolute value of a number. The argument may be a plain
|
|
or long integer or a floating point number. If the argument is a
|
|
complex number, its magnitude is returned.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{all}{iterable}
|
|
Return True if all elements of the \var{iterable} are true.
|
|
Equivalent to:
|
|
\begin{verbatim}
|
|
def all(iterable):
|
|
for element in iterable:
|
|
if not element:
|
|
return False
|
|
return True
|
|
\end{verbatim}
|
|
\versionadded{2.5}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{any}{iterable}
|
|
Return True if any element of the \var{iterable} is true.
|
|
Equivalent to:
|
|
\begin{verbatim}
|
|
def any(iterable):
|
|
for element in iterable:
|
|
if element:
|
|
return True
|
|
return False
|
|
\end{verbatim}
|
|
\versionadded{2.5}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{basestring}{}
|
|
This abstract type is the superclass for \class{str} and \class{unicode}.
|
|
It cannot be called or instantiated, but it can be used to test whether
|
|
an object is an instance of \class{str} or \class{unicode}.
|
|
\code{isinstance(obj, basestring)} is equivalent to
|
|
\code{isinstance(obj, (str, unicode))}.
|
|
\versionadded{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{bool}{\optional{x}}
|
|
Convert a value to a Boolean, using the standard truth testing
|
|
procedure. If \var{x} is false or omitted, this returns
|
|
\constant{False}; otherwise it returns \constant{True}.
|
|
\class{bool} is also a class, which is a subclass of \class{int}.
|
|
Class \class{bool} cannot be subclassed further. Its only instances
|
|
are \constant{False} and \constant{True}.
|
|
|
|
\indexii{Boolean}{type}
|
|
\versionadded{2.2.1}
|
|
\versionchanged[If no argument is given, this function returns
|
|
\constant{False}]{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{callable}{object}
|
|
Return true if the \var{object} argument appears callable, false if
|
|
not. If this returns true, it is still possible that a call fails,
|
|
but if it is false, calling \var{object} will never succeed. Note
|
|
that classes are callable (calling a class returns a new instance);
|
|
class instances are callable if they have a \method{__call__()}
|
|
method.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{chr}{i}
|
|
Return a string of one character whose \ASCII{} code is the integer
|
|
\var{i}. For example, \code{chr(97)} returns the string \code{'a'}.
|
|
This is the inverse of \function{ord()}. The argument must be in
|
|
the range [0..255], inclusive; \exception{ValueError} will be raised
|
|
if \var{i} is outside that range.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{classmethod}{function}
|
|
Return a class method for \var{function}.
|
|
|
|
A class method receives the class as implicit first argument,
|
|
just like an instance method receives the instance.
|
|
To declare a class method, use this idiom:
|
|
|
|
\begin{verbatim}
|
|
class C:
|
|
@classmethod
|
|
def f(cls, arg1, arg2, ...): ...
|
|
\end{verbatim}
|
|
|
|
The \code{@classmethod} form is a function decorator -- see the description
|
|
of function definitions in chapter 7 of the
|
|
\citetitle[../ref/ref.html]{Python Reference Manual} for details.
|
|
|
|
It can be called either on the class (such as \code{C.f()}) or on an
|
|
instance (such as \code{C().f()}). The instance is ignored except for
|
|
its class.
|
|
If a class method is called for a derived class, the derived class
|
|
object is passed as the implied first argument.
|
|
|
|
Class methods are different than \Cpp{} or Java static methods.
|
|
If you want those, see \function{staticmethod()} in this section.
|
|
|
|
For more information on class methods, consult the documentation on the
|
|
standard type hierarchy in chapter 3 of the
|
|
\citetitle[../ref/types.html]{Python Reference Manual} (at the bottom).
|
|
\versionadded{2.2}
|
|
\versionchanged[Function decorator syntax added]{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{cmp}{x, y}
|
|
Compare the two objects \var{x} and \var{y} and return an integer
|
|
according to the outcome. The return value is negative if \code{\var{x}
|
|
< \var{y}}, zero if \code{\var{x} == \var{y}} and strictly positive if
|
|
\code{\var{x} > \var{y}}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{compile}{string, filename, kind\optional{,
|
|
flags\optional{, dont_inherit}}}
|
|
Compile the \var{string} into a code object. Code objects can be
|
|
executed by a call to \function{exec()} or evaluated by a call to
|
|
\function{eval()}. The \var{filename} argument should
|
|
give the file from which the code was read; pass some recognizable value
|
|
if it wasn't read from a file (\code{'<string>'} is commonly used).
|
|
The \var{kind} argument specifies what kind of code must be
|
|
compiled; it can be \code{'exec'} if \var{string} consists of a
|
|
sequence of statements, \code{'eval'} if it consists of a single
|
|
expression, or \code{'single'} if it consists of a single
|
|
interactive statement (in the latter case, expression statements
|
|
that evaluate to something else than \code{None} will be printed).
|
|
|
|
When compiling multi-line statements, two caveats apply: line
|
|
endings must be represented by a single newline character
|
|
(\code{'\e n'}), and the input must be terminated by at least one
|
|
newline character. If line endings are represented by
|
|
\code{'\e r\e n'}, use the string \method{replace()} method to
|
|
change them into \code{'\e n'}.
|
|
|
|
The optional arguments \var{flags} and \var{dont_inherit}
|
|
(which are new in Python 2.2) control which future statements (see
|
|
\pep{236}) affect the compilation of \var{string}. If neither is
|
|
present (or both are zero) the code is compiled with those future
|
|
statements that are in effect in the code that is calling compile.
|
|
If the \var{flags} argument is given and \var{dont_inherit} is not
|
|
(or is zero) then the future statements specified by the \var{flags}
|
|
argument are used in addition to those that would be used anyway.
|
|
If \var{dont_inherit} is a non-zero integer then the \var{flags}
|
|
argument is it -- the future statements in effect around the call to
|
|
compile are ignored.
|
|
|
|
Future statements are specified by bits which can be bitwise or-ed
|
|
together to specify multiple statements. The bitfield required to
|
|
specify a given feature can be found as the \member{compiler_flag}
|
|
attribute on the \class{_Feature} instance in the
|
|
\module{__future__} module.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{complex}{\optional{real\optional{, imag}}}
|
|
Create a complex number with the value \var{real} + \var{imag}*j or
|
|
convert a string or number to a complex number. If the first
|
|
parameter is a string, it will be interpreted as a complex number
|
|
and the function must be called without a second parameter. The
|
|
second parameter can never be a string.
|
|
Each argument may be any numeric type (including complex).
|
|
If \var{imag} is omitted, it defaults to zero and the function
|
|
serves as a numeric conversion function like \function{int()},
|
|
\function{long()} and \function{float()}. If both arguments
|
|
are omitted, returns \code{0j}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{delattr}{object, name}
|
|
This is a relative of \function{setattr()}. The arguments are an
|
|
object and a string. The string must be the name
|
|
of one of the object's attributes. The function deletes
|
|
the named attribute, provided the object allows it. For example,
|
|
\code{delattr(\var{x}, '\var{foobar}')} is equivalent to
|
|
\code{del \var{x}.\var{foobar}}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{dict}{\optional{mapping-or-sequence}}
|
|
Return a new dictionary initialized from an optional positional
|
|
argument or from a set of keyword arguments.
|
|
If no arguments are given, return a new empty dictionary.
|
|
If the positional argument is a mapping object, return a dictionary
|
|
mapping the same keys to the same values as does the mapping object.
|
|
Otherwise the positional argument must be a sequence, a container that
|
|
supports iteration, or an iterator object. The elements of the argument
|
|
must each also be of one of those kinds, and each must in turn contain
|
|
exactly two objects. The first is used as a key in the new dictionary,
|
|
and the second as the key's value. If a given key is seen more than
|
|
once, the last value associated with it is retained in the new
|
|
dictionary.
|
|
|
|
If keyword arguments are given, the keywords themselves with their
|
|
associated values are added as items to the dictionary. If a key
|
|
is specified both in the positional argument and as a keyword argument,
|
|
the value associated with the keyword is retained in the dictionary.
|
|
For example, these all return a dictionary equal to
|
|
\code{\{"one": 2, "two": 3\}}:
|
|
|
|
\begin{itemize}
|
|
\item \code{dict(\{'one': 2, 'two': 3\})}
|
|
\item \code{dict(\{'one': 2, 'two': 3\}.items())}
|
|
\item \code{dict(\{'one': 2, 'two': 3\}.iteritems())}
|
|
\item \code{dict(zip(('one', 'two'), (2, 3)))}
|
|
\item \code{dict([['two', 3], ['one', 2]])}
|
|
\item \code{dict(one=2, two=3)}
|
|
\item \code{dict([(['one', 'two'][i-2], i) for i in (2, 3)])}
|
|
\end{itemize}
|
|
|
|
\versionadded{2.2}
|
|
\versionchanged[Support for building a dictionary from keyword
|
|
arguments added]{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{dir}{\optional{object}}
|
|
Without arguments, return the list of names in the current local
|
|
symbol table. With an argument, attempts to return a list of valid
|
|
attributes for that object. This information is gleaned from the
|
|
object's \member{__dict__} attribute, if defined, and from the class
|
|
or type object. The list is not necessarily complete.
|
|
If the object is a module object, the list contains the names of the
|
|
module's attributes.
|
|
If the object is a type or class object,
|
|
the list contains the names of its attributes,
|
|
and recursively of the attributes of its bases.
|
|
Otherwise, the list contains the object's attributes' names,
|
|
the names of its class's attributes,
|
|
and recursively of the attributes of its class's base classes.
|
|
The resulting list is sorted alphabetically.
|
|
For example:
|
|
|
|
\begin{verbatim}
|
|
>>> import struct
|
|
>>> dir()
|
|
['__builtins__', '__doc__', '__name__', 'struct']
|
|
>>> dir(struct)
|
|
['__doc__', '__name__', 'calcsize', 'error', 'pack', 'unpack']
|
|
\end{verbatim}
|
|
|
|
\note{Because \function{dir()} is supplied primarily as a convenience
|
|
for use at an interactive prompt,
|
|
it tries to supply an interesting set of names more than it tries to
|
|
supply a rigorously or consistently defined set of names,
|
|
and its detailed behavior may change across releases.}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{divmod}{a, b}
|
|
Take two (non complex) numbers as arguments and return a pair of numbers
|
|
consisting of their quotient and remainder when using long division. With
|
|
mixed operand types, the rules for binary arithmetic operators apply. For
|
|
plain and long integers, the result is the same as
|
|
\code{(\var{a} // \var{b}, \var{a} \%{} \var{b})}.
|
|
For floating point numbers the result is \code{(\var{q}, \var{a} \%{}
|
|
\var{b})}, where \var{q} is usually \code{math.floor(\var{a} /
|
|
\var{b})} but may be 1 less than that. In any case \code{\var{q} *
|
|
\var{b} + \var{a} \%{} \var{b}} is very close to \var{a}, if
|
|
\code{\var{a} \%{} \var{b}} is non-zero it has the same sign as
|
|
\var{b}, and \code{0 <= abs(\var{a} \%{} \var{b}) < abs(\var{b})}.
|
|
|
|
\versionchanged[Using \function{divmod()} with complex numbers is
|
|
deprecated]{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{enumerate}{iterable}
|
|
Return an enumerate object. \var{iterable} must be a sequence, an
|
|
iterator, or some other object which supports iteration. The
|
|
\method{next()} method of the iterator returned by
|
|
\function{enumerate()} returns a tuple containing a count (from
|
|
zero) and the corresponding value obtained from iterating over
|
|
\var{iterable}. \function{enumerate()} is useful for obtaining an
|
|
indexed series: \code{(0, seq[0])}, \code{(1, seq[1])}, \code{(2,
|
|
seq[2])}, \ldots.
|
|
\versionadded{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{eval}{expression\optional{, globals\optional{, locals}}}
|
|
The arguments are a string and optional globals and locals. If provided,
|
|
\var{globals} must be a dictionary. If provided, \var{locals} can be
|
|
any mapping object. \versionchanged[formerly \var{locals} was required
|
|
to be a dictionary]{2.4}
|
|
|
|
The \var{expression} argument is parsed and evaluated as a Python
|
|
expression (technically speaking, a condition list) using the
|
|
\var{globals} and \var{locals} dictionaries as global and local name
|
|
space. If the \var{globals} dictionary is present and lacks
|
|
'__builtins__', the current globals are copied into \var{globals} before
|
|
\var{expression} is parsed. This means that \var{expression}
|
|
normally has full access to the standard
|
|
\refmodule[builtin]{__builtin__} module and restricted environments
|
|
are propagated. If the \var{locals} dictionary is omitted it defaults to
|
|
the \var{globals} dictionary. If both dictionaries are omitted, the
|
|
expression is executed in the environment where \keyword{eval} is
|
|
called. The return value is the result of the evaluated expression.
|
|
Syntax errors are reported as exceptions. Example:
|
|
|
|
\begin{verbatim}
|
|
>>> x = 1
|
|
>>> print eval('x+1')
|
|
2
|
|
\end{verbatim}
|
|
|
|
This function can also be used to execute arbitrary code objects
|
|
(such as those created by \function{compile()}). In this case pass
|
|
a code object instead of a string. The code object must have been
|
|
compiled passing \code{'eval'} as the \var{kind} argument.
|
|
|
|
Hints: dynamic execution of statements is supported by the
|
|
\function{exec()} function. Execution of statements from a file is
|
|
supported by the \function{execfile()} function. The
|
|
\function{globals()} and \function{locals()} functions returns the
|
|
current global and local dictionary, respectively, which may be
|
|
useful to pass around for use by \function{eval()} or
|
|
\function{execfile()}.
|
|
\end{funcdesc}
|
|
|
|
|
|
\begin{funcdesc}{exec}{object\optional{, globals\optional{, locals}}}
|
|
This function supports dynamic execution of Python code.
|
|
\var{object} must be either a string, an open file object, or
|
|
a code object. If it is a string, the string is parsed as a suite of
|
|
Python statements which is then executed (unless a syntax error
|
|
occurs). If it is an open file, the file is parsed until \EOF{} and
|
|
executed. If it is a code object, it is simply executed. In all
|
|
cases, the code that's executed is expected to be valid as file
|
|
input (see the section ``File input'' in the Reference Manual).
|
|
Be aware that the \keyword{return} and \keyword{yield} statements may
|
|
not be used outside of function definitions even within the context of
|
|
code passed to the \function{exec()} function.
|
|
The return value is \code{None}.
|
|
|
|
In all cases, if the optional parts are omitted, the code is executed
|
|
in the current scope. If only \var{globals} is provided, it must be
|
|
a dictionary, which will be used for both the global and the local
|
|
variables. If \var{globals} and \var{locals} are given, they are used
|
|
for the global and local variables, respectively. If provided,
|
|
\var{locals} can be any mapping object.
|
|
|
|
If the \var{globals} dictionary does not contain a value for the
|
|
key \code{__builtins__}, a reference to the dictionary of the built-in
|
|
module \module{__builtin__} is inserted under that key. That way you
|
|
can control what builtins are available to the executed code by
|
|
inserting your own \code{__builtins__} dictionary into \var{globals}
|
|
before passing it to \function{exec()}.
|
|
|
|
\note{The built-in functions \function{globals()} and \function{locals()}
|
|
return the current global and local dictionary, respectively, which
|
|
may be useful to pass around for use as the second and third
|
|
argument to \function{exec()}.}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{execfile}{filename\optional{, globals\optional{, locals}}}
|
|
This function is similar to the \function{exec()} function, but parses a
|
|
file given by the file name instead of a string. It
|
|
is different from the \keyword{import} statement in that it does not
|
|
use the module administration --- it reads the file unconditionally
|
|
and does not create a new module.
|
|
|
|
The arguments are a file name and two optional dictionaries. The file is
|
|
parsed and evaluated as a sequence of Python statements (similarly to a
|
|
module) using the \var{globals} and \var{locals} dictionaries as global and
|
|
local namespace. If provided, \var{locals} can be any mapping object.
|
|
\versionchanged[formerly \var{locals} was required to be a dictionary]{2.4}
|
|
If the \var{locals} dictionary is omitted it defaults to the \var{globals}
|
|
dictionary. If both dictionaries are omitted, the expression is executed in
|
|
the environment where \function{execfile()} is called. The return value is
|
|
\code{None}.
|
|
|
|
\warning{The default \var{locals} act as described for function
|
|
\function{locals()} below: modifications to the default \var{locals}
|
|
dictionary should not be attempted. Pass an explicit \var{locals}
|
|
dictionary if you need to see effects of the code on \var{locals} after
|
|
function \function{execfile()} returns. \function{execfile()} cannot
|
|
be used reliably to modify a function's locals.}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{file}{filename\optional{, mode\optional{, bufsize}}}
|
|
Constructor function for the \class{file} type, described further
|
|
in section~\ref{bltin-file-objects}, ``\ulink{File
|
|
Objects}{bltin-file-objects.html}''. The constructor's arguments
|
|
are the same as those of the \function{open()} built-in function
|
|
described below.
|
|
|
|
When opening a file, it's preferable to use \function{open()} instead of
|
|
invoking this constructor directly. \class{file} is more suited to
|
|
type testing (for example, writing \samp{isinstance(f, file)}).
|
|
|
|
\versionadded{2.2}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{filter}{function, list}
|
|
Construct a list from those elements of \var{list} for which
|
|
\var{function} returns true. \var{list} may be either a sequence, a
|
|
container which supports iteration, or an iterator, If \var{list}
|
|
is a string or a tuple, the result
|
|
also has that type; otherwise it is always a list. If \var{function} is
|
|
\code{None}, the identity function is assumed, that is, all elements of
|
|
\var{list} that are false are removed.
|
|
|
|
Note that \code{filter(function, \var{list})} is equivalent to
|
|
\code{[item for item in \var{list} if function(item)]} if function is
|
|
not \code{None} and \code{[item for item in \var{list} if item]} if
|
|
function is \code{None}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{float}{\optional{x}}
|
|
Convert a string or a number to floating point. If the argument is a
|
|
string, it must contain a possibly signed decimal or floating point
|
|
number, possibly embedded in whitespace. Otherwise, the argument may be a plain
|
|
or long integer or a floating point number, and a floating point
|
|
number with the same value (within Python's floating point
|
|
precision) is returned. If no argument is given, returns \code{0.0}.
|
|
|
|
\note{When passing in a string, values for NaN\index{NaN}
|
|
and Infinity\index{Infinity} may be returned, depending on the
|
|
underlying C library. The specific set of strings accepted which
|
|
cause these values to be returned depends entirely on the C library
|
|
and is known to vary.}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{frozenset}{\optional{iterable}}
|
|
Return a frozenset object whose elements are taken from \var{iterable}.
|
|
Frozensets are sets that have no update methods but can be hashed and
|
|
used as members of other sets or as dictionary keys. The elements of
|
|
a frozenset must be immutable themselves. To represent sets of sets,
|
|
the inner sets should also be \class{frozenset} objects. If
|
|
\var{iterable} is not specified, returns a new empty set,
|
|
\code{frozenset([])}.
|
|
\versionadded{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{getattr}{object, name\optional{, default}}
|
|
Return the value of the named attributed of \var{object}. \var{name}
|
|
must be a string. If the string is the name of one of the object's
|
|
attributes, the result is the value of that attribute. For example,
|
|
\code{getattr(x, 'foobar')} is equivalent to \code{x.foobar}. If the
|
|
named attribute does not exist, \var{default} is returned if provided,
|
|
otherwise \exception{AttributeError} is raised.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{globals}{}
|
|
Return a dictionary representing the current global symbol table.
|
|
This is always the dictionary of the current module (inside a
|
|
function or method, this is the module where it is defined, not the
|
|
module from which it is called).
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{hasattr}{object, name}
|
|
The arguments are an object and a string. The result is \code{True} if the
|
|
string is the name of one of the object's attributes, \code{False} if not.
|
|
(This is implemented by calling \code{getattr(\var{object},
|
|
\var{name})} and seeing whether it raises an exception or not.)
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{hash}{object}
|
|
Return the hash value of the object (if it has one). Hash values
|
|
are integers. They are used to quickly compare dictionary
|
|
keys during a dictionary lookup. Numeric values that compare equal
|
|
have the same hash value (even if they are of different types, as is
|
|
the case for 1 and 1.0).
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{help}{\optional{object}}
|
|
Invoke the built-in help system. (This function is intended for
|
|
interactive use.) If no argument is given, the interactive help
|
|
system starts on the interpreter console. If the argument is a
|
|
string, then the string is looked up as the name of a module,
|
|
function, class, method, keyword, or documentation topic, and a
|
|
help page is printed on the console. If the argument is any other
|
|
kind of object, a help page on the object is generated.
|
|
\versionadded{2.2}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{hex}{x}
|
|
Convert an integer number (of any size) to a hexadecimal string.
|
|
The result is a valid Python expression.
|
|
\versionchanged[Formerly only returned an unsigned literal]{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{id}{object}
|
|
Return the ``identity'' of an object. This is an integer (or long
|
|
integer) which is guaranteed to be unique and constant for this
|
|
object during its lifetime. Two objects with non-overlapping lifetimes
|
|
may have the same \function{id()} value. (Implementation
|
|
note: this is the address of the object.)
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{int}{\optional{x\optional{, radix}}}
|
|
Convert a string or number to a plain integer. If the argument is a
|
|
string, it must contain a possibly signed decimal number
|
|
representable as a Python integer, possibly embedded in whitespace.
|
|
The \var{radix} parameter gives the base for the
|
|
conversion and may be any integer in the range [2, 36], or zero. If
|
|
\var{radix} is zero, the proper radix is guessed based on the
|
|
contents of string; the interpretation is the same as for integer
|
|
literals. If \var{radix} is specified and \var{x} is not a string,
|
|
\exception{TypeError} is raised.
|
|
Otherwise, the argument may be a plain or
|
|
long integer or a floating point number. Conversion of floating
|
|
point numbers to integers truncates (towards zero).
|
|
If the argument is outside the integer range a long object will
|
|
be returned instead. If no arguments are given, returns \code{0}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{isinstance}{object, classinfo}
|
|
Return true if the \var{object} argument is an instance of the
|
|
\var{classinfo} argument, or of a (direct or indirect) subclass
|
|
thereof. Also return true if \var{classinfo} is a type object and
|
|
\var{object} is an object of that type. If \var{object} is not a
|
|
class instance or an object of the given type, the function always
|
|
returns false. If \var{classinfo} is neither a class object nor a
|
|
type object, it may be a tuple of class or type objects, or may
|
|
recursively contain other such tuples (other sequence types are not
|
|
accepted). If \var{classinfo} is not a class, type, or tuple of
|
|
classes, types, and such tuples, a \exception{TypeError} exception
|
|
is raised.
|
|
\versionchanged[Support for a tuple of type information was added]{2.2}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{issubclass}{class, classinfo}
|
|
Return true if \var{class} is a subclass (direct or indirect) of
|
|
\var{classinfo}. A class is considered a subclass of itself.
|
|
\var{classinfo} may be a tuple of class objects, in which case every
|
|
entry in \var{classinfo} will be checked. In any other case, a
|
|
\exception{TypeError} exception is raised.
|
|
\versionchanged[Support for a tuple of type information was added]{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{iter}{o\optional{, sentinel}}
|
|
Return an iterator object. The first argument is interpreted very
|
|
differently depending on the presence of the second argument.
|
|
Without a second argument, \var{o} must be a collection object which
|
|
supports the iteration protocol (the \method{__iter__()} method), or
|
|
it must support the sequence protocol (the \method{__getitem__()}
|
|
method with integer arguments starting at \code{0}). If it does not
|
|
support either of those protocols, \exception{TypeError} is raised.
|
|
If the second argument, \var{sentinel}, is given, then \var{o} must
|
|
be a callable object. The iterator created in this case will call
|
|
\var{o} with no arguments for each call to its \method{next()}
|
|
method; if the value returned is equal to \var{sentinel},
|
|
\exception{StopIteration} will be raised, otherwise the value will
|
|
be returned.
|
|
\versionadded{2.2}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{len}{s}
|
|
Return the length (the number of items) of an object. The argument
|
|
may be a sequence (string, tuple or list) or a mapping (dictionary).
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{list}{\optional{sequence}}
|
|
Return a list whose items are the same and in the same order as
|
|
\var{sequence}'s items. \var{sequence} may be either a sequence, a
|
|
container that supports iteration, or an iterator object. If
|
|
\var{sequence} is already a list, a copy is made and returned,
|
|
similar to \code{\var{sequence}[:]}. For instance,
|
|
\code{list('abc')} returns \code{['a', 'b', 'c']} and \code{list(
|
|
(1, 2, 3) )} returns \code{[1, 2, 3]}. If no argument is given,
|
|
returns a new empty list, \code{[]}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{locals}{}
|
|
Update and return a dictionary representing the current local symbol table.
|
|
\warning{The contents of this dictionary should not be modified;
|
|
changes may not affect the values of local variables used by the
|
|
interpreter.}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{long}{\optional{x\optional{, radix}}}
|
|
Convert a string or number to a long integer. If the argument is a
|
|
string, it must contain a possibly signed number of
|
|
arbitrary size, possibly embedded in whitespace. The
|
|
\var{radix} argument is interpreted in the same way as for
|
|
\function{int()}, and may only be given when \var{x} is a string.
|
|
Otherwise, the argument may be a plain or
|
|
long integer or a floating point number, and a long integer with
|
|
the same value is returned. Conversion of floating
|
|
point numbers to integers truncates (towards zero). If no arguments
|
|
are given, returns \code{0L}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{map}{function, list, ...}
|
|
Apply \var{function} to every item of \var{list} and return a list
|
|
of the results. If additional \var{list} arguments are passed,
|
|
\var{function} must take that many arguments and is applied to the
|
|
items of all lists in parallel; if a list is shorter than another it
|
|
is assumed to be extended with \code{None} items. If \var{function}
|
|
is \code{None}, the identity function is assumed; if there are
|
|
multiple list arguments, \function{map()} returns a list consisting
|
|
of tuples containing the corresponding items from all lists (a kind
|
|
of transpose operation). The \var{list} arguments may be any kind
|
|
of sequence; the result is always a list.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{max}{s\optional{, args...}\optional{key}}
|
|
With a single argument \var{s}, return the largest item of a
|
|
non-empty sequence (such as a string, tuple or list). With more
|
|
than one argument, return the largest of the arguments.
|
|
|
|
The optional \var{key} argument specifies a one-argument ordering
|
|
function like that used for \method{list.sort()}. The \var{key}
|
|
argument, if supplied, must be in keyword form (for example,
|
|
\samp{max(a,b,c,key=func)}).
|
|
\versionchanged[Added support for the optional \var{key} argument]{2.5}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{min}{s\optional{, args...}\optional{key}}
|
|
With a single argument \var{s}, return the smallest item of a
|
|
non-empty sequence (such as a string, tuple or list). With more
|
|
than one argument, return the smallest of the arguments.
|
|
|
|
The optional \var{key} argument specifies a one-argument ordering
|
|
function like that used for \method{list.sort()}. The \var{key}
|
|
argument, if supplied, must be in keyword form (for example,
|
|
\samp{min(a,b,c,key=func)}).
|
|
\versionchanged[Added support for the optional \var{key} argument]{2.5}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{object}{}
|
|
Return a new featureless object. \class{object} is a base
|
|
for all new style classes. It has the methods that are common
|
|
to all instances of new style classes.
|
|
\versionadded{2.2}
|
|
|
|
\versionchanged[This function does not accept any arguments.
|
|
Formerly, it accepted arguments but ignored them]{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{oct}{x}
|
|
Convert an integer number (of any size) to an octal string. The
|
|
result is a valid Python expression.
|
|
\versionchanged[Formerly only returned an unsigned literal]{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{open}{filename\optional{, mode\optional{, bufsize}}}
|
|
Open a file, returning an object of the \class{file} type described
|
|
in section~\ref{bltin-file-objects}, ``\ulink{File
|
|
Objects}{bltin-file-objects.html}''. If the file cannot be opened,
|
|
\exception{IOError} is raised. When opening a file, it's
|
|
preferable to use \function{open()} instead of invoking the
|
|
\class{file} constructor directly.
|
|
|
|
The first two arguments are the same as for \code{stdio}'s
|
|
\cfunction{fopen()}: \var{filename} is the file name to be opened,
|
|
and \var{mode} is a string indicating how the file is to be opened.
|
|
|
|
The most commonly-used values of \var{mode} are \code{'r'} for
|
|
reading, \code{'w'} for writing (truncating the file if it already
|
|
exists), and \code{'a'} for appending (which on \emph{some} \UNIX{}
|
|
systems means that \emph{all} writes append to the end of the file
|
|
regardless of the current seek position). If \var{mode} is omitted,
|
|
it defaults to \code{'r'}. When opening a binary file, you should
|
|
append \code{'b'} to the \var{mode} value to open the file in binary
|
|
mode, which will improve portability. (Appending \code{'b'} is
|
|
useful even on systems that don't treat binary and text files
|
|
differently, where it serves as documentation.) See below for more
|
|
possible values of \var{mode}.
|
|
|
|
\index{line-buffered I/O}\index{unbuffered I/O}\index{buffer size, I/O}
|
|
\index{I/O control!buffering}
|
|
The optional \var{bufsize} argument specifies the
|
|
file's desired buffer size: 0 means unbuffered, 1 means line
|
|
buffered, any other positive value means use a buffer of
|
|
(approximately) that size. A negative \var{bufsize} means to use
|
|
the system default, which is usually line buffered for tty
|
|
devices and fully buffered for other files. If omitted, the system
|
|
default is used.\footnote{
|
|
Specifying a buffer size currently has no effect on systems that
|
|
don't have \cfunction{setvbuf()}. The interface to specify the
|
|
buffer size is not done using a method that calls
|
|
\cfunction{setvbuf()}, because that may dump core when called
|
|
after any I/O has been performed, and there's no reliable way to
|
|
determine whether this is the case.}
|
|
|
|
Modes \code{'r+'}, \code{'w+'} and \code{'a+'} open the file for
|
|
updating (note that \code{'w+'} truncates the file). Append
|
|
\code{'b'} to the mode to open the file in binary mode, on systems
|
|
that differentiate between binary and text files; on systems
|
|
that don't have this distinction, adding the \code{'b'} has no effect.
|
|
|
|
In addition to the standard \cfunction{fopen()} values \var{mode}
|
|
may be \code{'U'} or \code{'rU'}. Python is usually built with universal
|
|
newline support; supplying \code{'U'} opens the file as a text file, but
|
|
lines may be terminated by any of the following: the \UNIX{} end-of-line
|
|
convention \code{'\e n'},
|
|
the Macintosh convention \code{'\e r'}, or the Windows
|
|
convention \code{'\e r\e n'}. All of these external representations are seen as
|
|
\code{'\e n'}
|
|
by the Python program. If Python is built without universal newline support
|
|
a \var{mode} with \code{'U'} is the same as normal text mode. Note that
|
|
file objects so opened also have an attribute called
|
|
\member{newlines} which has a value of \code{None} (if no newlines
|
|
have yet been seen), \code{'\e n'}, \code{'\e r'}, \code{'\e r\e n'},
|
|
or a tuple containing all the newline types seen.
|
|
|
|
Python enforces that the mode, after stripping \code{'U'}, begins with
|
|
\code{'r'}, \code{'w'} or \code{'a'}.
|
|
|
|
\versionchanged[Restriction on first letter of mode string
|
|
introduced]{2.5}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{ord}{c}
|
|
Given a string of length one, return an integer representing the
|
|
Unicode code point of the character when the argument is a unicode object,
|
|
or the value of the byte when the argument is an 8-bit string.
|
|
For example, \code{ord('a')} returns the integer \code{97},
|
|
\code{ord(u'\e u2020')} returns \code{8224}. This is the inverse of
|
|
\function{chr()} for 8-bit strings and of \function{unichr()} for unicode
|
|
objects. If a unicode argument is given and Python was built with
|
|
UCS2 Unicode, then the character's code point must be in the range
|
|
[0..65535] inclusive; otherwise the string length is two, and a
|
|
\exception{TypeError} will be raised.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{pow}{x, y\optional{, z}}
|
|
Return \var{x} to the power \var{y}; if \var{z} is present, return
|
|
\var{x} to the power \var{y}, modulo \var{z} (computed more
|
|
efficiently than \code{pow(\var{x}, \var{y}) \%\ \var{z}}).
|
|
The two-argument form \code{pow(\var{x}, \var{y})} is equivalent to using
|
|
the power operator: \code{\var{x}**\var{y}}.
|
|
|
|
The arguments must have numeric types. 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.)
|
|
If the second argument is negative, the third argument must be omitted.
|
|
If \var{z} is present, \var{x} and \var{y} must be of integer types,
|
|
and \var{y} must be non-negative. (This restriction was added in
|
|
Python 2.2. In Python 2.1 and before, floating 3-argument \code{pow()}
|
|
returned platform-dependent results depending on floating-point
|
|
rounding accidents.)
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{property}{\optional{fget\optional{, fset\optional{,
|
|
fdel\optional{, doc}}}}}
|
|
Return a property attribute for new-style classes (classes that
|
|
derive from \class{object}).
|
|
|
|
\var{fget} is a function for getting an attribute value, likewise
|
|
\var{fset} is a function for setting, and \var{fdel} a function
|
|
for del'ing, an attribute. Typical use is to define a managed attribute x:
|
|
|
|
\begin{verbatim}
|
|
class C(object):
|
|
def __init__(self): self._x = None
|
|
def getx(self): return self._x
|
|
def setx(self, value): self._x = value
|
|
def delx(self): del self._x
|
|
x = property(getx, setx, delx, "I'm the 'x' property.")
|
|
\end{verbatim}
|
|
|
|
If given, \var{doc} will be the docstring of the property attribute.
|
|
Otherwise, the property will copy \var{fget}'s docstring (if it
|
|
exists). This makes it possible to create read-only properties
|
|
easily using \function{property()} as a decorator:
|
|
|
|
\begin{verbatim}
|
|
class Parrot(object):
|
|
def __init__(self):
|
|
self._voltage = 100000
|
|
|
|
@property
|
|
def voltage(self):
|
|
"""Get the current voltage."""
|
|
return self._voltage
|
|
\end{verbatim}
|
|
|
|
turns the \method{voltage()} method into a ``getter'' for a read-only
|
|
attribute with the same name.
|
|
|
|
\versionadded{2.2}
|
|
\versionchanged[Use \var{fget}'s docstring if no \var{doc} given]{2.5}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{range}{\optional{start,} stop\optional{, step}}
|
|
This is a versatile function to create lists containing arithmetic
|
|
progressions. It is most often used in \keyword{for} loops. The
|
|
arguments must be plain integers. If the \var{step} argument is
|
|
omitted, it defaults to \code{1}. If the \var{start} argument is
|
|
omitted, it defaults to \code{0}. The full form returns a list of
|
|
plain integers \code{[\var{start}, \var{start} + \var{step},
|
|
\var{start} + 2 * \var{step}, \ldots]}. If \var{step} is positive,
|
|
the last element is the largest \code{\var{start} + \var{i} *
|
|
\var{step}} less than \var{stop}; if \var{step} is negative, the last
|
|
element is the smallest \code{\var{start} + \var{i} * \var{step}}
|
|
greater than \var{stop}. \var{step} must not be zero (or else
|
|
\exception{ValueError} is raised). Example:
|
|
|
|
\begin{verbatim}
|
|
>>> range(10)
|
|
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
|
|
>>> range(1, 11)
|
|
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
|
|
>>> range(0, 30, 5)
|
|
[0, 5, 10, 15, 20, 25]
|
|
>>> range(0, 10, 3)
|
|
[0, 3, 6, 9]
|
|
>>> range(0, -10, -1)
|
|
[0, -1, -2, -3, -4, -5, -6, -7, -8, -9]
|
|
>>> range(0)
|
|
[]
|
|
>>> range(1, 0)
|
|
[]
|
|
\end{verbatim}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{reload}{module}
|
|
Reload a previously imported \var{module}. The
|
|
argument must be a module object, so it must have been successfully
|
|
imported before. This is useful if you have edited the module
|
|
source file using an external editor and want to try out the new
|
|
version without leaving the Python interpreter. The return value is
|
|
the module object (the same as the \var{module} argument).
|
|
|
|
When \code{reload(module)} is executed:
|
|
|
|
\begin{itemize}
|
|
|
|
\item Python modules' code is recompiled and the module-level code
|
|
reexecuted, defining a new set of objects which are bound to names in
|
|
the module's dictionary. The \code{init} function of extension
|
|
modules is not called a second time.
|
|
|
|
\item As with all other objects in Python the old objects are only
|
|
reclaimed after their reference counts drop to zero.
|
|
|
|
\item The names in the module namespace are updated to point to
|
|
any new or changed objects.
|
|
|
|
\item Other references to the old objects (such as names external
|
|
to the module) are not rebound to refer to the new objects and
|
|
must be updated in each namespace where they occur if that is
|
|
desired.
|
|
|
|
\end{itemize}
|
|
|
|
There are a number of other caveats:
|
|
|
|
If a module is syntactically correct but its initialization fails,
|
|
the first \keyword{import} statement for it does not bind its name
|
|
locally, but does store a (partially initialized) module object in
|
|
\code{sys.modules}. To reload the module you must first
|
|
\keyword{import} it again (this will bind the name to the partially
|
|
initialized module object) before you can \function{reload()} it.
|
|
|
|
When a module is reloaded, its dictionary (containing the module's
|
|
global variables) is retained. Redefinitions of names will override
|
|
the old definitions, so this is generally not a problem. If the new
|
|
version of a module does not define a name that was defined by the
|
|
old version, the old definition remains. This feature can be used
|
|
to the module's advantage if it maintains a global table or cache of
|
|
objects --- with a \keyword{try} statement it can test for the
|
|
table's presence and skip its initialization if desired:
|
|
|
|
\begin{verbatim}
|
|
try:
|
|
cache
|
|
except NameError:
|
|
cache = {}
|
|
\end{verbatim}
|
|
|
|
|
|
It is legal though generally not very useful to reload built-in or
|
|
dynamically loaded modules, except for \refmodule{sys},
|
|
\refmodule[main]{__main__} and \refmodule[builtin]{__builtin__}. In
|
|
many cases, however, extension modules are not designed to be
|
|
initialized more than once, and may fail in arbitrary ways when
|
|
reloaded.
|
|
|
|
If a module imports objects from another module using \keyword{from}
|
|
\ldots{} \keyword{import} \ldots{}, calling \function{reload()} for
|
|
the other module does not redefine the objects imported from it ---
|
|
one way around this is to re-execute the \keyword{from} statement,
|
|
another is to use \keyword{import} and qualified names
|
|
(\var{module}.\var{name}) instead.
|
|
|
|
If a module instantiates instances of a class, reloading the module
|
|
that defines the class does not affect the method definitions of the
|
|
instances --- they continue to use the old class definition. The
|
|
same is true for derived classes.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{repr}{object}
|
|
Return a string containing a printable representation of an object.
|
|
This is the same value yielded by conversions (reverse quotes).
|
|
It is sometimes useful to be able to access this operation as an
|
|
ordinary function. For many types, this function makes an attempt
|
|
to return a string that would yield an object with the same value
|
|
when passed to \function{eval()}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{reversed}{seq}
|
|
Return a reverse iterator. \var{seq} must be an object which
|
|
supports the sequence protocol (the __len__() method and the
|
|
\method{__getitem__()} method with integer arguments starting at
|
|
\code{0}).
|
|
\versionadded{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{round}{x\optional{, n}}
|
|
Return the floating point value \var{x} rounded to \var{n} digits
|
|
after the decimal point. If \var{n} is omitted, it defaults to zero.
|
|
The result is a floating point number. Values are rounded to the
|
|
closest multiple of 10 to the power minus \var{n}; if two multiples
|
|
are equally close, rounding is done away from 0 (so. for example,
|
|
\code{round(0.5)} is \code{1.0} and \code{round(-0.5)} is \code{-1.0}).
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{set}{\optional{iterable}}
|
|
Return a set whose elements are taken from \var{iterable}. The elements
|
|
must be immutable. To represent sets of sets, the inner sets should
|
|
be \class{frozenset} objects. If \var{iterable} is not specified,
|
|
returns a new empty set, \code{set([])}.
|
|
\versionadded{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{setattr}{object, name, value}
|
|
This is the counterpart of \function{getattr()}. The arguments are an
|
|
object, a string and an arbitrary value. The string may name an
|
|
existing attribute or a new attribute. The function assigns the
|
|
value to the attribute, provided the object allows it. For example,
|
|
\code{setattr(\var{x}, '\var{foobar}', 123)} is equivalent to
|
|
\code{\var{x}.\var{foobar} = 123}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{slice}{\optional{start,} stop\optional{, step}}
|
|
Return a slice object representing the set of indices specified by
|
|
\code{range(\var{start}, \var{stop}, \var{step})}. The \var{start}
|
|
and \var{step} arguments default to \code{None}. Slice objects have
|
|
read-only data attributes \member{start}, \member{stop} and
|
|
\member{step} which merely return the argument values (or their
|
|
default). They have no other explicit functionality; however they
|
|
are used by Numerical Python\index{Numerical Python} and other third
|
|
party extensions. Slice objects are also generated when extended
|
|
indexing syntax is used. For example: \samp{a[start:stop:step]} or
|
|
\samp{a[start:stop, i]}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{sorted}{iterable\optional{, cmp\optional{,
|
|
key\optional{, reverse}}}}
|
|
Return a new sorted list from the items in \var{iterable}.
|
|
|
|
The optional arguments \var{cmp}, \var{key}, and \var{reverse} have
|
|
the same meaning as those for the \method{list.sort()} method
|
|
(described in section~\ref{typesseq-mutable}).
|
|
|
|
\var{cmp} specifies a custom comparison function of two arguments
|
|
(iterable elements) which should return a negative, zero or positive
|
|
number depending on whether the first argument is considered smaller
|
|
than, equal to, or larger than the second argument:
|
|
\samp{\var{cmp}=\keyword{lambda} \var{x},\var{y}:
|
|
\function{cmp}(x.lower(), y.lower())}
|
|
|
|
\var{key} specifies a function of one argument that is used to
|
|
extract a comparison key from each list element:
|
|
\samp{\var{key}=\function{str.lower}}
|
|
|
|
\var{reverse} is a boolean value. If set to \code{True}, then the
|
|
list elements are sorted as if each comparison were reversed.
|
|
|
|
In general, the \var{key} and \var{reverse} conversion processes are
|
|
much faster than specifying an equivalent \var{cmp} function. This is
|
|
because \var{cmp} is called multiple times for each list element while
|
|
\var{key} and \var{reverse} touch each element only once.
|
|
|
|
\versionadded{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{staticmethod}{function}
|
|
Return a static method for \var{function}.
|
|
|
|
A static method does not receive an implicit first argument.
|
|
To declare a static method, use this idiom:
|
|
|
|
\begin{verbatim}
|
|
class C:
|
|
@staticmethod
|
|
def f(arg1, arg2, ...): ...
|
|
\end{verbatim}
|
|
|
|
The \code{@staticmethod} form is a function decorator -- see the description
|
|
of function definitions in chapter 7 of the
|
|
\citetitle[../ref/function.html]{Python Reference Manual} for details.
|
|
|
|
It can be called either on the class (such as \code{C.f()}) or on an
|
|
instance (such as \code{C().f()}). The instance is ignored except
|
|
for its class.
|
|
|
|
Static methods in Python are similar to those found in Java or \Cpp.
|
|
For a more advanced concept, see \function{classmethod()} in this
|
|
section.
|
|
|
|
For more information on static methods, consult the documentation on the
|
|
standard type hierarchy in chapter 3 of the
|
|
\citetitle[../ref/types.html]{Python Reference Manual} (at the bottom).
|
|
\versionadded{2.2}
|
|
\versionchanged[Function decorator syntax added]{2.4}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{str}{\optional{object}}
|
|
Return a string containing a nicely printable representation of an
|
|
object. For strings, this returns the string itself. The
|
|
difference with \code{repr(\var{object})} is that
|
|
\code{str(\var{object})} does not always attempt to return a string
|
|
that is acceptable to \function{eval()}; its goal is to return a
|
|
printable string. If no argument is given, returns the empty
|
|
string, \code{''}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{sum}{sequence\optional{, start}}
|
|
Sums \var{start} and the items of a \var{sequence}, from left to
|
|
right, and returns the total. \var{start} defaults to \code{0}.
|
|
The \var{sequence}'s items are normally numbers, and are not allowed
|
|
to be strings. The fast, correct way to concatenate sequence of
|
|
strings is by calling \code{''.join(\var{sequence})}.
|
|
\versionadded{2.3}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{super}{type\optional{, object-or-type}}
|
|
Return the superclass of \var{type}. If the second argument is omitted
|
|
the super object returned is unbound. If the second argument is an
|
|
object, \code{isinstance(\var{obj}, \var{type})} must be true. If
|
|
the second argument is a type, \code{issubclass(\var{type2},
|
|
\var{type})} must be true.
|
|
\function{super()} only works for new-style classes.
|
|
|
|
A typical use for calling a cooperative superclass method is:
|
|
\begin{verbatim}
|
|
class C(B):
|
|
def meth(self, arg):
|
|
super(C, self).meth(arg)
|
|
\end{verbatim}
|
|
|
|
Note that \function{super} is implemented as part of the binding process for
|
|
explicit dotted attribute lookups such as
|
|
\samp{super(C, self).__getitem__(name)}. Accordingly, \function{super} is
|
|
undefined for implicit lookups using statements or operators such as
|
|
\samp{super(C, self)[name]}.
|
|
\versionadded{2.2}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{tuple}{\optional{sequence}}
|
|
Return a tuple whose items are the same and in the same order as
|
|
\var{sequence}'s items. \var{sequence} may be a sequence, a
|
|
container that supports iteration, or an iterator object.
|
|
If \var{sequence} is already a tuple, it
|
|
is returned unchanged. For instance, \code{tuple('abc')} returns
|
|
\code{('a', 'b', 'c')} and \code{tuple([1, 2, 3])} returns
|
|
\code{(1, 2, 3)}. If no argument is given, returns a new empty
|
|
tuple, \code{()}.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{type}{object}
|
|
Return the type of an \var{object}. The return value is a
|
|
type\obindex{type} object. The \function{isinstance()} built-in
|
|
function is recommended for testing the type of an object.
|
|
|
|
With three arguments, \function{type} functions as a constructor
|
|
as detailed below.
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{type}{name, bases, dict}
|
|
Return a new type object. This is essentially a dynamic form of the
|
|
\keyword{class} statement. The \var{name} string is the class name
|
|
and becomes the \member{__name__} attribute; the \var{bases} tuple
|
|
itemizes the base classes and becomes the \member{__bases__}
|
|
attribute; and the \var{dict} dictionary is the namespace containing
|
|
definitions for class body and becomes the \member{__dict__}
|
|
attribute. For example, the following two statements create
|
|
identical \class{type} objects:
|
|
|
|
\begin{verbatim}
|
|
>>> class X(object):
|
|
... a = 1
|
|
...
|
|
>>> X = type('X', (object,), dict(a=1))
|
|
\end{verbatim}
|
|
\versionadded{2.2}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{unichr}{i}
|
|
Return the Unicode string of one character whose Unicode code is the
|
|
integer \var{i}. For example, \code{unichr(97)} returns the string
|
|
\code{u'a'}. This is the inverse of \function{ord()} for Unicode
|
|
strings. The valid range for the argument depends how Python was
|
|
configured -- it may be either UCS2 [0..0xFFFF] or UCS4 [0..0x10FFFF].
|
|
\exception{ValueError} is raised otherwise.
|
|
\versionadded{2.0}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{unicode}{\optional{object\optional{, encoding
|
|
\optional{, errors}}}}
|
|
Return the Unicode string version of \var{object} using one of the
|
|
following modes:
|
|
|
|
If \var{encoding} and/or \var{errors} are given, \code{unicode()}
|
|
will decode the object which can either be an 8-bit string or a
|
|
character buffer using the codec for \var{encoding}. The
|
|
\var{encoding} parameter is a string giving the name of an encoding;
|
|
if the encoding is not known, \exception{LookupError} is raised.
|
|
Error handling is done according to \var{errors}; this specifies the
|
|
treatment of characters which are invalid in the input encoding. If
|
|
\var{errors} is \code{'strict'} (the default), a
|
|
\exception{ValueError} is raised on errors, while a value of
|
|
\code{'ignore'} causes errors to be silently ignored, and a value of
|
|
\code{'replace'} causes the official Unicode replacement character,
|
|
\code{U+FFFD}, to be used to replace input characters which cannot
|
|
be decoded. See also the \refmodule{codecs} module.
|
|
|
|
If no optional parameters are given, \code{unicode()} will mimic the
|
|
behaviour of \code{str()} except that it returns Unicode strings
|
|
instead of 8-bit strings. More precisely, if \var{object} is a
|
|
Unicode string or subclass it will return that Unicode string without
|
|
any additional decoding applied.
|
|
|
|
For objects which provide a \method{__unicode__()} method, it will
|
|
call this method without arguments to create a Unicode string. For
|
|
all other objects, the 8-bit string version or representation is
|
|
requested and then converted to a Unicode string using the codec for
|
|
the default encoding in \code{'strict'} mode.
|
|
|
|
\versionadded{2.0}
|
|
\versionchanged[Support for \method{__unicode__()} added]{2.2}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{vars}{\optional{object}}
|
|
Without arguments, return a dictionary corresponding to the current
|
|
local symbol table. With a module, class or class instance object
|
|
as argument (or anything else that has a \member{__dict__}
|
|
attribute), returns a dictionary corresponding to the object's
|
|
symbol table. The returned dictionary should not be modified: the
|
|
effects on the corresponding symbol table are undefined.\footnote{
|
|
In the current implementation, local variable bindings cannot
|
|
normally be affected this way, but variables retrieved from
|
|
other scopes (such as modules) can be. This may change.}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{xrange}{\optional{start,} stop\optional{, step}}
|
|
This function is very similar to \function{range()}, but returns an
|
|
``xrange object'' instead of a list. This is an opaque sequence
|
|
type which yields the same values as the corresponding list, without
|
|
actually storing them all simultaneously. The advantage of
|
|
\function{xrange()} over \function{range()} is minimal (since
|
|
\function{xrange()} still has to create the values when asked for
|
|
them) except when a very large range is used on a memory-starved
|
|
machine or when all of the range's elements are never used (such as
|
|
when the loop is usually terminated with \keyword{break}).
|
|
|
|
\note{\function{xrange()} is intended to be simple and fast.
|
|
Implementations may impose restrictions to achieve this.
|
|
The C implementation of Python restricts all arguments to
|
|
native C longs ("short" Python integers), and also requires
|
|
that the number of elements fit in a native C long.}
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{zip}{\optional{iterable, \moreargs}}
|
|
This function returns a list of tuples, where the \var{i}-th tuple contains
|
|
the \var{i}-th element from each of the argument sequences or iterables.
|
|
The returned list is truncated in length to the length of
|
|
the shortest argument sequence. When there are multiple arguments
|
|
which are all of the same length, \function{zip()} is
|
|
similar to \function{map()} with an initial argument of \code{None}.
|
|
With a single sequence argument, it returns a list of 1-tuples.
|
|
With no arguments, it returns an empty list.
|
|
\versionadded{2.0}
|
|
|
|
\versionchanged[Formerly, \function{zip()} required at least one argument
|
|
and \code{zip()} raised a \exception{TypeError} instead of returning
|
|
an empty list]{2.4}
|
|
\end{funcdesc}
|
|
|
|
|
|
% ---------------------------------------------------------------------------
|
|
|
|
|
|
\section{Non-essential Built-in Functions \label{non-essential-built-in-funcs}}
|
|
|
|
There are several built-in functions that are no longer essential to learn,
|
|
know or use in modern Python programming. They have been kept here to
|
|
maintain backwards compatibility with programs written for older versions
|
|
of Python.
|
|
|
|
Python programmers, trainers, students and bookwriters should feel free to
|
|
bypass these functions without concerns about missing something important.
|
|
|
|
|
|
\setindexsubitem{(non-essential built-in functions)}
|
|
|
|
\begin{funcdesc}{buffer}{object\optional{, offset\optional{, size}}}
|
|
The \var{object} argument must be an object that supports the buffer
|
|
call interface (such as strings, arrays, and buffers). A new buffer
|
|
object will be created which references the \var{object} argument.
|
|
The buffer object will be a slice from the beginning of \var{object}
|
|
(or from the specified \var{offset}). The slice will extend to the
|
|
end of \var{object} (or will have a length given by the \var{size}
|
|
argument).
|
|
\end{funcdesc}
|
|
|
|
\begin{funcdesc}{intern}{string}
|
|
Enter \var{string} in the table of ``interned'' strings and return
|
|
the interned string -- which is \var{string} itself or a copy.
|
|
Interning strings is useful to gain a little performance on
|
|
dictionary lookup -- if the keys in a dictionary are interned, and
|
|
the lookup key is interned, the key comparisons (after hashing) can
|
|
be done by a pointer compare instead of a string compare. Normally,
|
|
the names used in Python programs are automatically interned, and
|
|
the dictionaries used to hold module, class or instance attributes
|
|
have interned keys. \versionchanged[Interned strings are not
|
|
immortal (like they used to be in Python 2.2 and before);
|
|
you must keep a reference to the return value of \function{intern()}
|
|
around to benefit from it]{2.3}
|
|
\end{funcdesc}
|