summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeil Schemenauer <nascheme@enme.ucalgary.ca>2001-01-03 02:13:26 (GMT)
committerNeil Schemenauer <nascheme@enme.ucalgary.ca>2001-01-03 02:13:26 (GMT)
commite7e694fd22fd68f39d359b3d1d5a1f0ebb4ec265 (patch)
tree6a99b5249ee3b6da0283fcadd8b615c5feca12c0
parent38796d07a535618a9c12217c3d6d5d0309fceed5 (diff)
downloadcpython-e7e694fd22fd68f39d359b3d1d5a1f0ebb4ec265.zip
cpython-e7e694fd22fd68f39d359b3d1d5a1f0ebb4ec265.tar.gz
cpython-e7e694fd22fd68f39d359b3d1d5a1f0ebb4ec265.tar.bz2
Use == rather than cmp(). The return value of cmp() is not well defined when
comparing different types.
-rw-r--r--Lib/test/output/test_compare242
-rw-r--r--Lib/test/test_compare.py16
2 files changed, 130 insertions, 128 deletions
diff --git a/Lib/test/output/test_compare b/Lib/test/output/test_compare
index 4df9e49..8301233 100644
--- a/Lib/test/output/test_compare
+++ b/Lib/test/output/test_compare
@@ -1,122 +1,122 @@
test_compare
-cmp(2, 2) = 0
-cmp(2, 2.2) = -1
-cmp(2, 2) = 0
-cmp(2, (2+4j)) = -1
-cmp(2, [1]) = -108
-cmp(2, (2,)) = -116
-cmp(2, None) = -78
-cmp(2, <Empty>) = -1
-cmp(2, <Coerce 3>) = -1
-cmp(2, <Cmp 4>) = -1
-cmp(2, <RCmp 5>) = -1
-cmp(2.2, 2) = 1
-cmp(2.2, 2.2) = 0
-cmp(2.2, 2) = 1
-cmp(2.2, (2+4j)) = 1
-cmp(2.2, [1]) = -108
-cmp(2.2, (2,)) = -116
-cmp(2.2, None) = -78
-cmp(2.2, <Empty>) = -1
-cmp(2.2, <Coerce 3>) = -1
-cmp(2.2, <Cmp 4>) = -1
-cmp(2.2, <RCmp 5>) = -1
-cmp(2, 2) = 0
-cmp(2, 2.2) = -1
-cmp(2, 2) = 0
-cmp(2, (2+4j)) = -1
-cmp(2, [1]) = -108
-cmp(2, (2,)) = -116
-cmp(2, None) = -78
-cmp(2, <Empty>) = -1
-cmp(2, <Coerce 3>) = -1
-cmp(2, <Cmp 4>) = -1
-cmp(2, <RCmp 5>) = -1
-cmp((2+4j), 2) = 1
-cmp((2+4j), 2.2) = -1
-cmp((2+4j), 2) = 1
-cmp((2+4j), (2+4j)) = 0
-cmp((2+4j), [1]) = -108
-cmp((2+4j), (2,)) = -116
-cmp((2+4j), None) = -78
-cmp((2+4j), <Empty>) = -1
-cmp((2+4j), <Coerce 3>) = -1
-cmp((2+4j), <Cmp 4>) = -1
-cmp((2+4j), <RCmp 5>) = -1
-cmp([1], 2) = 108
-cmp([1], 2.2) = 108
-cmp([1], 2) = 108
-cmp([1], (2+4j)) = 108
-cmp([1], [1]) = 0
-cmp([1], (2,)) = -8
-cmp([1], None) = 30
-cmp([1], <Empty>) = -1
-cmp([1], <Coerce 3>) = 1
-cmp([1], <Cmp 4>) = 1
-cmp([1], <RCmp 5>) = -1
-cmp((2,), 2) = 116
-cmp((2,), 2.2) = 116
-cmp((2,), 2) = 116
-cmp((2,), (2+4j)) = 116
-cmp((2,), [1]) = 8
-cmp((2,), (2,)) = 0
-cmp((2,), None) = 38
-cmp((2,), <Empty>) = -1
-cmp((2,), <Coerce 3>) = 1
-cmp((2,), <Cmp 4>) = 1
-cmp((2,), <RCmp 5>) = -1
-cmp(None, 2) = 78
-cmp(None, 2.2) = 78
-cmp(None, 2) = 78
-cmp(None, (2+4j)) = 78
-cmp(None, [1]) = -30
-cmp(None, (2,)) = -38
-cmp(None, None) = 0
-cmp(None, <Empty>) = -1
-cmp(None, <Coerce 3>) = 1
-cmp(None, <Cmp 4>) = 1
-cmp(None, <RCmp 5>) = -1
-cmp(<Empty>, 2) = 1
-cmp(<Empty>, 2.2) = 1
-cmp(<Empty>, 2) = 1
-cmp(<Empty>, (2+4j)) = 1
-cmp(<Empty>, [1]) = 1
-cmp(<Empty>, (2,)) = 1
-cmp(<Empty>, None) = 1
-cmp(<Empty>, <Empty>) = 0
-cmp(<Empty>, <Coerce 3>) = -1
-cmp(<Empty>, <Cmp 4>) = -1
-cmp(<Empty>, <RCmp 5>) = 1
-cmp(<Coerce 3>, 2) = 1
-cmp(<Coerce 3>, 2.2) = 1
-cmp(<Coerce 3>, 2) = 1
-cmp(<Coerce 3>, (2+4j)) = 1
-cmp(<Coerce 3>, [1]) = -1
-cmp(<Coerce 3>, (2,)) = -1
-cmp(<Coerce 3>, None) = -1
-cmp(<Coerce 3>, <Empty>) = 1
-cmp(<Coerce 3>, <Coerce 3>) = 0
-cmp(<Coerce 3>, <Cmp 4>) = -1
-cmp(<Coerce 3>, <RCmp 5>) = -1
-cmp(<Cmp 4>, 2) = 1
-cmp(<Cmp 4>, 2.2) = 1
-cmp(<Cmp 4>, 2) = 1
-cmp(<Cmp 4>, (2+4j)) = 1
-cmp(<Cmp 4>, [1]) = -1
-cmp(<Cmp 4>, (2,)) = -1
-cmp(<Cmp 4>, None) = -1
-cmp(<Cmp 4>, <Empty>) = -1
-cmp(<Cmp 4>, <Coerce 3>) = 1
-cmp(<Cmp 4>, <Cmp 4>) = 0
-cmp(<Cmp 4>, <RCmp 5>) = -1
-cmp(<RCmp 5>, 2) = 1
-cmp(<RCmp 5>, 2.2) = 1
-cmp(<RCmp 5>, 2) = 1
-cmp(<RCmp 5>, (2+4j)) = 1
-cmp(<RCmp 5>, [1]) = 1
-cmp(<RCmp 5>, (2,)) = 1
-cmp(<RCmp 5>, None) = 1
-cmp(<RCmp 5>, <Empty>) = 1
-cmp(<RCmp 5>, <Coerce 3>) = 1
-cmp(<RCmp 5>, <Cmp 4>) = 1
-cmp(<RCmp 5>, <RCmp 5>) = 0
+2 == 2
+2 == 2.0
+2 == 2
+2 == (2+0j)
+2 != [1]
+2 != (3,)
+2 != None
+2 != <Empty>
+2 == <Coerce 2>
+2 == <Cmp 2.0>
+2 != <RCmp 2>
+2.0 == 2
+2.0 == 2.0
+2.0 == 2
+2.0 == (2+0j)
+2.0 != [1]
+2.0 != (3,)
+2.0 != None
+2.0 != <Empty>
+2.0 == <Coerce 2>
+2.0 == <Cmp 2.0>
+2.0 != <RCmp 2>
+2 == 2
+2 == 2.0
+2 == 2
+2 == (2+0j)
+2 != [1]
+2 != (3,)
+2 != None
+2 != <Empty>
+2 == <Coerce 2>
+2 == <Cmp 2.0>
+2 != <RCmp 2>
+(2+0j) == 2
+(2+0j) == 2.0
+(2+0j) == 2
+(2+0j) == (2+0j)
+(2+0j) != [1]
+(2+0j) != (3,)
+(2+0j) != None
+(2+0j) != <Empty>
+(2+0j) == <Coerce 2>
+(2+0j) == <Cmp 2.0>
+(2+0j) != <RCmp 2>
+[1] != 2
+[1] != 2.0
+[1] != 2
+[1] != (2+0j)
+[1] == [1]
+[1] != (3,)
+[1] != None
+[1] != <Empty>
+[1] != <Coerce 2>
+[1] != <Cmp 2.0>
+[1] != <RCmp 2>
+(3,) != 2
+(3,) != 2.0
+(3,) != 2
+(3,) != (2+0j)
+(3,) != [1]
+(3,) == (3,)
+(3,) != None
+(3,) != <Empty>
+(3,) != <Coerce 2>
+(3,) != <Cmp 2.0>
+(3,) != <RCmp 2>
+None != 2
+None != 2.0
+None != 2
+None != (2+0j)
+None != [1]
+None != (3,)
+None == None
+None != <Empty>
+None != <Coerce 2>
+None != <Cmp 2.0>
+None != <RCmp 2>
+<Empty> != 2
+<Empty> != 2.0
+<Empty> != 2
+<Empty> != (2+0j)
+<Empty> != [1]
+<Empty> != (3,)
+<Empty> != None
+<Empty> == <Empty>
+<Empty> != <Coerce 2>
+<Empty> != <Cmp 2.0>
+<Empty> != <RCmp 2>
+<Coerce 2> == 2
+<Coerce 2> == 2.0
+<Coerce 2> == 2
+<Coerce 2> == (2+0j)
+<Coerce 2> != [1]
+<Coerce 2> != (3,)
+<Coerce 2> != None
+<Coerce 2> != <Empty>
+<Coerce 2> == <Coerce 2>
+<Coerce 2> != <Cmp 2.0>
+<Coerce 2> == <RCmp 2>
+<Cmp 2.0> == 2
+<Cmp 2.0> == 2.0
+<Cmp 2.0> == 2
+<Cmp 2.0> == (2+0j)
+<Cmp 2.0> != [1]
+<Cmp 2.0> != (3,)
+<Cmp 2.0> != None
+<Cmp 2.0> != <Empty>
+<Cmp 2.0> == <Coerce 2>
+<Cmp 2.0> == <Cmp 2.0>
+<Cmp 2.0> != <RCmp 2>
+<RCmp 2> != 2
+<RCmp 2> != 2.0
+<RCmp 2> != 2
+<RCmp 2> != (2+0j)
+<RCmp 2> != [1]
+<RCmp 2> != (3,)
+<RCmp 2> != None
+<RCmp 2> != <Empty>
+<RCmp 2> != <Coerce 2>
+<RCmp 2> != <Cmp 2.0>
+<RCmp 2> == <RCmp 2>
diff --git a/Lib/test/test_compare.py b/Lib/test/test_compare.py
index d74f300..e8698a9 100644
--- a/Lib/test/test_compare.py
+++ b/Lib/test/test_compare.py
@@ -17,7 +17,7 @@ class Coerce:
if isinstance(other, Coerce):
return self.arg, other.arg
else:
- return (self.arg, other)
+ return self.arg, other
class Cmp:
def __init__(self,arg):
@@ -40,18 +40,20 @@ class RCmp:
return cmp(other, self.arg)
-candidates = [2, 2.2, 2L, 2+4j, [1], (2,), None, Empty(), Coerce(3),
- Cmp(4), RCmp(5)]
+candidates = [2, 2.0, 2L, 2+0j, [1], (3,), None, Empty(), Coerce(2),
+ Cmp(2.0), RCmp(2L)]
def test():
for a in candidates:
for b in candidates:
- print "cmp(%s, %s)" % (a, b),
try:
- x = cmp(a, b)
+ x = a == b
except:
- print '... %s' % sys.exc_info(0)
+ print 'cmp(%s, %s) => %s' % (a, b, sys.exc_info()[0])
else:
- print '=', x
+ if x:
+ print "%s == %s" % (a, b)
+ else:
+ print "%s != %s" % (a, b)
test()