Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
40cd4d4d
Commit
40cd4d4d
authored
Mar 06, 2018
by
Jason Madden
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Updating changelog for 1.3a2 release [skip ci]
parent
e966b871
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
126 additions
and
83 deletions
+126
-83
CHANGES.rst
CHANGES.rst
+99
-65
doc/gevent.rst
doc/gevent.rst
+1
-0
doc/whatsnew_1_3.rst
doc/whatsnew_1_3.rst
+26
-18
No files found.
CHANGES.rst
View file @
40cd4d4d
...
@@ -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
...
...
doc/gevent.rst
View file @
40cd4d4d
...
@@ -186,6 +186,7 @@ Timeouts
...
@@ -186,6 +186,7 @@ Timeouts
.. autofunction:: with_timeout
.. autofunction:: with_timeout
.. _gevent-configuration:
Configuration
Configuration
=============
=============
...
...
doc/whatsnew_1_3.rst
View file @
40cd4d4d
...
@@ -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
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment