runtimepy.task.basic
index
/home/vkottler/src/vkottler/workspace/runtimepy/runtimepy/task/basic/__init__.py

A module implementing a simple periodic-task interface.

 
Package Contents
       
manager
periodic

 
Classes
       
abc.ABC(builtins.object)
runtimepy.task.basic.periodic.PeriodicTask(runtimepy.mixins.logging.LoggerMixinLevelControl, runtimepy.mixins.environment.ChannelEnvironmentMixin, abc.ABC)
runtimepy.mixins.environment.ChannelEnvironmentMixin(builtins.object)
runtimepy.task.basic.periodic.PeriodicTask(runtimepy.mixins.logging.LoggerMixinLevelControl, runtimepy.mixins.environment.ChannelEnvironmentMixin, abc.ABC)
runtimepy.mixins.logging.LoggerMixinLevelControl(vcorelib.logging.LoggerMixin)
runtimepy.task.basic.periodic.PeriodicTask(runtimepy.mixins.logging.LoggerMixinLevelControl, runtimepy.mixins.environment.ChannelEnvironmentMixin, abc.ABC)
typing.Generic(builtins.object)
runtimepy.task.basic.manager.PeriodicTaskManager

 
class PeriodicTask(runtimepy.mixins.logging.LoggerMixinLevelControl, runtimepy.mixins.environment.ChannelEnvironmentMixin, abc.ABC)
    PeriodicTask(name: 'str', average_depth: 'int' = 10, metrics: 'PeriodicTaskMetrics' = None, period_s: 'float' = 1.0, env: 'ChannelEnvironment' = None) -> 'None'
 
A class implementing a simple periodic-task interface.
 
 
Method resolution order:
PeriodicTask
runtimepy.mixins.logging.LoggerMixinLevelControl
vcorelib.logging.LoggerMixin
runtimepy.mixins.environment.ChannelEnvironmentMixin
abc.ABC
builtins.object

Methods defined here:
__init__(self, name: 'str', average_depth: 'int' = 10, metrics: 'PeriodicTaskMetrics' = None, period_s: 'float' = 1.0, env: 'ChannelEnvironment' = None) -> 'None'
Initialize this task.
disable(self) -> 'bool'
Disable this task, return whether or not any action was taken.
async dispatch(self) -> 'bool'
Dispatch an iteration of this task.
async run(self, period_s: 'float' = None, stop_sig: '_asyncio.Event' = None) -> 'None'
Run this task by executing the dispatch method at the specified period
until a dispatch iteration fails or the task is otherwise disabled.
set_period(self, period_s: 'float' = None) -> 'bool'
Attempt to set a new period for this task.
async stop(self) -> 'bool'
Wait for this task to stop running (if it is).
async stop_extra(self) -> 'None'
Extra actions to perform when this task is stopping.
async task(self, period_s: 'float' = None, stop_sig: '_asyncio.Event' = None) -> '_asyncio.Task[None]'
Create an event-loop task for this periodic.

Data and other attributes defined here:
__abstractmethods__ = frozenset({'dispatch'})
__annotations__ = {}
auto_finalize = True

Methods inherited from runtimepy.mixins.logging.LoggerMixinLevelControl:
setup_level_channel(self, env: runtimepy.channel.environment.ChannelEnvironment, name: str = 'log_level', initial: str = 'info', description: str = 'Text-log level filter for this environment.') -> None
Add a commandable log-level channel to the environment.

Methods inherited from vcorelib.logging.LoggerMixin:
log_time(self, message: str, *args, level: int = 20, reminder: bool = False, **kwargs) -> Iterator[NoneType]
A simple wrapper.

Data descriptors inherited from vcorelib.logging.LoggerMixin:
__dict__
dictionary for instance variables
__weakref__
list of weak references to the object

Methods inherited from runtimepy.mixins.environment.ChannelEnvironmentMixin:
register_channel_metrics(self, name: str, channel: runtimepy.metrics.channel.ChannelMetrics, verb: str) -> None
Register individual channel metrics.
register_connection_metrics(self, metrics: runtimepy.metrics.connection.ConnectionMetrics, namespace: str = 'metrics') -> None
Register connection metrics.
register_task_metrics(self, metrics: runtimepy.metrics.task.PeriodicTaskMetrics, namespace: str = 'metrics') -> None
Register periodic task metrics.

 
class PeriodicTaskManager(typing.Generic)
    PeriodicTaskManager() -> None
 
A class for managing periodic tasks as a single group.
 
 
Method resolution order:
PeriodicTaskManager
typing.Generic
builtins.object

Methods defined here:
__getitem__(self, name: str) -> ~T
Get a task by name.
__init__(self) -> None
Initialize this instance.
register(self, task: ~T, period_s: float = None) -> bool
Register a periodic task.
running(self, stop_sig: asyncio.locks.Event = None) -> AsyncIterator[NoneType]
Run tasks as an async context.
async start(self, stop_sig: asyncio.locks.Event = None) -> None
Ensure tasks are started.
async stop(self) -> None
Ensure tasks are stopped.

Readonly properties defined here:
tasks
Iterate over tasks.

Data descriptors defined here:
__dict__
dictionary for instance variables
__weakref__
list of weak references to the object

Data and other attributes defined here:
__orig_bases__ = (typing.Generic[~T],)
__parameters__ = (~T,)

Class methods inherited from typing.Generic:
__class_getitem__(...) from builtins.type
Parameterizes a generic class.
 
At least, parameterizing a generic class is the *main* thing this
method does. For example, for some generic class `Foo`, this is called
when we do `Foo[int]` - there, with `cls=Foo` and `params=int`.
 
However, note that this method is also called when defining generic
classes in the first place with `class Foo[T]: ...`.
__init_subclass__(...) from builtins.type
Function to initialize subclasses.

 
Data
        __all__ = ['PeriodicTask', 'PeriodicTaskManager']