[Python-checkins] cpython (merge 3.5 -> default): typing.py: merge 3.5->3.6 (Tuple/ellipsis/equality).

guido.van.rossum python-checkins at python.org
Mon Apr 18 10:40:12 EDT 2016


https://hg.python.org/cpython/rev/98cda226d208
changeset: 101051:98cda226d208
parent: 101049:43567d214534
parent: 101050:9e9f01260b27
user: Guido van Rossum <guido at dropbox.com>
date: Mon Apr 18 07:39:54 2016 -0700
summary:
 typing.py: merge 3.5->3.6 (Tuple/ellipsis/equality).
files:
 Lib/test/test_typing.py | 6 ++++++
 Lib/typing.py | 3 ++-
 2 files changed, 8 insertions(+), 1 deletions(-)
diff --git a/Lib/test/test_typing.py b/Lib/test/test_typing.py
--- a/Lib/test/test_typing.py
+++ b/Lib/test/test_typing.py
@@ -359,6 +359,12 @@
 self.assertTrue(issubclass(tuple, Tuple))
 self.assertFalse(issubclass(Tuple, tuple)) # Can't have it both ways.
 
+ def test_equality(self):
+ assert Tuple[int] == Tuple[int]
+ assert Tuple[int, ...] == Tuple[int, ...]
+ assert Tuple[int] != Tuple[int, int]
+ assert Tuple[int] != Tuple[int, ...]
+
 def test_tuple_subclass(self):
 class MyTuple(tuple):
 pass
diff --git a/Lib/typing.py b/Lib/typing.py
--- a/Lib/typing.py
+++ b/Lib/typing.py
@@ -705,7 +705,8 @@
 def __eq__(self, other):
 if not isinstance(other, TupleMeta):
 return NotImplemented
- return self.__tuple_params__ == other.__tuple_params__
+ return (self.__tuple_params__ == other.__tuple_params__ and
+ self.__tuple_use_ellipsis__ == other.__tuple_use_ellipsis__)
 
 def __hash__(self):
 return hash(self.__tuple_params__)
-- 
Repository URL: https://hg.python.org/cpython


More information about the Python-checkins mailing list

AltStyle によって変換されたページ (->オリジナル) /