loongson/pypi/: greenlet-3.0.3 metadata and description

Homepage Simple index

Lightweight in-process concurrent programming

author Alexey Borzenkov
author_email snaury@gmail.com
classifiers
  • Development Status :: 5 - Production/Stable
  • Intended Audience :: Developers
  • License :: OSI Approved :: MIT License
  • Natural Language :: English
  • Programming Language :: C
  • Programming Language :: Python
  • Programming Language :: Python :: 3
  • Programming Language :: Python :: 3 :: Only
  • Programming Language :: Python :: 3.7
  • Programming Language :: Python :: 3.8
  • Programming Language :: Python :: 3.9
  • Programming Language :: Python :: 3.10
  • Programming Language :: Python :: 3.11
  • Programming Language :: Python :: 3.12
  • Operating System :: OS Independent
  • Topic :: Software Development :: Libraries :: Python Modules
description_content_type text/x-rst
keywords greenlet coroutine concurrency threads cooperative
license MIT License
maintainer Jason Madden
maintainer_email jason@seecoresoftware.com
project_urls
  • Bug Tracker, https://github.com/python-greenlet/greenlet/issues
  • Source Code, https://github.com/python-greenlet/greenlet/
  • Documentation, https://greenlet.readthedocs.io/
provides_extras test
requires_dist
  • Sphinx ; extra == 'docs'
  • furo ; extra == 'docs'
  • objgraph ; extra == 'test'
  • psutil ; extra == 'test'
requires_python >=3.7

Because this project isn't in the mirror_whitelist, no releases from root/pypi are included.

File Tox results History
greenlet-3.0.3-cp310-cp310-linux_loongarch64.whl
Size
569 KB
Type
Python Wheel
Python
3.1.0
greenlet-3.0.3-cp311-cp311-linux_loongarch64.whl
Size
574 KB
Type
Python Wheel
Python
3.1.1
greenlet-3.0.3-cp312-cp312-linux_loongarch64.whl
Size
571 KB
Type
Python Wheel
Python
3.1.2
greenlet-3.0.3-cp38-cp38-linux_loongarch64.whl
Size
578 KB
Type
Python Wheel
Python
3.8
greenlet-3.0.3-cp39-cp39-linux_loongarch64.whl
Size
572 KB
Type
Python Wheel
Python
3.9

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 available 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