loongson/pypi/: greenlet-0.3.1 metadata and description

Homepage Simple index Newer version available

Lightweight in-process concurrent programming

classifiers
  • Intended Audience :: Developers
  • License :: OSI Approved :: MIT License
  • Natural Language :: English
  • Programming Language :: Python
  • Operating System :: OS Independent
  • Topic :: Software Development :: Libraries :: Python Modules
license MIT License
maintainer Kyle Ambroff
maintainer_email kyle@ambroff.com
File Tox results History
greenlet-0.3.1-cp36-cp36m-linux_loongarch64.whl
Size
38 KB
Type
Python Wheel
Python
3.6
  • Replaced 1 time(s)
  • Uploaded to loongson/pypi by loongson 2025-04-09 10:12:21
greenlet-0.3.1-cp37-cp37m-linux_loongarch64.whl
Size
36 KB
Type
Python Wheel
Python
3.7
  • Replaced 1 time(s)
  • Uploaded to loongson/pypi by loongson 2025-04-09 10:12:14
greenlet-0.3.1-cp38-cp38-linux_loongarch64.whl
Size
40 KB
Type
Python Wheel
Python
3.8
  • Replaced 1 time(s)
  • Uploaded to loongson/pypi by loongson 2025-04-09 11:01:50
greenlet-0.3.1-cp39-cp39-linux_loongarch64.whl
Size
42 KB
Type
Python Wheel
Python
3.9
  • Replaced 1 time(s)
  • Uploaded to loongson/pypi by loongson 2025-04-09 10:40:28
greenlet-0.3.1.tar.gz
Size
39 KB
Type
Source

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/test_generator.py.

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

Greenlets are lightweight coroutines in-process concurrent programming. This package is the py.magic.greenlet module from the py lib.

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

The development tip is available via these tools as well:

pip install greenlet==dev
easy_install greenlet==dev