Skip to content

jonathandung/asyncutils

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

asyncutils

PyPI - Python Version PyPI version Coverage Build CodeQL Publish GitHub Pages pre-commit.ci OpenSSF Best Practices Docs Conda version conda-forge feedstock Contributor Covenant

A Python library abstracting all the common patterns I can think of that somehow always pop up in async code.

Includes a wide range of submodules tailored for specific usages, though concrete low-level implementations are lacking.

Takes pride in:

  • being as fast as can be in terms of import time
  • providing detailed type checking via stub files included in the distribution
  • having a well-equipped command line interface taking many flags and options

Setup

This package probably wouldn't work on alternate Python implementations. Make sure you have CPython 3.12 or above (even 3.15 will do), and at least one of many Python package managers you're comfortable with.

Discounting the installation, no extra setup is usually needed. See the installation guide for more.

Usage

This package is very resourceful, containing everything from higher-order error handling functions to network protocols. See the usage guide for some basic examples.

Version

This is asyncutils v0.9.10.

This library is currently in the beta stage, meaning the public API is subject to change even between patch versions, and changes made may be backward-incompatible. See the compatibility page.

See this page for the version tags up to now.

Configuration

Besides using command line arguments to change console settings, the behaviour of this module as a library can be customized as well.

See the configuration guide.

Remarks

Regarding .markdownlint.json, even though there is no longer a pre-commit or workflow step requiring it, it contains the most basic ignores suitable for this project's files and should be respected. It will be auto-detected by relevant IDE extensions and allows running the linter locally.

It is strongly recommended that you read the asyncio docs thoroughly if using event loop related features.

Resources

Here are some resources if you're new to the world of async. They were of great assistance on my async journey:

Contributing

If you have suggestions for how asyncutils could be improved, or want to report a bug, do open an issue! All contributions are welcome. For more, check out the contributing guide.

License

MIT © 2026 Jonathan Dung

Badges

GitHub Repo Package Uses Status Tests
GitHub release Project stars PyPI - Implementation uv Pytest Maintenance Tests
GitHub release date GitHub forks Noarch ruff Sphinx-lint Contributions Welcome Warnings
Commits since last release GitHub watchers PyPI - Wheel ty Read the Docs PRs Welcome Expected failures
GitHub commit activity GitHub PyPI - Format SemVer Dependabot Beta Duration
GitHub issues GitHub Downloads (all assets, all releases) PyPI - License Sphinx setuptools Blazingly fast Skipped
GitHub pull requests Repo creation PyPI - Downloads GitHub Pages
GitHub contributors GitHub repo size Pre-commit
GitHub last commit Top language detect-secrets