2024-05-08 16:34:40 -03:00
|
|
|
:mod:`!reprlib` --- Alternate :func:`repr` implementation
|
|
|
|
=========================================================
|
Merged revisions 63361-63373,63375,63377-63380 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r63361 | alexandre.vassalotti | 2008-05-16 03:14:08 -0400 (Fri, 16 May 2008) | 2 lines
Rename the test file of reprlib.
........
r63364 | georg.brandl | 2008-05-16 05:34:48 -0400 (Fri, 16 May 2008) | 2 lines
Make generator repr consistent with function and code object repr.
........
r63365 | georg.brandl | 2008-05-16 05:47:29 -0400 (Fri, 16 May 2008) | 2 lines
#2869: remove parameter from signature.
........
r63366 | christian.heimes | 2008-05-16 06:23:31 -0400 (Fri, 16 May 2008) | 1 line
Fixed #2870: cmathmodule.c compile error
........
r63367 | christian.heimes | 2008-05-16 07:28:56 -0400 (Fri, 16 May 2008) | 1 line
Following Amaury's advice
........
r63368 | georg.brandl | 2008-05-16 09:10:15 -0400 (Fri, 16 May 2008) | 2 lines
#2890: support os.O_ASYNC and fcntl.FASYNC.
........
r63369 | georg.brandl | 2008-05-16 09:18:50 -0400 (Fri, 16 May 2008) | 2 lines
#2845: fix copy2's docs.
........
r63370 | georg.brandl | 2008-05-16 09:24:29 -0400 (Fri, 16 May 2008) | 2 lines
Don't allow keyword arguments to reversed().
........
r63373 | georg.brandl | 2008-05-16 09:41:26 -0400 (Fri, 16 May 2008) | 2 lines
Document O_ASYNC addition.
........
r63380 | georg.brandl | 2008-05-16 13:33:13 -0400 (Fri, 16 May 2008) | 2 lines
Fix reprlib docs.
........
2008-05-16 15:15:12 -03:00
|
|
|
|
2008-05-16 04:12:44 -03:00
|
|
|
.. module:: reprlib
|
2007-08-15 11:28:22 -03:00
|
|
|
:synopsis: Alternate repr() implementation with size limits.
|
2016-06-11 16:02:54 -03:00
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
.. sectionauthor:: Fred L. Drake, Jr. <fdrake@acm.org>
|
|
|
|
|
2011-01-23 17:05:46 -04:00
|
|
|
**Source code:** :source:`Lib/reprlib.py`
|
|
|
|
|
|
|
|
--------------
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2023-12-06 16:16:12 -04:00
|
|
|
The :mod:`!reprlib` module provides a means for producing object representations
|
2007-08-15 11:28:22 -03:00
|
|
|
with limits on the size of the resulting strings. This is used in the Python
|
|
|
|
debugger and may be useful in other contexts as well.
|
|
|
|
|
|
|
|
This module provides a class, an instance, and a function:
|
|
|
|
|
|
|
|
|
2022-07-07 11:55:33 -03:00
|
|
|
.. class:: Repr(*, maxlevel=6, maxtuple=6, maxlist=6, maxarray=5, maxdict=4, \
|
|
|
|
maxset=6, maxfrozenset=6, maxdeque=6, maxstring=30, maxlong=40, \
|
2022-09-08 15:51:44 -03:00
|
|
|
maxother=30, fillvalue="...", indent=None)
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
Class which provides formatting services useful in implementing functions
|
|
|
|
similar to the built-in :func:`repr`; size limits for different object types
|
|
|
|
are added to avoid the generation of representations which are excessively long.
|
|
|
|
|
2022-07-07 11:55:33 -03:00
|
|
|
The keyword arguments of the constructor can be used as a shortcut to set the
|
|
|
|
attributes of the :class:`Repr` instance. Which means that the following
|
|
|
|
initialization::
|
|
|
|
|
|
|
|
aRepr = reprlib.Repr(maxlevel=3)
|
|
|
|
|
|
|
|
Is equivalent to::
|
|
|
|
|
|
|
|
aRepr = reprlib.Repr()
|
|
|
|
aRepr.maxlevel = 3
|
|
|
|
|
|
|
|
See section `Repr Objects`_ for more information about :class:`Repr`
|
|
|
|
attributes.
|
|
|
|
|
|
|
|
.. versionchanged:: 3.12
|
|
|
|
Allow attributes to be set via keyword arguments.
|
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. data:: aRepr
|
|
|
|
|
2009-07-26 12:02:41 -03:00
|
|
|
This is an instance of :class:`Repr` which is used to provide the
|
|
|
|
:func:`.repr` function described below. Changing the attributes of this
|
|
|
|
object will affect the size limits used by :func:`.repr` and the Python
|
|
|
|
debugger.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. function:: repr(obj)
|
|
|
|
|
2009-07-26 12:02:41 -03:00
|
|
|
This is the :meth:`~Repr.repr` method of ``aRepr``. It returns a string
|
|
|
|
similar to that returned by the built-in function of the same name, but with
|
|
|
|
limits on most sizes.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2010-09-13 18:36:00 -03:00
|
|
|
In addition to size-limiting tools, the module also provides a decorator for
|
2023-12-06 16:16:12 -04:00
|
|
|
detecting recursive calls to :meth:`~object.__repr__` and substituting a
|
|
|
|
placeholder string instead.
|
2010-09-13 18:36:00 -03:00
|
|
|
|
2018-11-20 13:26:09 -04:00
|
|
|
|
|
|
|
.. index:: single: ...; placeholder
|
|
|
|
|
2010-09-13 18:36:00 -03:00
|
|
|
.. decorator:: recursive_repr(fillvalue="...")
|
|
|
|
|
2023-12-06 16:16:12 -04:00
|
|
|
Decorator for :meth:`~object.__repr__` methods to detect recursive calls within the
|
2010-09-13 18:36:00 -03:00
|
|
|
same thread. If a recursive call is made, the *fillvalue* is returned,
|
2023-12-06 16:16:12 -04:00
|
|
|
otherwise, the usual :meth:`!__repr__` call is made. For example:
|
|
|
|
|
|
|
|
.. doctest::
|
|
|
|
|
|
|
|
>>> from reprlib import recursive_repr
|
|
|
|
>>> class MyList(list):
|
|
|
|
... @recursive_repr()
|
|
|
|
... def __repr__(self):
|
|
|
|
... return '<' + '|'.join(map(repr, self)) + '>'
|
|
|
|
...
|
|
|
|
>>> m = MyList('abc')
|
|
|
|
>>> m.append(m)
|
|
|
|
>>> m.append('x')
|
|
|
|
>>> print(m)
|
|
|
|
<'a'|'b'|'c'|...|'x'>
|
2010-09-13 18:36:00 -03:00
|
|
|
|
|
|
|
.. versionadded:: 3.2
|
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
.. _repr-objects:
|
|
|
|
|
|
|
|
Repr Objects
|
|
|
|
------------
|
|
|
|
|
2011-07-04 15:28:30 -03:00
|
|
|
:class:`Repr` instances provide several attributes which can be used to provide
|
2007-08-15 11:28:22 -03:00
|
|
|
size limits for the representations of different object types, and methods
|
|
|
|
which format specific object types.
|
|
|
|
|
|
|
|
|
2021-09-22 17:45:58 -03:00
|
|
|
.. attribute:: Repr.fillvalue
|
|
|
|
|
|
|
|
This string is displayed for recursive references. It defaults to
|
|
|
|
``...``.
|
|
|
|
|
|
|
|
.. versionadded:: 3.11
|
|
|
|
|
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
.. attribute:: Repr.maxlevel
|
|
|
|
|
|
|
|
Depth limit on the creation of recursive representations. The default is ``6``.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: Repr.maxdict
|
|
|
|
Repr.maxlist
|
|
|
|
Repr.maxtuple
|
|
|
|
Repr.maxset
|
|
|
|
Repr.maxfrozenset
|
|
|
|
Repr.maxdeque
|
|
|
|
Repr.maxarray
|
|
|
|
|
|
|
|
Limits on the number of entries represented for the named object type. The
|
|
|
|
default is ``4`` for :attr:`maxdict`, ``5`` for :attr:`maxarray`, and ``6`` for
|
|
|
|
the others.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: Repr.maxlong
|
|
|
|
|
2009-01-17 06:21:23 -04:00
|
|
|
Maximum number of characters in the representation for an integer. Digits
|
2007-08-15 11:28:22 -03:00
|
|
|
are dropped from the middle. The default is ``40``.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: Repr.maxstring
|
|
|
|
|
|
|
|
Limit on the number of characters in the representation of the string. Note
|
|
|
|
that the "normal" representation of the string is used as the character source:
|
|
|
|
if escape sequences are needed in the representation, these may be mangled when
|
|
|
|
the representation is shortened. The default is ``30``.
|
|
|
|
|
|
|
|
|
|
|
|
.. attribute:: Repr.maxother
|
|
|
|
|
|
|
|
This limit is used to control the size of object types for which no specific
|
|
|
|
formatting method is available on the :class:`Repr` object. It is applied in a
|
|
|
|
similar manner as :attr:`maxstring`. The default is ``20``.
|
|
|
|
|
|
|
|
|
2022-09-08 15:51:44 -03:00
|
|
|
.. attribute:: Repr.indent
|
|
|
|
|
|
|
|
If this attribute is set to ``None`` (the default), the output is formatted
|
|
|
|
with no line breaks or indentation, like the standard :func:`repr`.
|
|
|
|
For example:
|
|
|
|
|
2023-12-06 16:16:12 -04:00
|
|
|
.. doctest:: indent
|
2022-09-08 15:51:44 -03:00
|
|
|
|
|
|
|
>>> example = [
|
2023-12-06 16:16:12 -04:00
|
|
|
... 1, 'spam', {'a': 2, 'b': 'spam eggs', 'c': {3: 4.5, 6: []}}, 'ham']
|
2022-09-08 15:51:44 -03:00
|
|
|
>>> import reprlib
|
|
|
|
>>> aRepr = reprlib.Repr()
|
|
|
|
>>> print(aRepr.repr(example))
|
|
|
|
[1, 'spam', {'a': 2, 'b': 'spam eggs', 'c': {3: 4.5, 6: []}}, 'ham']
|
|
|
|
|
|
|
|
If :attr:`~Repr.indent` is set to a string, each recursion level
|
|
|
|
is placed on its own line, indented by that string:
|
|
|
|
|
2023-12-06 16:16:12 -04:00
|
|
|
.. doctest:: indent
|
2022-09-08 15:51:44 -03:00
|
|
|
|
|
|
|
>>> aRepr.indent = '-->'
|
|
|
|
>>> print(aRepr.repr(example))
|
|
|
|
[
|
|
|
|
-->1,
|
|
|
|
-->'spam',
|
|
|
|
-->{
|
|
|
|
-->-->'a': 2,
|
|
|
|
-->-->'b': 'spam eggs',
|
|
|
|
-->-->'c': {
|
|
|
|
-->-->-->3: 4.5,
|
|
|
|
-->-->-->6: [],
|
|
|
|
-->-->},
|
|
|
|
-->},
|
|
|
|
-->'ham',
|
|
|
|
]
|
|
|
|
|
|
|
|
Setting :attr:`~Repr.indent` to a positive integer value behaves as if it
|
|
|
|
was set to a string with that number of spaces:
|
|
|
|
|
2023-12-06 16:16:12 -04:00
|
|
|
.. doctest:: indent
|
2022-09-08 15:51:44 -03:00
|
|
|
|
|
|
|
>>> aRepr.indent = 4
|
|
|
|
>>> print(aRepr.repr(example))
|
|
|
|
[
|
|
|
|
1,
|
|
|
|
'spam',
|
|
|
|
{
|
|
|
|
'a': 2,
|
|
|
|
'b': 'spam eggs',
|
|
|
|
'c': {
|
|
|
|
3: 4.5,
|
|
|
|
6: [],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
'ham',
|
|
|
|
]
|
|
|
|
|
|
|
|
.. versionadded:: 3.12
|
|
|
|
|
|
|
|
|
2007-08-15 11:28:22 -03:00
|
|
|
.. method:: Repr.repr(obj)
|
|
|
|
|
|
|
|
The equivalent to the built-in :func:`repr` that uses the formatting imposed by
|
|
|
|
the instance.
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: Repr.repr1(obj, level)
|
|
|
|
|
2009-07-26 12:02:41 -03:00
|
|
|
Recursive implementation used by :meth:`.repr`. This uses the type of *obj* to
|
2007-08-15 11:28:22 -03:00
|
|
|
determine which formatting method to call, passing it *obj* and *level*. The
|
|
|
|
type-specific methods should call :meth:`repr1` to perform recursive formatting,
|
|
|
|
with ``level - 1`` for the value of *level* in the recursive call.
|
|
|
|
|
|
|
|
|
|
|
|
.. method:: Repr.repr_TYPE(obj, level)
|
|
|
|
:noindex:
|
|
|
|
|
|
|
|
Formatting methods for specific types are implemented as methods with a name
|
|
|
|
based on the type name. In the method name, **TYPE** is replaced by
|
2014-09-18 00:05:14 -03:00
|
|
|
``'_'.join(type(obj).__name__.split())``. Dispatch to these methods is
|
|
|
|
handled by :meth:`repr1`. Type-specific methods which need to recursively
|
|
|
|
format a value should call ``self.repr1(subobj, level - 1)``.
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
|
|
|
|
.. _subclassing-reprs:
|
|
|
|
|
|
|
|
Subclassing Repr Objects
|
|
|
|
------------------------
|
|
|
|
|
|
|
|
The use of dynamic dispatching by :meth:`Repr.repr1` allows subclasses of
|
|
|
|
:class:`Repr` to add support for additional built-in object types or to modify
|
|
|
|
the handling of types already supported. This example shows how special support
|
2023-12-06 16:16:12 -04:00
|
|
|
for file objects could be added:
|
|
|
|
|
|
|
|
.. testcode::
|
2007-08-15 11:28:22 -03:00
|
|
|
|
2008-10-15 00:09:45 -03:00
|
|
|
import reprlib
|
2007-08-15 11:28:22 -03:00
|
|
|
import sys
|
|
|
|
|
2008-10-15 00:09:45 -03:00
|
|
|
class MyRepr(reprlib.Repr):
|
2014-10-11 23:11:16 -03:00
|
|
|
|
|
|
|
def repr_TextIOWrapper(self, obj, level):
|
|
|
|
if obj.name in {'<stdin>', '<stdout>', '<stderr>'}:
|
2007-08-15 11:28:22 -03:00
|
|
|
return obj.name
|
2014-10-11 23:11:16 -03:00
|
|
|
return repr(obj)
|
2007-08-15 11:28:22 -03:00
|
|
|
|
|
|
|
aRepr = MyRepr()
|
2010-01-05 06:22:04 -04:00
|
|
|
print(aRepr.repr(sys.stdin)) # prints '<stdin>'
|
2023-12-06 16:16:12 -04:00
|
|
|
|
|
|
|
.. testoutput::
|
|
|
|
|
|
|
|
<stdin>
|