Skip to main content

Lightweight in-process concurrent programming

Project description

https://github.com/python-greenlet/greenlet/workflows/tests/badge.svg

Greenlets are lightweight coroutines for in-process concurrent programming.

The “greenlet” package is a spin-off of Stackless, a version of CPython that supports micro-threads called “tasklets”. Tasklets run pseudo-concurrently (typically in a single or a few OS-level threads) and are synchronized with data exchanges on “channels”.

A “greenlet”, on the other hand, is a still more primitive notion of micro-thread with no implicit scheduling; coroutines, in other words. This is useful when you want to control exactly when your code runs. You can build custom scheduled micro-threads on top of greenlet; however, it seems that greenlets are useful on their own as a way to make advanced control flow structures. For example, we can recreate generators; the difference with Python’s own generators is that our generators can call nested functions and the nested functions can yield values too. (Additionally, you don’t need a “yield” keyword. See the example in test_generator.py).

Greenlets are provided as a C extension module for the regular unmodified interpreter.

Who is using Greenlet?

There are several libraries that use Greenlet as a more flexible alternative to Python’s built in coroutine support:

Getting Greenlet

The easiest way to get Greenlet is to install it with pip:

pip install greenlet

Source code archives and binary distributions are vailable on the python package index at https://pypi.org/project/greenlet

The source code repository is hosted on github: https://github.com/python-greenlet/greenlet

Documentation is available on readthedocs.org: https://greenlet.readthedocs.io

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

greenlet-1.1.2.tar.gz (91.2 kB view hashes)

Uploaded source

Built Distributions

greenlet-1.1.2-cp310-cp310-win_amd64.whl (102.0 kB view hashes)

Uploaded cp310

greenlet-1.1.2-cp39-cp39-win_amd64.whl (101.9 kB view hashes)

Uploaded cp39

greenlet-1.1.2-cp39-cp39-win32.whl (99.0 kB view hashes)

Uploaded cp39

greenlet-1.1.2-cp38-cp38-win_amd64.whl (101.6 kB view hashes)

Uploaded cp38

greenlet-1.1.2-cp38-cp38-win32.whl (98.6 kB view hashes)

Uploaded cp38

greenlet-1.1.2-cp37-cp37m-win_amd64.whl (101.2 kB view hashes)

Uploaded cp37

greenlet-1.1.2-cp37-cp37m-win32.whl (98.2 kB view hashes)

Uploaded cp37

greenlet-1.1.2-cp36-cp36m-win_amd64.whl (100.9 kB view hashes)

Uploaded cp36

greenlet-1.1.2-cp36-cp36m-win32.whl (97.9 kB view hashes)

Uploaded cp36

greenlet-1.1.2-cp35-cp35m-win_amd64.whl (100.8 kB view hashes)

Uploaded cp35

greenlet-1.1.2-cp35-cp35m-win32.whl (97.9 kB view hashes)

Uploaded cp35

greenlet-1.1.2-cp27-cp27m-win_amd64.whl (94.7 kB view hashes)

Uploaded cp27

greenlet-1.1.2-cp27-cp27m-win32.whl (94.4 kB view hashes)

Uploaded cp27

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Huawei Huawei PSF Sponsor Microsoft Microsoft PSF Sponsor NVIDIA NVIDIA PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page