diff options
| author | Aldo Cortesi <aldo@nullcube.com> | 2016-06-12 11:17:05 +1200 | 
|---|---|---|
| committer | Aldo Cortesi <aldo@nullcube.com> | 2016-06-12 11:17:05 +1200 | 
| commit | dc545ca0f63b63c88dd5bf5d072a3d9b5cc2a2ea (patch) | |
| tree | 294986f989c5e4cdee4007e9cb1f9c74f849b6a5 /netlib | |
| parent | 9bea616441256e07495c5e5fd34f6a6673e05c52 (diff) | |
| download | mitmproxy-dc545ca0f63b63c88dd5bf5d072a3d9b5cc2a2ea.tar.gz mitmproxy-dc545ca0f63b63c88dd5bf5d072a3d9b5cc2a2ea.tar.bz2 mitmproxy-dc545ca0f63b63c88dd5bf5d072a3d9b5cc2a2ea.zip | |
Make the tcp connection closer cancellable
And use this to make pathoc error handling more sophisticated
Diffstat (limited to 'netlib')
| -rw-r--r-- | netlib/tcp.py | 30 | 
1 files changed, 21 insertions, 9 deletions
| diff --git a/netlib/tcp.py b/netlib/tcp.py index acd67cad..a8a68139 100644 --- a/netlib/tcp.py +++ b/netlib/tcp.py @@ -6,7 +6,6 @@ import sys  import threading  import time  import traceback -import contextlib  import binascii  from six.moves import range @@ -582,12 +581,24 @@ class _Connection(object):          return context -@contextlib.contextmanager -def _closer(client): -    try: -        yield -    finally: -        client.close() +class ConnectionCloser(object): +    def __init__(self, conn): +        self.conn = conn +        self._canceled = False + +    def pop(self): +        """ +            Cancel the current closer, and return a fresh one. +        """ +        self._canceled = True +        return ConnectionCloser(self.conn) + +    def __enter__(self): +        return self + +    def __exit__(self, *args): +        if not self._canceled: +            self.conn.close()  class TCPClient(_Connection): @@ -717,11 +728,12 @@ class TCPClient(_Connection):          except (socket.error, IOError) as err:              raise exceptions.TcpException(                  'Error connecting to "%s": %s' % -                (self.address.host, err)) +                (self.address.host, err) +            )          self.connection = connection          self.ip_address = Address(connection.getpeername())          self._makefile() -        return _closer(self) +        return ConnectionCloser(self)      def settimeout(self, n):          self.connection.settimeout(n) | 
