Show More
@@ -489,7 +489,12 b' class Client(HasTraits):' | |||
|
489 | 489 | } |
|
490 | 490 | self._queue_handlers = {'execute_reply' : self._handle_execute_reply, |
|
491 | 491 | 'apply_reply' : self._handle_apply_reply} |
|
492 | ||
|
493 | try: | |
|
492 | 494 | self._connect(sshserver, ssh_kwargs, timeout) |
|
495 | except: | |
|
496 | self.close(linger=0) | |
|
497 | raise | |
|
493 | 498 | |
|
494 | 499 | # last step: setup magics, if we are in IPython: |
|
495 | 500 | |
@@ -593,7 +598,6 b' class Client(HasTraits):' | |||
|
593 | 598 | self._connected=True |
|
594 | 599 | |
|
595 | 600 | def connect_socket(s, url): |
|
596 | # url = util.disambiguate_url(url, self._config['location']) | |
|
597 | 601 | if self._ssh: |
|
598 | 602 | return tunnel.tunnel_connection(s, url, sshserver, **ssh_kwargs) |
|
599 | 603 | else: |
@@ -950,13 +954,22 b' class Client(HasTraits):' | |||
|
950 | 954 | view.activate(suffix) |
|
951 | 955 | return view |
|
952 | 956 | |
|
953 | def close(self): | |
|
957 | def close(self, linger=None): | |
|
958 | """Close my zmq Sockets | |
|
959 | ||
|
960 | If `linger`, set the zmq LINGER socket option, | |
|
961 | which allows discarding of messages. | |
|
962 | """ | |
|
954 | 963 | if self._closed: |
|
955 | 964 | return |
|
956 | 965 | self.stop_spin_thread() |
|
957 | snames = filter(lambda n: n.endswith('socket'), dir(self)) | |
|
958 | for socket in map(lambda name: getattr(self, name), snames): | |
|
959 | if isinstance(socket, zmq.Socket) and not socket.closed: | |
|
966 | snames = [ trait for trait in self.trait_names() if trait.endswith("socket") ] | |
|
967 | for name in snames: | |
|
968 | socket = getattr(self, name) | |
|
969 | if socket is not None and not socket.closed: | |
|
970 | if linger is not None: | |
|
971 | socket.close(linger=linger) | |
|
972 | else: | |
|
960 | 973 | socket.close() |
|
961 | 974 | self._closed = True |
|
962 | 975 |
General Comments 0
You need to be logged in to leave comments.
Login now