lenskit.data.repr#
Utility functions for implementing __str__ and __repr__ methods
with consistent syntax.
Classes#
Base class for protocol classes. |
|
Functions#
|
Construct string "object" representations. |
Module Contents#
- class lenskit.data.repr.HasObjectRepr#
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: ...
- class lenskit.data.repr.ReprWriter#
- out: io.StringIO#
- class lenskit.data.repr.ReprIndenter(writer, size)#
- Parameters:
writer (ReprWriter)
size (int)
- writer: ReprWriter#
- __enter__()#
- __exit__(exc_type, exc_val, exc_tb)#
- Parameters:
exc_type (type)
exc_val (Exception)
exc_tb (types.TracebackType)
- class lenskit.data.repr.ObjectRepr#
-
- words: collections.abc.Sequence[str] = ()#
- attrs: collections.abc.Mapping[str, Any] | None = None#
- write(writer)#
- Parameters:
writer (ReprWriter)
- lenskit.data.repr.object_repr(tag, *words, comment=None, **attrs)#
Construct string “object” representations.
- Parameters:
- Return type: