From 44b769e497f9e972e398f98a3d80267ac03e3e1d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carlos=20Mart=C3=ADn=20Nieto?= Date: Mon, 13 Apr 2015 15:39:58 +0200 Subject: SecureTransport: handle graceful closes On close, we might get a return code which looks like an error but just means that the other side closed gracefully. Handle that. --- src/stransport_stream.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/stransport_stream.c b/src/stransport_stream.c index db993ffb7..429aa2d55 100644 --- a/src/stransport_stream.c +++ b/src/stransport_stream.c @@ -19,7 +19,7 @@ int stransport_error(OSStatus ret) { CFStringRef message; - if (ret == noErr) { + if (ret == noErr || ret == errSSLClosedGraceful) { giterr_clear(); return 0; } @@ -183,7 +183,8 @@ int stransport_close(git_stream *stream) stransport_stream *st = (stransport_stream *) stream; OSStatus ret; - if ((ret = SSLClose(st->ctx)) != noErr) + ret = SSLClose(st->ctx); + if (ret != noErr && ret != errSSLClosedGraceful) return stransport_error(ret); return git_stream_close(st->io); -- cgit v1.2.1