[Bugfix] Properly report transport errors to GNUTLS.
Signed-off-by: Martin Koegler <mkoegler@auto.tuwien.ac.at>
git-svn-id: svn://svn.code.sf.net/p/tigervnc/code/trunk@4125 3789f03b-4d11-0410-bbf8-ca57d06f2519
diff --git a/common/rdr/TLSInStream.cxx b/common/rdr/TLSInStream.cxx
index f6bf334..faf548c 100644
--- a/common/rdr/TLSInStream.cxx
+++ b/common/rdr/TLSInStream.cxx
@@ -37,16 +37,22 @@
{
InStream* in= (InStream*) str;
- if (!in->check(1, 1, false)) {
- errno=EAGAIN;
+ try {
+ if (!in->check(1, 1, false)) {
+ gnutls_transport_set_global_errno(EAGAIN);
+ return -1;
+ }
+
+ if (in->getend() - in->getptr() < size)
+ size = in->getend() - in->getptr();
+
+ in->readBytes(data, size);
+
+ } catch (Exception& e) {
+ gnutls_transport_set_global_errno(EINVAL);
return -1;
}
- if (in->getend() - in->getptr() < size)
- size = in->getend() - in->getptr();
-
- in->readBytes(data, size);
-
return size;
}