Module clingox.pprint
This module is a replacement for Python`s pprint module for pretty printing clingo objects.
Functions
- def isreadable(obj: Any) ‑> bool
- 
Expand source codedef isreadable(obj: Any) -> bool: """Determine if saferepr(object) is readable by eval().""" if hasattr(PrettyPrinter, "_safe_repr"): return PrettyPrinter()._safe_repr(obj, {}, None, 0)[1] # type: ignore return _pp.isreadable(obj) # nocoverageDetermine if saferepr(object) is readable by eval(). 
- def isrecursive(obj: Any) ‑> bool
- 
Expand source codedef isrecursive(obj: Any) -> bool: """Determine if object requires a recursive representation.""" if hasattr(PrettyPrinter, "_safe_repr"): return PrettyPrinter()._safe_repr(obj, {}, None, 0)[2] # type: ignore return _pp.isrecursive(obj) # nocoverageDetermine if object requires a recursive representation. 
- def pformat(obj: Any, indent: int = 1, width: int = 80, depth: int | None = None, **kwargs) ‑> str
- 
Expand source codedef pformat( obj: Any, indent: int = 1, width: int = 80, depth: Optional[int] = None, **kwargs ) -> str: """Format a Python object into a pretty-printed representation.""" return PrettyPrinter( stream=None, indent=indent, width=width, depth=depth, **kwargs ).pformat(obj)Format a Python object into a pretty-printed representation. 
- def pp(obj: Any, *args, sort_dicts: bool = False, **kwargs)
- 
Expand source codedef pp(obj: Any, *args, sort_dicts: bool = False, **kwargs): """Pretty-print a Python object.""" # pylint: disable=invalid-name pprint(obj, *args, sort_dicts=sort_dicts, **kwargs) # nocoveragePretty-print a Python object. 
- def pprint(obj: Any,
 stream: IO[str] | None = None,
 indent: int = 1,
 width: int = 80,
 depth: int | None = None,
 **kwargs)
- 
Expand source codedef pprint( obj: Any, stream: Optional[IO[str]] = None, indent: int = 1, width: int = 80, depth: Optional[int] = None, **kwargs ): """Pretty-print a Python object to a stream [default is sys.stdout].""" printer = PrettyPrinter( stream=stream, indent=indent, width=width, depth=depth, **kwargs ) printer.pprint(obj)Pretty-print a Python object to a stream [default is sys.stdout]. 
- def saferepr(obj: Any) ‑> str
- 
Expand source codedef saferepr(obj: Any) -> str: """Version of repr() which can handle recursive data structures.""" if hasattr(PrettyPrinter, "_safe_repr"): return PrettyPrinter()._safe_repr(obj, {}, None, 0)[0] # type: ignore return _pp.saferepr(obj) # nocoverageVersion of repr() which can handle recursive data structures. 
Classes
- class PrettyPrinter (*args, **kwargs)
- 
Expand source codeclass PrettyPrinter(_pp.PrettyPrinter): """ A pretty printer extending the standard `PrettyPrinter` class with functions to format `clingo.ast.AST` objects. """ _hide_location: bool def __init__(self, *args, **kwargs): hide_location = kwargs.pop("hide_location", False) super().__init__(*args, **kwargs) self._hide_location = hide_location if _pp.PrettyPrinter.__init__.__doc__ is not None: __init__.__doc__ = ( _pp.PrettyPrinter.__init__.__doc__ + """hide_location Replace locations in `clingo.ast.AST` objects by placeholder LOC. """ ) def _pprint_namedtuple( self, obj: Any, stream: IO[str], indent: int, allowance: int, context: Dict[int, Any], level: int, ): # Note: adjusted _pprint_dataclass from python 3.10 cls_name = obj.__class__.__name__ indent += len(cls_name) + 1 stream.write(cls_name + "(") self._format_kwargs_items( obj._asdict().items(), stream, indent, allowance, context, level ) stream.write(")") def _format_kwargs_items( self, items: Sequence[Tuple[str, Any]], stream: IO[str], indent: int, allowance: int, context: Dict[int, Any], level: int, ): # Note: copied _pprint_namespace_items from python 3.10 write = stream.write delimnl = ",\n" + " " * indent last_index = len(items) - 1 for i, (key, ent) in enumerate(items): last = i == last_index write(key) write("=") if id(ent) in context: write("...") # nocoverage else: self._format( # type: ignore ent, stream, indent + len(key) + 1, allowance if last else 1, context, level, ) if not last: write(delimnl) def _format_args_items( self, items: Sequence[Any], stream: IO[str], indent: int, allowance: int, context: Dict[int, Any], level: int, ): write = stream.write delimnl = ",\n" + " " * indent last_index = len(items) - 1 for i, ent in enumerate(items): last = i == last_index if id(ent) in context: write("...") # nocoverage else: self._format( # type: ignore ent, stream, indent, allowance if last else 1, context, level, ) if not last: write(delimnl) _dispatch = _pp.PrettyPrinter._dispatch.copy() # type: ignore def _pprint_pos( self, obj: Position, stream: IO[str], indent: int, allowance: int, context: Dict[int, Any], level: int, ): self._pprint_namedtuple(obj, stream, indent, allowance, context, level) _dispatch[Position.__repr__] = _pprint_pos def _pprint_loc( self, obj: Location, stream: IO[str], indent: int, allowance: int, context: Dict[int, Any], level: int, ): self._pprint_namedtuple(obj, stream, indent, allowance, context, level) _dispatch[Location.__repr__] = _pprint_loc def _pprint_ast( self, obj: AST, stream: IO[str], indent: int, allowance: int, context: Dict[int, Any], level: int, ): name = str(obj.ast_type).replace("ASTType", "ast") indent += len(name) + 1 items = [ (key, _DummyLoc() if self._hide_location and key == "location" else val) for key, val in obj.items() ] stream.write(name + "(") self._format_kwargs_items(items, stream, indent, allowance, context, level) stream.write(")") _dispatch[AST.__repr__] = _pprint_ast _dispatch[ASTSequence.__repr__] = _pp.PrettyPrinter._pprint_list # type: ignore def _pprint_sym( self, obj: Symbol, stream: IO[str], indent: int, allowance: int, context: Dict[int, Any], level: int, ): if obj.type == SymbolType.Function: indent += 9 items = [obj.name, obj.arguments, obj.positive] stream.write("Function(") self._format_args_items(items, stream, indent, allowance, context, level) stream.write(")") else: stream.write(repr(obj)) _dispatch[Symbol.__repr__] = _pprint_symA pretty printer extending the standard PrettyPrinterclass with functions to formatASTobjects.Handle pretty printing operations onto a stream using a set of configured parameters. indent Number of spaces to indent for each level of nesting. width Attempted maximum number of columns in the output. depth The maximum depth to print out nested structures. stream The desired output stream. If omitted (or false), the standard output stream available at construction will be used. compact If true, several items will be combined in one line. sort_dicts If true, dict keys are sorted. underscore_numbers If true, digit groups are separated with underscores. hide_location Replace locations in ASTobjects by placeholder LOC.Ancestors- pprint.PrettyPrinter