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
250ad613
Kaydet (Commit)
250ad613
authored
Nis 07, 2008
tarafından
Martin v. Löwis
Dosyalara gözat
Seçenekler
Dosyalara Gözat
İndir
Eposta Yamaları
Sade Fark
Bug #2565: The repr() of type objects now calls them 'class',
not 'type' - whether they are builtin types or not.
üst
5a6f4585
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
40 additions
and
43 deletions
+40
-43
stdtypes.rst
Doc/library/stdtypes.rst
+1
-1
errors.rst
Doc/tutorial/errors.rst
+1
-1
test_structures.py
Lib/ctypes/test/test_structures.py
+2
-2
test_defaultdict.py
Lib/test/test_defaultdict.py
+1
-1
test_descrtut.py
Lib/test/test_descrtut.py
+5
-5
test_doctest3.txt
Lib/test/test_doctest3.txt
+1
-1
test_generators.py
Lib/test/test_generators.py
+17
-17
test_genexps.py
Lib/test/test_genexps.py
+1
-1
test_metaclass.py
Lib/test/test_metaclass.py
+3
-3
test_wsgiref.py
Lib/test/test_wsgiref.py
+1
-1
test_xmlrpc.py
Lib/test/test_xmlrpc.py
+2
-2
NEWS
Misc/NEWS
+3
-0
typeobject.c
Objects/typeobject.c
+2
-8
No files found.
Doc/library/stdtypes.rst
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -2,4 +2,4 @@
Here we check that `__file__` is provided:
>>> type(__file__)
<
type
'str'>
<
class
'str'>
Lib/test/test_generators.py
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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
Dosyayı görüntüle @
250ad613
...
...
@@ -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