Skip to content
Projeler
Gruplar
Parçacıklar
Yardım
Yükleniyor...
Oturum aç / Kaydol
Gezinmeyi değiştir
C
cpython
Proje
Proje
Ayrıntılar
Etkinlik
Cycle Analytics
Depo (repository)
Depo (repository)
Dosyalar
Kayıtlar (commit)
Dallar (branch)
Etiketler
Katkıda bulunanlar
Grafik
Karşılaştır
Grafikler
Konular (issue)
0
Konular (issue)
0
Liste
Pano
Etiketler
Kilometre Taşları
Birleştirme (merge) Talepleri
0
Birleştirme (merge) Talepleri
0
CI / CD
CI / CD
İş akışları (pipeline)
İşler
Zamanlamalar
Grafikler
Paketler
Paketler
Wiki
Wiki
Parçacıklar
Parçacıklar
Üyeler
Üyeler
Collapse sidebar
Close sidebar
Etkinlik
Grafik
Grafikler
Yeni bir konu (issue) oluştur
İşler
Kayıtlar (commit)
Konu (issue) Panoları
Kenar çubuğunu aç
Batuhan Osman TASKAYA
cpython
Commits
7d36e2fc
Kaydet (Commit)
7d36e2fc
authored
Eki 03, 2013
tarafından
Antoine Pitrou
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Remove builtin "caching" in pprint
üst
bf14dccc
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
22 additions
and
28 deletions
+22
-28
pprint.py
Lib/pprint.py
+22
-28
No files found.
Lib/pprint.py
Dosyayı görüntüle @
7d36e2fc
...
@@ -42,12 +42,6 @@ from io import StringIO as _StringIO
...
@@ -42,12 +42,6 @@ from io import StringIO as _StringIO
__all__
=
[
"pprint"
,
"pformat"
,
"isreadable"
,
"isrecursive"
,
"saferepr"
,
__all__
=
[
"pprint"
,
"pformat"
,
"isreadable"
,
"isrecursive"
,
"saferepr"
,
"PrettyPrinter"
]
"PrettyPrinter"
]
# cache these for faster access:
_commajoin
=
", "
.
join
_id
=
id
_len
=
len
_type
=
type
def
pprint
(
object
,
stream
=
None
,
indent
=
1
,
width
=
80
,
depth
=
None
,
*
,
def
pprint
(
object
,
stream
=
None
,
indent
=
1
,
width
=
80
,
depth
=
None
,
*
,
compact
=
False
):
compact
=
False
):
...
@@ -96,8 +90,8 @@ class _safe_key:
...
@@ -96,8 +90,8 @@ class _safe_key:
rv
=
NotImplemented
rv
=
NotImplemented
if
rv
is
NotImplemented
:
if
rv
is
NotImplemented
:
rv
=
(
str
(
_type
(
self
.
obj
)),
_
id
(
self
.
obj
))
<
\
rv
=
(
str
(
type
(
self
.
obj
)),
id
(
self
.
obj
))
<
\
(
str
(
_type
(
other
.
obj
)),
_
id
(
other
.
obj
))
(
str
(
type
(
other
.
obj
)),
id
(
other
.
obj
))
return
rv
return
rv
def
_safe_tuple
(
t
):
def
_safe_tuple
(
t
):
...
@@ -159,16 +153,16 @@ class PrettyPrinter:
...
@@ -159,16 +153,16 @@ class PrettyPrinter:
def
_format
(
self
,
object
,
stream
,
indent
,
allowance
,
context
,
level
):
def
_format
(
self
,
object
,
stream
,
indent
,
allowance
,
context
,
level
):
level
=
level
+
1
level
=
level
+
1
objid
=
_
id
(
object
)
objid
=
id
(
object
)
if
objid
in
context
:
if
objid
in
context
:
stream
.
write
(
_recursion
(
object
))
stream
.
write
(
_recursion
(
object
))
self
.
_recursive
=
True
self
.
_recursive
=
True
self
.
_readable
=
False
self
.
_readable
=
False
return
return
rep
=
self
.
_repr
(
object
,
context
,
level
-
1
)
rep
=
self
.
_repr
(
object
,
context
,
level
-
1
)
typ
=
_
type
(
object
)
typ
=
type
(
object
)
max_width
=
self
.
_width
-
1
-
indent
-
allowance
max_width
=
self
.
_width
-
1
-
indent
-
allowance
sepLines
=
_
len
(
rep
)
>
max_width
sepLines
=
len
(
rep
)
>
max_width
write
=
stream
.
write
write
=
stream
.
write
if
sepLines
:
if
sepLines
:
...
@@ -177,7 +171,7 @@ class PrettyPrinter:
...
@@ -177,7 +171,7 @@ class PrettyPrinter:
write
(
'{'
)
write
(
'{'
)
if
self
.
_indent_per_level
>
1
:
if
self
.
_indent_per_level
>
1
:
write
((
self
.
_indent_per_level
-
1
)
*
' '
)
write
((
self
.
_indent_per_level
-
1
)
*
' '
)
length
=
_
len
(
object
)
length
=
len
(
object
)
if
length
:
if
length
:
context
[
objid
]
=
1
context
[
objid
]
=
1
indent
=
indent
+
self
.
_indent_per_level
indent
=
indent
+
self
.
_indent_per_level
...
@@ -189,13 +183,13 @@ class PrettyPrinter:
...
@@ -189,13 +183,13 @@ class PrettyPrinter:
rep
=
self
.
_repr
(
key
,
context
,
level
)
rep
=
self
.
_repr
(
key
,
context
,
level
)
write
(
rep
)
write
(
rep
)
write
(
': '
)
write
(
': '
)
self
.
_format
(
ent
,
stream
,
indent
+
_
len
(
rep
)
+
2
,
self
.
_format
(
ent
,
stream
,
indent
+
len
(
rep
)
+
2
,
allowance
+
1
,
context
,
level
)
allowance
+
1
,
context
,
level
)
if
length
>
1
:
if
length
>
1
:
for
key
,
ent
in
items
[
1
:]:
for
key
,
ent
in
items
[
1
:]:
rep
=
self
.
_repr
(
key
,
context
,
level
)
rep
=
self
.
_repr
(
key
,
context
,
level
)
write
(
',
\n
%
s
%
s: '
%
(
' '
*
indent
,
rep
))
write
(
',
\n
%
s
%
s: '
%
(
' '
*
indent
,
rep
))
self
.
_format
(
ent
,
stream
,
indent
+
_
len
(
rep
)
+
2
,
self
.
_format
(
ent
,
stream
,
indent
+
len
(
rep
)
+
2
,
allowance
+
1
,
context
,
level
)
allowance
+
1
,
context
,
level
)
indent
=
indent
-
self
.
_indent_per_level
indent
=
indent
-
self
.
_indent_per_level
del
context
[
objid
]
del
context
[
objid
]
...
@@ -207,7 +201,7 @@ class PrettyPrinter:
...
@@ -207,7 +201,7 @@ class PrettyPrinter:
(
issubclass
(
typ
,
set
)
and
r
is
set
.
__repr__
)
or
(
issubclass
(
typ
,
set
)
and
r
is
set
.
__repr__
)
or
(
issubclass
(
typ
,
frozenset
)
and
r
is
frozenset
.
__repr__
)
(
issubclass
(
typ
,
frozenset
)
and
r
is
frozenset
.
__repr__
)
):
):
length
=
_
len
(
object
)
length
=
len
(
object
)
if
issubclass
(
typ
,
list
):
if
issubclass
(
typ
,
list
):
write
(
'['
)
write
(
'['
)
endchar
=
']'
endchar
=
']'
...
@@ -225,7 +219,7 @@ class PrettyPrinter:
...
@@ -225,7 +219,7 @@ class PrettyPrinter:
write
(
typ
.
__name__
)
write
(
typ
.
__name__
)
write
(
'({'
)
write
(
'({'
)
endchar
=
'})'
endchar
=
'})'
indent
+=
_
len
(
typ
.
__name__
)
+
1
indent
+=
len
(
typ
.
__name__
)
+
1
object
=
sorted
(
object
,
key
=
_safe_key
)
object
=
sorted
(
object
,
key
=
_safe_key
)
if
self
.
_indent_per_level
>
1
:
if
self
.
_indent_per_level
>
1
:
write
((
self
.
_indent_per_level
-
1
)
*
' '
)
write
((
self
.
_indent_per_level
-
1
)
*
' '
)
...
@@ -240,7 +234,7 @@ class PrettyPrinter:
...
@@ -240,7 +234,7 @@ class PrettyPrinter:
write
(
endchar
)
write
(
endchar
)
return
return
if
issubclass
(
typ
,
str
)
and
_
len
(
object
)
>
0
and
r
is
str
.
__repr__
:
if
issubclass
(
typ
,
str
)
and
len
(
object
)
>
0
and
r
is
str
.
__repr__
:
def
_str_parts
(
s
):
def
_str_parts
(
s
):
"""
"""
Return a list of string literals comprising the repr()
Return a list of string literals comprising the repr()
...
@@ -249,16 +243,16 @@ class PrettyPrinter:
...
@@ -249,16 +243,16 @@ class PrettyPrinter:
lines
=
s
.
splitlines
(
True
)
lines
=
s
.
splitlines
(
True
)
for
i
,
line
in
enumerate
(
lines
):
for
i
,
line
in
enumerate
(
lines
):
rep
=
repr
(
line
)
rep
=
repr
(
line
)
if
_
len
(
rep
)
<=
max_width
:
if
len
(
rep
)
<=
max_width
:
yield
rep
yield
rep
else
:
else
:
# A list of alternating (non-space, space) strings
# A list of alternating (non-space, space) strings
parts
=
re
.
split
(
r'(\s+)'
,
line
)
+
[
''
]
parts
=
re
.
split
(
r'(\s+)'
,
line
)
+
[
''
]
current
=
''
current
=
''
for
i
in
range
(
0
,
_
len
(
parts
),
2
):
for
i
in
range
(
0
,
len
(
parts
),
2
):
part
=
parts
[
i
]
+
parts
[
i
+
1
]
part
=
parts
[
i
]
+
parts
[
i
+
1
]
candidate
=
current
+
part
candidate
=
current
+
part
if
_
len
(
repr
(
candidate
))
>
max_width
:
if
len
(
repr
(
candidate
))
>
max_width
:
if
current
:
if
current
:
yield
repr
(
current
)
yield
repr
(
current
)
current
=
part
current
=
part
...
@@ -281,7 +275,7 @@ class PrettyPrinter:
...
@@ -281,7 +275,7 @@ class PrettyPrinter:
for
ent
in
items
:
for
ent
in
items
:
if
self
.
_compact
:
if
self
.
_compact
:
rep
=
self
.
_repr
(
ent
,
context
,
level
)
rep
=
self
.
_repr
(
ent
,
context
,
level
)
w
=
_
len
(
rep
)
+
2
w
=
len
(
rep
)
+
2
if
width
<
w
:
if
width
<
w
:
width
=
max_width
width
=
max_width
if
delim
:
if
delim
:
...
@@ -316,7 +310,7 @@ class PrettyPrinter:
...
@@ -316,7 +310,7 @@ class PrettyPrinter:
# Return triple (repr_string, isreadable, isrecursive).
# Return triple (repr_string, isreadable, isrecursive).
def
_safe_repr
(
object
,
context
,
maxlevels
,
level
):
def
_safe_repr
(
object
,
context
,
maxlevels
,
level
):
typ
=
_
type
(
object
)
typ
=
type
(
object
)
if
typ
is
str
:
if
typ
is
str
:
if
'locale'
not
in
_sys
.
modules
:
if
'locale'
not
in
_sys
.
modules
:
return
repr
(
object
),
True
,
False
return
repr
(
object
),
True
,
False
...
@@ -340,7 +334,7 @@ def _safe_repr(object, context, maxlevels, level):
...
@@ -340,7 +334,7 @@ def _safe_repr(object, context, maxlevels, level):
if
issubclass
(
typ
,
dict
)
and
r
is
dict
.
__repr__
:
if
issubclass
(
typ
,
dict
)
and
r
is
dict
.
__repr__
:
if
not
object
:
if
not
object
:
return
"{}"
,
True
,
False
return
"{}"
,
True
,
False
objid
=
_
id
(
object
)
objid
=
id
(
object
)
if
maxlevels
and
level
>=
maxlevels
:
if
maxlevels
and
level
>=
maxlevels
:
return
"{...}"
,
False
,
objid
in
context
return
"{...}"
,
False
,
objid
in
context
if
objid
in
context
:
if
objid
in
context
:
...
@@ -361,7 +355,7 @@ def _safe_repr(object, context, maxlevels, level):
...
@@ -361,7 +355,7 @@ def _safe_repr(object, context, maxlevels, level):
if
krecur
or
vrecur
:
if
krecur
or
vrecur
:
recursive
=
True
recursive
=
True
del
context
[
objid
]
del
context
[
objid
]
return
"{
%
s}"
%
_comma
join
(
components
),
readable
,
recursive
return
"{
%
s}"
%
", "
.
join
(
components
),
readable
,
recursive
if
(
issubclass
(
typ
,
list
)
and
r
is
list
.
__repr__
)
or
\
if
(
issubclass
(
typ
,
list
)
and
r
is
list
.
__repr__
)
or
\
(
issubclass
(
typ
,
tuple
)
and
r
is
tuple
.
__repr__
):
(
issubclass
(
typ
,
tuple
)
and
r
is
tuple
.
__repr__
):
...
@@ -369,13 +363,13 @@ def _safe_repr(object, context, maxlevels, level):
...
@@ -369,13 +363,13 @@ def _safe_repr(object, context, maxlevels, level):
if
not
object
:
if
not
object
:
return
"[]"
,
True
,
False
return
"[]"
,
True
,
False
format
=
"[
%
s]"
format
=
"[
%
s]"
elif
_
len
(
object
)
==
1
:
elif
len
(
object
)
==
1
:
format
=
"(
%
s,)"
format
=
"(
%
s,)"
else
:
else
:
if
not
object
:
if
not
object
:
return
"()"
,
True
,
False
return
"()"
,
True
,
False
format
=
"(
%
s)"
format
=
"(
%
s)"
objid
=
_
id
(
object
)
objid
=
id
(
object
)
if
maxlevels
and
level
>=
maxlevels
:
if
maxlevels
and
level
>=
maxlevels
:
return
format
%
"..."
,
False
,
objid
in
context
return
format
%
"..."
,
False
,
objid
in
context
if
objid
in
context
:
if
objid
in
context
:
...
@@ -394,7 +388,7 @@ def _safe_repr(object, context, maxlevels, level):
...
@@ -394,7 +388,7 @@ def _safe_repr(object, context, maxlevels, level):
if
orecur
:
if
orecur
:
recursive
=
True
recursive
=
True
del
context
[
objid
]
del
context
[
objid
]
return
format
%
_comma
join
(
components
),
readable
,
recursive
return
format
%
", "
.
join
(
components
),
readable
,
recursive
rep
=
repr
(
object
)
rep
=
repr
(
object
)
return
rep
,
(
rep
and
not
rep
.
startswith
(
'<'
)),
False
return
rep
,
(
rep
and
not
rep
.
startswith
(
'<'
)),
False
...
@@ -402,7 +396,7 @@ def _safe_repr(object, context, maxlevels, level):
...
@@ -402,7 +396,7 @@ def _safe_repr(object, context, maxlevels, level):
def
_recursion
(
object
):
def
_recursion
(
object
):
return
(
"<Recursion on
%
s with id=
%
s>"
return
(
"<Recursion on
%
s with id=
%
s>"
%
(
_type
(
object
)
.
__name__
,
_
id
(
object
)))
%
(
type
(
object
)
.
__name__
,
id
(
object
)))
def
_perfcheck
(
object
=
None
):
def
_perfcheck
(
object
=
None
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment