]> granicus.if.org Git - python/commitdiff
Merged revisions 82404 via svnmerge from
authorGiampaolo Rodolà <g.rodola@gmail.com>
Wed, 30 Jun 2010 17:41:25 +0000 (17:41 +0000)
committerGiampaolo Rodolà <g.rodola@gmail.com>
Wed, 30 Jun 2010 17:41:25 +0000 (17:41 +0000)
svn+ssh://pythondev@svn.python.org/python/trunk

........
  r82404 | giampaolo.rodola | 2010-06-30 19:38:28 +0200 (mer, 30 giu 2010) | 1 line

  fix issue #6589: cleanup asyncore.socket_map if smtpd.SMTPServer constructor raises an exception
........

Lib/smtpd.py
Misc/NEWS

index 3992d7bb4e6cb7c7cd410e406dc97dae8810aa56..c3bd6a5addad35337be7323b10c5bffd61756829 100755 (executable)
@@ -274,15 +274,21 @@ class SMTPServer(asyncore.dispatcher):
         self._localaddr = localaddr
         self._remoteaddr = remoteaddr
         asyncore.dispatcher.__init__(self)
-        self.create_socket(socket.AF_INET, socket.SOCK_STREAM)
-        # try to re-use a server port if possible
-        self.set_reuse_addr()
-        self.bind(localaddr)
-        self.listen(5)
-        print >> DEBUGSTREAM, \
-              '%s started at %s\n\tLocal addr: %s\n\tRemote addr:%s' % (
-            self.__class__.__name__, time.ctime(time.time()),
-            localaddr, remoteaddr)
+        try:
+            self.create_socket(socket.AF_INET, socket.SOCK_STREAM)
+            # try to re-use a server port if possible
+            self.set_reuse_addr()
+            self.bind(localaddr)
+            self.listen(5)
+        except:
+            # cleanup asyncore.socket_map before raising
+            self.close()
+            raise
+        else:
+            print >> DEBUGSTREAM, \
+                  '%s started at %s\n\tLocal addr: %s\n\tRemote addr:%s' % (
+                self.__class__.__name__, time.ctime(time.time()),
+                localaddr, remoteaddr)
 
     def handle_accept(self):
         conn, addr = self.accept()
index bb74536df4dc972e291f140cf782c7ec5051c989..f876d3aab213128687c3052a8afd8b05bb5ad4ee 100644 (file)
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -73,6 +73,9 @@ C-API
 Library
 -------
 
+- Issue #6589: cleanup asyncore.socket_map in case smtpd.SMTPServer constructor 
+  raises an exception.
+
 - Issue #9125: Add recognition of 'except ... as ...' syntax to parser module.
 
 - Issue #9085: email package version number bumped to its correct