Added news on recent changes to logging
[python.git] / Misc / NEWS
blobf166f712682df51c6f6f111576575cbc9b021b31
1 +++++++++++
2 Python News
3 +++++++++++
5 (editors: check NEWS.help for information about editing NEWS using ReST.)
7 What's New in Python 2.6 alpha 1?
8 =================================
10 *Release date: XX-XXX-200X*
12 Core and builtins
13 -----------------
15 - Patch #1586791: Better exception messages for some operations on strings,
16   tuples and lists.
18 - Bug #1067760: Deprecate passing floats to file.seek.
20 - Bug #1591996: Correctly forward exception in instance_contains().
22 - Bug #1588287: fix invalid assertion for `1,2` in debug builds.
24 - Bug #1576657: when setting a KeyError for a tuple key, make sure that
25   the tuple isn't used as the "exception arguments tuple".
27 - Bug #1565514, SystemError not raised on too many nested blocks.
29 - Bug #1576174: WindowsError now displays the windows error code
30   again, no longer the posix error code.
32 - Patch #1549049: Support long values in structmember, issue warnings
33   if the assigned value for structmember fields gets truncated.
35 - Update the peephole optimizer to remove more dead code (jumps after returns)
36   and inline unconditional jumps to returns.
38 - Bug #1545497: when given an explicit base, int() did ignore NULs
39   embedded in the string to convert.
41 - Bug #1569998: break inside a try statement (outside a loop) is now
42   recognized and rejected.
44 - list.pop(x) accepts any object x following the __index__ protocol.
46 - Fix some leftovers from the conversion from int to Py_ssize_t
47   (relevant to strings and sequences of more than 2**31 items).
49 - A number of places, including integer negation and absolute value,
50   were fixed to not rely on undefined behaviour of the C compiler
51   anymore.
53 - Bug #1566800: make sure that EnvironmentError can be called with any
54   number of arguments, as was the case in Python 2.4.
56 - Patch #1567691: super() and new.instancemethod() now don't accept
57   keyword arguments any more (previously they accepted them, but didn't
58   use them).
60 - Fix a bug in the parser's future statement handling that led to "with"
61   not being recognized as a keyword after, e.g., this statement:
62   from __future__ import division, with_statement
64 - Bug #1557232: fix seg fault with def f((((x)))) and def f(((x),)).
66 - Fix %zd string formatting on Mac OS X so it prints negative numbers.
68 - Allow exception instances to be directly sliced again.
70 - Bug #1551432: Exceptions do not define an explicit __unicode__ method.  This
71   allows calling unicode() on exceptions classes directly to succeed.
73 - Make _PyGILState_NoteThreadState() static, it was not used anywhere
74   outside of pystate.c and should not be necessary.
76 - Bug #1542051: Exceptions now correctly call PyObject_GC_UnTrack.
77   Also make sure that every exception class has __module__ set to
78   'exceptions'.
80 - Bug #1550983: emit better error messages for erroneous relative
81   imports (if not in package and if beyond toplevel package).
83 - Overflow checking code in integer division ran afoul of new gcc
84   optimizations.  Changed to be more standard-conforming.
86 - Patch #1542451: disallow continue anywhere under a finally.
88 - Patch #1546288: fix seg fault in dict_equal due to ref counting bug.
90 - The return tuple from str.rpartition(sep) is (tail, sep, head) where
91   head is the original string if sep was not found.
93 - Bug #1520864: unpacking singleton tuples in list comprehensions and
94   generator expressions (x for x, in ... ) works again.  Fixing this problem
95   required changing the .pyc magic number.  This means that .pyc files
96   generated before 2.5c2 will be regenerated.
98 - with and as are now keywords.
101 Library
102 -------
104 - Bug #1503765: Fix a problem in logging.config with spaces in comma-
105   separated lists read from logging config files.
107 - Patch #1604907: Fix problems in logging.handlers caused at logging shutdown
108   when syslog handlers fail to initialize because of syslogd problems.
110 - Patch #1608267: fix a race condition in os.makedirs() is the directory
111   to be created is already there.
113 - Patch #1610437: fix a tarfile bug with long filename headers.
115 - Patch #1371075: Make ConfigParser accept optional dict type
116   for ordering, sorting, etc.
118 - Bug #1563807: _ctypes built on AIX fails with ld ffi error.
120 - Bug #1598620: A ctypes Structure cannot contain itself.
122 - Patch #1070046: Marshal new-style objects like InstanceType
123   in xmlrpclib.
125 - cStringIO.truncate(-1) now raises an IOError, like StringIO and
126   regular files.
128 - Patch #1472877: Fix Tix subwidget name resolution.
130 - Patch #1594554: Always close a tkSimpleDialog on ok(), even
131   if an exception occurs.
133 - Patch #1538878: Don't make tkSimpleDialog dialogs transient if
134   the parent window is withdrawn.
136 - Bug #1597824: return the registered function from atexit.register()
137   to facilitate usage as a decorator.
139 - Patch #1360200: Use unmangled_version RPM spec field to deal with
140   file name mangling.
142 - Patch #1359217: Process 2xx response in an ftplib transfer
143   that precedes an 1xx response.
145 - Patch #1355023: support whence argument for GzipFile.seek.
147 - Patch #1065257: Support passing open files as body in
148   HTTPConnection.request().
150 - Bug #1569790: mailbox.py: Maildir.get_folder() and MH.get_folder()
151   weren't passing the message factory on to newly created Maildir/MH
152   objects.
154 - Patch #1514543: mailbox.py: In the Maildir class, report errors if there's
155   a filename clash instead of possibly losing a message.  (Patch by David
156   Watson.)
158 - Patch #1514544: Try to ensure that messages/indexes have been physically
159   written to disk after calling .flush() or .close(). (Patch by David
160   Watson.)
162 - Patch #1592250: Add elidge argument to Tkinter.Text.search.
164 - Patch #838546: Make terminal become controlling in pty.fork()
166 - Patch #1351744: Add askyesnocancel helper for tkMessageBox.
168 - Patch #1060577: Extract list of RPM files from spec file in
169   bdist_rpm
171 - Bug #1586613: fix zlib and bz2 codecs' incremental en/decoders.
173 - Patch #1583880: fix tarfile's problems with long names and posix/
174   GNU modes.
176 - Bug #1586448: the compiler module now emits the same bytecode for
177   list comprehensions as the builtin compiler, using the LIST_APPEND
178   opcode.
180 - Fix codecs.EncodedFile which did not use file_encoding in 2.5.0, and
181   fix all codecs file wrappers to work correctly with the "with"
182   statement (bug #1586513).
184 - Lib/modulefinder.py now handles absolute and relative imports
185   correctly.
187 - Patch #1567274: Support SMTP over TLS.
189 - Patch #1560695: Add .note.GNU-stack to ctypes' sysv.S so that
190   ctypes isn't considered as requiring executable stacks.
192 - ctypes callback functions only support 'fundamental' data types as
193   result type.  Raise an error when something else is used.  This is a
194   partial fix for Bug #1574584.
196 - Fix turtle so that time.sleep is imported for the entire library.  Allows
197   the demo2 function to be executed on its own instead of only when the
198   module is run as a script.
200 - Bug #813342: Start the IDLE subprocess with -Qnew if the parent
201   is started with that option.
203 - Bug #1565150: Fix subsecond processing for os.utime on Windows.
205 - Support for MSVC 8 was added to bdist_wininst.
207 - Bug #1446043: correctly raise a LookupError if an encoding name given
208   to encodings.search_function() contains a dot.
210 - Bug #1560617: in pyclbr, return full module name not only for classes,
211   but also for functions.
213 - Bug #1457823: cgi.(Sv)FormContentDict's constructor now takes
214   keep_blank_values and strict_parsing keyword arguments.
216 - Bug #1566602: correct failure of posixpath unittest when $HOME ends
217   with a slash.
219 - Bug #1565661: in webbrowser, split() the command for the default
220   GNOME browser in case it is a command with args.
222 - Made the error message for time.strptime when the data data and format do
223   match be more clear.
225 - Fix a bug in traceback.format_exception_only() that led to an error
226   being raised when print_exc() was called without an exception set.
227   In version 2.4, this printed "None", restored that behavior.
229 - Make webbrowser.BackgroundBrowser usable in Windows (it wasn't because
230   the close_fds arg to subprocess.Popen is not supported).
232 - Reverted patch #1504333 to sgmllib because it introduced an infinite loop.
234 - Patch #1553314: Fix the inspect.py slowdown that was hurting IPython & SAGE
235   by adding smarter caching in inspect.getmodule()
237 - Fix missing import of the types module in logging.config.
239 - Patch #1550886: Fix decimal module context management implementation
240   to match the localcontext() example from PEP 343.
242 - Bug #1545341: The 'classifier' keyword argument to the Distutils setup()
243   function now accepts tuples as well as lists.
245 - Bug #1541863: uuid.uuid1 failed to generate unique identifiers
246   on systems with low clock resolution.
248 - Bug #1531862: Do not close standard file descriptors in subprocess.
250 - fixed a bug with bsddb.DB.stat: the flags and txn keyword arguments
251   were transposed.
254 Extension Modules
255 -----------------
257 - Patch #1544279: Improve thread-safety of the socket module by moving
258   the sock_addr_t storage out of the socket object.
260 - Speed up function calls into the math module.
262 - Bug #1588217: don't parse "= " as a soft line break in binascii's
263   a2b_qp() function, instead leave it in the string as quopri.decode()
264   does.
266 - Bug #1599782: Fix segfault on bsddb.db.DB().type().
268 - Bug #1567666: Emulate GetFileAttributesExA for Win95.
270 - Patch #1576166: Support os.utime for directories on Windows NT+.
272 - Bug #1548891: The cStringIO.StringIO() constructor now encodes unicode
273   arguments with the system default encoding just like the write()
274   method does, instead of converting it to a raw buffer.
276 - Patch #1572724: fix typo ('=' instead of '==') in _msi.c.
278 - Bug #1572832: fix a bug in ISO-2022 codecs which may cause segfault
279   when encoding non-BMP unicode characters.
281 - Bug #1556784: allow format strings longer than 127 characters in
282   datetime's strftime function.
284 - Fix itertools.count(n) to work with negative numbers again.
286 - RLIMIT_SBSIZE was added to the resource module where available.
288 - Bug #1551427: fix a wrong NULL pointer check in the win32 version
289   of os.urandom().
291 - Bug #1548092: fix curses.tparm seg fault on invalid input.
293 - Bug #1550714: fix SystemError from itertools.tee on negative value for n.
295 - Fixed a few bugs on cjkcodecs:
296   - gbk and gb18030 codec now handle U+30FB KATAKANA MIDDLE DOT correctly.
297   - iso2022_jp_2 codec now encodes into G0 for KS X 1001, GB2312
298     codepoints to conform the standard.
299   - iso2022_jp_3 and iso2022_jp_2004 codec can encode JIS X 0213:2
300     codepoints now.
302 - Bug #1552726: in readline.c, avoid repeatedly polling in interactive
303   mode by only placing a timeout on the select() if an input hook has
304   been defined.  This prevents an interactive Python from waking up 10
305   times per second.  Patch by Richard Boulton.
308 Tests
309 -----
311 - Added guard_warnings_filter to test.test_support.  It returns a context
312   manager that protects the 'warnings' module's filter from being mutated
313   once the context has been exited.
315 - Added some tests for modulefinder.
317 - Converted test_imp to use unittest.
319 - Fix bsddb test_basics.test06_Transactions to check the version
320   number properly.
323 Documentation
324 -------------
326 - Bug #1565919: document set types in the Language Reference.
328 - Bug #1546052: clarify that PyString_FromString(AndSize) copies the
329   string pointed to by its parameter.
331 - Bug #1566663: remove obsolete example from datetime docs.
333 - Bug #1541682: Fix example in the "Refcount details" API docs.
334   Additionally, remove a faulty example showing PySequence_SetItem applied
335   to a newly created list object and add notes that this isn't a good idea.
338 Tools/Demos
339 -----------
341 - Patch #1552024: add decorator support to unparse.py demo script.
343 - Make auto-generated python.vim file list built-ins and exceptions in
344   alphatbetical order.  Makes output more deterministic and easier to tell if
345   the file is stale or not.
347 - Bug #1546372: Fixed small bugglet in pybench that caused a missing
348   file not to get reported properly.
351 Build
352 -----
354 - Disable _XOPEN_SOURCE on NetBSD 1.x.
356 - configure now checks whether gcc supports the PyArg_ParseTuple format
357   attribute.
359 - Bug #1578513: Cross compilation was broken by a change to configure.
360   Repair so that it's back to how it was in 2.4.3.
362 - Patch #1576954: Update VC6 build directory; remove redundant
363   files in VC7.
365 - Bug #1568842: Fix test for uintptr_t.
367 - Patch #1540470, for OpenBSD 4.0.
369 - Fix build failure on kfreebsd and on the hurd.
371 - Fix the build of the library reference in info format.
374 C API
375 -----
377 - Bug #1542693: remove semi-colon at end of PyImport_ImportModuleEx macro
378   so it can be used as an expression.
381 Windows
382 -------
384 - Conditionalize definition of _CRT_SECURE_NO_DEPRECATE
385   and _CRT_NONSTDC_NO_DEPRECATE.
392 What's New in Python 2.5 release candidate 1?
393 =============================================
395 *Release date: 17-AUG-2006*
397 Core and builtins
398 -----------------
400 - Unicode objects will no longer raise an exception when being
401   compared equal or unequal to a string and a UnicodeDecodeError
402   exception occurs, e.g. as result of a decoding failure.
404   Instead, the equal (==) and unequal (!=) comparison operators will
405   now issue a UnicodeWarning and interpret the two objects as
406   unequal. The UnicodeWarning can be filtered as desired using
407   the warning framework, e.g. silenced completely, turned into an
408   exception, logged, etc.
410   Note that compare operators other than equal and unequal will still
411   raise UnicodeDecodeError exceptions as they've always done.
413 - Fix segfault when doing string formatting on subclasses of long.
415 - Fix bug related to __len__ functions using values > 2**32 on 64-bit machines
416   with new-style classes.
418 - Fix bug related to __len__ functions returning negative values with
419   classic classes.
421 - Patch #1538606, Fix __index__() clipping.  There were some problems
422   discovered with the API and how integers that didn't fit into Py_ssize_t
423   were handled.  This patch attempts to provide enough alternatives
424   to effectively use __index__.
426 - Bug #1536021: __hash__ may now return long int; the final hash
427   value is obtained by invoking hash on the long int.
429 - Bug #1536786: buffer comparison could emit a RuntimeWarning.
431 - Bug #1535165: fixed a segfault in input() and raw_input() when
432   sys.stdin is closed.
434 - On Windows, the PyErr_Warn function is now exported from
435   the Python dll again.
437 - Bug #1191458: tracing over for loops now produces a line event
438   on each iteration.  Fixing this problem required changing the .pyc
439   magic number.  This means that .pyc files generated before 2.5c1
440   will be regenerated.
442 - Bug #1333982: string/number constants were inappropriately stored
443   in the byte code and co_consts even if they were not used, ie
444   immediately popped off the stack.
446 - Fixed a reference-counting problem in property().
449 Library
450 -------
452 - Fix a bug in the ``compiler`` package that caused invalid code to be
453   generated for generator expressions.
455 - The distutils version has been changed to 2.5.0. The change to
456   keep it programmatically in sync with the Python version running
457   the code (introduced in 2.5b3) has been reverted. It will continue
458   to be maintained manually as static string literal.
460 - If the Python part of a ctypes callback function returns None,
461   and this cannot be converted to the required C type, an exception is
462   printed with PyErr_WriteUnraisable.  Before this change, the C
463   callback returned arbitrary values to the calling code.
465 - The __repr__ method of a NULL ctypes.py_object() no longer raises
466   an exception.
468 - uuid.UUID now has a bytes_le attribute. This returns the UUID in
469   little-endian byte order for Windows. In addition, uuid.py gained some
470   workarounds for clocks with low resolution, to stop the code yielding
471   duplicate UUIDs.
473 - Patch #1540892: site.py Quitter() class attempts to close sys.stdin
474   before raising SystemExit, allowing IDLE to honor quit() and exit().
476 - Bug #1224621: make tabnanny recognize IndentationErrors raised by tokenize.
478 - Patch #1536071: trace.py should now find the full module name of a
479   file correctly even on Windows.
481 - logging's atexit hook now runs even if the rest of the module has
482   already been cleaned up.
484 - Bug #1112549, fix DoS attack on cgi.FieldStorage.
486 - Bug #1531405, format_exception no longer raises an exception if
487   str(exception) raised an exception.
489 - Fix a bug in the ``compiler`` package that caused invalid code to be
490   generated for nested functions.
493 Extension Modules
494 -----------------
496 - Patch #1511317: don't crash on invalid hostname (alias) info.
498 - Patch #1535500: fix segfault in BZ2File.writelines and make sure it
499   raises the correct exceptions.
501 - Patch # 1536908: enable building ctypes on OpenBSD/AMD64.  The
502   '-no-stack-protector' compiler flag for OpenBSD has been removed.
504 - Patch #1532975 was applied, which fixes Bug #1533481: ctypes now
505   uses the _as_parameter_ attribute when objects are passed to foreign
506   function calls.  The ctypes version number was changed to 1.0.1.
508 - Bug #1530559, struct.pack raises TypeError where it used to convert.
509   Passing float arguments to struct.pack when integers are expected
510   now triggers a DeprecationWarning.
513 Tests
514 -----
516 - test_socketserver should now work on cygwin and not fail sporadically
517   on other platforms.
519 - test_mailbox should now work on cygwin versions 2006-08-10 and later.
521 - Bug #1535182: really test the xreadlines() method of bz2 objects.
523 - test_threading now skips testing alternate thread stack sizes on
524   platforms that don't support changing thread stack size.
527 Documentation
528 -------------
530 - Patch #1534922: unittest docs were corrected and enhanced.
533 Build
534 -----
536 - Bug #1535502, build _hashlib on Windows, and use masm assembler
537   code in OpenSSL.
539 - Bug #1534738, win32 debug version of _msi should be _msi_d.pyd.
541 - Bug #1530448, ctypes build failure on Solaris 10 was fixed.
544 C API
545 -----
547 - New API for Unicode rich comparisons: PyUnicode_RichCompare()
549 - Bug #1069160.  Internal correctness changes were made to
550   ``PyThreadState_SetAsyncExc()``.  A test case was added, and
551   the documentation was changed to state that the return value
552   is always 1 (normal) or 0 (if the specified thread wasn't found).
555 What's New in Python 2.5 beta 3?
556 ================================
558 *Release date: 03-AUG-2006*
560 Core and builtins
561 -----------------
563 - _PyWeakref_GetWeakrefCount() now returns a Py_ssize_t; it previously
564   returned a long (see PEP 353).
566 - Bug #1515471: string.replace() accepts character buffers again.
568 - Add PyErr_WarnEx() so C code can pass the stacklevel to warnings.warn().
569   This provides the proper warning for struct.pack().
570   PyErr_Warn() is now deprecated in favor of PyErr_WarnEx().
572 - Patch #1531113: Fix augmented assignment with yield expressions.
573   Also fix a SystemError when trying to assign to yield expressions.
575 - Bug #1529871: The speed enhancement patch #921466 broke Python's compliance
576   with PEP 302.  This was fixed by adding an ``imp.NullImporter`` type that is
577   used in ``sys.path_importer_cache`` to cache non-directory paths and avoid
578   excessive filesystem operations during imports.
580 - Bug #1521947: When checking for overflow, ``PyOS_strtol()`` used some
581   operations on signed longs that are formally undefined by C.
582   Unfortunately, at least one compiler now cares about that, so complicated
583   the code to make that compiler happy again.
585 - Bug #1524310: Properly report errors from FindNextFile in os.listdir.
587 - Patch #1232023: Stop including current directory in search
588   path on Windows.
590 - Fix some potential crashes found with failmalloc.
592 - Fix warnings reported by Klocwork's static analysis tool.
594 - Bug #1512814, Fix incorrect lineno's when code within a function
595   had more than 255 blank lines.
597 - Patch #1521179: Python now accepts the standard options ``--help`` and
598   ``--version`` as well as ``/?`` on Windows.
600 - Bug #1520864: unpacking singleton tuples in a 'for' loop (for x, in) works
601   again.  Fixing this problem required changing the .pyc magic number.
602   This means that .pyc files generated before 2.5b3 will be regenerated.
604 - Bug #1524317:  Compiling Python ``--without-threads`` failed.
605   The Python core compiles again, and, in a build without threads, the
606   new ``sys._current_frames()`` returns a dictionary with one entry,
607   mapping the faux "thread id" 0 to the current frame.
609 - Bug #1525447: build on MacOS X on a case-sensitive filesystem.
612 Library
613 -------
615 - Correction of patch #1455898: In the mbcs decoder, set final=False
616   for stream decoder, but final=True for the decode function.
618 - os.urandom no longer masks unrelated exceptions like SystemExit or
619   KeyboardInterrupt.
621 - Bug #1525866: Don't copy directory stat times in
622   shutil.copytree on Windows
624 - Bug #1002398: The documentation for os.path.sameopenfile now correctly
625   refers to file descriptors, not file objects.
627 - The renaming of the xml package to xmlcore, and the import hackery done
628   to make it appear at both names, has been removed.  Bug #1511497,
629   #1513611, and probably others.
631 - Bug #1441397: The compiler module now recognizes module and function
632   docstrings correctly as it did in Python 2.4.
634 - Bug #1529297:  The rewrite of doctest for Python 2.4 unintentionally
635   lost that tests are sorted by name before being run.  This rarely
636   matters for well-written tests, but can create baffling symptoms if
637   side effects from one test to the next affect outcomes.  ``DocTestFinder``
638   has been changed to sort the list of tests it returns.
640 - The distutils version has been changed to 2.5.0, and is now kept
641   in sync with sys.version_info[:3].
643 - Bug #978833: Really close underlying socket in _socketobject.close.
645 - Bug #1459963: urllib and urllib2 now normalize HTTP header names with
646   title().
648 - Patch #1525766: In pkgutil.walk_packages, correctly pass the onerror callback
649   to recursive calls and call it with the failing package name.
651 - Bug #1525817: Don't truncate short lines in IDLE's tool tips.
653 - Patch #1515343: Fix printing of deprecated string exceptions with a
654   value in the traceback module.
656 - Resync optparse with Optik 1.5.3: minor tweaks for/to tests.
658 - Patch #1524429: Use repr() instead of backticks in Tkinter again.
660 - Bug #1520914: Change time.strftime() to accept a zero for any position in its
661   argument tuple.  For arguments where zero is illegal, the value is forced to
662   the minimum value that is correct.  This is to support an undocumented but
663   common way people used  to fill in inconsequential information in the time
664   tuple pre-2.4.
666 - Patch #1220874: Update the binhex module for Mach-O.
668 - The email package has improved RFC 2231 support, specifically for
669   recognizing the difference between encoded (name*0*=<blah>) and non-encoded
670   (name*0=<blah>) parameter continuations.  This may change the types of
671   values returned from email.message.Message.get_param() and friends.
672   Specifically in some cases where non-encoded continuations were used,
673   get_param() used to return a 3-tuple of (None, None, string) whereas now it
674   will just return the string (since non-encoded continuations don't have
675   charset and language parts).
677   Also, whereas % values were decoded in all parameter continuations, they are
678   now only decoded in encoded parameter parts.
680 - Bug #1517990: IDLE keybindings on MacOS X now work correctly
682 - Bug #1517996: IDLE now longer shows the default Tk menu when a
683   path browser, class browser or debugger is the frontmost window on MacOS X
685 - Patch #1520294: Support for getset and member descriptors in types.py,
686   inspect.py, and pydoc.py.  Specifically, this allows for querying the type
687   of an object against these built-in types and more importantly, for getting
688   their docstrings printed in the interactive interpreter's help() function.
691 Extension Modules
692 -----------------
694 - Patch #1519025 and bug #926423: If a KeyboardInterrupt occurs during
695   a socket operation on a socket with a timeout, the exception will be
696   caught correctly.  Previously, the exception was not caught.
698 - Patch #1529514: The _ctypes extension is now compiled on more
699   openbsd target platforms.
701 - The ``__reduce__()`` method of the new ``collections.defaultdict`` had
702   a memory leak, affecting pickles and deep copies.
704 - Bug #1471938: Fix curses module build problem on Solaris 8; patch by
705   Paul Eggert.
707 - Patch #1448199: Release interpreter lock in _winreg.ConnectRegistry.
709 - Patch #1521817: Index range checking on ctypes arrays containing
710   exactly one element enabled again.  This allows iterating over these
711   arrays, without the need to check the array size before.
713 - Bug #1521375: When the code in ctypes.util.find_library was
714   run with root privileges, it could overwrite or delete
715   /dev/null in certain cases; this is now fixed.
717 - Bug #1467450: On Mac OS X 10.3, RTLD_GLOBAL is now used as the
718   default mode for loading shared libraries in ctypes.
720 - Because of a misspelled preprocessor symbol, ctypes was always
721   compiled without thread support; this is now fixed.
723 - pybsddb Bug #1527939: bsddb module DBEnv dbremove and dbrename
724   methods now allow their database parameter to be None as the
725   sleepycat API allows.
727 - Bug #1526460: Fix socketmodule compile on NetBSD as it has a different
728   bluetooth API compared with Linux and FreeBSD.
730 Tests
731 -----
733 - Bug #1501330: Change test_ossaudiodev to be much more tolerant in terms of
734   how long the test file should take to play.  Now accepts taking 2.93 secs
735   (exact time) +/- 10% instead of the hard-coded 3.1 sec.
737 - Patch #1529686: The standard tests ``test_defaultdict``, ``test_iterlen``,
738   ``test_uuid`` and ``test_email_codecs`` didn't actually run any tests when
739   run via ``regrtest.py``. Now they do.
741 Build
742 -----
744 - Bug #1439538: Drop usage of test -e in configure as it is not portable.
749 - PythonLauncher now works correctly when the path to the script contains
750   characters that are treated specially by the shell (such as quotes).
752 - Bug #1527397: PythonLauncher now launches scripts with the working directory
753   set to the directory that contains the script instead of the user home
754   directory. That latter was an implementation accident and not what users
755   expect.
758 What's New in Python 2.5 beta 2?
759 ================================
761 *Release date: 11-JUL-2006*
763 Core and builtins
764 -----------------
766 - Bug #1441486: The literal representation of -(sys.maxint - 1)
767   again evaluates to a int object, not a long.
769 - Bug #1501934: The scope of global variables that are locally assigned
770   using augmented assignment is now correctly determined.
772 - Bug #927248: Recursive method-wrapper objects can now safely
773   be released.
775 - Bug #1417699: Reject locale-specific decimal point in float()
776   and atof().
778 - Bug #1511381: codec_getstreamcodec() in codec.c is corrected to
779   omit a default "error" argument for NULL pointer.  This allows
780   the parser to take a codec from cjkcodecs again.
782 - Bug #1519018: 'as' is now validated properly in import statements.
784 - On 64 bit systems, int literals that use less than 64 bits are
785   now ints rather than longs.
787 - Bug #1512814, Fix incorrect lineno's when code at module scope
788   started after line 256.
790 - New function ``sys._current_frames()`` returns a dict mapping thread
791   id to topmost thread stack frame.  This is for expert use, and is
792   especially useful for debugging application deadlocks.  The functionality
793   was previously available in Fazal Majid's ``threadframe`` extension
794   module, but it wasn't possible to do this in a wholly threadsafe way from
795   an extension.
797 Library
798 -------
800 - Bug #1257728: Mention Cygwin in distutils error message about a missing
801   VS 2003.
803 - Patch #1519566: Update turtle demo, make begin_fill idempotent.
805 - Bug #1508010: msvccompiler now requires the DISTUTILS_USE_SDK
806   environment variable to be set in order to the SDK environment
807   for finding the compiler, include files, etc.
809 - Bug #1515998: Properly generate logical ids for files in bdist_msi.
811 - warnings.py now ignores ImportWarning by default
813 - string.Template() now correctly handles tuple-values. Previously,
814   multi-value tuples would raise an exception and single-value tuples would
815   be treated as the value they contain, instead.
817 - Bug #822974: Honor timeout in telnetlib.{expect,read_until}
818   even if some data are received.
820 - Bug #1267547: Put proper recursive setup.py call into the
821   spec file generated by bdist_rpm.
823 - Bug #1514693: Update turtle's heading when switching between
824   degrees and radians.
826 - Reimplement turtle.circle using a polyline, to allow correct
827   filling of arcs.
829 - Bug #1514703: Only setup canvas window in turtle when the canvas
830   is created.
832 - Bug #1513223: .close() of a _socketobj now releases the underlying
833   socket again, which then gets closed as it becomes unreferenced.
835 - Bug #1504333: Make sgmllib support angle brackets in quoted
836   attribute values.
838 - Bug #853506: Fix IPv6 address parsing in unquoted attributes in
839   sgmllib ('[' and ']' were not accepted).
841 - Fix a bug in the turtle module's end_fill function.
843 - Bug #1510580: The 'warnings' module improperly required that a Warning
844   category be either a types.ClassType and a subclass of Warning.  The proper
845   check is just that it is a subclass with Warning as the documentation states.
847 - The compiler module now correctly compiles the new try-except-finally
848   statement (bug #1509132).
850 - The wsgiref package is now installed properly on Unix.
852 - A bug was fixed in logging.config.fileConfig() which caused a crash on
853   shutdown when fileConfig() was called multiple times.
855 - The sqlite3 module did cut off data from the SQLite database at the first
856   null character before sending it to a custom converter. This has been fixed
857   now.
859 Extension Modules
860 -----------------
862 - #1494314: Fix a regression with high-numbered sockets in 2.4.3. This
863   means that select() on sockets > FD_SETSIZE (typically 1024) work again.
864   The patch makes sockets use poll() internally where available.
866 - Assigning None to pointer type fields in ctypes structures possible
867   overwrote the wrong fields, this is fixed now.
869 - Fixed a segfault in _ctypes when ctypes.wintypes were imported
870   on non-Windows platforms.
872 - Bug #1518190: The ctypes.c_void_p constructor now accepts any
873   integer or long, without range checking.
875 - Patch #1517790: It is now possible to use custom objects in the ctypes
876   foreign function argtypes sequence as long as they provide a from_param
877   method, no longer is it required that the object is a ctypes type.
879 - The '_ctypes' extension module now works when Python is configured
880   with the --without-threads option.
882 - Bug #1513646: os.access on Windows now correctly determines write
883   access, again.
885 - Bug #1512695: cPickle.loads could crash if it was interrupted with
886   a KeyboardInterrupt.
888 - Bug #1296433: parsing XML with a non-default encoding and
889   a CharacterDataHandler could crash the interpreter in pyexpat.
891 - Patch #1516912: improve Modules support for OpenVMS.
893 Build
894 -----
896 - Automate Windows build process for the Win64 SSL module.
898 - 'configure' now detects the zlib library the same way as distutils.
899   Previously, the slight difference could cause compilation errors of the
900   'zlib' module on systems with more than one version of zlib.
902 - The MSI compileall step was fixed to also support a TARGETDIR
903   with spaces in it.
905 - Bug #1517388: sqlite3.dll is now installed on Windows independent
906   of Tcl/Tk.
908 - Bug #1513032: 'make install' failed on FreeBSD 5.3 due to lib-old
909   trying to be installed even though it's empty.
911 Tests
912 -----
914 - Call os.waitpid() at the end of tests that spawn child processes in order
915   to minimize resources (zombies).
917 Documentation
918 -------------
920 - Cover ImportWarning, PendingDeprecationWarning and simplefilter() in the
921   documentation for the warnings module.
923 - Patch #1509163: MS Toolkit Compiler no longer available.
925 - Patch #1504046: Add documentation for xml.etree.
928 What's New in Python 2.5 beta 1?
929 ================================
931 *Release date: 20-JUN-2006*
933 Core and builtins
934 -----------------
936 - Patch #1507676: Error messages returned by invalid abstract object operations
937   (such as iterating over an integer) have been improved and now include the
938   type of the offending object to help with debugging.
940 - Bug #992017: A classic class that defined a __coerce__() method that returned
941   its arguments swapped would infinitely recurse and segfault the interpreter.
943 - Fix the socket tests so they can be run concurrently.
945 - Removed 5 integers from C frame objects (PyFrameObject).
946   f_nlocals, f_ncells, f_nfreevars, f_stack_size, f_restricted.
948 - Bug #532646: object.__call__() will continue looking for the __call__
949   attribute on objects until one without one is found.  This leads to recursion
950   when you take a class and set its __call__ attribute to an instance of the
951   class.  Originally fixed for classic classes, but this fix is for new-style.
952   Removes the infinite_rec_3 crasher.
954 - The string and unicode methods startswith() and endswith() now accept
955   a tuple of prefixes/suffixes to look for. Implements RFE #1491485.
957 - Buffer objects, at the C level, never used the char buffer
958   implementation even when the char buffer for the wrapped object was
959   explicitly requested (originally returned the read or write buffer).
960   Now a TypeError is raised if the char buffer is not present but is
961   requested.
963 - Patch #1346214: Statements like "if 0: suite" are now again optimized
964   away like they were in Python 2.4.
966 - Builtin exceptions are now full-blown new-style classes instead of
967   instances pretending to be classes, which speeds up exception handling
968   by about 80% in comparison to 2.5a2.
970 - Patch #1494554: Update unicodedata.numeric and unicode.isnumeric to
971   Unicode 4.1.
973 - Patch #921466: sys.path_importer_cache is now used to cache valid and
974   invalid file paths for the built-in import machinery which leads to
975   fewer open calls on startup.
977 - Patch #1442927: ``long(str, base)`` is now up to 6x faster for non-power-
978   of-2 bases.  The largest speedup is for inputs with about 1000 decimal
979   digits.  Conversion from non-power-of-2 bases remains quadratic-time in
980   the number of input digits (it was and remains linear-time for bases
981   2, 4, 8, 16 and 32).
983 - Bug #1334662: ``int(string, base)`` could deliver a wrong answer
984   when ``base`` was not 2, 4, 8, 10, 16 or 32, and ``string`` represented
985   an integer close to ``sys.maxint``.  This was repaired by patch
986   #1335972, which also gives a nice speedup.
988 - Patch #1337051: reduced size of frame objects.
990 - PyErr_NewException now accepts a tuple of base classes as its
991   "base" parameter.
993 - Patch #876206: function call speedup by retaining allocated frame
994   objects.
996 - Bug #1462152: file() now checks more thoroughly for invalid mode
997   strings and removes a possible "U" before passing the mode to the
998   C library function.
1000 - Patch #1488312, Fix memory alignment problem on SPARC in unicode
1002 - Bug #1487966: Fix SystemError with conditional expression in assignment
1004 - WindowsError now has two error code attributes: errno, which carries
1005   the error values from errno.h, and winerror, which carries the error
1006   values from winerror.h. Previous versions put the winerror.h values
1007   (from GetLastError()) into the errno attribute.
1009 - Patch #1475845: Raise IndentationError for unexpected indent.
1011 - Patch #1479181: split open() and file() from being aliases for each other.
1013 - Patch #1497053 & bug #1275608: Exceptions occurring in ``__eq__()``
1014   methods were always silently ignored by dictionaries when comparing keys.
1015   They are now passed through (except when using the C API function
1016   ``PyDict_GetItem()``, whose semantics did not change).
1018 - Bug #1456209: In some obscure cases it was possible for a class with a
1019   custom ``__eq__()`` method to confuse dict internals when class instances
1020   were used as a dict's keys and the ``__eq__()`` method mutated the dict.
1021   No, you don't have any code that did this ;-)
1023 Extension Modules
1024 -----------------
1026 - Bug #1295808: expat symbols should be namespaced in pyexpat
1028 - Patch #1462338: Upgrade pyexpat to expat 2.0.0
1030 - Change binascii.hexlify to accept a read-only buffer instead of only a char
1031   buffer and actually follow its documentation.
1033 - Fixed a potentially invalid memory access of CJKCodecs' shift-jis decoder.
1035 - Patch #1478788 (modified version): The functional extension module has
1036   been renamed to _functools and a functools Python wrapper module added.
1037   This provides a home for additional function related utilities that are
1038   not specifically about functional programming. See PEP 309.
1040 - Patch #1493701: performance enhancements for struct module.
1042 - Patch #1490224: time.altzone is now set correctly on Cygwin.
1044 - Patch #1435422: zlib's compress and decompress objects now have a
1045   copy() method.
1047 - Patch #1454481: thread stack size is now tunable at runtime for thread
1048   enabled builds on Windows and systems with Posix threads support.
1050 - On Win32, os.listdir now supports arbitrarily-long Unicode path names
1051   (up to the system limit of 32K characters).
1053 - Use Win32 API to implement os.{access,chdir,chmod,mkdir,remove,rename,rmdir,utime}.
1054   As a result, these functions now raise WindowsError instead of OSError.
1056 - ``time.clock()`` on Win64 should use the high-performance Windows
1057   ``QueryPerformanceCounter()`` now (as was already the case on 32-bit
1058   Windows platforms).
1060 - Calling Tk_Init twice is refused if the first call failed as that
1061   may deadlock.
1063 - bsddb: added the DB_ARCH_REMOVE flag and fixed db.DBEnv.log_archive() to
1064   accept it without potentially using an uninitialized pointer.
1066 - bsddb: added support for the DBEnv.log_stat() and DBEnv.lsn_reset() methods
1067   assuming BerkeleyDB >= 4.0 and 4.4 respectively.  [pybsddb project SF
1068   patch numbers 1494885 and 1494902]
1070 - bsddb: added an interface for the BerkeleyDB >= 4.3 DBSequence class.
1071   [pybsddb project SF patch number 1466734]
1073 - bsddb: fix DBCursor.pget() bug with keyword argument names when no data
1074   parameter is supplied.  [SF pybsddb bug #1477863]
1076 - bsddb: the __len__ method of a DB object has been fixed to return correct
1077   results.  It could previously incorrectly return 0 in some cases.
1078   Fixes SF bug 1493322 (pybsddb bug 1184012).
1080 - bsddb: the bsddb.dbtables Modify method now raises the proper error and
1081   aborts the db transaction safely when a modifier callback fails.
1082   Fixes SF python patch/bug #1408584.
1084 - bsddb: multithreaded DB access using the simple bsddb module interface
1085   now works reliably.  It has been updated to use automatic BerkeleyDB
1086   deadlock detection and the bsddb.dbutils.DeadlockWrap wrapper to retry
1087   database calls that would previously deadlock. [SF python bug #775414]
1089 - Patch #1446489: add support for the ZIP64 extensions to zipfile.
1091 - Patch #1506645: add Python wrappers for the curses functions
1092   is_term_resized, resize_term and resizeterm.
1094 Library
1095 -------
1097 - Patch #815924: Restore ability to pass type= and icon= in tkMessageBox
1098   functions.
1100 - Patch #812986: Update turtle output even if not tracing.
1102 - Patch #1494750: Destroy master after deleting children in
1103   Tkinter.BaseWidget.
1105 - Patch #1096231: Add ``default`` argument to Tkinter.Wm.wm_iconbitmap.
1107 - Patch #763580: Add name and value arguments to Tkinter variable
1108   classes.
1110 - Bug #1117556: SimpleHTTPServer now tries to find and use the system's
1111   mime.types file for determining MIME types.
1113 - Bug #1339007: Shelf objects now don't raise an exception in their
1114   __del__ method when initialization failed.
1116 - Patch #1455898: The MBCS codec now supports the incremental mode for
1117   double-byte encodings.
1119 - ``difflib``'s ``SequenceMatcher.get_matching_blocks()`` was changed to
1120   guarantee that adjacent triples in the return list always describe
1121   non-adjacent blocks.  Previously, a pair of matching blocks could end
1122   up being described by multiple adjacent triples that formed a partition
1123   of the matching pair.
1125 - Bug #1498146: fix optparse to handle Unicode strings in option help,
1126   description, and epilog.
1128 - Bug #1366250: minor optparse documentation error.
1130 - Bug #1361643: fix textwrap.dedent() so it handles tabs appropriately;
1131   clarify docs.
1133 - The wsgiref package has been added to the standard library.
1135 - The functions update_wrapper() and wraps() have been added to the functools
1136   module. These make it easier to copy relevant metadata from the original
1137   function when writing wrapper functions.
1139 - The optional ``isprivate`` argument to ``doctest.testmod()``, and the
1140   ``doctest.is_private()`` function, both deprecated in 2.4, were removed.
1142 - Patch #1359618: Speed up charmap encoder by using a trie structure
1143   for lookup.
1145 - The functions in the ``pprint`` module now sort dictionaries by key
1146   before computing the display.  Before 2.5, ``pprint`` sorted a dictionary
1147   if and only if its display required more than one line, although that
1148   wasn't documented.  The new behavior increases predictability; e.g.,
1149   using ``pprint.pprint(a_dict)`` in a doctest is now reliable.
1151 - Patch #1497027: try HTTP digest auth before basic auth in urllib2
1152   (thanks for J. J. Lee).
1154 - Patch #1496206: improve urllib2 handling of passwords with respect to
1155   default HTTP and HTTPS ports.
1157 - Patch #1080727: add "encoding" parameter to doctest.DocFileSuite.
1159 - Patch #1281707: speed up gzip.readline.
1161 - Patch #1180296: Two new functions were added to the locale module:
1162   format_string() to get the effect of  "format % items" but locale-aware,
1163   and currency() to format a monetary number with currency sign.
1165 - Patch #1486962: Several bugs in the turtle Tk demo module were fixed
1166   and several features added, such as speed and geometry control.
1168 - Patch #1488881: add support for external file objects in bz2 compressed
1169   tarfiles.
1171 - Patch #721464: pdb.Pdb instances can now be given explicit stdin and
1172   stdout arguments, making it possible to redirect input and output
1173   for remote debugging.
1175 - Patch #1484695: Update the tarfile module to version 0.8. This fixes
1176   a couple of issues, notably handling of long file names using the
1177   GNU LONGNAME extension.
1179 - Patch #1478292. ``doctest.register_optionflag(name)`` shouldn't create a
1180   new flag when ``name`` is already the name of an option flag.
1182 - Bug #1385040: don't allow "def foo(a=1, b): pass" in the compiler
1183   package.
1185 - Patch #1472854: make the rlcompleter.Completer class usable on non-
1186   UNIX platforms.
1188 - Patch #1470846: fix urllib2 ProxyBasicAuthHandler.
1190 - Bug #1472827: correctly escape newlines and tabs in attribute values in
1191   the saxutils.XMLGenerator class.
1194 Build
1195 -----
1197 - Bug #1502728: Correctly link against librt library on HP-UX.
1199 - OpenBSD 3.9 is supported now.
1201 - Patch #1492356: Port to Windows CE.
1203 - Bug/Patch #1481770: Use .so extension for shared libraries on HP-UX for ia64.
1205 - Patch #1471883: Add --enable-universalsdk.
1207 C API
1208 -----
1210 Tests
1211 -----
1213 Tools
1214 -----
1216 Documentation
1217 -------------
1221 What's New in Python 2.5 alpha 2?
1222 =================================
1224 *Release date: 27-APR-2006*
1226 Core and builtins
1227 -----------------
1229 - Bug #1465834: 'bdist_wininst preinstall script support' was fixed
1230   by converting these apis from macros into exported functions again:
1232     PyParser_SimpleParseFile PyParser_SimpleParseString PyRun_AnyFile
1233     PyRun_AnyFileEx PyRun_AnyFileFlags PyRun_File PyRun_FileEx
1234     PyRun_FileFlags PyRun_InteractiveLoop PyRun_InteractiveOne
1235     PyRun_SimpleFile PyRun_SimpleFileEx PyRun_SimpleString
1236     PyRun_String Py_CompileString
1238 - Under COUNT_ALLOCS, types are not necessarily immortal anymore.
1240 - All uses of PyStructSequence_InitType have been changed to initialize
1241   the type objects only once, even if the interpreter is initialized
1242   multiple times.
1244 - Bug #1454485, array.array('u') could crash the interpreter.  This was
1245   due to PyArgs_ParseTuple(args, 'u#', ...) trying to convert buffers (strings)
1246   to unicode when it didn't make sense.  'u#' now requires a unicode string.
1248 - Py_UNICODE is unsigned.  It was always documented as unsigned, but
1249   due to a bug had a signed value in previous versions.
1251 - Patch #837242: ``id()`` of any Python object always gives a positive
1252   number now, which might be a long integer. ``PyLong_FromVoidPtr`` and
1253   ``PyLong_AsVoidPtr`` have been changed accordingly.  Note that it has
1254   never been correct to implement a ``__hash()__`` method that returns the
1255   ``id()`` of an object:
1257       def __hash__(self):
1258           return id(self)  # WRONG
1260   because a hash result must be a (short) Python int but it was always
1261   possible for ``id()`` to return a Python long.  However, because ``id()``
1262   could return negative values before, on a 32-bit box an ``id()`` result
1263   was always usable as a hash value before this patch.  That's no longer
1264   necessarily so.
1266 - Python on OS X 10.3 and above now uses dlopen() (via dynload_shlib.c)
1267   to load extension modules and now provides the dl module. As a result,
1268   sys.setdlopenflags() now works correctly on these systems. (SF patch
1269   #1454844)
1271 - Patch #1463867: enhanced garbage collection to allow cleanup of cycles
1272   involving generators that have paused outside of any ``try`` or ``with``
1273   blocks.  (In 2.5a1, a paused generator that was part of a reference
1274   cycle could not be garbage collected, regardless of whether it was
1275   paused in a ``try`` or ``with`` block.)
1277 Extension Modules
1278 -----------------
1280 - Patch #1191065: Fix preprocessor problems on systems where recvfrom
1281   is a macro.
1283 - Bug #1467952: os.listdir() now correctly raises an error if readdir()
1284   fails with an error condition.
1286 - Fixed bsddb.db.DBError derived exceptions so they can be unpickled.
1288 - Bug #1117761: bsddb.*open() no longer raises an exception when using
1289   the cachesize parameter.
1291 - Bug #1149413: bsddb.*open() no longer raises an exception when using
1292   a temporary db (file=None) with the 'n' flag to truncate on open.
1294 - Bug #1332852: bsddb module minimum BerkeleyDB version raised to 3.3
1295   as older versions cause excessive test failures.
1297 - Patch #1062014: AF_UNIX sockets under Linux have a special
1298   abstract namespace that is now fully supported.
1300 Library
1301 -------
1303 - Bug #1223937: subprocess.CalledProcessError reports the exit status
1304   of the process using the returncode attribute, instead of
1305   abusing errno.
1307 - Patch #1475231: ``doctest`` has a new ``SKIP`` option, which causes
1308   a doctest to be skipped (the code is not run, and the expected output
1309   or exception is ignored).
1311 - Fixed contextlib.nested to cope with exceptions being raised and
1312   caught inside exit handlers.
1314 - Updated optparse module to Optik 1.5.1 (allow numeric constants in
1315   hex, octal, or binary; add ``append_const`` action; keep going if
1316   gettext cannot be imported; added ``OptionParser.destroy()`` method;
1317   added ``epilog`` for better help generation).
1319 - Bug #1473760: ``tempfile.TemporaryFile()`` could hang on Windows, when
1320   called from a thread spawned as a side effect of importing a module.
1322 - The pydoc module now supports documenting packages contained in
1323   .zip or .egg files.
1325 - The pkgutil module now has several new utility functions, such
1326   as ``walk_packages()`` to support working with packages that are either
1327   in the filesystem or zip files.
1329 - The mailbox module can now modify and delete messages from
1330   mailboxes, in addition to simply reading them.  Thanks to Gregory
1331   K. Johnson for writing the code, and to the 2005 Google Summer of
1332   Code for funding his work.
1334 - The ``__del__`` method of class ``local`` in module ``_threading_local``
1335   returned before accomplishing any of its intended cleanup.
1337 - Patch #790710: Add breakpoint command lists in pdb.
1339 - Patch #1063914: Add Tkinter.Misc.clipboard_get().
1341 - Patch #1191700: Adjust column alignment in bdb breakpoint lists.
1343 - SimpleXMLRPCServer relied on the fcntl module, which is unavailable on
1344   Windows. Bug #1469163.
1346 - The warnings, linecache, inspect, traceback, site, and doctest modules
1347   were updated to work correctly with modules imported from zipfiles or
1348   via other PEP 302 __loader__ objects.
1350 - Patch #1467770: Reduce usage of subprocess._active to processes which
1351   the application hasn't waited on.
1353 - Patch #1462222: Fix Tix.Grid.
1355 - Fix exception when doing glob.glob('anything*/')
1357 - The pstats.Stats class accepts an optional stream keyword argument to
1358   direct output to an alternate file-like object.
1360 Build
1361 -----
1363 - The Makefile now has a reindent target, which runs reindent.py on
1364   the library.
1366 - Patch #1470875: Building Python with MS Free Compiler
1368 - Patch #1161914: Add a python-config script.
1370 - Patch #1324762:Remove ccpython.cc; replace --with-cxx with
1371   --with-cxx-main. Link with C++ compiler only if --with-cxx-main was
1372   specified. (Can be overridden by explicitly setting LINKCC.) Decouple
1373   CXX from --with-cxx-main, see description in README.
1375 - Patch #1429775: Link extension modules with the shared libpython.
1377 - Fixed a libffi build problem on MIPS systems.
1379 - ``PyString_FromFormat``, ``PyErr_Format``, and ``PyString_FromFormatV``
1380   now accept formats "%u" for unsigned ints, "%lu" for unsigned longs,
1381   and "%zu" for unsigned integers of type ``size_t``.
1383 Tests
1384 -----
1386 - test_contextlib now checks contextlib.nested can cope with exceptions
1387   being raised and caught inside exit handlers.
1389 - test_cmd_line now checks operation of the -m and -c command switches
1391 - The test_contextlib test in 2.5a1 wasn't actually run unless you ran
1392   it separately and by hand.  It also wasn't cleaning up its changes to
1393   the current Decimal context.
1395 - regrtest.py now has a -M option to run tests that test the new limits of
1396   containers, on 64-bit architectures. Running these tests is only sensible
1397   on 64-bit machines with more than two gigabytes of memory. The argument
1398   passed is the maximum amount of memory for the tests to use.
1400 Tools
1401 -----
1403 - Added the Python benchmark suite pybench to the Tools/ directory;
1404   contributed by Marc-Andre Lemburg.
1406 Documentation
1407 -------------
1409 - Patch #1473132: Improve docs for ``tp_clear`` and ``tp_traverse``.
1411 - PEP 343: Added Context Types section to the library reference
1412   and attempted to bring other PEP 343 related documentation into
1413   line with the implementation and/or python-dev discussions.
1415 - Bug #1337990: clarified that ``doctest`` does not support examples
1416   requiring both expected output and an exception.
1419 What's New in Python 2.5 alpha 1?
1420 =================================
1422 *Release date: 05-APR-2006*
1424 Core and builtins
1425 -----------------
1427 - PEP 338: -m command line switch now delegates to runpy.run_module
1428   allowing it to support modules in packages and zipfiles
1430 - On Windows, .DLL is not an accepted file name extension for
1431   extension modules anymore; extensions are only found if they
1432   end in .PYD.
1434 - Bug #1421664: sys.stderr.encoding is now set to the same value as
1435   sys.stdout.encoding.
1437 - __import__ accepts keyword arguments.
1439 - Patch #1460496: round() now accepts keyword arguments.
1441 - Fixed bug #1459029 - unicode reprs were double-escaped.
1443 - Patch #1396919: The system scope threads are reenabled on FreeBSD
1444   5.4 and later versions.
1446 - Bug #1115379: Compiling a Unicode string with an encoding declaration
1447   now gives a SyntaxError.
1449 - Previously, Python code had no easy way to access the contents of a
1450   cell object. Now, a ``cell_contents`` attribute has been added
1451   (closes patch #1170323).
1453 - Patch #1123430: Python's small-object allocator now returns an arena to
1454   the system ``free()`` when all memory within an arena becomes unused
1455   again.  Prior to Python 2.5, arenas (256KB chunks of memory) were never
1456   freed.  Some applications will see a drop in virtual memory size now,
1457   especially long-running applications that, from time to time, temporarily
1458   use a large number of small objects.  Note that when Python returns an
1459   arena to the platform C's ``free()``, there's no guarantee that the
1460   platform C library will in turn return that memory to the operating system.
1461   The effect of the patch is to stop making that impossible, and in tests it
1462   appears to be effective at least on Microsoft C and gcc-based systems.
1463   Thanks to Evan Jones for hard work and patience.
1465 - Patch #1434038: property() now uses the getter's docstring if there is
1466   no "doc" argument given. This makes it possible to legitimately use
1467   property() as a decorator to produce a read-only property.
1469 - PEP 357, patch 1436368: add an __index__ method to int/long and a matching
1470   nb_index slot to the PyNumberMethods struct.  The slot is consulted instead
1471   of requiring an int or long in slicing and a few other contexts, enabling
1472   other objects (e.g. Numeric Python's integers) to be used as slice indices.
1474 - Fixed various bugs reported by Coverity's Prevent tool.
1476 - PEP 352, patch #1104669: Make exceptions new-style objects.  Introduced the
1477   new exception base class, BaseException, which has a new message attribute.
1478   KeyboardInterrupt and SystemExit to directly inherit from BaseException now.
1479   Raising a string exception now raises a DeprecationWarning.
1481 - Patch #1438387, PEP 328: relative and absolute imports. Imports can now be
1482   explicitly relative, using 'from .module import name' to mean 'from the same
1483   package as this module is in. Imports without dots still default to the
1484   old relative-then-absolute, unless 'from __future__ import
1485   absolute_import' is used.
1487 - Properly check if 'warnings' raises an exception (usually when a filter set
1488   to "error" is triggered) when raising a warning for raising string
1489   exceptions.
1491 - CO_GENERATOR_ALLOWED is no longer defined. This behavior is the default.
1492   The name was removed from Include/code.h.
1494 - PEP 308: conditional expressions were added: (x if cond else y).
1496 - Patch 1433928:
1497   - The copy module now "copies" function objects (as atomic objects).
1498   - dict.__getitem__ now looks for a __missing__ hook before raising
1499     KeyError.
1501 - PEP 343: with statement implemented. Needs ``from __future__ import
1502   with_statement``. Use of 'with' as a variable will generate a warning.
1503   Use of 'as' as a variable will also generate a warning (unless it's
1504   part of an import statement).
1505   The following objects have __context__ methods:
1506   - The built-in file type.
1507   - The thread.LockType type.
1508   - The following types defined by the threading module:
1509     Lock, RLock, Condition, Semaphore, BoundedSemaphore.
1510   - The decimal.Context class.
1512 - Fix the encodings package codec search function to only search
1513   inside its own package. Fixes problem reported in patch #1433198.
1515   Note: Codec packages should implement and register their own
1516   codec search function. PEP 100 has the details.
1518 - PEP 353: Using ``Py_ssize_t`` as the index type.
1520 - ``PYMALLOC_DEBUG`` builds now add ``4*sizeof(size_t)`` bytes of debugging
1521   info to each allocated block, since the ``Py_ssize_t`` changes (PEP 353)
1522   now allow Python to make use of memory blocks exceeding 2**32 bytes for
1523   some purposes on 64-bit boxes.  A ``PYMALLOC_DEBUG`` build was limited
1524   to 4-byte allocations before.
1526 - Patch #1400181, fix unicode string formatting to not use the locale.
1527   This is how string objects work.  u'%f' could use , instead of .
1528   for the decimal point.  Now both strings and unicode always use periods.
1530 - Bug #1244610, #1392915, fix build problem on OpenBSD 3.7 and 3.8.
1531   configure would break checking curses.h.
1533 - Bug #959576: The pwd module is now builtin. This allows Python to be
1534   built on UNIX platforms without $HOME set.
1536 - Bug #1072182, fix some potential problems if characters are signed.
1538 - Bug #889500, fix line number on SyntaxWarning for global declarations.
1540 - Bug #1378022, UTF-8 files with a leading BOM crashed the interpreter.
1542 - Support for converting hex strings to floats no longer works.
1543   This was not portable.  float('0x3') now raises a ValueError.
1545 - Patch #1382163: Expose Subversion revision number to Python.  New C API
1546   function Py_GetBuildNumber().  New attribute sys.subversion.  Build number
1547   is now displayed in interactive prompt banner.
1549 - Implementation of PEP 341 - Unification of try/except and try/finally.
1550   "except" clauses can now be written together with a "finally" clause in
1551   one try statement instead of two nested ones.  Patch #1355913.
1553 - Bug #1379994: Builtin unicode_escape and raw_unicode_escape codec
1554   now encodes backslash correctly.
1556 - Patch #1350409: Work around signal handling bug in Visual Studio 2005.
1558 - Bug #1281408: Py_BuildValue now works correctly even with unsigned longs
1559   and long longs.
1561 - SF Bug #1350188, "setdlopenflags" leads to crash upon "import"
1562   It was possible for dlerror() to return a NULL pointer, so
1563   it will now use a default error message in this case.
1565 - Replaced most Unicode charmap codecs with new ones using the
1566   new Unicode translate string feature in the builtin charmap
1567   codec; the codecs were created from the mapping tables available
1568   at ftp.unicode.org and contain a few updates (e.g. the Mac OS
1569   encodings now include a mapping for the Apple logo)
1571 - Added a few more codecs for Mac OS encodings
1573 - Sped up some Unicode operations.
1575 - A new AST parser implementation was completed. The abstract
1576   syntax tree is available for read-only (non-compile) access
1577   to Python code; an _ast module was added.
1579 - SF bug #1167751: fix incorrect code being produced for generator expressions.
1580   The following code now raises a SyntaxError:  foo(a = i for i in range(10))
1582 - SF Bug #976608: fix SystemError when mtime of an imported file is -1.
1584 - SF Bug #887946: fix segfault when redirecting stdin from a directory.
1585   Provide a warning when a directory is passed on the command line.
1587 - Fix segfault with invalid coding.
1589 - SF bug #772896: unknown encoding results in MemoryError.
1591 - All iterators now have a Boolean value of True.  Formerly, some iterators
1592   supported a __len__() method which evaluated to False when the iterator
1593   was empty.
1595 - On 64-bit platforms, when __len__() returns a value that cannot be
1596   represented as a C int, raise OverflowError.
1598 - test__locale is skipped on OS X < 10.4 (only partial locale support is
1599   present).
1601 - SF bug #893549: parsing keyword arguments was broken with a few format
1602   codes.
1604 - Changes donated by Elemental Security to make it work on AIX 5.3
1605   with IBM's 64-bit compiler (SF patch #1284289).  This also closes SF
1606   bug #105470: test_pwd fails on 64bit system (Opteron).
1608 - Changes donated by Elemental Security to make it work on HP-UX 11 on
1609   Itanium2 with HP's 64-bit compiler (SF patch #1225212).
1611 - Disallow keyword arguments for type constructors that don't use them
1612   (fixes bug #1119418).
1614 - Forward UnicodeDecodeError into SyntaxError for source encoding errors.
1616 - SF bug #900092: When tracing (e.g. for hotshot), restore 'return' events for
1617   exceptions that cause a function to exit.
1619 - The implementation of set() and frozenset() was revised to use its
1620   own internal data structure.  Memory consumption is reduced by 1/3
1621   and there are modest speed-ups as well.  The API is unchanged.
1623 - SF bug #1238681:  freed pointer is used in longobject.c:long_pow().
1625 - SF bug #1229429: PyObject_CallMethod failed to decrement some
1626   reference counts in some error exit cases.
1628 - SF bug #1185883:  Python's small-object memory allocator took over
1629   a block managed by the platform C library whenever a realloc specified
1630   a small new size.  However, there's no portable way to know then how
1631   much of the address space following the pointer is valid, so there's no
1632   portable way to copy data from the C-managed block into Python's
1633   small-object space without risking a memory fault.  Python's small-object
1634   realloc now leaves such blocks under the control of the platform C
1635   realloc.
1637 - SF bug #1232517: An overflow error was not detected properly when
1638   attempting to convert a large float to an int in os.utime().
1640 - SF bug #1224347: hex longs now print with lowercase letters just
1641   like their int counterparts.
1643 - SF bug #1163563: the original fix for bug #1010677 ("thread Module
1644   Breaks PyGILState_Ensure()") broke badly in the case of multiple
1645   interpreter states; back out that fix and do a better job (see
1646   http://mail.python.org/pipermail/python-dev/2005-June/054258.html
1647   for a longer write-up of the problem).
1649 - SF patch #1180995: marshal now uses a binary format by default when
1650   serializing floats.
1652 - SF patch #1181301: on platforms that appear to use IEEE 754 floats,
1653   the routines that promise to produce IEEE 754 binary representations
1654   of floats now simply copy bytes around.
1656 - bug #967182: disallow opening files with 'wU' or 'aU' as specified by PEP
1657   278.
1659 - patch #1109424: int, long, float, complex, and unicode now check for the
1660   proper magic slot for type conversions when subclassed.  Previously the
1661   magic slot was ignored during conversion.  Semantics now match the way
1662   subclasses of str always behaved.  int/long/float, conversion of an instance
1663   to the base class has been moved to the proper nb_* magic slot and out of
1664   PyNumber_*().
1665   Thanks Walter D�rwald.
1667 - Descriptors defined in C with a PyGetSetDef structure, where the setter is
1668   NULL, now raise an AttributeError when attempting to set or delete the
1669   attribute.  Previously a TypeError was raised, but this was inconsistent
1670   with the equivalent pure-Python implementation.
1672 - It is now safe to call PyGILState_Release() before
1673   PyEval_InitThreads() (note that if there is reason to believe there
1674   are multiple threads around you still must call PyEval_InitThreads()
1675   before using the Python API; this fix is for extension modules that
1676   have no way of knowing if Python is multi-threaded yet).
1678 - Typing Ctrl-C whilst raw_input() was waiting in a build with threads
1679   disabled caused a crash.
1681 - Bug #1165306: instancemethod_new allowed the creation of a method
1682   with im_class == im_self == NULL, which caused a crash when called.
1684 - Move exception finalisation later in the shutdown process - this
1685   fixes the crash seen in bug #1165761
1687 - Added two new builtins, any() and all().
1689 - Defining a class with empty parentheses is now allowed
1690   (e.g., ``class C(): pass`` is no longer a syntax error).
1691   Patch #1176012 added support to the 'parser' module and 'compiler' package
1692   (thanks to logistix for that added support).
1694 - Patch #1115086: Support PY_LONGLONG in structmember.
1696 - Bug #1155938: new style classes did not check that __init__() was
1697   returning None.
1699 - Patch #802188: Report characters after line continuation character
1700   ('\') with a specific error message.
1702 - Bug #723201: Raise a TypeError for passing bad objects to 'L' format.
1704 - Bug #1124295: the __name__ attribute of file objects was
1705   inadvertently made inaccessible in restricted mode.
1707 - Bug #1074011: closing sys.std{out,err} now causes a flush() and
1708   an ferror() call.
1710 - min() and max() now support key= arguments with the same meaning as in
1711   list.sort().
1713 - The peephole optimizer now performs simple constant folding in expressions:
1714       (2+3) --> (5).
1716 - set and frozenset objects can now be marshalled.  SF #1098985.
1718 - Bug #1077106: Poor argument checking could cause memory corruption
1719   in calls to os.read().
1721 - The parser did not complain about future statements in illegal
1722   positions.  It once again reports a syntax error if a future
1723   statement occurs after anything other than a doc string.
1725 - Change the %s format specifier for str objects so that it returns a
1726   unicode instance if the argument is not an instance of basestring and
1727   calling __str__ on the argument returns a unicode instance.
1729 - Patch #1413181:  changed ``PyThreadState_Delete()`` to forget about the
1730   current thread state when the auto-GIL-state machinery knows about
1731   it (since the thread state is being deleted, continuing to remember it
1732   can't help, but can hurt if another thread happens to get created with
1733   the same thread id).
1735 Extension Modules
1736 -----------------
1738 - Patch #1380952: fix SSL objects timing out on consecutive read()s
1740 - Patch #1309579: wait3 and wait4 were added to the posix module.
1742 - Patch #1231053: The audioop module now supports encoding/decoding of alaw.
1743   In addition, the existing ulaw code was updated.
1745 - RFE #567972: Socket objects' family, type and proto properties are
1746   now exposed via new attributes.
1748 - Everything under lib-old was removed.  This includes the following modules:
1749     Para, addpack, cmp, cmpcache, codehack, dircmp, dump, find, fmt, grep,
1750     lockfile, newdir, ni, packmail, poly, rand, statcache, tb, tzparse,
1751     util, whatsound, whrandom, zmod
1753 - The following modules were removed:  regsub, reconvert, regex, regex_syntax.
1755 - re and sre were swapped, so help(re) provides full help.  importing sre
1756   is deprecated.  The undocumented re.engine variable no longer exists.
1758 - Bug #1448490: Fixed a bug that ISO-2022 codecs could not handle
1759   SS2 (single-shift 2) escape sequences correctly.
1761 - The unicodedata module was updated to the 4.1 version of the Unicode
1762   database. The 3.2 version is still available as unicodedata.db_3_2_0
1763   for applications that require this specific version (such as IDNA).
1765 - The timing module is no longer built by default.  It was deprecated
1766   in PEP 4 in Python 2.0 or earlier.
1768 - Patch 1433928: Added a new type, defaultdict, to the collections module.
1769   This uses the new __missing__ hook behavior added to dict (see above).
1771 - Bug #854823: socketmodule now builds on Sun platforms even when
1772   INET_ADDRSTRLEN is not defined.
1774 - Patch #1393157: os.startfile() now has an optional argument to specify
1775   a "command verb" to invoke on the file.
1777 - Bug #876637, prevent stack corruption when socket descriptor
1778   is larger than FD_SETSIZE.
1780 - Patch #1407135, bug #1424041: harmonize mmap behavior of anonymous memory.
1781   mmap.mmap(-1, size) now returns anonymous memory in both Unix and Windows.
1782   mmap.mmap(0, size) should not be used on Windows for anonymous memory.
1784 - Patch #1422385: The nis module now supports access to domains other
1785   than the system default domain.
1787 - Use Win32 API to implement os.stat/fstat. As a result, subsecond timestamps
1788   are reported, the limit on path name lengths is removed, and stat reports
1789   WindowsError now (instead of OSError).
1791 - Add bsddb.db.DBEnv.set_tx_timestamp allowing time based database recovery.
1793 - Bug #1413192, fix seg fault in bsddb if a transaction was deleted
1794   before the env.
1796 - Patch #1103116: Basic AF_NETLINK support.
1798 - Bug #1402308, (possible) segfault when using mmap.mmap(-1, ...)
1800 - Bug #1400822, _curses over{lay,write} doesn't work when passing 6 ints.
1801   Also fix ungetmouse() which did not accept arguments properly.
1802   The code now conforms to the documented signature.
1804 - Bug #1400115, Fix segfault when calling curses.panel.userptr()
1805   without prior setting of the userptr.
1807 - Fix 64-bit problems in bsddb.
1809 - Patch #1365916: fix some unsafe 64-bit mmap methods.
1811 - Bug #1290333: Added a workaround for cjkcodecs' _codecs_cn build
1812   problem on AIX.
1814 - Bug #869197: os.setgroups rejects long integer arguments
1816 - Bug #1346533, select.poll() doesn't raise an error if timeout > sys.maxint
1818 - Bug #1344508, Fix UNIX mmap leaking file descriptors
1820 - Patch #1338314, Bug #1336623: fix tarfile so it can extract
1821   REGTYPE directories from tarfiles written by old programs.
1823 - Patch #1407992, fixes broken bsddb module db associate when using
1824   BerkeleyDB 3.3, 4.0 or 4.1.
1826 - Get bsddb module to build with BerkeleyDB version 4.4
1828 - Get bsddb module to build with BerkeleyDB version 3.2
1830 - Patch #1309009, Fix segfault in pyexpat when the XML document is in latin_1,
1831   but Python incorrectly assumes it is in UTF-8 format
1833 - Fix parse errors in the readline module when compiling without threads.
1835 - Patch #1288833: Removed thread lock from socket.getaddrinfo on
1836   FreeBSD 5.3 and later versions which got thread-safe getaddrinfo(3).
1838 - Patches #1298449 and #1298499: Add some missing checks for error
1839   returns in cStringIO.c.
1841 - Patch #1297028: fix segfault if call type on MultibyteCodec,
1842   MultibyteStreamReader, or MultibyteStreamWriter
1844 - Fix memory leak in posix.access().
1846 - Patch #1213831: Fix typo in unicodedata._getcode.
1848 - Bug #1007046: os.startfile() did not accept unicode strings encoded in
1849   the file system encoding.
1851 - Patch #756021: Special-case socket.inet_aton('255.255.255.255') for
1852   platforms that don't have inet_aton().
1854 - Bug #1215928: Fix bz2.BZ2File.seek() for 64-bit file offsets.
1856 - Bug #1191043: Fix bz2.BZ2File.(x)readlines for files containing one
1857   line without newlines.
1859 - Bug #728515: mmap.resize() now resizes the file on Unix as it did
1860   on Windows.
1862 - Patch #1180695: Add nanosecond stat resolution, and st_gen,
1863   st_birthtime for FreeBSD.
1865 - Patch #1231069: The fcntl.ioctl function now uses the 'I' code for
1866   the request code argument, which results in more C-like behaviour
1867   for large or negative values.
1869 - Bug #1234979: For the argument of thread.Lock.acquire, the Windows
1870   implementation treated all integer values except 1 as false.
1872 - Bug #1194181: bz2.BZ2File didn't handle mode 'U' correctly.
1874 - Patch #1212117: os.stat().st_flags is now accessible as a attribute
1875   if available on the platform.
1877 - Patch #1103951: Expose O_SHLOCK and O_EXLOCK in the posix module if
1878   available on the platform.
1880 - Bug #1166660: The readline module could segfault if hook functions
1881   were set in a different thread than that which called readline.
1883 - collections.deque objects now support a remove() method.
1885 - operator.itemgetter() and operator.attrgetter() now support retrieving
1886   multiple fields.  This provides direct support for sorting on multiple
1887   keys (primary, secondary, etc).
1889 - os.access now supports Unicode path names on non-Win32 systems.
1891 - Patches #925152, #1118602: Avoid reading after the end of the buffer
1892   in pyexpat.GetInputContext.
1894 - Patches #749830, #1144555: allow UNIX mmap size to default to current
1895   file size.
1897 - Added functional.partial().  See PEP309.
1899 - Patch #1093585: raise a ValueError for negative history items in readline.
1900   {remove_history,replace_history}
1902 - The spwd module has been added, allowing access to the shadow password
1903   database.
1905 - stat_float_times is now True.
1907 - array.array objects are now picklable.
1909 - the cPickle module no longer accepts the deprecated None option in the
1910   args tuple returned by __reduce__().
1912 - itertools.islice() now accepts None for the start and step arguments.
1913   This allows islice() to work more readily with slices:
1914       islice(s.start, s.stop, s.step)
1916 - datetime.datetime() now has a strptime class method which can be used to
1917   create datetime object using a string and format.
1919 - Patch #1117961: Replace the MD5 implementation from RSA Data Security Inc
1920   with the implementation from http://sourceforge.net/projects/libmd5-rfc/.
1922 Library
1923 -------
1925 - Patch #1388073: Numerous __-prefixed attributes of unittest.TestCase have
1926   been renamed to have only a single underscore prefix.  This was done to
1927   make subclassing easier.
1929 - PEP 338: new module runpy defines a run_module function to support
1930   executing modules which provide access to source code or a code object
1931   via the PEP 302 import mechanisms.
1933 - The email module's parsedate_tz function now sets the daylight savings
1934   flag to -1 (unknown) since it can't tell from the date whether it should
1935   be set.
1937 - Patch #624325: urlparse.urlparse() and urlparse.urlsplit() results
1938   now sport attributes that provide access to the parts of the result.
1940 - Patch #1462498: sgmllib now handles entity and character references
1941   in attribute values.
1943 - Added the sqlite3 package. This is based on pysqlite2.1.3, and provides
1944   a DB-API interface in the standard library. You'll need sqlite 3.0.8 or
1945   later to build this - if you have an earlier version, the C extension
1946   module will not be built.
1948 - Bug #1460340: ``random.sample(dict)`` failed in various ways.  Dicts
1949   aren't officially supported here, and trying to use them will probably
1950   raise an exception some day.  But dicts have been allowed, and "mostly
1951   worked", so support for them won't go away without warning.
1953 - Bug #1445068: getpass.getpass() can now be given an explicit stream
1954   argument to specify where to write the prompt.
1956 - Patch #1462313, bug #1443328: the pickle modules now can handle classes
1957   that have __private names in their __slots__.
1959 - Bug #1250170: mimetools now handles socket.gethostname() failures gracefully.
1961 - patch #1457316: "setup.py upload" now supports --identity to select the
1962   key to be used for signing the uploaded code.
1964 - Queue.Queue objects now support .task_done() and .join() methods
1965   to make it easier to monitor when daemon threads have completed
1966   processing all enqueued tasks.  Patch #1455676.
1968 - popen2.Popen objects now preserve the command in a .cmd attribute.
1970 - Added the ctypes ffi package.
1972 - email 4.0 package now integrated.  This is largely the same as the email 3.0
1973   package that was included in Python 2.3, except that PEP 8 module names are
1974   now used (e.g. mail.message instead of email.Message).  The MIME classes
1975   have been moved to a subpackage (e.g. email.mime.text instead of
1976   email.MIMEText).  The old names are still supported for now.  Several
1977   deprecated Message methods have been removed and lots of bugs have been
1978   fixed.  More details can be found in the email package documentation.
1980 - Patches #1436130/#1443155: codecs.lookup() now returns a CodecInfo object
1981   (a subclass of tuple) that provides incremental decoders and encoders
1982   (a way to use stateful codecs without the stream API). Python functions
1983   codecs.getincrementaldecoder() and codecs.getincrementalencoder() as well
1984   as C functions PyCodec_IncrementalEncoder() and PyCodec_IncrementalDecoder()
1985   have been added.
1987 - Patch #1359365: Calling next() on a closed StringIO.String object raises
1988   a ValueError instead of a StopIteration now (like file and cString.String do).
1989   cStringIO.StringIO.isatty() will raise a ValueError now if close() has been
1990   called before (like file and StringIO.StringIO do).
1992 - A regrtest option -w was added to re-run failed tests in verbose mode.
1994 - Patch #1446372: quit and exit can now be called from the interactive
1995   interpreter to exit.
1997 - The function get_count() has been added to the gc module, and gc.collect()
1998   grew an optional 'generation' argument.
2000 - A library msilib to generate Windows Installer files, and a distutils
2001   command bdist_msi have been added.
2003 - PEP 343: new module contextlib.py defines decorator @contextmanager
2004   and helpful context managers nested() and closing().
2006 - The compiler package now supports future imports after the module docstring.
2008 - Bug #1413790: zipfile now sanitizes absolute archive names that are
2009   not allowed by the specs.
2011 - Patch #1215184: FileInput now can be given an opening hook which can
2012   be used to control how files are opened.
2014 - Patch #1212287: fileinput.input() now has a mode parameter for
2015   specifying the file mode input files should be opened with.
2017 - Patch #1215184: fileinput now has a fileno() function for getting the
2018   current file number.
2020 - Patch #1349274: gettext.install() now optionally installs additional
2021   translation functions other than _() in the builtin namespace.
2023 - Patch #1337756: fileinput now accepts Unicode filenames.
2025 - Patch #1373643: The chunk module can now read chunks larger than
2026   two gigabytes.
2028 - Patch #1417555: SimpleHTTPServer now returns Last-Modified headers.
2030 - Bug #1430298: It is now possible to send a mail with an empty
2031   return address using smtplib.
2033 - Bug #1432260: The names of lambda functions are now properly displayed
2034   in pydoc.
2036 - Patch #1412872: zipfile now sets the creator system to 3 (Unix)
2037   unless the system is Win32.
2039 - Patch #1349118: urllib now supports user:pass@ style proxy
2040   specifications, raises IOErrors when proxies for unsupported protocols
2041   are defined, and uses the https proxy on https redirections.
2043 - Bug #902075: urllib2 now supports 'host:port' style proxy specifications.
2045 - Bug #1407902: Add support for sftp:// URIs to urlparse.
2047 - Bug #1371247: Update Windows locale identifiers in locale.py.
2049 - Bug #1394565: SimpleHTTPServer now doesn't choke on query parameters
2050   any more.
2052 - Bug #1403410: The warnings module now doesn't get confused
2053   when it can't find out the module name it generates a warning for.
2055 - Patch #1177307: Added a new codec utf_8_sig for UTF-8 with a BOM signature.
2057 - Patch #1157027: cookielib mishandles RFC 2109 cookies in Netscape mode
2059 - Patch #1117398: cookielib.LWPCookieJar and .MozillaCookieJar now raise
2060   LoadError as documented, instead of IOError.  For compatibility,
2061   LoadError subclasses IOError.
2063 - Added the hashlib module.  It provides secure hash functions for MD5 and
2064   SHA1, 224, 256, 384, and 512.  Note that recent developments make the
2065   historic MD5 and SHA1 unsuitable for cryptographic-strength applications.
2066   In <http://mail.python.org/pipermail/python-dev/2005-December/058850.html>
2067   Ronald L. Rivest offered this advice for Python:
2069       "The consensus of researchers in this area (at least as
2070       expressed at the NIST Hash Function Workshop 10/31/05),
2071       is that SHA-256 is a good choice for the time being, but
2072       that research should continue, and other alternatives may
2073       arise from this research.  The larger SHA's also seem OK."
2075 - Added a subset of Fredrik Lundh's ElementTree package.  Available
2076   modules are xml.etree.ElementTree, xml.etree.ElementPath, and
2077   xml.etree.ElementInclude, from ElementTree 1.2.6.
2079 - Patch #1162825: Support non-ASCII characters in IDLE window titles.
2081 - Bug #1365984: urllib now opens "data:" URLs again.
2083 - Patch #1314396: prevent deadlock for threading.Thread.join() when an exception
2084   is raised within the method itself on a previous call (e.g., passing in an
2085   illegal argument)
2087 - Bug #1340337: change time.strptime() to always return ValueError when there
2088   is an error in the format string.
2090 - Patch #754022: Greatly enhanced webbrowser.py (by Oleg Broytmann).
2092 - Bug #729103: pydoc.py: Fix docother() method to accept additional
2093   "parent" argument.
2095 - Patch #1300515: xdrlib.py: Fix pack_fstring() to really use null bytes
2096   for padding.
2098 - Bug #1296004: httplib.py: Limit maximal amount of data read from the
2099   socket to avoid a MemoryError on Windows.
2101 - Patch #1166948: locale.py: Prefer LC_ALL, LC_CTYPE and LANG over LANGUAGE
2102   to get the correct encoding.
2104 - Patch #1166938: locale.py: Parse LANGUAGE as a colon separated list of
2105   languages.
2107 - Patch #1268314: Cache lines in StreamReader.readlines for performance.
2109 - Bug #1290505: Fix clearing the regex cache for time.strptime().
2111 - Bug #1167128: Fix size of a symlink in a tarfile to be 0.
2113 - Patch #810023: Fix off-by-one bug in urllib.urlretrieve reporthook
2114   functionality.
2116 - Bug #1163178: Make IDNA return an empty string when the input is empty.
2118 - Patch #848017: Make Cookie more RFC-compliant. Use CRLF as default output
2119   separator and do not output trailing semicolon.
2121 - Patch #1062060: urllib.urlretrieve() now raises a new exception, named
2122   ContentTooShortException, when the actually downloaded size does not
2123   match the Content-Length header.
2125 - Bug #1121494: distutils.dir_utils.mkpath now accepts Unicode strings.
2127 - Bug #1178484: Return complete lines from codec stream readers
2128   even if there is an exception in later lines, resulting in
2129   correct line numbers for decoding errors in source code.
2131 - Bug #1192315: Disallow negative arguments to clear() in pdb.
2133 - Patch #827386: Support absolute source paths in msvccompiler.py.
2135 - Patch #1105730: Apply the new implementation of commonprefix in posixpath
2136   to ntpath, macpath, os2emxpath and riscospath.
2138 - Fix a problem in Tkinter introduced by SF patch #869468: delete bogus
2139   __hasattr__ and __delattr__ methods on class Tk that were breaking
2140   Tkdnd.
2142 - Bug #1015140: disambiguated the term "article id" in nntplib docs and
2143   docstrings to either "article number" or "message id".
2145 - Bug #1238170: threading.Thread.__init__ no longer has "kwargs={}" as a
2146   parameter, but uses the usual "kwargs=None".
2148 - textwrap now processes text chunks at O(n) speed instead of O(n**2).
2149   Patch #1209527 (Contributed by Connelly).
2151 - urllib2 has now an attribute 'httpresponses' mapping from HTTP status code
2152   to W3C name (404 -> 'Not Found'). RFE #1216944.
2154 - Bug #1177468: Don't cache the /dev/urandom file descriptor for os.urandom,
2155   as this can cause problems with apps closing all file descriptors.
2157 - Bug #839151: Fix an attempt to access sys.argv in the warnings module;
2158   it can be missing in embedded interpreters
2160 - Bug #1155638: Fix a bug which affected HTTP 0.9 responses in httplib.
2162 - Bug #1100201: Cross-site scripting was possible on BaseHTTPServer via
2163   error messages.
2165 - Bug #1108948: Cookie.py produced invalid JavaScript code.
2167 - The tokenize module now detects and reports indentation errors.
2168   Bug #1224621.
2170 - The tokenize module has a new untokenize() function to support a full
2171   roundtrip from lexed tokens back to Python source code.  In addition,
2172   the generate_tokens() function now accepts a callable argument that
2173   terminates by raising StopIteration.
2175 - Bug #1196315: fix weakref.WeakValueDictionary constructor.
2177 - Bug #1213894: os.path.realpath didn't resolve symlinks that were the first
2178   component of the path.
2180 - Patch #1120353: The xmlrpclib module provides better, more transparent,
2181   support for datetime.{datetime,date,time} objects.  With use_datetime set
2182   to True, applications shouldn't have to fiddle with the DateTime wrapper
2183   class at all.
2185 - distutils.commands.upload was added to support uploading distribution
2186   files to PyPI.
2188 - distutils.commands.register now encodes the data as UTF-8 before posting
2189   them to PyPI.
2191 - decimal operator and comparison methods now return NotImplemented
2192   instead of raising a TypeError when interacting with other types.  This
2193   allows other classes to implement __radd__ style methods and have them
2194   work as expected.
2196 - Bug #1163325:  Decimal infinities failed to hash.  Attempting to
2197   hash a NaN raised an InvalidOperation instead of a TypeError.
2199 - Patch #918101: Add tarfile open mode r|* for auto-detection of the
2200   stream compression; add, for symmetry reasons, r:* as a synonym of r.
2202 - Patch #1043890: Add extractall method to tarfile.
2204 - Patch #1075887: Don't require MSVC in distutils if there is nothing
2205   to build.
2207 - Patch #1103407: Properly deal with tarfile iterators when untarring
2208   symbolic links on Windows.
2210 - Patch #645894: Use getrusage for computing the time consumption in
2211   profile.py if available.
2213 - Patch #1046831: Use get_python_version where appropriate in sysconfig.py.
2215 - Patch #1117454: Remove code to special-case cookies without values
2216   in LWPCookieJar.
2218 - Patch #1117339: Add cookielib special name tests.
2220 - Patch #1112812: Make bsddb/__init__.py more friendly for modulefinder.
2222 - Patch #1110248: SYNC_FLUSH the zlib buffer for GZipFile.flush.
2224 - Patch #1107973: Allow to iterate over the lines of a tarfile.ExFileObject.
2226 - Patch #1104111: Alter setup.py --help and --help-commands.
2228 - Patch #1121234: Properly cleanup _exit and tkerror commands.
2230 - Patch #1049151: xdrlib now unpacks booleans as True or False.
2232 - Fixed bug in a NameError bug in cookielib.  Patch #1116583.
2234 - Applied a security fix to SimpleXMLRPCserver (PSF-2005-001).  This
2235   disables recursive traversal through instance attributes, which can
2236   be exploited in various ways.
2238 - Bug #1222790: in SimpleXMLRPCServer, set the reuse-address and close-on-exec
2239   flags on the HTTP listening socket.
2241 - Bug #792570: SimpleXMLRPCServer had problems if the request grew too large.
2242   Fixed by reading the HTTP body in chunks instead of one big socket.read().
2244 - Patches #893642, #1039083: add allow_none, encoding arguments to
2245   constructors of SimpleXMLRPCServer and CGIXMLRPCRequestHandler.
2247 - Bug #1110478: Revert os.environ.update to do putenv again.
2249 - Bug #1103844: fix distutils.install.dump_dirs() with negated options.
2251 - os.{SEEK_SET, SEEK_CUR, SEEK_END} have been added for convenience.
2253 - Enhancements to the csv module:
2255   + Dialects are now validated by the underlying C code, better
2256     reflecting its capabilities, and improving its compliance with
2257     PEP 305.
2258   + Dialect parameter parsing has been re-implemented to improve error
2259     reporting.
2260   + quotechar=None and quoting=QUOTE_NONE now work the way PEP 305
2261     dictates.
2262   + the parser now removes the escapechar prefix from escaped characters.
2263   + when quoting=QUOTE_NONNUMERIC, the writer now tests for numeric
2264     types, rather than any object that can be represented as a numeric.
2265   + when quoting=QUOTE_NONNUMERIC, the reader now casts unquoted fields
2266     to floats.
2267   + reader now allows \r characters to be quoted (previously it only allowed
2268     \n to be quoted).
2269   + writer doublequote handling improved.
2270   + Dialect classes passed to the module are no longer instantiated by
2271     the module before being parsed (the former validation scheme required
2272     this, but the mechanism was unreliable).
2273   + The dialect registry now contains instances of the internal
2274     C-coded dialect type, rather than references to python objects.
2275   + the internal c-coded dialect type is now immutable.
2276   + register_dialect now accepts the same keyword dialect specifications
2277     as the reader and writer, allowing the user to register dialects
2278     without first creating a dialect class.
2279   + a configurable limit to the size of parsed fields has been added -
2280     previously, an unmatched quote character could result in the entire
2281     file being read into the field buffer before an error was reported.
2282   + A new module method csv.field_size_limit() has been added that sets
2283     the parser field size limit (returning the former limit). The initial
2284     limit is 128kB.
2285   + A line_num attribute has been added to the reader object, which tracks
2286     the number of lines read from the source iterator. This is not
2287     the same as the number of records returned, as records can span
2288     multiple lines.
2289   + reader and writer objects were not being registered with the cyclic-GC.
2290     This has been fixed.
2292 - _DummyThread objects in the threading module now delete self.__block that is
2293   inherited from _Thread since it uses up a lock allocated by 'thread'.  The
2294   lock primitives tend to be limited in number and thus should not be wasted on
2295   a _DummyThread object.  Fixes bug #1089632.
2297 - The imghdr module now detects Exif files.
2299 - StringIO.truncate() now correctly adjusts the size attribute.
2300   (Bug #951915).
2302 - locale.py now uses an updated locale alias table (built using
2303   Tools/i18n/makelocalealias.py, a tool to parse the X11 locale
2304   alias file); the encoding lookup was enhanced to use Python's
2305   encoding alias table.
2307 - moved deprecated modules to Lib/lib-old:  whrandom, tzparse, statcache.
2309 - the pickle module no longer accepts the deprecated None option in the
2310   args tuple returned by __reduce__().
2312 - optparse now optionally imports gettext.  This allows its use in setup.py.
2314 - the pickle module no longer uses the deprecated bin parameter.
2316 - the shelve module no longer uses the deprecated binary parameter.
2318 - the pstats module no longer uses the deprecated ignore() method.
2320 - the filecmp module no longer uses the deprecated use_statcache argument.
2322 - unittest.TestCase.run() and unittest.TestSuite.run() can now be successfully
2323   extended or overridden by subclasses.  Formerly, the subclassed method would
2324   be ignored by the rest of the module.  (Bug #1078905).
2326 - heapq.nsmallest() and heapq.nlargest() now support key= arguments with
2327   the same meaning as in list.sort().
2329 - Bug #1076985: ``codecs.StreamReader.readline()`` now calls ``read()`` only
2330   once when a size argument is given. This prevents a buffer overflow in the
2331   tokenizer with very long source lines.
2333 - Bug #1083110: ``zlib.decompress.flush()`` would segfault if called
2334   immediately after creating the object, without any intervening
2335   ``.decompress()`` calls.
2337 - The reconvert.quote function can now emit triple-quoted strings.  The
2338   reconvert module now has some simple documentation.
2340 - ``UserString.MutableString`` now supports negative indices in
2341   ``__setitem__`` and ``__delitem__``
2343 - Bug #1149508: ``textwrap`` now handles hyphenated numbers (eg. "2004-03-05")
2344   correctly.
2346 - Partial fixes for SF bugs #1163244 and #1175396: If a chunk read by
2347   ``codecs.StreamReader.readline()`` has a trailing "\r", read one more
2348   character even if the user has passed a size parameter to get a proper
2349   line ending. Remove the special handling of a "\r\n" that has been split
2350   between two lines.
2352 - Bug #1251300: On UCS-4 builds the "unicode-internal" codec will now complain
2353   about illegal code points. The codec now supports PEP 293 style error
2354   handlers.
2356 - Bug #1235646: ``codecs.StreamRecoder.next()`` now reencodes the data it reads
2357   from the input stream, so that the output is a byte string in the correct
2358   encoding instead of a unicode string.
2360 - Bug #1202493: Fixing SRE parser to handle '{}' as perl does, rather than
2361   considering it exactly like a '*'.
2363 - Bug #1245379: Add "unicode-1-1-utf-7" as an alias for "utf-7" to
2364   ``encodings.aliases``.
2366 - ` uu.encode()`` and ``uu.decode()`` now support unicode filenames.
2368 - Patch #1413711: Certain patterns of differences were making difflib
2369   touch the recursion limit.
2371 - Bug #947906: An object oriented interface has been added to the calendar
2372   module. It's possible to generate HTML calendar now and the module can be
2373   called as a script (e.g. via ``python -mcalendar``). Localized month and
2374   weekday names can be ouput (even if an exotic encoding is used) using
2375   special classes that use unicode.
2377 Build
2378 -----
2380 - Fix test_float, test_long, and test_struct failures on Tru64 with gcc
2381   by using -mieee gcc option.
2383 - Patch #1432345: Make python compile on DragonFly.
2385 - Build support for Win64-AMD64 was added.
2387 - Patch #1428494: Prefer linking against ncursesw over ncurses library.
2389 - Patch #881820: look for openpty and forkpty also in libbsd.
2391 - The sources of zlib are now part of the Python distribution (zlib 1.2.3).
2392   The zlib module is now builtin on Windows.
2394 - Use -xcode=pic32 for CCSHARED on Solaris with SunPro.
2396 - Bug #1189330: configure did not correctly determine the necessary
2397   value of LINKCC if python was built with GCC 4.0.
2399 - Upgrade Windows build to zlib 1.2.3 which eliminates a potential security
2400   vulnerability in zlib 1.2.1 and 1.2.2.
2402 - EXTRA_CFLAGS has been introduced as an environment variable to hold compiler
2403   flags that change binary compatibility.  Changes were also made to
2404   distutils.sysconfig to also use the environment variable when used during
2405   compilation of the interpreter and of C extensions through distutils.
2407 - SF patch 1171735: Darwin 8's headers are anal about POSIX compliance,
2408   and linking has changed (prebinding is now deprecated, and libcc_dynamic
2409   no longer exists). This configure patch makes things right.
2411 - Bug #1158607: Build with --disable-unicode again.
2413 - spwdmodule.c is built only if either HAVE_GETSPNAM or HAVE_HAVE_GETSPENT is
2414   defined.  Discovered as a result of not being able to build on OS X.
2416 - setup.py now uses the directories specified in LDFLAGS using the -L option
2417   and in CPPFLAGS using the -I option for adding library and include
2418   directories, respectively, for compiling extension modules against.  This has
2419   led to the core being compiled using the values in CPPFLAGS.  It also removes
2420   the need for the special-casing of both DarwinPorts and Fink for darwin since
2421   the proper directories can be specified in LDFLAGS (``-L/sw/lib`` for Fink,
2422   ``-L/opt/local/lib`` for DarwinPorts) and CPPFLAGS (``-I/sw/include`` for
2423   Fink, ``-I/opt/local/include`` for DarwinPorts).
2425 - Test in configure.in that checks for tzset no longer dependent on tm->tm_zone
2426   to exist in the struct (not required by either ISO C nor the UNIX 2 spec).
2427   Tests for sanity in tzname when HAVE_TZNAME defined were also defined.
2428   Closes bug #1096244.  Thanks Gregory Bond.
2430 C API
2431 -----
2433 - ``PyMem_{Del, DEL}`` and ``PyMem_{Free, FREE}`` no longer map to
2434   ``PyObject_{Free, FREE}``.  They map to the system ``free()`` now.  If memory
2435   is obtained via the ``PyObject_`` family, it must be released via the
2436   ``PyObject_`` family, and likewise for the ``PyMem_`` family.  This has
2437   always been officially true, but when Python's small-object allocator was
2438   introduced, an attempt was made to cater to a few extension modules
2439   discovered at the time that obtained memory via ``PyObject_New`` but
2440   released it via ``PyMem_DEL``.  It's years later, and if such code still
2441   exists it will fail now (probably with segfaults, but calling wrong
2442   low-level memory management functions can yield many symptoms).
2444 - Added a C API for set and frozenset objects.
2446 - Removed PyRange_New().
2448 - Patch #1313939: PyUnicode_DecodeCharmap() accepts a unicode string as the
2449   mapping argument now. This string is used as a mapping table. Byte values
2450   greater than the length of the string and 0xFFFE are treated as undefined
2451   mappings.
2454 Tests
2455 -----
2457 - In test_os, st_?time is now truncated before comparing it with ST_?TIME.
2459 - Patch #1276356: New resource "urlfetch" is implemented.  This enables
2460   even impatient people to run tests that require remote files.
2463 Documentation
2464 -------------
2466 - Bug #1402224: Add warning to dl docs about crashes.
2468 - Bug #1396471: Document that Windows' ftell() can return invalid
2469   values for text files with UNIX-style line endings.
2471 - Bug #1274828: Document os.path.splitunc().
2473 - Bug #1190204: Clarify which directories are searched by site.py.
2475 - Bug #1193849: Clarify os.path.expanduser() documentation.
2477 - Bug #1243192: re.UNICODE and re.LOCALE affect \d, \D, \s and \S.
2479 - Bug #755617: Document the effects of os.chown() on Windows.
2481 - Patch #1180012: The documentation for modulefinder is now in the library reference.
2483 - Patch #1213031: Document that os.chown() accepts argument values of -1.
2485 - Bug #1190563: Document os.waitpid() return value with WNOHANG flag.
2487 - Bug #1175022: Correct the example code for property().
2489 - Document the IterableUserDict class in the UserDict module.
2490   Closes bug #1166582.
2492 - Remove all latent references for "Macintosh" that referred to semantics for
2493   Mac OS 9 and change to reflect the state for OS X.
2494   Closes patch #1095802.  Thanks Jack Jansen.
2500 New platforms
2501 -------------
2503 - FreeBSD 7 support is added.
2506 Tools/Demos
2507 -----------
2509 - Created Misc/Vim/vim_syntax.py to auto-generate a python.vim file in that
2510   directory for syntax highlighting in Vim.  Vim directory was added and placed
2511   vimrc to it (was previous up a level).
2513 - Added two new files to Tools/scripts: pysource.py, which recursively
2514   finds Python source files, and findnocoding.py, which finds Python
2515   source files that need an encoding declaration.
2516   Patch #784089, credits to Oleg Broytmann.
2518 - Bug #1072853: pindent.py used an uninitialized variable.
2520 - Patch #1177597: Correct Complex.__init__.
2522 - Fixed a display glitch in Pynche, which could cause the right arrow to
2523   wiggle over by a pixel.
2525 ----
2527 **(For information about older versions, consult the HISTORY file.)**