Skip to main content

An asynchronous plugin tool for writing clean asynchornous decoator and class callback applications.

Project description

AioPlugin

PyPI version PyPI - Downloads License: MIT IDIM

A tool inspired by the way pluggy works with pytest but is meant to help build application-like builds using asynchronous event wrappers. It is the successor to aiocallback as it's primary rewrite, however aiocallback does plan to get some of this project's backend stuff in the future so that aiocallback never goes stale but helps keep aioplugin a bit more neat and organized.

It takes inspiration from the popular discord.py and pluggy libraries allowing you to build very cleaver asynchronous programs. It can be ran in some very unique ways and allows for other developers to add on to your application's callbacks in some very clean/unique and surprising ways.

It can be used with virtually any asynchronous implementations as long as it uses the await syntax. A few examples would include, anyio, trio and asyncio, curio and twisted are not tested but I can gaurentee that it is likely to work with those implementations too.

Small example

from aioplugin.event import event
from aioplugin.plugin import Plugin


class MyEvent(Plugin):
    # you can very easily add your own data, it's recommended 
    # to use typing.Generic for the best results if the data 
    # can be combined to other events.
    def __init__(self, items):
        super().__init__()
        self._items = items

    @event
    async def on_name(self, name: str) -> None:
        pass


events = MyEvent()

print(events.__event_names__)


@events.on_name
async def hello(name: str):
    print(f"Hello {name}")


async def main():
    # Like aiosignal this comes with it's own freezing funciton. 
    # This is inspired by aiocallback as aioplugin was meant 
    # to remedy some of aiocallback's shortcomings and other various bugs.
    events.freeze()
    await events.on_name.send("World!")


if __name__ == "__main__":
    import winloop

    winloop.run(main())

There is much more documentation is coming soon.

Other Dependencies

Libraries such as these are the library's main back bones. They were developed for this library specifically with very a tiny footprint, these will not eat diskspace at all if this was your primary concern, these were seperated specifically if developers had something else in mind:

  • freezabledict2 there were so many names taken so many times that a #2 was needed. It works the same way as FrozenList giving the option to mutate a dictionary/hash-table until frozen.

  • reductable-params This library is the main tools responsible for giving developers like you the freedom of positioning parameters however you want or ignore them and adding new ones using hooks. If you want to make your own stuff, reductable-params is perfect for writing your own callable plugin systems and has powerful performance benefits thanks to it's use of C & Cython however it also has a pure python fallback if you plan to use something a little bit more unsupported.

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

aioplugin-0.1.1.tar.gz (12.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aioplugin-0.1.1-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file aioplugin-0.1.1.tar.gz.

File metadata

  • Download URL: aioplugin-0.1.1.tar.gz
  • Upload date:
  • Size: 12.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aioplugin-0.1.1.tar.gz
Algorithm Hash digest
SHA256 28ec9c731524326bc28960a067923af301d0eb3f6e16c8a57f9c3c3d8668db8d
MD5 0fd81a9be87a484ab1fbf3f6d43d41c5
BLAKE2b-256 da3c563d728a5aeac3512de537ac9539a771b0a2409fd438b784685e34573d67

See more details on using hashes here.

File details

Details for the file aioplugin-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: aioplugin-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 10.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for aioplugin-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 78409a0d57ea08e5c0dfd2c97641707b9c40a5c80b6992cc3fc66db0481052cf
MD5 bc49c2b3e69e14d6f4b69503923be959
BLAKE2b-256 72c6b8da23a66792f67c96aa5f52cffdf4651dd62890f09b7482be01bf3bac42

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page