Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
8ac64c88
Commit
8ac64c88
authored
Apr 07, 2008
by
Martin v. Löwis
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Bug #2565: The repr() of type objects now calls them 'class',
not 'type' - whether they are builtin types or not.
parent
33e43393
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
40 additions
and
43 deletions
+40
-43
Doc/library/stdtypes.rst
Doc/library/stdtypes.rst
+1
-1
Doc/tutorial/errors.rst
Doc/tutorial/errors.rst
+1
-1
Lib/ctypes/test/test_structures.py
Lib/ctypes/test/test_structures.py
+2
-2
Lib/test/test_defaultdict.py
Lib/test/test_defaultdict.py
+1
-1
Lib/test/test_descrtut.py
Lib/test/test_descrtut.py
+5
-5
Lib/test/test_doctest3.txt
Lib/test/test_doctest3.txt
+1
-1
Lib/test/test_generators.py
Lib/test/test_generators.py
+17
-17
Lib/test/test_genexps.py
Lib/test/test_genexps.py
+1
-1
Lib/test/test_metaclass.py
Lib/test/test_metaclass.py
+3
-3
Lib/test/test_wsgiref.py
Lib/test/test_wsgiref.py
+1
-1
Lib/test/test_xmlrpc.py
Lib/test/test_xmlrpc.py
+2
-2
Misc/NEWS
Misc/NEWS
+3
-0
Objects/typeobject.c
Objects/typeobject.c
+2
-8
No files found.
Doc/library/stdtypes.rst
View file @
8ac64c88
...
...
@@ -2345,7 +2345,7 @@ by the built-in function :func:`type`. There are no special operations on
types. The standard module :mod:`types` defines names for all standard built-in
types.
Types are written like this: ``<
type
'int'>``.
Types are written like this: ``<
class
'int'>``.
.. _bltin-null-object:
...
...
Doc/tutorial/errors.rst
View file @
8ac64c88
...
...
@@ -184,7 +184,7 @@ desired. ::
... print('x =', x)
... print('y =', y)
...
<
type
'Exception'>
<
class
'Exception'>
('spam', 'eggs')
('spam', 'eggs')
x = spam
...
...
Lib/ctypes/test/test_structures.py
View file @
8ac64c88
...
...
@@ -307,14 +307,14 @@ class StructureTestCase(unittest.TestCase):
cls
,
msg
=
self
.
get_except
(
Person
,
"Someone"
,
(
1
,
2
))
self
.
failUnlessEqual
(
cls
,
RuntimeError
)
self
.
failUnlessEqual
(
msg
,
"(Phone) <
type
'TypeError'>: "
"(Phone) <
class
'TypeError'>: "
"expected string, int found"
)
cls
,
msg
=
self
.
get_except
(
Person
,
"Someone"
,
(
"a"
,
"b"
,
"c"
))
self
.
failUnlessEqual
(
cls
,
RuntimeError
)
if
issubclass
(
Exception
,
object
):
self
.
failUnlessEqual
(
msg
,
"(Phone) <
type
'TypeError'>: too many initializers"
)
"(Phone) <
class
'TypeError'>: too many initializers"
)
else
:
self
.
failUnlessEqual
(
msg
,
"(Phone) TypeError: too many initializers"
)
...
...
Lib/test/test_defaultdict.py
View file @
8ac64c88
...
...
@@ -64,7 +64,7 @@ class TestDefaultDict(unittest.TestCase):
d2
=
defaultdict
(
int
)
self
.
assertEqual
(
d2
.
default_factory
,
int
)
d2
[
12
]
=
42
self
.
assertEqual
(
repr
(
d2
),
"defaultdict(<
type
'int'>, {12: 42})"
)
self
.
assertEqual
(
repr
(
d2
),
"defaultdict(<
class
'int'>, {12: 42})"
)
def
foo
():
return
43
d3
=
defaultdict
(
foo
)
self
.
assert_
(
d3
.
default_factory
is
foo
)
...
...
Lib/test/test_descrtut.py
View file @
8ac64c88
...
...
@@ -39,7 +39,7 @@ Here's the new type at work:
>>> print(defaultdict) # show our type
<class 'test.test_descrtut.defaultdict'>
>>> print(type(defaultdict)) # its metatype
<
type
'type'>
<
class
'type'>
>>> a = defaultdict(default=0.0) # create an instance
>>> print(a) # show the instance
{}
...
...
@@ -149,11 +149,11 @@ Introspecting instances of built-in types
For instance of built-in types, x.__class__ is now the same as type(x):
>>> type([])
<
type
'list'>
<
class
'list'>
>>> [].__class__
<
type
'list'>
<
class
'list'>
>>> list
<
type
'list'>
<
class
'list'>
>>> isinstance([], list)
True
>>> isinstance([], dict)
...
...
@@ -346,7 +346,7 @@ Hmm -- property is builtin now, so let's try it that way too.
>>> del property # unmask the builtin
>>> property
<
type
'property'>
<
class
'property'>
>>> class C(object):
... def __init__(self):
...
...
Lib/test/test_doctest3.txt
View file @
8ac64c88
...
...
@@ -2,4 +2,4 @@
Here we check that `__file__` is provided:
>>> type(__file__)
<
type
'str'>
<
class
'str'>
Lib/test/test_generators.py
View file @
8ac64c88
...
...
@@ -377,10 +377,10 @@ From the Iterators list, about the types of these things.
... yield 1
...
>>> type(g)
<
type
'function'>
<
class
'function'>
>>> i = g()
>>> type(i)
<
type
'generator'>
<
class
'generator'>
>>> [s for s in dir(i) if not s.startswith('_')]
['close', 'gi_code', 'gi_frame', 'gi_running', 'send', 'throw']
>>> print(i.__next__.__doc__)
...
...
@@ -396,7 +396,7 @@ And more, added later.
>>> i.gi_running
0
>>> type(i.gi_frame)
<
type
'frame'>
<
class
'frame'>
>>> i.gi_running = 42
Traceback (most recent call last):
...
...
...
@@ -794,27 +794,27 @@ These are fine:
>>> def f():
... yield
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f():
... if 0:
... yield
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f():
... if 0:
... yield 1
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f():
... if "":
... yield None
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f():
... return
...
...
@@ -838,7 +838,7 @@ These are fine:
... x = 1
... return
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f():
... if 0:
...
...
@@ -846,7 +846,7 @@ These are fine:
... yield 1
...
>>> type(f())
<
type
'NoneType'>
<
class
'NoneType'>
>>> def f():
... if 0:
...
...
@@ -856,7 +856,7 @@ These are fine:
... def f(self):
... yield 2
>>> type(f())
<
type
'NoneType'>
<
class
'NoneType'>
>>> def f():
... if 0:
...
...
@@ -864,7 +864,7 @@ These are fine:
... if 0:
... yield 2
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f():
...
...
@@ -1512,7 +1512,7 @@ And a more sane, but still weird usage:
>>> def f(): list(i for i in [(yield 26)])
>>> type(f())
<
type
'generator'>
<
class
'generator'>
A yield expression with augmented assignment.
...
...
@@ -1749,25 +1749,25 @@ enclosing function a generator:
>>> def f(): x += yield
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f(): x = yield
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f(): lambda x=(yield): 1
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f(): x=(i for i in (yield) if (yield))
>>> type(f())
<
type
'generator'>
<
class
'generator'>
>>> def f(d): d[(yield "a")] = d[(yield "b")] = 27
>>> data = [1,2]
>>> g = f(data)
>>> type(g)
<
type
'generator'>
<
class
'generator'>
>>> g.send(None)
'a'
>>> data
...
...
Lib/test/test_genexps.py
View file @
8ac64c88
...
...
@@ -27,7 +27,7 @@ Test first class
>>> g = (i*i for i in range(4))
>>> type(g)
<
type
'generator'>
<
class
'generator'>
>>> list(g)
[0, 1, 4, 9]
...
...
Lib/test/test_metaclass.py
View file @
8ac64c88
...
...
@@ -78,7 +78,7 @@ Also pass another keyword.
>>> class C(object, metaclass=M, other="haha"):
... pass
...
Prepare called: ('C', (<
type
'object'>,)) {'other': 'haha'}
Prepare called: ('C', (<
class
'object'>,)) {'other': 'haha'}
New called: {'other': 'haha'}
>>> C.__class__ is M
True
...
...
@@ -104,7 +104,7 @@ Use various combinations of explicit keywords and **kwds.
>>> kwds = {'metaclass': M, 'other': 'haha'}
>>> class C(*bases, **kwds): pass
...
Prepare called: ('C', (<
type
'object'>,)) {'other': 'haha'}
Prepare called: ('C', (<
class
'object'>,)) {'other': 'haha'}
New called: {'other': 'haha'}
>>> C.__class__ is M
True
...
...
@@ -114,7 +114,7 @@ Use various combinations of explicit keywords and **kwds.
>>> kwds = {'other': 'haha'}
>>> class C(B, metaclass=M, *bases, **kwds): pass
...
Prepare called: ('C', (<class 'test.test_metaclass.B'>, <
type
'object'>)) {'other': 'haha'}
Prepare called: ('C', (<class 'test.test_metaclass.B'>, <
class
'object'>)) {'other': 'haha'}
New called: {'other': 'haha'}
>>> C.__class__ is M
True
...
...
Lib/test/test_wsgiref.py
View file @
8ac64c88
...
...
@@ -157,7 +157,7 @@ class IntegrationTests(TestCase):
self
.
assertEqual
(
err
.
splitlines
()[
-
2
],
"AssertionError: Headers (('Content-Type', 'text/plain')) must"
" be of type list: <
type
'tuple'>"
" be of type list: <
class
'tuple'>"
)
...
...
Lib/test/test_xmlrpc.py
View file @
8ac64c88
...
...
@@ -416,12 +416,12 @@ class SimpleServerTestCase(unittest.TestCase):
result
=
multicall
()
# result.results contains;
# [{'faultCode': 1, 'faultString': '<
type
\'exceptions.Exception\'>:'
# [{'faultCode': 1, 'faultString': '<
class
\'exceptions.Exception\'>:'
# 'method "this_is_not_exists" is not supported'>}]
self
.
assertEqual
(
result
.
results
[
0
][
'faultCode'
],
1
)
self
.
assertEqual
(
result
.
results
[
0
][
'faultString'
],
'<
type
\
'
Exception
\
'
>:method "this_is_not_exists" '
'<
class
\
'
Exception
\
'
>:method "this_is_not_exists" '
'is not supported'
)
except
(
xmlrpclib
.
ProtocolError
,
socket
.
error
)
as
e
:
# ignore failures due to non-blocking socket 'unavailable' errors
...
...
Misc/NEWS
View file @
8ac64c88
...
...
@@ -12,6 +12,9 @@ What's New in Python 3.0a5?
Core and Builtins
-----------------
- Bug #2565: The repr() of type objects now calls them 'class',
not 'type' - whether they are builtin types or not.
- The command line processing was converted to pass Unicode strings
through as unmodified as possible; as a consequence, the C API
related to command line arguments was changed to use wchar_t.
...
...
Objects/typeobject.c
View file @
8ac64c88
...
...
@@ -600,7 +600,6 @@ static PyObject *
type_repr
(
PyTypeObject
*
type
)
{
PyObject
*
mod
,
*
name
,
*
rtn
;
char
*
kind
;
mod
=
type_module
(
type
,
NULL
);
if
(
mod
==
NULL
)
...
...
@@ -613,15 +612,10 @@ type_repr(PyTypeObject *type)
if
(
name
==
NULL
)
return
NULL
;
if
(
type
->
tp_flags
&
Py_TPFLAGS_HEAPTYPE
)
kind
=
"class"
;
else
kind
=
"type"
;
if
(
mod
!=
NULL
&&
PyUnicode_CompareWithASCIIString
(
mod
,
"builtins"
))
rtn
=
PyUnicode_FromFormat
(
"<
%s '%U.%U'>"
,
kind
,
mod
,
name
);
rtn
=
PyUnicode_FromFormat
(
"<
class '%U.%U'>"
,
mod
,
name
);
else
rtn
=
PyUnicode_FromFormat
(
"<
%s '%s'>"
,
kind
,
type
->
tp_name
);
rtn
=
PyUnicode_FromFormat
(
"<
class '%s'>"
,
type
->
tp_name
);
Py_XDECREF
(
mod
);
Py_DECREF
(
name
);
...
...
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