Fix the tag.
[python/dscho.git] / Misc / NEWS
blob2152f5cf14237539a360a45f85823681427ee966
1 +++++++++++
2 Python News
3 +++++++++++
5 (editors: check NEWS.help for information about editing NEWS using ReST.)
7 What's New in Python 3.0a5?
8 ===========================
10 *Release date: 08-May-2008*
12 Core and Builtins
13 -----------------
15 - Fix misbehaviour of PyLong_FromSsize_t on systems where sizeof(size_t) >
16   sizeof(long).
18 - Issue #2221: Corrected a SystemError "error return without exception set",
19   when the code executed by exec() raises an exception, and sys.stdout.flush()
20   also raises an error.
22 - Bug #2565: The repr() of type objects now calls them 'class', 
23   not 'type' - whether they are builtin types or not.
25 - The command line processing was converted to pass Unicode strings
26   through as unmodified as possible; as a consequence, the C API
27   related to command line arguments was changed to use wchar_t.
29 - All backslashes in raw strings are interpreted literally.  This means that
30   '\u' and '\U' escapes are not treated specially.
32 Extension Modules
33 -----------------
35 Library
36 -------
38 - ctypes objects now support the PEP3118 buffer interface
40 - Issue #2682: ctypes callback functions now longer contain a cyclic
41   reference to themselves.
43 - Issue #2058: Remove the buf attribute and add __slots__ to the TarInfo
44   class in order to reduce tarfile's memory usage.
46 - Bug #2606: Avoid calling .sort() on a dict_keys object.
48 - The bundled libffi copy is now in sync with the recently released
49   libffi3.0.5 version, apart from some small changes to
50   Modules/_ctypes/libffi/configure.ac.
52 Build
53 -----
55 - Issue #1496032: On alpha, use -mieee when gcc is the compiler.
57 - "make install" is now an alias for "make altinstall", to prevent
58   accidentally overwriting a Python 2.x installation.
59   Use "make fullinstall" to force Python 3.0 to be installed as
60   "python".
62 - Issue #2544: On HP-UX systems, use 'gcc -shared' for linking when
63   gcc is used as compiler.
65 What's New in Python 3.0a4?
66 ===========================
68 *Release date: 02-Apr-2008*
70 Core and Builtins
71 -----------------
73 - Bug #2301: Don't try decoding the source code into the original
74   encoding for syntax errors.
76 Extension Modules
77 -----------------
79 - The dl module was removed, use the ctypes module instead.
81 - Use wchar_t functions in _locale module.
83 Library
84 -------
86 - The class distutils.commands.build_py.build_py_2to3 can be used
87   as a build_py replacement to automatically run 2to3 on modules
88   that are going to be installed.
90 - A new pickle protocol (protocol 3) is added with explicit support
91   for bytes.  This is the default protocol.  It intentionally cannot
92   be unpickled by Python 2.x.
94 - When a pickle written by Python 2.x contains an (8-bit) str
95   instance, this is now decoded to a (Unicode) str instance.  The
96   encoding used to do this defaults to ASCII, but can be overridden
97   via two new keyword arguments to the Unpickler class.  Previously
98   this would create bytes instances, which is usually wrong: str
99   instances are often used to pickle attribute names etc., and text is
100   more common than binary data anyway.
102 - Default to ASCII as the locale.getpreferredencoding, if the POSIX
103   system doesn't support CODESET and LANG isn't set or doesn't
104   allow deduction of an encoding.
106 - Issue #1202: zlib.crc32 and zlib.adler32 now return an unsigned value.
108 - Issue #719888: Updated tokenize to use a bytes API. generate_tokens has been
109   renamed tokenize and now works with bytes rather than strings. A new
110   detect_encoding function has been added for determining source file encoding
111   according to PEP-0263. Token sequences returned by tokenize always start
112   with an ENCODING token which specifies the encoding used to decode the file.
113   This token is used to encode the output of untokenize back to bytes.
115 What's New in Python 3.0a3?
116 ===========================
118 *Release date: 29-Feb-2008*
120 Core and Builtins
121 -----------------
123 - Issue #2282: io.TextIOWrapper was not overriding seekable() from io.IOBase.
125 - Issue #2115: Important speedup in setting __slot__ attributes.  Also 
126   prevent a possible crash: an Abstract Base Class would try to access a slot 
127   on a registered virtual subclass.
129 - Fixed repr() and str() of complex numbers with infinity or nan as real or
130   imaginary part.
132 - Clear all free list during a gc.collect() of the highest generation in order
133   to allow pymalloc to free more arenas. Python may give back memory to the
134   OS earlier.
136 - Issue #2045: Fix an infinite recursion triggered when printing a subclass of
137   collections.defaultdict, if its default_factory is set to a bound method.
139 - Fixed a minor memory leak in dictobject.c. The content of the free
140   list was not freed on interpreter shutdown.
142 - Limit free list of method and builtin function objects to 256 entries
143   each.
145 - Patch #1953: Added ``sys._compact_freelists()`` and the C API functions
146   ``PyInt_CompactFreeList`` and ``PyFloat_CompactFreeList``
147   to compact the internal free lists of pre-allocted ints and floats.
149 - Bug #1983: Fixed return type of fork(), fork1() and forkpty() calls.
150   Python expected the return type int but the fork familie returns pi_t.
152 - Issue #1678380: Fix a bug that identifies 0j and -0j when they appear
153   in the same code unit.
155 - Issue #2025 :  Add tuple.count() and tuple.index() methods to comply with
156   the collections.Sequence API.
158 - Fixed multiple reinitialization of the Python interpreter. The small int
159   list in longobject.c has caused a seg fault during the third finalization.
161 - Issue #1973: bytes.fromhex('') raises SystemError
163 - Issue #1771: remove cmp parameter from sorted() and list.sort()
165 - Issue #1969: split and rsplit in bytearray are inconsistent
167 - map() and no longer accepts None for the first argument.
168   Use zip() instead.
170 - Issue #1769: Now int("- 1") is not allowed any more.
172 - Object/longobject.c: long(float('nan')) raises an OverflowError instead
173   of returning 0.
175 - Issue #1762972: __file__ points to the source file instead of the pyc/pyo
176   file if the py file exists.
178 - Issue #1393: object_richcompare() returns NotImplemented instead of
179   False if the objects aren't equal, to give the other side a chance.
181 - Issue #1692: Interpreter was not displaying location of SyntaxError.
183 - Improve some exception messages when Windows fails to load an extension
184   module. Now we get for example '%1 is not a valid Win32 application' instead
185   of 'error code 193'.  Also use Unicode strings to deal with non-English
186   locales.
188 - Issue #1587: Added instancemethod wrapper for PyCFunctions. The Python C API
189   has gained a new type *PyInstanceMethod_Type* and the functions
190   *PyInstanceMethod_Check(o)*, *PyInstanceMethod_New(func)* and
191   *PyInstanceMethod_Function(im)*.
193 - Constants gc.DEBUG_OBJECT and gc.DEBUG_INSTANCE have been removed from the
194   gc module; gc.DEBUG_COLLECTABLE or gc.DEBUG_UNCOLLECTABLE are now enough to
195   print the corresponding list of objects considered by the garbage collector.
197 - Issue #1573: Improper use of the keyword-only syntax makes the parser crash.
199 - Issue #1564: The set implementation should special-case PyUnicode instead
200   of PyString.
202 - Patch #1031213: Decode source line in SyntaxErrors back to its
203   original source encoding.
205 - inspect.getsource() includes the decorators again.
207 - Bug #1713: posixpath.ismount() claims symlink to a mountpoint is a
208   mountpoint.
210 - Fix utf-8-sig incremental decoder, which didn't recognise a BOM when the
211   first chunk fed to the decoder started with a BOM, but was longer than 3
212   bytes.
215 Extension Modules
216 -----------------
218 - Code for itertools ifilter(), imap(), and izip() moved to bultins and
219   renamed to filter(), map(), and zip().  Also, renamed izip_longest()
220   to zip_longest() and ifilterfalse() to filterfalse().
222 - Issue #1762972: Readded the reload() function as imp.reload()
224 - Bug #2111: mmap segfaults when trying to write a block opened with PROT_READ
226 - #2063: correct order of utime and stime in os.times() result on Windows.
229 Library
230 -------
232 - Weakref dictionaries now inherit from MutableMapping.
233   XXX their API still needs to be modernized (i.e. eliminate the iter methods).
235 - Created new UserDict class in collections module.  This one inherits from and
236   complies with the MutableMapping ABC.  Also, moved UserString and UserList
237   to the collections module.  The MutableUserString class was removed.
239 - Removed UserDict.DictMixin.  Replaced all its uses with
240   collections.MutableMapping.
242 - Issue #1703: getpass() should flush after writing prompt.
244 - Issue #1585: IDLE uses non-existent xrange() function.
246 - Issue #1578: Problems in win_getpass.
248 Build
249 -----
251 - Renamed --enable-unicode configure flag to --with-wide-unicode, since
252   Unicode strings can't be disabled anymore.
255 C API
256 -----
258 - Issue #1629: Renamed Py_Size, Py_Type and Py_Refcnt to Py_SIZE,
259   Py_TYPE and Py_REFCNT.
261 - New API PyImport_ImportModuleNoBlock(), works like PyImport_ImportModule()
262   but won't block on the import lock (returning an error instead).
265 What's New in Python 3.0a2?
266 ===========================
268 *Release date: 07-Dec-2007*
270 (Note: this list is incomplete.)
272 Core and Builtins
273 -----------------
275 - str8 now has the same construction signature as bytes.
277 - Comparisons between str and str8 now return False/True for ==/!=.  sqlite3
278   returns str8 when recreating on object from it's __conform__ value.  The
279   struct module returns str8 for all string-related formats.  This was true
280   before this change, but becomes more apparent thanks to string comparisons
281   always being False.
283 - Replaced `PyFile_FromFile()` with `PyFile_FromFd(fd, name. mode, buffer, 
284   encoding, newline)`
286 - Fixed `imp.find_module()` to obey the -*- coding: -*- header.
288 - Changed `__file__` and `co_filename` to unicode. The path names are decoded
289   with `Py_FileSystemDefaultEncoding` and a new API method 
290   `PyUnicode_DecodeFSDefault(char*)` was added.
292 - io.open() and _fileio.FileIO have grown a new argument closefd. A false
293   value disables the closing of the file descriptor.
295 - Added a new option -b to issues warnings (-bb for errors) about certain
296   operations between bytes/buffer and str like str(b'') and comparsion.
298 - The standards streams sys.stdin, stdout and stderr may be None when the
299   when the C runtime library returns an invalid file descriptor for the
300   streams (fileno(stdin) < 0). For now this happens only for Windows GUI
301   apps and scripts started with `pythonw.exe`.
303 - Added PCbuild9 directory for VS 2008.
305 - Renamed structmember.h WRITE_RESTRICTED to PY_WRITE_RESTRICTED to work
306   around a name clash with VS 2008 on Windows.
308 - Unbound methods are gone for good. ClassObject.method returns an ordinary
309   function object, instance.method still returns a bound method object.
310   The API of bound methods is cleaned up, too. The im_class attribute is
311   removed and im_func + im_self are renamed to __func__ and __self__. The
312   factory PyMethod_New takes only func and instance as argument.
314 - intobject.h is no longer included by Python.h. The remains were moved
315   to longobject.h. It still exists to define several aliases from PyInt_
316   to PyLong_ functions.
318 - Removed sys.maxint, use sys.maxsize instead.
321 Extension Modules
322 -----------------
324 - The `hotshot` profiler has been removed; use `cProfile` instead.
327 Library
328 -------
330 - When loading an external file using testfile(), the passed-in encoding
331   argument was being ignored if __loader__ is defined and forcing the source to
332   be UTF-8.
334 - The methods `os.tmpnam()`, `os.tempnam()` and `os.tmpfile()` have been
335   removed in favor of the tempfile module.
337 - Removed the 'new' module.
339 - Removed all types from the 'types' module that are easily accessable through
340   builtins.
343 What's New in Python 3.0a1?
344 ==========================
346 *Release date: 31-Aug-2007*
348 Core and Builtins
349 -----------------
351 - PEP 3131: Support non-ASCII identifiers.
353 - PEP 3120: Change default encoding to UTF-8.
355 - PEP 3123: Use proper C inheritance for PyObject.
357 - Removed the __oct__ and __hex__ special methods and added a bin()
358   builtin function.
360 - PEP 3127: octal literals now start with "0o". Old-style octal literals
361   are invalid. There are binary literals with a prefix of "0b".
362   This also affects int(x, 0).
364 - None, True, False are now keywords.
366 - PEP 3119: isinstance() and issubclass() can be overridden.
368 - Remove BaseException.message.
370 - Remove tuple parameter unpacking (PEP 3113).
372 - Remove the f_restricted attribute from frames.  This naturally leads to the
373   removal of PyEval_GetRestricted() and PyFrame_IsRestricted().
375 - PEP 3132 was accepted. That means that you can do ``a, *b = range(5)``
376   to assign 0 to a and [1, 2, 3, 4] to b.
378 - range() now returns an iterator rather than a list.  Floats are not allowed.
379   xrange() is no longer defined.
381 - Patch #1660500: hide iteration variable in list comps, add set comps
382   and use common code to handle compilation of iterative expressions
384 - By default, != returns the opposite of ==, unless the latter returns
385   NotImplemented.
387 - Patch #1680961: sys.exitfunc has been removed and replaced with a private
388   C-level API.
390 - PEP 3115: new metaclasses: the metaclass is now specified as a
391   keyword arg in the class statement, which can now use the full syntax of
392   a parameter list. Also, the metaclass can implement a __prepare__ function
393   which will be called to create the dictionary for the new class namespace.
395 - The long-deprecated argument "pend" of PyFloat_FromString() has been
396   removed.
398 - The dir() function has been extended to call the __dir__() method on
399   its argument, if it exists. If not, it will work like before. This allows
400   customizing the output of dir() in the presence of a __getattr__().
402 - Removed support for __members__ and __methods__.
404 - Removed indexing/slicing on BaseException.
406 - input() became raw_input(): the name input() now implements the
407   functionality formerly known as raw_input(); the name raw_input()
408   is no longer defined.
410 - Classes listed in an 'except' clause must inherit from BaseException.
412 - PEP 3106: dict.iterkeys(), .iteritems(), .itervalues() are now gone;
413   and .keys(), .items(), .values() return dict views, which behave
414   like sets.
416 - PEP 3105: print is now a function.  Also (not in the PEP) the
417   'softspace' attribute of files is now gone (since print() doesn't use
418   it).  A side effect of this change is that you can get incomplete
419   output lines in interactive sessions:
421   >>> print(42, end="")
422   42>>>
424   We may be able to fix this after the I/O library rewrite.
426 - PEP 3102: keyword-only arguments.
428 - Int/Long unification is complete.  The 'long' built-in type
429   and literals with trailing 'L' or 'l' have been removed.
430   Performance may be sub-optimal (haven't really benchmarked).
432 - 'except E, V' must now be spelled as 'except E as V' and deletes V
433   at the end of the except clause; V must be a simple name.
435 - Added function annotations per PEP 3107.
437 - Added nonlocal declaration from PEP 3104
439   >>> def f(x):
440   ...     def inc():
441   ...         nonlocal x
442   ...         x += 1
443   ...         return x
444   ...     return inc
445   ...
446   >>> inc = f(0)
447   >>> inc()
448   1
449   >>> inc()
450   2
452 - Moved intern() to sys.intern().
454 - exec is now a function.
456 - Renamed nb_nonzero to nb_bool and __nonzero__ to __bool__.
458 - Classic classes are a thing of the past.  All classes are new style.
460 - Exceptions *must* derive from BaseException.
462 - Integer division always returns a float.  The -Q option is no more.
463   All the following are gone:
464    * PyNumber_Divide and PyNumber_InPlaceDivide
465    * __div__, __rdiv__, and __idiv__
466    * nb_divide, nb_inplace_divide
467    * operator.div, operator.idiv, operator.__div__, operator.__idiv__
468   (Only __truediv__ and __floordiv__ remain, not sure how to handle them
469    if we want to re-use __div__ and friends.  If we do, it will make
470    it harder to write code for both 2.x and 3.x.)
472 - 'as' and 'with' are keywords.
474 - Absolute import is the default behavior for 'import foo' etc.
476 - Removed support for syntax:
477   backticks (ie, `x`), <>
479 - Removed these Python builtins:
480   apply(), callable(), coerce(), execfile(), file(), reduce(), reload()
482 - Removed these Python methods:
483   {}.has_key
485 - Removed these opcodes:
486   BINARY_DIVIDE, INPLACE_DIVIDE, UNARY_CONVERT
488 - Remove C API support for restricted execution.
490 - zip(), map() and filter() now return iterators, behaving like their
491   itertools counterparts. This also affect map()'s behavior on
492   sequences of unequal length -- it now stops after the shortest one
493   is exhausted.
495 - Additions:
496   set literals, set comprehensions, ellipsis literal.
498 - Added class decorators per PEP 3129.
501 Extension Modules
502 -----------------
504 - Remove the imageop module.  Obsolete long with its unit tests becoming
505   useless from the removal of rgbimg and imgfile.
507 - Removed these attributes from Python modules:
508   * operator module: div, idiv, __div__, __idiv__, isCallable, sequenceIncludes
509   * sys module: exc_clear(), exc_type, exc_value, exc_traceback
512 Library
513 -------
515 - Remove the compiler package.  Use of the _ast module and (an eventual)
516   AST -> bytecode mechanism.
518 - Removed these modules:
519   * audiodev, Bastion, bsddb185, exceptions, linuxaudiodev,
520     md5, MimeWriter, mimify, popen2,
521     rexec, sets, sha, stringold, strop, sunaudiodev, timing, xmllib.
523 - Moved these modules to Tools/Demos:
524   * toaiff
526 - Remove obsolete IRIX modules: al/AL, cd/CD, cddb, cdplayer, cl/CL, DEVICE,
527   ERRNO, FILE, fl/FL, flp, fm, GET, gl/GL, GLWS, IN, imgfile, IOCTL, jpeg,
528   panel, panelparser, readcd, sgi, sv/SV, torgb, WAIT.
530 - Remove obsolete functions:
531   * commands.getstatus(), os.popen*,
533 - Remove functions in the string module that are also string methods;
534   Remove string.{letters, lowercase, uppercase}.
536 - Remove support for long obsolete platforms: plat-aix3, plat-irix5.
538 - Remove xmlrpclib.SlowParser.  It was based on xmllib.
540 - Patch #1680961: atexit has been reimplemented in C.
542 - Add new codecs for UTF-32, UTF-32-LE and UTF-32-BE.
545 Build
546 -----
548 C API
549 -----
551 - Removed these Python slots:
552   __coerce__, __div__, __idiv__, __rdiv__
554 - Removed these C APIs:
555   PyNumber_Coerce(), PyNumber_CoerceEx(), PyMember_Get, PyMember_Set
557 - Removed these C slots/fields:
558   nb_divide, nb_inplace_divide
560 - Removed these macros:
561   staticforward, statichere, PyArg_GetInt, PyArg_NoArgs, _PyObject_Del
563 - Removed these typedefs:
564   intargfunc, intintargfunc, intobjargproc, intintobjargproc,
565   getreadbufferproc, getwritebufferproc, getsegcountproc, getcharbufferproc,
566   memberlist
569 Tests
570 -----
572 - Removed test.testall as test.regrtest replaces it.
575 Documentation
576 -------------
581 - The cfmfile was removed.
584 Platforms
585 ---------
587 - Support for BeOS and AtheOS was removed (according to PEP 11).
589 - Support for RiscOS, Irix, Tru64 was removed (alledgedly).
592 Tools/Demos
593 -----------
595 **(For information about older versions, consult the HISTORY file.)**