Commit 40cd4d4d authored by Jason Madden's avatar Jason Madden

Updating changelog for 1.3a2 release [skip ci]

parent e966b871
...@@ -7,10 +7,83 @@ ...@@ -7,10 +7,83 @@
1.3a2 (unreleased) 1.3a2 (unreleased)
================== ==================
- Fix building from a source distribution (PyPI) without Cython installed. Dependencies
------------
- Cython 0.28b1 or later is now required to build gevent from a source - Cython 0.28b1 or later is now required to build gevent from a source
checkout. checkout (Cython is *not* required to build a source distribution
from PyPI).
- Update c-ares to 1.14.0. See :issue:`1105`.
- gevent now **requires** the patched version of libuv it is
distributed with. Building gevent with a non-embedded libuv, while
not previously supported, is not possible now. See
:issue:`1126`.
Platform Support
----------------
- Travis CI tests on Python 3.7.0b2 and PyPy 2.7 5.10.0 and PyPy 3.5
5.10.1.
Build Changes
-------------
- Fix building from a source distribution (PyPI) without Cython installed.
Enhancements
------------
- Add the ``dnspython`` resolver as a lightweight alternative to
c-ares. It is generally faster than c-ares and is supported on PyPy.
c-ares may be deprecated in the future. See :pr:`1088` and
:issue:`1103`.
- Add the module :mod:`gevent.time` that can be imported instead of
:mod:`time`, much like :mod:`gevent.socket` can be imported instead
of :mod:`socket`. It contains ``gevent.sleep``. This aids
monkey-patching.
- Simple subclasses of `gevent.local.local` now have the same
(substantially improved) performance characteristics of plain
`gevent.local.local` itself, making them 2 to 3 times faster than
before. See :pr:`1117`. If there are any compatibility
problems, please open issues.
Monitoring and Debugging
~~~~~~~~~~~~~~~~~~~~~~~~
- Greenlet objects now keep track of their spawning parent greenlet
and the code location that spawned them, in addition to maintaining
a "spawn tree local" mapping. This adds some runtime overhead in
relative terms, but absolute numbers are still relatively small.
Based on a proposal from PayPal and comments by Mahmoud Hashemi and
Kurt Rose. See :issue:`755` and :pr:`1115`. As always, feedback is
appreciated.
- Greenlet objects now have a `minimal_ident
<gevent.Greenlet.minimal_ident>` property. It functions
similarly to ``Thread.ident`` or ``id`` by uniquely identifying the
greenlet object while it remains alive, and it can be reused after
the greenlet object is dead. It is different in that it is small and
sequential. Based on a proposal from PayPal and comments by Mahmoud
Hashemi and Kurt Rose. See :issue:`755`. As always, feedback is
appreciated.
- `gevent.Greenlet` objects now have a `gevent.Greenlet.name`
attribute that is included in the default repr.
- Include the values of `gevent.local.local` objects associated with
each greenlet in `gevent.util.format_run_info`.
- Add `gevent.util.GreenletTree` to visualize the greenlet tree. This
is used by `gevent.util.format_run_info`.
Subprocess
~~~~~~~~~~
- Make :class:`gevnt.subprocess.Popen` accept the ``restore_signals`` - Make :class:`gevnt.subprocess.Popen` accept the ``restore_signals``
keyword argument on all versions of Python, and on Python 2 have it keyword argument on all versions of Python, and on Python 2 have it
...@@ -26,31 +99,11 @@ ...@@ -26,31 +99,11 @@
They have always had the same default as Python 3, namely an empty They have always had the same default as Python 3, namely an empty
tuple and false, but now are accessible to Python 2. tuple and false, but now are accessible to Python 2.
- The internal, undocumented module ``gevent._threading`` has been
simplified.
- The internal, undocumented class ``gevent._socket3._fileobject`` has
been removed. See :issue:`1084`.
- Travis CI tests on Python 3.7.0b2 and PyPy 2.7 5.10.0 and PyPy 3.5
5.10.1.
- Support the ``capture_output`` argument added to Python 3.7 in - Support the ``capture_output`` argument added to Python 3.7 in
:func:`gevent.subprocess.run`. :func:`gevent.subprocess.run`.
- Add the ``dnspython`` resolver as a lightweight alternative to Configuration
c-ares. See :pr:`1088` and :issue:`1103`. ~~~~~~~~~~~~~
- The ``GEVENTARES_SERVERS`` environment variable is deprecated in
favor of ``GEVENT_RESOLVER_SERVERS``. See :issue:`1103`.
- Fix calling ``shutdown`` on a closed socket. It was raising
``AttributeError``, now it once again raises the correct
``socket.error``. Reported in :issue:`1089` by André Cimander.
- Add the module :mod:`gevent.time` that can be imported instead of
:mod:`time`, much like :mod:`gevent.socket` can be imported instead
of :mod:`socket`.
- Centralize all gevent configuration in an object at - Centralize all gevent configuration in an object at
``gevent.config``, allowing for gevent to be configured through code ``gevent.config``, allowing for gevent to be configured through code
...@@ -64,12 +117,34 @@ ...@@ -64,12 +117,34 @@
order, or be a dotted name; it may also be assigned to an order, or be a dotted name; it may also be assigned to an
object in Python code at ``gevent.config.loop``). object in Python code at ``gevent.config.loop``).
- The ``GEVENTARES_SERVERS`` environment variable is deprecated in
favor of ``GEVENT_RESOLVER_SERVERS``. See :issue:`1103`.
Bug Fixes
---------
- Fix calling ``shutdown`` on a closed socket. It was raising
``AttributeError``, now it once again raises the correct
``socket.error``. Reported in :issue:`1089` by André Cimander.
- Fix an interpreter crash that could happen if two or more ``loop`` - Fix an interpreter crash that could happen if two or more ``loop``
objects referenced the default event loop and one of them was objects referenced the default event loop and one of them was
destroyed and then the other one destroyed or (in the libev C destroyed and then the other one destroyed or (in the libev C
extension implementation only) deallocated (garbage collected). See extension implementation only) deallocated (garbage collected). See
:issue:`1098`. :issue:`1098`.
- Fix a race condition in libuv child callbacks. See :issue:`1104`.
Other Changes
-------------
- The internal, undocumented module ``gevent._threading`` has been
simplified.
- The internal, undocumented class ``gevent._socket3._fileobject`` has
been removed. See :issue:`1084`.
- Simplify handling of the libev default loop and the ``destroy()`` - Simplify handling of the libev default loop and the ``destroy()``
method. The default loop, when destroyed, can again be requested and method. The default loop, when destroyed, can again be requested and
it will regenerate itself. The default loop is the only one that can it will regenerate itself. The default loop is the only one that can
...@@ -78,62 +153,21 @@ ...@@ -78,62 +153,21 @@
- Make :meth:`gevent.socket.socket.sendall` up to ten times faster on - Make :meth:`gevent.socket.socket.sendall` up to ten times faster on
PyPy3, through the same change that was applied in gevent 1.1b3 for PyPy2. PyPy3, through the same change that was applied in gevent 1.1b3 for PyPy2.
- Update c-ares to 1.14.0. See :issue:`1105`.
- Be more careful about issuing a warning about patching SSL on - Be more careful about issuing a warning about patching SSL on
Python 2. See :issue:`1108`. Python 2. See :issue:`1108`.
- Fix a race condition in libuv child callbacks. See :issue:`1104`.
- Signal handling under PyPy with libuv is more reliable. See - Signal handling under PyPy with libuv is more reliable. See
:issue:`1112`. :issue:`1112`.
- Greenlet objects now keep track of their spawning parent greenlet
and the code location that spawned them, in addition to maintaining
a "spawn tree local" mapping. This adds some runtime overhead in
relative terms, but absolute numbers are still relatively small.
Based on a proposal from PayPal and comments by Mahmoud Hashemi and
Kurt Rose. See :issue:`755` and :pr:`1115`. As always, feedback is
appreciated.
- The :mod:`gevent.greenlet` module is now compiled with Cython to - The :mod:`gevent.greenlet` module is now compiled with Cython to
offset any performance decrease due to :issue:`755`. Please open offset any performance decrease due to :issue:`755`. Please open
issues for any compatibility concerns. See :pr:`1115` and :pr:`1120`. issues for any compatibility concerns. See :pr:`1115` and :pr:`1120`.
- Greenlet objects now have a `minimal_ident
<gevent.Greenlet.minimal_ident>` property. It functions
similarly to ``Thread.ident`` or ``id`` by uniquely identifying the
greenlet object while it remains alive, and it can be reused after
the greenlet object is dead. It is different in that it is small and
sequential. Based on a proposal from PayPal and comments by Mahmoud
Hashemi and Kurt Rose. See :issue:`755`. As always, feedback is
appreciated.
- Simple subclasses of `gevent.local.local` now have the same
(substantially improved) performance characteristics of plain
`gevent.local.local` itself, making them 2 to 3 times faster than
before. See :pr:`1117`. If there are any compatibility
problems, please open issues.
- On CPython, allow the pure-Python implementations of - On CPython, allow the pure-Python implementations of
`gevent.Greenlet`, `gevent.local` and `gevent.lock` to be `gevent.Greenlet`, `gevent.local` and `gevent.lock` to be
used when the environment variable ``PURE_PYTHON`` is set. This is used when the environment variable ``PURE_PYTHON`` is set. This is
not recommended except for debugging and testing. See :issue:`1118`. not recommended except for debugging and testing. See :issue:`1118`.
- Include the values of `gevent.local.local` objects associated with
each greenlet in `gevent.util.format_run_info`.
- `gevent.Greenlet` objects now have a `gevent.Greenlet.name`
attribute that is included in the default repr.
- Add `gevent.util.GreenletTree` to visualize the greenlet tree. This
is used by `gevent.util.format_run_info`.
- gevent now **requires** the patched version of libuv it is
distributed with. Building gevent with a non-embedded libuv, while
not previously supported, is not possible now. See
:issue:`1226`.
- :meth:`gevent.select.poll.poll` now interprets a *timeout* of -1 the - :meth:`gevent.select.poll.poll` now interprets a *timeout* of -1 the
same as a *timeout* of *None* as the standard requires. Previously, same as a *timeout* of *None* as the standard requires. Previously,
on libuv this was interpreted the same as a *timeout* of 0. In on libuv this was interpreted the same as a *timeout* of 0. In
......
...@@ -186,6 +186,7 @@ Timeouts ...@@ -186,6 +186,7 @@ Timeouts
.. autofunction:: with_timeout .. autofunction:: with_timeout
.. _gevent-configuration:
Configuration Configuration
============= =============
......
...@@ -6,39 +6,48 @@ Detailed information on what has changed is available in the ...@@ -6,39 +6,48 @@ Detailed information on what has changed is available in the
:doc:`changelog`. This document summarizes the most important changes :doc:`changelog`. This document summarizes the most important changes
since :doc:`gevent 1.2 <whatsnew_1_2>`. since :doc:`gevent 1.2 <whatsnew_1_2>`.
.. caution:: This document has not yet been updated for gevent 1.3. .. caution:: This document has not yet been fully updated for gevent 1.3.
In general, gevent 1.2 is a smaller update than gevent 1.1, focusing gevent 1.3 is an important update for performance, debugging and
on platform support, standard library compatibility, security, bug monitoring, and platform support. It introduces an (optional) `libuv
fixes and consistency. <http://libuv.org>`_ loop implementation and supports PyPy on Windows.
See :ref:`gevent-configuration` for information on how to use libuv.
Platform Support Platform Support
================ ================
gevent 1.2 supports Python 2.7, 3.4, 3.5 and 3.6 on the CPython gevent 1.3 supports Python 2.7, 3.4, 3.5, 3.6 and 3.7 on the CPython
(`python.org`_) interpreter. It also supports `PyPy2`_ 4.0.1 and above (`python.org`_) interpreter. It also supports `PyPy2`_ 5.8.0 and above
(PyPy2 5.4 or higher is recommended) and PyPy3 5.5.0. (PyPy2 5.10 or higher is recommended) and PyPy3 5.10.0.
.. caution:: Python 2.7.8 and below (Python 2.7 without a modern
``ssl`` module), is no longer tested or supported. The
support code remains in this release and gevent can be
installed on such implementations, but such usage is not
supported.
.. caution:: Support for Python 2.6 was removed. Support for Python 3.3 is only .. note:: PyPy is now supported on Windows with the libuv loop implementation.
tested on PyPy3.
.. note:: PyPy is not supported on Windows. (gevent's CFFI backend is not Python 3.7 is in the process of release right now and gevent is tested
available on Windows.) with 3.7b2.
Python 3.6 was released recently and is supported at the same level as 3.5. For ease of installation on Windows and OS X, gevent 1.3 is
For ease of installation on Windows and OS X, gevent 1.2 is
distributed as pre-compiled binary wheels, in addition to source code. distributed as pre-compiled binary wheels, in addition to source code.
.. note:: On Linux, you'll need to install gevent from source if you
wish to use the libuv loop implementation. This is because
the `manylinux1
<https://www.python.org/dev/peps/pep-0513/>`_ specification
for the distributed wheels does not support libuv.
.. _python.org: http://www.python.org/downloads/ .. _python.org: http://www.python.org/downloads/
.. _PyPy2: http://pypy.org .. _PyPy2: http://pypy.org
Bug Fixes Bug Fixes
========= =========
Since 1.1.2, gevent 1.2 contains over 240 commits from nine different TODO: How many commits and contributors? How many pull requests merged?
dozen contributors. About two dozen pull requests were merged.
New Pure-Python DNS Resolver New Pure-Python DNS Resolver
============================ ============================
...@@ -57,8 +66,7 @@ Library Updates ...@@ -57,8 +66,7 @@ Library Updates
=============== ===============
One of the C libraries that are bundled with gevent have been updated. One of the C libraries that are bundled with gevent have been updated.
c-ares has been updated from 1.12.0 to 1.13.0 (`c-ares release notes`_). c-ares has been updated from 1.13.0 to 1.14.0 (`c-ares release notes`_).
.. _c-ares release notes: https://c-ares.haxx.se/changelog.html .. _c-ares release notes: https://c-ares.haxx.se/changelog.html
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment