summaryrefslogtreecommitdiffstats
path: root/Demo/classes/Complex.py
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1993-12-17 14:23:52 (GMT)
committerGuido van Rossum <guido@python.org>1993-12-17 14:23:52 (GMT)
commit7565b934144012f25e8b22d888572c048f0eb21a (patch)
tree1fe49e0e20f1201f97eb13596ef3c5f014d8182a /Demo/classes/Complex.py
parent3cbc16d9041fe1fa87356bdacc2f1ad52fb99a89 (diff)
downloadcpython-7565b934144012f25e8b22d888572c048f0eb21a.zip
cpython-7565b934144012f25e8b22d888572c048f0eb21a.tar.gz
cpython-7565b934144012f25e8b22d888572c048f0eb21a.tar.bz2
*** empty log message ***
Diffstat (limited to 'Demo/classes/Complex.py')
-rwxr-xr-xDemo/classes/Complex.py32
1 files changed, 22 insertions, 10 deletions
diff --git a/Demo/classes/Complex.py b/Demo/classes/Complex.py
index 5880c64..b7ba2e0 100755
--- a/Demo/classes/Complex.py
+++ b/Demo/classes/Complex.py
@@ -4,16 +4,21 @@
from math import sqrt
-def complex(re, im):
- return Complex().init(re, im)
+class complex:
-
-class Complex:
-
- def init(self, re, im):
+ def __init__(self, re, im):
self.re = float(re)
self.im = float(im)
- return self
+
+ def __coerce__(self, other):
+ if type(other) == type(self):
+ if other.__class__ == self.__class__:
+ return self, other
+ else:
+ raise TypeError, 'cannot coerce to complex'
+ else:
+ # The cast to float() may raise an exception!
+ return self, complex(float(other), 0.0)
def __repr__(self):
return 'complex' + `self.re, self.im`
@@ -60,9 +65,16 @@ class Complex:
def test():
a = complex(2, 0)
b = complex(3, 4)
- print a, b
- print a+b, a-b, a*b, a/b
- print b+a, b-a, b*a, b/a
+ print a
+ print b
+ print a+b
+ print a-b
+ print a*b
+ print a/b
+ print b+a
+ print b-a
+ print b*a
+ print b/a
i = complex(0, 1)
print i, i*i, i*i*i, i*i*i*i
j = complex(1, 1)