Lightweight in-process concurrent programming
C Python C++ Batchfile Assembly Shell
Clone or download
Failed to load latest commit information.
appveyor Fix running pip on Python 2.6 Jun 12, 2016
benchmarks Remove unuseful while loop in benchmarks Jan 24, 2015
doc documentation ready for python3 Oct 16, 2017
platform Add support for RISC-V Jul 19, 2018
tests Try to fix spurious thread test failures May 16, 2015
.gitignore Script for building manylinux wheels Apr 2, 2016
.travis.yml Travis CI: use Python "3.7-dev" instead of "3.7" Jul 4, 2018
AUTHORS Add Victor Stinner to AUTHORS Jul 4, 2018
LICENSE add copyright holders Dec 22, 2011
LICENSE.PSF Attempt to clarify greenlet license Sep 1, 2011 Start building with Python 3.7 Jun 28, 2018
NEWS Start NEWS for future 0.4.15 Jul 23, 2018
README.rst Convert readthedocs link for their .org -> .io migration for hosted p… May 29, 2016
appveyor.yml Start NEWS for future 0.4.15 Jul 23, 2018 Don't symlink libraries unless inplace build is requested Jun 25, 2014
dev-requirements.txt Start building greenlet with appveyor Jun 11, 2016
greenlet.c Coding style Jul 3, 2018
greenlet.h Start NEWS for future 0.4.15 Jul 23, 2018
make-manifest update make-manifest and Jan 7, 2014
make-manylinux Use a shared volume label for SELinux compatibility (fixes #108) Sep 9, 2016
make-win-release Build 3.5 binaries on Windows Sep 21, 2015 Don't symlink libraries unless inplace build is requested Jun 25, 2014 Catch unit-test errors in Sep 24, 2014
setup.cfg Add gztar to sdist formats Aug 29, 2015 Start NEWS for future 0.4.15 Jul 23, 2018
setup_switch_x64_masm.cmd make the greenlet module work on x64 windows Dec 18, 2011
slp_platformselect.h Add support for RISC-V Jul 19, 2018
tox.ini add testenv:docs, which tests "make html" in doc directory Jan 26, 2012


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 tests/

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

Greenlets are lightweight coroutines for in-process concurrent programming.

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 or easy_install:

pip install greenlet
easy_install greenlet

Source code archives and windows installers are available on the python package index at

The source code repository is hosted on github:

Documentation is available on