doot.control.loaders._interface
Type Aliases
Protocols
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:
ProtocolBase 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: ...