Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1 | **************************** |
| 2 | What's New In Python 3.4 |
| 3 | **************************** |
| 4 | |
Georg Brandl | 3b80d34 | 2012-10-28 13:37:54 +0100 | [diff] [blame] | 5 | .. :Author: Someone <email> |
| 6 | (uncomment if there is a principal author) |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 7 | |
| 8 | .. Rules for maintenance: |
| 9 | |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 10 | * Anyone can add text to this document, but the maintainer reserves the |
| 11 | right to rewrite any additions. In particular, for obscure or esoteric |
| 12 | features, the maintainer may reduce any addition to a simple reference to |
| 13 | the new documentation rather than explaining the feature inline. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 14 | |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 15 | * While the maintainer will periodically go through Misc/NEWS |
| 16 | and add changes, it's best not to rely on this. We know from experience |
| 17 | that any changes that aren't in the What's New documentation around the |
| 18 | time of the original release will remain largely unknown to the community |
| 19 | for years, even if they're added later. We also know from experience that |
| 20 | other priorities can arise, and the maintainer will run out of time to do |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 21 | updates -- in such cases, end users will be much better served by partial |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 22 | notifications that at least give a hint about new features to |
| 23 | investigate. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 24 | |
| 25 | * This is not a complete list of every single change; completeness |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 26 | is the purpose of Misc/NEWS. The What's New should focus on changes that |
| 27 | are visible to Python *users* and that *require* a feature release (i.e. |
| 28 | most bug fixes should only be recorded in Misc/NEWS) |
| 29 | |
| 30 | * PEPs should not be marked Final until they have an entry in What's New. |
| 31 | A placeholder entry that is just a section header and a link to the PEP |
| 32 | (e.g ":pep:`397` has been implemented") is acceptable. If a PEP has been |
| 33 | implemented and noted in What's New, don't forget to mark it as Final! |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 34 | |
| 35 | * If you want to draw your new text to the attention of the |
| 36 | maintainer, add 'XXX' to the beginning of the paragraph or |
| 37 | section. |
| 38 | |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 39 | * It's OK to add just a very brief note about a change. For |
| 40 | example: "The :ref:`~socket.transmogrify()` function was added to the |
| 41 | :mod:`socket` module." The maintainer will research the change and |
| 42 | write the necessary text (if appropriate). The advantage of doing this |
| 43 | is that even if no more descriptive text is ever added, readers will at |
| 44 | least have a notification that the new feature exists and a link to the |
| 45 | relevant documentation. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 46 | |
| 47 | * You can comment out your additions if you like, but it's not |
| 48 | necessary (especially when a final release is some months away). |
| 49 | |
| 50 | * Credit the author of a patch or bugfix. Just the name is |
| 51 | sufficient; the e-mail address isn't necessary. |
| 52 | |
| 53 | * It's helpful to add the bug/patch number as a comment: |
| 54 | |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 55 | The :ref:`~socket.transmogrify()` function was added to the |
| 56 | :mod:`socket` module. (Contributed by P.Y. Developer in :issue:`12345`.) |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 57 | |
| 58 | This saves the maintainer the effort of going through the Mercurial log |
| 59 | when researching a change. |
| 60 | |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 61 | * Cross referencing tip: :ref:`mod.attr` will display as ``mod.attr``, |
| 62 | while :ref:`~mod.attr` will display as ``attr``. |
| 63 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 64 | This article explains the new features in Python 3.4, compared to 3.3. |
| 65 | |
Nick Coghlan | 03074fd | 2012-09-30 18:51:53 +0530 | [diff] [blame] | 66 | .. Python 3.4 was released on TBD. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 67 | |
Ezio Melotti | 25bbe5e | 2012-11-17 19:30:48 +0200 | [diff] [blame] | 68 | For full details, see the |
| 69 | `changelog <http://docs.python.org/3.4/whatsnew/changelog.html>`_. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 70 | |
| 71 | .. note:: Prerelease users should be aware that this document is currently in |
| 72 | draft form. It will be updated substantially as Python 3.4 moves towards |
| 73 | release, so it's worth checking back even after reading earlier versions. |
| 74 | |
| 75 | |
| 76 | .. seealso:: |
| 77 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 78 | :pep:`429` -- Python 3.4 Release Schedule |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 79 | |
| 80 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 81 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 82 | Summary -- Release Highlights |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 83 | ============================= |
| 84 | |
Kristjan Valur Jonsson | a1e8244 | 2013-03-26 13:56:14 +0000 | [diff] [blame] | 85 | .. This section singles out the most important changes in Python 3.4. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 86 | Brevity is key. |
| 87 | |
| 88 | New syntax features: |
| 89 | |
R David Murray | e0f7a78 | 2013-12-20 16:04:29 -0500 | [diff] [blame] | 90 | * No new syntax features were added in Python 3.4. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 91 | |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 92 | New expected features for Python implementations: |
| 93 | |
R David Murray | 6879066 | 2013-12-23 11:17:51 -0500 | [diff] [blame] | 94 | * :ref:`pip should always be "available" <whatsnew-pep-453>` (:pep:`453`). |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 95 | * :ref:`Make newly created file descriptors non-inheritable <whatsnew-pep-446>` |
| 96 | (:pep:`446`). |
| 97 | * command line option for :ref:`isolated mode <using-on-misc-options>`, |
| 98 | (:issue:`16499`). |
R David Murray | 8d85678 | 2013-12-23 10:28:57 -0500 | [diff] [blame] | 99 | * :ref:`improvements in the handling of codecs <codec-handling-improvements>` |
| 100 | that are not text encodings (multiple issues). |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 101 | * :ref:`A ModuleSpec Type <whatsnew-pep-451>` for the Import System |
R David Murray | e9b74d4 | 2013-12-22 21:05:04 -0500 | [diff] [blame] | 102 | (:pep:`451`). (Affects importer authors.) |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 103 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 104 | New library modules: |
| 105 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 106 | * :mod:`asyncio`: :ref:`New provisional API for asynchronous IO |
| 107 | <whatsnew-asyncio>` (:pep:`3156`). |
| 108 | * :mod:`ensurepip`: :ref:`Bootstrapping the pip installer <whatsnew-ensurepip>` |
| 109 | (:pep:`453`). |
| 110 | * :mod:`enum`: :ref:`Support for enumeration types <whatsnew-enum>` |
| 111 | (:pep:`435`). |
| 112 | * :mod:`pathlib`: :ref:`Object-oriented filesystem paths <whatsnew-pathlib>` |
| 113 | (:pep:`428`). |
R David Murray | f9976e7 | 2013-12-23 10:32:02 -0500 | [diff] [blame] | 114 | * :mod:`selectors`: :ref:`High-level and efficient I/O multiplexing |
| 115 | <whatsnew-selectors>`, built upon the :mod:`select` module primitives (part |
| 116 | of :pep:`3156`). |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 117 | * :mod:`statistics`: A basic :ref:`numerically stable statistics library |
| 118 | <whatsnew-statistics>` (:pep:`450`). |
| 119 | * :mod:`tracemalloc`: :ref:`Trace Python memory allocations |
| 120 | <whatsnew-tracemalloc>` (:pep:`454`). |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 121 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 122 | Significantly Improved Library Modules: |
| 123 | |
R David Murray | 0a10216 | 2013-12-20 15:00:54 -0500 | [diff] [blame] | 124 | * :ref:`Single-dispatch generic functions <whatsnew-singledispatch>` in |
R David Murray | 8d85678 | 2013-12-23 10:28:57 -0500 | [diff] [blame] | 125 | :mod:`functools` (:pep:`443`). |
| 126 | * New :mod:`pickle` :ref:`protocol 4 <whatsnew-protocol-4>` (:pep:`3154`). |
R David Murray | 8d85678 | 2013-12-23 10:28:57 -0500 | [diff] [blame] | 127 | * :ref:`TLSv1.1 and TLSv1.2 support <whatsnew-tls-11-12>` for :mod:`ssl` |
| 128 | (:issue:`16692`). |
R David Murray | ac18622 | 2013-12-20 17:23:57 -0500 | [diff] [blame] | 129 | * :mod:`multiprocessing` now has :ref:`an option to avoid using os.fork |
| 130 | on Unix <whatsnew-multiprocessing-no-fork>` (:issue:`8713`). |
R David Murray | 6adb454 | 2013-12-20 13:10:43 -0500 | [diff] [blame] | 131 | * :mod:`email` has a new submodule, :mod:`~email.contentmanager`, and |
| 132 | a new :mod:`~email.message.Message` subclass |
R David Murray | 26b80cfd | 2013-12-20 17:26:52 -0500 | [diff] [blame] | 133 | (:class:`~email.contentmanager.EmailMessage`) that :ref:`simplify MIME |
R David Murray | 8d85678 | 2013-12-23 10:28:57 -0500 | [diff] [blame] | 134 | handling <whatsnew_email_contentmanager>` (:issue:`18891`). |
Ronald Oussoren | 6db6653 | 2014-01-15 11:32:35 +0100 | [diff] [blame] | 135 | * :mod:`plistlib` has a cleaned up interface and support for binary |
| 136 | plist files (:issue:`14455`) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 137 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 138 | CPython implementation improvements: |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 139 | |
R David Murray | a93ca97 | 2013-12-22 14:10:21 -0500 | [diff] [blame] | 140 | * :ref:`Safe object finalization <whatsnew-pep-442>` (:pep:`442`). |
R David Murray | ca79461 | 2013-12-22 14:05:11 -0500 | [diff] [blame] | 141 | * Leveraging :pep:`442`, :ref:`module globals are no longer set to None |
| 142 | during finalization <whatsnew-pep-442>`, in most cases (:issue:`18214`). |
R David Murray | a93ca97 | 2013-12-22 14:10:21 -0500 | [diff] [blame] | 143 | * :ref:`Configurable memory allocators <whatsnew-pep-445>` (:pep:`445`). |
| 144 | * :ref:`Secure and interchangeable hash algorithm <whatsnew-pep-456>` |
| 145 | (:pep:`456`). |
| 146 | * :ref:`Argument Clinic <whatsnew-pep-436>` (:pep:`436`). |
R David Murray | 8f7664a | 2013-12-22 20:40:11 -0500 | [diff] [blame] | 147 | * The :mod:`marshal` format has been made :ref:`more compact and efficient |
| 148 | <whatsnew-marshal-3>` (:issue:`16475`). |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 149 | |
R David Murray | 347f9c7 | 2013-12-23 21:30:06 -0500 | [diff] [blame] | 150 | Please read on for a comprehensive list of user-facing changes, including many |
| 151 | other smaller improvements, CPython optimizations, deprecations, and potential |
| 152 | porting issues. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 153 | |
Nick Coghlan | d0cf063 | 2013-11-11 22:11:55 +1000 | [diff] [blame] | 154 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 155 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 156 | New Expected Features for Python Implementations |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 157 | ================================================ |
| 158 | |
R David Murray | 6879066 | 2013-12-23 11:17:51 -0500 | [diff] [blame] | 159 | .. _whatsnew-pep-453: |
| 160 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 161 | PEP 453: Explicit Bootstrapping of PIP in Python Installations |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 162 | -------------------------------------------------------------- |
Nick Coghlan | d0cf063 | 2013-11-11 22:11:55 +1000 | [diff] [blame] | 163 | |
| 164 | The new :mod:`ensurepip` module (defined in :pep:`453`) provides a standard |
| 165 | cross-platform mechanism to boostrap the pip installer into Python |
| 166 | installations and virtual environments. |
| 167 | |
Nick Coghlan | 7bc4b3b | 2013-11-23 11:59:40 +1000 | [diff] [blame] | 168 | The :mod:`venv` module and the :command:`pyvenv` utility make use of this |
| 169 | module to make ``pip`` readily available in virtual environments. When |
| 170 | using the command line interface, ``pip`` is installed by default, while |
| 171 | for the module API installation of ``pip`` must be requested explicitly. |
| 172 | |
| 173 | For CPython source builds on POSIX systems, the ``make install`` and |
| 174 | ``make altinstall`` commands bootstrap ``pip`` by default. This behaviour |
| 175 | can be controlled through configure options, and overridden through |
| 176 | Makefile options. |
| 177 | |
Ned Deily | 44a0db0 | 2013-11-22 22:39:09 -0800 | [diff] [blame] | 178 | On Windows and Mac OS X, the CPython installers now offer the option to |
| 179 | install ``pip`` along with CPython itself. |
Nick Coghlan | 7bc4b3b | 2013-11-23 11:59:40 +1000 | [diff] [blame] | 180 | |
R David Murray | 6879066 | 2013-12-23 11:17:51 -0500 | [diff] [blame] | 181 | As `discussed in the PEP`__, platform packagers may choose not to install |
| 182 | ``pip`` by default, as long as the command ``pip``, when invoked, provides |
| 183 | clear and simple directions on how to install ``pip`` on the platform. |
| 184 | |
| 185 | __ http://www.python.org/dev/peps/pep-0453/#recommendations-for-downstream-distributors |
| 186 | |
Nick Coghlan | d0cf063 | 2013-11-11 22:11:55 +1000 | [diff] [blame] | 187 | .. note:: |
| 188 | |
Nick Coghlan | 7bc4b3b | 2013-11-23 11:59:40 +1000 | [diff] [blame] | 189 | The implementation of PEP 453 is still a work in progress. Refer to |
| 190 | :issue:`19347` for the progress on additional steps: |
Nick Coghlan | d0cf063 | 2013-11-11 22:11:55 +1000 | [diff] [blame] | 191 | |
Nick Coghlan | 7bc4b3b | 2013-11-23 11:59:40 +1000 | [diff] [blame] | 192 | * Having the binary installers install ``pip`` by default |
| 193 | * Recommending the use of ``pip`` in the "Installing Python Module" |
| 194 | documentation. |
Nick Coghlan | d0cf063 | 2013-11-11 22:11:55 +1000 | [diff] [blame] | 195 | |
| 196 | .. seealso:: |
| 197 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 198 | :pep:`453` -- Explicit bootstrapping of pip in Python installations |
Nick Coghlan | d0cf063 | 2013-11-11 22:11:55 +1000 | [diff] [blame] | 199 | PEP written by Donald Stufft and Nick Coghlan, implemented by |
Nick Coghlan | 7bc4b3b | 2013-11-23 11:59:40 +1000 | [diff] [blame] | 200 | Donald Stufft, Nick Coghlan, Martin von Löwis and Ned Deily. |
Nick Coghlan | d0cf063 | 2013-11-11 22:11:55 +1000 | [diff] [blame] | 201 | |
| 202 | |
R David Murray | f9909c2 | 2013-12-20 14:50:12 -0500 | [diff] [blame] | 203 | .. _whatsnew-pep-446: |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 204 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 205 | PEP 446: Make Newly Created File Descriptors Non-Inheritable |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 206 | ------------------------------------------------------------ |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 207 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 208 | :pep:`446` makes newly created file descriptors :ref:`non-inheritable |
Georg Brandl | 5642ff9 | 2013-09-15 10:37:57 +0200 | [diff] [blame] | 209 | <fd_inheritance>`. New functions and methods: |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 210 | |
| 211 | * :func:`os.get_inheritable`, :func:`os.set_inheritable` |
| 212 | * :func:`os.get_handle_inheritable`, :func:`os.set_handle_inheritable` |
| 213 | * :meth:`socket.socket.get_inheritable`, :meth:`socket.socket.set_inheritable` |
| 214 | |
Antoine Pitrou | 796564c | 2013-07-30 19:59:21 +0200 | [diff] [blame] | 215 | .. seealso:: |
| 216 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 217 | :pep:`446` -- Make newly created file descriptors non-inheritable |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 218 | PEP written and implemented by Victor Stinner. |
Antoine Pitrou | 796564c | 2013-07-30 19:59:21 +0200 | [diff] [blame] | 219 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 220 | |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 221 | .. _codec-handling-improvements: |
| 222 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 223 | Improvements to Codec Handling |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 224 | ------------------------------ |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 225 | |
| 226 | Since it was first introduced, the :mod:`codecs` module has always been |
| 227 | intended to operate as a type-neutral dynamic encoding and decoding |
| 228 | system. However, its close coupling with the Python text model, especially |
| 229 | the type restricted convenience methods on the builtin :class:`str`, |
| 230 | :class:`bytes` and :class:`bytearray` types, has historically obscured that |
| 231 | fact. |
| 232 | |
| 233 | As a key step in clarifying the situation, the :meth:`codecs.encode` and |
| 234 | :meth:`codecs.decode` convenience functions are now properly documented in |
| 235 | Python 2.7, 3.3 and 3.4. These functions have existed in the :mod:`codecs` |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 236 | module (and have been covered by the regression test suite) since Python 2.4, |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 237 | but were previously only discoverable through runtime introspection. |
| 238 | |
| 239 | Unlike the convenience methods on :class:`str`, :class:`bytes` and |
| 240 | :class:`bytearray`, these convenience functions support arbitrary codecs |
| 241 | in both Python 2 and Python 3, rather than being limited to Unicode text |
| 242 | encodings (in Python 3) or ``basestring`` <-> ``basestring`` conversions |
| 243 | (in Python 2). |
| 244 | |
Nick Coghlan | 8afc8f6 | 2013-11-22 23:00:22 +1000 | [diff] [blame] | 245 | In Python 3.4, the interpreter is able to identify the known non-text |
| 246 | encodings provided in the standard library and direct users towards these |
| 247 | general purpose convenience functions when appropriate:: |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 248 | |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 249 | >>> b"abcdef".decode("hex") |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 250 | Traceback (most recent call last): |
| 251 | File "<stdin>", line 1, in <module> |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 252 | LookupError: 'hex' is not a text encoding; use codecs.decode() to handle arbitrary codecs |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 253 | |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 254 | >>> "hello".encode("rot13") |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 255 | Traceback (most recent call last): |
| 256 | File "<stdin>", line 1, in <module> |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 257 | LookupError: 'rot13' is not a text encoding; use codecs.encode() to handle arbitrary codecs |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 258 | |
| 259 | In a related change, whenever it is feasible without breaking backwards |
| 260 | compatibility, exceptions raised during encoding and decoding operations |
| 261 | will be wrapped in a chained exception of the same type that mentions the |
| 262 | name of the codec responsible for producing the error:: |
| 263 | |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 264 | >>> import codecs |
| 265 | |
| 266 | >>> codecs.decode(b"abcdefgh", "hex") |
Nick Coghlan | 8afc8f6 | 2013-11-22 23:00:22 +1000 | [diff] [blame] | 267 | binascii.Error: Non-hexadecimal digit found |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 268 | |
| 269 | The above exception was the direct cause of the following exception: |
| 270 | |
| 271 | Traceback (most recent call last): |
| 272 | File "<stdin>", line 1, in <module> |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 273 | binascii.Error: decoding with 'hex' codec failed (Error: Non-hexadecimal digit found) |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 274 | |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 275 | >>> codecs.encode("hello", "bz2") |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 276 | TypeError: 'str' does not support the buffer interface |
| 277 | |
| 278 | The above exception was the direct cause of the following exception: |
| 279 | |
| 280 | Traceback (most recent call last): |
| 281 | File "<stdin>", line 1, in <module> |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 282 | TypeError: encoding with 'bz2' codec failed (TypeError: 'str' does not support the buffer interface) |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 283 | |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 284 | Finally, as the examples above show, these improvements have permitted |
| 285 | the restoration of the convenience aliases for the non-Unicode codecs that |
| 286 | were themselves restored in Python 3.2. This means that encoding binary data |
| 287 | to and from its hexadecimal representation (for example) can now be written |
| 288 | as:: |
| 289 | |
| 290 | >>> from codecs import encode, decode |
| 291 | >>> encode(b"hello", "hex") |
| 292 | b'68656c6c6f' |
| 293 | >>> decode(b"68656c6c6f", "hex") |
| 294 | b'hello' |
| 295 | |
| 296 | The binary and text transforms provided in the standard library are detailed |
| 297 | in :ref:`binary-transforms` and :ref:`text-transforms`. |
| 298 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 299 | (Contributed by Nick Coghlan in :issue:`7475`, , :issue:`17827`, |
Nick Coghlan | 9c1aed8 | 2013-11-23 11:13:36 +1000 | [diff] [blame] | 300 | :issue:`17828` and :issue:`19619`) |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 301 | |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 302 | .. _whatsnew-pep-451: |
Eric Snow | b523f84 | 2013-11-22 09:05:39 -0700 | [diff] [blame] | 303 | |
| 304 | PEP 451: A ModuleSpec Type for the Import System |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 305 | ------------------------------------------------ |
Eric Snow | b523f84 | 2013-11-22 09:05:39 -0700 | [diff] [blame] | 306 | |
R David Murray | f85b2a8 | 2013-12-22 21:06:13 -0500 | [diff] [blame] | 307 | :pep:`451` provides an encapsulation of the information about a module that the |
| 308 | import machinery will use to load it (that is, a module specification). This |
| 309 | helps simplify both the import implementation and several import-related APIs. |
| 310 | The change is also a stepping stone for `several future import-related |
| 311 | improvements`__. |
Eric Snow | b523f84 | 2013-11-22 09:05:39 -0700 | [diff] [blame] | 312 | |
R David Murray | e9b74d4 | 2013-12-22 21:05:04 -0500 | [diff] [blame] | 313 | __ https://mail.python.org/pipermail/python-dev/2013-November/130111.html |
Eric Snow | b523f84 | 2013-11-22 09:05:39 -0700 | [diff] [blame] | 314 | |
| 315 | The public-facing changes from the PEP are entirely backward-compatible. |
R David Murray | f85b2a8 | 2013-12-22 21:06:13 -0500 | [diff] [blame] | 316 | Furthermore, they should be transparent to everyone but importer authors. Key |
| 317 | finder and loader methods have been deprecated, but they will continue working. |
| 318 | New importers should use the new methods described in the PEP. Existing |
| 319 | importers should be updated to implement the new methods. |
Eric Snow | b523f84 | 2013-11-22 09:05:39 -0700 | [diff] [blame] | 320 | |
Nick Coghlan | 8b097b4 | 2013-11-13 23:49:21 +1000 | [diff] [blame] | 321 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 322 | Other Language Changes |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 323 | ---------------------- |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 324 | |
| 325 | Some smaller changes made to the core Python language are: |
| 326 | |
Ezio Melotti | 34808e2 | 2013-10-12 16:36:13 +0300 | [diff] [blame] | 327 | * Unicode database updated to UCD version 6.3. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 328 | |
R David Murray | 9a2f139 | 2013-06-28 13:31:19 -0400 | [diff] [blame] | 329 | * :func:`min` and :func:`max` now accept a *default* argument that can be used |
| 330 | to specify the value they return if the iterable they are evaluating has no |
| 331 | elements. Contributed by Julian Berman in :issue:`18111`. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 332 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 333 | * Module objects are now :mod:`weakref`'able. |
| 334 | |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 335 | * Module ``__file__`` attributes (and related values) should now always |
| 336 | contain absolute paths by default, with the sole exception of |
| 337 | ``__main__.__file__`` when a script has been executed directly using |
| 338 | a relative path (Contributed by Brett Cannon in :issue:`18416`). |
| 339 | |
Serhiy Storchaka | 58cf607 | 2013-11-19 11:32:41 +0200 | [diff] [blame] | 340 | * Now all the UTF-\* codecs (except UTF-7) reject surrogates during both |
| 341 | encoding and decoding unless the ``surrogatepass`` error handler is used, |
| 342 | with the exception of the UTF-16 decoder that accepts valid surrogate pairs, |
| 343 | and the UTF-16 encoder that produces them while encoding non-BMP characters. |
| 344 | Contributed by Victor Stinner, Kang-Hao (Kenny) Lu and Serhiy Storchaka in |
| 345 | :issue:`12892`. |
| 346 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 347 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 348 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 349 | New Modules |
| 350 | =========== |
| 351 | |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 352 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 353 | .. _whatsnew-asyncio: |
| 354 | |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 355 | asyncio |
| 356 | ------- |
| 357 | |
| 358 | The new :mod:`asyncio` module (defined in :pep:`3156`) provides a standard |
| 359 | pluggable event loop model for Python, providing solid asynchronous IO |
| 360 | support in the standard library, and making it easier for other event loop |
| 361 | implementations to interoperate with the standard library and each other. |
| 362 | |
| 363 | For Python 3.4, this module is considered a :term:`provisional API`. |
| 364 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 365 | .. seealso:: |
| 366 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 367 | :pep:`3156` -- Asynchronous IO Support Rebooted: the "asyncio" Module |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 368 | PEP written and implementation led by Guido van Rossum. |
| 369 | |
R David Murray | 6879066 | 2013-12-23 11:17:51 -0500 | [diff] [blame] | 370 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 371 | .. _whatsnew-ensurepip: |
R David Murray | 6879066 | 2013-12-23 11:17:51 -0500 | [diff] [blame] | 372 | |
| 373 | ensurepip |
| 374 | --------- |
| 375 | |
| 376 | The new :mod:`ensurepip` module is the primary infrastructure for the |
| 377 | :pep:`453` implementation. In the normal course of events end users will not |
| 378 | need to interact with this module, but it can be used to manually bootstrap |
| 379 | ``pip`` if the automated bootstrapping into an installation or virtual |
| 380 | environment was declined. |
| 381 | |
| 382 | :mod:`ensurepip` includes a bundled copy of ``pip``, up-to-date as of the first |
| 383 | release candidate of the release of CPython with which it ships (this applies |
| 384 | to both maintenance releases and feature releases). ``ensurepip`` does not |
| 385 | access the internet. (If the installation has Internet access, it is of course |
| 386 | possible to upgrade ``pip`` to a release more recent than the bundled ``pip`` |
| 387 | by using the bundled ``pip`` command itself once it is installed.) |
| 388 | |
| 389 | The module is named *ensure*\ pip because if called when ``pip`` is already |
| 390 | installed, it does nothing. It also has an ``--upgrade`` option that will |
| 391 | cause it to install the bundled copy of ``pip`` if the existing installed |
| 392 | version of ``pip`` is older than the bundled copy. |
| 393 | |
| 394 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 395 | .. _whatsnew-enum: |
| 396 | |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 397 | enum |
| 398 | ---- |
| 399 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 400 | The new :mod:`enum` module (defined in :pep:`435`) provides a standard |
| 401 | implementation of enumeration types, allowing other modules (such as |
| 402 | :mod:`socket`) to provide more informative error messages and better |
| 403 | debugging support by replacing opaque integer constants with backwards |
| 404 | compatible enumeration values. |
| 405 | |
| 406 | .. seealso:: |
| 407 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 408 | :pep:`435` -- Adding an Enum type to the Python standard library |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 409 | PEP written by Barry Warsaw, Eli Bendersky and Ethan Furman, |
| 410 | implemented by Ethan Furman. |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 411 | |
| 412 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 413 | .. _whatsnew-pathlib: |
| 414 | |
Antoine Pitrou | 31119e4 | 2013-11-22 17:38:12 +0100 | [diff] [blame] | 415 | pathlib |
| 416 | ------- |
| 417 | |
| 418 | The new :mod:`pathlib` module offers classes representing filesystem paths |
| 419 | with semantics appropriate for different operating systems. Path classes are |
| 420 | divided between *pure paths*, which provide purely computational operations |
| 421 | without I/O, and *concrete paths*, which inherit from pure paths but also |
| 422 | provide I/O operations. |
| 423 | |
| 424 | For Python 3.4, this module is considered a :term:`provisional API`. |
| 425 | |
| 426 | .. seealso:: |
| 427 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 428 | :pep:`428` -- The pathlib module -- object-oriented filesystem paths |
Antoine Pitrou | 31119e4 | 2013-11-22 17:38:12 +0100 | [diff] [blame] | 429 | PEP written and implemented by Antoine Pitrou. |
| 430 | |
| 431 | |
R David Murray | f9976e7 | 2013-12-23 10:32:02 -0500 | [diff] [blame] | 432 | .. _whatsnew-selectors: |
| 433 | |
Charles-François Natali | 243d8d8 | 2013-09-04 19:02:49 +0200 | [diff] [blame] | 434 | selectors |
| 435 | --------- |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 436 | |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 437 | The new :mod:`selectors` module (created as part of implementing :pep:`3156`) |
| 438 | allows high-level and efficient I/O multiplexing, built upon the |
| 439 | :mod:`select` module primitives. |
| 440 | |
| 441 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 442 | .. _whatsnew-statistics: |
| 443 | |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 444 | statistics |
| 445 | ---------- |
| 446 | |
| 447 | The new :mod:`statistics` module (defined in :pep:`450`) offers some core |
| 448 | statistics functionality directly in the standard library. This module |
| 449 | supports calculation of the mean, median, mode, variance and standard |
| 450 | deviation of a data series. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 451 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 452 | .. seealso:: |
| 453 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 454 | :pep:`450` -- Adding A Statistics Module To The Standard Library |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 455 | PEP written and implemented by Steven D'Aprano |
| 456 | |
R David Murray | 9217dad | 2013-12-23 21:08:28 -0500 | [diff] [blame] | 457 | .. _whatsnew-tracemalloc: |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 458 | |
R David Murray | 8b2d682 | 2013-12-31 15:06:05 -0500 | [diff] [blame] | 459 | |
Victor Stinner | d2736af | 2013-11-25 09:40:27 +0100 | [diff] [blame] | 460 | tracemalloc |
| 461 | ----------- |
| 462 | |
| 463 | The new :mod:`tracemalloc` module (defined in :pep:`454`) is a debug tool to |
| 464 | trace memory blocks allocated by Python. It provides the following information: |
| 465 | |
| 466 | * Traceback where an object was allocated |
| 467 | * Statistics on allocated memory blocks per filename and per line number: |
| 468 | total size, number and average size of allocated memory blocks |
| 469 | * Compute the differences between two snapshots to detect memory leaks |
| 470 | |
| 471 | .. seealso:: |
| 472 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 473 | :pep:`454` -- Add a new tracemalloc module to trace Python memory allocations |
Victor Stinner | d2736af | 2013-11-25 09:40:27 +0100 | [diff] [blame] | 474 | PEP written and implemented by Victor Stinner |
| 475 | |
| 476 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 477 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 478 | Improved Modules |
| 479 | ================ |
| 480 | |
R David Murray | 6e39015 | 2013-12-24 22:28:04 -0500 | [diff] [blame] | 481 | |
R David Murray | 3edcc78 | 2013-12-24 16:13:32 -0500 | [diff] [blame] | 482 | abc |
| 483 | --- |
| 484 | |
| 485 | New function :func:`abc.get_cache_token` can be used to know when to invalidate |
| 486 | caches that are affected by changes in the object graph. (Contributed |
| 487 | by Łukasz Langa in :issue:`16832`.) |
R David Murray | 72420ff | 2013-12-24 10:46:44 -0500 | [diff] [blame] | 488 | |
R David Murray | 2691ee6 | 2013-12-28 23:15:12 -0500 | [diff] [blame] | 489 | New class :class:`~abc.ABC` has :class:`~abc.ABCMeta` as its meta class. |
| 490 | Using ``ABC`` as a base class has essentially the same effect as specifying |
| 491 | ``metaclass=abc.ABCMeta``, but is simpler to type and easier to read. |
| 492 | (Contributed by Bruno Dupuis in :issue:`16049`.) |
| 493 | |
| 494 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 495 | aifc |
| 496 | ---- |
| 497 | |
| 498 | The :meth:`~aifc.getparams` method now returns a namedtuple rather than a |
| 499 | plain tuple. (Contributed by Claudiu Popa in :issue:`17818`.) |
| 500 | |
R David Murray | d592bb2 | 2013-12-31 13:45:38 -0500 | [diff] [blame] | 501 | :func:`aifc.open` now supports the context manager protocol: when used in a |
| 502 | :keyword:`with` block, the :meth:`~aifc.aifc.close` method of the returned |
| 503 | object will be called automatically at the end of the block. (Contributed by |
| 504 | Serhiy Storchacha in :issue:`16486`.) |
| 505 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 506 | |
R David Murray | fced3ec | 2013-12-31 11:18:01 -0500 | [diff] [blame] | 507 | argparse |
| 508 | -------- |
| 509 | |
| 510 | The :class:`~argparse.FileType` class now accepts *encoding* and |
| 511 | *errors* arguments, which are passed through to :func:`open`. (Contributed |
| 512 | by Lucas Maystre in :issue:`11175`.) |
| 513 | |
| 514 | |
Serhiy Storchaka | eaea5e9 | 2013-10-19 21:10:46 +0300 | [diff] [blame] | 515 | audioop |
| 516 | ------- |
| 517 | |
| 518 | Added support for 24-bit samples (:issue:`12866`). |
| 519 | |
Serhiy Storchaka | 3062c9a | 2013-11-23 22:26:01 +0200 | [diff] [blame] | 520 | Added the :func:`~audioop.byteswap` function to convert big-endian samples |
| 521 | to little-endian and vice versa (:issue:`19641`). |
| 522 | |
Serhiy Storchaka | eaea5e9 | 2013-10-19 21:10:46 +0300 | [diff] [blame] | 523 | |
Nick Coghlan | d4fdbcc | 2013-11-14 00:24:31 +1000 | [diff] [blame] | 524 | base64 |
| 525 | ------ |
| 526 | |
| 527 | The encoding and decoding functions in :mod:`base64` now accept any |
| 528 | :term:`bytes-like object` in cases where it previously required a |
Georg Brandl | ed007d5 | 2013-11-24 16:09:26 +0100 | [diff] [blame] | 529 | :class:`bytes` or :class:`bytearray` instance (:issue:`17839`). |
Nick Coghlan | d4fdbcc | 2013-11-14 00:24:31 +1000 | [diff] [blame] | 530 | |
| 531 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 532 | colorsys |
| 533 | -------- |
| 534 | |
| 535 | The number of digits in the coefficients for the RGB --- YIQ conversions have |
| 536 | been expanded so that they match the FCC NTSC versions. The change in |
| 537 | results should be less than 1% and may better match results found elsewhere. |
| 538 | |
R David Murray | 8e37d5d | 2013-04-13 14:49:48 -0400 | [diff] [blame] | 539 | |
Nick Coghlan | b4534ae | 2013-10-13 23:23:08 +1000 | [diff] [blame] | 540 | contextlib |
| 541 | ---------- |
| 542 | |
Nick Coghlan | 240f86d | 2013-10-17 23:40:57 +1000 | [diff] [blame] | 543 | The new :class:`contextlib.suppress` context manager helps to clarify the |
| 544 | intent of code that deliberately suppresses exceptions from a single |
| 545 | statement. (Contributed by Raymond Hettinger in :issue:`15806` and |
| 546 | Zero Piraeus in :issue:`19266`) |
| 547 | |
Victor Stinner | 6633c39 | 2013-10-21 13:27:11 +0200 | [diff] [blame] | 548 | The new :func:`contextlib.redirect_stdout` context manager makes it easier |
Nick Coghlan | b4534ae | 2013-10-13 23:23:08 +1000 | [diff] [blame] | 549 | for utility scripts to handle inflexible APIs that don't provide any |
| 550 | options to retrieve their output as a string or direct it to somewhere |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 551 | other than :data:`sys.stdout`. In conjunction with :class:`io.StringIO`, |
| 552 | this context manager is also useful for checking expected output from |
| 553 | command line utilities. (Contribute by Raymond Hettinger in :issue:`15805`) |
| 554 | |
| 555 | The :mod:`contextlib` documentation has also been updated to include a |
| 556 | :ref:`discussion <single-use-reusable-and-reentrant-cms>` of the |
| 557 | differences between single use, reusable and reentrant context managers. |
Nick Coghlan | b4534ae | 2013-10-13 23:23:08 +1000 | [diff] [blame] | 558 | |
| 559 | |
Nick Coghlan | b39fd0c | 2013-05-06 23:59:20 +1000 | [diff] [blame] | 560 | dis |
| 561 | --- |
| 562 | |
R David Murray | 0bce6e7 | 2014-01-07 14:30:17 -0500 | [diff] [blame] | 563 | Functions :func:`~dis.show_code`, :func:`~dis.dis`, :func:`~dis.distb`, and |
| 564 | :func:`~dis.disassemble` now accept a keyword-only *file* argument that |
| 565 | controls where they write their output. |
Nick Coghlan | b39fd0c | 2013-05-06 23:59:20 +1000 | [diff] [blame] | 566 | |
R David Murray | 0bce6e7 | 2014-01-07 14:30:17 -0500 | [diff] [blame] | 567 | The :mod:`dis` module is now built around an :class:`~dis.Instruction` class |
| 568 | that provides object oriented access to the details of each individual bytecode |
| 569 | operation. |
| 570 | |
| 571 | A new method, :func:`~dis.get_instructions`, provides an iterator that emits |
| 572 | the Instruction stream for a given piece of Python code. Thus it is now |
| 573 | possible to write a program that inspects and manipulates a bytecode |
| 574 | object in ways different from those provided by the :mod:`~dis` module |
| 575 | itself. For example:: |
| 576 | |
| 577 | >>> import dis |
| 578 | >>> for instr in dis.get_instructions(lambda x: x + 1): |
| 579 | ... print(instr.opname) |
| 580 | LOAD_FAST |
| 581 | LOAD_CONST |
| 582 | BINARY_ADD |
| 583 | RETURN_VALUE |
| 584 | |
| 585 | The various display tools in the :mod:`dis` module have been rewritten to use |
| 586 | these new components. |
| 587 | |
| 588 | In addition, a new application-friendly class :class:`~dis.Bytecode` provides |
| 589 | an object-oriented API for inspecting bytecode in both in human-readable form |
| 590 | and for iterating over instructions. The :class:`~dis.Bytecode` constructor |
| 591 | takes the same arguments that :func:`~dis.get_instruction` does (plus an |
| 592 | optional *current_offset*), and the resulting object can be iterated to produce |
| 593 | :class:`~dis.Instruction` objects. But it also has a :mod:`~dis.Bytecode.dis` |
| 594 | method, equivalent to calling :mod:`~dis.dis` on the constructor argument, but |
| 595 | returned as a multi-line string:: |
| 596 | |
| 597 | >>> bytecode = dis.Bytecode(lambda x: x +1, current_offset=3) |
| 598 | >>> for instr in bytecode: |
| 599 | ... print('{} ({})'.format(instr.opname, instr.opcode)) |
| 600 | LOAD_FAST (124) |
| 601 | LOAD_CONST (100) |
| 602 | BINARY_ADD (23) |
| 603 | RETURN_VALUE (83) |
| 604 | >>> bytecode.dis().splitlines() # doctest: +NORMALIZE_WHITESPACE |
| 605 | [' 1 0 LOAD_FAST 0 (x)', |
| 606 | ' --> 3 LOAD_CONST 1 (1)', |
| 607 | ' 6 BINARY_ADD', |
| 608 | ' 7 RETURN_VALUE'] |
| 609 | |
| 610 | :class:`~dis.Bytecode` also has a class method, |
| 611 | :meth:`~dis.Bytecode.from_traceback`, that provides the ability to manipulate a |
| 612 | traceback (that is, ``print(Bytecode.from_traceback(tb).dis())`` is equivalent |
| 613 | to ``distb(tb)``). |
Nick Coghlan | b39fd0c | 2013-05-06 23:59:20 +1000 | [diff] [blame] | 614 | |
Nick Coghlan | 50c48b8 | 2013-11-23 00:57:00 +1000 | [diff] [blame] | 615 | (Contributed by Nick Coghlan, Ryan Kelly and Thomas Kluyver in :issue:`11816` |
| 616 | and Claudiu Popa in :issue:`17916`) |
Nick Coghlan | b39fd0c | 2013-05-06 23:59:20 +1000 | [diff] [blame] | 617 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 618 | |
R David Murray | 5a9d706 | 2012-11-21 15:09:21 -0500 | [diff] [blame] | 619 | doctest |
| 620 | ------- |
| 621 | |
R David Murray | 473f45b | 2013-12-27 17:01:16 -0500 | [diff] [blame] | 622 | A new :ref:`option flag <doctest-options>`, :data:`~doctest.FAIL_FAST`, halts |
| 623 | test running as soon as the first failure is detected. (Contributed by R. |
| 624 | David Murray and Daniel Urban in :issue:`16522`.) |
R David Murray | 5707d50 | 2013-06-23 14:24:13 -0400 | [diff] [blame] | 625 | |
R David Murray | 473f45b | 2013-12-27 17:01:16 -0500 | [diff] [blame] | 626 | The :mod:`doctest` command line interface now uses :mod:`argparse`, and has two |
| 627 | new options, ``-o`` and ``-f``. ``-o`` allows :ref:`doctest options |
| 628 | <doctest-options>` to be specified on the command line, and ``-f`` is a |
| 629 | shorthand for ``-o FAIL_FAST`` (to parallel the similar option supported by the |
| 630 | :mod:`unittest` CLI). (Contributed by R. David Murray in :issue:`11390`.) |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 631 | |
R David Murray | 8e37d5d | 2013-04-13 14:49:48 -0400 | [diff] [blame] | 632 | |
R David Murray | bb17d2b | 2013-08-09 16:15:28 -0400 | [diff] [blame] | 633 | email |
| 634 | ----- |
| 635 | |
| 636 | :meth:`~email.message.Message.as_string` now accepts a *policy* argument to |
| 637 | override the default policy of the message when generating a string |
| 638 | representation of it. This means that ``as_string`` can now be used in more |
| 639 | circumstances, instead of having to create and use a :mod:`~email.generator` in |
| 640 | order to pass formatting parameters to its ``flatten`` method. |
| 641 | |
| 642 | New method :meth:`~email.message.Message.as_bytes` added to produce a bytes |
| 643 | representation of the message in a fashion similar to how ``as_string`` |
| 644 | produces a string representation. It does not accept the *maxheaderlen* |
| 645 | argument, but does accept the *unixfrom* and *policy* arguments. The |
| 646 | :class:`~email.message.Message` :meth:`~email.message.Message.__bytes__` method |
| 647 | calls it, meaning that ``bytes(mymsg)`` will now produce the intuitive |
| 648 | result: a bytes object containing the fully formatted message. |
| 649 | |
| 650 | (Contributed by R. David Murray in :issue:`18600`.) |
| 651 | |
R David Murray | 26b80cfd | 2013-12-20 17:26:52 -0500 | [diff] [blame] | 652 | .. _whatsnew_email_contentmanager: |
| 653 | |
R David Murray | 3da240f | 2013-10-16 22:48:40 -0400 | [diff] [blame] | 654 | A pair of new subclasses of :class:`~email.message.Message` have been added, |
| 655 | along with a new sub-module, :mod:`~email.contentmanager`. All documentation |
| 656 | is currently in the new module, which is being added as part of the new |
Nick Coghlan | 240f86d | 2013-10-17 23:40:57 +1000 | [diff] [blame] | 657 | :term:`provisional <provisional package>` email API. These classes provide a |
R David Murray | 3da240f | 2013-10-16 22:48:40 -0400 | [diff] [blame] | 658 | number of new methods that make extracting content from and inserting content |
| 659 | into email messages much easier. See the :mod:`~email.contentmanager` |
| 660 | documentation for details. |
| 661 | |
| 662 | These API additions complete the bulk of the work that was planned as part of |
| 663 | the email6 project. The currently provisional API is scheduled to become final |
| 664 | in Python 3.5 (possibly with a few minor additions in the area of error |
| 665 | handling). |
| 666 | |
| 667 | (Contributed by R. David Murray in :issue:`18891`.) |
| 668 | |
R David Murray | bb17d2b | 2013-08-09 16:15:28 -0400 | [diff] [blame] | 669 | |
Victor Stinner | 854ffcb | 2013-06-21 00:36:30 +0200 | [diff] [blame] | 670 | functools |
| 671 | --------- |
| 672 | |
Nick Coghlan | f4cb48a | 2013-11-03 16:41:46 +1000 | [diff] [blame] | 673 | The new :func:`~functools.partialmethod` descriptor bring partial argument |
| 674 | application to descriptors, just as :func:`~functools.partial` provides |
| 675 | for normal callables. The new descriptor also makes it easier to get |
| 676 | arbitrary callables (including :func:`~functools.partial` instances) |
| 677 | to behave like normal instance methods when included in a class definition. |
| 678 | |
| 679 | (Contributed by Alon Horev and Nick Coghlan in :issue:`4331`) |
| 680 | |
R David Murray | 0a10216 | 2013-12-20 15:00:54 -0500 | [diff] [blame] | 681 | .. _whatsnew-singledispatch: |
| 682 | |
Nick Coghlan | f4cb48a | 2013-11-03 16:41:46 +1000 | [diff] [blame] | 683 | The new :func:`~functools.singledispatch` decorator brings support for |
| 684 | single-dispatch generic functions to the Python standard library. Where |
| 685 | object oriented programming focuses on grouping multiple operations on a |
| 686 | common set of data into a class, a generic function focuses on grouping |
| 687 | multiple implementations of an operation that allows it to work with |
| 688 | *different* kinds of data. |
| 689 | |
| 690 | .. seealso:: |
| 691 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 692 | :pep:`443` -- Single-dispatch generic functions |
Nick Coghlan | f4cb48a | 2013-11-03 16:41:46 +1000 | [diff] [blame] | 693 | PEP written and implemented by Łukasz Langa. |
Victor Stinner | 854ffcb | 2013-06-21 00:36:30 +0200 | [diff] [blame] | 694 | |
R David Murray | d265381 | 2013-12-27 14:06:15 -0500 | [diff] [blame] | 695 | A pure-python version of the :func:`~functools.partial` function is now in the |
| 696 | stdlib; in CPython it is overridden by the C accelerated version, but it is |
| 697 | available for other implementations to use. (Contributed by Brian Thorne in |
| 698 | :issue:`12428`.) |
| 699 | |
Nick Coghlan | e8c45d6 | 2013-07-28 20:00:01 +1000 | [diff] [blame] | 700 | |
R David Murray | 0e81463 | 2013-12-26 15:11:28 -0500 | [diff] [blame] | 701 | gc |
| 702 | -- |
| 703 | |
R David Murray | a101bdb | 2014-01-06 16:32:05 -0500 | [diff] [blame] | 704 | New function :func:`~gc.get_stats` returns a list of three per-generation |
| 705 | dictionaries containing the collections statistics since interpreter startup. |
| 706 | (Contributed by Antoine Pitrou in :issue:`16351`.) |
R David Murray | 0e81463 | 2013-12-26 15:11:28 -0500 | [diff] [blame] | 707 | |
| 708 | |
Christian Heimes | e92ef13 | 2013-10-13 00:52:43 +0200 | [diff] [blame] | 709 | hashlib |
| 710 | ------- |
| 711 | |
| 712 | New :func:`hashlib.pbkdf2_hmac` function. |
Christian Heimes | e92ef13 | 2013-10-13 00:52:43 +0200 | [diff] [blame] | 713 | (Contributed by Christian Heimes in :issue:`18582`) |
| 714 | |
| 715 | |
Ezio Melotti | 250a06c | 2013-11-25 06:18:47 +0200 | [diff] [blame] | 716 | html |
| 717 | ---- |
| 718 | |
| 719 | Added a new :func:`html.unescape` function that converts HTML5 character |
| 720 | references to the corresponding Unicode characters. |
Ezio Melotti | 250a06c | 2013-11-25 06:18:47 +0200 | [diff] [blame] | 721 | (Contributed by Ezio Melotti in :issue:`2927`) |
| 722 | |
| 723 | Added a new *convert_charrefs* keyword argument to |
| 724 | :class:`~html.parser.HTMLParser` that, when ``True``, automatically converts |
| 725 | all character references. For backward-compatibility, its value defaults |
| 726 | to ``False``, but it will change to ``True`` in future versions, so you |
| 727 | are invited to set it explicitly and update your code to use this new feature. |
Ezio Melotti | 250a06c | 2013-11-25 06:18:47 +0200 | [diff] [blame] | 728 | (Contributed by Ezio Melotti in :issue:`13633`) |
| 729 | |
| 730 | The *strict* argument of :class:`~html.parser.HTMLParser` is now deprecated. |
Ezio Melotti | 250a06c | 2013-11-25 06:18:47 +0200 | [diff] [blame] | 731 | (Contributed by Ezio Melotti in :issue:`15114`) |
| 732 | |
| 733 | |
R David Murray | a475a8d | 2014-01-03 13:03:00 -0500 | [diff] [blame] | 734 | http |
| 735 | ---- |
| 736 | |
| 737 | :meth:`~http.server.BaseHTTPRequestHandler.send_error` now accepts an |
Zachary Ware | 335957e | 2014-01-13 16:08:54 -0600 | [diff] [blame] | 738 | optional additional *explain* parameter which can be used to provide an |
R David Murray | a475a8d | 2014-01-03 13:03:00 -0500 | [diff] [blame] | 739 | extended error description, overriding the hardcoded default if there is one. |
| 740 | This extended error description will be formatted using the |
| 741 | :attr:`~http.server.HTTP.error_message_format` attribute and sent as the body |
| 742 | of the error response. (Contributed by Karl Cow in :issue:`12921`.) |
| 743 | |
| 744 | |
| 745 | |
R David Murray | d265381 | 2013-12-27 14:06:15 -0500 | [diff] [blame] | 746 | importlib |
| 747 | --------- |
| 748 | |
| 749 | The :class:`~importlib.abc.InspectLoader` ABC defines a new method, |
| 750 | :meth:`~importlib.abc.InspectLoader.source_to_code` that accepts source |
| 751 | data and a path and returns a code object. The default implementation |
| 752 | is equivalent to ``compile(data, path, 'exec', dont_inherit=True)``. |
| 753 | (Contributed by Eric Snow and Brett Cannon in :issue:`15627`.) |
| 754 | |
R David Murray | 0ae7ae1 | 2014-01-08 18:16:02 -0500 | [diff] [blame] | 755 | :class:`~importlib.abc.InspectLoader` also now has a default implementation |
| 756 | for the :meth:`~importlib.abc.InspectLoader.get_code` method. However, |
| 757 | it will normally be desirable to override the default implementation |
| 758 | for performance reasons. (Contributed by Brett Cannon in :issue:`18072`.) |
| 759 | |
R David Murray | d265381 | 2013-12-27 14:06:15 -0500 | [diff] [blame] | 760 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 761 | inspect |
| 762 | ------- |
| 763 | |
Nick Coghlan | f94a16b | 2013-09-22 22:46:49 +1000 | [diff] [blame] | 764 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 765 | The inspect module now offers a basic :ref:`command line interface |
| 766 | <inspect-module-cli>` to quickly display source code and other |
| 767 | information for modules, classes and functions. (Contributed by Claudiu Popa |
| 768 | and Nick Coghlan in :issue:`18626`) |
Nick Coghlan | f94a16b | 2013-09-22 22:46:49 +1000 | [diff] [blame] | 769 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 770 | :func:`~inspect.unwrap` makes it easy to unravel wrapper function chains |
| 771 | created by :func:`functools.wraps` (and any other API that sets the |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 772 | ``__wrapped__`` attribute on a wrapper function). (Contributed by |
| 773 | Daniel Urban, Aaron Iles and Nick Coghlan in :issue:`13266`) |
| 774 | |
| 775 | As part of the implementation of the new :mod:`enum` module, the |
| 776 | :mod:`inspect` module now has substantially better support for custom |
| 777 | ``__dir__`` methods and dynamic class attributes provided through |
| 778 | metaclasses (Contributed by Ethan Furman in :issue:`18929` and |
| 779 | :issue:`19030`) |
| 780 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 781 | |
R David Murray | 9cf617b | 2014-01-04 18:55:01 -0500 | [diff] [blame] | 782 | logging |
| 783 | ------- |
| 784 | |
| 785 | The :class:`~logging.handlers.TimedRotatingFileHandler` has a new *atTime* |
| 786 | parameter that can be used to specify the time of day when rollover should |
| 787 | happen. (Contributed by Ronald Oussoren in :issue:`9556`.) |
| 788 | |
| 789 | |
R David Murray | 8f7664a | 2013-12-22 20:40:11 -0500 | [diff] [blame] | 790 | .. _whatsnew-marshal-3: |
| 791 | |
| 792 | marshal |
| 793 | ------- |
| 794 | |
| 795 | The default :mod:`marshal` version has been bumped to 3. The code implementing |
| 796 | the new version restores the Python2 behavior of recording only one copy of |
| 797 | interned strings and preserving the interning on deserialization, and extends |
| 798 | this "one copy" ability to any object type (including handling recursive |
| 799 | references). This reduces both the size of ``.pyc`` files and the amount of |
| 800 | memory a module occupies in memory when it is loaded from a ``.pyc`` (or |
| 801 | ``.pyo``) file. (Contributed by Kristján Valur Jónsson in :issue:`16475`.) |
| 802 | |
| 803 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 804 | mmap |
| 805 | ---- |
| 806 | |
| 807 | mmap objects can now be weakref'ed. |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 808 | (Contributed by Valerie Lambert in :issue:`4885`.) |
| 809 | |
| 810 | |
R David Murray | 33ef1ae | 2013-12-31 16:04:50 -0500 | [diff] [blame] | 811 | mock |
| 812 | ---- |
| 813 | |
| 814 | :mod:`~unittest.mock` objects now inspect their specification signatures when |
| 815 | matching calls, which means an argument can now be matched by either position |
| 816 | or name, instead of only by position. (Contributed by Antoine Pitrou in |
| 817 | :issue:`17015`.) |
| 818 | |
R David Murray | 57fcf76 | 2014-01-03 23:31:54 -0500 | [diff] [blame] | 819 | :func:`~mock.mock_open` objects now have ``readline`` and ``readlines`` |
| 820 | methods. (Contributed by Toshio Kuratomi in :issue:`17467`.) |
| 821 | |
R David Murray | 33ef1ae | 2013-12-31 16:04:50 -0500 | [diff] [blame] | 822 | |
Richard Oudkerk | 84ed9a6 | 2013-08-14 15:35:41 +0100 | [diff] [blame] | 823 | multiprocessing |
| 824 | --------------- |
| 825 | |
R David Murray | ac18622 | 2013-12-20 17:23:57 -0500 | [diff] [blame] | 826 | .. _whatsnew-multiprocessing-no-fork: |
| 827 | |
| 828 | On Unix, two new :ref:`start methods <multiprocessing-start-methods>` |
| 829 | (``spawn`` and ``forkserver``) have been added for starting processes using |
| 830 | :mod:`multiprocessing`. These make the mixing of processes with threads more |
| 831 | robust, and the ``spawn`` method matches the semantics that multiprocessing has |
| 832 | always used on Windows. (Contributed by Richard Oudkerk in :issue:`8713`). |
Richard Oudkerk | 84ed9a6 | 2013-08-14 15:35:41 +0100 | [diff] [blame] | 833 | |
| 834 | Also, except when using the old *fork* start method, child processes |
R David Murray | ac18622 | 2013-12-20 17:23:57 -0500 | [diff] [blame] | 835 | will no longer inherit unneeded handles/file descriptors from their parents |
| 836 | (part of :issue:`8713`). |
Richard Oudkerk | 84ed9a6 | 2013-08-14 15:35:41 +0100 | [diff] [blame] | 837 | |
Nick Coghlan | 9a76735 | 2013-12-17 22:17:26 +1000 | [diff] [blame] | 838 | :mod:`multiprocessing` now relies on :mod:`runpy` (which implements the |
| 839 | ``-m`` switch) to initialise ``__main__`` appropriately in child processes |
| 840 | when using the ``spawn`` or ``forkserver`` start methods. This resolves some |
| 841 | edge cases where combining multiprocessing, the ``-m`` command line switch |
| 842 | and explicit relative imports could cause obscure failures in child |
| 843 | processes. (Contributed by Nick Coghlan in :issue:`19946`) |
| 844 | |
Richard Oudkerk | 84ed9a6 | 2013-08-14 15:35:41 +0100 | [diff] [blame] | 845 | |
R David Murray | 9835827 | 2014-01-05 20:52:06 -0500 | [diff] [blame] | 846 | operator |
| 847 | -------- |
| 848 | |
| 849 | There is now a pure-python version of the :mod:`operator` module available for |
| 850 | reference and for use by alternate implementations of Python. (Contributed by |
| 851 | Zachary Ware in :issue:`16694`.) |
| 852 | |
| 853 | |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 854 | os |
| 855 | -- |
| 856 | |
Georg Brandl | c6ebbef | 2013-09-16 04:03:12 +0200 | [diff] [blame] | 857 | New functions to get and set the :ref:`inheritable flag <fd_inheritance>` of a file |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 858 | descriptors or a Windows handle: |
| 859 | |
| 860 | * :func:`os.get_inheritable`, :func:`os.set_inheritable` |
| 861 | * :func:`os.get_handle_inheritable`, :func:`os.set_handle_inheritable` |
| 862 | |
R David Murray | 66bf12a | 2014-01-08 17:21:22 -0500 | [diff] [blame] | 863 | The :mod:`os` module now provides a :func:`~os.cpu_count` function, analogous to |
| 864 | the :func:`multiprocessing.cpu_count` function (which is now implemented in |
| 865 | terms of the new :mod:`os` function). (Contributed by Trent Nelson, Yogesh |
| 866 | Chaudhari, Victor Stinner, and Charles-François Natali in :issue:`17914`.) |
| 867 | |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 868 | |
R David Murray | 78d692f | 2013-10-10 17:23:26 -0400 | [diff] [blame] | 869 | pdb |
| 870 | --- |
| 871 | |
| 872 | The ``print`` command has been removed from :mod:`pdb`, restoring access to the |
| 873 | ``print`` function. |
| 874 | |
| 875 | Rationale: Python2's ``pdb`` did not have a ``print`` command; instead, |
| 876 | entering ``print`` executed the ``print`` statement. In Python3 ``print`` was |
| 877 | mistakenly made an alias for the pdb :pdbcmd:`p` command. ``p``, however, |
| 878 | prints the ``repr`` of its argument, not the ``str`` like the Python2 ``print`` |
| 879 | command did. Worse, the Python3 ``pdb print`` command shadowed the Python3 |
| 880 | ``print`` function, making it inaccessible at the ``pdb`` prompt. |
| 881 | |
| 882 | (Contributed by Connor Osborn in :issue:`18764`.) |
| 883 | |
| 884 | |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 885 | .. _whatsnew-protocol-4: |
| 886 | |
R David Murray | 5ea9524 | 2013-12-24 15:59:57 -0500 | [diff] [blame] | 887 | pickle |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 888 | ------ |
| 889 | |
| 890 | protocol 4 |
| 891 | |
| 892 | :mod:`pickle` now supports (but does not use by default) a new pickle protocol, |
| 893 | protocol 4. This new protocol addresses a number of issues that were present |
| 894 | in previous protocols, such as the serialization of nested classes, very large |
| 895 | strings and containers, or classes whose :meth:`__new__` method takes |
| 896 | keyword-only arguments. It also provides some efficiency improvements. |
| 897 | |
| 898 | .. seealso:: |
| 899 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 900 | :pep:`3154` -- Pickle protocol 4 |
R David Murray | 809487e | 2013-12-22 20:49:40 -0500 | [diff] [blame] | 901 | PEP written by Antoine Pitrou and implemented by Alexandre Vassalotti. |
| 902 | |
| 903 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 904 | poplib |
| 905 | ------ |
| 906 | |
R David Murray | 473f45b | 2013-12-27 17:01:16 -0500 | [diff] [blame] | 907 | Two new methods have been added to :mod:`poplib`: :meth:`~poplib.POP3.capa`, |
| 908 | which returns the list of capabilities advertised by the POP server, and |
| 909 | :meth:`~poplib.POP3.stls`, which switches a clear-text POP3 session into an |
| 910 | encrypted POP3 session if the POP server supports it. (Contributed by Lorenzo |
| 911 | Catucci in :issue:`4473`.) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 912 | |
| 913 | |
Serhiy Storchaka | 7c411a4 | 2013-10-02 11:56:18 +0300 | [diff] [blame] | 914 | pprint |
| 915 | ------ |
| 916 | |
Christian Heimes | e1bfd3e | 2013-10-21 12:32:21 +0200 | [diff] [blame] | 917 | The :mod:`pprint` module now supports *compact* mode for formatting long |
Serhiy Storchaka | 7c411a4 | 2013-10-02 11:56:18 +0300 | [diff] [blame] | 918 | sequences (:issue:`19132`). |
| 919 | |
R David Murray | b231b2b | 2014-01-04 17:11:23 -0500 | [diff] [blame] | 920 | Long strings are now wrapped using Python's normal line continuation |
| 921 | syntax (Contributed by Antoine Pitrou in :issue:`17150`.) |
| 922 | |
Serhiy Storchaka | 7c411a4 | 2013-10-02 11:56:18 +0300 | [diff] [blame] | 923 | |
R David Murray | 6e39015 | 2013-12-24 22:28:04 -0500 | [diff] [blame] | 924 | pty |
| 925 | --- |
| 926 | |
| 927 | :func:`pty.spawn` now returns the status value from :func:`os.waitpid` on |
| 928 | the child process, instead of ``None``. (Contributed by Gregory P. Smith.) |
| 929 | |
| 930 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 931 | pydoc |
| 932 | ----- |
| 933 | |
| 934 | While significant changes have not been made to :mod:`pydoc` directly, |
| 935 | its handling of custom ``__dir__`` methods and various descriptor |
| 936 | behaviours has been improved substantially by the underlying changes in |
| 937 | the :mod:`inspect` module. |
| 938 | |
| 939 | |
Serhiy Storchaka | 32eddc1 | 2013-11-23 23:20:30 +0200 | [diff] [blame] | 940 | re |
| 941 | -- |
| 942 | |
| 943 | Added :func:`re.fullmatch` function and :meth:`regex.fullmatch` method, |
| 944 | which anchor the pattern at both ends of the string to match. |
| 945 | (Contributed by Matthew Barnett in :issue:`16203`.) |
| 946 | |
Ezio Melotti | dd7e291 | 2013-11-25 23:20:20 +0200 | [diff] [blame] | 947 | The repr of :ref:`regex objects <re-objects>` now includes the pattern |
| 948 | and the flags; the repr of :ref:`match objects <match-objects>` now |
| 949 | includes the start, end, and the part of the string that matched. |
Ezio Melotti | dd7e291 | 2013-11-25 23:20:20 +0200 | [diff] [blame] | 950 | (Contributed by Serhiy Storchaka in :issue:`13592` and :issue:`17087`.) |
| 951 | |
| 952 | |
Christian Heimes | b7bd5df | 2013-10-22 11:21:54 +0200 | [diff] [blame] | 953 | resource |
| 954 | -------- |
| 955 | |
| 956 | New :func:`resource.prlimit` function and Linux specific constants. |
| 957 | (Contributed by Christian Heimes in :issue:`16595` and :issue:`19324`.) |
| 958 | |
R David Murray | 575fb31 | 2013-12-25 23:21:03 -0500 | [diff] [blame] | 959 | |
R David Murray | 2bc930f | 2013-12-31 11:17:21 -0500 | [diff] [blame] | 960 | select |
| 961 | ------ |
| 962 | |
| 963 | :class:`~select.epoll` objects now support the context management protocol. |
| 964 | When used in a :keyword:`with` statement, the :meth:`~select.epoll.close` |
| 965 | method will be called automatically at the end of the block. (Contributed |
| 966 | by Serhiy Storchaka in :issue:`16488`.) |
| 967 | |
| 968 | |
R David Murray | 575fb31 | 2013-12-25 23:21:03 -0500 | [diff] [blame] | 969 | shelve |
| 970 | ------ |
| 971 | |
| 972 | :class:`~shelve.Shelf` instances may now be used in :keyword:`with` statements, |
| 973 | and will be automatically closed at the end of the :keyword:`with` block. |
| 974 | (Contributed by Filip Gruszczyński in :issue:`13896`.) |
| 975 | |
| 976 | |
R David Murray | 8e37d5d | 2013-04-13 14:49:48 -0400 | [diff] [blame] | 977 | smtplib |
| 978 | ------- |
| 979 | |
R David Murray | 8a34596 | 2013-04-14 06:46:35 -0400 | [diff] [blame] | 980 | :exc:`~smtplib.SMTPException` is now a subclass of :exc:`OSError`, which allows |
R David Murray | 8e37d5d | 2013-04-13 14:49:48 -0400 | [diff] [blame] | 981 | both socket level errors and SMTP protocol level errors to be caught in one |
| 982 | try/except statement by code that only cares whether or not an error occurred. |
| 983 | (:issue:`2118`). |
| 984 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 985 | |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 986 | socket |
| 987 | ------ |
| 988 | |
R David Murray | 33ef1ae | 2013-12-31 16:04:50 -0500 | [diff] [blame] | 989 | The socket module now supports the :data:`~socket.CAN_BCM` protocol on |
| 990 | platforms that support it. (Contributed by Brian Thorne in :issue:`15359`.) |
| 991 | |
Georg Brandl | 5642ff9 | 2013-09-15 10:37:57 +0200 | [diff] [blame] | 992 | Socket objects have new methods to get or set their :ref:`inheritable flag |
R David Murray | 33ef1ae | 2013-12-31 16:04:50 -0500 | [diff] [blame] | 993 | <fd_inheritance>`, :meth:`~socket.socket.get_inheritable` and |
| 994 | :meth:`~socket.socket.set_inheritable`. |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 995 | |
R David Murray | 33ef1ae | 2013-12-31 16:04:50 -0500 | [diff] [blame] | 996 | The ``socket.AF_*`` and ``socket.SOCK_*`` constants are now enumeration values |
| 997 | using the new :mod:`enum` module. This allows meaningful names to be printed |
| 998 | during debugging, instead of integer "magic numbers". |
Victor Stinner | daf4555 | 2013-08-28 00:53:59 +0200 | [diff] [blame] | 999 | |
R David Murray | 66bf12a | 2014-01-08 17:21:22 -0500 | [diff] [blame] | 1000 | The :data:`~socket.AF_LINK` constant is now available on BSD and OSX. |
| 1001 | |
R David Murray | 8b2d682 | 2013-12-31 15:06:05 -0500 | [diff] [blame] | 1002 | |
R David Murray | 9025f1c | 2014-01-02 13:44:18 -0500 | [diff] [blame] | 1003 | sqlite3 |
| 1004 | ------- |
| 1005 | |
| 1006 | A new boolean parameter, *uri*, to the :func:`~sqlite3.connect` function can |
| 1007 | be used to indicate that the *database* parameter is a ``uri`` (see |
| 1008 | the `SQLite URI documentation <http://www.sqlite.org/uri.html>`_). |
| 1009 | (Contributed by poq in :issue:`13773`.) |
| 1010 | |
| 1011 | |
Christian Heimes | 24cd4cf | 2013-06-22 19:31:58 +0200 | [diff] [blame] | 1012 | ssl |
| 1013 | --- |
| 1014 | |
R David Murray | 748bad2 | 2013-12-20 17:08:39 -0500 | [diff] [blame] | 1015 | .. _whatsnew-tls-11-12: |
Christian Heimes | 24cd4cf | 2013-06-22 19:31:58 +0200 | [diff] [blame] | 1016 | |
R David Murray | 748bad2 | 2013-12-20 17:08:39 -0500 | [diff] [blame] | 1017 | :data:`~ssl.PROTOCOL_TLSv1_1` and :data:`~ssl.PROTOCOL_TLSv1_2` (TLSv1.1 and |
| 1018 | TLSv1.2 support) have been added; support for these protocols is only available if |
| 1019 | Python is linked with OpenSSL 1.0.1 or later. (Contributed by Michele Orrù and |
| 1020 | Antoine Pitrou in :issue:`16692`) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1021 | |
R David Murray | 748bad2 | 2013-12-20 17:08:39 -0500 | [diff] [blame] | 1022 | New diagnostic functions :func:`~ssl.get_default_verify_paths`, |
| 1023 | :meth:`~ssl.SSLContext.cert_store_stats` and |
| 1024 | :meth:`~ssl.SSLContext.get_ca_certs` (Contributed by Christian Heimes |
| 1025 | in :issue:`18143` and :issue:`18147`) |
Christian Heimes | 24cd4cf | 2013-06-22 19:31:58 +0200 | [diff] [blame] | 1026 | |
R David Murray | 748bad2 | 2013-12-20 17:08:39 -0500 | [diff] [blame] | 1027 | Add :func:`ssl.enum_cert_store` to retrieve certificates and CRL from Windows' |
| 1028 | cert store. (Contributed by Christian Heimes in :issue:`17134`.) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1029 | |
| 1030 | Support for server-side SNI using the new |
| 1031 | :meth:`ssl.SSLContext.set_servername_callback` method. |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1032 | (Contributed by Daniel Black in :issue:`8109`.) |
| 1033 | |
| 1034 | |
Antoine Pitrou | d6cbd34 | 2013-08-12 20:48:15 +0200 | [diff] [blame] | 1035 | stat |
| 1036 | ---- |
| 1037 | |
| 1038 | The :mod:`stat` module is now backed by a C implementation in :mod:`_stat`. A C |
| 1039 | implementation is required as most of the values aren't standardized and |
| 1040 | platform-dependent. (Contributed by Christian Heimes in :issue:`11016`.) |
| 1041 | |
| 1042 | The module supports new file types: door, event port and whiteout. |
| 1043 | |
| 1044 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1045 | struct |
| 1046 | ------ |
| 1047 | |
R David Murray | 9835827 | 2014-01-05 20:52:06 -0500 | [diff] [blame] | 1048 | :mod:`struct` now supports the streamed unpacking of a buffer containing |
| 1049 | repeated instances of a given format of data. Both a module level |
| 1050 | :mod:`~struct.iter_unpack` function and a :meth:`struct.Struct.iter_unpack` |
| 1051 | method on compiled formats have been added. (Contributed by Antoine Pitrou in |
| 1052 | :issue:`17804`.) |
| 1053 | |
| 1054 | |
| 1055 | subprocess |
| 1056 | ---------- |
| 1057 | |
| 1058 | :func:`~subprocess.check_output` now accepts an *input* argument that can |
| 1059 | be used to provide the contents of ``stdin`` for the command that is run. |
| 1060 | (Contributed by Zack Weinberg in :issue:`16624`.) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1061 | |
| 1062 | |
Serhiy Storchaka | e06a896 | 2013-09-04 00:43:03 +0300 | [diff] [blame] | 1063 | sunau |
| 1064 | ----- |
| 1065 | |
| 1066 | The :meth:`~sunau.getparams` method now returns a namedtuple rather than a |
| 1067 | plain tuple. (Contributed by Claudiu Popa in :issue:`18901`.) |
| 1068 | |
Serhiy Storchaka | 34d2013 | 2013-09-05 17:01:53 +0300 | [diff] [blame] | 1069 | :meth:`sunau.open` now supports the context manager protocol (:issue:`18878`). |
| 1070 | |
Serhiy Storchaka | e06a896 | 2013-09-04 00:43:03 +0300 | [diff] [blame] | 1071 | |
R David Murray | d17aba7 | 2013-12-24 14:46:23 -0500 | [diff] [blame] | 1072 | sys |
| 1073 | --- |
| 1074 | |
| 1075 | New function :func:`sys.getallocatedblocks` returns the current number of |
| 1076 | blocks allocated by the interpreter (in CPython with the default |
| 1077 | ``--with-pymalloc`` setting, this is allocations made through the |
| 1078 | :c:func:`PyObject_Malloc` API). This can be useful for tracking memory leaks, |
| 1079 | especially if automated via a test suite. (Contributed by Antoine Pitrou |
| 1080 | in :issue:`13390`.) |
| 1081 | |
| 1082 | |
Andrew Kuchling | 173a157 | 2013-09-15 18:15:56 -0400 | [diff] [blame] | 1083 | traceback |
| 1084 | --------- |
| 1085 | |
| 1086 | A new :func:`traceback.clear_frames` function takes a traceback object |
| 1087 | and clears the local variables in all of the frames it references, |
| 1088 | reducing the amount of memory consumed (:issue:`1565525`). |
| 1089 | |
| 1090 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1091 | urllib |
| 1092 | ------ |
| 1093 | |
R David Murray | 473f45b | 2013-12-27 17:01:16 -0500 | [diff] [blame] | 1094 | :mod:`urllib.request` now supports ``data:`` URLs via the |
| 1095 | :class:`~urllib.request.DataHandler` class. (Contributed by Mathias Panzenböck |
| 1096 | in :issue:`16423`.) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1097 | |
| 1098 | |
| 1099 | unittest |
| 1100 | -------- |
| 1101 | |
R David Murray | 57fcf76 | 2014-01-03 23:31:54 -0500 | [diff] [blame] | 1102 | The :class:`~unittest.TestCase` class has a new method, |
| 1103 | :meth:`~unittest.TestCase.subTest`, that produces a context manager whose |
| 1104 | :keyword:`with` block becomes a "sub-test". This context manager allows a test |
| 1105 | method to dynamically generate subtests by, say, calling the ``subTest`` |
| 1106 | context manager inside a loop. A single test method can thereby produce an |
| 1107 | indefinite number of separately-identified and separately-counted tests, all of |
| 1108 | which will run even if one or more of them fail. For example:: |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1109 | |
R David Murray | 57fcf76 | 2014-01-03 23:31:54 -0500 | [diff] [blame] | 1110 | class NumbersTest(unittest.TestCase): |
| 1111 | def test_even(self): |
| 1112 | for i in range(6): |
| 1113 | with self.subTest(i=1): |
| 1114 | self.assertEqual(i % 2, 0) |
| 1115 | |
| 1116 | will result in six subtests, each identified in the unittest verbose output |
| 1117 | with a label consisting of the variable name ``i`` and a particular value for |
| 1118 | that variable (``i=0``, ``i=1``, etc). See :ref:`subtests` for the full |
| 1119 | version of this example. (Contributed by Antoine Pitrou in :issue:`16997`.) |
| 1120 | |
| 1121 | :func:`unittest.main` now accepts an iterable of test names for |
R David Murray | 9025f1c | 2014-01-02 13:44:18 -0500 | [diff] [blame] | 1122 | *defaultTest*, where previously it only accepted a single test name as a |
| 1123 | string. (Contributed by Jyrki Pulliainen in :issue:`15132`.) |
| 1124 | |
R David Murray | 42fa110 | 2014-01-03 13:03:36 -0500 | [diff] [blame] | 1125 | If :class:`~unittest.SkipTest` is raised during test discovery (that is, at the |
| 1126 | module level in the test file), it is now reported as a skip instead of an |
| 1127 | error. (Contributed by Zach Ware in :issue:`16935`.) |
| 1128 | |
R David Murray | db085f5 | 2014-01-03 15:46:24 -0500 | [diff] [blame] | 1129 | :meth:`~unittest.TestLoader.discover` now sorts the discovered files to provide |
| 1130 | consistent test ordering. (Contributed by Martin Melin and Jeff Ramnani in |
| 1131 | :issue:`16709`.) |
| 1132 | |
R David Murray | 8e37d5d | 2013-04-13 14:49:48 -0400 | [diff] [blame] | 1133 | |
R David Murray | 575fb31 | 2013-12-25 23:21:03 -0500 | [diff] [blame] | 1134 | venv |
| 1135 | ---- |
| 1136 | |
| 1137 | :mod:`venv` now includes activation scripts for the ``csh`` and ``fish`` |
| 1138 | shells (Contributed by Andrew Svetlov in :issue:`15417`.) |
| 1139 | |
| 1140 | |
R David Murray | 671cd32 | 2013-04-10 12:31:43 -0400 | [diff] [blame] | 1141 | wave |
| 1142 | ---- |
| 1143 | |
| 1144 | The :meth:`~wave.getparams` method now returns a namedtuple rather than a |
| 1145 | plain tuple. (Contributed by Claudiu Popa in :issue:`17487`.) |
| 1146 | |
R David Murray | c91d5ee | 2013-07-31 13:46:08 -0400 | [diff] [blame] | 1147 | :meth:`wave.open` now supports the context manager protocol. (Contributed |
| 1148 | by Claudiu Popa in :issue:`17616`.) |
| 1149 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1150 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1151 | weakref |
| 1152 | ------- |
| 1153 | |
| 1154 | New :class:`~weakref.WeakMethod` class simulates weak references to bound |
Nick Coghlan | be57ab8 | 2013-09-22 21:26:30 +1000 | [diff] [blame] | 1155 | methods. (Contributed by Antoine Pitrou in :issue:`14631`.) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1156 | |
Nick Coghlan | be57ab8 | 2013-09-22 21:26:30 +1000 | [diff] [blame] | 1157 | New :class:`~weakref.finalize` class makes it possible to register a callback |
| 1158 | to be invoked when an object is garbage collected, without needing to |
| 1159 | carefully manage the lifecycle of the weak reference itself. (Contributed by |
| 1160 | Richard Oudkerk in :issue:`15528`) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1161 | |
R David Murray | a101bdb | 2014-01-06 16:32:05 -0500 | [diff] [blame] | 1162 | The callback, if any, associated with a :class:`~weakref.ref` is now |
| 1163 | exposed via the :attr:`~weakref.ref.__callback__` attribute. (Contributed |
| 1164 | by Mark Dickinson in :issue:`17643`.) |
| 1165 | |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1166 | |
| 1167 | xml.etree |
| 1168 | --------- |
| 1169 | |
R David Murray | 410d320 | 2014-01-04 23:52:50 -0500 | [diff] [blame] | 1170 | A new parser, :class:`~xml.etree.ElementTree.XMLPullParser`, allows a |
| 1171 | non-blocking applications to parse XML documents. An example can be |
| 1172 | seen at :ref:`elementtree-pull-parsing`. (Contributed by Antoine |
| 1173 | Pitrou in :issue:`17741`.) |
Antoine Pitrou | f89aa9a | 2013-08-12 20:46:47 +0200 | [diff] [blame] | 1174 | |
R David Murray | 575fb31 | 2013-12-25 23:21:03 -0500 | [diff] [blame] | 1175 | The :mod:`xml.etree.ElementTree` :func:`~xml.etree.ElementTree.tostring` and |
| 1176 | :func:`~xml.etree.ElementTree.tostringlist` functions, and the |
| 1177 | :class:`~xml.etree.ElementTree.ElementTree` |
| 1178 | :meth:`~xml.etree.ElementTree.ElementTree.write` method, now have a |
| 1179 | *short_empty_elements* :ref:`keyword-only parameter <keyword-only_parameter>` |
| 1180 | providing control over whether elements with no content are written in |
| 1181 | abbreviated (``<tag />``) or expanded (``<tag></tag>``) form. (Contributed by |
| 1182 | Ariel Poliak and Serhiy Storchaka in :issue:`14377`.) |
| 1183 | |
Christian Tismer | 59202e5 | 2013-10-21 03:59:23 +0200 | [diff] [blame] | 1184 | |
| 1185 | zipfile.PyZipfile |
| 1186 | ----------------- |
| 1187 | |
| 1188 | Add a filter function to ignore some packages (tests for instance), |
| 1189 | :meth:`~zipfile.PyZipFile.writepy`. |
Christian Tismer | 59202e5 | 2013-10-21 03:59:23 +0200 | [diff] [blame] | 1190 | (Contributed by Christian Tismer in :issue:`19274`.) |
| 1191 | |
| 1192 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 1193 | |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1194 | CPython Implementation Changes |
| 1195 | ============================== |
| 1196 | |
| 1197 | |
R David Murray | c16dfe1 | 2013-12-21 12:32:10 -0500 | [diff] [blame] | 1198 | .. _whatsnew-pep-445: |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1199 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 1200 | PEP 445: Customization of CPython Memory Allocators |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1201 | --------------------------------------------------- |
| 1202 | |
| 1203 | :pep:`445` adds new C level interfaces to customize memory allocation in |
| 1204 | the CPython interpreter. |
| 1205 | |
| 1206 | .. seealso:: |
| 1207 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 1208 | :pep:`445` -- Add new APIs to customize Python memory allocators |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1209 | PEP written and implemented by Victor Stinner. |
| 1210 | |
| 1211 | |
R David Murray | c16dfe1 | 2013-12-21 12:32:10 -0500 | [diff] [blame] | 1212 | .. _whatsnew-pep-442: |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1213 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 1214 | PEP 442: Safe Object Finalization |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1215 | --------------------------------- |
| 1216 | |
| 1217 | :pep:`442` removes the current limitations and quirks of object finalization |
| 1218 | in CPython. With it, objects with :meth:`__del__` methods, as well as |
| 1219 | generators with :keyword:`finally` clauses, can be finalized when they are |
| 1220 | part of a reference cycle. |
| 1221 | |
| 1222 | As part of this change, module globals are no longer forcibly set to |
| 1223 | :const:`None` during interpreter shutdown in most cases, instead relying |
R David Murray | ca79461 | 2013-12-22 14:05:11 -0500 | [diff] [blame] | 1224 | on the normal operation of the cyclic garbage collector. This avoids a |
| 1225 | whole class of interpreter-shutdown-time errors, usually involving |
| 1226 | ``__del__`` methods, that have plagued Python since the cyclic GC |
| 1227 | was first introduced. |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1228 | |
| 1229 | .. seealso:: |
| 1230 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 1231 | :pep:`442` -- Safe object finalization |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1232 | PEP written and implemented by Antoine Pitrou. |
| 1233 | |
| 1234 | |
R David Murray | c16dfe1 | 2013-12-21 12:32:10 -0500 | [diff] [blame] | 1235 | .. _whatsnew-pep-456: |
| 1236 | |
| 1237 | PEP 456: Secure and Interchangeable Hash Algorithm |
| 1238 | -------------------------------------------------- |
| 1239 | |
| 1240 | :pep:`456` follows up on earlier security fix work done on Python's hash |
| 1241 | algorithm to address certain DOS attacks to which public facing APIs backed by |
| 1242 | dictionary lookups may be subject. (See :issue:`14621` for the start of the |
| 1243 | current round of improvements.) The PEP unifies CPython's hash code to make it |
| 1244 | easier for a packager to substitute a different hash algorithm, and switches |
| 1245 | Python's default implementation to a SipHash implementation on platforms that |
| 1246 | have a 64 bit data type. Any performance differences in comparison with the |
| 1247 | older FNV algorithm are trivial. |
| 1248 | |
| 1249 | The PEP adds additional fields to the :func:`sys.hash_info` struct sequence to |
| 1250 | describe the hash algorithm in use by the currently executing binary. Otherwise, |
| 1251 | the PEP does not alter any existing CPython APIs. |
| 1252 | |
| 1253 | |
R David Murray | 6dd1830 | 2013-12-24 12:23:56 -0500 | [diff] [blame] | 1254 | .. _whatsnew-pep-436: |
| 1255 | |
| 1256 | PEP 436: Argument Clinic |
| 1257 | ------------------------ |
| 1258 | |
| 1259 | "Argument Clinic" (:pep:`436`) is now part of the CPython build process |
| 1260 | and can be used to simplify the process of defining and maintaining |
| 1261 | accurate signatures for builtins and standard library extension modules |
| 1262 | implemented in C. |
| 1263 | |
| 1264 | .. note:: |
| 1265 | The Argument Clinic PEP is not fully up to date with the state of the |
| 1266 | implementation. This has been deemed acceptable by the release manager |
| 1267 | and core development team in this case, as Argument Clinic will not |
| 1268 | be made available as a public API for third party use in Python 3.4. |
| 1269 | |
| 1270 | .. seealso:: |
| 1271 | |
R David Murray | 061efb1 | 2013-12-24 12:35:59 -0500 | [diff] [blame] | 1272 | :pep:`436` -- The Argument Clinic DSL |
R David Murray | 6dd1830 | 2013-12-24 12:23:56 -0500 | [diff] [blame] | 1273 | PEP written and implemented by Larry Hastings. |
| 1274 | |
| 1275 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 1276 | Other Build and C API Changes |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1277 | ----------------------------- |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1278 | |
Nick Coghlan | 7d270ee | 2013-10-17 22:35:35 +1000 | [diff] [blame] | 1279 | * The new :c:func:`Py_SetStandardStreamEncoding` pre-initialization API |
| 1280 | allows applications embedding the CPython interpreter to reliably force |
| 1281 | a particular encoding and error handler for the standard streams |
| 1282 | (Contributed by Bastien Montagne and Nick Coghlan in :issue:`16129`) |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1283 | |
Nick Coghlan | 0acceb7 | 2013-10-20 13:22:21 +1000 | [diff] [blame] | 1284 | * Most Python C APIs that don't mutate string arguments are now correctly |
| 1285 | marked as accepting ``const char *`` rather than ``char *`` (Contributed |
| 1286 | by Serhiy Storchaka in :issue:`1772673`). |
| 1287 | |
R David Murray | d91ba20 | 2013-12-24 12:13:44 -0500 | [diff] [blame] | 1288 | * New shell version of ``python-config``; can be used even when a python |
| 1289 | interpreter is not available (for example, in cross compilation scenarios). |
| 1290 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1291 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 1292 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 1293 | Other Improvements |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1294 | ================== |
| 1295 | |
| 1296 | * Tab-completion is now enabled by default in the interactive interpreter. |
| 1297 | (Contributed by Antoine Pitrou and Éric Araujo in :issue:`5845`.) |
| 1298 | |
| 1299 | * Invoking the Python interpreter with ``--version`` now outputs the version to |
| 1300 | standard output instead of standard error (:issue:`18338`). Similar changes |
| 1301 | were made to :mod:`argparse` (:issue:`18920`) and other modules that have |
| 1302 | script-like invocation capabilities (:issue:`18922`). |
| 1303 | |
R David Murray | 72420ff | 2013-12-24 10:46:44 -0500 | [diff] [blame] | 1304 | * The CPython Windows installer now adds ``.py`` to the :envvar:`PATHEXT` |
| 1305 | variable when extensions are registered, allowing users to run a python |
| 1306 | script at the windows command prompt by just typing its name without the |
| 1307 | ``.py`` extension. (Contributed by Paul Moore in :issue:`18569`.) |
| 1308 | |
R David Murray | d17aba7 | 2013-12-24 14:46:23 -0500 | [diff] [blame] | 1309 | * A new ``make`` target `coverage-report |
| 1310 | <http://docs.python.org/devguide/coverage.html#measuring-coverage-of-c-code-with-gcov-and-lcov>`_ |
| 1311 | will build python, run the test suite, and generate an HTML coverage report |
| 1312 | for the C codebase using ``gcov`` and `lcov |
| 1313 | <http://ltp.sourceforge.net/coverage/lcov.php>`_. |
| 1314 | |
| 1315 | * The ``-R`` option to the :ref:`python regression test suite <regrtest>` now |
| 1316 | also checks for memory allocation leaks, using |
| 1317 | :func:`sys.getallocatedblocks()`. (Contributed by Antoine Pitrou in |
| 1318 | :issue:`13390`). |
| 1319 | |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1320 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 1321 | |
R David Murray | d74d09a | 2013-12-24 15:33:02 -0500 | [diff] [blame] | 1322 | Significant Optimizations |
| 1323 | ========================= |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1324 | |
R David Murray | 4908f4a | 2014-01-04 18:07:20 -0500 | [diff] [blame] | 1325 | * The UTF-32 decoder is now 3x to 4x faster. (Contributed by Serhiy Storchaka |
| 1326 | in :issue:`14625`.) |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1327 | |
| 1328 | * The cost of hash collisions for sets is now reduced. Each hash table |
| 1329 | probe now checks a series of consecutive, adjacent key/hash pairs before |
| 1330 | continuing to make random probes through the hash table. This exploits |
| 1331 | cache locality to make collision resolution less expensive. |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1332 | The collision resolution scheme can be described as a hybrid of linear |
| 1333 | probing and open addressing. The number of additional linear probes |
| 1334 | defaults to nine. This can be changed at compile-time by defining |
| 1335 | LINEAR_PROBES to be any value. Set LINEAR_PROBES=0 to turn-off |
R David Murray | 5917172 | 2014-01-03 15:52:22 -0500 | [diff] [blame] | 1336 | linear probing entirely. (Contributed by Raymond Hettinger in |
| 1337 | :issue:`18771`.) |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1338 | |
| 1339 | * The interpreter starts about 30% faster. A couple of measures lead to the |
| 1340 | speedup. The interpreter loads fewer modules on startup, e.g. the :mod:`re`, |
| 1341 | :mod:`collections` and :mod:`locale` modules and their dependencies are no |
| 1342 | longer imported by default. The marshal module has been improved to load |
R David Murray | 5917172 | 2014-01-03 15:52:22 -0500 | [diff] [blame] | 1343 | compiled Python code faster. (Contributed by Antoine Pitrou, Christian |
| 1344 | Heimes and Victor Stinner in :issue:`19219`, :issue:`19218`, :issue:`19209`, |
| 1345 | :issue:`19205` and :issue:`9548`) |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1346 | |
R David Murray | 6e39015 | 2013-12-24 22:28:04 -0500 | [diff] [blame] | 1347 | * :class:`bz2.BZ2File` is now as fast or faster than the Python2 version for |
| 1348 | most cases. :class:`lzma.LZMAFile` has also been optimized. (Contributed by |
| 1349 | Serhiy Storchaka and Nadeem Vawda in :issue:`16034`.) |
| 1350 | |
R David Murray | 8b2d682 | 2013-12-31 15:06:05 -0500 | [diff] [blame] | 1351 | * :func:`random.getrandbits` is 20%-40% faster for small integers (the most |
| 1352 | common use case). (Contributed by Serhiy Storchaka in :issue:`16674`). |
| 1353 | |
R David Murray | b231b2b | 2014-01-04 17:11:23 -0500 | [diff] [blame] | 1354 | * By taking advantage of the new storage format for strings, pickling of |
| 1355 | strings is now significantly faster. (Contributed by Victor Stinner and |
| 1356 | Antoine Pitrou in :issue:`15596`.) |
| 1357 | |
R David Murray | 66bf12a | 2014-01-08 17:21:22 -0500 | [diff] [blame] | 1358 | * A performance issue in :meth:`io.FileIO.readall` has been solved. This |
| 1359 | particularly affects Windows, and significantly speeds up the case of piping |
| 1360 | significant amounts of data through :mod:`subprocess`. (Contributed |
| 1361 | by Richard Oudkerk in :issue:`15758`.) |
| 1362 | |
R David Murray | bcaaecf | 2013-12-23 21:23:36 -0500 | [diff] [blame] | 1363 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 1364 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1365 | Deprecated |
| 1366 | ========== |
| 1367 | |
R David Murray | d74d09a | 2013-12-24 15:33:02 -0500 | [diff] [blame] | 1368 | This section covers various APIs and other features that have been deprecated |
| 1369 | in Python 3.4, and will be removed in Python 3.5 or later. In most (but not |
| 1370 | all) cases, using the deprecated APIs will produce a :exc:`DeprecationWarning` |
| 1371 | when the interpreter is run with deprecation warnings enabled (for example, by |
| 1372 | using ``-Wd``). |
| 1373 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1374 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 1375 | Deprecated Python Modules, Functions and Methods |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1376 | ------------------------------------------------ |
| 1377 | |
Terry Jan Reedy | 2b6c26e | 2013-03-21 19:36:26 -0400 | [diff] [blame] | 1378 | * :meth:`difflib.SequenceMatcher.isbjunk` and |
Andrew Kuchling | 0d0813a | 2013-06-15 13:29:09 -0400 | [diff] [blame] | 1379 | :meth:`difflib.SequenceMatcher.isbpopular` were removed: use ``x in sm.bjunk`` and |
| 1380 | ``x in sm.bpopular``, where *sm* is a :class:`~difflib.SequenceMatcher` object. |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1381 | |
Brett Cannon | 82b3d6a | 2013-06-14 22:37:11 -0400 | [diff] [blame] | 1382 | * :func:`importlib.util.module_for_loader` is pending deprecation. Using |
| 1383 | :func:`importlib.util.module_to_load` and |
| 1384 | :meth:`importlib.abc.Loader.init_module_attrs` allows subclasses of a loader |
| 1385 | to more easily customize module loading. |
| 1386 | |
Brett Cannon | e4f41de | 2013-06-16 13:13:40 -0400 | [diff] [blame] | 1387 | * The :mod:`imp` module is pending deprecation. To keep compatibility with |
| 1388 | Python 2/3 code bases, the module's removal is currently not scheduled. |
| 1389 | |
Brett Cannon | 1448ecf | 2013-10-04 11:38:59 -0400 | [diff] [blame] | 1390 | * The :mod:`formatter` module is pending deprecation and is slated for removal |
| 1391 | in Python 3.6. |
| 1392 | |
Christian Heimes | 634919a | 2013-11-20 17:23:06 +0100 | [diff] [blame] | 1393 | * MD5 as default digestmod for :mod:`hmac` is deprecated. Python 3.6 will |
| 1394 | require an explicit digest name or constructor as *digestmod* argument. |
| 1395 | |
R David Murray | 9025f1c | 2014-01-02 13:44:18 -0500 | [diff] [blame] | 1396 | * The internal ``Netrc`` class in the :mod:`ftplib` module has been documented |
| 1397 | as deprecated in its docstring for quite some time. It now emits a |
| 1398 | :exc:`DeprecationWarning` and will be removed completely in Python 3.5. |
| 1399 | |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1400 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 1401 | Deprecated Functions and Types in the C API |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1402 | ------------------------------------------- |
| 1403 | |
R David Murray | d74d09a | 2013-12-24 15:33:02 -0500 | [diff] [blame] | 1404 | XXX: None so far |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1405 | |
| 1406 | |
R David Murray | e7cf678 | 2013-12-24 14:51:25 -0500 | [diff] [blame] | 1407 | Deprecated Features |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1408 | ------------------- |
| 1409 | |
R David Murray | 5ea9524 | 2013-12-24 15:59:57 -0500 | [diff] [blame] | 1410 | * Running :ref:`idle` with the ``-n`` flag (no subprocess) is deprecated. |
| 1411 | However, the feature will not be removed until :issue:`18823` is resolved. |
| 1412 | |
Antoine Pitrou | 3b2f0f0 | 2013-10-25 21:39:26 +0200 | [diff] [blame] | 1413 | * The site module adding a "site-python" directory to sys.path, if it |
| 1414 | exists, is deprecated (:issue:`19375`). |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1415 | |
| 1416 | |
R David Murray | 5917172 | 2014-01-03 15:52:22 -0500 | [diff] [blame] | 1417 | |
R David Murray | 72420ff | 2013-12-24 10:46:44 -0500 | [diff] [blame] | 1418 | Removed |
| 1419 | ======= |
| 1420 | |
R David Murray | 5917172 | 2014-01-03 15:52:22 -0500 | [diff] [blame] | 1421 | |
| 1422 | Operating Systems No Longer Supported |
| 1423 | ------------------------------------- |
| 1424 | |
| 1425 | Support for the following operating systems has been removed from the source |
| 1426 | and build tools: |
| 1427 | |
| 1428 | * OS/2 (:issue:`16135`). |
| 1429 | * Windows 2000 (changeset e52df05b496a). |
| 1430 | * VMS (:issue:`16136`). |
| 1431 | |
| 1432 | |
| 1433 | API and Feature Removals |
| 1434 | ------------------------ |
| 1435 | |
R David Murray | d265381 | 2013-12-27 14:06:15 -0500 | [diff] [blame] | 1436 | The following obsolete and previously deprecated APIs and features have been |
R David Murray | 5917172 | 2014-01-03 15:52:22 -0500 | [diff] [blame] | 1437 | removed: |
R David Murray | 076dead | 2013-12-24 14:59:50 -0500 | [diff] [blame] | 1438 | |
R David Murray | 72420ff | 2013-12-24 10:46:44 -0500 | [diff] [blame] | 1439 | * The unmaintained ``Misc/TextMate`` and ``Misc/vim`` directories have been |
R David Murray | d91ba20 | 2013-12-24 12:13:44 -0500 | [diff] [blame] | 1440 | removed (see the `devguide <http://docs.python.org/devguide>`_ |
R David Murray | 0056936 | 2014-01-03 13:04:25 -0500 | [diff] [blame] | 1441 | for suggestions on what to use instead). |
R David Murray | 72420ff | 2013-12-24 10:46:44 -0500 | [diff] [blame] | 1442 | |
R David Murray | d17aba7 | 2013-12-24 14:46:23 -0500 | [diff] [blame] | 1443 | * The ``SO`` makefile macro is removed (it was replaced by the |
| 1444 | ``SHLIB_SUFFIX`` and ``EXT_SUFFIX`` macros) (:issue:`16754`). |
| 1445 | |
R David Murray | d74d09a | 2013-12-24 15:33:02 -0500 | [diff] [blame] | 1446 | * The ``PyThreadState.tick_counter`` field has been removed; its value has |
| 1447 | been meaningless since Python 3.2, when the "new GIL" was introduced. |
| 1448 | |
R David Murray | d265381 | 2013-12-27 14:06:15 -0500 | [diff] [blame] | 1449 | * ``PyLoader`` and ``PyPycLoader`` have been removed from :mod:`importlib`. |
| 1450 | (Contributed by Taras Lyapun in :issue:`15641`.) |
| 1451 | |
R David Murray | a2924ca | 2014-01-03 14:06:01 -0500 | [diff] [blame] | 1452 | * The *strict* argument to :class:`~http.client.HTTPConnection` and |
| 1453 | :class:`~http.client.HTTPSConnection` has been removed. HTTP 0.9-style |
| 1454 | "Simple Responses" are no longer supported. |
R David Murray | 0056936 | 2014-01-03 13:04:25 -0500 | [diff] [blame] | 1455 | |
R David Murray | db085f5 | 2014-01-03 15:46:24 -0500 | [diff] [blame] | 1456 | * The deprecated :mod:`urllib.request.Request` getter and setter methods |
| 1457 | ``add_data``, ``has_data``, ``get_data``, ``get_type``, ``get_host``, |
| 1458 | ``get_selector``, ``set_proxy``, ``get_origin_req_host``, and |
| 1459 | ``is_unverifiable`` have been removed (use direct attribute access instead). |
| 1460 | |
R David Murray | 244ad60 | 2014-01-04 21:17:52 -0500 | [diff] [blame] | 1461 | * Support for loading the deprecated ``TYPE_INT64`` has been removed from |
| 1462 | :mod:`marshal`. (Contributed by Dan Riti in :issue:`15480`.) |
| 1463 | |
R David Murray | 72420ff | 2013-12-24 10:46:44 -0500 | [diff] [blame] | 1464 | |
R David Murray | 9835827 | 2014-01-05 20:52:06 -0500 | [diff] [blame] | 1465 | Code Cleanups |
| 1466 | ------------- |
| 1467 | |
| 1468 | * The unused and undocumented internal ``Scanner`` class has been removed from |
| 1469 | the :mod:`pydoc` module. |
| 1470 | |
| 1471 | |
R David Murray | e608255 | 2014-01-03 16:15:45 -0500 | [diff] [blame] | 1472 | |
Benjamin Peterson | 88f3b23 | 2012-10-04 12:45:10 -0400 | [diff] [blame] | 1473 | Porting to Python 3.4 |
Georg Brandl | b80f511 | 2012-09-30 09:11:58 +0200 | [diff] [blame] | 1474 | ===================== |
| 1475 | |
| 1476 | This section lists previously described changes and other bugfixes |
| 1477 | that may require changes to your code. |
| 1478 | |
R David Murray | d74d09a | 2013-12-24 15:33:02 -0500 | [diff] [blame] | 1479 | Changes in the Python API |
| 1480 | ------------------------- |
| 1481 | |
Brett Cannon | 777622b | 2013-04-09 17:03:10 -0400 | [diff] [blame] | 1482 | * The ABCs defined in :mod:`importlib.abc` now either raise the appropriate |
| 1483 | exception or return a default value instead of raising |
| 1484 | :exc:`NotImplementedError` blindly. This will only affect code calling |
| 1485 | :func:`super` and falling through all the way to the ABCs. For compatibility, |
| 1486 | catch both :exc:`NotImplementedError` or the appropriate exception as needed. |
Brett Cannon | 4c14b5d | 2013-05-04 13:56:58 -0400 | [diff] [blame] | 1487 | |
| 1488 | * The module type now initializes the :attr:`__package__` and :attr:`__loader__` |
| 1489 | attributes to ``None`` by default. To determine if these attributes were set |
| 1490 | in a backwards-compatible fashion, use e.g. |
Brett Cannon | 3dc48d6 | 2013-05-28 18:35:54 -0400 | [diff] [blame] | 1491 | ``getattr(module, '__loader__', None) is not None``. |
| 1492 | |
| 1493 | * :meth:`importlib.util.module_for_loader` now sets ``__loader__`` and |
| 1494 | ``__package__`` unconditionally to properly support reloading. If this is not |
| 1495 | desired then you will need to set these attributes manually. You can use |
Brett Cannon | 028d512 | 2013-05-31 18:02:11 -0400 | [diff] [blame] | 1496 | :func:`importlib.util.module_to_load` for module management. |
Brett Cannon | 3e0651b | 2013-05-31 23:18:39 -0400 | [diff] [blame] | 1497 | |
| 1498 | * Import now resets relevant attributes (e.g. ``__name__``, ``__loader__``, |
| 1499 | ``__package__``, ``__file__``, ``__cached__``) unconditionally when reloading. |
| 1500 | |
Brett Cannon | 1448ecf | 2013-10-04 11:38:59 -0400 | [diff] [blame] | 1501 | * Frozen packages no longer set ``__path__`` to a list containing the package |
| 1502 | name but an empty list instead. Determing if a module is a package should be |
| 1503 | done using ``hasattr(module, '__path__')``. |
Brett Cannon | 8f5ac51 | 2013-06-12 23:29:18 -0400 | [diff] [blame] | 1504 | |
Brett Cannon | 33915eb | 2013-06-14 18:33:00 -0400 | [diff] [blame] | 1505 | * :func:`py_compile.compile` now raises :exc:`FileExistsError` if the file path |
| 1506 | it would write to is a symlink or a non-regular file. This is to act as a |
| 1507 | warning that import will overwrite those files with a regular file regardless |
| 1508 | of what type of file path they were originally. |
Brett Cannon | f4375ef | 2013-06-16 18:05:54 -0400 | [diff] [blame] | 1509 | |
| 1510 | * :meth:`importlib.abc.SourceLoader.get_source` no longer raises |
| 1511 | :exc:`ImportError` when the source code being loaded triggers a |
| 1512 | :exc:`SyntaxError` or :exc:`UnicodeDecodeError`. As :exc:`ImportError` is |
| 1513 | meant to be raised only when source code cannot be found but it should, it was |
| 1514 | felt to be over-reaching/overloading of that meaning when the source code is |
| 1515 | found but improperly structured. If you were catching ImportError before and |
| 1516 | wish to continue to ignore syntax or decoding issues, catch all three |
Victor Stinner | 84e33c8 | 2013-06-21 00:31:55 +0200 | [diff] [blame] | 1517 | exceptions now. |
Nick Coghlan | 24c05bc | 2013-07-15 21:13:08 +1000 | [diff] [blame] | 1518 | |
| 1519 | * :func:`functools.update_wrapper` and :func:`functools.wraps` now correctly |
Nick Coghlan | 367df12 | 2013-10-27 01:57:34 +1000 | [diff] [blame] | 1520 | set the ``__wrapped__`` attribute to the function being wrapper, even if |
| 1521 | that function also had its ``__wrapped__`` attribute set. This means |
| 1522 | ``__wrapped__`` attributes now correctly link a stack of decorated |
| 1523 | functions rather than every ``__wrapped__`` attribute in the chain |
| 1524 | referring to the innermost function. Introspection libraries that |
| 1525 | assumed the previous behaviour was intentional can use |
| 1526 | :func:`inspect.unwrap` to access the first function in the chain that has |
| 1527 | no ``__wrapped__`` attribute. |
Victor Stinner | 2fe9bac | 2013-10-10 16:18:20 +0200 | [diff] [blame] | 1528 | |
Georg Brandl | 0f5bff2 | 2013-10-19 17:46:38 +0200 | [diff] [blame] | 1529 | * :class:`importlib.machinery.PathFinder` now passes on the current working |
Brett Cannon | 27e27f7 | 2013-10-18 11:39:04 -0400 | [diff] [blame] | 1530 | directory to objects in :data:`sys.path_hooks` for the empty string. This |
| 1531 | results in :data:`sys.path_importer_cache` never containing ``''``, thus |
| 1532 | iterating through :data:`sys.path_importer_cache` based on :data:`sys.path` |
| 1533 | will not find all keys. A module's ``__file__`` when imported in the current |
| 1534 | working directory will also now have an absolute path, including when using |
| 1535 | ``-m`` with the interpreter (this does not influence when the path to a file |
| 1536 | is specified on the command-line). |
Victor Stinner | 2748bc7 | 2013-12-13 10:57:04 +0100 | [diff] [blame] | 1537 | |
R David Murray | a2924ca | 2014-01-03 14:06:01 -0500 | [diff] [blame] | 1538 | * The removal of the *strict* argument to :class:`~http.client.HTTPConnection` |
| 1539 | and :class:`~http.client.HTTPSConnection` changes the meaning of the |
| 1540 | remaining arguments if you are specifying them positionally rather than by |
| 1541 | keyword. If you've been paying attention to deprecation warnings your code |
| 1542 | should already be specifying any additional arguments via keywords. |
| 1543 | |
R David Murray | 4908f4a | 2014-01-04 18:07:20 -0500 | [diff] [blame] | 1544 | * Strings between ``from __future__ import ...`` statements now *always* raise |
| 1545 | a :exc:`SyntaxError`. Previously if there was no leading docstring, an |
| 1546 | interstitial string would sometimes be ignored. This brings CPython into |
| 1547 | compliance with the language spec; Jython and PyPy already were. |
| 1548 | (:issue:`17434`). |
| 1549 | |
R David Murray | a101bdb | 2014-01-06 16:32:05 -0500 | [diff] [blame] | 1550 | * :meth:`ssl.SSLSocket.getpeercert` and :meth:`ssl.SSLSocket.do_handshake` |
| 1551 | now raise an :exc:`OSError` with ``ENOTCONN`` when the ``SSLSocket`` is not |
| 1552 | connected, instead of the previous behavior of raising an |
| 1553 | :exc:`AttributError`. In addition, :meth:`~ssl.SSLSocket.getpeercert` |
| 1554 | will raise a :exc:`ValueError` if the handshake has not yet been done. |
| 1555 | |
R David Murray | 0ae7ae1 | 2014-01-08 18:16:02 -0500 | [diff] [blame] | 1556 | * :func:`base64.b32decode` now raises a :exc:`binascii.Error` when the |
| 1557 | input string contains non-b32-alphabet characters, instead of a |
| 1558 | :exc:`TypeError`. This particular :exc:`TypeError` was missed when the other |
| 1559 | :exc:`TypeError`\ s were converted. (Contributed by Serhiy Storchaka in |
| 1560 | :issue:`18011`.) Note: this change was also inadvertently applied in Python |
| 1561 | 3.3.3. |
| 1562 | |
Brett Cannon | c089f70 | 2014-01-17 11:03:19 -0500 | [diff] [blame] | 1563 | * The :attr:`~cgi.FieldStorage.file` attribute is now automatically closed when |
| 1564 | the creating :class:`cgi.FieldStorage` instance is garbage collected. If you |
| 1565 | were pulling the file object out separately from the :class:`cgi.FieldStorage` |
| 1566 | instance and not keeping the instance alive, then you should either store the |
| 1567 | entire :class:`cgi.FieldStorage` instance or read the contents of the file |
| 1568 | before the :class:`cgi.FieldStorage` instance is garbage collected. |
| 1569 | |
R David Murray | d265381 | 2013-12-27 14:06:15 -0500 | [diff] [blame] | 1570 | |
Victor Stinner | 774b2e0 | 2013-12-13 14:33:01 +0100 | [diff] [blame] | 1571 | Changes in the C API |
| 1572 | -------------------- |
| 1573 | |
| 1574 | * :c:func:`PyErr_SetImportError` now sets :exc:`TypeError` when its **msg** |
| 1575 | argument is not set. Previously only ``NULL`` was returned with no exception |
| 1576 | set. |
| 1577 | |
| 1578 | * The result of the :c:data:`PyOS_ReadlineFunctionPointer` callback must |
| 1579 | now be a string allocated by :c:func:`PyMem_RawMalloc` or |
| 1580 | :c:func:`PyMem_RawRealloc`, or *NULL* if an error occurred, instead of a |
| 1581 | string allocated by :c:func:`PyMem_Malloc` or :c:func:`PyMem_Realloc`. |
| 1582 | |
| 1583 | * :c:func:`PyThread_set_key_value` now always set the value. In Python |
Victor Stinner | 2748bc7 | 2013-12-13 10:57:04 +0100 | [diff] [blame] | 1584 | 3.3, the function did nothing if the key already exists (if the current |
| 1585 | value is a non-NULL pointer). |
| 1586 | |
Victor Stinner | 774b2e0 | 2013-12-13 14:33:01 +0100 | [diff] [blame] | 1587 | * The ``f_tstate`` (thread state) field of the :c:type:`PyFrameObject` |
| 1588 | structure has been removed to fix a bug: see :issue:`14432` for the |
| 1589 | rationale. |
| 1590 | |