mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 11:14:33 +00:00 
			
		
		
		
	bpo-28556: Minor fixes for typing module (GH-6732)
This also fixes https://bugs.python.org/issue33420
This commit is contained in:
		
							parent
							
								
									0904f766e1
								
							
						
					
					
						commit
						43d12a6bd8
					
				
					 3 changed files with 79 additions and 2 deletions
				
			
		|  | @ -1324,6 +1324,72 @@ class D(C): | ||||||
|         with self.assertRaises(Exception): |         with self.assertRaises(Exception): | ||||||
|             D[T] |             D[T] | ||||||
| 
 | 
 | ||||||
|  |     def test_new_with_args(self): | ||||||
|  | 
 | ||||||
|  |         class A(Generic[T]): | ||||||
|  |             pass | ||||||
|  | 
 | ||||||
|  |         class B: | ||||||
|  |             def __new__(cls, arg): | ||||||
|  |                 # call object | ||||||
|  |                 obj = super().__new__(cls) | ||||||
|  |                 obj.arg = arg | ||||||
|  |                 return obj | ||||||
|  | 
 | ||||||
|  |         # mro: C, A, Generic, B, object | ||||||
|  |         class C(A, B): | ||||||
|  |             pass | ||||||
|  | 
 | ||||||
|  |         c = C('foo') | ||||||
|  |         self.assertEqual(c.arg, 'foo') | ||||||
|  | 
 | ||||||
|  |     def test_new_with_args2(self): | ||||||
|  | 
 | ||||||
|  |         class A: | ||||||
|  |             def __init__(self, arg): | ||||||
|  |                 self.from_a = arg | ||||||
|  |                 # call object | ||||||
|  |                 super().__init__() | ||||||
|  | 
 | ||||||
|  |         # mro: C, Generic, A, object | ||||||
|  |         class C(Generic[T], A): | ||||||
|  |             def __init__(self, arg): | ||||||
|  |                 self.from_c = arg | ||||||
|  |                 # call Generic | ||||||
|  |                 super().__init__(arg) | ||||||
|  | 
 | ||||||
|  |         c = C('foo') | ||||||
|  |         self.assertEqual(c.from_a, 'foo') | ||||||
|  |         self.assertEqual(c.from_c, 'foo') | ||||||
|  | 
 | ||||||
|  |     def test_new_no_args(self): | ||||||
|  | 
 | ||||||
|  |         class A(Generic[T]): | ||||||
|  |             pass | ||||||
|  | 
 | ||||||
|  |         class B: | ||||||
|  |             def __new__(cls): | ||||||
|  |                 # call object | ||||||
|  |                 obj = super().__new__(cls) | ||||||
|  |                 obj.from_b = 'b' | ||||||
|  |                 return obj | ||||||
|  | 
 | ||||||
|  |         # mro: C, A, Generic, B, object | ||||||
|  |         class C(A, B): | ||||||
|  |             def __init__(self, arg): | ||||||
|  |                 self.arg = arg | ||||||
|  | 
 | ||||||
|  |             def __new__(cls, arg): | ||||||
|  |                 # call A | ||||||
|  |                 obj = super().__new__(cls) | ||||||
|  |                 obj.from_c = 'c' | ||||||
|  |                 return obj | ||||||
|  | 
 | ||||||
|  |         c = C('foo') | ||||||
|  |         self.assertEqual(c.arg, 'foo') | ||||||
|  |         self.assertEqual(c.from_b, 'b') | ||||||
|  |         self.assertEqual(c.from_c, 'c') | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| class ClassVarTests(BaseTestCase): | class ClassVarTests(BaseTestCase): | ||||||
| 
 | 
 | ||||||
|  | @ -1737,6 +1803,8 @@ def test_get_type_hints_classes(self): | ||||||
|         self.assertEqual(gth(HasForeignBaseClass), |         self.assertEqual(gth(HasForeignBaseClass), | ||||||
|                          {'some_xrepr': XRepr, 'other_a': mod_generics_cache.A, |                          {'some_xrepr': XRepr, 'other_a': mod_generics_cache.A, | ||||||
|                           'some_b': mod_generics_cache.B}) |                           'some_b': mod_generics_cache.B}) | ||||||
|  |         self.assertEqual(gth(XRepr.__new__), | ||||||
|  |                          {'x': int, 'y': int}) | ||||||
|         self.assertEqual(gth(mod_generics_cache.B), |         self.assertEqual(gth(mod_generics_cache.B), | ||||||
|                          {'my_inner_a1': mod_generics_cache.B.A, |                          {'my_inner_a1': mod_generics_cache.B.A, | ||||||
|                           'my_inner_a2': mod_generics_cache.B.A, |                           'my_inner_a2': mod_generics_cache.B.A, | ||||||
|  |  | ||||||
|  | @ -607,7 +607,8 @@ def __reduce__(self): | ||||||
| # * __parameters__ is a tuple of unique free type parameters of a generic | # * __parameters__ is a tuple of unique free type parameters of a generic | ||||||
| #   type, for example, Dict[T, T].__parameters__ == (T,); | #   type, for example, Dict[T, T].__parameters__ == (T,); | ||||||
| # * __origin__ keeps a reference to a type that was subscripted, | # * __origin__ keeps a reference to a type that was subscripted, | ||||||
| #   e.g., Union[T, int].__origin__ == Union; | #   e.g., Union[T, int].__origin__ == Union, or the non-generic version of | ||||||
|  | #   the type. | ||||||
| # * __args__ is a tuple of all arguments used in subscripting, | # * __args__ is a tuple of all arguments used in subscripting, | ||||||
| #   e.g., Dict[T, int].__args__ == (T, int). | #   e.g., Dict[T, int].__args__ == (T, int). | ||||||
| 
 | 
 | ||||||
|  | @ -835,7 +836,11 @@ def __new__(cls, *args, **kwds): | ||||||
|         if cls is Generic: |         if cls is Generic: | ||||||
|             raise TypeError("Type Generic cannot be instantiated; " |             raise TypeError("Type Generic cannot be instantiated; " | ||||||
|                             "it can be used only as a base class") |                             "it can be used only as a base class") | ||||||
|         return super().__new__(cls) |         if super().__new__ is object.__new__: | ||||||
|  |             obj = super().__new__(cls) | ||||||
|  |         else: | ||||||
|  |             obj = super().__new__(cls, *args, **kwds) | ||||||
|  |         return obj | ||||||
| 
 | 
 | ||||||
|     @_tp_cache |     @_tp_cache | ||||||
|     def __class_getitem__(cls, params): |     def __class_getitem__(cls, params): | ||||||
|  | @ -1385,6 +1390,7 @@ def __new__(cls, typename, bases, ns): | ||||||
|                                 "follow default field(s) {default_names}" |                                 "follow default field(s) {default_names}" | ||||||
|                                 .format(field_name=field_name, |                                 .format(field_name=field_name, | ||||||
|                                         default_names=', '.join(defaults_dict.keys()))) |                                         default_names=', '.join(defaults_dict.keys()))) | ||||||
|  |         nm_tpl.__new__.__annotations__ = collections.OrderedDict(types) | ||||||
|         nm_tpl.__new__.__defaults__ = tuple(defaults) |         nm_tpl.__new__.__defaults__ = tuple(defaults) | ||||||
|         nm_tpl._field_defaults = defaults_dict |         nm_tpl._field_defaults = defaults_dict | ||||||
|         # update from user namespace without overriding special namedtuple attributes |         # update from user namespace without overriding special namedtuple attributes | ||||||
|  |  | ||||||
|  | @ -0,0 +1,3 @@ | ||||||
|  | Minor fixes in typing module: add annotations to ``NamedTuple.__new__``, | ||||||
|  | pass ``*args`` and ``**kwds`` in ``Generic.__new__``.  Original PRs by | ||||||
|  | Paulius Šarka and Chad Dombrova. | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Ivan Levkivskyi
						Ivan Levkivskyi