From 1ef9bed7525cc60c9875ac9cbc0332ba2329c68d Mon Sep 17 00:00:00 2001 From: Michael Scherer Date: Fri, 1 Nov 2013 17:42:54 +0100 Subject: [PATCH] Try/finally is a python 2.5 construct, so not working on EL5. Fix #4763 --- library/utilities/accelerate | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/library/utilities/accelerate b/library/utilities/accelerate index c4d726e62a..59953da327 100644 --- a/library/utilities/accelerate +++ b/library/utilities/accelerate @@ -330,12 +330,12 @@ class ThreadedTCPRequestHandler(SocketServer.BaseRequestHandler): log("got a failed response from the master") return dict(failed=True, stderr="Master reported failure, aborting transfer") except Exception, e: + fd.close() tb = traceback.format_exc() log("failed to fetch the file: %s" % tb) return dict(failed=True, stderr="Could not fetch the file: %s" % str(e)) - finally: - fd.close() + fd.close() return dict() def put(self, data): @@ -373,12 +373,13 @@ class ThreadedTCPRequestHandler(SocketServer.BaseRequestHandler): data = self.server.key.Decrypt(data) data = json.loads(data) except: + out_fd.close() tb = traceback.format_exc() log("failed to put the file: %s" % tb) return dict(failed=True, stdout="Could not write the file") - finally: - vvvv("wrote %d bytes" % bytes) - out_fd.close() + + vvvv("wrote %d bytes" % bytes) + out_fd.close() if final_path: vvv("moving %s to %s" % (out_path, final_path))