VMM/EmailAddress: reworked class EmailAddress again. v0.6.x
authorPascal Volk <neverseen@users.sourceforge.net>
Tue, 09 Feb 2010 22:14:08 +0000 (2010-02-09)
branchv0.6.x
changeset 195 05dd49fc3ea1
parent 194 6c06edb5b2d2
child 196 65a3163bd113
VMM/EmailAddress: reworked class EmailAddress again. The attributes domainname and localpart are now read-only.
VirtualMailManager/EmailAddress.py
--- a/VirtualMailManager/EmailAddress.py	Tue Feb 09 04:59:40 2010 +0000
+++ b/VirtualMailManager/EmailAddress.py	Tue Feb 09 22:14:08 2010 +0000
@@ -21,34 +21,44 @@
 
 class EmailAddress(object):
     """Simple class for validated e-mail addresses."""
-    __slots__ = ('localpart', 'domainname')
+    __slots__ = ('_localpart', '_domainname')
 
     def __init__(self, address):
         """Creates a new instance from the string/unicode ``address``."""
         if not isinstance(address, basestring):
             raise TypeError('address is not a str/unicode object: %r' %
                             address)
-        self.localpart = None
-        self.domainname = None
+        self._localpart = None
+        self._domainname = None
         self._chk_address(address)
 
+    @property
+    def localpart(self):
+        """The local-part of the address *local-part@domain*"""
+        return self._localpart
+
+    @property
+    def domainname(self):
+        """The domain part of the address *local-part@domain*"""
+        return self._domainname
+
     def __eq__(self, other):
         if isinstance(other, self.__class__):
-            return self.localpart == other.localpart and \
-                    self.domainname == other.domainname
+            return self._localpart == other.localpart and \
+                    self._domainname == other.domainname
         return NotImplemented
 
     def __ne__(self, other):
         if isinstance(other, self.__class__):
-            return self.localpart != other.localpart or \
-                    self.domainname != other.domainname
+            return self._localpart != other.localpart or \
+                    self._domainname != other.domainname
         return NotImplemented
 
     def __repr__(self):
-        return "EmailAddress('%s@%s')" % (self.localpart, self.domainname)
+        return "EmailAddress('%s@%s')" % (self._localpart, self._domainname)
 
     def __str__(self):
-        return "%s@%s" % (self.localpart, self.domainname)
+        return "%s@%s" % (self._localpart, self._domainname)
 
     def _chk_address(self, address):
         """Checks if the string ``address`` could be used for an e-mail
@@ -56,12 +66,12 @@
         parts = address.split('@')
         p_len = len(parts)
         if p_len is 2:
-            self.localpart = check_localpart(parts[0])
+            self._localpart = check_localpart(parts[0])
             if len(parts[1]) > 0:
-                self.domainname = chk_domainname(parts[1])
+                self._domainname = chk_domainname(parts[1])
             else:
                 raise VMMEAE(_(u"Missing domain name after ā€œ%s@ā€.") %
-                             self.localpart, DOMAIN_NO_NAME)
+                             self._localpart, DOMAIN_NO_NAME)
         elif p_len < 2:
             raise VMMEAE(_(u"Missing '@' sign in e-mail address ā€œ%sā€.") %
                          address, INVALID_ADDRESS)