doot.control.loaders._interface

Type Aliases

Loaders_p

PluginLoader_p

CommandLoader_p

TaskLoader_p

Protocols

Loader_p

Base class for protocol classes.

Module Contents

doot.control.loaders._interface.Loaders_p: TypeAlias = CommandLoader_p | PluginLoader_p | TaskLoader_p
doot.control.loaders._interface.PluginLoader_p: TypeAlias = Loader_p[EntryPoint]
doot.control.loaders._interface.CommandLoader_p: TypeAlias = Loader_p[Command_p]
doot.control.loaders._interface.TaskLoader_p: TypeAlias = Loader_p[SpecStruct_p]
class doot.control.loaders._interface.Loader_p[source]

Bases: Protocol

Base class for protocol classes.

Protocol classes are defined as:

class Proto(Protocol):
    def meth(self) -> int:
        ...

Such classes are primarily used with static type checkers that recognize structural subtyping (static duck-typing).

For example:

class C:
    def meth(self) -> int:
        return 0

def func(x: Proto) -> int:
    return x.meth()

func(C())  # Passes static type check

See PEP 544 for details. Protocol classes decorated with @typing.runtime_checkable act as simple-minded runtime protocols that check only the presence of given attributes, ignoring their type signatures. Protocol classes can be generic, they are defined as:

class GenProto[T](Protocol):
    def meth(self) -> T:
        ...
setup(
data: jgdv.structs.chainguard.ChainGuard,
) Self[source]
Parameters:

data (jgdv.structs.chainguard.ChainGuard)

Return type:

Self

load() jgdv.structs.chainguard.ChainGuard[source]
Return type:

jgdv.structs.chainguard.ChainGuard