An asynchronous task queue with priority support.
Project description
wcpan.worker
An asynchronous task queue with priority support.
from wcpan.worker import AsyncQueue, Task
class HighPriorityTask(Task):
@property
def priority(self) -> int:
return 2
class LowPriorityTask(Task):
@property
def priority(self) -> int:
return 1
# Note this queue is non-preemptive.
queue = AsyncQueue()
queue.start()
# function_2 will come first.
queue.post(LowPriorityTask(function_1))
queue.post(HighPriorityTask(function_2))
# cancel pending tasks
queue.flush()
# wait for executing task (if any) ends, then stop the queue
await queue.stop()
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
wcpan_worker-6.1.1.tar.gz
(4.1 kB
view hashes)
Built Distribution
Close
Hashes for wcpan_worker-6.1.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e741292595f258cf8e5bf84f80efb518633145202bd8c4c6c8a80f2b9255ab0c |
|
MD5 | 1be54b4b5d7ca301ecdba28fb8e2f448 |
|
BLAKE2b-256 | aa8c9a5abe659b2fdd17a2e1d540495d3e5c06dfb3c10578fac40c680738d2c6 |