vmklib.tasks.mixins.concrete
index
/home/vkottler/src/vkottler/workspace/vmklib/vmklib/tasks/mixins/concrete.py

A task mixin for writing concrete outputs to a build directory.

 
Classes
       
vmklib.tasks.VmklibBase(vcorelib.task.Task)
ConcreteBuilderMixin
ConcreteOnceMixin

 
class ConcreteBuilderMixin(vmklib.tasks.VmklibBase)
    ConcreteBuilderMixin(name: 'str', *args, execute: 'TaskExecute' = None, log: 'Logger' = None, timer: 'Timer' = None, target: 'Target' = None, **kwargs) -> 'None'
 
Create a concrete file output after a task completes.
 
 
Method resolution order:
ConcreteBuilderMixin
vmklib.tasks.VmklibBase
vcorelib.task.Task
vcorelib.logging.LoggerMixin
builtins.object

Methods defined here:
concrete_path(self, inbox: Dict[str, Dict[str, Any]], substitutions: Dict[str, Union[str, int]] = None) -> pathlib.Path
By default name the concrete after the compiled target name.
is_concrete_stale(self, inbox: Dict[str, Dict[str, Any]], candidates: Iterable[Union[pathlib.Path, str, NoneType]], substitutions: Dict[str, Union[str, int]] = None) -> bool
Check if any candidate paths are modified after the concrete was.
async run_exit(self, _inbox: Dict[str, Dict[str, Any]], _outbox: Dict[str, Any], *_args, **kwargs) -> bool
Update the concrete target after main execution by default.
update_concrete(self, inbox: Dict[str, Dict[str, Any]], **kwargs) -> pathlib.Path
Write a text file to disk in the build directory based on the name of
this task.
 
This is useful to bootstrap compatibility with other tools like GNU
Make that assess concrete targets.

Data and other attributes defined here:
__annotations__ = {}

Class methods inherited from vmklib.tasks.VmklibBase:
build_dir(inbox: Dict[str, Dict[str, Any]]) -> pathlib.Path from builtins.type
Get a path to the build directory.

Data and other attributes inherited from vmklib.tasks.VmklibBase:
default_requirements = {'vmklib.init'}

Methods inherited from vcorelib.task.Task:
__init__(self, name: 'str', *args, execute: 'TaskExecute' = None, log: 'Logger' = None, timer: 'Timer' = None, target: 'Target' = None, **kwargs) -> 'None'
Initialize this task.
__str__(self) -> 'str'
Convert this task into a string.
create_execute(self, *args, **kwargs) -> 'TaskExecute'
Create a default execute function for this task.
depend_on(self, task: "'Task'", eloop: '_asyncio.AbstractEventLoop' = None, **kwargs) -> 'bool'
Register other tasks' output data to your input box. Return true
if a new dependency was added.
depend_on_all(self, tasks: "_Iterable['Task']", **kwargs) -> 'int'
Register multiple dependencies. Return the number of dependencies
added.
async dispatch(self, caller: "'Task'" = None, init_only: 'bool' = False, substitutions: 'Substitutions' = None, **kwargs) -> 'None'
Dispatch this task and return whether or not it succeeded.
dispatch_init(self, caller: "'Task'" = None, substitutions: 'Substitutions' = None, **kwargs) -> '_Tuple[Substitutions, str]'
Perform some dispatch initialization.
resolve(self, log: 'Logger', compiled: 'str', substitutions: 'Substitutions' = None) -> 'None'
Mark this task resolved.
async resolve_dependencies(self, **substitutions) -> 'None'
A default dependency resolver for tasks. Note that the default
dependency resolver cannot propagate current-task substitutions to
its dependencies as they've already been explicitly registered.
resolved(self, compiled: 'str', substitutions: 'Substitutions' = None) -> 'bool'
Override this in a derived task to implement more complex logic.
async run(self, inbox: 'Inbox', outbox: 'Outbox', *args, **kwargs) -> 'bool'
Override this method to implement the task.
async run_enter(self, _inbox: 'Inbox', _outbox: 'Outbox', *_args, **_kwargs) -> 'bool'
A default enter method.
task_fail(self, compiled: 'str', substitutions: 'Substitutions', caller: "'Task'" = None, indent: 'int' = 4) -> 'TaskFailed'
Build an exception message for when this task fails.

Readonly properties inherited from vcorelib.task.Task:
stack
Get this task's execution stack.

Data and other attributes inherited from vcorelib.task.Task:
stages = ['run_enter', 'run', 'run_exit']

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

 
class ConcreteOnceMixin(ConcreteBuilderMixin)
    ConcreteOnceMixin(name: 'str', *args, execute: 'TaskExecute' = None, log: 'Logger' = None, timer: 'Timer' = None, target: 'Target' = None, **kwargs) -> 'None'
 
A mixin for tasks that only need to run once.
 
 
Method resolution order:
ConcreteOnceMixin
ConcreteBuilderMixin
vmklib.tasks.VmklibBase
vcorelib.task.Task
vcorelib.logging.LoggerMixin
builtins.object

Methods defined here:
async run_enter(self, _inbox: Dict[str, Dict[str, Any]], _outbox: Dict[str, Any], *_args, **_kwargs) -> bool
Ensure that this task only runs once.

Data and other attributes defined here:
__annotations__ = {}

Methods inherited from ConcreteBuilderMixin:
concrete_path(self, inbox: Dict[str, Dict[str, Any]], substitutions: Dict[str, Union[str, int]] = None) -> pathlib.Path
By default name the concrete after the compiled target name.
is_concrete_stale(self, inbox: Dict[str, Dict[str, Any]], candidates: Iterable[Union[pathlib.Path, str, NoneType]], substitutions: Dict[str, Union[str, int]] = None) -> bool
Check if any candidate paths are modified after the concrete was.
async run_exit(self, _inbox: Dict[str, Dict[str, Any]], _outbox: Dict[str, Any], *_args, **kwargs) -> bool
Update the concrete target after main execution by default.
update_concrete(self, inbox: Dict[str, Dict[str, Any]], **kwargs) -> pathlib.Path
Write a text file to disk in the build directory based on the name of
this task.
 
This is useful to bootstrap compatibility with other tools like GNU
Make that assess concrete targets.

Class methods inherited from vmklib.tasks.VmklibBase:
build_dir(inbox: Dict[str, Dict[str, Any]]) -> pathlib.Path from builtins.type
Get a path to the build directory.

Data and other attributes inherited from vmklib.tasks.VmklibBase:
default_requirements = {'vmklib.init'}

Methods inherited from vcorelib.task.Task:
__init__(self, name: 'str', *args, execute: 'TaskExecute' = None, log: 'Logger' = None, timer: 'Timer' = None, target: 'Target' = None, **kwargs) -> 'None'
Initialize this task.
__str__(self) -> 'str'
Convert this task into a string.
create_execute(self, *args, **kwargs) -> 'TaskExecute'
Create a default execute function for this task.
depend_on(self, task: "'Task'", eloop: '_asyncio.AbstractEventLoop' = None, **kwargs) -> 'bool'
Register other tasks' output data to your input box. Return true
if a new dependency was added.
depend_on_all(self, tasks: "_Iterable['Task']", **kwargs) -> 'int'
Register multiple dependencies. Return the number of dependencies
added.
async dispatch(self, caller: "'Task'" = None, init_only: 'bool' = False, substitutions: 'Substitutions' = None, **kwargs) -> 'None'
Dispatch this task and return whether or not it succeeded.
dispatch_init(self, caller: "'Task'" = None, substitutions: 'Substitutions' = None, **kwargs) -> '_Tuple[Substitutions, str]'
Perform some dispatch initialization.
resolve(self, log: 'Logger', compiled: 'str', substitutions: 'Substitutions' = None) -> 'None'
Mark this task resolved.
async resolve_dependencies(self, **substitutions) -> 'None'
A default dependency resolver for tasks. Note that the default
dependency resolver cannot propagate current-task substitutions to
its dependencies as they've already been explicitly registered.
resolved(self, compiled: 'str', substitutions: 'Substitutions' = None) -> 'bool'
Override this in a derived task to implement more complex logic.
async run(self, inbox: 'Inbox', outbox: 'Outbox', *args, **kwargs) -> 'bool'
Override this method to implement the task.
task_fail(self, compiled: 'str', substitutions: 'Substitutions', caller: "'Task'" = None, indent: 'int' = 4) -> 'TaskFailed'
Build an exception message for when this task fails.

Readonly properties inherited from vcorelib.task.Task:
stack
Get this task's execution stack.

Data and other attributes inherited from vcorelib.task.Task:
stages = ['run_enter', 'run', 'run_exit']

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

 
Functions
       
asctime(...)
asctime([tuple]) -> string
 
Convert a time tuple to a string, e.g. 'Sat Jun 06 16:26:11 1998'.
When the time tuple is not present, current time as returned by localtime()
is used.

 
Data
        Inbox = typing.Dict[str, typing.Dict[str, typing.Any]]
Iterable = typing.Iterable
Outbox = typing.Dict[str, typing.Any]
Pathlike = typing.Union[pathlib.Path, str, NoneType]
Substitutions = typing.Dict[str, typing.Union[str, int]]
linesep = '\n'